6#ifndef MATERIALX_DOCUMENT
7#define MATERIALX_DOCUMENT
17MATERIALX_NAMESPACE_BEGIN
40 shared_ptr<T> doc = std::make_shared<T>(
ElementPtr(), EMPTY_STRING);
52 doc->copyContentFrom(
getSelf());
75 return addChild<NodeGraph>(name);
81 return getChildOfType<NodeGraph>(name);
87 return getChildrenOfType<NodeGraph>();
93 removeChildOfType<NodeGraph>(name);
114 geomInfo->setGeom(geom);
121 return getChildOfType<GeomInfo>(name);
127 return getChildrenOfType<GeomInfo>();
133 removeChildOfType<GeomInfo>(name);
150 geomPropDef->setGeomProp(geomprop);
157 return getChildOfType<GeomPropDef>(name);
163 return getChildrenOfType<GeomPropDef>();
169 removeChildOfType<GeomPropDef>(name);
190 return addChild<Look>(name);
196 return getChildOfType<Look>(name);
202 return getChildrenOfType<Look>();
208 removeChildOfType<Look>(name);
222 return addChild<LookGroup>(name);
228 return getChildOfType<LookGroup>(name);
234 return getChildrenOfType<LookGroup>();
240 removeChildOfType<LookGroup>(name);
254 return addChild<Collection>(name);
260 return getChildOfType<Collection>(name);
266 return getChildrenOfType<Collection>();
272 removeChildOfType<Collection>(name);
286 return addChild<TypeDef>(name);
292 return getChildOfType<TypeDef>(name);
298 return getChildrenOfType<TypeDef>();
304 removeChildOfType<TypeDef>(name);
321 const string& type = DEFAULT_TYPE_STRING,
322 const string& node = EMPTY_STRING)
324 NodeDefPtr child = addChild<NodeDef>(name);
325 if (!type.empty() && type != MULTI_OUTPUT_TYPE_STRING)
327 child->addOutput(
"out", type);
331 child->setNodeString(node);
343 const string& category,
const string& newGraphName);
348 return getChildOfType<NodeDef>(name);
354 return getChildrenOfType<NodeDef>();
360 removeChildOfType<NodeDef>(name);
377 return addChild<AttributeDef>(name);
383 return getChildOfType<AttributeDef>(name);
389 return getChildrenOfType<AttributeDef>();
395 removeChildOfType<AttributeDef>(name);
409 return addChild<TargetDef>(name);
415 return getChildOfType<TargetDef>(name);
421 return getChildrenOfType<TargetDef>();
427 removeChildOfType<TargetDef>(name);
441 return addChild<PropertySet>(name);
447 return getChildOfType<PropertySet>(name);
453 return getChildrenOfType<PropertySet>();
459 removeChildOfType<PropertySet>(name);
473 return addChild<VariantSet>(name);
479 return getChildOfType<VariantSet>(name);
485 return getChildrenOfType<VariantSet>();
491 removeChildOfType<VariantSet>(name);
505 return addChild<Implementation>(name);
511 return getChildOfType<Implementation>(name);
517 return getChildrenOfType<Implementation>();
523 removeChildOfType<Implementation>(name);
539 throw Exception(
"A unit definition name cannot be empty");
541 return addChild<UnitDef>(name);
547 return getChildOfType<UnitDef>(name);
553 return getChildrenOfType<UnitDef>();
559 removeChildOfType<UnitDef>(name);
570 throw Exception(
"A unit type definition name cannot be empty");
572 return addChild<UnitTypeDef>(name);
578 return getChildOfType<UnitTypeDef>(name);
584 return getChildrenOfType<UnitTypeDef>();
590 removeChildOfType<UnitTypeDef>(name);
657 bool validate(
string* message =
nullptr)
const override;
672 [[deprecated]] NodeDefPtr addNodeDefFromGraph(
NodeGraphPtr nodeGraph,
const string& nodeDefName,
const string& node,
const string& version,
673 bool isDefaultVersion,
const string& nodeGroup,
const string& newGraphName);
676 static const string CATEGORY;
677 static const string CMS_ATTRIBUTE;
678 static const string CMS_CONFIG_ATTRIBUTE;
682 std::unique_ptr<Cache> _cache;
689MATERIALX_NAMESPACE_END
shared_ptr< TargetDef > TargetDefPtr
A shared pointer to a TargetDef.
Definition: Definition.h:47
shared_ptr< UnitDef > UnitDefPtr
A shared pointer to a UnitDef.
Definition: Definition.h:62
shared_ptr< Implementation > ImplementationPtr
A shared pointer to an Implementation.
Definition: Definition.h:37
shared_ptr< AttributeDef > AttributeDefPtr
A shared pointer to an AttributeDef.
Definition: Definition.h:72
shared_ptr< UnitTypeDef > UnitTypeDefPtr
A shared pointer to a UnitTypeDef.
Definition: Definition.h:67
shared_ptr< const Document > ConstDocumentPtr
A shared pointer to a const Document.
Definition: Document.h:24
shared_ptr< Document > DocumentPtr
A shared pointer to a Document.
Definition: Document.h:22
shared_ptr< Element > ElementPtr
A shared pointer to an Element.
Definition: Element.h:31
shared_ptr< GeomInfo > GeomInfoPtr
A shared pointer to a GeomInfo.
Definition: Geom.h:38
shared_ptr< Collection > CollectionPtr
A shared pointer to a Collection.
Definition: Geom.h:53
shared_ptr< GeomPropDef > GeomPropDefPtr
A shared pointer to a GeomPropDef.
Definition: Geom.h:48
shared_ptr< LookGroup > LookGroupPtr
A shared pointer to a LookGroup.
Definition: Look.h:32
shared_ptr< Look > LookPtr
A shared pointer to a Look.
Definition: Look.h:27
Import and export declarations for the Core library.
std::set< string > StringSet
A set of strings.
Definition: Library.h:59
shared_ptr< NodeGraph > NodeGraphPtr
A shared pointer to a NodeGraph.
Definition: Node.h:34
shared_ptr< PropertySet > PropertySetPtr
A shared pointer to a PropertySet.
Definition: Property.h:34
shared_ptr< Value > ValuePtr
A shared pointer to a Value.
Definition: Value.h:29
shared_ptr< VariantSet > VariantSetPtr
A shared pointer to a VariantSet.
Definition: Variant.h:28
A MaterialX document, which represents the top-level element in the MaterialX ownership hierarchy.
Definition: Document.h:32
vector< PropertySetPtr > getPropertySets() const
Return a vector of all PropertySet elements in the document.
Definition: Document.h:451
TargetDefPtr addTargetDef(const string &name=EMPTY_STRING)
Add an TargetDef to the document.
Definition: Document.h:407
void removeLookGroup(const string &name)
Remove the LookGroup, if any, with the given name.
Definition: Document.h:238
void removeNodeDef(const string &name)
Remove the NodeDef, if any, with the given name.
Definition: Document.h:358
vector< LookPtr > getLooks() const
Return a vector of all Look elements in the document.
Definition: Document.h:200
void removeUnitTypeDef(const string &name)
Remove the UnitTypeDef, if any, with the given name.
Definition: Document.h:588
void removeVariantSet(const string &name)
Remove the VariantSet, if any, with the given name.
Definition: Document.h:489
vector< UnitTypeDefPtr > getUnitTypeDefs() const
Return a vector of all UnitTypeDef elements in the document.
Definition: Document.h:582
AttributeDefPtr addAttributeDef(const string &name=EMPTY_STRING)
Add an AttributeDef to the document.
Definition: Document.h:375
GeomInfoPtr getGeomInfo(const string &name) const
Return the GeomInfo, if any, with the given name.
Definition: Document.h:119
vector< InterfaceElementPtr > getMatchingImplementations(const string &nodeDef) const
Return a vector of all node implementations that match the given NodeDef string.
GeomPropDefPtr getGeomPropDef(const string &name) const
Return the GeomPropDef, if any, with the given name.
Definition: Document.h:155
TargetDefPtr getTargetDef(const string &name) const
Return the AttributeDef, if any, with the given name.
Definition: Document.h:413
ImplementationPtr getImplementation(const string &name) const
Return the Implementation, if any, with the given name.
Definition: Document.h:509
UnitTypeDefPtr getUnitTypeDef(const string &name) const
Return the UnitTypeDef, if any, with the given name.
Definition: Document.h:576
void setColorManagementSystem(const string &cms)
Set the color management system string.
Definition: Document.h:609
vector< PortElementPtr > getMatchingPorts(const string &nodeName) const
Return a vector of all port elements that match the given node name.
void removeImplementation(const string &name)
Remove the Implementation, if any, with the given name.
Definition: Document.h:521
void removeNodeGraph(const string &name)
Remove the NodeGraph, if any, with the given name.
Definition: Document.h:91
bool hasColorManagementSystem() const
Return true if a color management system string has been set.
Definition: Document.h:615
TypeDefPtr getTypeDef(const string &name) const
Return the TypeDef, if any, with the given name.
Definition: Document.h:290
vector< NodeDefPtr > getMatchingNodeDefs(const string &nodeName) const
Return a vector of all NodeDef elements that match the given node name.
CollectionPtr addCollection(const string &name=EMPTY_STRING)
Add a Collection to the document.
Definition: Document.h:252
vector< ImplementationPtr > getImplementations() const
Return a vector of all Implementation elements in the document.
Definition: Document.h:515
vector< TypeDefPtr > getTypeDefs() const
Return a vector of all TypeDef elements in the document.
Definition: Document.h:296
const string & getColorManagementConfig() const
Return the color management config string.
Definition: Document.h:643
bool validate(string *message=nullptr) const override
Validate that the given document is consistent with the MaterialX specification.
void removeGeomInfo(const string &name)
Remove the GeomInfo, if any, with the given name.
Definition: Document.h:131
vector< NodeGraphPtr > getNodeGraphs() const
Return a vector of all NodeGraph elements in the document.
Definition: Document.h:85
NodeDefPtr addNodeDefFromGraph(NodeGraphPtr nodeGraph, const string &nodeDefName, const string &category, const string &newGraphName)
Create a NodeDef and Functional Graph based on a Compound NodeGraph.
vector< UnitDefPtr > getUnitDefs() const
Return a vector of all Member elements in the TypeDef.
Definition: Document.h:551
CollectionPtr getCollection(const string &name) const
Return the Collection, if any, with the given name.
Definition: Document.h:258
void removeTypeDef(const string &name)
Remove the TypeDef, if any, with the given name.
Definition: Document.h:302
static shared_ptr< T > createDocument()
Create a new document of the given subclass.
Definition: Document.h:38
bool hasColorManagementConfig() const
Return true if a color management config string has been set.
Definition: Document.h:637
vector< TargetDefPtr > getTargetDefs() const
Return a vector of all TargetDef elements in the document.
Definition: Document.h:419
GeomPropDefPtr addGeomPropDef(const string &name, const string &geomprop)
Add a GeomPropDef to the document.
Definition: Document.h:147
StringSet getReferencedSourceUris() const
Get a list of source URI's referenced by the document.
LookGroupPtr addLookGroup(const string &name=EMPTY_STRING)
Add a LookGroup to the document.
Definition: Document.h:220
virtual void initialize()
Initialize the document, removing any existing content.
void setColorManagementConfig(const string &cmsConfig)
Set the color management config string.
Definition: Document.h:631
void removeTargetDef(const string &name)
Remove the TargetDef, if any, with the given name.
Definition: Document.h:425
GeomInfoPtr addGeomInfo(const string &name=EMPTY_STRING, const string &geom=UNIVERSAL_GEOM_NAME)
Add a GeomInfo to the document.
Definition: Document.h:111
NodeGraphPtr getNodeGraph(const string &name) const
Return the NodeGraph, if any, with the given name.
Definition: Document.h:79
LookPtr addLook(const string &name=EMPTY_STRING)
Add a Look to the document.
Definition: Document.h:188
vector< AttributeDefPtr > getAttributeDefs() const
Return a vector of all AttributeDef elements in the document.
Definition: Document.h:387
UnitDefPtr getUnitDef(const string &name) const
Return the UnitDef, if any, with the given name.
Definition: Document.h:545
void removeLook(const string &name)
Remove the Look, if any, with the given name.
Definition: Document.h:206
vector< GeomInfoPtr > getGeomInfos() const
Return a vector of all GeomInfo elements in the document.
Definition: Document.h:125
NodeGraphPtr addNodeGraph(const string &name=EMPTY_STRING)
Add a NodeGraph to the document.
Definition: Document.h:73
NodeDefPtr addNodeDef(const string &name=EMPTY_STRING, const string &type=DEFAULT_TYPE_STRING, const string &node=EMPTY_STRING)
Add a NodeDef to the document.
Definition: Document.h:320
vector< VariantSetPtr > getVariantSets() const
Return a vector of all VariantSet elements in the document.
Definition: Document.h:483
VariantSetPtr addVariantSet(const string &name=EMPTY_STRING)
Add a VariantSet to the document.
Definition: Document.h:471
NodeDefPtr getNodeDef(const string &name) const
Return the NodeDef, if any, with the given name.
Definition: Document.h:346
void upgradeVersion()
Upgrade the content of this document from earlier supported versions to the library version.
AttributeDefPtr getAttributeDef(const string &name) const
Return the AttributeDef, if any, with the given name.
Definition: Document.h:381
std::pair< int, int > getVersionIntegers() const override
Return the major and minor versions as an integer pair.
vector< OutputPtr > getMaterialOutputs() const
Return material-type outputs for all nodegraphs in the document.
ImplementationPtr addImplementation(const string &name=EMPTY_STRING)
Add an Implementation to the document.
Definition: Document.h:503
void removeAttributeDef(const string &name)
Remove the AttributeDef, if any, with the given name.
Definition: Document.h:393
vector< CollectionPtr > getCollections() const
Return a vector of all Collection elements in the document.
Definition: Document.h:264
virtual DocumentPtr copy() const
Create a deep copy of the document.
Definition: Document.h:49
vector< LookGroupPtr > getLookGroups() const
Return a vector of all LookGroup elements in the document.
Definition: Document.h:232
LookGroupPtr getLookGroup(const string &name) const
Return the LookGroup, if any, with the given name.
Definition: Document.h:226
PropertySetPtr getPropertySet(const string &name) const
Return the PropertySet, if any, with the given name.
Definition: Document.h:445
const string & getColorManagementSystem() const
Return the color management system string.
Definition: Document.h:621
LookPtr getLook(const string &name) const
Return the Look, if any, with the given name.
Definition: Document.h:194
void importLibrary(const ConstDocumentPtr &library)
Import the given document as a library within this document.
VariantSetPtr getVariantSet(const string &name) const
Return the VariantSet, if any, with the given name.
Definition: Document.h:477
void invalidateCache()
Invalidate cached data for optimized lookups within the given document.
vector< GeomPropDefPtr > getGeomPropDefs() const
Return a vector of all GeomPropDef elements in the document.
Definition: Document.h:161
void removeCollection(const string &name)
Remove the Collection, if any, with the given name.
Definition: Document.h:270
void removeGeomPropDef(const string &name)
Remove the GeomPropDef, if any, with the given name.
Definition: Document.h:167
void removeUnitDef(const string &name)
Remove the UnitDef, if any, with the given name.
Definition: Document.h:557
vector< NodeDefPtr > getNodeDefs() const
Return a vector of all NodeDef elements in the document.
Definition: Document.h:352
TypeDefPtr addTypeDef(const string &name)
Add a TypeDef to the document.
Definition: Document.h:284
PropertySetPtr addPropertySet(const string &name=EMPTY_STRING)
Add a PropertySet to the document.
Definition: Document.h:439
void removePropertySet(const string &name)
Remove the PropertySet, if any, with the given name.
Definition: Document.h:457
ValuePtr getGeomPropValue(const string &geomPropName, const string &geom=UNIVERSAL_GEOM_NAME) const
Return the value of a geometric property for the given geometry string.
const string & getAttribute(const string &attrib) const
Return the value string of the given attribute.
Definition: Element.h:504
void setAttribute(const string &attrib, const string &value)
Set the value string of the given attribute.
ElementPtr getSelf()
Return our self pointer.
Definition: Element.h:550
bool hasAttribute(const string &attrib) const
Return true if the given attribute is present.
Definition: Element.h:497
The base class for exceptions that are propagated from the MaterialX library to the client applicatio...
Definition: Exception.h:22
The base class for graph elements such as NodeGraph and Document.
Definition: Node.h:174