]> git.mxchange.org Git - simgear.git/blob - simgear/hla/RTI13ObjectClass.hxx
Add default constructor to simgear::Dir
[simgear.git] / simgear / hla / RTI13ObjectClass.hxx
1 // Copyright (C) 2009 - 2010  Mathias Froehlich - Mathias.Froehlich@web.de
2 //
3 // This library is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU Library General Public
5 // License as published by the Free Software Foundation; either
6 // version 2 of the License, or (at your option) any later version.
7 //
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11 // Library General Public License for more details.
12 //
13 // You should have received a copy of the GNU General Public License
14 // along with this program; if not, write to the Free Software
15 // Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
16 //
17
18 #ifndef RTI13ObjectClass_hxx
19 #define RTI13ObjectClass_hxx
20
21 #include <map>
22
23 #ifndef RTI_USES_STD_FSTREAM
24 #define RTI_USES_STD_FSTREAM
25 #endif
26
27 #include <RTI.hh>
28
29 #include <simgear/structure/SGWeakPtr.hxx>
30
31 #include "RTIObjectClass.hxx"
32
33 namespace simgear {
34
35 class RTI13Ambassador;
36 class RTIObjectInstance;
37
38 class RTI13ObjectClass : public RTIObjectClass {
39 public:
40     RTI13ObjectClass(HLAObjectClass* hlaObjectClass, RTI::ObjectClassHandle& handle, RTI13Ambassador* ambassador);
41     virtual ~RTI13ObjectClass();
42
43     const RTI::ObjectClassHandle& getHandle() const
44     { return _handle; }
45
46     virtual std::string getName() const;
47
48     virtual unsigned getNumAttributes() const;
49     virtual unsigned getAttributeIndex(const std::string& name) const;
50     virtual unsigned getOrCreateAttributeIndex(const std::string& name);
51
52     unsigned getAttributeIndex(const RTI::AttributeHandle& handle) const
53     {
54         AttributeHandleIndexMap::const_iterator i = _attributeHandleIndexMap.find(handle);
55         if (i == _attributeHandleIndexMap.end())
56             return ~0u;
57         return i->second;
58     }
59     RTI::AttributeHandle getAttributeHandle(unsigned index) const
60     {
61         if (_attributeHandleVector.size() <= index)
62             return -1;
63         return _attributeHandleVector[index];
64     }
65
66     virtual bool publish(const std::set<unsigned>& indexSet);
67     virtual bool unpublish();
68
69     virtual bool subscribe(const std::set<unsigned>& indexSet, bool);
70     virtual bool unsubscribe();
71
72     virtual RTIObjectInstance* registerObjectInstance(HLAObjectInstance* hlaObjectInstance);
73
74 private:
75     RTI::ObjectClassHandle _handle;
76     SGSharedPtr<RTI13Ambassador> _ambassador;
77
78     typedef std::map<RTI::AttributeHandle, unsigned> AttributeHandleIndexMap;
79     AttributeHandleIndexMap _attributeHandleIndexMap;
80
81     typedef std::vector<RTI::AttributeHandle> AttributeHandleVector;
82     AttributeHandleVector _attributeHandleVector;
83 };
84
85 }
86
87 #endif