GraphDescription Class Reference

#include <graphdescription.h>

Detailed Description

Provides functions and constants to read and write node graphs from and into the graph description format.

A graph description is JSON-like format to describe complete or partial node graphs for arbitrary node spaces. Graph descriptions can describe node types and their attributes over their labels in a natural language, absolute and lazy node paths, and queries to select entities in a graph by their values. Graph descriptions are primarily intended to be written and read from the Python API which binds to this class.

Public Types

enum class  PARSE_FLAGS {
  NONE ,
  VERBOSE_ATTRIBUTES ,
  VERBOSE_REFERENCES ,
  ALWAYS_VALIDATE_PATHS
}
 
enum class  QUERY_FLAGS {
  NONE ,
  MATCH_FIRST ,
  MATCH_ALL ,
  MATCH_MAYBE ,
  SELECT_THIS
}
 

Public Member Functions

enum maxon::nodes::GraphDescription::PARSE_FLAGS MAXON_ENUM_FLAGS_CLASS (PARSE_FLAGS)
 
enum maxon::nodes::GraphDescription::QUERY_FLAGS MAXON_ENUM_FLAGS_CLASS (QUERY_FLAGS)
 

Static Public Member Functions

static MAXON_METHOD String GetDescriptionKey ()
 
static MAXON_METHOD String GetFlagsKey ()
 
static MAXON_METHOD String GetIdKey ()
 
static MAXON_METHOD String GetLanguageKey ()
 
static MAXON_METHOD String GetQueryKey ()
 
static MAXON_METHOD String GetQueryModeKey ()
 
static MAXON_METHOD String GetSpaceKey ()
 
static MAXON_METHOD String GetTypeKey ()
 
static MAXON_METHOD String GetCommandsKey ()
 
static MAXON_METHOD String GetGroupCommandKey ()
 
static MAXON_METHOD String GetUnGroupCommandKey ()
 
static MAXON_METHOD String GetRemoveNodeCommandKey ()
 
static MAXON_METHOD String GetDefaultNodeCommandKey ()
 
static MAXON_METHOD String GetDisconnectCommandKey ()
 
static MAXON_METHOD String GetSetPortCountCommandKey ()
 
static MAXON_METHOD String GetShowPortsCommandKey ()
 
static MAXON_METHOD String GetHidePortsCommandKey ()
 
static MAXON_METHOD Result< DataDictionary > GenerateDescription (NodesGraphModelRef &graph, DataDictionary description)
 
static MAXON_METHOD Result< DataDictionary > TranslateDescription (DataDictionary description)
 
static MAXON_METHOD Result< DataDictionary > ApplyDescription (NodesGraphModelRef &graph, DataDictionary description)
 
static MAXON_METHOD Result< nodes::NodesGraphModelRef > CreateGraph (cinema::BaseList2D *element, Id &nodeSpaceId, const Bool createEmpty, const String &name)
 
static MAXON_METHOD Result< nodes::NodesGraphModelRef > GetGraph (cinema::BaseList2D *element, Id &nodeSpaceId, const Bool createEmpty, const String &name)
 
static MAXON_METHOD Result< BaseArray< nodes::NodesGraphModelRef > > GetMaterialGraphs (const cinema::BaseDocument *const doc, const Id &nodeSpaceId)
 

Private Member Functions

 MAXON_INTERFACE_NONVIRTUAL (GraphDescription, MAXON_REFERENCE_STATIC, "net.maxon.node.interface.graphdescription")
 

Member Enumeration Documentation

◆ PARSE_FLAGS

enum PARSE_FLAGS
strong

Expresses options when parsing graph descriptions.

Note
Currently unused.
Enumerator
NONE 

Marks a description as having no special flags.

VERBOSE_ATTRIBUTES 

Marks a description as also encoding attributes which hold default values instead of omitting them.

VERBOSE_REFERENCES 

Marks a description as exclusively using identifiers instead of labels to reference nodes and attributes.

ALWAYS_VALIDATE_PATHS 

Marks a description as always validating absolute node paths with the underlying graph description cache.

◆ QUERY_FLAGS

enum QUERY_FLAGS
strong

Expresses options when querying a graph for nodes.

Enumerator
NONE 

Marks a query as having no special flags.

MATCH_FIRST 

Marks a query to pick the first match when ambiguous. Dominant over MATCH_ALL. When no match flag is set, a query must be unambiguous.

MATCH_ALL 

Marks a query to pick all matches when ambiguous. Suppressed by MATCH_FIRST. When no match flag is set, a query must be unambiguous.

MATCH_MAYBE 

Marks a query to match lazily, instead of raising an error, a non-matching sub-graph will simply not be executed.

SELECT_THIS 

Marks the to be selected element in a query. When a query does not contain a selection marker, the out most element will be selected.

Member Function Documentation

◆ MAXON_INTERFACE_NONVIRTUAL()

MAXON_INTERFACE_NONVIRTUAL ( GraphDescription  ,
MAXON_REFERENCE_STATIC  ,
"net.maxon.node.interface.graphdescription"   
)
private

◆ MAXON_ENUM_FLAGS_CLASS() [1/2]

enum maxon::nodes::GraphDescription::PARSE_FLAGS MAXON_ENUM_FLAGS_CLASS ( PARSE_FLAGS  )

◆ MAXON_ENUM_FLAGS_CLASS() [2/2]

enum maxon::nodes::GraphDescription::QUERY_FLAGS MAXON_ENUM_FLAGS_CLASS ( QUERY_FLAGS  )

◆ GetDescriptionKey()

