2008-06-15 10:27:08 +00:00
|
|
|
/*
|
|
|
|
Open Asset Import Library (ASSIMP)
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
|
2010-04-10 15:30:22 +00:00
|
|
|
Copyright (c) 2006-2010, ASSIMP Development Team
|
2008-06-15 10:27:08 +00:00
|
|
|
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.
|
|
|
|
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
/** @file Definition of platform independent string workers:
|
2008-06-15 10:27:08 +00:00
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
ASSIMP_itoa10
|
|
|
|
ASSIMP_stricmp
|
|
|
|
ASSIMP_strincmp
|
2008-06-15 10:27:08 +00:00
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
These functions are not consistently available on all platforms,
|
|
|
|
or the provided implementations behave too differently.
|
|
|
|
*/
|
|
|
|
#ifndef INCLUDED_AI_STRING_WORKERS_H
|
|
|
|
#define INCLUDED_AI_STRING_WORKERS_H
|
|
|
|
|
|
|
|
namespace Assimp {
|
|
|
|
|
|
|
|
// -------------------------------------------------------------------------------
|
|
|
|
/** @brief itoa with a fixed base 10
|
|
|
|
* 'itoa' is not consistently available on all platforms so it is quite useful
|
|
|
|
* to have a small replacement function here. No need to use a full sprintf()
|
|
|
|
* if we just want to print a number ...
|
|
|
|
* @param out Output buffer
|
2010-05-20 12:07:04 +00:00
|
|
|
* @param max Maximum number of characters to be written, including '\0'.
|
|
|
|
* This parameter may not be 0.
|
2009-01-12 22:06:54 +00:00
|
|
|
* @param number Number to be written
|
2010-05-20 12:07:04 +00:00
|
|
|
* @return Length of the output string, excluding the '\0'
|
2009-01-12 22:06:54 +00:00
|
|
|
*/
|
|
|
|
inline unsigned int ASSIMP_itoa10( char* out, unsigned int max, int32_t number)
|
2008-10-22 20:06:16 +00:00
|
|
|
{
|
|
|
|
ai_assert(NULL != out);
|
|
|
|
|
|
|
|
// write the unary minus to indicate we have a negative number
|
|
|
|
unsigned int written = 1u;
|
2010-05-14 12:27:29 +00:00
|
|
|
if (number < 0 && written < max) {
|
2008-10-22 20:06:16 +00:00
|
|
|
*out++ = '-';
|
|
|
|
++written;
|
2010-05-14 12:27:29 +00:00
|
|
|
number = -number;
|
2008-10-22 20:06:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// We begin with the largest number that is not zero.
|
|
|
|
int32_t cur = 1000000000; // 2147483648
|
|
|
|
bool mustPrint = false;
|
2010-05-14 12:27:29 +00:00
|
|
|
while (written < max) {
|
|
|
|
|
|
|
|
const unsigned int digit = number / cur;
|
|
|
|
if (mustPrint || digit > 0 || 1 == cur) {
|
|
|
|
// print all future zeroes from now
|
2008-10-22 20:06:16 +00:00
|
|
|
mustPrint = true;
|
2010-05-14 12:27:29 +00:00
|
|
|
|
|
|
|
*out++ = '0'+digit;
|
2008-10-22 20:06:16 +00:00
|
|
|
|
|
|
|
++written;
|
General
- Added format auto-detection to most loaders
- Simplified BaseImporter::CanRead() with some utility methods
- improved fast_atof -> no overruns anymore. Fuck you, irrlicht.
- added assimp_cmd tool to allow command line model processing. Mainly adebugging tool for internal purposes, but others might find it useful, too.
- vc8/vc9: revision number is now written to DLL version header
- mkutil: some batch scripts to simplify tagging & building of release versions
- some API cleanup
- fixing some doxygen markup (+now explicit use of @file <filename>)
- Icon for assimp_view and assimp_cmd
3DS
- Normal vectors are not anymore inverted in some cases
- Improved pivot handling
- Improved handling of x-flipped meshes
Collada
- fixed a minor bug (visual_scene element)
LWS
- WIP implementation. No animations yet, some bugs and crashes.
- Animation system remains disabled, WIP code
- many test files for LWS, but most of them test the anim support, which is, read above, currently disabled.
STL
- fixing a log warning which appears for every model
- added binary&ascii test spider, exported from truespace
MD3
- Cleaning up output tags for automatically joined player models.
IRR
- Fixing coordinate system issues.
- Instance handling improved.
- Some of the reported crashes not yet fixed.
PretransformVertices
- Numerous performance improvements.
- Added config option to preserve the hierarchy during the step.
RemoveRedundantMaterials
- Added config option to specify a list of materials which are kept in every case.
UNREAL
- Added support for the old unreal data format (*.a,*.d,*.uc)
- tested only with exports from Milkshape
- more Unreal stuff to come soon
git-svn-id: https://assimp.svn.sourceforge.net/svnroot/assimp/trunk@356 67173fc5-114c-0410-ac8e-9d2fd5bffc1f
2009-03-05 22:32:13 +00:00
|
|
|
number -= digit*cur;
|
2010-05-14 12:27:29 +00:00
|
|
|
if (1 == cur) {
|
|
|
|
break;
|
|
|
|
}
|
2008-10-22 20:06:16 +00:00
|
|
|
}
|
|
|
|
cur /= 10;
|
|
|
|
}
|
|
|
|
|
|
|
|
// append a terminal zero
|
|
|
|
*out++ = '\0';
|
2010-05-20 12:07:04 +00:00
|
|
|
return written-1;
|
2008-10-22 20:06:16 +00:00
|
|
|
}
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// -------------------------------------------------------------------------------
|
|
|
|
/** @brief itoa with a fixed base 10 (Secure template overload)
|
2010-05-20 12:07:04 +00:00
|
|
|
* The compiler should choose this function if he or she is able to determine the
|
2009-01-12 22:06:54 +00:00
|
|
|
* size of the array automatically.
|
|
|
|
*/
|
2010-05-20 12:07:04 +00:00
|
|
|
template <size_t length>
|
2009-01-12 22:06:54 +00:00
|
|
|
inline unsigned int ASSIMP_itoa10( char(& out)[length], int32_t number)
|
2008-10-22 20:06:16 +00:00
|
|
|
{
|
2009-01-12 22:06:54 +00:00
|
|
|
return ASSIMP_itoa10(out,length,number);
|
2008-10-22 20:06:16 +00:00
|
|
|
}
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// -------------------------------------------------------------------------------
|
|
|
|
/** @brief Helper function to do platform independent string comparison.
|
2008-06-15 10:27:08 +00:00
|
|
|
*
|
|
|
|
* This is required since stricmp() is not consistently available on
|
|
|
|
* all platforms. Some platforms use the '_' prefix, others don't even
|
2008-09-30 20:20:56 +00:00
|
|
|
* have such a function.
|
2008-06-15 10:27:08 +00:00
|
|
|
*
|
2009-01-12 22:06:54 +00:00
|
|
|
* @param s1 First input string
|
|
|
|
* @param s2 Second input string
|
|
|
|
* @return 0 if the given strings are identical
|
2008-06-15 10:27:08 +00:00
|
|
|
*/
|
|
|
|
inline int ASSIMP_stricmp(const char *s1, const char *s2)
|
|
|
|
{
|
2009-01-12 22:06:54 +00:00
|
|
|
ai_assert(NULL != s1 && NULL != s2);
|
|
|
|
|
2008-06-15 10:27:08 +00:00
|
|
|
#if (defined _MSC_VER)
|
|
|
|
|
|
|
|
return ::_stricmp(s1,s2);
|
|
|
|
|
2008-11-28 23:02:27 +00:00
|
|
|
#elif defined( __GNUC__ )
|
|
|
|
|
|
|
|
return ::strcasecmp(s1,s2);
|
|
|
|
|
2008-06-15 10:27:08 +00:00
|
|
|
#else
|
2008-10-13 16:45:48 +00:00
|
|
|
register char c1, c2;
|
|
|
|
do
|
2008-06-15 10:27:08 +00:00
|
|
|
{
|
2008-10-13 16:45:48 +00:00
|
|
|
c1 = tolower(*s1++);
|
|
|
|
c2 = tolower(*s2++);
|
|
|
|
}
|
|
|
|
while ( c1 && (c1 == c2) );
|
|
|
|
|
|
|
|
return c1 - c2;
|
2008-06-15 10:27:08 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// -------------------------------------------------------------------------------
|
|
|
|
/** @brief Case independent comparison of two std::strings
|
|
|
|
*
|
|
|
|
* @param a First string
|
|
|
|
* @param b Second string
|
|
|
|
* @return 0 if a == b
|
2008-10-22 20:06:16 +00:00
|
|
|
*/
|
2008-08-13 15:45:57 +00:00
|
|
|
inline int ASSIMP_stricmp(const std::string& a, const std::string& b)
|
|
|
|
{
|
2008-10-13 16:45:48 +00:00
|
|
|
register int i = (int)b.length()-(int)a.length();
|
|
|
|
return (i ? i : ASSIMP_stricmp(a.c_str(),b.c_str()));
|
2008-08-13 15:45:57 +00:00
|
|
|
}
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// -------------------------------------------------------------------------------
|
|
|
|
/** @brief Helper function to do platform independent string comparison.
|
2008-06-15 10:27:08 +00:00
|
|
|
*
|
|
|
|
* This is required since strincmp() is not consistently available on
|
|
|
|
* all platforms. Some platforms use the '_' prefix, others don't even
|
2008-09-30 20:20:56 +00:00
|
|
|
* have such a function.
|
2008-06-15 10:27:08 +00:00
|
|
|
*
|
2009-01-12 22:06:54 +00:00
|
|
|
* @param s1 First input string
|
|
|
|
* @param s2 Second input string
|
|
|
|
* @param n Macimum number of characters to compare
|
|
|
|
* @return 0 if the given strings are identical
|
2008-06-15 10:27:08 +00:00
|
|
|
*/
|
|
|
|
inline int ASSIMP_strincmp(const char *s1, const char *s2, unsigned int n)
|
|
|
|
{
|
2009-01-12 22:06:54 +00:00
|
|
|
ai_assert(NULL != s1 && NULL != s2);
|
|
|
|
if (!n)return 0;
|
|
|
|
|
2008-06-15 10:27:08 +00:00
|
|
|
#if (defined _MSC_VER)
|
|
|
|
|
|
|
|
return ::_strnicmp(s1,s2,n);
|
|
|
|
|
2008-11-28 23:02:27 +00:00
|
|
|
#elif defined( __GNUC__ )
|
|
|
|
|
|
|
|
return ::strncasecmp(s1,s2, n);
|
|
|
|
|
2008-06-15 10:27:08 +00:00
|
|
|
#else
|
2008-10-13 16:45:48 +00:00
|
|
|
register char c1, c2;
|
2008-06-15 10:27:08 +00:00
|
|
|
unsigned int p = 0;
|
2008-10-13 16:45:48 +00:00
|
|
|
do
|
2008-06-15 10:27:08 +00:00
|
|
|
{
|
2008-10-13 16:45:48 +00:00
|
|
|
if (p++ >= n)return 0;
|
|
|
|
c1 = tolower(*s1++);
|
|
|
|
c2 = tolower(*s2++);
|
|
|
|
}
|
|
|
|
while ( c1 && (c1 == c2) );
|
|
|
|
|
|
|
|
return c1 - c2;
|
2008-06-15 10:27:08 +00:00
|
|
|
#endif
|
|
|
|
}
|
2008-11-28 23:02:27 +00:00
|
|
|
|
|
|
|
|
2009-01-12 22:06:54 +00:00
|
|
|
// -------------------------------------------------------------------------------
|
|
|
|
/** @brief Evaluates an integer power
|
|
|
|
*
|
|
|
|
* todo: move somewhere where it fits better in than here
|
|
|
|
*/
|
2008-11-28 23:02:27 +00:00
|
|
|
inline unsigned int integer_pow (unsigned int base, unsigned int power)
|
|
|
|
{
|
|
|
|
unsigned int res = 1;
|
|
|
|
for (unsigned int i = 0; i < power;++i)
|
|
|
|
res *= base;
|
|
|
|
|
|
|
|
return res;
|
2008-08-13 15:45:57 +00:00
|
|
|
}
|
2008-11-28 23:02:27 +00:00
|
|
|
} // end of namespace
|
2008-06-15 10:27:08 +00:00
|
|
|
|
|
|
|
#endif // ! AI_STRINGCOMPARISON_H_INC
|