Merge pull request #502 from Haojia521/OutputStreamUseTargertSoVersion
write binary file with a specific so version
This commit is contained in:
committed by
Robert Osfield
parent
647b578ce6
commit
46850214df
@@ -25,7 +25,7 @@
|
||||
using namespace osgDB;
|
||||
|
||||
OutputStream::OutputStream( const osgDB::Options* options )
|
||||
: _writeImageHint(WRITE_USE_IMAGE_HINT), _useSchemaData(false), _useRobustBinaryFormat(true)
|
||||
: _writeImageHint(WRITE_USE_IMAGE_HINT), _useSchemaData(false), _useRobustBinaryFormat(true), _targetFileVersion(OPENSCENEGRAPH_SOVERSION)
|
||||
{
|
||||
BEGIN_BRACKET.set( "{", +INDENT_VALUE );
|
||||
END_BRACKET.set( "}", -INDENT_VALUE );
|
||||
@@ -61,15 +61,31 @@ OutputStream::OutputStream( const osgDB::Options* options )
|
||||
_domainVersionMap[keyAndValue.front()] = atoi(keyAndValue.back().c_str());
|
||||
}
|
||||
}
|
||||
|
||||
if (!options->getPluginStringData("TargetFileVersion").empty())
|
||||
{
|
||||
std::string strVersion = options->getPluginStringData("TargetFileVersion");
|
||||
int version = atoi(strVersion.c_str());
|
||||
if (version > 0 && version <= OPENSCENEGRAPH_SOVERSION)
|
||||
_targetFileVersion = version;
|
||||
}
|
||||
|
||||
if (_targetFileVersion < 99) _useRobustBinaryFormat = false;
|
||||
}
|
||||
|
||||
OutputStream::~OutputStream()
|
||||
{
|
||||
}
|
||||
|
||||
void OutputStream::setFileVersion( const std::string& d, int v )
|
||||
{
|
||||
if (d.empty()) _targetFileVersion = v;
|
||||
else _domainVersionMap[d] = v;
|
||||
}
|
||||
|
||||
int OutputStream::getFileVersion( const std::string& d ) const
|
||||
{
|
||||
if ( d.empty() ) return OPENSCENEGRAPH_SOVERSION;
|
||||
if ( d.empty() ) return _targetFileVersion;
|
||||
VersionMap::const_iterator itr = _domainVersionMap.find(d);
|
||||
return itr==_domainVersionMap.end() ? 0 : itr->second;
|
||||
}
|
||||
@@ -389,15 +405,18 @@ void OutputStream::writePrimitiveSet( const osg::PrimitiveSet* p )
|
||||
*this << MAPPEE(PrimitiveType, ID_DRAWARRAYS);
|
||||
{
|
||||
const osg::DrawArrays* da = static_cast<const osg::DrawArrays*>(p);
|
||||
*this << MAPPEE(PrimitiveType, da->getMode()) << da->getNumInstances()
|
||||
<< da->getFirst() << da->getCount() << std::endl;
|
||||
*this << MAPPEE(PrimitiveType, da->getMode());
|
||||
if (_targetFileVersion > 96) *this << da->getNumInstances();
|
||||
*this << da->getFirst() << da->getCount() << std::endl;
|
||||
}
|
||||
break;
|
||||
case osg::PrimitiveSet::DrawArrayLengthsPrimitiveType:
|
||||
*this << MAPPEE(PrimitiveType, ID_DRAWARRAY_LENGTH);
|
||||
{
|
||||
const osg::DrawArrayLengths* dl = static_cast<const osg::DrawArrayLengths*>(p);
|
||||
*this << MAPPEE(PrimitiveType, dl->getMode()) << dl->getNumInstances() << dl->getFirst();
|
||||
*this << MAPPEE(PrimitiveType, dl->getMode());
|
||||
if (_targetFileVersion > 96) *this << dl->getNumInstances();
|
||||
*this << dl->getFirst();
|
||||
writeArrayImplementation( dl, dl->size(), 4 );
|
||||
}
|
||||
break;
|
||||
@@ -405,7 +424,8 @@ void OutputStream::writePrimitiveSet( const osg::PrimitiveSet* p )
|
||||
*this << MAPPEE(PrimitiveType, ID_DRAWELEMENTS_UBYTE);
|
||||
{
|
||||
const osg::DrawElementsUByte* de = static_cast<const osg::DrawElementsUByte*>(p);
|
||||
*this << MAPPEE(PrimitiveType, de->getMode()) << de->getNumInstances();
|
||||
*this << MAPPEE(PrimitiveType, de->getMode());
|
||||
if (_targetFileVersion > 96) *this << de->getNumInstances();
|
||||
writeArrayImplementation( de, de->size(), 4 );
|
||||
}
|
||||
break;
|
||||
@@ -413,7 +433,8 @@ void OutputStream::writePrimitiveSet( const osg::PrimitiveSet* p )
|
||||
*this << MAPPEE(PrimitiveType, ID_DRAWELEMENTS_USHORT);
|
||||
{
|
||||
const osg::DrawElementsUShort* de = static_cast<const osg::DrawElementsUShort*>(p);
|
||||
*this << MAPPEE(PrimitiveType, de->getMode()) << de->getNumInstances();
|
||||
*this << MAPPEE(PrimitiveType, de->getMode());
|
||||
if (_targetFileVersion > 96) *this << de->getNumInstances();
|
||||
writeArrayImplementation( de, de->size(), 4 );
|
||||
}
|
||||
break;
|
||||
@@ -421,7 +442,8 @@ void OutputStream::writePrimitiveSet( const osg::PrimitiveSet* p )
|
||||
*this << MAPPEE(PrimitiveType, ID_DRAWELEMENTS_UINT);
|
||||
{
|
||||
const osg::DrawElementsUInt* de = static_cast<const osg::DrawElementsUInt*>(p);
|
||||
*this << MAPPEE(PrimitiveType, de->getMode()) << de->getNumInstances();
|
||||
*this << MAPPEE(PrimitiveType, de->getMode());
|
||||
if (_targetFileVersion > 96) *this << de->getNumInstances();
|
||||
writeArrayImplementation( de, de->size(), 4 );
|
||||
}
|
||||
break;
|
||||
@@ -440,7 +462,8 @@ void OutputStream::writeImage( const osg::Image* img )
|
||||
bool newID = false;
|
||||
unsigned int id = findOrCreateObjectID( img, newID );
|
||||
|
||||
*this << PROPERTY("ClassName") << name << std::endl; // Write object name
|
||||
if (_targetFileVersion > 94) *this << PROPERTY("ClassName") << name << std::endl; // Write object name
|
||||
|
||||
*this << PROPERTY("UniqueID") << id << std::endl; // Write image ID
|
||||
if ( getException() ) return;
|
||||
|
||||
@@ -710,7 +733,7 @@ void OutputStream::start( OutputIterator* outIterator, OutputStream::WriteType t
|
||||
|
||||
if ( isBinary() )
|
||||
{
|
||||
*this << (unsigned int)type << (unsigned int)OPENSCENEGRAPH_SOVERSION;
|
||||
*this << (unsigned int)type << (unsigned int)_targetFileVersion;
|
||||
|
||||
bool useCompressSource = false;
|
||||
unsigned int attributes = 0;
|
||||
|
||||
Reference in New Issue
Block a user