diff options
author | sanine <sanine.not@pm.me> | 2022-04-16 11:55:54 -0500 |
---|---|---|
committer | sanine <sanine.not@pm.me> | 2022-04-16 11:55:54 -0500 |
commit | 8fb7916a0d0cb007a4c3a4e6a31af58765268ca3 (patch) | |
tree | 52b5524a94a5b04e17a1fd7f8aca988ab6d0c75f /src/mesh/assimp-master/port/dAssimp/assimp/loader.d | |
parent | db81b925d776103326128bf629cbdda576a223e7 (diff) |
delete src/mesh/assimp-master
Diffstat (limited to 'src/mesh/assimp-master/port/dAssimp/assimp/loader.d')
-rw-r--r-- | src/mesh/assimp-master/port/dAssimp/assimp/loader.d | 193 |
1 files changed, 0 insertions, 193 deletions
diff --git a/src/mesh/assimp-master/port/dAssimp/assimp/loader.d b/src/mesh/assimp-master/port/dAssimp/assimp/loader.d deleted file mode 100644 index 279f0a7..0000000 --- a/src/mesh/assimp-master/port/dAssimp/assimp/loader.d +++ /dev/null @@ -1,193 +0,0 @@ -/* ---------------------------------------------------------------------------- -Open Asset Import Library (ASSIMP) ---------------------------------------------------------------------------- - -Copyright (c) 2006-2020, ASSIMP Development Team - -All rights reserved. - -Redistribution and use of this software in source and binary forms, -with or without modification, are permitted provided that the following -conditions are met: - - * Redistributions of source code must retain the above - copyright notice, this list of conditions and the - following disclaimer. - - * Redistributions in binary form must reproduce the above - copyright notice, this list of conditions and the - following disclaimer in the documentation and/or other - materials provided with the distribution. - - * Neither the name of the ASSIMP team, nor the names of its - contributors may be used to endorse or promote products - derived from this software without specific prior - written permission of the ASSIMP Development Team. - -THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS -"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT -LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR -A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT -OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, -SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE -OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ---------------------------------------------------------------------------- -*/ - -/** - * Provides facilities for dynamically loading the Assimp library. - * - * Currently requires Tango, but there is no reason why Phobos could not be - * supported too. - */ -module assimp.loader; - -import assimp.api; -import tango.io.Stdout; -import tango.sys.SharedLib; - -const uint ASSIMP_BINDINGS_MAJOR = 2; -const uint ASSIMP_BINDINGS_MINOR = 0; - -/** - * Loader class for dynamically loading the Assimp library. - * - * The library is »reference-counted«, meaning that the library is not - * unloaded on a call to <code>unload()</code> if there are still other - * references to it. - */ -struct Assimp { -public: - /** - * Loads the library if it is not already loaded and increases the - * reference counter. - * - * The library file (<code>libassimp.so</code> on POSIX systems, - * <code>Assimp32.dll</code> on Win32) is loaded via Tango's SharedLib - * class. - */ - static void load() { - if ( m_sRefCount == 0 ) { - version ( Posix ) { - version ( OSX ) { - m_sLibrary = SharedLib.load( "libassimp.dylib" ); - } else { - m_sLibrary = SharedLib.load( "libassimp.so" ); - } - } - version ( Win32 ) { - m_sLibrary = SharedLib.load( "Assimp32.dll" ); - } - - // Versioning - mixin( bindCode( "aiGetLegalString" ) ); - mixin( bindCode( "aiGetVersionMinor" ) ); - mixin( bindCode( "aiGetVersionMajor" ) ); - mixin( bindCode( "aiGetVersionRevision" ) ); - mixin( bindCode( "aiGetCompileFlags" ) ); - - // Check for version mismatch between the external, dynamically loaded - // library and the version the bindings were created against. - uint libMajor = aiGetVersionMajor(); - uint libMinor = aiGetVersionMinor(); - - if ( ( libMajor < ASSIMP_BINDINGS_MAJOR ) || - ( libMinor < ASSIMP_BINDINGS_MINOR ) ) { - Stdout.format( - "WARNING: Assimp version too old (loaded library: {}.{}, " ~ - "bindings: {}.{})!", - libMajor, - libMinor, - ASSIMP_BINDINGS_MAJOR, - ASSIMP_BINDINGS_MINOR - ).newline; - } - - if ( libMajor > ASSIMP_BINDINGS_MAJOR ) { - Stdout.format( - "WARNING: Assimp version too new (loaded library: {}.{}, " ~ - "bindings: {}.{})!", - libMajor, - libMinor, - ASSIMP_BINDINGS_MAJOR, - ASSIMP_BINDINGS_MINOR - ).newline; - } - - // General API - mixin( bindCode( "aiImportFile" ) ); - mixin( bindCode( "aiImportFileEx" ) ); - mixin( bindCode( "aiImportFileFromMemory" ) ); - mixin( bindCode( "aiApplyPostProcessing" ) ); - mixin( bindCode( "aiGetPredefinedLogStream" ) ); - mixin( bindCode( "aiAttachLogStream" ) ); - mixin( bindCode( "aiEnableVerboseLogging" ) ); - mixin( bindCode( "aiDetachLogStream" ) ); - mixin( bindCode( "aiDetachAllLogStreams" ) ); - mixin( bindCode( "aiReleaseImport" ) ); - mixin( bindCode( "aiGetErrorString" ) ); - mixin( bindCode( "aiIsExtensionSupported" ) ); - mixin( bindCode( "aiGetExtensionList" ) ); - mixin( bindCode( "aiGetMemoryRequirements" ) ); - mixin( bindCode( "aiSetImportPropertyInteger" ) ); - mixin( bindCode( "aiSetImportPropertyFloat" ) ); - mixin( bindCode( "aiSetImportPropertyString" ) ); - - // Mathematical functions - mixin( bindCode( "aiCreateQuaternionFromMatrix" ) ); - mixin( bindCode( "aiDecomposeMatrix" ) ); - mixin( bindCode( "aiTransposeMatrix4" ) ); - mixin( bindCode( "aiTransposeMatrix3" ) ); - mixin( bindCode( "aiTransformVecByMatrix3" ) ); - mixin( bindCode( "aiTransformVecByMatrix4" ) ); - mixin( bindCode( "aiMultiplyMatrix4" ) ); - mixin( bindCode( "aiMultiplyMatrix3" ) ); - mixin( bindCode( "aiIdentityMatrix3" ) ); - mixin( bindCode( "aiIdentityMatrix4" ) ); - - // Material system - mixin( bindCode( "aiGetMaterialProperty" ) ); - mixin( bindCode( "aiGetMaterialFloatArray" ) ); - mixin( bindCode( "aiGetMaterialIntegerArray" ) ); - mixin( bindCode( "aiGetMaterialColor" ) ); - mixin( bindCode( "aiGetMaterialString" ) ); - mixin( bindCode( "aiGetMaterialTextureCount" ) ); - mixin( bindCode( "aiGetMaterialTexture" ) ); - } - ++m_sRefCount; - } - - /** - * Decreases the reference counter and unloads the library if this was the - * last reference. - */ - static void unload() { - assert( m_sRefCount > 0 ); - --m_sRefCount; - - if ( m_sRefCount == 0 ) { - m_sLibrary.unload(); - } - } - -private: - /// Current number of references to the library. - static uint m_sRefCount; - - /// Library handle. - static SharedLib m_sLibrary; -} - -/** - * Private helper function which constructs the bind command for a symbol to - * keep the code DRY. - */ -private char[] bindCode( char[] symbol ) { - return symbol ~ " = cast( typeof( " ~ symbol ~ - " ) )m_sLibrary.getSymbol( `" ~ symbol ~ "` );"; -} |