HDK
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
SOP_SoftTransform.proto.h
Go to the documentation of this file.
1 /* Automagically Generated by generate_proto.py
2  * Do not Edit
3  */
4 #pragma once
5 
6 #include <SOP/SOP_API.h>
7 #include <SOP/SOP_NodeVerb.h>
8 #include <OP/OP_GraphProxy.h>
9 
10 #include <OP/OP_Utils.h>
11 #include <PRM/PRM_Parm.h>
12 #include <UT/UT_IStream.h>
13 #include <UT/UT_NTStreamUtil.h>
14 #include <UT/UT_Ramp.h>
15 #include <UT/UT_SharedPtr.h>
16 #include <UT/UT_StringHolder.h>
17 #include <UT/UT_StringStream.h>
18 #include <UT/UT_VectorTypes.h>
19 #include <UT/UT_EnvControl.h>
20 #include <SYS/SYS_Types.h>
21 
22 class DEP_MicroNode;
23 namespace SOP_SoftTransformEnums
24 {
25  enum class Xord
26  {
27  SRT = 0,
28  STR,
29  RST,
30  RTS,
31  TSR,
32  TRS
33  };
34 
36  getToken(Xord enum_value)
37  {
38  using namespace UT::Literal;
39  switch (enum_value) {
40  case Xord::SRT: return "srt"_sh;
41  case Xord::STR: return "str"_sh;
42  case Xord::RST: return "rst"_sh;
43  case Xord::RTS: return "rts"_sh;
44  case Xord::TSR: return "tsr"_sh;
45  case Xord::TRS: return "trs"_sh;
46  default: UT_ASSERT(false); return ""_sh;
47  }
48  }
49 
50  enum class Rord
51  {
52  XYZ = 0,
53  XZY,
54  YXZ,
55  YZX,
56  ZXY,
57  ZYX
58  };
59 
61  getToken(Rord enum_value)
62  {
63  using namespace UT::Literal;
64  switch (enum_value) {
65  case Rord::XYZ: return "xyz"_sh;
66  case Rord::XZY: return "xzy"_sh;
67  case Rord::YXZ: return "yxz"_sh;
68  case Rord::YZX: return "yzx"_sh;
69  case Rord::ZXY: return "zxy"_sh;
70  case Rord::ZYX: return "zyx"_sh;
71  default: UT_ASSERT(false); return ""_sh;
72  }
73  }
74 
75  enum class Distmetric
76  {
77  CUSTOM = 0,
78  EDGES,
79  GLOBAL,
81  SURFACE
82  };
83 
85  getToken(Distmetric enum_value)
86  {
87  using namespace UT::Literal;
88  switch (enum_value) {
89  case Distmetric::CUSTOM: return "custom"_sh;
90  case Distmetric::EDGES: return "edges"_sh;
91  case Distmetric::GLOBAL: return "global"_sh;
92  case Distmetric::GLOBALCONNECTED: return "globalconnected"_sh;
93  case Distmetric::SURFACE: return "surface"_sh;
94  default: UT_ASSERT(false); return ""_sh;
95  }
96  }
97 
98  enum class Type
99  {
100  LINEAR = 0,
101  QUADRATIC,
102  CUBIC,
103  META
104  };
105 
107  getToken(Type enum_value)
108  {
109  using namespace UT::Literal;
110  switch (enum_value) {
111  case Type::LINEAR: return "linear"_sh;
112  case Type::QUADRATIC: return "quadratic"_sh;
113  case Type::CUBIC: return "cubic"_sh;
114  case Type::META: return "meta"_sh;
115  default: UT_ASSERT(false); return ""_sh;
116  }
117  }
118 
119  enum class Visualizefalloff
120  {
121  NEVER = 0,
122  ALWAYS,
123  STATE
124  };
125 
128  {
129  using namespace UT::Literal;
130  switch (enum_value) {
131  case Visualizefalloff::NEVER: return "never"_sh;
132  case Visualizefalloff::ALWAYS: return "always"_sh;
133  case Visualizefalloff::STATE: return "state"_sh;
134  default: UT_ASSERT(false); return ""_sh;
135  }
136  }
137 
138 }
139 
140 
142 {
143 public:
144  static int version() { return 1; }
145 
147  {
148  myGroup = ""_UTsh;
149  myXord = 0;
150  myRord = 0;
151  myT = UT_Vector3D(0,0,0);
152  myR = UT_Vector3D(0,0,0);
153  myS = UT_Vector3D(1,1,1);
154  myShear = UT_Vector3D(0,0,0);
155  myP = UT_Vector3D(0,0,0);
156  myPr = UT_Vector3D(0,0,0);
157  myDistmetric = 4;
158  myApplyrolloff = false;
159  myDistattr = ""_UTsh;
160  myRad = 0.5;
161  myType = 2;
162  myTandeg = UT_Vector2D(0,0);
163  myKernel = "wyvill"_UTsh;
164  myAttribs = "*"_UTsh;
165  myUpdatenmls = false;
166  myUpdateaffectednmls = true;
167  myVlength = true;
168  myVisualizefalloff = 2;
169  myLocalspace = false;
170  myUpvector = UT_Vector3D(0,1,0);
171 
172  }
173 
174  explicit SOP_SoftTransformParms(const SOP_SoftTransformParms &) = default;
176  SOP_SoftTransformParms(SOP_SoftTransformParms &&) noexcept = default;
177  SOP_SoftTransformParms &operator=(SOP_SoftTransformParms &&) noexcept = default;
178 
179  ~SOP_SoftTransformParms() override {}
180 
182  {
183  if (myGroup != src.myGroup) return false;
184  if (myXord != src.myXord) return false;
185  if (myRord != src.myRord) return false;
186  if (myT != src.myT) return false;
187  if (myR != src.myR) return false;
188  if (myS != src.myS) return false;
189  if (myShear != src.myShear) return false;
190  if (myP != src.myP) return false;
191  if (myPr != src.myPr) return false;
192  if (myDistmetric != src.myDistmetric) return false;
193  if (myApplyrolloff != src.myApplyrolloff) return false;
194  if (myDistattr != src.myDistattr) return false;
195  if (myRad != src.myRad) return false;
196  if (myType != src.myType) return false;
197  if (myTandeg != src.myTandeg) return false;
198  if (myKernel != src.myKernel) return false;
199  if (myAttribs != src.myAttribs) return false;
200  if (myUpdatenmls != src.myUpdatenmls) return false;
201  if (myUpdateaffectednmls != src.myUpdateaffectednmls) return false;
202  if (myVlength != src.myVlength) return false;
203  if (myVisualizefalloff != src.myVisualizefalloff) return false;
204  if (myLocalspace != src.myLocalspace) return false;
205  if (myUpvector != src.myUpvector) return false;
206 
207 
208  if (baseGetSignature() != src.baseGetSignature()) return false;
209 
210  return true;
211  }
213  {
214  return !operator==(src);
215  }
221 
222 
223 
224  void buildFromOp(const OP_GraphProxy *graph, exint nodeidx, fpreal time, DEP_MicroNode *depnode)
225  {
226  myGroup = ""_UTsh;
227  if (true)
228  graph->evalOpParm(myGroup, nodeidx, "group", time, graph->isDirect()?nullptr:depnode);
229  myXord = 0;
230  if (true)
231  graph->evalOpParm(myXord, nodeidx, "xOrd", time, graph->isDirect()?nullptr:depnode);
232  myRord = 0;
233  if (true)
234  graph->evalOpParm(myRord, nodeidx, "rOrd", time, graph->isDirect()?nullptr:depnode);
235  myT = UT_Vector3D(0,0,0);
236  if (true)
237  graph->evalOpParm(myT, nodeidx, "t", time, graph->isDirect()?nullptr:depnode);
238  myR = UT_Vector3D(0,0,0);
239  if (true)
240  graph->evalOpParm(myR, nodeidx, "r", time, graph->isDirect()?nullptr:depnode);
241  myS = UT_Vector3D(1,1,1);
242  if (true)
243  graph->evalOpParm(myS, nodeidx, "s", time, graph->isDirect()?nullptr:depnode);
244  myShear = UT_Vector3D(0,0,0);
245  if (true)
246  graph->evalOpParm(myShear, nodeidx, "shear", time, graph->isDirect()?nullptr:depnode);
247  myP = UT_Vector3D(0,0,0);
248  if (true)
249  graph->evalOpParm(myP, nodeidx, "p", time, graph->isDirect()?nullptr:depnode);
250  myPr = UT_Vector3D(0,0,0);
251  if (true)
252  graph->evalOpParm(myPr, nodeidx, "pr", time, graph->isDirect()?nullptr:depnode);
253  myDistmetric = 4;
254  if (true)
255  graph->evalOpParm(myDistmetric, nodeidx, "distmetric", time, graph->isDirect()?nullptr:depnode);
256  myApplyrolloff = false;
257  if (true && ( (true&&!(((int64(getDistmetric())!=0)))) ) )
258  graph->evalOpParm(myApplyrolloff, nodeidx, "applyrolloff", time, graph->isDirect()?nullptr:depnode);
259  myDistattr = ""_UTsh;
260  if (true && ( (true&&!(((int64(getDistmetric())!=0)))) ) )
261  graph->evalOpParm(myDistattr, nodeidx, "distattr", time, graph->isDirect()?nullptr:depnode);
262  myRad = 0.5;
263  if (true && ( (true&&!(((int64(getDistmetric())==0)&&(getApplyrolloff()==0)))) ) )
264  graph->evalOpParm(myRad, nodeidx, "rad", time, graph->isDirect()?nullptr:depnode);
265  myType = 2;
266  if (true && ( (true&&!(((int64(getDistmetric())==0)&&(getApplyrolloff()==0)))) ) )
267  graph->evalOpParm(myType, nodeidx, "type", time, graph->isDirect()?nullptr:depnode);
268  myTandeg = UT_Vector2D(0,0);
269  if (true && ( (true&&!(((int64(getType())!=2))||((int64(getDistmetric())==0)&&(getApplyrolloff()==0)))) ) )
270  graph->evalOpParm(myTandeg, nodeidx, "tandeg", time, graph->isDirect()?nullptr:depnode);
271  myKernel = "wyvill"_UTsh;
272  if (true && ( (true&&!(((int64(getType())!=3))||((int64(getDistmetric())==0)&&(getApplyrolloff()==0)))) ) )
273  graph->evalOpParm(myKernel, nodeidx, "kernel", time, graph->isDirect()?nullptr:depnode);
274  myAttribs = "*"_UTsh;
275  if (true)
276  graph->evalOpParm(myAttribs, nodeidx, "attribs", time, graph->isDirect()?nullptr:depnode);
277  myUpdatenmls = false;
278  if (true)
279  graph->evalOpParm(myUpdatenmls, nodeidx, "updatenmls", time, graph->isDirect()?nullptr:depnode);
280  myUpdateaffectednmls = true;
281  if (true && ( (true&&!(((getUpdatenmls()==1)))) ) )
282  graph->evalOpParm(myUpdateaffectednmls, nodeidx, "updateaffectednmls", time, graph->isDirect()?nullptr:depnode);
283  myVlength = true;
284  if (true && ( (true&&!(((getUpdatenmls()==1)))) ) )
285  graph->evalOpParm(myVlength, nodeidx, "vlength", time, graph->isDirect()?nullptr:depnode);
286  myVisualizefalloff = 2;
287  if (true)
288  graph->evalOpParm(myVisualizefalloff, nodeidx, "visualizefalloff", time, graph->isDirect()?nullptr:depnode);
289  myLocalspace = false;
290  if (true)
291  graph->evalOpParm(myLocalspace, nodeidx, "localspace", time, graph->isDirect()?nullptr:depnode);
292  myUpvector = UT_Vector3D(0,1,0);
293  if (true && ( (true&&!(((getLocalspace()==0)))) ) )
294  graph->evalOpParm(myUpvector, nodeidx, "upvector", time, graph->isDirect()?nullptr:depnode);
295 
296  }
297 
298 
299  void loadFromOpSubclass(const LoadParms &loadparms) override
300  {
301  buildFromOp(loadparms.graph(), loadparms.nodeIdx(), loadparms.context().getTime(), loadparms.depnode());
302  }
303 
304 
305  void copyFrom(const OP_NodeParms *src) override
306  {
307  *this = *((const SOP_SoftTransformParms *)src);
308  }
309 
310  template <typename T>
311  void
312  doGetParmValue(TempIndex idx, TempIndex instance, T &value) const
313  {
314  if (idx.size() < 1)
315  return;
316  UT_ASSERT(idx.size() == instance.size()+1);
317  if (idx.size() != instance.size()+1)
318  return;
319  switch (idx[0])
320  {
321  case 0:
322  coerceValue(value, myGroup);
323  break;
324  case 1:
325  coerceValue(value, myXord);
326  break;
327  case 2:
328  coerceValue(value, myRord);
329  break;
330  case 3:
331  coerceValue(value, myT);
332  break;
333  case 4:
334  coerceValue(value, myR);
335  break;
336  case 5:
337  coerceValue(value, myS);
338  break;
339  case 6:
340  coerceValue(value, myShear);
341  break;
342  case 7:
343  coerceValue(value, myP);
344  break;
345  case 8:
346  coerceValue(value, myPr);
347  break;
348  case 9:
349  coerceValue(value, myDistmetric);
350  break;
351  case 10:
352  coerceValue(value, myApplyrolloff);
353  break;
354  case 11:
355  coerceValue(value, myDistattr);
356  break;
357  case 12:
358  coerceValue(value, myRad);
359  break;
360  case 13:
361  coerceValue(value, myType);
362  break;
363  case 14:
364  coerceValue(value, myTandeg);
365  break;
366  case 15:
367  coerceValue(value, myKernel);
368  break;
369  case 16:
370  coerceValue(value, myAttribs);
371  break;
372  case 17:
373  coerceValue(value, myUpdatenmls);
374  break;
375  case 18:
376  coerceValue(value, myUpdateaffectednmls);
377  break;
378  case 19:
379  coerceValue(value, myVlength);
380  break;
381  case 20:
382  coerceValue(value, myVisualizefalloff);
383  break;
384  case 21:
385  coerceValue(value, myLocalspace);
386  break;
387  case 22:
388  coerceValue(value, myUpvector);
389  break;
390 
391  }
392  }
393 
394  bool isParmColorRamp(exint idx) const override
395  {
396  switch (idx)
397  {
398 
399  }
400  return false;
401  }
402 
403  void getNestParmValue(TempIndex idx, TempIndex instance, exint &value) const override
404  { doGetParmValue(idx, instance, value); }
405  void getNestParmValue(TempIndex idx, TempIndex instance, fpreal &value) const override
406  { doGetParmValue(idx, instance, value); }
407  void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector2D &value) const override
408  { doGetParmValue(idx, instance, value); }
409  void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector3D &value) const override
410  { doGetParmValue(idx, instance, value); }
411  void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector4D &value) const override
412  { doGetParmValue(idx, instance, value); }
413  void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix2D &value) const override
414  { doGetParmValue(idx, instance, value); }
415  void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix3D &value) const override
416  { doGetParmValue(idx, instance, value); }
417  void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix4D &value) const override
418  { doGetParmValue(idx, instance, value); }
419  void getNestParmValue(TempIndex idx, TempIndex instance, UT_StringHolder &value) const override
420  { doGetParmValue(idx, instance, value); }
421  void getNestParmValue(TempIndex idx, TempIndex instance, UT_SharedPtr<UT_Ramp> &value) const override
422  { doGetParmValue(idx, instance, value); }
423  void getNestParmValue(TempIndex idx, TempIndex instance, PRM_DataItemHandle &value) const override
424  { doGetParmValue(idx, instance, value); }
425 
426  template <typename T>
427  void
428  doSetParmValue(TempIndex idx, TempIndex instance, const T &value)
429  {
430  if (idx.size() < 1)
431  return;
432  UT_ASSERT(idx.size() == instance.size()+1);
433  if (idx.size() != instance.size()+1)
434  return;
435  switch (idx[0])
436  {
437  case 0:
438  coerceValue(myGroup, ( ( value ) ));
439  break;
440  case 1:
441  coerceValue(myXord, clampMinValue(0, clampMaxValue(5, value ) ));
442  break;
443  case 2:
444  coerceValue(myRord, clampMinValue(0, clampMaxValue(5, value ) ));
445  break;
446  case 3:
447  coerceValue(myT, ( ( value ) ));
448  break;
449  case 4:
450  coerceValue(myR, ( ( value ) ));
451  break;
452  case 5:
453  coerceValue(myS, ( ( value ) ));
454  break;
455  case 6:
456  coerceValue(myShear, ( ( value ) ));
457  break;
458  case 7:
459  coerceValue(myP, ( ( value ) ));
460  break;
461  case 8:
462  coerceValue(myPr, ( ( value ) ));
463  break;
464  case 9:
465  coerceValue(myDistmetric, clampMinValue(0, clampMaxValue(4, value ) ));
466  break;
467  case 10:
468  coerceValue(myApplyrolloff, ( ( value ) ));
469  break;
470  case 11:
471  coerceValue(myDistattr, ( ( value ) ));
472  break;
473  case 12:
474  coerceValue(myRad, clampMinValue(0, ( value ) ));
475  break;
476  case 13:
477  coerceValue(myType, clampMinValue(0, clampMaxValue(3, value ) ));
478  break;
479  case 14:
480  coerceValue(myTandeg, ( ( value ) ));
481  break;
482  case 15:
483  coerceValue(myKernel, ( ( value ) ));
484  break;
485  case 16:
486  coerceValue(myAttribs, ( ( value ) ));
487  break;
488  case 17:
489  coerceValue(myUpdatenmls, ( ( value ) ));
490  break;
491  case 18:
492  coerceValue(myUpdateaffectednmls, ( ( value ) ));
493  break;
494  case 19:
495  coerceValue(myVlength, ( ( value ) ));
496  break;
497  case 20:
498  coerceValue(myVisualizefalloff, clampMinValue(0, clampMaxValue(2, value ) ));
499  break;
500  case 21:
501  coerceValue(myLocalspace, ( ( value ) ));
502  break;
503  case 22:
504  coerceValue(myUpvector, ( ( value ) ));
505  break;
506 
507  }
508  }
509 
510  void setNestParmValue(TempIndex idx, TempIndex instance, const exint &value) override
511  { doSetParmValue(idx, instance, value); }
512  void setNestParmValue(TempIndex idx, TempIndex instance, const fpreal &value) override
513  { doSetParmValue(idx, instance, value); }
514  void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector2D &value) override
515  { doSetParmValue(idx, instance, value); }
516  void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector3D &value) override
517  { doSetParmValue(idx, instance, value); }
518  void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector4D &value) override
519  { doSetParmValue(idx, instance, value); }
520  void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix2D &value) override
521  { doSetParmValue(idx, instance, value); }
522  void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix3D &value) override
523  { doSetParmValue(idx, instance, value); }
524  void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix4D &value) override
525  { doSetParmValue(idx, instance, value); }
526  void setNestParmValue(TempIndex idx, TempIndex instance, const UT_StringHolder &value) override
527  { doSetParmValue(idx, instance, value); }
528  void setNestParmValue(TempIndex idx, TempIndex instance, const UT_SharedPtr<UT_Ramp> &value) override
529  { doSetParmValue(idx, instance, value); }
530  void setNestParmValue(TempIndex idx, TempIndex instance, const PRM_DataItemHandle &value) override
531  { doSetParmValue(idx, instance, value); }
532 
533  exint getNestNumParms(TempIndex idx) const override
534  {
535  if (idx.size() == 0)
536  return 23;
537  switch (idx[0])
538  {
539 
540  }
541  // Invalid
542  return 0;
543  }
544 
545  const char *getNestParmName(TempIndex fieldnum) const override
546  {
547  if (fieldnum.size() < 1)
548  return 0;
549  switch (fieldnum[0])
550  {
551  case 0:
552  return "group";
553  case 1:
554  return "xOrd";
555  case 2:
556  return "rOrd";
557  case 3:
558  return "t";
559  case 4:
560  return "r";
561  case 5:
562  return "s";
563  case 6:
564  return "shear";
565  case 7:
566  return "p";
567  case 8:
568  return "pr";
569  case 9:
570  return "distmetric";
571  case 10:
572  return "applyrolloff";
573  case 11:
574  return "distattr";
575  case 12:
576  return "rad";
577  case 13:
578  return "type";
579  case 14:
580  return "tandeg";
581  case 15:
582  return "kernel";
583  case 16:
584  return "attribs";
585  case 17:
586  return "updatenmls";
587  case 18:
588  return "updateaffectednmls";
589  case 19:
590  return "vlength";
591  case 20:
592  return "visualizefalloff";
593  case 21:
594  return "localspace";
595  case 22:
596  return "upvector";
597 
598  }
599  return 0;
600  }
601 
602  ParmType getNestParmType(TempIndex fieldnum) const override
603  {
604  if (fieldnum.size() < 1)
605  return PARM_UNSUPPORTED;
606  switch (fieldnum[0])
607  {
608  case 0:
609  return PARM_STRING;
610  case 1:
611  return PARM_INTEGER;
612  case 2:
613  return PARM_INTEGER;
614  case 3:
615  return PARM_VECTOR3;
616  case 4:
617  return PARM_VECTOR3;
618  case 5:
619  return PARM_VECTOR3;
620  case 6:
621  return PARM_VECTOR3;
622  case 7:
623  return PARM_VECTOR3;
624  case 8:
625  return PARM_VECTOR3;
626  case 9:
627  return PARM_INTEGER;
628  case 10:
629  return PARM_INTEGER;
630  case 11:
631  return PARM_STRING;
632  case 12:
633  return PARM_FLOAT;
634  case 13:
635  return PARM_INTEGER;
636  case 14:
637  return PARM_VECTOR2;
638  case 15:
639  return PARM_STRING;
640  case 16:
641  return PARM_STRING;
642  case 17:
643  return PARM_INTEGER;
644  case 18:
645  return PARM_INTEGER;
646  case 19:
647  return PARM_INTEGER;
648  case 20:
649  return PARM_INTEGER;
650  case 21:
651  return PARM_INTEGER;
652  case 22:
653  return PARM_VECTOR3;
654 
655  }
656  return PARM_UNSUPPORTED;
657  }
658 
659  // Boiler plate to load individual types.
660  static void loadData(UT_IStream &is, int64 &v)
661  { is.bread(&v, 1); }
662  static void loadData(UT_IStream &is, bool &v)
663  { int64 iv; is.bread(&iv, 1); v = iv; }
664  static void loadData(UT_IStream &is, fpreal64 &v)
665  { is.bread<fpreal64>(&v, 1); }
666  static void loadData(UT_IStream &is, UT_Vector2D &v)
667  { is.bread<fpreal64>(&v.x(), 1); is.bread<fpreal64>(&v.y(), 1); }
668  static void loadData(UT_IStream &is, UT_Vector3D &v)
669  { is.bread<fpreal64>(&v.x(), 1); is.bread<fpreal64>(&v.y(), 1);
670  is.bread<fpreal64>(&v.z(), 1); }
671  static void loadData(UT_IStream &is, UT_Vector4D &v)
672  { is.bread<fpreal64>(&v.x(), 1); is.bread<fpreal64>(&v.y(), 1);
673  is.bread<fpreal64>(&v.z(), 1); is.bread<fpreal64>(&v.w(), 1); }
674  static void loadData(UT_IStream &is, UT_Matrix2D &v)
675  { for (int r = 0; r < 2; r++) for (int c = 0; c < 2; c++) is.bread<fpreal64>(&v(r, c), 1); }
676  static void loadData(UT_IStream &is, UT_Matrix3D &v)
677  { for (int r = 0; r < 3; r++) for (int c = 0; c < 3; c++) is.bread<fpreal64>(&v(r, c), 1); }
678  static void loadData(UT_IStream &is, UT_Matrix4D &v)
679  { for (int r = 0; r < 4; r++) for (int c = 0; c < 4; c++) is.bread<fpreal64>(&v(r, c), 1); }
680  static void loadData(UT_IStream &is, UT_Vector2I &v)
681  { is.bread<int64>(&v.x(), 1); is.bread<int64>(&v.y(), 1); }
682  static void loadData(UT_IStream &is, UT_Vector3I &v)
683  { is.bread<int64>(&v.x(), 1); is.bread<int64>(&v.y(), 1);
684  is.bread<int64>(&v.z(), 1); }
685  static void loadData(UT_IStream &is, UT_Vector4I &v)
686  { is.bread<int64>(&v.x(), 1); is.bread<int64>(&v.y(), 1);
687  is.bread<int64>(&v.z(), 1); is.bread<int64>(&v.w(), 1); }
689  { is.bread(v); }
691  { UT_StringHolder rampdata;
692  loadData(is, rampdata);
693  if (rampdata.isstring())
694  {
695  v.reset(new UT_Ramp());
696  UT_IStream istr((const char *) rampdata, rampdata.length(), UT_ISTREAM_ASCII);
697  v->load(istr);
698  }
699  else v.reset();
700  }
703  loadData(is, data);
704  if (data.isstring())
705  {
706  // Find the data type.
707  const char *colon = UT_StringWrap(data).findChar(':');
708  if (colon)
709  {
710  int typelen = colon - data.buffer();
712  type.strncpy(data.buffer(), typelen);
713  UT_IStream istr(((const char *) data) + typelen + 1, data.length() - (typelen + 1), UT_ISTREAM_BINARY);
714 
715  v = PRM_DataFactory::parseBinary(type.buffer(), istr);
716  }
717  }
718  else v.reset();
719  }
720 
721  static void saveData(std::ostream &os, int64 v)
722  { UTwrite(os, &v); }
723  static void saveData(std::ostream &os, bool v)
724  { int64 iv = v; UTwrite(os, &iv); }
725  static void saveData(std::ostream &os, fpreal64 v)
726  { UTwrite<fpreal64>(os, &v); }
727  static void saveData(std::ostream &os, UT_Vector2D v)
728  { UTwrite<fpreal64>(os, &v.x()); UTwrite<fpreal64>(os, &v.y()); }
729  static void saveData(std::ostream &os, UT_Vector3D v)
730  { UTwrite<fpreal64>(os, &v.x()); UTwrite<fpreal64>(os, &v.y());
731  UTwrite<fpreal64>(os, &v.z()); }
732  static void saveData(std::ostream &os, UT_Vector4D v)
733  { UTwrite<fpreal64>(os, &v.x()); UTwrite<fpreal64>(os, &v.y());
734  UTwrite<fpreal64>(os, &v.z()); UTwrite<fpreal64>(os, &v.w()); }
735  static void saveData(std::ostream &os, UT_Matrix2D v)
737  static void saveData(std::ostream &os, UT_Matrix3D v)
739  static void saveData(std::ostream &os, UT_Matrix4D v)
741  static void saveData(std::ostream &os, UT_StringHolder s)
742  { UT_StringWrap(s).saveBinary(os); }
743  static void saveData(std::ostream &os, UT_SharedPtr<UT_Ramp> s)
745  UT_OStringStream ostr;
746  if (s) s->save(ostr);
747  result = ostr.str();
748  saveData(os, result);
749  }
750  static void saveData(std::ostream &os, PRM_DataItemHandle s)
752  UT_OStringStream ostr;
753  if (s)
754  {
755  ostr << s->getDataTypeToken();
756  ostr << ":";
757  s->saveBinary(ostr);
758  }
759  result = ostr.str();
760  saveData(os, result);
761  }
762 
763 
764  void save(std::ostream &os) const
765  {
766  int32 v = version();
767  UTwrite(os, &v);
768  saveData(os, myGroup);
769  saveData(os, myXord);
770  saveData(os, myRord);
771  saveData(os, myT);
772  saveData(os, myR);
773  saveData(os, myS);
774  saveData(os, myShear);
775  saveData(os, myP);
776  saveData(os, myPr);
777  saveData(os, myDistmetric);
778  saveData(os, myApplyrolloff);
779  saveData(os, myDistattr);
780  saveData(os, myRad);
781  saveData(os, myType);
782  saveData(os, myTandeg);
783  saveData(os, myKernel);
784  saveData(os, myAttribs);
785  saveData(os, myUpdatenmls);
786  saveData(os, myUpdateaffectednmls);
787  saveData(os, myVlength);
788  saveData(os, myVisualizefalloff);
789  saveData(os, myLocalspace);
790  saveData(os, myUpvector);
791 
792  }
793 
794  bool load(UT_IStream &is)
795  {
796  int32 v;
797  is.bread(&v, 1);
798  if (version() != v)
799  {
800  // Fail incompatible versions
801  return false;
802  }
803  loadData(is, myGroup);
804  loadData(is, myXord);
805  loadData(is, myRord);
806  loadData(is, myT);
807  loadData(is, myR);
808  loadData(is, myS);
809  loadData(is, myShear);
810  loadData(is, myP);
811  loadData(is, myPr);
812  loadData(is, myDistmetric);
813  loadData(is, myApplyrolloff);
814  loadData(is, myDistattr);
815  loadData(is, myRad);
816  loadData(is, myType);
817  loadData(is, myTandeg);
818  loadData(is, myKernel);
819  loadData(is, myAttribs);
820  loadData(is, myUpdatenmls);
821  loadData(is, myUpdateaffectednmls);
822  loadData(is, myVlength);
823  loadData(is, myVisualizefalloff);
824  loadData(is, myLocalspace);
825  loadData(is, myUpvector);
826 
827  return true;
828  }
829 
830  const UT_StringHolder & getGroup() const { return myGroup; }
831  void setGroup(const UT_StringHolder & val) { myGroup = val; }
833  {
834  SOP_Node *thissop = cookparms.getNode();
835  if (!thissop) return getGroup();
837  OP_Utils::evalOpParm(result, thissop, "group", cookparms.getCookTime(), 0);
838  return result;
839  }
840  Xord getXord() const { return Xord(myXord); }
841  void setXord(Xord val) { myXord = int64(val); }
842  Xord opXord(const SOP_NodeVerb::CookParms &cookparms) const
843  {
844  SOP_Node *thissop = cookparms.getNode();
845  if (!thissop) return getXord();
846  int64 result;
847  OP_Utils::evalOpParm(result, thissop, "xOrd", cookparms.getCookTime(), 0);
848  return Xord(result);
849  }
850  Rord getRord() const { return Rord(myRord); }
851  void setRord(Rord val) { myRord = int64(val); }
852  Rord opRord(const SOP_NodeVerb::CookParms &cookparms) const
853  {
854  SOP_Node *thissop = cookparms.getNode();
855  if (!thissop) return getRord();
856  int64 result;
857  OP_Utils::evalOpParm(result, thissop, "rOrd", cookparms.getCookTime(), 0);
858  return Rord(result);
859  }
860  UT_Vector3D getT() const { return myT; }
861  void setT(UT_Vector3D val) { myT = val; }
862  UT_Vector3D opT(const SOP_NodeVerb::CookParms &cookparms) const
863  {
864  SOP_Node *thissop = cookparms.getNode();
865  if (!thissop) return getT();
867  OP_Utils::evalOpParm(result, thissop, "t", cookparms.getCookTime(), 0);
868  return result;
869  }
870  UT_Vector3D getR() const { return myR; }
871  void setR(UT_Vector3D val) { myR = val; }
872  UT_Vector3D opR(const SOP_NodeVerb::CookParms &cookparms) const
873  {
874  SOP_Node *thissop = cookparms.getNode();
875  if (!thissop) return getR();
877  OP_Utils::evalOpParm(result, thissop, "r", cookparms.getCookTime(), 0);
878  return result;
879  }
880  UT_Vector3D getS() const { return myS; }
881  void setS(UT_Vector3D val) { myS = val; }
882  UT_Vector3D opS(const SOP_NodeVerb::CookParms &cookparms) const
883  {
884  SOP_Node *thissop = cookparms.getNode();
885  if (!thissop) return getS();
887  OP_Utils::evalOpParm(result, thissop, "s", cookparms.getCookTime(), 0);
888  return result;
889  }
890  UT_Vector3D getShear() const { return myShear; }
891  void setShear(UT_Vector3D val) { myShear = val; }
893  {
894  SOP_Node *thissop = cookparms.getNode();
895  if (!thissop) return getShear();
897  OP_Utils::evalOpParm(result, thissop, "shear", cookparms.getCookTime(), 0);
898  return result;
899  }
900  UT_Vector3D getP() const { return myP; }
901  void setP(UT_Vector3D val) { myP = val; }
902  UT_Vector3D opP(const SOP_NodeVerb::CookParms &cookparms) const
903  {
904  SOP_Node *thissop = cookparms.getNode();
905  if (!thissop) return getP();
907  OP_Utils::evalOpParm(result, thissop, "p", cookparms.getCookTime(), 0);
908  return result;
909  }
910  UT_Vector3D getPr() const { return myPr; }
911  void setPr(UT_Vector3D val) { myPr = val; }
912  UT_Vector3D opPr(const SOP_NodeVerb::CookParms &cookparms) const
913  {
914  SOP_Node *thissop = cookparms.getNode();
915  if (!thissop) return getPr();
917  OP_Utils::evalOpParm(result, thissop, "pr", cookparms.getCookTime(), 0);
918  return result;
919  }
920  Distmetric getDistmetric() const { return Distmetric(myDistmetric); }
921  void setDistmetric(Distmetric val) { myDistmetric = int64(val); }
923  {
924  SOP_Node *thissop = cookparms.getNode();
925  if (!thissop) return getDistmetric();
926  int64 result;
927  OP_Utils::evalOpParm(result, thissop, "distmetric", cookparms.getCookTime(), 0);
928  return Distmetric(result);
929  }
930  bool getApplyrolloff() const { return myApplyrolloff; }
931  void setApplyrolloff(bool val) { myApplyrolloff = val; }
932  bool opApplyrolloff(const SOP_NodeVerb::CookParms &cookparms) const
933  {
934  SOP_Node *thissop = cookparms.getNode();
935  if (!thissop) return getApplyrolloff();
936  bool result;
937  OP_Utils::evalOpParm(result, thissop, "applyrolloff", cookparms.getCookTime(), 0);
938  return result;
939  }
940  const UT_StringHolder & getDistattr() const { return myDistattr; }
941  void setDistattr(const UT_StringHolder & val) { myDistattr = val; }
943  {
944  SOP_Node *thissop = cookparms.getNode();
945  if (!thissop) return getDistattr();
947  OP_Utils::evalOpParm(result, thissop, "distattr", cookparms.getCookTime(), 0);
948  return result;
949  }
950  fpreal64 getRad() const { return myRad; }
951  void setRad(fpreal64 val) { myRad = val; }
952  fpreal64 opRad(const SOP_NodeVerb::CookParms &cookparms) const
953  {
954  SOP_Node *thissop = cookparms.getNode();
955  if (!thissop) return getRad();
957  OP_Utils::evalOpParm(result, thissop, "rad", cookparms.getCookTime(), 0);
958  return result;
959  }
960  Type getType() const { return Type(myType); }
961  void setType(Type val) { myType = int64(val); }
962  Type opType(const SOP_NodeVerb::CookParms &cookparms) const
963  {
964  SOP_Node *thissop = cookparms.getNode();
965  if (!thissop) return getType();
966  int64 result;
967  OP_Utils::evalOpParm(result, thissop, "type", cookparms.getCookTime(), 0);
968  return Type(result);
969  }
970  UT_Vector2D getTandeg() const { return myTandeg; }
971  void setTandeg(UT_Vector2D val) { myTandeg = val; }
973  {
974  SOP_Node *thissop = cookparms.getNode();
975  if (!thissop) return getTandeg();
977  OP_Utils::evalOpParm(result, thissop, "tandeg", cookparms.getCookTime(), 0);
978  return result;
979  }
980  const UT_StringHolder & getKernel() const { return myKernel; }
981  void setKernel(const UT_StringHolder & val) { myKernel = val; }
983  {
984  SOP_Node *thissop = cookparms.getNode();
985  if (!thissop) return getKernel();
987  OP_Utils::evalOpParm(result, thissop, "kernel", cookparms.getCookTime(), 0);
988  return result;
989  }
990  const UT_StringHolder & getAttribs() const { return myAttribs; }
991  void setAttribs(const UT_StringHolder & val) { myAttribs = val; }
993  {
994  SOP_Node *thissop = cookparms.getNode();
995  if (!thissop) return getAttribs();
997  OP_Utils::evalOpParm(result, thissop, "attribs", cookparms.getCookTime(), 0);
998  return result;
999  }
1000  bool getUpdatenmls() const { return myUpdatenmls; }
1001  void setUpdatenmls(bool val) { myUpdatenmls = val; }
1002  bool opUpdatenmls(const SOP_NodeVerb::CookParms &cookparms) const
1003  {
1004  SOP_Node *thissop = cookparms.getNode();
1005  if (!thissop) return getUpdatenmls();
1006  bool result;
1007  OP_Utils::evalOpParm(result, thissop, "updatenmls", cookparms.getCookTime(), 0);
1008  return result;
1009  }
1010  bool getUpdateaffectednmls() const { return myUpdateaffectednmls; }
1011  void setUpdateaffectednmls(bool val) { myUpdateaffectednmls = val; }
1012  bool opUpdateaffectednmls(const SOP_NodeVerb::CookParms &cookparms) const
1013  {
1014  SOP_Node *thissop = cookparms.getNode();
1015  if (!thissop) return getUpdateaffectednmls();
1016  bool result;
1017  OP_Utils::evalOpParm(result, thissop, "updateaffectednmls", cookparms.getCookTime(), 0);
1018  return result;
1019  }
1020  bool getVlength() const { return myVlength; }
1021  void setVlength(bool val) { myVlength = val; }
1022  bool opVlength(const SOP_NodeVerb::CookParms &cookparms) const
1023  {
1024  SOP_Node *thissop = cookparms.getNode();
1025  if (!thissop) return getVlength();
1026  bool result;
1027  OP_Utils::evalOpParm(result, thissop, "vlength", cookparms.getCookTime(), 0);
1028  return result;
1029  }
1030  Visualizefalloff getVisualizefalloff() const { return Visualizefalloff(myVisualizefalloff); }
1031  void setVisualizefalloff(Visualizefalloff val) { myVisualizefalloff = int64(val); }
1033  {
1034  SOP_Node *thissop = cookparms.getNode();
1035  if (!thissop) return getVisualizefalloff();
1036  int64 result;
1037  OP_Utils::evalOpParm(result, thissop, "visualizefalloff", cookparms.getCookTime(), 0);
1038  return Visualizefalloff(result);
1039  }
1040  bool getLocalspace() const { return myLocalspace; }
1041  void setLocalspace(bool val) { myLocalspace = val; }
1042  bool opLocalspace(const SOP_NodeVerb::CookParms &cookparms) const
1043  {
1044  SOP_Node *thissop = cookparms.getNode();
1045  if (!thissop) return getLocalspace();
1046  bool result;
1047  OP_Utils::evalOpParm(result, thissop, "localspace", cookparms.getCookTime(), 0);
1048  return result;
1049  }
1050  UT_Vector3D getUpvector() const { return myUpvector; }
1051  void setUpvector(UT_Vector3D val) { myUpvector = val; }
1053  {
1054  SOP_Node *thissop = cookparms.getNode();
1055  if (!thissop) return getUpvector();
1057  OP_Utils::evalOpParm(result, thissop, "upvector", cookparms.getCookTime(), 0);
1058  return result;
1059  }
1060 
1061 private:
1062  UT_StringHolder myGroup;
1063  int64 myXord;
1064  int64 myRord;
1065  UT_Vector3D myT;
1066  UT_Vector3D myR;
1067  UT_Vector3D myS;
1068  UT_Vector3D myShear;
1069  UT_Vector3D myP;
1070  UT_Vector3D myPr;
1071  int64 myDistmetric;
1072  bool myApplyrolloff;
1073  UT_StringHolder myDistattr;
1074  fpreal64 myRad;
1075  int64 myType;
1076  UT_Vector2D myTandeg;
1077  UT_StringHolder myKernel;
1078  UT_StringHolder myAttribs;
1079  bool myUpdatenmls;
1080  bool myUpdateaffectednmls;
1081  bool myVlength;
1082  int64 myVisualizefalloff;
1083  bool myLocalspace;
1084  UT_Vector3D myUpvector;
1085 
1086 };
type
Definition: core.h:556
UT_StringHolder opKernel(const SOP_NodeVerb::CookParms &cookparms) const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector2D &value) const override
UT_Vector3D opUpvector(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Matrix4D &v)
int int32
Definition: SYS_Types.h:39
void setP(UT_Vector3D val)
SOP_Node * getNode() const
Definition: SOP_NodeVerb.h:347
UT_StringHolder opGroup(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Vector4I &v)
Visualizefalloff getVisualizefalloff() const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix3D &value) const override
Visualizefalloff opVisualizefalloff(const SOP_NodeVerb::CookParms &cookparms) const
bool opUpdateaffectednmls(const SOP_NodeVerb::CookParms &cookparms) const
static void saveData(std::ostream &os, UT_Vector4D v)
UT_Vector3D getShear() const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector3D &value) const override
exint bread(int32 *buffer, exint asize=1)
exint getNestNumParms(TempIndex idx) const override
GLboolean * data
Definition: glcorearb.h:131
void setDistattr(const UT_StringHolder &val)
static void loadData(UT_IStream &is, UT_Vector3D &v)
GT_API const UT_StringHolder time
constexpr SYS_FORCE_INLINE T & y() noexcept
Definition: UT_Vector4.h:493
const GLdouble * v
Definition: glcorearb.h:837
fpreal getTime() const
Definition: OP_Context.h:63
UT_Vector2T< fpreal64 > UT_Vector2D
Type opType(const SOP_NodeVerb::CookParms &cookparms) const
UT_Vector2D getTandeg() const
GLsizei const GLfloat * value
Definition: glcorearb.h:824
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector2D &value) override
const OP_Context & context() const
Definition: OP_NodeParms.h:97
const UT_StringHolder & getAttribs() const
constexpr SYS_FORCE_INLINE T & z() noexcept
Definition: UT_Vector3.h:667
int64 exint
Definition: SYS_Types.h:125
SYS_FORCE_INLINE const char * buffer() const
UT_Vector3D opT(const SOP_NodeVerb::CookParms &cookparms) const
GLdouble s
Definition: glad.h:3009
void setAttribs(const UT_StringHolder &val)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix4D &value) const override
Rord opRord(const SOP_NodeVerb::CookParms &cookparms) const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_StringHolder &value) const override
An output stream object that owns its own string buffer storage.
static void saveData(std::ostream &os, UT_SharedPtr< UT_Ramp > s)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector3D &value) override
void loadFromOpSubclass(const LoadParms &loadparms) override
void setShear(UT_Vector3D val)
SYS_FORCE_INLINE UT_StringHolder getToken(Xord enum_value)
**But if you need a result
Definition: thread.h:622
void setGroup(const UT_StringHolder &val)
exint nodeIdx() const
Definition: OP_NodeParms.h:95
static PRM_DataItemHandle parseBinary(const char *type, UT_IStream &is)
const UT_WorkBuffer & str()
Returns a read-only reference to the underlying UT_WorkBuffer.
static void loadData(UT_IStream &is, UT_Matrix2D &v)
void buildFromOp(const OP_GraphProxy *graph, exint nodeidx, fpreal time, DEP_MicroNode *depnode)
constexpr SYS_FORCE_INLINE T & x() noexcept
Definition: UT_Vector4.h:491
void getNestParmValue(TempIndex idx, TempIndex instance, UT_SharedPtr< UT_Ramp > &value) const override
double fpreal64
Definition: SYS_Types.h:201
Distmetric opDistmetric(const SOP_NodeVerb::CookParms &cookparms) const
UT_SharedPtr< const PRM_DataItem > PRM_DataItemHandle
Definition: APEX_Include.h:55
constexpr SYS_FORCE_INLINE T & x() noexcept
Definition: UT_Vector2.h:423
static void loadData(UT_IStream &is, UT_Vector4D &v)
void copyFrom(const OP_NodeParms *src) override
bool operator==(const BaseDimensions< T > &a, const BaseDimensions< Y > &b)
Definition: Dimensions.h:137
UT_Vector3D opShear(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Vector2D &v)
static void loadData(UT_IStream &is, UT_Vector3I &v)
static void loadData(UT_IStream &is, UT_Matrix3D &v)
static void loadData(UT_IStream &is, UT_Vector2I &v)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_SharedPtr< UT_Ramp > &value) override
static void saveData(std::ostream &os, UT_Vector3D v)
exint length() const
static void loadData(UT_IStream &is, fpreal64 &v)
SYS_FORCE_INLINE const char * buffer() const
std::shared_ptr< T > UT_SharedPtr
Wrapper around std::shared_ptr.
Definition: UT_SharedPtr.h:36
constexpr SYS_FORCE_INLINE T & z() noexcept
Definition: UT_Vector4.h:495
const char * getNestParmName(TempIndex fieldnum) const override
Xord opXord(const SOP_NodeVerb::CookParms &cookparms) const
bool opVlength(const SOP_NodeVerb::CookParms &cookparms) const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector4D &value) const override
static void loadData(UT_IStream &is, UT_SharedPtr< UT_Ramp > &v)
const OP_GraphProxy * graph() const
Definition: OP_NodeParms.h:94
#define SYS_FORCE_INLINE
Definition: SYS_Inline.h:45
void setNestParmValue(TempIndex idx, TempIndex instance, const exint &value) override
bool isParmColorRamp(exint idx) const override
void setUpvector(UT_Vector3D val)
static void saveData(std::ostream &os, int64 v)
fpreal64 opRad(const SOP_NodeVerb::CookParms &cookparms) const
bool opApplyrolloff(const SOP_NodeVerb::CookParms &cookparms) const
const UT_StringHolder & getDistattr() const
UT_Vector3D opS(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_StringHolder &v)
long long int64
Definition: SYS_Types.h:116
UT_Vector3D opP(const SOP_NodeVerb::CookParms &cookparms) const
static void saveData(std::ostream &os, fpreal64 v)
static void saveData(std::ostream &os, UT_StringHolder s)
UT_StringHolder opAttribs(const SOP_NodeVerb::CookParms &cookparms) const
UT_Vector3T< fpreal64 > UT_Vector3D
static void loadData(UT_IStream &is, PRM_DataItemHandle &v)
virtual void evalOpParm(int64 &v, NodeIdx node, const char *parmname, fpreal time, DEP_MicroNode *depnode) const =0
UT_Vector2D opTandeg(const SOP_NodeVerb::CookParms &cookparms) const
static void saveData(std::ostream &os, UT_Vector2D v)
bool opLocalspace(const SOP_NodeVerb::CookParms &cookparms) const
static void saveData(std::ostream &os, PRM_DataItemHandle s)
const UT_StringHolder & getKernel() const
void saveBinary(std::ostream &os) const
Save string to binary stream.
Definition: UT_String.h:303
GT_API const UT_StringHolder version
void setTandeg(UT_Vector2D val)
void save(std::ostream &os) const
bool operator==(const SOP_SoftTransformParms &src) const
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix3D &value) override
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix2D &value) const override
void setT(UT_Vector3D val)
void setPr(UT_Vector3D val)
static void loadData(UT_IStream &is, int64 &v)
ParmType getNestParmType(TempIndex fieldnum) const override
void getNestParmValue(TempIndex idx, TempIndex instance, exint &value) const override
void getNestParmValue(TempIndex idx, TempIndex instance, fpreal &value) const override
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector4D &value) override
static void saveData(std::ostream &os, UT_Matrix2D v)
fpreal64 fpreal
Definition: SYS_Types.h:278
DEP_MicroNode * depnode() const
Definition: OP_NodeParms.h:99
const UT_StringHolder & getGroup() const
void setDistmetric(Distmetric val)
LeafData & operator=(const LeafData &)=delete
Utility class for containing a color ramp.
Definition: UT_Ramp.h:96
UT_StringHolder opDistattr(const SOP_NodeVerb::CookParms &cookparms) const
void setNestParmValue(TempIndex idx, TempIndex instance, const PRM_DataItemHandle &value) override
UT_Vector3D getUpvector() const
void doGetParmValue(TempIndex idx, TempIndex instance, T &value) const
constexpr SYS_FORCE_INLINE T & w() noexcept
Definition: UT_Vector4.h:497
void setVisualizefalloff(Visualizefalloff val)
GLuint GLfloat * val
Definition: glcorearb.h:1608
static void loadData(UT_IStream &is, bool &v)
virtual UT_StringHolder baseGetSignature() const
Definition: OP_NodeParms.h:294
void setS(UT_Vector3D val)
#define SOP_API
Definition: SOP_API.h:10
static void saveData(std::ostream &os, UT_Matrix3D v)
fpreal getCookTime() const
Definition: SOP_NodeVerb.h:372
void setR(UT_Vector3D val)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_StringHolder &value) override
const char * findChar(int c) const
Definition: UT_String.h:1401
#define UT_ASSERT(ZZ)
Definition: UT_Assert.h:156
bool operator!=(const SOP_SoftTransformParms &src) const
void setKernel(const UT_StringHolder &val)
Distmetric getDistmetric() const
GLboolean r
Definition: glcorearb.h:1222
void setNestParmValue(TempIndex idx, TempIndex instance, const fpreal &value) override
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix4D &value) override
static void saveData(std::ostream &os, UT_Matrix4D v)
void getNestParmValue(TempIndex idx, TempIndex instance, PRM_DataItemHandle &value) const override
constexpr SYS_FORCE_INLINE T & y() noexcept
Definition: UT_Vector3.h:665
UT_Vector3D opPr(const SOP_NodeVerb::CookParms &cookparms) const
UT_Vector3D opR(const SOP_NodeVerb::CookParms &cookparms) const
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix2D &value) override
virtual bool isDirect() const =0
Direct proxies mirror actual nodes:
bool opUpdatenmls(const SOP_NodeVerb::CookParms &cookparms) const
void doSetParmValue(TempIndex idx, TempIndex instance, const T &value)
constexpr SYS_FORCE_INLINE T & y() noexcept
Definition: UT_Vector2.h:425
SYS_FORCE_INLINE bool isstring() const
static void saveData(std::ostream &os, bool v)
SYS_FORCE_INLINE void strncpy(const char *src, exint maxlen)
GLenum src
Definition: glcorearb.h:1793
constexpr SYS_FORCE_INLINE T & x() noexcept
Definition: UT_Vector3.h:663