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
257 PCP_API
258 void SetHasSymmetry(bool hasSymmetry);
259 PCP_API
260 bool HasSymmetry() const;
261
264 PCP_API
266 PCP_API
267 SdfPermission GetPermission() const;
268
273 PCP_API
274 void SetInert(bool inert);
275 PCP_API
276 bool IsInert() const;
277
281 PCP_API
282 void SetCulled(bool culled);
283 PCP_API
284 bool IsCulled() const;
285
288 PCP_API
289 void SetRestricted(bool restricted);
290 PCP_API
291 bool IsRestricted() const;
292
295 PCP_API
296 bool CanContributeSpecs() const;
297
305 PCP_API
307
313 PCP_API
315
318 PCP_API
319 void SetHasSpecs(bool hasSpecs);
320 PCP_API
321 bool HasSpecs() const;
322
324
325 // Returns a compressed Sd site. For internal use only.
326 Pcp_CompressedSdSite GetCompressedSdSite(size_t layerIndex) const
327 {
328 return Pcp_CompressedSdSite(_nodeIdx, layerIndex);
329 }
330
331 PCP_API
332 friend std::ostream & operator<<(std::ostream &out, const PcpNodeRef &node);
333
334private:
335 friend class PcpPrimIndex_Graph;
336 friend class PcpNodeIterator;
337 friend class PcpNodeRef_ChildrenIterator;
338 friend class PcpNodeRef_ChildrenReverseIterator;
339 friend class PcpNodeRef_PrivateChildrenConstIterator;
340 friend class PcpNodeRef_PrivateChildrenConstReverseIterator;
341 friend class PcpNodeRef_PrivateSubtreeConstIterator;
342 template <class T> friend class Pcp_TraversalCache;
343 friend bool Pcp_IsPropagatedSpecializesNode(const PcpNodeRef& node);
344
345 // Private constructor for internal use.
346 PcpNodeRef(PcpPrimIndex_Graph* graph, size_t idx)
347 : _graph(graph), _nodeIdx(idx)
348 {}
349
350 size_t _GetNodeIndex() const { return _nodeIdx; }
351
352 inline size_t _GetParentIndex() const;
353 inline size_t _GetOriginIndex() const;
354
355 inline void _SetInert(bool inert);
356 inline void _SetRestricted(bool restricted);
357
358 enum class _Restricted { Yes, Unknown };
359 void _RecordRestrictionDepth(_Restricted isRestricted);
360
361private: // Data
362 PcpPrimIndex_Graph* _graph;
363 size_t _nodeIdx;
364};
365
367template <typename HashState>
368inline
369void
370TfHashAppend(HashState& h, const PcpNodeRef& x){
371 h.Append((size_t)(x.GetUniqueIdentifier()));
372}
373inline
374size_t
375hash_value(const PcpNodeRef& x)
376{
377 return TfHash{}(x);
378}
379
380typedef TfHashSet<PcpNodeRef, PcpNodeRef::Hash> PcpNodeRefHashSet;
381typedef std::vector<PcpNodeRef> PcpNodeRefVector;
382
383class PcpNodeRef_PtrProxy {
384public:
385 PcpNodeRef* operator->() { return &_nodeRef; }
386private:
387 friend class PcpNodeRef_ChildrenIterator;
388 friend class PcpNodeRef_ChildrenReverseIterator;
389 explicit PcpNodeRef_PtrProxy(const PcpNodeRef& nodeRef) : _nodeRef(nodeRef) {}
390 PcpNodeRef _nodeRef;
391};
392
398class PcpNodeRef_ChildrenIterator
399{
400public:
401 using iterator_category = std::forward_iterator_tag;
402 using value_type = PcpNodeRef;
403 using reference = PcpNodeRef;
404 using pointer = PcpNodeRef_PtrProxy;
405 using difference_type = std::ptrdiff_t;
406
408 PCP_API
409 PcpNodeRef_ChildrenIterator();
410
413 PCP_API
414 PcpNodeRef_ChildrenIterator(const PcpNodeRef& node, bool end = false);
415
416 reference operator*() const { return dereference(); }
417 pointer operator->() const { return pointer(dereference()); }
418
419 PcpNodeRef_ChildrenIterator& operator++() {
420 increment();
421 return *this;
422 }
423
424 PcpNodeRef_ChildrenIterator operator++(int) {
425 const PcpNodeRef_ChildrenIterator result = *this;
426 increment();
427 return result;
428 }
429
430 bool operator==(const PcpNodeRef_ChildrenIterator& other) const {
431 return equal(other);
432 }
433
434 bool operator!=(const PcpNodeRef_ChildrenIterator& other) const {
435 return !equal(other);
436 }
437
438private:
439 PCP_API
440 void increment();
441 bool equal(const PcpNodeRef_ChildrenIterator& other) const
442 {
443 // Note: The default constructed iterator is *not* equal to any
444 // other iterator.
445 return (_node == other._node && _index == other._index);
446 }
447 reference dereference() const
448 {
449 return reference(_node._graph, _index);
450 }
451
452private:
453 // Current graph node this iterator is pointing at.
454 PcpNodeRef _node;
455
456 // Index of current child.
457 size_t _index;
458
459 friend class PcpNodeRef_ChildrenReverseIterator;
460};
461
467class PcpNodeRef_ChildrenReverseIterator
468{
469public:
470 using iterator_category = std::forward_iterator_tag;
471 using value_type = PcpNodeRef;
472 using reference = PcpNodeRef;
473 using pointer = PcpNodeRef_PtrProxy;
474 using difference_type = std::ptrdiff_t;
475
477 PCP_API
478 PcpNodeRef_ChildrenReverseIterator();
479
481 PCP_API
482 PcpNodeRef_ChildrenReverseIterator(const PcpNodeRef_ChildrenIterator&);
483
486 PCP_API
487 PcpNodeRef_ChildrenReverseIterator(const PcpNodeRef& node,bool end = false);
488
489 reference operator*() const { return dereference(); }
490 pointer operator->() const { return pointer(dereference()); }
491
492 PcpNodeRef_ChildrenReverseIterator& operator++() {
493 increment();
494 return *this;
495 }
496
497 PcpNodeRef_ChildrenReverseIterator operator++(int) {
498 const PcpNodeRef_ChildrenReverseIterator result = *this;
499 increment();
500 return result;
501 }
502
503 bool operator==(const PcpNodeRef_ChildrenReverseIterator& other) const {
504 return equal(other);
505 }
506
507 bool operator!=(const PcpNodeRef_ChildrenReverseIterator& other) const {
508 return !equal(other);
509 }
510
511private:
512 PCP_API
513 void increment();
514 bool equal(const PcpNodeRef_ChildrenReverseIterator& other) const
515 {
516 // Note: The default constructed iterator is *not* equal to any
517 // other iterator.
518 return (_node == other._node && _index == other._index);
519 }
520 reference dereference() const
521 {
522 return reference(_node._graph, _index);
523 }
524
525private:
526 // Current graph node this iterator is pointing at.
527 PcpNodeRef _node;
528
529 // Index of current child.
530 size_t _index;
531};
532
533template <>
534struct Tf_IteratorInterface<PcpNodeRef::child_const_range, false> {
535 typedef PcpNodeRef::child_const_iterator IteratorType;
536 static IteratorType Begin(PcpNodeRef::child_const_range const &c)
537 {
538 return c.first;
539 }
540 static IteratorType End(PcpNodeRef::child_const_range const &c)
541 {
542 return c.second;
543 }
544};
545
546template <>
547struct Tf_IteratorInterface<PcpNodeRef::child_const_range, true> {
548 typedef PcpNodeRef::child_const_reverse_iterator IteratorType;
549 static IteratorType Begin(PcpNodeRef::child_const_range const &c)
550 {
551 return c.second;
552 }
553 static IteratorType End(PcpNodeRef::child_const_range const &c)
554 {
555 return c.first;
556 }
557};
558
559template <>
560struct Tf_ShouldIterateOverCopy<PcpNodeRef::child_const_range> :
561 std::true_type {};
562
564inline
565PcpNodeRef_ChildrenIterator
566begin(const PcpNodeRef::child_const_range& r)
567{
568 return r.first;
569}
570
572inline
573PcpNodeRef_ChildrenIterator
574end(const PcpNodeRef::child_const_range& r)
575{
576 return r.second;
577}
578
580inline
581PcpNodeRef_ChildrenReverseIterator
582begin(const PcpNodeRef::child_const_reverse_range& r)
583{
584 return r.first;
585}
586
588inline
589PcpNodeRef_ChildrenReverseIterator
590end(const PcpNodeRef::child_const_reverse_range& r)
591{
592 return r.second;
593}
594
595// Helper to count the non-variant path components of a path; equivalent
596// to path.StripAllVariantSelections().GetPathElementCount() except
597// this method avoids constructing a new SdfPath value.
598int PcpNode_GetNonVariantPathElementCount(const SdfPath &path);
599
600PXR_NAMESPACE_CLOSE_SCOPE
601
602#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 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:274
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:132