# error This library requires C++
#endif
-#include <osg/Version>
-
-#define FG_OSG_VERSION \
- ((OPENSCENEGRAPH_MAJOR_VERSION*10000)\
- + (OPENSCENEGRAPH_MINOR_VERSION*1000) + OPENSCENEGRAPH_PATCH_VERSION)
+#include <simgear/structure/OSGVersion.hxx>
+#define FG_OSG_VERSION SG_OSG_VERSION
// #define FANCY_FRAME_COUNTER
#ifdef FANCY_FRAME_COUNTER
#include <algorithm>
#include <functional>
+using namespace osg;
using namespace flightgear;
-using osg::ref_ptr;
-using osg::Node;
SceneryPager::SceneryPager()
{
{
}
-void SceneryPager::requestNodeFile(const std::string& fileName,osg::Group* group,
- float priority, const osg::FrameStamp* framestamp)
+void SceneryPager::requestNodeFile(const std::string& fileName, Group* group,
+ float priority,
+ const FrameStamp* framestamp,
+#ifdef FGOSGPAGER25
+ ref_ptr<Referenced>& databaseRequest
+#endif
+ )
{
simgear::SGPagedLOD *sgplod = dynamic_cast<simgear::SGPagedLOD*>(group);
if(sgplod)
- DatabasePager::requestNodeFile(fileName,group,priority,framestamp,sgplod->getReaderWriterOptions());
+ DatabasePager::requestNodeFile(fileName, group, priority, framestamp,
+#ifdef FGOSGPAGER25
+ databaseRequest,
+#endif
+ sgplod->getReaderWriterOptions());
else
- DatabasePager::requestNodeFile(fileName,group,priority,framestamp);
+ DatabasePager::requestNodeFile(fileName, group, priority, framestamp,
+#ifdef FGOSGPAGER25
+ databaseRequest
+#endif
+ );
}
-void SceneryPager::queueRequest(const std::string& fileName, osg::Group* group,
- float priority, osg::FrameStamp* frameStamp,
+void SceneryPager::queueRequest(const std::string& fileName, Group* group,
+ float priority, FrameStamp* frameStamp,
+#ifdef FGOSGPAGER25
+ ref_ptr<Referenced>& databaseRequest,
+#endif
osgDB::ReaderWriter::Options* options)
{
_pagerRequests.push_back(PagerRequest(fileName, group, priority,
- frameStamp, options));
+ frameStamp,
+#ifdef FGOSGPAGER25
+ databaseRequest,
+#endif
+ options));
}
void SceneryPager::queueDeleteRequest(osg::ref_ptr<osg::Object>& objptr)
bool arePagerRequests = false;
if (!_deleteRequests.empty()) {
areDeleteRequests = true;
+#ifdef FGOSGPAGER25
+ OpenThreads::ScopedLock<OpenThreads::Mutex>
+ lock(_fileRequestQueue->_childrenToDeleteListMutex);
+ ObjectList& deleteList = _fileRequestQueue->_childrenToDeleteList;
+#else
OpenThreads::ScopedLock<OpenThreads::Mutex>
lock(_childrenToDeleteListMutex);
- _childrenToDeleteList.insert(_childrenToDeleteList.end(),
- _deleteRequests.begin(),
- _deleteRequests.end());
+ ObjectList& deleteList = _childrenToDeleteList;
+#endif
+ deleteList.insert(deleteList.end(),
+ _deleteRequests.begin(),
+ _deleteRequests.end());
_deleteRequests.clear();
}
if (!_pagerRequests.empty()) {
bind2nd(mem_fun_ref(&PagerRequest::doRequest), this));
_pagerRequests.clear();
}
- if (areDeleteRequests && !arePagerRequests)
+ if (areDeleteRequests && !arePagerRequests) {
+#ifdef FGOSGPAGER25
+ _fileRequestQueue->updateBlock();
+#else
updateDatabasePagerThreadBlock();
+#endif
+ }
DatabasePager::signalEndFrame();
}
#include <osg/Group>
#include <osgDB/DatabasePager>
+#include <simgear/structure/OSGVersion.hxx>
+
+// Pager request change in OpenSceneGraph 2.5.1
+#if SG_OSG_VERSION >= 25001
+#define FGOSGPAGER25
+#endif
+
namespace flightgear
{
class SceneryPager : public osgDB::DatabasePager
public:
SceneryPager();
SceneryPager(const SceneryPager& rhs);
-
+ // Unhide DatabasePager::requestNodeFile
+ using osgDB::DatabasePager::requestNodeFile;
// reimplement to add readerWriterOptions from SGPagedLOD
- virtual void requestNodeFile(const std::string& fileName,osg::Group* group,
- float priority, const osg::FrameStamp* framestamp);
-
- virtual void requestNodeFile(const std::string& fileName,osg::Group* group,
- float priority, const osg::FrameStamp* framestamp,
- osgDB::ReaderWriter::Options* options) {
- osgDB::DatabasePager::requestNodeFile(fileName, group, priority,
- framestamp, options);
- }
-
+ virtual void requestNodeFile(const std::string& fileName, osg::Group* group,
+ float priority,
+ const osg::FrameStamp* framestamp,
+#ifdef FGOSGPAGER25
+ osg::ref_ptr<osg::Referenced>&
+ databaseRequest
+#endif
+ );
void queueRequest(const std::string& fileName, osg::Group* node,
float priority, osg::FrameStamp* frameStamp,
+#ifdef FGOSGPAGER25
+ osg::ref_ptr<osg::Referenced>& databaseRequest,
+#endif
osgDB::ReaderWriter::Options* options);
// This is passed a ref_ptr so that it can "take ownership" of the
// node to delete and decrement its refcount while holding the
// Queue up file requests until the end of the frame
struct PagerRequest
{
- PagerRequest() {}
+ PagerRequest() : _priority(0.0f), _databaseRequest(0) {}
PagerRequest(const PagerRequest& rhs) :
_fileName(rhs._fileName), _group(rhs._group),
_priority(rhs._priority), _frameStamp(rhs._frameStamp),
- _options(rhs._options) {}
+ _options(rhs._options), _databaseRequest(rhs._databaseRequest) {}
PagerRequest(const std::string& fileName, osg::Group* group,
float priority, osg::FrameStamp* frameStamp,
+#ifdef FGOSGPAGER25
+ osg::ref_ptr<Referenced>& databaseRequest,
+#endif
osgDB::ReaderWriter::Options* options):
_fileName(fileName), _group(group), _priority(priority),
- _frameStamp(frameStamp), _options(options) {}
+ _frameStamp(frameStamp), _options(options),
+#ifdef FGOSGPAGER25
+ _databaseRequest(&databaseRequest)
+#else
+ _databaseRequest(0)
+#endif
+ {}
void doRequest(SceneryPager* pager)
{
if (_group->getNumChildren() == 0)
pager->requestNodeFile(_fileName, _group.get(), _priority,
- _frameStamp.get(), _options.get());
+ _frameStamp.get(),
+#ifdef FGOSGPAGER25
+ *_databaseRequest,
+#endif
+ _options.get());
}
std::string _fileName;
float _priority;
osg::ref_ptr<osg::FrameStamp> _frameStamp;
osg::ref_ptr<osgDB::ReaderWriter::Options> _options;
+ osg::ref_ptr<osg::Referenced>* _databaseRequest;
};
typedef std::vector<PagerRequest> PagerRequestList;
PagerRequestList _pagerRequests;
_pager->queueRequest(entry->tileFileName,
entry->getNode(),
entry->get_inner_ring() ? 10.0f : 1.0f,
- _framestamp, _options);
+ _framestamp,
+#ifdef FGOSGPAGER25
+ entry->getDatabaseRequest(),
+#endif
+ _options);
}
}
private: