MaterialX 1.39.2
|
The base class for MaterialX elements. More...
#include <Element.h>
Public Member Functions | |
Element (const Element &)=delete | |
Element & | operator= (const Element &)=delete |
bool | operator== (const Element &rhs) const |
Return true if the given element tree, including all descendants, is identical to this one. | |
bool | operator!= (const Element &rhs) const |
Return true if the given element tree, including all descendants, differs from this one. | |
Category | |
void | setCategory (const string &category) |
Set the element's category string. | |
const string & | getCategory () const |
Return the element's category string. | |
Name | |
void | setName (const string &name) |
Set the element's name string. | |
const string & | getName () const |
Return the element's name string. | |
string | getNamePath (ConstElementPtr relativeTo=nullptr) const |
Return the element's hierarchical name path, relative to the root document. | |
ElementPtr | getDescendant (const string &namePath) const |
Return the element specified by the given hierarchical name path, relative to the current element. | |
File Prefix | |
void | setFilePrefix (const string &prefix) |
Set the element's file prefix string. | |
bool | hasFilePrefix () const |
Return true if the given element has a file prefix string. | |
const string & | getFilePrefix () const |
Return the element's file prefix string. | |
const string & | getActiveFilePrefix () const |
Return the file prefix string that is active at the scope of this element, taking all ancestor elements into account. | |
Geom Prefix | |
void | setGeomPrefix (const string &prefix) |
Set the element's geom prefix string. | |
bool | hasGeomPrefix () const |
Return true if the given element has a geom prefix string. | |
const string & | getGeomPrefix () const |
Return the element's geom prefix string. | |
const string & | getActiveGeomPrefix () const |
Return the geom prefix string that is active at the scope of this element, taking all ancestor elements into account. | |
Color Space | |
void | setColorSpace (const string &colorSpace) |
Set the element's color space string. | |
bool | hasColorSpace () const |
Return true if the given element has a color space string. | |
const string & | getColorSpace () const |
Return the element's color space string. | |
const string & | getActiveColorSpace () const |
Return the color space string that is active at the scope of this element, taking all ancestor elements into account. | |
Inheritance | |
void | setInheritString (const string &inherit) |
Set the inherit string of this element. | |
bool | hasInheritString () const |
Return true if this element has an inherit string. | |
const string & | getInheritString () const |
Return the inherit string of this element. | |
void | setInheritsFrom (ConstElementPtr super) |
Set the element that this one directly inherits from. | |
ElementPtr | getInheritsFrom () const |
Return the element, if any, that this one directly inherits from. | |
bool | hasInheritedBase (ConstElementPtr base) const |
Return true if this element has the given element as an inherited base, taking the full inheritance chain into account. | |
bool | hasInheritanceCycle () const |
Return true if the inheritance chain for this element contains a cycle. | |
Namespace | |
void | setNamespace (const string &space) |
Set the namespace string of this element. | |
bool | hasNamespace () const |
Return true if this element has a namespace string. | |
const string & | getNamespace () const |
Return the namespace string of this element. | |
string | getQualifiedName (const string &name) const |
Return a qualified version of the given name, taking the namespace at the scope of this element into account. | |
Documentation String | |
void | setDocString (const string &doc) |
Set the documentation string of this element. | |
string | getDocString () const |
Return the documentation string of this element. | |
Subclass | |
template<class T> | |
bool | isA (const string &category=EMPTY_STRING) const |
Return true if this element belongs to the given subclass. | |
template<class T> | |
shared_ptr< T > | asA () |
Dynamic cast to an instance of the given subclass. | |
template<class T> | |
shared_ptr< const T > | asA () const |
Dynamic cast to a const instance of the given subclass. | |
Child Elements | |
template<class T> | |
shared_ptr< T > | addChild (const string &name=EMPTY_STRING) |
Add a child element of the given subclass and name. | |
ElementPtr | addChildOfCategory (const string &category, string name=EMPTY_STRING) |
Add a child element of the given category and name. | |
ElementPtr | changeChildCategory (ElementPtr child, const string &category) |
Change the category of the given child element. | |
ElementPtr | getChild (const string &name) const |
Return the child element, if any, with the given name. | |
template<class T> | |
shared_ptr< T > | getChildOfType (const string &name) const |
Return the child element, if any, with the given name and subclass. | |
const vector< ElementPtr > & | getChildren () const |
Return a constant vector of all child elements. | |
template<class T> | |
vector< shared_ptr< T > > | getChildrenOfType (const string &category=EMPTY_STRING) const |
Return a vector of all child elements that are instances of the given subclass, optionally filtered by the given category string. | |
void | setChildIndex (const string &name, int index) |
Set the index of the child, if any, with the given name. | |
int | getChildIndex (const string &name) const |
Return the index of the child, if any, with the given name. | |
void | removeChild (const string &name) |
Remove the child element, if any, with the given name. | |
template<class T> | |
void | removeChildOfType (const string &name) |
Remove the child element, if any, with the given name and subclass. | |
Attributes | |
void | setAttribute (const string &attrib, const string &value) |
Set the value string of the given attribute. | |
bool | hasAttribute (const string &attrib) const |
Return true if the given attribute is present. | |
const string & | getAttribute (const string &attrib) const |
Return the value string of the given attribute. | |
const StringVec & | getAttributeNames () const |
Return a vector of stored attribute names, in the order they were set. | |
template<class T> | |
void | setTypedAttribute (const string &attrib, const T &data) |
Set the value of an implicitly typed attribute. | |
template<class T> | |
T | getTypedAttribute (const string &attrib) const |
Return the value of an implicitly typed attribute. | |
void | removeAttribute (const string &attrib) |
Remove the given attribute, if present. | |
Self And Ancestor Elements | |
ElementPtr | getSelf () |
Return our self pointer. | |
ConstElementPtr | getSelf () const |
Return our self pointer. | |
ElementPtr | getParent () |
Return our parent element. | |
ConstElementPtr | getParent () const |
Return our parent element. | |
ElementPtr | getRoot () |
Return the root element of our tree. | |
ConstElementPtr | getRoot () const |
Return the root element of our tree. | |
DocumentPtr | getDocument () |
Return the root document of our tree. | |
ConstDocumentPtr | getDocument () const |
Return the root document of our tree. | |
template<class T> | |
shared_ptr< T > | getAncestorOfType () |
Return the first ancestor of the given subclass, or an empty shared pointer if no ancestor of this subclass is found. | |
template<class T> | |
shared_ptr< const T > | getAncestorOfType () const |
Return the first ancestor of the given subclass, or an empty shared pointer if no ancestor of this subclass is found. | |
Functional Equivalence | |
bool | isEquivalent (ConstElementPtr rhs, const ElementEquivalenceOptions &options, string *message=nullptr) const |
Return true if the given element tree, including all descendents, is considered to be equivalent to this one based on the equivalence criteria provided. | |
virtual bool | isAttributeEquivalent (ConstElementPtr rhs, const string &attributeName, const ElementEquivalenceOptions &options, string *message=nullptr) const |
Return true if the attribute on a given element is equivalent based on the equivalence criteria provided. | |
Traversal | |
TreeIterator | traverseTree () const |
Traverse the tree from the given element to each of its descendants in depth-first order, using pre-order visitation. | |
GraphIterator | traverseGraph () const |
Traverse the dataflow graph from the given element to each of its upstream sources in depth-first order, using pre-order visitation. | |
virtual Edge | getUpstreamEdge (size_t index=0) const |
Return the Edge with the given index that lies directly upstream from this element in the dataflow graph. | |
virtual size_t | getUpstreamEdgeCount () const |
Return the number of queryable upstream edges for this element. | |
ElementPtr | getUpstreamElement (size_t index=0) const |
Return the Element with the given index that lies directly upstream from this one in the dataflow graph. | |
InheritanceIterator | traverseInheritance () const |
Traverse the inheritance chain from the given element to each element from which it inherits. | |
Source URI | |
void | setSourceUri (const string &sourceUri) |
Set the element's source URI. | |
bool | hasSourceUri () const |
Return true if this element has a source URI. | |
const string & | getSourceUri () const |
Return the element's source URI. | |
const string & | getActiveSourceUri () const |
Return the source URI that is active at the scope of this element, taking all ancestor elements into account. | |
Validation | |
virtual bool | validate (string *message=nullptr) const |
Validate that the given element tree, including all descendants, is consistent with the MaterialX specification. | |
Utility | |
void | copyContentFrom (const ConstElementPtr &source) |
Copy all attributes and descendants from the given element to this one. | |
virtual void | clearContent () |
Clear all attributes and descendants from this element. | |
string | createValidChildName (string name) const |
Using the input name as a starting point, modify it to create a valid, unique name for a child element. | |
StringResolverPtr | createStringResolver (const string &geom=EMPTY_STRING) const |
Construct a StringResolver at the scope of this element. | |
string | asString () const |
Return a single-line description of this element, including its category, name, and attributes. | |
Protected Types | |
using | DocumentPtr = shared_ptr<Document> |
using | ConstDocumentPtr = shared_ptr<const Document> |
Protected Member Functions | |
Element (ElementPtr parent, const string &category, const string &name) | |
template<class T> | |
shared_ptr< T > | resolveNameReference (const string &name, ConstElementPtr parent=nullptr) const |
void | validateRequire (bool expression, bool &res, string *message, const string &errorDesc) const |
virtual void | registerChildElement (ElementPtr child) |
virtual void | unregisterChildElement (ElementPtr child) |
ElementPtr | getSelfNonConst () const |
Protected Attributes | |
string | _category |
string | _name |
string | _sourceUri |
ElementMap | _childMap |
vector< ElementPtr > | _childOrder |
StringMap | _attributeMap |
StringVec | _attributeOrder |
weak_ptr< Element > | _parent |
weak_ptr< Element > | _root |
Friends | |
template<class T> | |
class | ElementRegistry |
The base class for MaterialX elements.
An Element is a named object within a Document, which may possess any number of child elements and attributes.
shared_ptr< T > addChild | ( | const string & | name = EMPTY_STRING | ) |
Add a child element of the given subclass and name.
name | The name of the new child element. If no name is specified, then a unique name will automatically be generated. |
Exception | if a child of this element already possesses the given name. |
ElementPtr addChildOfCategory | ( | const string & | category, |
string | name = EMPTY_STRING ) |
Add a child element of the given category and name.
category | The category string of the new child element. If the category string is recognized, then the corresponding Element subclass is generated; otherwise, a GenericElement is generated. |
name | The name of the new child element. If no name is specified, then a unique name will automatically be generated. |
Exception | if a child of this element already possesses the given name. |
ElementPtr changeChildCategory | ( | ElementPtr | child, |
const string & | category ) |
Change the category of the given child element.
child | The child element that will be modified. |
category | The new category string for the child element. |
|
virtual |
Clear all attributes and descendants from this element.
Reimplemented in InterfaceElement.
void copyContentFrom | ( | const ConstElementPtr & | source | ) |
Copy all attributes and descendants from the given element to this one.
source | The element from which content is copied. |
StringResolverPtr createStringResolver | ( | const string & | geom = EMPTY_STRING | ) | const |
Construct a StringResolver at the scope of this element.
The returned object may be used to apply substring modifiers to data values in the context of a specific element, geometry, and material.
geom | An optional geometry name, which will be used to select the applicable set of geometry token substitutions. By default, no geometry token substitutions are applied. If the universal geometry name "/" is given, then all geometry token substitutions are applied, |
|
inline |
Return the value string of the given attribute.
If the given attribute is not present, then an empty string is returned.
|
inline |
Return the element's category string.
The category of a MaterialX element represents its role within the document, with common examples being "material", "nodegraph", and "image".
int getChildIndex | ( | const string & | name | ) | const |
Return the index of the child, if any, with the given name.
If no child with the given name is found, then -1 is returned.
shared_ptr< T > getChildOfType | ( | const string & | name | ) | const |
Return the child element, if any, with the given name and subclass.
If a child with the given name exists, but belongs to a different subclass, then an empty shared pointer is returned.
|
inline |
Return a constant vector of all child elements.
The returned vector maintains the order in which children were added.
vector< shared_ptr< T > > getChildrenOfType | ( | const string & | category = EMPTY_STRING | ) | const |
Return a vector of all child elements that are instances of the given subclass, optionally filtered by the given category string.
The returned vector maintains the order in which children were added.
ElementPtr getDescendant | ( | const string & | namePath | ) | const |
Return the element specified by the given hierarchical name path, relative to the current element.
If the name path is empty then the current element is returned. If no element is found at the given path, then an empty shared pointer is returned.
namePath | The relative name path of the specified element. |
string getNamePath | ( | ConstElementPtr | relativeTo = nullptr | ) | const |
Return the element's hierarchical name path, relative to the root document.
The name of each ancestor will be prepended in turn, separated by forward slashes.
relativeTo | If a valid ancestor element is specified, then the returned path will be relative to this ancestor. |
|
inline |
Return the value of an implicitly typed attribute.
If the given attribute is not present, or cannot be converted to the given data type, then the zero value for the data type is returned.
|
virtual |
Return the Edge with the given index that lies directly upstream from this element in the dataflow graph.
index | An optional index of the edge to be returned, where the valid index range may be determined with getUpstreamEdgeCount. |
|
inlinevirtual |
ElementPtr getUpstreamElement | ( | size_t | index = 0 | ) | const |
Return the Element with the given index that lies directly upstream from this one in the dataflow graph.
index | An optional index of the element to be returned, where the valid index range may be determined with getUpstreamEdgeCount. |
|
inline |
Return true if this element belongs to the given subclass.
If a category string is specified, then both subclass and category matches are required.
|
virtual |
Return true if the attribute on a given element is equivalent based on the equivalence criteria provided.
rhs | Element to compare against |
attributeName | Name of attribute to compare |
options | Equivalence criteria |
message | Optional text description of differences |
Reimplemented in ValueElement.
bool isEquivalent | ( | ConstElementPtr | rhs, |
const ElementEquivalenceOptions & | options, | ||
string * | message = nullptr ) const |
Return true if the given element tree, including all descendents, is considered to be equivalent to this one based on the equivalence criteria provided.
rhs | Element to compare against |
options | Equivalence criteria |
message | Optional text description of differences |
|
inline |
Remove the child element, if any, with the given name and subclass.
If a child with the given name exists, but belongs to a different subclass, then this method has no effect.
void setChildIndex | ( | const string & | name, |
int | index ) |
Set the index of the child, if any, with the given name.
If the given index is out of bounds, then an exception is thrown.
void setName | ( | const string & | name | ) |
Set the element's name string.
The name of a MaterialX element must be unique among all elements at the same scope.
Exception | if an element at the same scope already possesses the given name. |
|
inline |
Set the element's source URI.
sourceUri | A URI string representing the resource from which this element originates. This string may be used by serialization and deserialization routines to maintain hierarchies of include references. |
|
inline |
Set the value of an implicitly typed attribute.
Since an attribute stores no explicit type, the same type argument must be used in corresponding calls to getTypedAttribute.
GraphIterator traverseGraph | ( | ) | const |
Traverse the dataflow graph from the given element to each of its upstream sources in depth-first order, using pre-order visitation.
ExceptionFoundCycle | if a cycle is encountered. |
Example usage with an implicit iterator:
Example usage with an explicit iterator:
InheritanceIterator traverseInheritance | ( | ) | const |
Traverse the inheritance chain from the given element to each element from which it inherits.
ExceptionFoundCycle | if a cycle is encountered. |
Example usage:
TreeIterator traverseTree | ( | ) | const |
Traverse the tree from the given element to each of its descendants in depth-first order, using pre-order visitation.
Example usage with an implicit iterator:
Example usage with an explicit iterator:
|
virtual |
Validate that the given element tree, including all descendants, is consistent with the MaterialX specification.
Reimplemented in Backdrop, Collection, Document, GeomElement, Implementation, Input, Node, NodeDef, NodeGraph, Output, PortElement, and ValueElement.