This is a specialization of EggNameUniquifier to generate unique names for EggGroup nodes. More...
#include "eggGroupUniquifier.h"
Public Member Functions | |
EggGroupUniquifier (bool filter_names=true) | |
If filter_names is true, then the group names will be coerced into a fairly safe, standard convention that uses no characters other than a-z, A-Z, 0-9, and underscore. More... | |
virtual std::string | filter_name (EggNode *node) |
Returns the name of the given node, or at least the name it should be. More... | |
virtual TypeHandle | force_init_type () |
virtual std::string | generate_name (EggNode *node, const std::string &category, int index) |
Generates a new name for the given node when its existing name clashes with some other node. More... | |
virtual std::string | get_category (EggNode *node) |
Returns the category name into which the given node should be collected, or the empty string if the node's name should be left alone. More... | |
virtual TypeHandle | get_type () const |
Public Member Functions inherited from EggNameUniquifier | |
bool | add_name (const std::string &category, const std::string &name, EggNode *node=nullptr) |
Adds the name to the indicated category. More... | |
void | clear () |
Empties the table of used named and prepares the Uniquifier for a new tree. More... | |
EggNode * | get_node (const std::string &category, const std::string &name) const |
Returns the node associated with the given category and name, or NULL if the name has not been used. More... | |
bool | has_name (const std::string &category, const std::string &name) const |
Returns true if the name has been used for the indicated category already, false otherwise. More... | |
void | uniquify (EggNode *node) |
Begins the traversal from the indicated node. More... | |
Public Member Functions inherited from EggObject | |
EggObject (const EggObject ©) | |
virtual EggTransform * | as_transform () |
Returns this object cross-cast to an EggTransform pointer, if it inherits from EggTransform, or NULL if it does not. More... | |
void | clear_user_data () |
Removes *all* user data pointers from the node. More... | |
void | clear_user_data (TypeHandle type) |
Removes the user data pointer of the indicated type. More... | |
EggUserData * | get_user_data () const |
Returns the user data pointer most recently stored on this object, or NULL if nothing was previously stored. More... | |
EggUserData * | get_user_data (TypeHandle type) const |
Returns the user data pointer of the indicated type, if it exists, or NULL if it does not. More... | |
bool | has_user_data () const |
Returns true if a generic user data pointer has recently been set and not yet cleared, false otherwise. More... | |
bool | has_user_data (TypeHandle type) const |
Returns true if the user data pointer of the indicated type has been set, false otherwise. More... | |
EggObject & | operator= (const EggObject ©) |
void | set_user_data (EggUserData *user_data) |
Sets the user data associated with this object. More... | |
Public Member Functions inherited from TypedReferenceCount | |
TypedReferenceCount (const TypedReferenceCount ©) | |
void | operator= (const TypedReferenceCount ©) |
Public Member Functions inherited from TypedObject | |
TypedObject (const TypedObject ©)=default | |
TypedObject * | as_typed_object () |
Returns the object, upcast (if necessary) to a TypedObject pointer. More... | |
const TypedObject * | as_typed_object () const |
Returns the object, upcast (if necessary) to a TypedObject pointer. More... | |
int | get_best_parent_from_Set (const std::set< int > &) const |
int | get_type_index () const |
Returns the internal index number associated with this object's TypeHandle, a unique number for each different type. More... | |
bool | is_exact_type (TypeHandle handle) const |
Returns true if the current object is the indicated type exactly. More... | |
bool | is_of_type (TypeHandle handle) const |
Returns true if the current object is or derives from the indicated type. More... | |
TypedObject & | operator= (const TypedObject ©)=default |
Public Member Functions inherited from ReferenceCount | |
int | get_ref_count () const |
WeakReferenceList * | get_weak_list () const |
Returns the WeakReferenceList associated with this ReferenceCount object. More... | |
bool | has_weak_list () const |
Returns true if this particular ReferenceCount object has a WeakReferenceList created, false otherwise. More... | |
void | local_object () |
This function should be called, once, immediately after creating a new instance of some ReferenceCount-derived object on the stack. More... | |
void | ref () const |
Explicitly increments the reference count. More... | |
bool | ref_if_nonzero () const |
Atomically increases the reference count of this object if it is not zero. More... | |
bool | test_ref_count_integrity () const |
Does some easy checks to make sure that the reference count isn't completely bogus. More... | |
bool | test_ref_count_nonzero () const |
Does some easy checks to make sure that the reference count isn't zero, or completely bogus. More... | |
virtual bool | unref () const |
Explicitly decrements the reference count. More... | |
WeakReferenceList * | weak_ref () |
Adds the indicated PointerToVoid as a weak reference to this object. More... | |
void | weak_unref () |
Removes the indicated PointerToVoid as a weak reference to this object. More... | |
Static Public Member Functions | |
static TypeHandle | get_class_type () |
static void | init_type () |
Static Public Member Functions inherited from EggNameUniquifier | |
static TypeHandle | get_class_type () |
static void | init_type () |
Static Public Member Functions inherited from EggObject | |
static TypeHandle | get_class_type () |
static void | init_type () |
Static Public Member Functions inherited from TypedReferenceCount | |
static TypeHandle | get_class_type () |
static void | init_type () |
Static Public Member Functions inherited from TypedObject | |
static TypeHandle | get_class_type () |
static void | init_type () |
This function is declared non-inline to work around a compiler bug in g++ 2.96. More... | |
Static Public Member Functions inherited from ReferenceCount | |
static TypeHandle | get_class_type () |
static void | init_type () |
Additional Inherited Members | |
Public Attributes inherited from TypedObject | |
get_type | |
Public Attributes inherited from ReferenceCount | |
get_ref_count | |
Returns the current reference count. More... | |
This is a specialization of EggNameUniquifier to generate unique names for EggGroup nodes.
It's not called automatically; you must invoke it yourself if you want it.
Definition at line 26 of file eggGroupUniquifier.h.
|
explicit |
If filter_names is true, then the group names will be coerced into a fairly safe, standard convention that uses no characters other than a-z, A-Z, 0-9, and underscore.
If filter_names is false, the group names will be left unchanged.
Definition at line 33 of file eggGroupUniquifier.cxx.
|
virtual |
Returns the name of the given node, or at least the name it should be.
This provides a hook to adjust the name before attempting to uniquify it, if desired, for instance to remove invalid characters.
Reimplemented from EggNameUniquifier.
Definition at line 57 of file eggGroupUniquifier.cxx.
|
virtual |
Generates a new name for the given node when its existing name clashes with some other node.
This function will be called repeatedly, if necessary, until it returns a name that actually is unique.
The category is the string returned by get_category(), and index is a uniquely-generated number that may be useful for synthesizing the name.
Reimplemented from EggNameUniquifier.
Definition at line 99 of file eggGroupUniquifier.cxx.
|
virtual |
Returns the category name into which the given node should be collected, or the empty string if the node's name should be left alone.
Implements EggNameUniquifier.
Definition at line 43 of file eggGroupUniquifier.cxx.
References Namable::has_name(), and TypedObject::is_of_type().