/usr/include/oce/TObj_Persistence.hxx is in liboce-ocaf-lite-dev 0.9.1-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 | // File: TObj_Persistence.hxx
// Created: Tue Nov 23 11:36:03 2004
// Author: Pavel TELKOV
// Copyright: Open CASCADE 2007
// The original implementation Copyright: (C) RINA S.p.A
#ifndef TObj_Persistence_HeaderFile
#define TObj_Persistence_HeaderFile
#include <TObj_Container.hxx>
class TDF_Label;
class Handle(TObj_Object);
/** This class is intended to be a root of tools (one per class)
* to manage persistence of objects inherited from TObj_Object
* It provides a mechanism to recover correctly typed
* objects (subtypes of TObj_Object) out of their persistent names
*
* This is a special kind of object, it automatically registers itself
* in a global map when created, and the only thing it does is to
* create a new object of the type that it manages, by request
*/
class TObj_Persistence
{
public:
/**
* Public methods, to be called externally
*/
//! Creates and returns a new object of the registered type
//! If the type is not registered, returns Null handle
static Standard_EXPORT Handle(TObj_Object) CreateNewObject
(const Standard_CString theType,
const TDF_Label& theLabel);
//! Dumps names of all the types registered for persistence to the
//! specified stream
static Standard_EXPORT void DumpTypes (Standard_OStream& theOs);
protected:
/**
* Protected methods, to be used or defined by descendants
*/
//! The constructor registers the object
Standard_EXPORT TObj_Persistence (const Standard_CString theType);
//! The destructor unregisters the object
virtual Standard_EXPORT ~TObj_Persistence ();
//! The method must be redefined in the derived class and return
//! new object of the proper type
virtual Standard_EXPORT Handle(TObj_Object) New
(const TDF_Label& theLabel) const = 0;
//! Dictionary storing all the registered types. It is implemented as static
//! variable inside member function in order to ensure initialization
//! at first call
static Standard_EXPORT TObj_DataMapOfStringPointer& getMapOfTypes();
private:
Standard_CString myType; //!< Name of managed type (recorded for unregistering)
};
//! Declare subclass and methods of the class inherited from TObj_Object
//! necessary for implementation of persistence
//! This declaration should be put inside class declaration, under 'protected' modifier
#ifdef SOLARIS
//! Workaround on SUN to avoid stupid warnings
#define _TOBJOCAF_PERSISTENCE_ACCESS_ public:
#else
#define _TOBJOCAF_PERSISTENCE_ACCESS_
#endif
#define DECLARE_TOBJOCAF_PERSISTENCE(name,ancestor) \
name (const TObj_Persistence *p, \
const TDF_Label& aLabel) : ancestor(p,aLabel) \
{ initFields(); } /* give the object a chance to initialize its fields */ \
\
/* Creates an object of a proper type */ \
/* First argument is used just to avoid possible conflict with other constructors */ \
_TOBJOCAF_PERSISTENCE_ACCESS_ \
class Persistence_ : public TObj_Persistence { \
/* Friend private class of name, is a tool providing persistence */ \
public: \
Persistence_ () : TObj_Persistence(#name) {} /* register the tool */ \
virtual Handle(TObj_Object) New (const TDF_Label& aLabel) const; \
/* Creates an object of a proper type */ \
}; \
friend class Persistence_; \
static Persistence_ myPersistence_; /* Static field implementing persistsnce tool */
//! Implement mechanism for registration the type for persistence
//! This should not be used for abstract classes (while DECLARE should)
#define IMPLEMENT_TOBJOCAF_PERSISTENCE(name) \
name::Persistence_ name::myPersistence_; \
Handle(TObj_Object) name::Persistence_::New (const TDF_Label& aLabel) const { \
return new name((const TObj_Persistence*)0, aLabel); \
}
#endif
#ifdef _MSC_VER
#pragma once
#endif
|