HDK
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
schema.h
Go to the documentation of this file.
1 //
2 // Copyright 2021 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 
25 #ifndef PXR_IMAGING_HD_SCHEMA_H
26 #define PXR_IMAGING_HD_SCHEMA_H
27 
28 #include "pxr/imaging/hd/api.h"
29 
32 
34 
35 // ----------------------------------------------------------------------------
36 
37 /// Schema classes represent a structured view of the inherently unstructured
38 /// container data source passed into the constructor. They're used to
39 /// represent what fields a given object is expected to have.
40 /// Note that a schema can be applied to a container which doesn't contain
41 /// all of the named fields; in that case, some of the field accessors will
42 /// return null, and the caller should use default values for those fields.
43 class HdSchema
44 {
45 public:
46  HdSchema(HdContainerDataSourceHandle container)
47  : _container(container) {}
48 
49 
50  /// Returns the container data source that this schema is interpreting.
51  HD_API
52  HdContainerDataSourceHandle GetContainer();
53  HD_API
54  bool IsDefined() const;
55 
56  /// Returns \c true if this schema is applied on top of a non-null
57  /// container.
58  explicit operator bool() const { return IsDefined(); }
59 
60 
61 protected:
62  HdContainerDataSourceHandle _container;
63 
64  /// Returns a datasource of the requested type for the given name:
65  /// schema implementations can use this to ask for child containers,
66  /// sampled values, vectors, etc. If the key has the wrong type, this
67  /// function returns null.
68  template <typename T>
70  return _container ? T::Cast(
71  _container->Get(name)) : nullptr;
72  }
73 };
74 
76 
77 #endif
T::Handle _GetTypedDataSource(TfToken name)
Definition: schema.h:69
HD_API bool IsDefined() const
#define HD_API
Definition: api.h:40
Definition: token.h:87
HD_API HdContainerDataSourceHandle GetContainer()
Returns the container data source that this schema is interpreting.
HdContainerDataSourceHandle _container
Definition: schema.h:62
GLuint const GLchar * name
Definition: glcorearb.h:786
HdSchema(HdContainerDataSourceHandle container)
Definition: schema.h:46
PXR_NAMESPACE_CLOSE_SCOPE PXR_NAMESPACE_OPEN_SCOPE
Definition: path.h:1441
#define PXR_NAMESPACE_CLOSE_SCOPE
Definition: pxr.h:91
void * Handle
Definition: plugin.h:27