From f45aeca3f670b40da8f48598ea479f20e41f7eaf Mon Sep 17 00:00:00 2001 From: Kim Kulling Date: Tue, 22 Nov 2016 21:17:47 +0100 Subject: [PATCH 01/10] Fix build: use ai_assert instead of assert. --- code/Assimp.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/code/Assimp.cpp b/code/Assimp.cpp index c28da95ee..092c40979 100644 --- a/code/Assimp.cpp +++ b/code/Assimp.cpp @@ -150,7 +150,7 @@ void ReportSceneNotFoundError() DefaultLogger::get()->error("Unable to find the Assimp::Importer for this aiScene. " "The C-API does not accept scenes produced by the C++ API and vice versa"); - assert(false); + ai_assert(false); } // ------------------------------------------------------------------------------------------------ From d87400b76aac7cb6aa60eb4867e7a94f00f0f416 Mon Sep 17 00:00:00 2001 From: Kim Kulling Date: Wed, 23 Nov 2016 20:20:11 +0100 Subject: [PATCH 02/10] Fix some findings in animation header. --- code/ColladaParser.cpp | 1 - code/ColladaParser.h | 3 +- include/assimp/anim.h | 89 ++++++++++++++++++++++-------------------- test/CMakeLists.txt | 1 + test/unit/utAnim.cpp | 75 +++++++++++++++++++++++++++++++++++ 5 files changed, 124 insertions(+), 45 deletions(-) create mode 100644 test/unit/utAnim.cpp diff --git a/code/ColladaParser.cpp b/code/ColladaParser.cpp index 1fd762e40..6257771e6 100644 --- a/code/ColladaParser.cpp +++ b/code/ColladaParser.cpp @@ -59,7 +59,6 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. #include - using namespace Assimp; using namespace Assimp::Collada; using namespace Assimp::Formatter; diff --git a/code/ColladaParser.h b/code/ColladaParser.h index 645ef0dc2..5aa724063 100644 --- a/code/ColladaParser.h +++ b/code/ColladaParser.h @@ -268,8 +268,7 @@ namespace Assimp Collada::InputType GetTypeForSemantic( const std::string& pSemantic); /** Finds the item in the given library by its reference, throws if not found */ - template const Type& ResolveLibraryReference( - const std::map& pLibrary, const std::string& pURL) const; + template const Type& ResolveLibraryReference( const std::map& pLibrary, const std::string& pURL) const; protected: /** Filename, for a verbose error message */ diff --git a/include/assimp/anim.h b/include/assimp/anim.h index 6380b4650..f2ace4416 100644 --- a/include/assimp/anim.h +++ b/include/assimp/anim.h @@ -39,16 +39,17 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. --------------------------------------------------------------------------- */ -/** @file anim.h - * @brief Defines the data structures in which the imported animations - * are returned. - */ +/** + * @file anim.h + * @brief Defines the data structures in which the imported animations + * are returned. + */ #pragma once #ifndef AI_ANIM_H_INC #define AI_ANIM_H_INC -#include "types.h" -#include "quaternion.h" +#include +#include #ifdef __cplusplus extern "C" { @@ -66,16 +67,20 @@ struct aiVectorKey #ifdef __cplusplus - //! Default constructor - aiVectorKey(){} + /// @brief The default constructor. + aiVectorKey() + : mTime( 0.0 ) + , mValue() { + // empty + } + + /// @brief Construction from a given time and key value. - //! Construction from a given time and key value aiVectorKey(double time, const aiVector3D& value) : mTime (time) , mValue (value) {} - typedef aiVector3D elem_type; // Comparison operators. For use with std::find(); @@ -93,7 +98,7 @@ struct aiVectorKey bool operator > (const aiVectorKey& o) const { return mTime > o.mTime; } -#endif +#endif // __cplusplus }; // --------------------------------------------------------------------------- @@ -108,7 +113,10 @@ struct aiQuatKey C_STRUCT aiQuaternion mValue; #ifdef __cplusplus - aiQuatKey(){ + aiQuatKey() + : mTime( 0.0 ) + , mValue() { + // empty } /** Construction from a given time and key value */ @@ -145,7 +153,7 @@ struct aiMeshKey double mTime; /** Index into the aiMesh::mAnimMeshes array of the - * mesh coresponding to the #aiMeshAnim hosting this + * mesh corresponding to the #aiMeshAnim hosting this * key frame. The referenced anim mesh is evaluated * according to the rules defined in the docs for #aiAnimMesh.*/ unsigned int mValue; @@ -204,8 +212,6 @@ enum aiAnimBehaviour * time is t, use the value at (t-n) % (|m-n|).*/ aiAnimBehaviour_REPEAT = 0x3, - - /** This value is not used, it is just here to force the * the compiler to map this enum to a 32 Bit integer */ #ifndef SWIG @@ -228,8 +234,7 @@ enum aiAnimBehaviour * Duplicate keys don't pass the validation step. Most likely there * will be no negative time values, but they are not forbidden also ( so * implementations need to cope with them! ) */ -struct aiNodeAnim -{ +struct aiNodeAnim { /** The name of the node affected by this animation. The node * must exist and it must be unique.*/ C_STRUCT aiString mNodeName; @@ -280,17 +285,17 @@ struct aiNodeAnim C_ENUM aiAnimBehaviour mPostState; #ifdef __cplusplus - aiNodeAnim() - { - mNumPositionKeys = 0; mPositionKeys = NULL; - mNumRotationKeys = 0; mRotationKeys = NULL; - mNumScalingKeys = 0; mScalingKeys = NULL; - + aiNodeAnim() + : mNumPositionKeys( 0 ) + , mPositionKeys( NULL ) + , mNumRotationKeys( 0 ) + , mRotationKeys( NULL ) + , mNumScalingKeys( 0 ) + , mScalingKeys( NULL ) { mPreState = mPostState = aiAnimBehaviour_DEFAULT; } - ~aiNodeAnim() - { + ~aiNodeAnim() { delete [] mPositionKeys; delete [] mRotationKeys; delete [] mScalingKeys; @@ -308,7 +313,7 @@ struct aiMeshAnim { /** Name of the mesh to be animated. An empty string is not allowed, * animated meshes need to be named (not necessarily uniquely, - * the name can basically serve as wildcard to select a group + * the name can basically serve as wild-card to select a group * of meshes with similar animation setup)*/ C_STRUCT aiString mName; @@ -334,10 +339,9 @@ struct aiMeshAnim }; // --------------------------------------------------------------------------- -/** An animation consists of keyframe data for a number of nodes. For +/** An animation consists of key-frame data for a number of nodes. For * each node affected by the animation a separate series of data is given.*/ -struct aiAnimation -{ +struct aiAnimation { /** The name of the animation. If the modeling package this data was * exported from does support only a single animation channel, this * name is usually empty (length is zero). */ @@ -385,14 +389,14 @@ struct aiAnimation delete mChannels[a]; } - delete [] mChannels; + delete [] mChannels; } if (mNumMeshChannels && mMeshChannels) { for( unsigned int a = 0; a < mNumMeshChannels; a++) { delete mMeshChannels[a]; } - delete [] mMeshChannels; + delete [] mMeshChannels; } } #endif // __cplusplus @@ -401,15 +405,16 @@ struct aiAnimation #ifdef __cplusplus } - -// some C++ utilities for inter- and extrapolation +/// @brief Some C++ utilities for inter- and extrapolation namespace Assimp { // --------------------------------------------------------------------------- -/** @brief CPP-API: Utility class to simplify interpolations of various data types. - * - * The type of interpolation is chosen automatically depending on the - * types of the arguments. */ +/** + * @brief CPP-API: Utility class to simplify interpolations of various data types. + * + * The type of interpolation is chosen automatically depending on the + * types of the arguments. + */ template struct Interpolator { @@ -445,7 +450,7 @@ struct Interpolator { }; // ! Interpolator template <> -struct Interpolator { +struct Interpolator { void operator () (aiVector3D& out,const aiVectorKey& a, const aiVectorKey& b, ai_real d) const { @@ -455,7 +460,7 @@ struct Interpolator { }; // ! Interpolator template <> -struct Interpolator { +struct Interpolator { void operator () (aiQuaternion& out, const aiQuatKey& a, const aiQuatKey& b, ai_real d) const { @@ -465,7 +470,7 @@ struct Interpolator { }; // ! Interpolator template <> -struct Interpolator { +struct Interpolator { void operator () (unsigned int& out, const aiMeshKey& a, const aiMeshKey& b, ai_real d) const { @@ -475,9 +480,9 @@ struct Interpolator { }; // ! Interpolator //! @endcond + } // ! end namespace Assimp - - #endif // __cplusplus + #endif // AI_ANIM_H_INC diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index 5a76016fd..c97480ccd 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -56,6 +56,7 @@ SOURCE_GROUP( unit FILES SET( TEST_SRCS unit/TestIOSystem.h + unit/utAnim.cpp unit/AssimpAPITest.cpp unit/utBatchLoader.cpp unit/utBlenderIntermediate.cpp diff --git a/test/unit/utAnim.cpp b/test/unit/utAnim.cpp new file mode 100644 index 000000000..f2db2c251 --- /dev/null +++ b/test/unit/utAnim.cpp @@ -0,0 +1,75 @@ +/* +--------------------------------------------------------------------------- +Open Asset Import Library (assimp) +--------------------------------------------------------------------------- + +Copyright (c) 2006-2016, assimp 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 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. +--------------------------------------------------------------------------- +*/ +#include "UnitTestPCH.h" + +#include + +using namespace Assimp; + +class utAnim : public ::testing::Test { + // empty +}; + +TEST_F( utAnim, aiVectorKeyCreationTest ) { + aiVectorKey defaultConstTest; + EXPECT_DOUBLE_EQ( 0.0, defaultConstTest.mTime ); + + aiVector3D v( 1, 2, 3 ); + aiVectorKey constrWithValuesTest( 1, v ); + EXPECT_DOUBLE_EQ( 1.0, constrWithValuesTest.mTime ); + EXPECT_EQ( v, constrWithValuesTest.mValue ); + + EXPECT_NE( defaultConstTest, constrWithValuesTest ); + EXPECT_TRUE( defaultConstTest != constrWithValuesTest ); + defaultConstTest.mTime = 1; + constrWithValuesTest.mTime = 2; + EXPECT_TRUE( defaultConstTest < constrWithValuesTest ); +} + +TEST_F( utAnim, aiQuatKeyTest ) { + aiQuatKey defaultConstrTest; + EXPECT_DOUBLE_EQ( 0.0, defaultConstrTest.mTime ); + + aiQuaternion q; + aiQuatKey constrWithValuesTest( 1.0, q ); + EXPECT_DOUBLE_EQ( 1.0, constrWithValuesTest.mTime ); + EXPECT_EQ( q, constrWithValuesTest.mValue ); +} \ No newline at end of file From 1939aca31c3dbd319939eabc2dd47ca0a097bf73 Mon Sep 17 00:00:00 2001 From: Kim Kulling Date: Wed, 23 Nov 2016 22:00:52 +0100 Subject: [PATCH 03/10] anim-header: fix some review findings + andd base tests. --- include/assimp/anim.h | 28 +++++++++++++++------------- test/unit/utAnim.cpp | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 47 insertions(+), 13 deletions(-) diff --git a/include/assimp/anim.h b/include/assimp/anim.h index f2ace4416..2a0b0e06e 100644 --- a/include/assimp/anim.h +++ b/include/assimp/anim.h @@ -291,8 +291,10 @@ struct aiNodeAnim { , mNumRotationKeys( 0 ) , mRotationKeys( NULL ) , mNumScalingKeys( 0 ) - , mScalingKeys( NULL ) { - mPreState = mPostState = aiAnimBehaviour_DEFAULT; + , mScalingKeys( NULL ) + , mPreState( aiAnimBehaviour_DEFAULT ) + , mPostState( aiAnimBehaviour_DEFAULT ) { + // empty } ~aiNodeAnim() { @@ -372,21 +374,20 @@ struct aiAnimation { #ifdef __cplusplus aiAnimation() - : mDuration(-1.) - , mTicksPerSecond() - , mNumChannels() - , mChannels() - , mNumMeshChannels() - , mMeshChannels() - { + : mDuration(-1.) + , mTicksPerSecond(0.) + , mNumChannels(0) + , mChannels(nullptr) + , mNumMeshChannels(0) + , mMeshChannels(nullptr) { + // empty } - ~aiAnimation() - { + ~aiAnimation() { // DO NOT REMOVE THIS ADDITIONAL CHECK - if (mNumChannels && mChannels) { + if ( mNumChannels && mChannels ) { for( unsigned int a = 0; a < mNumChannels; a++) { - delete mChannels[a]; + delete mChannels[ a ]; } delete [] mChannels; @@ -403,6 +404,7 @@ struct aiAnimation { }; #ifdef __cplusplus + } /// @brief Some C++ utilities for inter- and extrapolation diff --git a/test/unit/utAnim.cpp b/test/unit/utAnim.cpp index f2db2c251..90d6d36b3 100644 --- a/test/unit/utAnim.cpp +++ b/test/unit/utAnim.cpp @@ -72,4 +72,36 @@ TEST_F( utAnim, aiQuatKeyTest ) { aiQuatKey constrWithValuesTest( 1.0, q ); EXPECT_DOUBLE_EQ( 1.0, constrWithValuesTest.mTime ); EXPECT_EQ( q, constrWithValuesTest.mValue ); +} + +TEST_F( utAnim, aiNodeAnimTest ) { + bool ok( true ); + try { + aiNodeAnim myAnim; + EXPECT_EQ( aiAnimBehaviour_DEFAULT, myAnim.mPreState ); + EXPECT_EQ( aiAnimBehaviour_DEFAULT, myAnim.mPostState ); + } catch ( ... ) { + ok = false; + } + EXPECT_TRUE( ok ); +} + +TEST_F( utAnim, aiMeshAnimTest ) { + bool ok( true ); + try { + aiMeshAnim myMeshAnim; + } catch ( ... ) { + ok = false; + } + EXPECT_TRUE( ok ); +} + +TEST_F( utAnim, aiAnimationTest ) { + bool ok( true ); + try { + aiAnimation myAnimation; + } catch ( ... ) { + ok = false; + } + EXPECT_TRUE( ok ); } \ No newline at end of file From 30cd60ff828e4600e3b91e071486a5b96e27b362 Mon Sep 17 00:00:00 2001 From: Albin Bernhardsson Date: Thu, 24 Nov 2016 13:26:18 +0100 Subject: [PATCH 04/10] Remove unnecessary semicolons --- code/Exporter.cpp | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/code/Exporter.cpp b/code/Exporter.cpp index 26cb5e998..ce134f0a3 100644 --- a/code/Exporter.cpp +++ b/code/Exporter.cpp @@ -602,28 +602,28 @@ bool ExportProperties :: HasPropertyInteger(const char* szName) const bool ExportProperties :: HasPropertyBool(const char* szName) const { return HasGenericProperty(mIntProperties, szName); -}; +} // ------------------------------------------------------------------------------------------------ // Has a configuration property bool ExportProperties :: HasPropertyFloat(const char* szName) const { return HasGenericProperty(mFloatProperties, szName); -}; +} // ------------------------------------------------------------------------------------------------ // Has a configuration property bool ExportProperties :: HasPropertyString(const char* szName) const { return HasGenericProperty(mStringProperties, szName); -}; +} // ------------------------------------------------------------------------------------------------ // Has a configuration property bool ExportProperties :: HasPropertyMatrix(const char* szName) const { return HasGenericProperty(mMatrixProperties, szName); -}; +} #endif // !ASSIMP_BUILD_NO_EXPORT From 3b49dfe93e8b4642d12e07b281ec25c74c24c678 Mon Sep 17 00:00:00 2001 From: Albin Bernhardsson Date: Thu, 24 Nov 2016 14:10:24 +0100 Subject: [PATCH 05/10] Comment out unused variables --- code/ObjFileImporter.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/code/ObjFileImporter.cpp b/code/ObjFileImporter.cpp index 97ae29996..f0746085b 100644 --- a/code/ObjFileImporter.cpp +++ b/code/ObjFileImporter.cpp @@ -149,10 +149,10 @@ void ObjFileImporter::InternReadFile( const std::string &file, aiScene* pScene, // This next stage takes ~ 1/3th of the total readFile task // so should amount for 1/3th of the progress // only update every 100KB or it'll be too slow - unsigned int progress = 0; + /*unsigned int progress = 0; unsigned int progressCounter = 0; const unsigned int updateProgressEveryBytes = 100 * 1024; - const unsigned int progressTotal = (3*m_Buffer.size()/updateProgressEveryBytes); + const unsigned int progressTotal = (3*m_Buffer.size()/updateProgressEveryBytes);*/ // process all '\' /*std::vector ::iterator iter = m_Buffer.begin(); while (iter != m_Buffer.end()) From bd6f94b9267ba2dcdadb0484d353c3b891667f44 Mon Sep 17 00:00:00 2001 From: Albin Bernhardsson Date: Thu, 24 Nov 2016 14:15:13 +0100 Subject: [PATCH 06/10] Remove unused variable --- code/ObjFileParser.cpp | 2 -- 1 file changed, 2 deletions(-) diff --git a/code/ObjFileParser.cpp b/code/ObjFileParser.cpp index 7371b2d81..ddab8f786 100644 --- a/code/ObjFileParser.cpp +++ b/code/ObjFileParser.cpp @@ -101,8 +101,6 @@ ObjFile::Model *ObjFileParser::GetModel() const { // ------------------------------------------------------------------- // File parsing method. void ObjFileParser::parseFile( IOStreamBuffer &streamBuffer ) { - // only update every 100KB or it'll be too slow - const unsigned int updateProgressEveryBytes = 100 * 1024; unsigned int progressCounter = 0; const unsigned int bytesToProcess = streamBuffer.size(); const unsigned int progressTotal = 3 * bytesToProcess; From bde2b466be10b0aadd9ef7548d70202c33b3191b Mon Sep 17 00:00:00 2001 From: Albin Bernhardsson Date: Thu, 24 Nov 2016 14:53:33 +0100 Subject: [PATCH 07/10] Remove unnecessary semicolon --- code/X3DExporter.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/code/X3DExporter.cpp b/code/X3DExporter.cpp index cb6a6740f..9e89b5b9e 100644 --- a/code/X3DExporter.cpp +++ b/code/X3DExporter.cpp @@ -158,7 +158,7 @@ string tstr; AttrHelper_FloatToString(pValue, tstr); pList.push_back({pName, tstr}); -}; +} void X3DExporter::NodeHelper_OpenNode(const string& pNodeName, const size_t pTabLevel, const bool pEmptyElement, const list& pAttrList) { From 347c09c539f23686abf500b900f58237a29a0564 Mon Sep 17 00:00:00 2001 From: Albin Bernhardsson Date: Thu, 24 Nov 2016 15:15:17 +0100 Subject: [PATCH 08/10] Put back unused line (in comments) --- code/ObjFileParser.cpp | 2 ++ 1 file changed, 2 insertions(+) diff --git a/code/ObjFileParser.cpp b/code/ObjFileParser.cpp index ddab8f786..eba43c3b5 100644 --- a/code/ObjFileParser.cpp +++ b/code/ObjFileParser.cpp @@ -101,6 +101,8 @@ ObjFile::Model *ObjFileParser::GetModel() const { // ------------------------------------------------------------------- // File parsing method. void ObjFileParser::parseFile( IOStreamBuffer &streamBuffer ) { + // only update every 100KB or it'll be too slow + //const unsigned int updateProgressEveryBytes = 100 * 1024; unsigned int progressCounter = 0; const unsigned int bytesToProcess = streamBuffer.size(); const unsigned int progressTotal = 3 * bytesToProcess; From d82fd0d750d6b995a01582ec7634fa4f01160788 Mon Sep 17 00:00:00 2001 From: Kim Kulling Date: Thu, 24 Nov 2016 21:15:07 +0100 Subject: [PATCH 09/10] closes https://github.com/assimp/assimp/issues/1076: use ai_assert instead of assert. --- code/JoinVerticesProcess.h | 1 - code/SIBImporter.cpp | 24 ++++++++------- code/SIBImporter.h | 6 +--- code/TriangulateProcess.cpp | 24 +++++++-------- include/assimp/types.h | 3 +- test/CMakeLists.txt | 1 + test/unit/utSIBImporter.cpp | 59 +++++++++++++++++++++++++++++++++++++ 7 files changed, 88 insertions(+), 30 deletions(-) create mode 100644 test/unit/utSIBImporter.cpp diff --git a/code/JoinVerticesProcess.h b/code/JoinVerticesProcess.h index af92040d2..b1a9aa910 100644 --- a/code/JoinVerticesProcess.h +++ b/code/JoinVerticesProcess.h @@ -62,7 +62,6 @@ namespace Assimp class ASSIMP_API JoinVerticesProcess : public BaseProcess { public: - JoinVerticesProcess(); ~JoinVerticesProcess(); diff --git a/code/SIBImporter.cpp b/code/SIBImporter.cpp index 8e91ce7c3..8594a4126 100644 --- a/code/SIBImporter.cpp +++ b/code/SIBImporter.cpp @@ -197,13 +197,15 @@ static aiString ReadString(StreamReaderLE* stream, uint32_t numWChars) // ------------------------------------------------------------------------------------------------ // Constructor to be privately used by Importer -SIBImporter::SIBImporter() -{} +SIBImporter::SIBImporter() { + // empty +} // ------------------------------------------------------------------------------------------------ // Destructor, private as well -SIBImporter::~SIBImporter() -{} +SIBImporter::~SIBImporter() { + // empty +} // ------------------------------------------------------------------------------------------------ // Returns whether the class can handle the format of the given file. @@ -508,7 +510,7 @@ struct TempMesh std::vector vtx; std::vector nrm; std::vector uv; - std::vector faces; + std::vector faces; }; static void ReadShape(SIB* sib, StreamReaderLE* stream) @@ -546,7 +548,7 @@ static void ReadShape(SIB* sib, StreamReaderLE* stream) stream->SetReadLimit(oldLimit); } - assert(smesh.faceStart.size() == smesh.mtls.size()); // sanity check + ai_assert(smesh.faceStart.size() == smesh.mtls.size()); // sanity check // Silo doesn't store any normals in the file - we need to compute // them ourselves. We can't let AssImp handle it as AssImp doesn't @@ -792,8 +794,9 @@ static void ReadInstance(SIB* sib, StreamReaderLE* stream) stream->SetReadLimit(oldLimit); } - if (shapeIndex >= sib->objs.size()) - throw DeadlyImportError("SIB: Invalid shape index."); + if ( shapeIndex >= sib->objs.size() ) { + throw DeadlyImportError( "SIB: Invalid shape index." ); + } const SIBObject& src = sib->objs[shapeIndex]; inst.meshIdx = src.meshIdx; @@ -805,8 +808,9 @@ static void ReadInstance(SIB* sib, StreamReaderLE* stream) static void CheckVersion(StreamReaderLE* stream) { uint32_t version = stream->GetU4(); - if (version != 1) - throw DeadlyImportError("SIB: Unsupported file version."); + if ( version != 1 ) { + throw DeadlyImportError( "SIB: Unsupported file version." ); + } } static void ReadScene(SIB* sib, StreamReaderLE* stream) diff --git a/code/SIBImporter.h b/code/SIBImporter.h index d82a40da0..bd71104c6 100644 --- a/code/SIBImporter.h +++ b/code/SIBImporter.h @@ -53,15 +53,13 @@ namespace Assimp { // --------------------------------------------------------------------------- /** Importer class for the Nevercenter Silo SIB scene format */ -class SIBImporter : public BaseImporter +class ASSIMP_API SIBImporter : public BaseImporter { public: SIBImporter(); ~SIBImporter(); - public: - // ------------------------------------------------------------------- /** Returns whether the class can handle the format of the given file. * See BaseImporter::CanRead() for details. @@ -70,7 +68,6 @@ public: bool checkSig) const; protected: - // ------------------------------------------------------------------- /** Return importer meta information. * See #BaseImporter::GetInfo for the details @@ -85,7 +82,6 @@ protected: IOSystem* pIOHandler); private: - struct MeshInformation { explicit MeshInformation(const std::string& _name) diff --git a/code/TriangulateProcess.cpp b/code/TriangulateProcess.cpp index f19f85037..883a45e3d 100644 --- a/code/TriangulateProcess.cpp +++ b/code/TriangulateProcess.cpp @@ -57,9 +57,6 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * - dump all polygons and their triangulation sequences to * a file */ - - - #ifndef ASSIMP_BUILD_NO_TRIANGULATE_PROCESS #include "TriangulateProcess.h" #include "ProcessHelper.h" @@ -106,11 +103,15 @@ void TriangulateProcess::Execute( aiScene* pScene) bool bHas = false; for( unsigned int a = 0; a < pScene->mNumMeshes; a++) { - if( TriangulateMesh( pScene->mMeshes[a])) + if ( TriangulateMesh( pScene->mMeshes[ a ] ) ) { bHas = true; + } + } + if ( bHas ) { + DefaultLogger::get()->info( "TriangulateProcess finished. All polygons have been triangulated." ); + } else { + DefaultLogger::get()->debug( "TriangulateProcess finished. There was nothing to be done." ); } - if (bHas)DefaultLogger::get()->info ("TriangulateProcess finished. All polygons have been triangulated."); - else DefaultLogger::get()->debug("TriangulateProcess finished. There was nothing to be done."); } @@ -155,7 +156,7 @@ bool TriangulateProcess::TriangulateMesh( aiMesh* pMesh) } // Just another check whether aiMesh::mPrimitiveTypes is correct - assert(numOut != pMesh->mNumFaces); + ai_assert(numOut != pMesh->mNumFaces); aiVector3D* nor_out = NULL; @@ -184,7 +185,6 @@ bool TriangulateProcess::TriangulateMesh( aiMesh* pMesh) aiColor4D* clr = pMesh->mColors[0]; #endif - #ifdef AI_BUILD_TRIANGULATE_DEBUG_POLYS FILE* fout = fopen(POLY_OUTPUT_FILE,"a"); #endif @@ -276,7 +276,7 @@ bool TriangulateProcess::TriangulateMesh( aiMesh* pMesh) { // A polygon with more than 3 vertices can be either concave or convex. // Usually everything we're getting is convex and we could easily - // triangulate by trifanning. However, LightWave is probably the only + // triangulate by tri-fanning. However, LightWave is probably the only // modeling suite to make extensive use of highly concave, monster polygons ... // so we need to apply the full 'ear cutting' algorithm to get it right. @@ -325,7 +325,6 @@ bool TriangulateProcess::TriangulateMesh( aiMesh* pMesh) done[tmp] = false; } - #ifdef AI_BUILD_TRIANGULATE_DEBUG_POLYS // plot the plane onto which we mapped the polygon to a 2D ASCII pic aiVector2D bmin,bmax; @@ -404,14 +403,13 @@ bool TriangulateProcess::TriangulateMesh( aiMesh* pMesh) if (num_found == 2) { // Due to the 'two ear theorem', every simple polygon with more than three points must - // have 2 'ears'. Here's definitely someting wrong ... but we don't give up yet. + // have 2 'ears'. Here's definitely something wrong ... but we don't give up yet. // - // Instead we're continuting with the standard trifanning algorithm which we'd + // Instead we're continuing with the standard tri-fanning algorithm which we'd // use if we had only convex polygons. That's life. DefaultLogger::get()->error("Failed to triangulate polygon (no ear found). Probably not a simple polygon?"); - #ifdef AI_BUILD_TRIANGULATE_DEBUG_POLYS fprintf(fout,"critical error here, no ear found! "); #endif diff --git a/include/assimp/types.h b/include/assimp/types.h index 4a2e133e4..7904413b0 100644 --- a/include/assimp/types.h +++ b/include/assimp/types.h @@ -109,7 +109,8 @@ extern "C" { /** Maximum dimension for strings, ASSIMP strings are zero terminated. */ #ifdef __cplusplus -static const size_t MAXLEN = 1024; +static +const size_t MAXLEN = 1024; #else # define MAXLEN 1024 #endif diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt index c97480ccd..038a68d62 100644 --- a/test/CMakeLists.txt +++ b/test/CMakeLists.txt @@ -83,6 +83,7 @@ SET( TEST_SRCS unit/utMetadata.cpp unit/SceneDiffer.h unit/SceneDiffer.cpp + unit/utSIBImporter.cpp unit/utObjImportExport.cpp unit/utPretransformVertices.cpp unit/utRemoveComments.cpp diff --git a/test/unit/utSIBImporter.cpp b/test/unit/utSIBImporter.cpp new file mode 100644 index 000000000..727824431 --- /dev/null +++ b/test/unit/utSIBImporter.cpp @@ -0,0 +1,59 @@ +/* +--------------------------------------------------------------------------- +Open Asset Import Library (assimp) +--------------------------------------------------------------------------- + +Copyright (c) 2006-2016, assimp 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 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. +--------------------------------------------------------------------------- +*/ +#include "UnitTestPCH.h" + +#include "SIBImporter.h" + +using namespace ::Assimp; + +class utSIBImporter : public ::testing::Test { + // empty +}; + +TEST_F( utSIBImporter, createTest ) { + bool ok( true ); + try { + SIBImporter myImporter; + } catch ( ... ) { + ok = false; + } + EXPECT_TRUE( ok ); +} From 1541db01ccc9b8bc967fc44042886ca81dcbfad8 Mon Sep 17 00:00:00 2001 From: John Senneker Date: Fri, 25 Nov 2016 10:56:11 -0500 Subject: [PATCH 10/10] Remove scaling of specular exponent in OBJFileImporter.cpp --- code/ObjFileImporter.cpp | 3 --- 1 file changed, 3 deletions(-) diff --git a/code/ObjFileImporter.cpp b/code/ObjFileImporter.cpp index f0746085b..ad3cbf0ea 100644 --- a/code/ObjFileImporter.cpp +++ b/code/ObjFileImporter.cpp @@ -600,9 +600,6 @@ void ObjFileImporter::createMaterials(const ObjFile::Model* pModel, aiScene* pSc mat->AddProperty( &sm, 1, AI_MATKEY_SHADING_MODEL); - // multiplying the specular exponent with 2 seems to yield better results - pCurrentMaterial->shineness *= 4.f; - // Adding material colors mat->AddProperty( &pCurrentMaterial->ambient, 1, AI_MATKEY_COLOR_AMBIENT ); mat->AddProperty( &pCurrentMaterial->diffuse, 1, AI_MATKEY_COLOR_DIFFUSE );