summaryrefslogtreecommitdiff
path: root/src/mesh/assimp-master/port/dAssimp/assimp/fileIO.d
diff options
context:
space:
mode:
Diffstat (limited to 'src/mesh/assimp-master/port/dAssimp/assimp/fileIO.d')
-rw-r--r--src/mesh/assimp-master/port/dAssimp/assimp/fileIO.d140
1 files changed, 140 insertions, 0 deletions
diff --git a/src/mesh/assimp-master/port/dAssimp/assimp/fileIO.d b/src/mesh/assimp-master/port/dAssimp/assimp/fileIO.d
new file mode 100644
index 0000000..108d883
--- /dev/null
+++ b/src/mesh/assimp-master/port/dAssimp/assimp/fileIO.d
@@ -0,0 +1,140 @@
+/*
+---------------------------------------------------------------------------
+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.
+---------------------------------------------------------------------------
+*/
+
+/**
+ * The data structures necessary to use Assimip with a custom IO system.
+ */
+module assimp.fileIO;
+
+import assimp.types;
+
+extern ( C ) {
+ // aiFile callbacks
+ alias size_t function( aiFile*, char*, size_t, size_t ) aiFileWriteProc;
+ alias size_t function( aiFile*, char*, size_t, size_t ) aiFileReadProc;
+ alias size_t function( aiFile* ) aiFileTellProc;
+ alias void function( aiFile* ) aiFileFlushProc;
+ alias aiReturn function( aiFile*, size_t, aiOrigin ) aiFileSeek;
+
+ // aiFileIO callbacks
+ alias aiFile* function( aiFileIO*, char*, char* ) aiFileOpenProc;
+ alias void function( aiFileIO*, aiFile* ) aiFileCloseProc;
+
+ /**
+ * Represents user-defined data.
+ */
+ alias char* aiUserData;
+
+ /**
+ * File system callbacks.
+ *
+ * Provided are functions to open and close files. Supply a custom structure
+ * to the import function. If you don't, a default implementation is used.
+ * Use custom file systems to enable reading from other sources, such as
+ * ZIPs or memory locations.
+ */
+ struct aiFileIO {
+ /**
+ * Function used to open a new file
+ */
+ aiFileOpenProc OpenProc;
+
+ /**
+ * Function used to close an existing file
+ */
+ aiFileCloseProc CloseProc;
+
+ /**
+ * User-defined, opaque data.
+ */
+ aiUserData UserData;
+ }
+
+ /**
+ * File callbacks.
+ *
+ * Actually, it's a data structure to wrap a set of <code>fXXXX</code>
+ * (e.g <code>fopen()</code>) replacement functions.
+ *
+ * The default implementation of the functions utilizes the <code>fXXX</code>
+ * functions from the CRT. However, you can supply a custom implementation
+ * to Assimp by passing a custom <code>aiFileIO</code>. Use this to enable
+ * reading from other sources such as ZIP archives or memory locations.
+ */
+ struct aiFile {
+ /**
+ * Callback to read from a file.
+ */
+ aiFileReadProc ReadProc;
+
+ /**
+ * Callback to write to a file.
+ */
+ aiFileWriteProc WriteProc;
+
+ /**
+ * Callback to retrieve the current position of the file cursor
+ * (<code>ftell()</code>).
+ */
+ aiFileTellProc TellProc;
+
+ /**
+ * Callback to retrieve the size of the file, in bytes.
+ */
+ aiFileTellProc FileSizeProc;
+
+ /**
+ * Callback to set the current position of the file cursor
+ * (<code>fseek()</code>).
+ */
+ aiFileSeek SeekProc;
+
+ /**
+ * Callback to flush the file contents.
+ */
+ aiFileFlushProc FlushProc;
+
+ /**
+ * User-defined, opaque data.
+ */
+ aiUserData UserData;
+ }
+}