forked from PixarAnimationStudios/OpenUSD
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathreference.cpp
121 lines (107 loc) · 3.73 KB
/
reference.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
//
// Copyright 2016 Pixar
//
// Licensed under the Apache License, Version 2.0 (the "Apache License")
// with the following modification; you may not use this file except in
// compliance with the Apache License and the following modification to it:
// Section 6. Trademarks. is deleted and replaced with:
//
// 6. Trademarks. This License does not grant permission to use the trade
// names, trademarks, service marks, or product names of the Licensor
// and its affiliates, except as required to comply with Section 4(c) of
// the License and to reproduce the content of the NOTICE file.
//
// You may obtain a copy of the Apache License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the Apache License with the above modification is
// distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the Apache License for the specific
// language governing permissions and limitations under the Apache License.
//
// Reference.cpp
//
#include "pxr/pxr.h"
#include "pxr/usd/sdf/reference.h"
#include "pxr/base/tf/registryManager.h"
#include "pxr/base/tf/type.h"
#include <algorithm>
#include <functional>
#include <ostream>
PXR_NAMESPACE_OPEN_SCOPE
TF_REGISTRY_FUNCTION(TfType)
{
TfType::Define<SdfReference>();
TfType::Define<SdfReferenceVector>();
}
SdfReference::SdfReference(
const std::string &assetPath,
const SdfPath &primPath,
const SdfLayerOffset &layerOffset,
const VtDictionary &customData) :
// Pass through SdfAssetPath() to issue an error and produce empty string if
// \p assetPath contains invalid characters.
_assetPath(SdfAssetPath(assetPath).GetAssetPath()),
_primPath(primPath),
_layerOffset(layerOffset),
_customData(customData)
{
}
void
SdfReference::SetCustomData(const std::string &name, const VtValue &value)
{
if (value.IsEmpty()) {
_customData.erase(name);
} else {
_customData[name] = value;
}
}
bool
SdfReference::IsInternal() const
{
return _assetPath.empty();
}
bool
SdfReference::operator==(const SdfReference &rhs) const
{
return _assetPath == rhs._assetPath &&
_primPath == rhs._primPath &&
_layerOffset == rhs._layerOffset &&
_customData == rhs._customData;
}
bool
SdfReference::operator<(const SdfReference &rhs) const
{
// XXX: This would be much cleaner and less error prone if we used
// std::tie for comparison, however, it's not ideal given the awkward
// (and not truly correct) comparison of customData size. If customData
// is ever removed this should be updated to use the cleaner std::tie.
return (_assetPath < rhs._assetPath || (_assetPath == rhs._assetPath &&
(_primPath < rhs._primPath || (_primPath == rhs._primPath &&
(_layerOffset < rhs._layerOffset || (_layerOffset == rhs._layerOffset &&
(_customData.size() < rhs._customData.size())))))));
}
int
SdfFindReferenceByIdentity(
const SdfReferenceVector &references,
const SdfReference &referenceId)
{
SdfReferenceVector::const_iterator it = std::find_if(
references.begin(), references.end(),
[&referenceId](SdfReference const &ref) {
return SdfReference::IdentityEqual()(referenceId, ref);
});
return it != references.end() ? it - references.begin() : -1;
}
std::ostream & operator<<( std::ostream &out,
const SdfReference &reference )
{
return out << "SdfReference("
<< reference.GetAssetPath() << ", "
<< reference.GetPrimPath() << ", "
<< reference.GetLayerOffset() << ", "
<< reference.GetCustomData() << ")";
}
PXR_NAMESPACE_CLOSE_SCOPE