1 //
2 // Copyright 2016 Pixar
3 //
4 // Licensed under the Apache License, Version 2.0 (the "Apache License")
5 // with the following modification; you may not use this file except in
6 // compliance with the Apache License and the following modification to it:
7 // Section 6. Trademarks. is deleted and replaced with:
8 //
9 // 6. Trademarks. This License does not grant permission to use the trade
10 // names, trademarks, service marks, or product names of the Licensor
11 // and its affiliates, except as required to comply with Section 4(c) of
12 // the License and to reproduce the content of the NOTICE file.
13 //
14 // You may obtain a copy of the Apache License at
15 //
16 // http://www.apache.org/licenses/LICENSE-2.0
17 //
18 // Unless required by applicable law or agreed to in writing, software
19 // distributed under the Apache License with the above modification is
20 // distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21 // KIND, either express or implied. See the Apache License for the specific
22 // language governing permissions and limitations under the Apache License.
23 //
24 #include "pxr/usd/usdContrived/testHairman.h"
25 #include "pxr/usd/usd/schemaRegistry.h"
26 #include "pxr/usd/usd/typed.h"
27
28 #include "pxr/usd/sdf/types.h"
29 #include "pxr/usd/sdf/assetPath.h"
30
31 namespace foo { namespace bar { namespace baz {
32
33 // Register the schema with the TfType system.
TF_REGISTRY_FUNCTION(TfType)34 TF_REGISTRY_FUNCTION(TfType)
35 {
36 TfType::Define<UsdContrivedTestHairman,
37 TfType::Bases< UsdTyped > >();
38
39 // Register the usd prim typename as an alias under UsdSchemaBase. This
40 // enables one to call
41 // TfType::Find<UsdSchemaBase>().FindDerivedByName("TestPxHairman")
42 // to find TfType<UsdContrivedTestHairman>, which is how IsA queries are
43 // answered.
44 TfType::AddAlias<UsdSchemaBase, UsdContrivedTestHairman>("TestPxHairman");
45 }
46
47 /* virtual */
~UsdContrivedTestHairman()48 UsdContrivedTestHairman::~UsdContrivedTestHairman()
49 {
50 }
51
52 /* static */
53 UsdContrivedTestHairman
Get(const UsdStagePtr & stage,const SdfPath & path)54 UsdContrivedTestHairman::Get(const UsdStagePtr &stage, const SdfPath &path)
55 {
56 if (!stage) {
57 TF_CODING_ERROR("Invalid stage");
58 return UsdContrivedTestHairman();
59 }
60 return UsdContrivedTestHairman(stage->GetPrimAtPath(path));
61 }
62
63 /* static */
64 UsdContrivedTestHairman
Define(const UsdStagePtr & stage,const SdfPath & path)65 UsdContrivedTestHairman::Define(
66 const UsdStagePtr &stage, const SdfPath &path)
67 {
68 static TfToken usdPrimTypeName("TestPxHairman");
69 if (!stage) {
70 TF_CODING_ERROR("Invalid stage");
71 return UsdContrivedTestHairman();
72 }
73 return UsdContrivedTestHairman(
74 stage->DefinePrim(path, usdPrimTypeName));
75 }
76
77 /* virtual */
_GetSchemaKind() const78 UsdSchemaKind UsdContrivedTestHairman::_GetSchemaKind() const
79 {
80 return UsdContrivedTestHairman::schemaKind;
81 }
82
83 /* static */
84 const TfType &
_GetStaticTfType()85 UsdContrivedTestHairman::_GetStaticTfType()
86 {
87 static TfType tfType = TfType::Find<UsdContrivedTestHairman>();
88 return tfType;
89 }
90
91 /* static */
92 bool
_IsTypedSchema()93 UsdContrivedTestHairman::_IsTypedSchema()
94 {
95 static bool isTyped = _GetStaticTfType().IsA<UsdTyped>();
96 return isTyped;
97 }
98
99 /* virtual */
100 const TfType &
_GetTfType() const101 UsdContrivedTestHairman::_GetTfType() const
102 {
103 return _GetStaticTfType();
104 }
105
106 UsdAttribute
GetTempAttr() const107 UsdContrivedTestHairman::GetTempAttr() const
108 {
109 return GetPrim().GetAttribute(UsdContrivedTokens->temp);
110 }
111
112 UsdAttribute
CreateTempAttr(VtValue const & defaultValue,bool writeSparsely) const113 UsdContrivedTestHairman::CreateTempAttr(VtValue const &defaultValue, bool writeSparsely) const
114 {
115 return UsdSchemaBase::_CreateAttr(UsdContrivedTokens->temp,
116 SdfValueTypeNames->Float,
117 /* custom = */ true,
118 SdfVariabilityVarying,
119 defaultValue,
120 writeSparsely);
121 }
122
123 UsdAttribute
GetGofur_GeomOnHairdensityAttr() const124 UsdContrivedTestHairman::GetGofur_GeomOnHairdensityAttr() const
125 {
126 return GetPrim().GetAttribute(UsdContrivedTokens->riStatementsAttributesUserGofur_GeomOnHairdensity);
127 }
128
129 UsdAttribute
CreateGofur_GeomOnHairdensityAttr(VtValue const & defaultValue,bool writeSparsely) const130 UsdContrivedTestHairman::CreateGofur_GeomOnHairdensityAttr(VtValue const &defaultValue, bool writeSparsely) const
131 {
132 return UsdSchemaBase::_CreateAttr(UsdContrivedTokens->riStatementsAttributesUserGofur_GeomOnHairdensity,
133 SdfValueTypeNames->Float,
134 /* custom = */ false,
135 SdfVariabilityVarying,
136 defaultValue,
137 writeSparsely);
138 }
139
140 UsdRelationship
GetGofur_GeomOnHairdensityRel() const141 UsdContrivedTestHairman::GetGofur_GeomOnHairdensityRel() const
142 {
143 return GetPrim().GetRelationship(UsdContrivedTokens->relCanShareApiNameWithAttr);
144 }
145
146 UsdRelationship
CreateGofur_GeomOnHairdensityRel() const147 UsdContrivedTestHairman::CreateGofur_GeomOnHairdensityRel() const
148 {
149 return GetPrim().CreateRelationship(UsdContrivedTokens->relCanShareApiNameWithAttr,
150 /* custom = */ false);
151 }
152
153 namespace {
154 static inline TfTokenVector
_ConcatenateAttributeNames(const TfTokenVector & left,const TfTokenVector & right)155 _ConcatenateAttributeNames(const TfTokenVector& left,const TfTokenVector& right)
156 {
157 TfTokenVector result;
158 result.reserve(left.size() + right.size());
159 result.insert(result.end(), left.begin(), left.end());
160 result.insert(result.end(), right.begin(), right.end());
161 return result;
162 }
163 }
164
165 /*static*/
166 const TfTokenVector&
GetSchemaAttributeNames(bool includeInherited)167 UsdContrivedTestHairman::GetSchemaAttributeNames(bool includeInherited)
168 {
169 static TfTokenVector localNames = {
170 UsdContrivedTokens->temp,
171 UsdContrivedTokens->riStatementsAttributesUserGofur_GeomOnHairdensity,
172 UsdContrivedTokens->attrWithoutGeneratedAccessorAPI,
173 };
174 static TfTokenVector allNames =
175 _ConcatenateAttributeNames(
176 UsdTyped::GetSchemaAttributeNames(true),
177 localNames);
178
179 if (includeInherited)
180 return allNames;
181 else
182 return localNames;
183 }
184
185 }}}
186
187 // ===================================================================== //
188 // Feel free to add custom code below this line. It will be preserved by
189 // the code generator.
190 //
191 // Just remember to wrap code in the appropriate delimiters:
192 // 'namespace foo { namespace bar { namespace baz {', '}}}'.
193 // ===================================================================== //
194 // --(BEGIN CUSTOM CODE)--
195