HDK
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
HOM_Geometry.h
Go to the documentation of this file.
1 /*
2  * PROPRIETARY INFORMATION. This software is proprietary to
3  * Side Effects Software Inc., and is not to be reproduced,
4  * transmitted, or disclosed in any way without written permission.
5  *
6  * COMMENTS:
7  */
8 
9 #ifndef __HOM_Geometry_h__
10 #define __HOM_Geometry_h__
11 
12 #include "HOM_API.h"
13 #include "HOM_BinaryString.h"
14 #include "HOM_Defines.h"
15 #include "HOM_Errors.h"
16 #include "HOM_IterableList.h"
17 #include "HOM_BoundingBox.h"
19 #include "HOM_Attrib.h"
20 #include "HOM_LopNode.h"
21 #include "HOM_LopSelectionRule.h"
22 #include <UT/UT_Tuple.h>
23 #include <vector>
24 #include <string>
25 
26 class HOM_AttribDataId;
27 class HOM_ChannelPrim;
28 class HOM_Edge;
29 class HOM_EdgeGroup;
30 class HOM_Face;
31 class HOM_GUDetailHandle;
32 class HOM_LopLockedStage;
33 class HOM_Matrix4;
34 class HOM_PackedGeometry;
35 class HOM_PackedPrim;
36 class HOM_Parm;
37 class HOM_Point;
38 class HOM_PointGroup;
39 class HOM_Polygon;
40 class HOM_Prim;
41 class HOM_PrimGroup;
42 class HOM_Selection;
43 class HOM_SopNode;
44 class HOM_Surface;
45 class HOM_VDB;
46 class HOM_Vector2;
47 class HOM_Vector3;
48 class HOM_Vertex;
49 class HOM_VertexGroup;
50 class HOM_Volume;
51 class HOMF_GeometryHandle;
52 
54 // Force SWIG to output an __init__ method even though it determines this
55 // class is abstract.
56 SWIGOUT(%feature("notabstract") HOM_Geometry;)
57 
59 {
60 public:
61 #ifdef SWIG
62 %extend
63 {
64  HOM_Geometry(HOM_Geometry *geo=nullptr, bool clone_data_ids=false)
65  { return HOM().newGeometry(geo, clone_data_ids); }
66 }
67 #else
69  { HOM_CONSTRUCT_OBJECT(this) }
71  { HOM_CONSTRUCT_OBJECT(this) }
72 #endif
73  virtual ~HOM_Geometry()
74  { HOM_DESTRUCT_OBJECT(this) }
75 
76  virtual std::string __repr__() = 0;
77 
78  SWIGOUT(%newobject sopNode;)
79  virtual HOM_SopNode *sopNode() = 0;
80  virtual int sopNodeOutputIndex() = 0;
81 
82  virtual bool isValid() = 0;
83 
84  SWIGOUT(%newobject freeze;)
85  virtual HOM_Geometry *freeze(bool read_only=false,
86  bool clone_data_ids=false) = 0;
87 
88  virtual int64 pointCount() = 0;
89  virtual int64 vertexCount() = 0;
90  virtual int64 primCount() = 0;
91 
92  SWIGOUT(%newobject iterPoints;)
93  virtual HOM_IterableList<HOM_Point> *iterPoints() = 0;
94 
95  virtual std::vector<HOM_ElemPtr<HOM_Point> > points() = 0;
96 
97  SWIGOUT(%newobject point;)
98  virtual HOM_Point *point(int index) = 0;
99 
100  SWIGOUT(%newobject iterPrims;)
101  virtual HOM_IterableList<HOM_Prim> *iterPrims() = 0;
102 
103  virtual std::vector<HOM_ElemPtr<HOM_Prim> > prims() = 0;
104 
105  SWIGOUT(%newobject prim;)
106  virtual HOM_Prim *prim(int index) = 0;
107 
108  virtual std::vector<std::string> primTypeNames() = 0;
109  virtual std::vector<std::string> primTypeLabels() = 0;
110  virtual std::vector<std::string> primTypeIcons() = 0;
111  virtual bool containsPrimType(const char *type_name) = 0;
112  virtual bool containsPrimType(HOM_EnumValue &prim_type) = 0;
113  virtual int64 countPrimType(const char *type_name) = 0;
114  virtual int64 countPrimType(HOM_EnumValue &prim_type) = 0;
115  virtual int64 countUnusedPoints() = 0;
116 
117  virtual std::vector<HOM_ElemPtr<HOM_Prim> > primsOfType(HOM_EnumValue &prim_type) = 0;
118 
119  SWIGOUT(%newobject iterPrimsOfType;)
120  virtual HOM_IterableList<HOM_Prim> *iterPrimsOfType(HOM_EnumValue &prim_type) = 0;
121 
122  virtual int64 preferredPrecision() = 0;
123  virtual void setPreferredPrecision(int64 prec) = 0;
124 
125  virtual double averageMinDistance(
126  const HOM_Matrix4& local_transform,
127  HOM_Geometry& geometry,
128  const HOM_Matrix4& geometry_transform) = 0;
129 
130  virtual double averageEdgeLength() = 0;
131 
132  virtual std::vector<HOM_ElemPtr<HOM_Point> > globPoints(const char *pattern, bool ordered = false) = 0;
133 
134  virtual std::vector<HOM_ElemPtr<HOM_Prim> > globPrims(const char *pattern) = 0;
135 
136  virtual std::vector<HOM_ElemPtr<HOM_Vertex> > globVertices(
137  const char *pattern) = 0;
138 
139  virtual std::vector<HOM_ElemPtr<HOM_Edge> > globEdges(const char *pattern) = 0;
140 
141  // Wrapped in houpythonportion.py for the deprecated include_private flag
142  virtual std::vector<HOM_ElemPtr<HOM_Attrib> > _pointAttribs(
143  HOM_EnumValue &scope = HOM_attribScope::Public) = 0;
144 
145  // Wrapped in houpythonportion.py for the deprecated include_private flag
146  virtual std::vector<HOM_ElemPtr<HOM_Attrib> > _primAttribs(
147  HOM_EnumValue &scope = HOM_attribScope::Public) = 0;
148 
149  // Wrapped in houpythonportion.py for the deprecated include_private flag
150  virtual std::vector<HOM_ElemPtr<HOM_Attrib> > _vertexAttribs(
151  HOM_EnumValue &scope = HOM_attribScope::Public) = 0;
152 
153  // Wrapped in houpythonportion.py for the deprecated include_private flag
154  virtual std::vector<HOM_ElemPtr<HOM_Attrib> > _globalAttribs(
155  HOM_EnumValue &scope = HOM_attribScope::Public) = 0;
156 
157 
158  SWIGOUT(%newobject findPointAttrib;)
159  virtual HOM_Attrib *findPointAttrib(
160  const char *name, HOM_EnumValue &scope = HOM_attribScope::Public) = 0;
161 
162  SWIGOUT(%newobject findPrimAttrib;)
163  virtual HOM_Attrib *findPrimAttrib(
164  const char *name, HOM_EnumValue &scope = HOM_attribScope::Public) = 0;
165 
166  SWIGOUT(%newobject findVertexAttrib;)
167  virtual HOM_Attrib *findVertexAttrib(
168  const char *name, HOM_EnumValue &scope = HOM_attribScope::Public) = 0;
169 
170  SWIGOUT(%newobject findGlobalAttrib;)
171  virtual HOM_Attrib *findGlobalAttrib(
172  const char *name, HOM_EnumValue &scope = HOM_attribScope::Public) = 0;
173 
174  virtual HOM_EnumValue& attribType() = 0;
175 
176 
177  // These methods return global (detail) attribute values.
178  virtual double floatAttribValue(const char *name) = 0;
179 
180  virtual double floatAttribValue(HOM_Attrib &attrib) = 0;
181 
182  virtual std::vector<double> floatListAttribValue(const char *name) = 0;
183 
184  virtual std::vector<double> floatListAttribValue(HOM_Attrib &attrib) = 0;
185 
186  virtual int64 intAttribValue(const char *name) = 0;
187 
188  virtual int64 intAttribValue(HOM_Attrib &attrib) = 0;
189 
190  virtual std::vector<int64> intListAttribValue(const char *name) = 0;
191 
192  virtual std::vector<int64> intListAttribValue(HOM_Attrib &attrib) = 0;
193 
194  virtual std::string stringAttribValue(const char *name) = 0;
195 
196  virtual std::string stringAttribValue(HOM_Attrib &attrib) = 0;
197 
198  virtual std::vector<std::string> stringListAttribValue(const char *name) = 0;
199 
200  virtual std::vector<std::string> stringListAttribValue(HOM_Attrib &attrib) = 0;
201  virtual std::map<std::string,hboost::any> dictAttribValue(const char *name) = 0;
202  virtual std::map<std::string,hboost::any> dictAttribValue(HOM_Attrib &name) = 0;
203  virtual std::vector<std::map<std::string,hboost::any> > dictListAttribValue(const char *name) = 0;
204  virtual std::vector<std::map<std::string,hboost::any> > dictListAttribValue(HOM_Attrib &name) = 0;
205 
206 
207  // These methods return/set arrays of point/primitive attribute values.
208  virtual std::vector<double> pointFloatAttribValues(const char *name) = 0;
209  SWIGOUT(%kwargs pointFloatAttribValuesAsString;)
210  virtual HOM_BinaryString pointFloatAttribValuesAsString(const char *name,
211  HOM_EnumValue &float_type = HOM_numericData::Float32) = 0;
212  virtual std::vector<double> primFloatAttribValues(const char *name) = 0;
213  SWIGOUT(%kwargs primFloatAttribValuesAsString;)
214  virtual HOM_BinaryString primFloatAttribValuesAsString(const char *name,
215  HOM_EnumValue &float_type = HOM_numericData::Float32) = 0;
216  virtual std::vector<double> vertexFloatAttribValues(const char *name) = 0;
217  SWIGOUT(%kwargs vertexFloatAttribValuesAsString;)
218  virtual HOM_BinaryString vertexFloatAttribValuesAsString(const char *name,
219  HOM_EnumValue &float_type = HOM_numericData::Float32) = 0;
220 
221  virtual std::vector<int64> pointIntAttribValues(const char *name) = 0;
222  SWIGOUT(%kwargs pointIntAttribValuesAsString;)
223  virtual HOM_BinaryString pointIntAttribValuesAsString(const char *name,
224  HOM_EnumValue &int_type = HOM_numericData::Int32) = 0;
225  virtual std::vector<int64> primIntAttribValues(const char *name) = 0;
226  SWIGOUT(%kwargs primIntAttribValuesAsString;)
227  virtual HOM_BinaryString primIntAttribValuesAsString(const char *name,
228  HOM_EnumValue &int_type = HOM_numericData::Int32) = 0;
229  virtual std::vector<int64> vertexIntAttribValues(const char *name) = 0;
230  SWIGOUT(%kwargs vertexIntAttribValuesAsString;)
231  virtual HOM_BinaryString vertexIntAttribValuesAsString(const char *name,
232  HOM_EnumValue &int_type = HOM_numericData::Int32) = 0;
233 
234  virtual std::vector<std::string> pointStringAttribValues(const char *name) = 0;
235  virtual std::vector<std::string> primStringAttribValues(const char *name) = 0;
236  virtual std::vector<std::string> vertexStringAttribValues(const char *name) = 0;
237 
238  virtual void setPointFloatAttribValues(
239  const char *name, const std::vector<double> &values) = 0;
240  virtual void setPrimFloatAttribValues(
241  const char *name, const std::vector<double> &values) = 0;
242  virtual void setVertexFloatAttribValues(
243  const char *name, const std::vector<double> &values) = 0;
244 
245  SWIGOUT(%ignore opaqueSetPointFloatAttribValuesFromString);
246  virtual void opaqueSetPointFloatAttribValuesFromString(
247  const char *name, const char *values, int64 length,
248  HOM_EnumValue &float_type) = 0;
249  SWIGOUT(%ignore opaqueSetPrimFloatAttribValuesFromString);
250  virtual void opaqueSetPrimFloatAttribValuesFromString(
251  const char *name, const char *values, int64 length,
252  HOM_EnumValue &float_type) = 0;
253  SWIGOUT(%ignore opaqueSetVertexFloatAttribValuesFromString);
254  virtual void opaqueSetVertexFloatAttribValuesFromString(
255  const char *name, const char *values, int64 length,
256  HOM_EnumValue &float_type) = 0;
257 
258 #ifdef SWIG
259 %extend
260 {
261  %kwargs setPointFloatAttribValuesFromString;
262  void setPointFloatAttribValuesFromString(
263  const char *name, InterpreterObject values,
264  HOM_EnumValue &float_type = HOM_numericData::Float32)
265  {
266  HOM_PyBuffer buffer(values);
267  self->opaqueSetPointFloatAttribValuesFromString(
268  name, (const char *)buffer.myData, buffer.myLength, float_type);
269  }
270 
271  %kwargs setPrimFloatAttribValuesFromString;
272  void setPrimFloatAttribValuesFromString(
273  const char *name, InterpreterObject values,
274  HOM_EnumValue &float_type = HOM_numericData::Float32)
275  {
276  HOM_PyBuffer buffer(values);
277  self->opaqueSetPrimFloatAttribValuesFromString(
278  name, (const char *)buffer.myData, buffer.myLength, float_type);
279  }
280 
281  %kwargs setVertexFloatAttribValuesFromString;
282  void setVertexFloatAttribValuesFromString(
283  const char *name, InterpreterObject values,
284  HOM_EnumValue &float_type = HOM_numericData::Float32)
285  {
286  HOM_PyBuffer buffer(values);
287  self->opaqueSetVertexFloatAttribValuesFromString(
288  name, (const char *)buffer.myData, buffer.myLength, float_type);
289  }
290 }
291 #endif
292 
293  virtual void setPointIntAttribValues(
294  const char *name, const std::vector<int64> &values) = 0;
295  virtual void setPrimIntAttribValues(
296  const char *name, const std::vector<int64> &values) = 0;
297  virtual void setVertexIntAttribValues(
298  const char *name, const std::vector<int64> &values) = 0;
299 
300  SWIGOUT(%ignore opaqueSetPointIntAttribValuesFromString);
301  virtual void opaqueSetPointIntAttribValuesFromString(
302  const char *name, const char *values, int64 length,
303  HOM_EnumValue &int_type) = 0;
304  SWIGOUT(%ignore opaqueSetPrimIntAttribValuesFromString);
305  virtual void opaqueSetPrimIntAttribValuesFromString(
306  const char *name, const char *values, int64 length,
307  HOM_EnumValue &int_type) = 0;
308  SWIGOUT(%ignore opaqueSetVertexIntAttribValuesFromString);
309  virtual void opaqueSetVertexIntAttribValuesFromString(
310  const char *name, const char *values, int64 length,
311  HOM_EnumValue &int_type) = 0;
312 
313 #ifdef SWIG
314 %extend
315 {
316  %kwargs setPointIntAttribValuesFromString;
317  void setPointIntAttribValuesFromString(
318  const char *name, InterpreterObject values,
319  HOM_EnumValue &int_type = HOM_numericData::Int32)
320  {
321  HOM_PyBuffer buffer(values);
322  self->opaqueSetPointIntAttribValuesFromString(
323  name, (const char *)buffer.myData, buffer.myLength, int_type);
324  }
325 
326  %kwargs setPrimIntAttribValuesFromString;
327  void setPrimIntAttribValuesFromString(
328  const char *name, InterpreterObject values,
329  HOM_EnumValue &int_type = HOM_numericData::Int32)
330  {
331  HOM_PyBuffer buffer(values);
332  self->opaqueSetPrimIntAttribValuesFromString(
333  name, (const char *)buffer.myData, buffer.myLength, int_type);
334  }
335 
336  %kwargs setVertexIntAttribValuesFromString;
337  void setVertexIntAttribValuesFromString(
338  const char *name, InterpreterObject values,
339  HOM_EnumValue &int_type = HOM_numericData::Int32)
340  {
341  HOM_PyBuffer buffer(values);
342  self->opaqueSetVertexIntAttribValuesFromString(
343  name, (const char *)buffer.myData, buffer.myLength, int_type);
344  }
345 }
346 #endif
347 
348  virtual void setPointStringAttribValues(
349  const char *name, const std::vector<std::string> &values) = 0;
350  virtual void setPrimStringAttribValues(
351  const char *name, const std::vector<std::string> &values) = 0;
352  virtual void setVertexStringAttribValues(
353  const char *name, const std::vector<std::string> &values) = 0;
354 
355  virtual void renamePointAttrib(const char *old_name, const char *new_name) = 0;
356  virtual void renamePrimAttrib(const char *old_name, const char *new_name) = 0;
357  virtual void renameVertexAttrib(const char *old_name, const char *new_name) = 0;
358  virtual void renameGlobalAttrib(const char *old_name, const char *new_name) = 0;
359 
360  SWIGOUT(%newobject createPoint;)
361  virtual HOM_Point *createPoint() = 0;
362  virtual std::vector<HOM_ElemPtr<HOM_Point> >createPoints(
363  const std::vector<std::vector<double> > &point_positions) = 0;
364  virtual std::vector<HOM_ElemPtr<HOM_Point> >createPoints(
365  const std::vector<HOM_Vector3 *> &point_positions) = 0;
366 
367  SWIGOUT(%newobject createPolygon;)
368  virtual HOM_Polygon *createPolygon(bool is_closed=true) = 0;
369  virtual std::vector<HOM_ElemPtr<HOM_Polygon> >createPolygons(
370  const std::vector<std::vector<HOM_Point *> > &points,
371  bool is_closed=true) = 0;
372  virtual std::vector<HOM_ElemPtr<HOM_Polygon> >createPolygons(
373  const std::vector<std::vector<int> > &point_numbers,
374  bool is_closed=true) = 0;
375 
376  SWIGOUT(%newobject createPacked;)
377  virtual HOM_PackedPrim *createPacked(
378  const char *packed_type,
379  HOM_Point *point = nullptr) = 0;
380 
381  SWIGOUT(%newobject createTetrahedron;)
382  virtual HOM_Prim *createTetrahedron() = 0;
383 
384  SWIGOUT(%newobject createTetrahedronInPlace;)
385  virtual HOM_Prim *createTetrahedronInPlace(HOM_Point *p0, HOM_Point *p1,
386  HOM_Point *p2, HOM_Point *p3) = 0;
387 
388  SWIGOUT(%newobject createHexahedron;)
389  virtual HOM_Prim *createHexahedron() = 0;
390 
391  SWIGOUT(%newobject createHexahedronInPlace;)
392  virtual HOM_Prim *createHexahedronInPlace(HOM_Point *p0, HOM_Point *p1,
393  HOM_Point *p2, HOM_Point *p3,
394  HOM_Point *p4, HOM_Point *p5,
395  HOM_Point *p6, HOM_Point *p7
396  ) = 0;
397 
398  SWIGOUT(%newobject createNURBSCurve;)
399  SWIGOUT(%kwargs createNURBSCurve;)
400  virtual HOM_Face *createNURBSCurve(int num_points=4, bool is_closed=false,
401  int order=4) = 0;
402 
403  SWIGOUT(%newobject createBezierCurve;)
404  SWIGOUT(%kwargs createBezierCurve;)
405  virtual HOM_Face *createBezierCurve(int num_points=4, bool is_closed=false,
406  int order=4) = 0;
407 
408  SWIGOUT(%newobject createNURBSSurface;)
409  SWIGOUT(%kwargs createNURBSSurface;)
410  virtual HOM_Surface *createNURBSSurface(
411  int rows, int cols,
412  bool is_closed_in_u=false, bool is_closed_in_v=false,
413  int order_u=4, int order_v=4) = 0;
414 
415  SWIGOUT(%newobject createBezierSurface;)
416  SWIGOUT(%kwargs createBezierSurface;)
417  virtual HOM_Surface *createBezierSurface(
418  int rows, int cols,
419  bool is_closed_in_u=false, bool is_closed_in_v=false,
420  int order_u=4, int order_v=4) = 0;
421 
422  SWIGOUT(%newobject createMeshSurface;)
423  SWIGOUT(%kwargs createMeshSurface;)
424  virtual HOM_Surface *createMeshSurface(
425  int rows, int cols,
426  bool is_closed_in_u=false, bool is_closed_in_v=false) = 0;
427 
428  SWIGOUT(%newobject createVolume;)
429  SWIGOUT(%kwargs createVolume;)
430  virtual HOM_Volume *createVolume(
431  int xres, int yres, int zres, HOM_BoundingBox *bounding_box=NULL) = 0;
432 
433  SWIGOUT(%newobject createChannelPrim;)
434  SWIGOUT(%kwargs createChannelPrim;)
435  virtual HOM_ChannelPrim *createChannelPrim() = 0;
436 
437 
438  virtual void transform(HOM_Matrix4 &matrix) = 0;
439 
440  virtual void transformPrims(
441  const std::vector<HOM_Prim *> &prims, const HOM_Matrix4 &matrix) = 0;
442  virtual void transformPrims(
443  const HOM_PrimGroup &prims, const HOM_Matrix4 &matrix) = 0;
444 
445  // Swig does not allow keyword arguments for overloaded functions, so
446  // deletePrims is wrapped in houpythonportion.py to enable keyword
447  // arguments. If you want to change the signature of deletePrims, you must
448  // also edit houpythonportion.py.
449  virtual void deletePrims(
450  const std::vector<HOM_Prim *> &prims, bool keep_points = false) = 0;
451  virtual void deletePrims(
452  const HOM_PrimGroup &prims, bool keep_points = false) = 0;
453 
454  SWIGOUT(%kwargs deletePrimsOutsideBoundingBox;)
455  virtual void deletePrimsOutsideBoundingBox(
456  const HOM_BoundingBox &bbox) = 0;
457 
458  virtual void deletePoints(const std::vector<HOM_Point *> &points) = 0;
459  virtual void deletePoints(const HOM_PointGroup &points) = 0;
460 
461 
462  // Swig does not allow keyword arguments for overloaded functions, so
463  // addAttrib is wrapped in houpythonportion.py to enable keyword
464  // arguments. If you want to change the signature of addAttrib, you must
465  // also edit houpythonportion.py.
466  SWIGOUT(%newobject addAttrib;)
467  virtual HOM_Attrib *addAttrib(
468  HOM_EnumValue &type, const char *name,
469  int64 default_value,
470  bool transform_as_normal,
471  bool create_local_variable) = 0;
472 
473  virtual HOM_Attrib *addAttrib(
474  HOM_EnumValue &type, const char *name,
475  double default_value,
476  bool transform_as_normal,
477  bool create_local_variable) = 0;
478 
479  virtual HOM_Attrib *addAttrib(
480  HOM_EnumValue &type, const char *name,
481  const char *default_value,
482  bool transform_as_normal,
483  bool create_local_variable) = 0;
484 
485  virtual HOM_Attrib *addAttrib(
487  const char *name,
488  const std::vector<int64> &default_value,
489  bool transform_as_normal,
490  bool create_local_variable) = 0;
491 
492  virtual HOM_Attrib *addAttrib(
494  const char *name,
495  const std::vector<double> &default_value,
496  bool transform_as_normal,
497  bool create_local_variable) = 0;
498 
499  virtual HOM_Attrib *addAttrib(
501  const char *name,
502  const std::vector<std::string> &default_value,
503  bool transform_as_normal,
504  bool create_local_variable) = 0;
505 
506  virtual HOM_Attrib *addAttrib(
508  const char *name,
509  const std::map<std::string, hboost::any> &default_value,
510  bool transform_as_normal,
511  bool create_local_variable) = 0;
512 
513  SWIGOUT(%kwargs addArrayAttrib;)
514  SWIGOUT(%newobject addArrayAttrib;)
515  virtual HOM_Attrib *addArrayAttrib(
516  HOM_EnumValue &type, const char *name,
517  HOM_EnumValue &data_type,
518  int64 tuple_size = 1) = 0;
519 
520 
521  virtual void setGlobalAttribValue(
522  HOM_Attrib &attrib, int64 attrib_value) = 0;
523  virtual void setGlobalAttribValue(
524  HOM_Attrib &attrib, double attrib_value) = 0;
525  virtual void setGlobalAttribValue(
526  HOM_Attrib &attrib, const char *attrib_value) = 0;
527  virtual void setGlobalAttribValue(
528  HOM_Attrib &attrib, const std::vector<int64> &attrib_value) = 0;
529  virtual void setGlobalAttribValue(
530  HOM_Attrib &attrib, const std::vector<double> &attrib_value) = 0;
531  virtual void setGlobalAttribValue(
532  HOM_Attrib &attrib, const std::vector<std::string> &attrib_value) = 0;
533  virtual void setGlobalAttribValue(
534  HOM_Attrib &attrib, const std::map<std::string, hboost::any> &attrib_value) = 0;
535  virtual void setGlobalAttribValue(
536  HOM_Attrib &attrib, const std::vector<std::map<std::string,hboost::any> > &attrib_value) = 0;
537 
538  virtual void setGlobalAttribValue(
539  const char *attrib_name, int64 attrib_value) = 0;
540  virtual void setGlobalAttribValue(
541  const char *attrib_name, double attrib_value) = 0;
542  virtual void setGlobalAttribValue(
543  const char *attrib_name, const char *attrib_value) = 0;
544  // Note that, because of strangess the with way swig works when deciding
545  // which overloaded method to call, it's very important that we list the
546  // vector of ints before the vector of doubles. Otherwise, swig will call
547  // the double version when you pass in a vector of ints.
548  // It isn't that simple, the order is important but also depends on
549  // everything else in the override, so you may have to switch these
550  // until SWIG generates the right code...
551  virtual void setGlobalAttribValue(
552  const char *attrib_name, const std::vector<int64> &attrib_value) = 0;
553  virtual void setGlobalAttribValue(
554  const char *attrib_name, const std::vector<double> &attrib_value) = 0;
555  virtual void setGlobalAttribValue(
556  const char *attrib_name,
557  const std::vector<std::string> &attrib_value) = 0;
558  virtual void setGlobalAttribValue(
559  const char *attrib_name,
560  const std::map<std::string, hboost::any> &attrib_value) = 0;
561  virtual void setGlobalAttribValue(
562  const char *attrib_name,
563  const std::vector<std::map<std::string,hboost::any> > &attrib_value) = 0;
564 
565  virtual void copyAttrib(HOM_Attrib *attrib) = 0;
566  virtual void copyAttribs(const std::vector<HOM_Attrib *> &attribs) = 0;
567 
568  SWIGOUT(%kwargs copy;)
569  virtual void copy(HOM_Geometry &geometry, bool clone_data_ids = false,
570  const HOM_Selection *prims = nullptr) = 0;
571 
572  virtual void copyPoints(HOM_Geometry &geometry, const HOM_PointGroup *points = nullptr) = 0;
573  virtual void copyPrims(HOM_Geometry &geometry, const HOM_PrimGroup *prims = nullptr) = 0;
574  virtual void copyEdges(HOM_Geometry &geometry, const HOM_EdgeGroup *edges = nullptr) = 0;
575 
576  virtual int _copySelectionForDrawable(HOM_Geometry &src_geo, const HOM_Selection *sel) = 0;
577  virtual int _copyPrimsForDrawable(HOM_Geometry &src_geo, const std::vector<HOM_Prim*> &prims) = 0;
578  virtual int _copyClearForDrawable(bool keep) = 0;
579  virtual int _replaceWith(HOM_Geometry &src_geo) = 0;
580  virtual int _copyCacheTopology(HOM_Geometry &src_geo) = 0;
581 
582  virtual std::vector<HOM_ElemPtr<HOM_Point> > _getPointChildren(HOM_Point *pt) = 0;
583 #ifdef SWIG
584 %extend
585 {
586  InterpreterObject attribValue(const char *name)
587  { return HOMattribValue(*self, name); }
588 
589  InterpreterObject attribValue(HOM_Attrib &attrib)
590  { return HOMattribValue(*self, attrib); }
591 }
592 #endif
593 
594  virtual std::vector<std::string> attributeCaptureRegions() = 0;
595  virtual std::vector<std::string> attributeCaptureObjectPaths() = 0;
596 
597 
598  virtual std::vector<std::string> intrinsicNames() = 0;
599 
600  virtual hboost::any intrinsicValue(
601  const char *intrinsic_name) = 0;
602  virtual size_t intrinsicSize(const char *intrinsic_name) = 0;
603  virtual bool intrinsicReadOnly(const char *intrinsic_name) = 0;
604 
605  virtual void setIntrinsicValue(const char *intrinsic_name, double value) = 0;
606  virtual void setIntrinsicValue(const char *intrinsic_name, int value) = 0;
607  virtual void setIntrinsicValue(const char *intrinsic_name, int64 value) = 0;
608  virtual void setIntrinsicValue(
609  const char *intrinsic_name, const char *value) = 0;
610  virtual void setIntrinsicValue(
611  const char *intrinsic_name, const std::vector<double> &value) = 0;
612  virtual void setIntrinsicValue(
613  const char *intrinsic_name, const std::vector<int> &value) = 0;
614  virtual void setIntrinsicValue(
615  const char *intrinsic_name, const std::vector<int64> &value) = 0;
616  virtual void setIntrinsicValue(
617  const char *intrinsic_name, const std::vector<std::string> &value) = 0;
618 
619  virtual HOM_BinaryString data() = 0;
620  virtual void load(HOM_BinaryString data) = 0;
621 
622  virtual void saveToFile(const char *file_name) = 0;
623 
624  virtual void loadFromFile(const char *file_name) = 0;
625 
626  SWIGOUT(%kwargs merge;)
627  virtual void merge(HOM_Geometry &geometry, bool clone_data_ids = false,
628  const HOM_Selection *prims = nullptr) = 0;
629 
630  virtual void mergePoints(HOM_Geometry &geometry, const HOM_PointGroup *points = nullptr) = 0;
631  virtual void mergePrims(HOM_Geometry &geometry, const HOM_PrimGroup *prims = nullptr) = 0;
632  virtual void mergeEdges(HOM_Geometry &geometry, const HOM_EdgeGroup *edges = nullptr) = 0;
633 
634  virtual void clear() = 0;
635 
636  SWIGOUT(%kwargs intersect;)
637  virtual int intersect(
638  const HOM_Vector3 &rayorig, const HOM_Vector3 &dir,
640  const char *pattern = nullptr, float min_hit=1e-2f, float max_hit=1e18f,
641  float tolerance=1e-2F) = 0;
642 
643  virtual std::vector<int> _orderedPoints(
644  const char *groupname,
645  const char *corner_groupname,
646  HOM_Vector2 &dimensions) = 0;
647 
648  virtual std::vector<HOM_ElemPtr<HOM_PointGroup> > pointGroups(
649  HOM_EnumValue &scope = HOM_groupScope::Public) = 0;
650 
651  SWIGOUT(%newobject findPointGroup;)
652  virtual HOM_PointGroup *findPointGroup(
653  const char *name, HOM_EnumValue &scope = HOM_groupScope::Public) = 0;
654 
655  SWIGOUT(%newobject createPointGroup;)
656  SWIGOUT(%kwargs createPointGroup;)
657  virtual HOM_PointGroup *createPointGroup(
658  const char *name,
659  bool is_ordered = false,
660  bool unique_name = false) = 0;
661 
662  virtual std::vector<HOM_ElemPtr<HOM_PrimGroup> > primGroups(
663  HOM_EnumValue &scope = HOM_groupScope::Public) = 0;
664 
665  SWIGOUT(%newobject findPrimGroup;)
666  virtual HOM_PrimGroup *findPrimGroup(
667  const char *name, HOM_EnumValue &scope = HOM_groupScope::Public) = 0;
668 
669  SWIGOUT(%newobject createPrimGroup;)
670  SWIGOUT(%kwargs createPrimGroup;)
671  virtual HOM_PrimGroup *createPrimGroup(
672  const char *name,
673  bool is_ordered = false,
674  bool unique_name = false) = 0;
675 
676  virtual std::vector<HOM_ElemPtr<HOM_EdgeGroup> > edgeGroups(
677  HOM_EnumValue &scope = HOM_groupScope::Public) = 0;
678 
679  SWIGOUT(%newobject findEdgeGroup;)
680  virtual HOM_EdgeGroup *findEdgeGroup(
681  const char *name, HOM_EnumValue &scope = HOM_groupScope::Public) = 0;
682 
683  SWIGOUT(%newobject createEdgeGroup;)
684  virtual HOM_EdgeGroup *createEdgeGroup(
685  const char *name) = 0;
686 
687  virtual std::vector<HOM_ElemPtr<HOM_VertexGroup> > vertexGroups(
688  HOM_EnumValue &scope = HOM_groupScope::Public) = 0;
689 
690  SWIGOUT(%newobject findVertexGroup;)
691  virtual HOM_VertexGroup *findVertexGroup(
692  const char *name, HOM_EnumValue &scope = HOM_groupScope::Public) = 0;
693 
694  SWIGOUT(%newobject createVertexGroup;)
695  virtual HOM_VertexGroup *createVertexGroup(
696  const char *name, bool is_ordered=false) = 0;
697 
698  SWIGOUT(%newobject findEdge;)
699  virtual HOM_Edge *findEdge(HOM_Point * p0, HOM_Point * p1) = 0;
700 
701  virtual HOM_BoundingBox boundingBox(HOM_Matrix4* transform = nullptr) = 0;
702  virtual HOM_BoundingBox pointBoundingBox(const char *ptgroup) = 0;
703  virtual HOM_BoundingBox primBoundingBox(const char *primgroup) = 0;
704 
705  virtual HOM_OrientedBoundingBox orientedBoundingBox() = 0;
706  virtual HOM_OrientedBoundingBox orientedPointBoundingBox(const char *ptgroup) = 0;
707  virtual HOM_OrientedBoundingBox orientedPrimBoundingBox(const char *primgroup) = 0;
708 
709  virtual UT_Tuple<HOM_ElemPtr<HOM_Prim>, double, double, double>
710  nearestPrim(const std::vector<double> &position) = 0;
711 
712  SWIGOUT(%newobject nearestPoint;)
713  SWIGOUT(%kwargs nearestPoint;)
714  virtual HOM_Point *
715  nearestPoint(const std::vector<double> &position,
716  const char *ptgroup = nullptr,
717  double max_radius = 1e+18f) = 0;
718 
719  SWIGOUT(%kwargs nearestPoints;)
720  virtual std::vector<HOM_ElemPtr<HOM_Point> >
721  nearestPoints(const std::vector<double> &position,
722  int64 max_points,
723  const char *ptgroup = nullptr,
724  double max_radius = 1e+18f) = 0;
725 
726  SWIGOUT(%kwargs primLoop;)
727  virtual std::vector<HOM_ElemPtr<HOM_Prim> >
728  primLoop(const std::vector<HOM_Prim *> &prims,
729  HOM_EnumValue &loop_type = HOM_componentLoopType::Partial) = 0;
730  SWIGOUT(%kwargs pointLoop;)
731  virtual std::vector<HOM_ElemPtr<HOM_Point> >
732  pointLoop(const std::vector<HOM_Point *> &points,
733  HOM_EnumValue &loop_type = HOM_componentLoopType::Partial) = 0;
734  SWIGOUT(%kwargs edgeLoop;)
735  virtual std::vector<HOM_ElemPtr<HOM_Edge> >
736  edgeLoop(const std::vector<HOM_Edge *> &edges,
737  HOM_EnumValue &loop_type = HOM_componentLoopType::Partial,
738  bool full_loop_per_edge = true,
739  bool force_ring = false,
740  bool allow_ring = true) = 0;
741 
742  virtual std::vector<HOM_Vector3>
743  pointNormals(const std::vector<HOM_Point *> &points) = 0;
744  virtual std::vector<HOM_Vector3>
745  pointNormals(const HOM_PointGroup &points) = 0;
746 
747  SWIGOUT(%newobject importLop;)
748  SWIGOUT(%kwargs importLop;)
749  virtual HOM_LopLockedStage *
750  importLop(
751  HOM_LopNode &lopnode,
752  HOM_LopSelectionRule &selection_rule,
753  const char *purpose = NULL,
754  const char *traversal = NULL,
755  const char *path_attrib_name = NULL,
756  const char *name_attrib_name = NULL,
757  bool strip_layers = false,
759  int lop_output_index = -1) = 0;
760 
761  SWIGOUT(%ignore importUsdStageOpaque;)
762  virtual void importUsdStageOpaque(
763  void *stage,
764  HOM_LopSelectionRule &selection_rule,
765  const char *purpose = NULL,
766  const char *traversal = NULL,
767  const char *path_attrib_name = NULL,
768  const char *name_attrib_name = NULL,
769  HOM_OptionalDouble frame = HOM_OptionalDouble()) = 0;
770 
771 #ifdef SWIG
772 %extend
773 {
774  %kwargs importUsdStage;
775  void importUsdStage(
776  InterpreterObject stage,
777  HOM_LopSelectionRule &selection_rule,
778  const char *purpose = NULL,
779  const char *traversal = NULL,
780  const char *path_attrib_name = NULL,
781  const char *name_attrib_name = NULL,
783  {
784  return self->importUsdStageOpaque(
785  stage, selection_rule, purpose, traversal,
786  path_attrib_name, name_attrib_name, frame);
787  }
788 }
789 #endif
790 
791  SWIGOUT(%newobject selection;)
792  virtual HOM_Selection *selection() = 0;
793 
794  // This method is not documented in the user documentation. See
795  // the comments in HOMF_Geometry.C for what it does.
796  SWIGOUT(%newobject _guDetailHandle;)
797  virtual HOM_GUDetailHandle *_guDetailHandle() = 0;
798 
799  // This method is not documented in the user documentation. See the
800  // comments in HOMF_Geometry.C for what it does.
801  virtual HOMF_GeometryHandle& _geometryHandle() = 0;
802 
803  virtual std::vector<int> vexAttribDataId() = 0;
804 
805  virtual int64 modificationCounter() = 0;
806  virtual void incrementModificationCounter() = 0;
807 
808  virtual void incrementAllDataIds() = 0;
809 
810  SWIGOUT(%kwargs incrementDataIdsForAddOrRemove;)
811  virtual void incrementDataIdsForAddOrRemove(
812  bool for_points=true, bool for_prims=true) = 0;
813 
814  SWIGOUT(%newobject primitiveIntrinsicsDataId;)
815  virtual HOM_AttribDataId *primitiveIntrinsicsDataId() = 0;
816  virtual void incrementPrimitiveIntrinsicsDataId() = 0;
817 
818  SWIGOUT(%newobject topologyDataId;)
819  virtual HOM_AttribDataId *topologyDataId() = 0;
820  virtual void incrementTopologyDataId() = 0;
821 
822  SWIGOUT(%kwargs generateAttribMenu;)
823  virtual std::vector<std::string> generateAttribMenu(
824  HOM_EnumValue *attrib_type = nullptr,
825  HOM_EnumValue *data_type = nullptr,
826  int min_size = 1,
827  int max_size = -1,
828  bool array_type = true,
829  bool scalar_type = true,
830  bool case_sensitive = true,
831  const char *pattern = "*",
832  bool decode_tokens = false) = 0;
833 
834  // Wrapped in houpythonportion to handle kwargs for an overloaded method.
835  virtual std::vector<std::string> _generateGroupMenu(
836  const std::vector<HOM_EnumValue *> &group_types,
837  bool include_selection,
838  bool include_name_attrib,
839  bool case_sensitive,
840  const char *pattern,
841  bool decode_tokens,
842  HOM_Parm *parm) = 0;
843 
844  virtual bool isReadOnly() = 0;
845 
846  virtual void _attribInfo( const char *name, int &attr_data_type, int &attr_size, bool &is_array_type) = 0;
847 
848  virtual std::vector<std::string> extractPackedPaths(const char *pattern) = 0;
849  SWIGOUT(%newobject unpackFromFolder;)
850  virtual HOM_Geometry *unpackFromFolder(const char *path) = 0;
851  SWIGOUT(%newobject unpackPropertiesFromFolder;)
852  virtual std::map<std::string, hboost::any> packedFolderProperties(const char *path) = 0;
853  SWIGOUT(%kwargs packToFolder;)
854  virtual bool packToFolder(
855  const char *path,
856  HOM_Geometry &geometry,
857  bool is_folder = false,
858  bool is_visible = true,
859  bool pack = true) = 0;
860 
861  virtual bool removeFromFolder(const char *path) = 0;
862 };
863 
864 #endif
GT_API const UT_StringHolder selection
__hostdev__ uint64_t pointCount() const
Definition: NanoVDB.h:5974
#define HOM_DESTRUCT_OBJECT(pointer)
Definition: HOM_Module.h:1343
GLdouble GLdouble GLint GLint const GLdouble * points
Definition: glad.h:2676
GLboolean * data
Definition: glcorearb.h:131
OIIO_UTIL_API bool copy(string_view from, string_view to, std::string &err)
GLsizei const GLfloat * value
Definition: glcorearb.h:824
GLsizei const GLchar *const * path
Definition: glcorearb.h:3341
#define SWIGOUT(x)
Definition: HOM_Defines.h:24
GLuint GLsizei GLsizei * length
Definition: glcorearb.h:795
string __repr__(VtArray< T > const &self)
Definition: wrapArray.h:312
std::tuple< Types...> UT_Tuple
Definition: UT_Tuple.h:53
virtual HOM_Geometry * newGeometry(HOM_Geometry *geo=nullptr, bool clone_data_ids=false)=0
GLuint buffer
Definition: glcorearb.h:660
GLdouble n
Definition: glcorearb.h:2008
GLfloat f
Definition: glcorearb.h:1926
GLint GLint GLsizei GLint GLenum GLenum type
Definition: glcorearb.h:108
bool any(const vbool4 &v)
Definition: simd.h:3600
#define HOM_API
Definition: HOM_API.h:13
HOM_Geometry(const HOM_Geometry &)
Definition: HOM_Geometry.h:70
void ignore(T const &) VULKAN_HPP_NOEXCEPT
Definition: vulkan.hpp:6508
constexpr std::enable_if< I< type_count_base< T >::value, int >::type tuple_type_size(){return subtype_count< typename std::tuple_element< I, T >::type >::value+tuple_type_size< T, I+1 >);}template< typename T > struct type_count< T, typename std::enable_if< is_tuple_like< T >::value >::type >{static constexpr int value{tuple_type_size< T, 0 >)};};template< typename T > struct subtype_count{static constexpr int value{is_mutable_container< T >::value?expected_max_vector_size:type_count< T >::value};};template< typename T, typename Enable=void > struct type_count_min{static const int value{0};};template< typename T >struct type_count_min< T, typename std::enable_if<!is_mutable_container< T >::value &&!is_tuple_like< T >::value &&!is_wrapper< T >::value &&!is_complex< T >::value &&!std::is_void< T >::value >::type >{static constexpr int value{type_count< T >::value};};template< typename T > struct type_count_min< T, typename std::enable_if< is_complex< T >::value >::type >{static constexpr int value{1};};template< typename T >struct type_count_min< T, typename std::enable_if< is_wrapper< T >::value &&!is_complex< T >::value &&!is_tuple_like< T >::value >::type >{static constexpr int value{subtype_count_min< typename T::value_type >::value};};template< typename T, std::size_t I >constexpr typename std::enable_if< I==type_count_base< T >::value, int >::type tuple_type_size_min(){return 0;}template< typename T, std::size_t I > constexpr typename std::enable_if< I< type_count_base< T >::value, int >::type tuple_type_size_min(){return subtype_count_min< typename std::tuple_element< I, T >::type >::value+tuple_type_size_min< T, I+1 >);}template< typename T > struct type_count_min< T, typename std::enable_if< is_tuple_like< T >::value >::type >{static constexpr int value{tuple_type_size_min< T, 0 >)};};template< typename T > struct subtype_count_min{static constexpr int value{is_mutable_container< T >::value?((type_count< T >::value< expected_max_vector_size)?type_count< T >::value:0):type_count_min< T >::value};};template< typename T, typename Enable=void > struct expected_count{static const int value{0};};template< typename T >struct expected_count< T, typename std::enable_if<!is_mutable_container< T >::value &&!is_wrapper< T >::value &&!std::is_void< T >::value >::type >{static constexpr int value{1};};template< typename T > struct expected_count< T, typename std::enable_if< is_mutable_container< T >::value >::type >{static constexpr int value{expected_max_vector_size};};template< typename T >struct expected_count< T, typename std::enable_if<!is_mutable_container< T >::value &&is_wrapper< T >::value >::type >{static constexpr int value{expected_count< typename T::value_type >::value};};enum class object_category:int{char_value=1, integral_value=2, unsigned_integral=4, enumeration=6, boolean_value=8, floating_point=10, number_constructible=12, double_constructible=14, integer_constructible=16, string_assignable=23, string_constructible=24, other=45, wrapper_value=50, complex_number=60, tuple_value=70, container_value=80,};template< typename T, typename Enable=void > struct classify_object{static constexpr object_category value{object_category::other};};template< typename T >struct classify_object< T, typename std::enable_if< std::is_integral< T >::value &&!std::is_same< T, char >::value &&std::is_signed< T >::value &&!is_bool< T >::value &&!std::is_enum< T >::value >::type >{static constexpr object_category value{object_category::integral_value};};template< typename T >struct classify_object< T, typename std::enable_if< std::is_integral< T >::value &&std::is_unsigned< T >::value &&!std::is_same< T, char >::value &&!is_bool< T >::value >::type >{static constexpr object_category value{object_category::unsigned_integral};};template< typename T >struct classify_object< T, typename std::enable_if< std::is_same< T, char >::value &&!std::is_enum< T >::value >::type >{static constexpr object_category value{object_category::char_value};};template< typename T > struct classify_object< T, typename std::enable_if< is_bool< T >::value >::type >{static constexpr object_category value{object_category::boolean_value};};template< typename T > struct classify_object< T, typename std::enable_if< std::is_floating_point< T >::value >::type >{static constexpr object_category value{object_category::floating_point};};template< typename T >struct classify_object< T, typename std::enable_if<!std::is_floating_point< T >::value &&!std::is_integral< T >::value &&std::is_assignable< T &, std::string >::value >::type >{static constexpr object_category value{object_category::string_assignable};};template< typename T >struct classify_object< T, typename std::enable_if<!std::is_floating_point< T >::value &&!std::is_integral< T >::value &&!std::is_assignable< T &, std::string >::value &&(type_count< T >::value==1)&&std::is_constructible< T, std::string >::value >::type >{static constexpr object_category value{object_category::string_constructible};};template< typename T > struct classify_object< T, typename std::enable_if< std::is_enum< T >::value >::type >{static constexpr object_category value{object_category::enumeration};};template< typename T > struct classify_object< T, typename std::enable_if< is_complex< T >::value >::type >{static constexpr object_category value{object_category::complex_number};};template< typename T > struct uncommon_type{using type=typename std::conditional<!std::is_floating_point< T >::value &&!std::is_integral< T >::value &&!std::is_assignable< T &, std::string >::value &&!std::is_constructible< T, std::string >::value &&!is_complex< T >::value &&!is_mutable_container< T >::value &&!std::is_enum< T >::value, std::true_type, std::false_type >::type;static constexpr bool value=type::value;};template< typename T >struct classify_object< T, typename std::enable_if<(!is_mutable_container< T >::value &&is_wrapper< T >::value &&!is_tuple_like< T >::value &&uncommon_type< T >::value)>::type >{static constexpr object_category value{object_category::wrapper_value};};template< typename T >struct classify_object< T, typename std::enable_if< uncommon_type< T >::value &&type_count< T >::value==1 &&!is_wrapper< T >::value &&is_direct_constructible< T, double >::value &&is_direct_constructible< T, int >::value >::type >{static constexpr object_category value{object_category::number_constructible};};template< typename T >struct classify_object< T, typename std::enable_if< uncommon_type< T >::value &&type_count< T >::value==1 &&!is_wrapper< T >::value &&!is_direct_constructible< T, double >::value &&is_direct_constructible< T, int >::value >::type >{static constexpr object_category value{object_category::integer_constructible};};template< typename T >struct classify_object< T, typename std::enable_if< uncommon_type< T >::value &&type_count< T >::value==1 &&!is_wrapper< T >::value &&is_direct_constructible< T, double >::value &&!is_direct_constructible< T, int >::value >::type >{static constexpr object_category value{object_category::double_constructible};};template< typename T >struct classify_object< T, typename std::enable_if< is_tuple_like< T >::value &&((type_count< T >::value >=2 &&!is_wrapper< T >::value)||(uncommon_type< T >::value &&!is_direct_constructible< T, double >::value &&!is_direct_constructible< T, int >::value)||(uncommon_type< T >::value &&type_count< T >::value >=2))>::type >{static constexpr object_category value{object_category::tuple_value};};template< typename T > struct classify_object< T, typename std::enable_if< is_mutable_container< T >::value >::type >{static constexpr object_category value{object_category::container_value};};template< typename T, enable_if_t< classify_object< T >::value==object_category::char_value, detail::enabler >=detail::dummy >constexpr const char *type_name(){return"CHAR";}template< typename T, enable_if_t< classify_object< T >::value==object_category::integral_value||classify_object< T >::value==object_category::integer_constructible, detail::enabler >=detail::dummy >constexpr const char *type_name(){return"INT";}template< typename T, enable_if_t< classify_object< T >::value==object_category::unsigned_integral, detail::enabler >=detail::dummy >constexpr const char *type_name(){return"UINT";}template< typename T, enable_if_t< classify_object< T >::value==object_category::floating_point||classify_object< T >::value==object_category::number_constructible||classify_object< T >::value==object_category::double_constructible, detail::enabler >=detail::dummy >constexpr const char *type_name(){return"FLOAT";}template< typename T, enable_if_t< classify_object< T >::value==object_category::enumeration, detail::enabler >=detail::dummy >constexpr const char *type_name(){return"ENUM";}template< typename T, enable_if_t< classify_object< T >::value==object_category::boolean_value, detail::enabler >=detail::dummy >constexpr const char *type_name(){return"BOOLEAN";}template< typename T, enable_if_t< classify_object< T >::value==object_category::complex_number, detail::enabler >=detail::dummy >constexpr const char *type_name(){return"COMPLEX";}template< typename T, enable_if_t< classify_object< T >::value >=object_category::string_assignable &&classify_object< T >::value<=object_category::other, detail::enabler >=detail::dummy >constexpr const char *type_name(){return"TEXT";}template< typename T, enable_if_t< classify_object< T >::value==object_category::tuple_value &&type_count_base< T >::value >=2, detail::enabler >=detail::dummy >std::string type_name();template< typename T, enable_if_t< classify_object< T >::value==object_category::container_value||classify_object< T >::value==object_category::wrapper_value, detail::enabler >=detail::dummy >std::string type_name();template< typename T, enable_if_t< classify_object< T >::value==object_category::tuple_value &&type_count_base< T >::value==1, detail::enabler >=detail::dummy >inline std::string type_name(){return type_name< typename std::decay< typename std::tuple_element< 0, T >::type >::type >);}template< typename T, std::size_t I >inline typename std::enable_if< I==type_count_base< T >::value, std::string >::type tuple_name(){return std::string{};}template< typename T, std::size_t I >inline typename std::enable_if<(I< type_count_base< T >::value), std::string >::type tuple_name(){auto str=std::string{type_name< typename std::decay< typename std::tuple_element< I, T >::type >::type >)}+ ','+tuple_name< T, I+1 >);if(str.back()== ',') str.pop_back();return str;}template< typename T, enable_if_t< classify_object< T >::value==object_category::tuple_value &&type_count_base< T >::value >=2, detail::enabler > > std::string type_name()
Recursively generate the tuple type name.
Definition: CLI11.h:1729
ApexGeometry Geometry
Definition: APEX_Include.h:69
#define HOM_CONSTRUCT_OBJECT(pointer)
Definition: HOM_Module.h:1342
GLdouble GLdouble GLint GLint order
Definition: glad.h:2676
long long int64
Definition: SYS_Types.h:116
GLuint const GLchar * name
Definition: glcorearb.h:786
GLushort pattern
Definition: glad.h:2583
GA_API const UT_StringHolder transform
GLenum GLsizei GLsizei GLint * values
Definition: glcorearb.h:1602
OIIO_UTIL_API bool rename(string_view from, string_view to, std::string &err)
GLuint index
Definition: glcorearb.h:786
SIM_API const UT_StringHolder position
IMATH_CONSTEXPR14 bool intersect(const Line3< T > &line, const Vec3< T > &v0, const Vec3< T > &v1, const Vec3< T > &v2, Vec3< T > &pt, Vec3< T > &barycentric, bool &front) IMATH_NOEXCEPT
Definition: ImathLineAlgo.h:80
UT_Optional< double > HOM_OptionalDouble
Definition: HOM_Defines.h:45
virtual ~HOM_Geometry()
Definition: HOM_Geometry.h:73
OutGridT XformOp bool bool MergePolicy merge
HOM_API HOM_Module & HOM()
Definition: format.h:1821