mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0031173: Point Cloud Rendering - Enable remote file systems as input and output for the Point Cloud converter
Make RWStl_Reader::IsAscii() accepting optional argument pointing how to rewind the input stream, using unget() or seekg(). This allows writing a reader that uses a stream supporting seekg but not supporting unget.
This commit is contained in:
parent
cd0705f660
commit
97454ee0cb
@ -149,7 +149,7 @@ Standard_Boolean RWStl_Reader::Read (const char* theFile,
|
|||||||
// (80 bytes header + 4 bytes facet count + 50 bytes for one facet);
|
// (80 bytes header + 4 bytes facet count + 50 bytes for one facet);
|
||||||
// thus assume files shorter than 134 as Ascii without probing
|
// thus assume files shorter than 134 as Ascii without probing
|
||||||
// (probing may bring stream to fail state if EOF is reached)
|
// (probing may bring stream to fail state if EOF is reached)
|
||||||
bool isAscii = ((size_t)theEnd < THE_STL_MIN_FILE_SIZE || IsAscii (aStream));
|
bool isAscii = ((size_t)theEnd < THE_STL_MIN_FILE_SIZE || IsAscii (aStream, true));
|
||||||
|
|
||||||
Standard_ReadLineBuffer aBuffer (THE_BUFFER_SIZE);
|
Standard_ReadLineBuffer aBuffer (THE_BUFFER_SIZE);
|
||||||
|
|
||||||
@ -185,7 +185,8 @@ Standard_Boolean RWStl_Reader::Read (const char* theFile,
|
|||||||
//purpose :
|
//purpose :
|
||||||
//==============================================================================
|
//==============================================================================
|
||||||
|
|
||||||
Standard_Boolean RWStl_Reader::IsAscii (Standard_IStream& theStream)
|
Standard_Boolean RWStl_Reader::IsAscii (Standard_IStream& theStream,
|
||||||
|
const bool isSeekgAvailable)
|
||||||
{
|
{
|
||||||
// read first 134 bytes to detect file format
|
// read first 134 bytes to detect file format
|
||||||
char aBuffer[THE_STL_MIN_FILE_SIZE];
|
char aBuffer[THE_STL_MIN_FILE_SIZE];
|
||||||
@ -196,10 +197,18 @@ Standard_Boolean RWStl_Reader::IsAscii (Standard_IStream& theStream)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// put back the read symbols
|
if (isSeekgAvailable)
|
||||||
for (std::streamsize aByteIter = aNbRead; aByteIter > 0; --aByteIter)
|
|
||||||
{
|
{
|
||||||
theStream.unget();
|
// get back to the beginning
|
||||||
|
theStream.seekg(0, theStream.beg);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// put back the read symbols
|
||||||
|
for (std::streamsize aByteIter = aNbRead; aByteIter > 0; --aByteIter)
|
||||||
|
{
|
||||||
|
theStream.unget();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// if file is shorter than size of binary file with 1 facet, it must be ascii
|
// if file is shorter than size of binary file with 1 facet, it must be ascii
|
||||||
|
@ -45,9 +45,12 @@ public:
|
|||||||
const Message_ProgressRange& theProgress);
|
const Message_ProgressRange& theProgress);
|
||||||
|
|
||||||
//! Guess whether the stream is an Ascii STL file, by analysis of the first bytes (~200).
|
//! Guess whether the stream is an Ascii STL file, by analysis of the first bytes (~200).
|
||||||
//! The function attempts to put back the read symbols to the stream which thus must support ungetc().
|
//! If the stream does not support seekg() then the parameter isSeekgAvailable should
|
||||||
|
//! be passed as 'false', in this case the function attempts to put back the read symbols
|
||||||
|
//! to the stream which thus must support ungetc().
|
||||||
//! Returns true if the stream seems to contain Ascii STL.
|
//! Returns true if the stream seems to contain Ascii STL.
|
||||||
Standard_EXPORT Standard_Boolean IsAscii (Standard_IStream& theStream);
|
Standard_EXPORT Standard_Boolean IsAscii (Standard_IStream& theStream,
|
||||||
|
const bool isSeekgAvailable);
|
||||||
|
|
||||||
//! Reads STL data from binary stream.
|
//! Reads STL data from binary stream.
|
||||||
//! The stream must be opened in binary mode.
|
//! The stream must be opened in binary mode.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user