mirror of
https://github.com/minetest/irrlicht.git
synced 2024-12-27 08:27:30 +01:00
0c6385cb92
Usually something like __IRR_SOME_GUARD_INCLUDED__ replaced by IRR_SOME_GUARD_INCLUDED. Removing underscores at the end wasn't necessary, but more symmetric (probably the reason they got added there as well). While this touches every header it shouldn't affect users (I hope). Also a few whitespace changes to unify whitespace usage a bit. And a bunch of spelling fixes in comments. git-svn-id: svn://svn.code.sf.net/p/irrlicht/code/trunk@6252 dfc29bdd-3216-0410-991c-e03cc46cb475
51 lines
1.9 KiB
C++
51 lines
1.9 KiB
C++
// Copyright (C) 2002-2012 Nikolaus Gebhardt
|
|
// This file is part of the "Irrlicht Engine".
|
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
|
|
|
#ifndef IRR_I_SCENE_USER_DATA_SERIALIZER_H_INCLUDED
|
|
#define IRR_I_SCENE_USER_DATA_SERIALIZER_H_INCLUDED
|
|
|
|
#include "IReferenceCounted.h"
|
|
|
|
namespace irr
|
|
{
|
|
namespace io
|
|
{
|
|
class IAttributes;
|
|
} // end namespace io
|
|
namespace scene
|
|
{
|
|
class ISceneNode;
|
|
|
|
//! Interface to read and write user data to and from .irr files.
|
|
/** This interface is to be implemented by the user, to make it possible to read
|
|
and write user data when reading or writing .irr files via ISceneManager.
|
|
To be used with ISceneManager::loadScene() and ISceneManager::saveScene() */
|
|
class ISceneUserDataSerializer
|
|
{
|
|
public:
|
|
|
|
virtual ~ISceneUserDataSerializer() {}
|
|
|
|
//! Called when the scene manager create a scene node while loading a file.
|
|
virtual void OnCreateNode(ISceneNode* node) = 0;
|
|
|
|
//! Called when the scene manager read a scene node while loading a file.
|
|
/** The userData pointer contains a list of attributes with userData which
|
|
were attached to the scene node in the read scene file.*/
|
|
virtual void OnReadUserData(ISceneNode* forSceneNode, io::IAttributes* userData) = 0;
|
|
|
|
//! Called when the scene manager is writing a scene node to an xml file for example.
|
|
/** Implement this method and return a list of attributes containing the user data
|
|
you want to be saved together with the scene node. Return 0 if no user data should
|
|
be added. Please note that the scene manager will call drop() to the returned pointer
|
|
after it no longer needs it, so if you didn't create a new object for the return value
|
|
and returning a longer existing IAttributes object, simply call grab() before returning it. */
|
|
virtual io::IAttributes* createUserData(ISceneNode* forSceneNode) = 0;
|
|
};
|
|
|
|
} // end namespace scene
|
|
} // end namespace irr
|
|
|
|
#endif
|