*/
SGPropertyNode::SGPropertyNode ()
: _name(copy_string("")),
+ _display_name(0),
_index(0),
_parent(0),
_path(0),
* Copy constructor.
*/
SGPropertyNode::SGPropertyNode (const SGPropertyNode &node)
- : _index(node._index),
+ : _display_name(0),
+ _index(node._index),
_parent(0), // don't copy the parent
_path(0),
_path_cache(0),
SGPropertyNode::SGPropertyNode (const char * name,
int index,
SGPropertyNode * parent)
- : _index(index),
+ : _display_name(0),
+ _index(index),
_parent(parent),
_path(0),
_path_cache(0),
SGPropertyNode::~SGPropertyNode ()
{
delete [] _name;
- delete _path;
+ delete [] _display_name;
+ delete [] _path;
delete _path_cache;
clear_value();
delete _listeners;
}
+const char *
+SGPropertyNode::getDisplayName (bool simplify) const
+{
+ string display = _name;
+ if (_index != 0 || !simplify) {
+ char buffer[64];
+ sprintf(buffer, "[%d]", _index);
+ display += buffer;
+ }
+ _display_name = copy_string(display.c_str());
+ return _display_name;
+}
+
+
const char *
SGPropertyNode::getPath (bool simplify) const
{
} else {
path = _parent->getPath(simplify);
path += '/';
- path += _name;
- if (_index != 0 || !simplify) {
- char buffer[64];
- sprintf(buffer, "[%d]", _index);
- path += buffer;
- }
+ path += getDisplayName(simplify);
}
_path = copy_string(path.c_str());
}