Obj-Stream-Handling: fix compiler-errors and warnings.

pull/1043/head
Kim Kulling 2016-10-29 21:41:24 +02:00
parent 186f3f091f
commit b9261f01a3
3 changed files with 77 additions and 12 deletions

View File

@ -42,6 +42,7 @@ OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#include <assimp/types.h> #include <assimp/types.h>
#include <assimp/IOStream.hpp> #include <assimp/IOStream.hpp>
#include "ParsingUtils.h"
#include <iostream> #include <iostream>
@ -81,6 +82,18 @@ public:
/// @return true if successful. /// @return true if successful.
bool readNextBlock(); bool readNextBlock();
/// @brief Returns the number of blocks to read.
/// @return The number of blocks.
size_t getNumBlocks() const;
/// @brief Returns the current block index.
/// @return The current block index.
size_t getCurrentBlockIndex() const;
/// @brief Returns the current file pos.
/// @return The current file pos.
size_t getFilePos() const;
/// @brief Will read the next line. /// @brief Will read the next line.
/// @param buffer The buffer for the next line. /// @param buffer The buffer for the next line.
/// @return true if successful. /// @return true if successful.
@ -90,6 +103,8 @@ private:
IOStream *m_stream; IOStream *m_stream;
size_t m_filesize; size_t m_filesize;
size_t m_cacheSize; size_t m_cacheSize;
size_t m_numBlocks;
size_t m_blockIdx;
std::vector<T> m_cache; std::vector<T> m_cache;
size_t m_cachePos; size_t m_cachePos;
size_t m_filePos; size_t m_filePos;
@ -101,6 +116,8 @@ IOStreamBuffer<T>::IOStreamBuffer( size_t cache )
: m_stream( nullptr ) : m_stream( nullptr )
, m_filesize( 0 ) , m_filesize( 0 )
, m_cacheSize( cache ) , m_cacheSize( cache )
, m_numBlocks( 0 )
, m_blockIdx( 0 )
, m_cachePos( 0 ) , m_cachePos( 0 )
, m_filePos( 0 ) { , m_filePos( 0 ) {
m_cache.resize( cache ); m_cache.resize( cache );
@ -116,10 +133,12 @@ IOStreamBuffer<T>::~IOStreamBuffer() {
template<class T> template<class T>
inline inline
bool IOStreamBuffer<T>::open( IOStream *stream ) { bool IOStreamBuffer<T>::open( IOStream *stream ) {
// file still opened!
if ( nullptr != m_stream ) { if ( nullptr != m_stream ) {
return false; return false;
} }
// Invalid stream pointer
if ( nullptr == stream ) { if ( nullptr == stream ) {
return false; return false;
} }
@ -133,6 +152,11 @@ bool IOStreamBuffer<T>::open( IOStream *stream ) {
m_cacheSize = m_filesize; m_cacheSize = m_filesize;
} }
m_numBlocks = m_filesize / m_cacheSize;
if ( ( m_filesize % m_cacheSize ) > 0 ) {
m_numBlocks++;
}
return true; return true;
} }
@ -143,8 +167,13 @@ bool IOStreamBuffer<T>::close() {
return false; return false;
} }
// init counters and state vars
m_stream = nullptr; m_stream = nullptr;
m_filesize = 0; m_filesize = 0;
m_numBlocks = 0;
m_blockIdx = 0;
m_cachePos = 0;
m_filePos = 0;
return true; return true;
} }
@ -174,10 +203,29 @@ bool IOStreamBuffer<T>::readNextBlock() {
} }
m_filePos += m_cacheSize; m_filePos += m_cacheSize;
m_cachePos = 0; m_cachePos = 0;
m_blockIdx++;
return true; return true;
} }
template<class T>
inline
size_t IOStreamBuffer<T>::getNumBlocks() const {
return m_numBlocks;
}
template<class T>
inline
size_t IOStreamBuffer<T>::getCurrentBlockIndex() const {
return m_blockIdx;
}
template<class T>
inline
size_t IOStreamBuffer<T>::getFilePos() const {
return m_filePos;
}
template<class T> template<class T>
inline inline
bool IOStreamBuffer<T>::getNextLine( std::vector<T> &buffer ) { bool IOStreamBuffer<T>::getNextLine( std::vector<T> &buffer ) {

View File

@ -110,8 +110,7 @@ void ObjFileParser::parseFile( IOStreamBuffer<char> &streamBuffer ) {
const unsigned int progressTotal = 3 * bytesToProcess; const unsigned int progressTotal = 3 * bytesToProcess;
const unsigned int progressOffset = bytesToProcess; const unsigned int progressOffset = bytesToProcess;
unsigned int processed = 0; unsigned int processed = 0;
size_t lastFilePos( 0 );
//DataArrayIt lastDataIt = m_DataIt;
bool endOfFile( false ); bool endOfFile( false );
std::vector<char> buffer; std::vector<char> buffer;
@ -122,13 +121,13 @@ void ObjFileParser::parseFile( IOStreamBuffer<char> &streamBuffer ) {
m_DataItEnd = buffer.end(); m_DataItEnd = buffer.end();
// Handle progress reporting // Handle progress reporting
/*processed += std::distance(lastDataIt, m_DataIt); const size_t filePos( streamBuffer.getFilePos() );
lastDataIt = m_DataIt; if ( lastFilePos < filePos ) {
if (processed > (progressCounter * updateProgressEveryBytes)) processed += filePos;
{ lastFilePos = filePos;
progressCounter++; progressCounter++;
m_progress->UpdateFileRead( progressOffset + processed * 2, progressTotal ); m_progress->UpdateFileRead( progressOffset + processed * 2, progressTotal );
}*/ }
// parse line // parse line
switch (*m_DataIt) switch (*m_DataIt)

View File

@ -87,5 +87,23 @@ TEST_F( IOStreamBufferTest, open_close_Test ) {
} }
TEST_F( IOStreamBufferTest, readlineTest ) { TEST_F( IOStreamBufferTest, readlineTest ) {
char buffer[ L_tmpnam ];
tmpnam( buffer );
std::FILE *fs( std::fopen( buffer, "w+" ) );
size_t written( std::fwrite( buffer, 1, sizeof( char ) * L_tmpnam, fs ) );
std::fflush( fs );
IOStreamBuffer<char> myBuffer( 26 );
EXPECT_EQ( 26, myBuffer.cacheSize() );
TestDefaultIOStream myStream( fs, buffer );
EXPECT_TRUE( myBuffer.open( &myStream ) );
EXPECT_EQ( 10, myBuffer.getNumBlocks() );
EXPECT_TRUE( myBuffer.close() );
}
TEST_F( IOStreamBufferTest, accessBlockIndexTest ) {
} }