Added population and access of the ReaderWriter::Options::s/getDatabasePath()

to enable paged database to accessed without setting file paths explictly
This commit is contained in:
Robert Osfield
2004-10-13 14:13:17 +00:00
parent 3f0e4ea99a
commit 9d67383621
5 changed files with 57 additions and 4 deletions

View File

@@ -97,6 +97,17 @@ void PagedLOD::read(DataInputStream* in){
else
throw Exception("Group::read(): Could not cast this osg::Group to an osg::Node.");
if (getDatabasePath().empty() && in->getOptions())
{
const std::string& path = in->getOptions()->getDatabasePath();
if (!path.empty())
{
setDatabasePath(path);
}
}
setRadius(in->readFloat());
setNumChildrenThatCannotBeExpired(in->readUInt());

View File

@@ -28,8 +28,18 @@ class IVEReaderWriter : public ReaderWriter
std::string fileName = osgDB::findDataFile( file );
if (fileName.empty()) return ReadResult::FILE_NOT_FOUND;
// code for setting up the database path so that any paged
// databases can be automatically located.
osg::ref_ptr<Options> local_opt = const_cast<Options*>(options);
if (!local_opt) local_opt = new Options;
if (local_opt.valid() && local_opt->getDatabasePath().empty())
{
local_opt->setDatabasePath(osgDB::getFilePath(fileName));
}
std::ifstream istream(fileName.c_str(), std::ios::in | std::ios::binary);
return readNode(istream,options);
return readNode(istream,local_opt.get());
}
virtual ReadResult readNode(std::istream& fin, const Options* options)

View File

@@ -308,12 +308,23 @@ class NetReader : public osgDB::ReaderWriter
} while( linebuff[0] != '\r' );
// code for setting up the database path so that any paged
// databases can be automatically located.
osg::ref_ptr<Options> local_opt = const_cast<Options*>(options);
if (!local_opt) local_opt = new Options;
if (local_opt.valid() && local_opt->getDatabasePath().empty())
{
local_opt->setDatabasePath(osgDB::getFilePath(inFileName));
}
osg::notify(osg::DEBUG_INFO) << "osgPlugin .net: " << fileName <<
" fetched from server." << std::endl;
if( reader != 0L )
readResult = readFile(objectType, reader, sio, options );
readResult = readFile(objectType, reader, sio, local_opt.get() );
if( !localCacheDir.empty() && cacheMode & Write )
{

View File

@@ -1,4 +1,5 @@
#include "osg/PagedLOD"
#include "osg/Notify"
#include "osgDB/Registry"
#include "osgDB/Input"
@@ -26,6 +27,15 @@ bool PagedLOD_readLocalData(Object& obj, Input& fr)
bool iteratorAdvanced = false;
PagedLOD& lod = static_cast<PagedLOD&>(obj);
if (lod.getDatabasePath().empty() && fr.getOptions())
{
const std::string& path = fr.getOptions()->getDatabasePath();
if (!path.empty())
{
lod.setDatabasePath(path);
}
}
unsigned int num;
if (fr[0].matchWord("NumChildrenThatCannotBeExpired") && fr[1].getUInt(num))

View File

@@ -2,6 +2,7 @@
#include <osg/Image>
#include <osg/Group>
#include <osg/Notify>
#include <osgDB/FileNameUtils>
#include <osgDB/FileUtils>
@@ -34,10 +35,20 @@ class OSGReaderWriter : public ReaderWriter
std::string fileName = osgDB::findDataFile( file );
if (fileName.empty()) return ReadResult::FILE_NOT_FOUND;
// code for setting up the database path so that any paged
// databases can be automatically located.
osg::ref_ptr<Options> local_opt = const_cast<Options*>(opt);
if (!local_opt) local_opt = new Options;
if (local_opt.valid() && local_opt->getDatabasePath().empty())
{
local_opt->setDatabasePath(osgDB::getFilePath(fileName));
}
std::ifstream fin(fileName.c_str());
if (fin)
{
return readNode(fin, opt);
return readNode(fin, local_opt.get());
}
return 0L;
@@ -49,7 +60,7 @@ class OSGReaderWriter : public ReaderWriter
Input fr;
fr.attach(&fin);
fr.setOptions(options);
typedef std::vector<osg::Node*> NodeList;
NodeList nodeList;