mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-07 12:54:00 +00:00
5debd6e25a
This PR removes dummy serialisers for `StateSetUpdater`, `NodeCallback` and the respective `META` macros that trigger serialisation requirement here. `StateSetUpdater` and `NodeCallback` are just base classes that can not be used on their own, so there is no need to incorporate them into serialisation. These changes might have minor effects on derived classes that forget to override `className()`, `libraryName()` through `META`, but it makes hardly a difference to now serialise such classes as a dysfunctional `osg::Callback` instead of a dysfunctional `SceneUtil::NodeCallback`.
41 lines
881 B
C++
41 lines
881 B
C++
#ifndef SCENEUTIL_NODECALLBACK_H
|
|
#define SCENEUTIL_NODECALLBACK_H
|
|
|
|
#include <osg/Callback>
|
|
|
|
namespace osg
|
|
{
|
|
class Node;
|
|
class NodeVisitor;
|
|
}
|
|
|
|
namespace SceneUtil
|
|
{
|
|
|
|
template <class Derived, typename NodeType=osg::Node*, typename VisitorType=osg::NodeVisitor*>
|
|
class NodeCallback : public osg::Callback
|
|
{
|
|
public:
|
|
NodeCallback(){}
|
|
NodeCallback(const NodeCallback& nc,const osg::CopyOp& copyop):
|
|
osg::Callback(nc, copyop) {}
|
|
|
|
bool run(osg::Object* object, osg::Object* data) override
|
|
{
|
|
static_cast<Derived*>(this)->operator()((NodeType)object, (VisitorType)data->asNodeVisitor());
|
|
return true;
|
|
}
|
|
|
|
template <typename VT>
|
|
void traverse(NodeType object, VT data)
|
|
{
|
|
if (_nestedCallback.valid())
|
|
_nestedCallback->run(object, data);
|
|
else
|
|
data->traverse(*object);
|
|
}
|
|
};
|
|
|
|
}
|
|
#endif
|