static MAXON_METHOD String GetDescriptionKey ( )
static

Returns the key for a description field in a description. Alias for "$description".

◆ GetFlagsKey()

static MAXON_METHOD String GetFlagsKey ( )
static

Returns the key for a flags field in a description. Alias for "$flags".

◆ GetIdKey()

static MAXON_METHOD String GetIdKey ( )
static

Returns the key for a node ID field in a description. Alias for "$id".

◆ GetLanguageKey()

static MAXON_METHOD String GetLanguageKey ( )
static

Returns the key for a language ID field in a description. Alias for "$language".

◆ GetQueryKey()

static MAXON_METHOD String GetQueryKey ( )
static

Returns the key for a query field in a description. Alias for "$query".

◆ GetQueryModeKey()

static MAXON_METHOD String GetQueryModeKey ( )
static

Returns the key for a query mode field in a description. Alias for "$qmode".

◆ GetSpaceKey()

static MAXON_METHOD String GetSpaceKey ( )
static

Returns the key for a node space ID field in a description. Alias for "$space".

◆ GetTypeKey()

static MAXON_METHOD String GetTypeKey ( )
static

Returns the key for a node type field in a description. Alias for "$type".

◆ GetCommandsKey()

static MAXON_METHOD String GetCommandsKey ( )
static

Returns the key for a node command field in a description. Alias for "$commands".

◆ GetGroupCommandKey()

static MAXON_METHOD String GetGroupCommandKey ( )
static

Returns the command key for grouping a node. Alias for "$cmd_group".

◆ GetUnGroupCommandKey()

static MAXON_METHOD String GetUnGroupCommandKey ( )
static

Returns the command key for grouping a node. Alias for "$cmd_ungroup".

◆ GetRemoveNodeCommandKey()

static MAXON_METHOD String GetRemoveNodeCommandKey ( )
static

Returns the command key for a removing a node. Alias for "$cmd_remove".

◆ GetDefaultNodeCommandKey()

static MAXON_METHOD String GetDefaultNodeCommandKey ( )
static

Returns the command key for setting a node to its defaults. Alias for "$cmd_default".

◆ GetDisconnectCommandKey()

static MAXON_METHOD String GetDisconnectCommandKey ( )
static

Returns the command key for removing all wires from a node. Alias for "$cmd_disconnect".

◆ GetSetPortCountCommandKey()

static MAXON_METHOD String GetSetPortCountCommandKey ( )
static

Returns the command key for changing the number of varidadic children of the variadic ports of a node. Alias for "$cmd_count_ports".

◆ GetShowPortsCommandKey()

static MAXON_METHOD String GetShowPortsCommandKey ( )
static

Returns the command key for showing the ports of a node. Alias for "$cmd_show_ports".

◆ GetHidePortsCommandKey()

static MAXON_METHOD String GetHidePortsCommandKey ( )
static

Returns the command key for hiding the ports of a node. Alias for "$cmd_hide_ports".

◆ GenerateDescription()

static MAXON_METHOD Result<DataDictionary> GenerateDescription ( NodesGraphModelRef &  graph,
DataDictionary  description 
)
static

Not yet implemented.

◆ TranslateDescription()

static MAXON_METHOD Result<DataDictionary> TranslateDescription ( DataDictionary  description)
static

Not yet implemented.

◆ ApplyDescription()

static MAXON_METHOD Result<DataDictionary> ApplyDescription ( NodesGraphModelRef &  graph,
DataDictionary  description 
)
static

Applies the given graph #description to the given nodes #graph.

Parameters
[in]graphThe nodes graph to apply the #description to.
[in]descriptionThe graph description to apply to #graph.
Returns
All nodes in the graph after the description has been read as <String, GraphNode> pairs where the string is the ID of the node. Primarily intended for the Python fronted.

◆ CreateGraph()

static MAXON_METHOD Result<nodes::NodesGraphModelRef> CreateGraph ( cinema::BaseList2D element,
Id nodeSpaceId,
const Bool  createEmpty,
const String name 
)
static
Note
Deprecated in favour of GetGraph.

◆ GetGraph()

static MAXON_METHOD Result<nodes::NodesGraphModelRef> GetGraph ( cinema::BaseList2D element,
Id nodeSpaceId,
const Bool  createEmpty,
const String name 
)
static

Returns the nodes graph for the given scene element and #nodeSpaceId.

element can be a BaseDocument (for the document wide scene nodes graph), a BaseObject (for capsules), or a material (for material graphs), or nullptr (to create a material in the active document). When the passed element does not yet have a graph in the requested node space, it will be created.

Parameters
[in]elementThe scene element to get the graph for. Can be nullptr to create a material in the active document.
[in]nodeSpaceIdThe node space to retrieve the graph for. When the empty ID is passed, it will default to the active node space for materials and the neutron node space for everything else.
[in]createEmptyWhen #true, new graphs will be created as an empty graph, when #false the default graph will be created.
[in]nameThe name to give the material which is created when element is the nullptr.
Returns
The retrieved graph.

◆ GetMaterialGraphs()

static MAXON_METHOD Result<BaseArray<nodes::NodesGraphModelRef> > GetMaterialGraphs ( const cinema::BaseDocument *const  doc,
const Id nodeSpaceId 
)
static

Returns all material graphs in the given scene doc which are in the given #nodeSpaceId.

Parameters
[in]docThe document to get the material graphs from.
[in]nodeSpaceIdThe node space to retrieve the graphs for. Cannot be the empty ID.
Returns
All material graphs in the given scene doc which are of the given #nodeSpaceId.