This file is indexed.

/usr/include/BALL/CONCEPT/embeddable.h is in libball1.4-dev 1.4.3~beta1-4.

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
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
// -*- Mode: C++; tab-width: 2; -*-
// vi: set ts=2:
//

#ifndef BALL_CONCEPT_EMBEDDABLE_H
#define BALL_CONCEPT_EMBEDDABLE_H

#ifndef BALL_COMMON_H
#	include <BALL/common.h>
#endif

#ifndef BALL_DATATYPE_STRINGHASHMAP_H
#	include <BALL/DATATYPE/stringHashMap.h>
#endif

#ifndef BALL_DATATYPE_HASHMAP_H
#	include <BALL/DATATYPE/hashMap.h>
#endif

#include <typeinfo>

namespace BALL 
{

	/** Embeddable macro.
			This macro defines all methods required for clases
			derived from Embeddable. It should be included in the class definition
			of each of these classes, even for classes further down in the inheritance.
			The argument ist just the class type, e.g. BALL::ModularWidget.
	*/
	#define BALL_EMBEDDABLE(TYPE,BASE)\
		virtual void registerThis()  \
		{ \
			if (typeid(*this) != typeid(TYPE))\
			{\
				Log.error() << "Warning: derived class " << typeid(*this).name() << " was derived from BALL::Embeddable, but the macro\n"\
                  << "BALL_EMBEDDABLE(...) was not specified in the class declaration!" << std::endl;\
			}\
			Embeddable::registerInstance_(typeid(TYPE), this);\
			Embeddable::registerInstance_(typeid(BASE), this);\
		}\
		\
		static TYPE* getInstance(Position index)  \
		{ \
			Embeddable* ptr = Embeddable::getInstance_(typeid(TYPE), index);\
			if (ptr != 0)\
			{\
				return dynamic_cast<TYPE*>(ptr); \
			}\
			else\
			{\
				return 0;\
			}\
		}\
		static TYPE* getInstance(const String& identifier) \
		{\
			Embeddable* ptr = Embeddable::getInstance_(typeid(TYPE), identifier);\
			if (ptr != 0)\
			{\
				return dynamic_cast<TYPE*>(ptr); \
			}\
			else\
			{\
				return 0;\
			}\
		}\
		static Size countInstances()  { return (Embeddable::countInstances_(typeid(TYPE))); };
	
	/**	Python Embedding Base Class.
			This class defines a common interface for all classes that
			have to be accessible from an embedded Python interpreter.
			Each instance of a class derived from embeddable can be registered by calling
			registerThis() of the instance and is then accessible through the static methods
			of the class (e.g. getInstance).
		 \par
			@see PyInterpreter
			@see MainControl
			@see ModularWidget
	 	 \ingroup ConceptsMiscellaneous
	*/
	class BALL_EXPORT Embeddable
	{
		public:

		/**	@name Type definitions
		*/
		//@{
		typedef std::vector<Embeddable*> EmbeddableVector;
		//@}

		/**	@name Constructors and Destructors
		*/
		//@{

		/**	Default constructor
		*/
		Embeddable(const String& identifier = "<Embeddable>")
			;
		
		/**	Copy constructor
		*/
		Embeddable(const Embeddable& embeddable)
			;
		
		/**
		*/
		virtual ~Embeddable()
			;
		//@}

		/**	@name	Accessors
		*/
		//@{

		/**	Return the instance identifier
		*/
		void setIdentifier(const String& identifier)
			;

		/**	Assign a new identifier
		*/
		const String& getIdentifier() const
			;

		/**	Unregister the instance.
		*/
		void unregisterThis()
			;

		/**	Register the instance.
				DO NOT IMPLEMENT THIS METHOD! It is automatically implemented
				correctly when putting the  \link BALL_EMBEDDABLE BALL_EMBEDDABLE \endlink  macro in a class
				definition.
				@see getInstanceVector
		*/
		virtual void registerThis()
			;	

		//@}
		
		/** Internal value dump.
				Dump the current state to 
				the output ostream <b> s</b> with dumping depth <b> depth</b>.
				\param   s output stream where to output the state 
				\param   depth the dumping depth
		*/
		virtual void dump(std::ostream& s = std::cout, Size depth = 0) const
			;

		protected:
		/**
		*/
		static void registerInstance_(const std::type_info& type, const Embeddable* instance)
			;
		/**
		*/
		static void unregisterInstance_(const Embeddable* instance)
			;
		
		/**	Return the number of instances of a certain type
		*/
		static Size countInstances_(const std::type_info& type)
			;

		/**	Return an instance of a registered type by its index.
				If the index is out of bounds or the position is
				invalid, a null pointer is returned 
		*/
		static Embeddable* getInstance_(const std::type_info& type, Position index)
			;

		/**	Return an instance of a registered type by its identifier.
				If the identifier does not exist, a null pointer is returned 
		*/
		static Embeddable* getInstance_(const std::type_info& type, const String& identifier)
			;


		private:
		
		/**	An identifier for the class
		*/
		String	identifier_;

		/**	The instance vectors
		*/
		static StringHashMap<EmbeddableVector>	instance_vectors_;

		/**	A hash map to retrieve the class ID for each instance.
		*/
		static HashMap<Embeddable*, string>		instance_to_type_map_;
	};

} // namespace BALL

#endif // BALL_CONCEPT_EMBEDDABLE_H