Merge pull request #1064 from snowzurfer/master

Fix obj .mtl file loading
pull/1070/head
Kim Kulling 2016-11-14 20:17:28 +01:00 committed by GitHub
commit 302b8044c6
2 changed files with 42 additions and 1 deletions

View File

@ -178,7 +178,7 @@ void ObjFileParser::parseFile( IOStreamBuffer<char> &streamBuffer ) {
{ {
std::string name; std::string name;
getName(m_DataIt, m_DataItEnd, name); getNameNoSpace(m_DataIt, m_DataItEnd, name);
size_t nextSpace = name.find(" "); size_t nextSpace = name.find(" ");
if (nextSpace != std::string::npos) if (nextSpace != std::string::npos)

View File

@ -165,6 +165,47 @@ inline char_t getName( char_t it, char_t end, std::string &name )
return it; return it;
} }
/** @brief Get a name from the current line. Do not preserve space
* in the middle, but trim it at the end.
* @param it set to current position
* @param end set to end of scratch buffer for readout
* @param name Separated name
* @return Current-iterator with new position
*/
template<class char_t>
inline char_t getNameNoSpace( char_t it, char_t end, std::string &name )
{
name = "";
if( isEndOfBuffer( it, end ) ) {
return end;
}
char *pStart = &( *it );
while( !isEndOfBuffer( it, end ) && !IsLineEnd( *it )
&& !IsSpaceOrNewLine( *it ) ) {
++it;
}
while( isEndOfBuffer( it, end ) || IsLineEnd( *it )
|| IsSpaceOrNewLine( *it ) ) {
--it;
}
++it;
// Get name
// if there is no name, and the previous char is a separator, come back to start
while (&(*it) < pStart) {
++it;
}
std::string strName( pStart, &(*it) );
if ( strName.empty() )
return it;
else
name = strName;
return it;
}
/** @brief Get next word from given line /** @brief Get next word from given line
* @param it set to current position * @param it set to current position
* @param end set to end of scratch buffer for readout * @param end set to end of scratch buffer for readout