Loading...
Searching...
No Matches
node.h
1//
2// Copyright 2016 Pixar
3//
4// Licensed under the terms set forth in the LICENSE.txt file available at
5// https://openusd.org/license.
6//
7#ifndef PXR_USD_PCP_NODE_H
8#define PXR_USD_PCP_NODE_H
9
10#include "pxr/pxr.h"
11#include "pxr/usd/pcp/api.h"
12#include "pxr/usd/pcp/types.h"
13#include "pxr/usd/sdf/types.h"
15#include "pxr/base/tf/hashset.h"
16
17PXR_NAMESPACE_OPEN_SCOPE
18
19class PcpArc;
22class PcpNodeRef;
23class PcpNodeRef_ChildrenIterator;
24class PcpNodeRef_ChildrenReverseIterator;
25class PcpErrorBase;
26typedef std::shared_ptr<PcpErrorBase> PcpErrorBasePtr;
27
28TF_DECLARE_REF_PTRS(PcpPrimIndex_Graph);
29
47{
48public:
49 typedef PcpNodeRef_ChildrenIterator child_const_iterator;
50 typedef PcpNodeRef_ChildrenReverseIterator child_const_reverse_iterator;
51 typedef std::pair<child_const_iterator,
52 child_const_iterator> child_const_range;
53 typedef std::pair<child_const_reverse_iterator,
54 child_const_reverse_iterator> child_const_reverse_range;
55
56 PcpNodeRef() : _graph(0), _nodeIdx(PCP_INVALID_INDEX) {}
57
60
63 inline operator UnspecifiedBoolType() const {
64 return (_graph && _nodeIdx != PCP_INVALID_INDEX) ? &PcpNodeRef::_nodeIdx : 0;
65 }
66
68 inline bool operator==(const PcpNodeRef& rhs) const {
69 return _nodeIdx == rhs._nodeIdx && _graph == rhs._graph;
70 }
71
74 inline bool operator!=(const PcpNodeRef& rhs) const {
75 return !(*this == rhs);
76 }
77
81 PCP_API
82 bool operator<(const PcpNodeRef& rhs) const;
83
86 bool operator<=(const PcpNodeRef& rhs) const {
87 return !(rhs < *this);
88 }
89
92 bool operator>(const PcpNodeRef& rhs) const {
93 return rhs < *this;
94 }
95
98 bool operator>=(const PcpNodeRef& rhs) const {
99 return !(*this < rhs);
100 }
101
103 struct Hash {
104 size_t operator()(const PcpNodeRef& rhs) const
105 { return (size_t)rhs.GetUniqueIdentifier(); }
106 };
107
109 PcpPrimIndex_Graph *GetOwningGraph() const {
110 return _graph;
111 }
112
114 PCP_API
115 void* GetUniqueIdentifier() const;
116
118
123
125 PCP_API
127
130 PCP_API
132
135 PCP_API
136 child_const_range GetChildrenRange() const;
137
140 PCP_API
141 child_const_reverse_range GetChildrenReverseRange() const;
142
145 PCP_API
147 PcpErrorBasePtr *error);
148
151 PCP_API
153 const PcpPrimIndex_GraphRefPtr& subgraph, const PcpArc& arc,
154 PcpErrorBasePtr *error);
155
160 PCP_API
162
167 PCP_API
169
171 PCP_API
173
176 PCP_API
178
181 PCP_API
183
186 PCP_API
188
191 PCP_API
192 int GetNamespaceDepth() const;
193
196 PCP_API
198
200 PCP_API
202
208 PCP_API
210
222 PCP_API
224
226
231
233 PCP_API
235
237 PCP_API
238 const SdfPath& GetPath() const;
239
241 PCP_API
242 const PcpLayerStackRefPtr& GetLayerStack() const;
243
245 PCP_API
246 bool IsRootNode() const;
247
250 PCP_API
251 void SetIsDueToAncestor(bool isDueToAncestor);
252 PCP_API
253 bool IsDueToAncestor() const;
254
255 // Get/set whether this node or any of its ancestor nodes represents a
256 // direct dependency.
257 PCP_API
258 void SetHasTransitiveDirectDependency(bool hasDep);
259 PCP_API
260 bool HasTransitiveDirectDependency() const;
261
262 // Get/set whether this node or any of its ancestor nodes represents an
263 // ancestral dependency.
264 PCP_API
265 void SetHasTransitiveAncestralDependency(bool hasDep);
266 PCP_API
267 bool HasTransitiveAncestralDependency() const;
268
271 PCP_API
272 void SetHasSymmetry(bool hasSymmetry);
273 PCP_API
274 bool HasSymmetry() const;
275
278 PCP_API
280 PCP_API
281 SdfPermission GetPermission() const;
282
287 PCP_API
288 void SetInert(bool inert);
289 PCP_API
290 bool IsInert() const;
291
295 PCP_API
296 void SetCulled(bool culled);
297 PCP_API
298 bool IsCulled() const;
299
302 PCP_API
303 void SetRestricted(bool restricted);
304 PCP_API
305 bool IsRestricted() const;
306
309 PCP_API
310 bool CanContributeSpecs() const;
311
319 PCP_API
321
327 PCP_API
329
332 PCP_API
333 void SetHasSpecs(bool hasSpecs);
334 PCP_API
335 bool HasSpecs() const;
336
339 PCP_API
340 void SetHasValueClips(bool hasValueClips);
341 PCP_API
342 bool HasValueClips() const;
343
345
346 // Returns a compressed Sd site. For internal use only.
347 Pcp_CompressedSdSite GetCompressedSdSite(size_t layerIndex) const
348 {
349 return Pcp_CompressedSdSite(_nodeIdx, layerIndex);
350 }
351
352 PCP_API
353 friend std::ostream & operator<<(std::ostream &out, const PcpNodeRef &node);
354
355private:
356 friend class PcpPrimIndex_Graph;
357 friend class PcpNodeIterator;
358 friend class PcpNodeRef_ChildrenIterator;
359 friend class PcpNodeRef_ChildrenReverseIterator;
360 friend class PcpNodeRef_PrivateChildrenConstIterator;
361 friend class PcpNodeRef_PrivateChildrenConstReverseIterator;
362 friend class PcpNodeRef_PrivateSubtreeConstIterator;
363 template <class T> friend class Pcp_TraversalCache;
364 friend bool Pcp_IsPropagatedSpecializesNode(const PcpNodeRef& node);
365
366 // Private constructor for internal use.
367 PcpNodeRef(PcpPrimIndex_Graph* graph, size_t idx)
368 : _graph(graph), _nodeIdx(idx)
369 {}
370
371 size_t _GetNodeIndex() const { return _nodeIdx; }
372
373 inline size_t _GetParentIndex() const;
374 inline size_t _GetOriginIndex() const;
375
376 inline void _SetInert(bool inert);
377 inline void _SetRestricted(bool restricted);
378
379 enum class _Restricted { Yes, Unknown };
380 void _RecordRestrictionDepth(_Restricted isRestricted);
381
382private: // Data
383 PcpPrimIndex_Graph* _graph;
384 size_t _nodeIdx;
385};
386
388template <typename HashState>
389inline
390void
391TfHashAppend(HashState& h, const PcpNodeRef& x){
392 h.Append((size_t)(x.GetUniqueIdentifier()));
393}
394inline
395size_t
396hash_value(const PcpNodeRef& x)
397{
398 return TfHash{}(x);
399}
400
401typedef TfHashSet<PcpNodeRef, PcpNodeRef::Hash> PcpNodeRefHashSet;
402typedef std::vector<PcpNodeRef> PcpNodeRefVector;
403
404class PcpNodeRef_PtrProxy {
405public:
406 PcpNodeRef* operator->() { return &_nodeRef; }
407private:
408 friend class PcpNodeRef_ChildrenIterator;
409 friend class PcpNodeRef_ChildrenReverseIterator;
410 explicit PcpNodeRef_PtrProxy(const PcpNodeRef& nodeRef) : _nodeRef(nodeRef) {}
411 PcpNodeRef _nodeRef;
412};
413
419class PcpNodeRef_ChildrenIterator
420{
421public:
422 using iterator_category = std::forward_iterator_tag;
423 using value_type = PcpNodeRef;
424 using reference = PcpNodeRef;
425 using pointer = PcpNodeRef_PtrProxy;
426 using difference_type = std::ptrdiff_t;
427
429 PCP_API
430 PcpNodeRef_ChildrenIterator();
431
434 PCP_API
435 PcpNodeRef_ChildrenIterator(const PcpNodeRef& node, bool end = false);
436
437 reference operator*() const { return dereference(); }
438 pointer operator->() const { return pointer(dereference()); }
439
440 PcpNodeRef_ChildrenIterator& operator++() {
441 increment();
442 return *this;
443 }
444
445 PcpNodeRef_ChildrenIterator operator++(int) {
446 const PcpNodeRef_ChildrenIterator result = *this;
447 increment();
448 return result;
449 }
450
451 bool operator==(const PcpNodeRef_ChildrenIterator& other) const {
452 return equal(other);
453 }
454
455 bool operator!=(const PcpNodeRef_ChildrenIterator& other) const {
456 return !equal(other);
457 }
458
459private:
460 PCP_API
461 void increment();
462 bool equal(const PcpNodeRef_ChildrenIterator& other) const
463 {
464 // Note: The default constructed iterator is *not* equal to any
465 // other iterator.
466 return (_node == other._node && _index == other._index);
467 }
468 reference dereference() const
469 {
470 return reference(_node._graph, _index);
471 }
472
473private:
474 // Current graph node this iterator is pointing at.
475 PcpNodeRef _node;
476
477 // Index of current child.
478 size_t _index;
479
480 friend class PcpNodeRef_ChildrenReverseIterator;
481};
482
488class PcpNodeRef_ChildrenReverseIterator
489{
490public:
491 using iterator_category = std::forward_iterator_tag;
492 using value_type = PcpNodeRef;
493 using reference = PcpNodeRef;
494 using pointer = PcpNodeRef_PtrProxy;
495 using difference_type = std::ptrdiff_t;
496
498 PCP_API
499 PcpNodeRef_ChildrenReverseIterator();
500
502 PCP_API
503 PcpNodeRef_ChildrenReverseIterator(const PcpNodeRef_ChildrenIterator&);
504
507 PCP_API
508 PcpNodeRef_ChildrenReverseIterator(const PcpNodeRef& node,bool end = false);
509
510 reference operator*() const { return dereference(); }
511 pointer operator->() const { return pointer(dereference()); }
512
513 PcpNodeRef_ChildrenReverseIterator& operator++() {
514 increment();
515 return *this;
516 }
517
518 PcpNodeRef_ChildrenReverseIterator operator++(int) {
519 const PcpNodeRef_ChildrenReverseIterator result = *this;
520 increment();
521 return result;
522 }
523
524 bool operator==(const PcpNodeRef_ChildrenReverseIterator& other) const {
525 return equal(other);
526 }
527
528 bool operator!=(const PcpNodeRef_ChildrenReverseIterator& other) const {
529 return !equal(other);
530 }
531
532private:
533 PCP_API
534 void increment();
535 bool equal(const PcpNodeRef_ChildrenReverseIterator& other) const
536 {
537 // Note: The default constructed iterator is *not* equal to any
538 // other iterator.
539 return (_node == other._node && _index == other._index);
540 }
541 reference dereference() const
542 {
543 return reference(_node._graph, _index);
544 }
545
546private:
547 // Current graph node this iterator is pointing at.
548 PcpNodeRef _node;
549
550 // Index of current child.
551 size_t _index;
552};
553
554template <>
555struct Tf_IteratorInterface<PcpNodeRef::child_const_range, false> {
556 typedef PcpNodeRef::child_const_iterator IteratorType;
557 static IteratorType Begin(PcpNodeRef::child_const_range const &c)
558 {
559 return c.first;
560 }
561 static IteratorType End(PcpNodeRef::child_const_range const &c)
562 {
563 return c.second;
564 }
565};
566
567template <>
568struct Tf_IteratorInterface<PcpNodeRef::child_const_range, true> {
569 typedef PcpNodeRef::child_const_reverse_iterator IteratorType;
570 static IteratorType Begin(PcpNodeRef::child_const_range const &c)
571 {
572 return c.second;
573 }
574 static IteratorType End(PcpNodeRef::child_const_range const &c)
575 {
576 return c.first;
577 }
578};
579
580template <>
581struct Tf_ShouldIterateOverCopy<PcpNodeRef::child_const_range> :
582 std::true_type {};
583
585inline
586PcpNodeRef_ChildrenIterator
587begin(const PcpNodeRef::child_const_range& r)
588{
589 return r.first;
590}
591
593inline
594PcpNodeRef_ChildrenIterator
595end(const PcpNodeRef::child_const_range& r)
596{
597 return r.second;
598}
599
601inline
602PcpNodeRef_ChildrenReverseIterator
603begin(const PcpNodeRef::child_const_reverse_range& r)
604{
605 return r.first;
606}
607
609inline
610PcpNodeRef_ChildrenReverseIterator
611end(const PcpNodeRef::child_const_reverse_range& r)
612{
613 return r.second;
614}
615
616// Helper to count the non-variant path components of a path; equivalent
617// to path.StripAllVariantSelections().GetPathElementCount() except
618// this method avoids constructing a new SdfPath value.
619int PcpNode_GetNonVariantPathElementCount(const SdfPath &path);
620
621PXR_NAMESPACE_CLOSE_SCOPE
622
623#endif // PXR_USD_PCP_NODE_H
A simple iterator adapter for STL containers.
Represents an arc connecting two nodes in the prim index.
Definition: arc.h:28
Base class for all error types.
Definition: errors.h:71
A site specifies a path in a layer stack of scene description.
Definition: site.h:79
An expression that yields a PcpMapFunction value.
Definition: mapExpression.h:39
Object used to iterate over nodes in the prim index graph in strong-to-weak order.
Definition: iterator.h:34
PcpNode represents a node in an expression tree for compositing scene description.
Definition: node.h:47
PCP_API void SetRestricted(bool restricted)
Get/set whether this node is restricted.
PCP_API bool CanContributeSpecs() const
Returns true if this node is allowed to contribute opinions for composition, false otherwise.
PCP_API SdfPath GetPathAtIntroduction() const
Returns the path for this node's site when it was introduced.
PCP_API void * GetUniqueIdentifier() const
Returns a value that uniquely identifies this node.
bool operator==(const PcpNodeRef &rhs) const
Returns true if this references the same node as rhs.
Definition: node.h:68
PCP_API void SetHasValueClips(bool hasValueClips)
Returns true if this node's site or a namespace ancestor has authored value clips.
PCP_API PcpNodeRef GetRootNode() const
Walk up to the root node of this expression.
size_t PcpNodeRef::* UnspecifiedBoolType
Returns true if this is a valid node reference, false otherwise.
Definition: node.h:62
PCP_API SdfPath GetIntroPath() const
Get the path that introduced this node.
PCP_API void SetPermission(SdfPermission perm)
Get/set the permission for this node.
PCP_API void SetIsDueToAncestor(bool isDueToAncestor)
Get/set whether this node was introduced by being copied from its namespace ancestor,...
bool operator>(const PcpNodeRef &rhs) const
Greater than operator.
Definition: node.h:92
PCP_API void SetHasSymmetry(bool hasSymmetry)
Get/set whether this node provides any symmetry opinions, either directly or from a namespace ancesto...
PCP_API PcpArcType GetArcType() const
Returns the type of arc connecting this node to its parent node.
PCP_API void SetSpecContributionRestrictedDepth(size_t depth)
Set this node's contribution restriction depth.
PCP_API size_t GetSpecContributionRestrictedDepth() const
Returns the namespace depth (i.e., the path element count) of this node's path when it was restricted...
PCP_API child_const_reverse_range GetChildrenReverseRange() const
Returns an iterator range over the children nodes in weakest to strongest order.
PCP_API PcpNodeRef GetOriginNode() const
Returns the immediate origin node for this node.
PCP_API PcpLayerStackSite GetSite() const
Get the site this node represents.
PCP_API PcpNodeRef InsertChildSubgraph(const PcpPrimIndex_GraphRefPtr &subgraph, const PcpArc &arc, PcpErrorBasePtr *error)
Inserts subgraph as a child of this node, with the root node of subtree connected to this node via ar...
bool operator<=(const PcpNodeRef &rhs) const
Less than or equal operator.
Definition: node.h:86
PCP_API PcpNodeRef GetParentNode() const
Returns this node's immediate parent node.
PCP_API bool IsRootNode() const
Returns true if this node is the root node of the prim index graph.
PCP_API PcpNodeRef GetOriginRootNode() const
Walk up to the root origin node for this node.
PcpPrimIndex_Graph * GetOwningGraph() const
Returns the graph that this node belongs to.
Definition: node.h:109
PCP_API const SdfPath & GetPath() const
Returns the path for the site this node represents.
PCP_API int GetSiblingNumAtOrigin() const
Returns this node's index among siblings with the same arc type at this node's origin.
PCP_API void SetHasSpecs(bool hasSpecs)
Returns true if this node has opinions authored for composition, false otherwise.
PCP_API PcpNodeRef InsertChild(const PcpLayerStackSite &site, const PcpArc &arc, PcpErrorBasePtr *error)
Inserts a new child node for site, connected to this node via arc.
PCP_API int GetNamespaceDepth() const
Returns the absolute namespace depth of the node that introduced this node.
bool operator>=(const PcpNodeRef &rhs) const
Greater than or equal operator.
Definition: node.h:98
PCP_API bool operator<(const PcpNodeRef &rhs) const
Returns true if this node is 'less' than rhs.
PCP_API const PcpMapExpression & GetMapToRoot() const
Returns mapping function used to translate paths and values from this node directly to the root node.
PCP_API const PcpLayerStackRefPtr & GetLayerStack() const
Returns the layer stack for the site this node represents.
PCP_API void SetInert(bool inert)
Get/set whether this node is inert.
PCP_API int GetDepthBelowIntroduction() const
Return the number of levels of namespace this node's site is below the level at which it was introduc...
PCP_API child_const_range GetChildrenRange() const
Returns an iterator range over the children nodes in strongest to weakest order.
PCP_API SdfPath GetPathAtOriginRootIntroduction() const
Returns the node's path at the same level of namespace as its origin root node was when it was added ...
PCP_API void SetCulled(bool culled)
Get/set whether this node is culled.
PCP_API const PcpMapExpression & GetMapToParent() const
Returns mapping function used to translate paths and values from this node to its parent node.
bool operator!=(const PcpNodeRef &rhs) const
Inequality operator.
Definition: node.h:74
A path value used to locate objects in layers or scenegraphs.
Definition: path.h:280
A user-extensible hashing mechanism for use with runtime hash tables.
Definition: hash.h:472
#define TF_DECLARE_REF_PTRS(type)
Define standard ref pointer types.
Definition: declarePtrs.h:58
Hash functor.
Definition: node.h:103
size_t hash_value(const TfToken &x)
Overload hash_value for TfToken.
Definition: token.h:437
constexpr size_t PCP_INVALID_INDEX
A value which indicates an invalid index.
Definition: types.h:198
PcpArcType
Describes the type of arc connecting two nodes in the prim index.
Definition: types.h:27
Basic Sdf data types.
SdfPermission
An enum that defines permission levels.
Definition: types.h:135