20 using namespace UT::Literal;
23 namespace SOP_ResampleEnums
65 myRandomshift =
false;
68 myOutputsubdpoly =
false;
69 myDoptdistattr =
false;
70 myPtdistattr =
"ptdist"_sh;
71 myDotangentattr =
false;
72 myTangentattr =
"tangentu"_sh;
73 myDocurveuattr =
false;
74 myCurveuattr =
"curveu"_sh;
75 myDocurvenumattr =
false;
76 myCurvenumattr =
"curvenum"_sh;
86 if (myGroup != src.myGroup)
return false;
87 if (myLod != src.myLod)
return false;
88 if (myEdge != src.myEdge)
return false;
89 if (myMethod != src.myMethod)
return false;
90 if (myMeasure != src.myMeasure)
return false;
91 if (myDolength != src.myDolength)
return false;
92 if (myLength != src.myLength)
return false;
93 if (myDosegs != src.myDosegs)
return false;
94 if (mySegs != src.mySegs)
return false;
95 if (myUseattribs != src.myUseattribs)
return false;
96 if (myAllequal != src.myAllequal)
return false;
97 if (myLast != src.myLast)
return false;
98 if (myRandomshift != src.myRandomshift)
return false;
99 if (myOnlypoints != src.myOnlypoints)
return false;
100 if (myTreatpolysas != src.myTreatpolysas)
return false;
101 if (myOutputsubdpoly != src.myOutputsubdpoly)
return false;
102 if (myDoptdistattr != src.myDoptdistattr)
return false;
103 if (myPtdistattr != src.myPtdistattr)
return false;
104 if (myDotangentattr != src.myDotangentattr)
return false;
105 if (myTangentattr != src.myTangentattr)
return false;
106 if (myDocurveuattr != src.myDocurveuattr)
return false;
107 if (myCurveuattr != src.myCurveuattr)
return false;
108 if (myDocurvenumattr != src.myDocurvenumattr)
return false;
109 if (myCurvenumattr != src.myCurvenumattr)
return false;
127 graph->
evalOpParm(myGroup, nodeidx,
"group", time, 0);
130 graph->
evalOpParm(myLod, nodeidx,
"lod", time, 0);
133 graph->
evalOpParm(myEdge, nodeidx,
"edge", time, 0);
136 graph->
evalOpParm(myMethod, nodeidx,
"method", time, 0);
139 graph->
evalOpParm(myMeasure, nodeidx,
"measure", time, 0);
142 graph->
evalOpParm(myDolength, nodeidx,
"dolength", time, 0);
144 if (
true && ( (!(((getDolength()==0)))) ) )
145 graph->
evalOpParm(myLength, nodeidx,
"length", time, 0);
148 graph->
evalOpParm(myDosegs, nodeidx,
"dosegs", time, 0);
150 if (
true && ( (!(((getDosegs()==0)))) ) )
151 graph->
evalOpParm(mySegs, nodeidx,
"segs", time, 0);
154 graph->
evalOpParm(myUseattribs, nodeidx,
"useattribs", time, 0);
156 if (
true && ( (!(((getDolength()==0))||((getEdge()==1))||((
int64(getMeasure())!=0))||((
int64(getMethod())!=0)))) ) )
157 graph->
evalOpParm(myAllequal, nodeidx,
"allequal", time, 0);
159 if (
true && ( (!(((getDolength()==0))||((getEdge()==1))||((getDolength()==1)&&(getEdge()==0)&&(
int64(getMeasure())==0)&&(
int64(getMethod())==0)&&(getAllequal()==1)))) ) )
160 graph->
evalOpParm(myLast, nodeidx,
"last", time, 0);
161 myRandomshift =
false;
162 if (
true && ( (!(((getDolength()==0))||((getEdge()==1))||((getDolength()==1)&&(getEdge()==0)&&(
int64(getMeasure())==0)&&(
int64(getMethod())==0)&&(getAllequal()==1)))) ) )
163 graph->
evalOpParm(myRandomshift, nodeidx,
"randomshift", time, 0);
164 myOnlypoints =
false;
166 graph->
evalOpParm(myOnlypoints, nodeidx,
"onlypoints", time, 0);
169 graph->
evalOpParm(myTreatpolysas, nodeidx,
"treatpolysas", time, 0);
170 myOutputsubdpoly =
false;
172 graph->
evalOpParm(myOutputsubdpoly, nodeidx,
"outputsubdpoly", time, 0);
173 myDoptdistattr =
false;
175 graph->
evalOpParm(myDoptdistattr, nodeidx,
"doptdistattr", time, 0);
176 myPtdistattr =
"ptdist"_sh;
177 if (
true && ( (!(((getDoptdistattr()==0)))) ) )
178 graph->
evalOpParm(myPtdistattr, nodeidx,
"ptdistattr", time, 0);
179 myDotangentattr =
false;
181 graph->
evalOpParm(myDotangentattr, nodeidx,
"dotangentattr", time, 0);
182 myTangentattr =
"tangentu"_sh;
183 if (
true && ( (!(((getDotangentattr()==0)))) ) )
184 graph->
evalOpParm(myTangentattr, nodeidx,
"tangentattr", time, 0);
185 myDocurveuattr =
false;
187 graph->
evalOpParm(myDocurveuattr, nodeidx,
"docurveuattr", time, 0);
188 myCurveuattr =
"curveu"_sh;
189 if (
true && ( (!(((getDocurveuattr()==0)))) ) )
190 graph->
evalOpParm(myCurveuattr, nodeidx,
"curveuattr", time, 0);
191 myDocurvenumattr =
false;
193 graph->
evalOpParm(myDocurvenumattr, nodeidx,
"docurvenumattr", time, 0);
194 myCurvenumattr =
"curvenum"_sh;
195 if (
true && ( (!(((getDocurvenumattr()==0)))) ) )
196 graph->
evalOpParm(myCurvenumattr, nodeidx,
"curvenumattr", time, 0);
212 template <
typename T>
219 if (idx.
size() != instance.
size()+1)
224 coerceValue(value, myGroup);
227 coerceValue(value, myLod);
230 coerceValue(value, myEdge);
233 coerceValue(value, myMethod);
236 coerceValue(value, myMeasure);
239 coerceValue(value, myDolength);
242 coerceValue(value, myLength);
245 coerceValue(value, myDosegs);
248 coerceValue(value, mySegs);
251 coerceValue(value, myUseattribs);
254 coerceValue(value, myAllequal);
257 coerceValue(value, myLast);
260 coerceValue(value, myRandomshift);
263 coerceValue(value, myOnlypoints);
266 coerceValue(value, myTreatpolysas);
269 coerceValue(value, myOutputsubdpoly);
272 coerceValue(value, myDoptdistattr);
275 coerceValue(value, myPtdistattr);
278 coerceValue(value, myDotangentattr);
281 coerceValue(value, myTangentattr);
284 coerceValue(value, myDocurveuattr);
287 coerceValue(value, myCurveuattr);
290 coerceValue(value, myDocurvenumattr);
293 coerceValue(value, myCurvenumattr);
300 { doGetParmValue(idx, instance, value); }
302 { doGetParmValue(idx, instance, value); }
304 { doGetParmValue(idx, instance, value); }
306 { doGetParmValue(idx, instance, value); }
308 { doGetParmValue(idx, instance, value); }
310 { doGetParmValue(idx, instance, value); }
312 { doGetParmValue(idx, instance, value); }
314 { doGetParmValue(idx, instance, value); }
316 { doGetParmValue(idx, instance, value); }
318 { doGetParmValue(idx, instance, value); }
320 { doGetParmValue(idx, instance, value); }
322 template <
typename T>
329 if (idx.
size() != instance.
size()+1)
334 coerceValue(myGroup, value);
337 coerceValue(myLod, value);
340 coerceValue(myEdge, value);
343 coerceValue(myMethod, value);
346 coerceValue(myMeasure, value);
349 coerceValue(myDolength, value);
352 coerceValue(myLength, value);
355 coerceValue(myDosegs, value);
358 coerceValue(mySegs, value);
361 coerceValue(myUseattribs, value);
364 coerceValue(myAllequal, value);
367 coerceValue(myLast, value);
370 coerceValue(myRandomshift, value);
373 coerceValue(myOnlypoints, value);
376 coerceValue(myTreatpolysas, value);
379 coerceValue(myOutputsubdpoly, value);
382 coerceValue(myDoptdistattr, value);
385 coerceValue(myPtdistattr, value);
388 coerceValue(myDotangentattr, value);
391 coerceValue(myTangentattr, value);
394 coerceValue(myDocurveuattr, value);
397 coerceValue(myCurveuattr, value);
400 coerceValue(myDocurvenumattr, value);
403 coerceValue(myCurvenumattr, value);
410 { doSetParmValue(idx, instance, value); }
412 { doSetParmValue(idx, instance, value); }
414 { doSetParmValue(idx, instance, value); }
416 { doSetParmValue(idx, instance, value); }
418 { doSetParmValue(idx, instance, value); }
420 { doSetParmValue(idx, instance, value); }
422 { doSetParmValue(idx, instance, value); }
424 { doSetParmValue(idx, instance, value); }
426 { doSetParmValue(idx, instance, value); }
428 { doSetParmValue(idx, instance, value); }
430 { doSetParmValue(idx, instance, value); }
446 if (fieldnum.
size() < 1)
475 return "randomshift";
479 return "treatpolysas";
481 return "outputsubdpoly";
483 return "doptdistattr";
487 return "dotangentattr";
489 return "tangentattr";
491 return "docurveuattr";
495 return "docurvenumattr";
497 return "curvenumattr";
505 if (fieldnum.
size() < 1)
506 return PARM_UNSUPPORTED;
559 return PARM_UNSUPPORTED;
595 loadData(is, rampdata);
613 int typelen = colon - data.
buffer();
627 {
int64 iv =
v; UTwrite(os, &iv); }
629 { UTwrite<fpreal64>(os, &
v); }
631 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y()); }
633 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y());
634 UTwrite<fpreal64>(os, &v.
z()); }
636 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y());
637 UTwrite<fpreal64>(os, &v.
z()); UTwrite<fpreal64>(os, &v.
w()); }
649 if (s) s->save(ostr);
651 saveData(os, result);
658 ostr << s->getDataTypeToken();
663 saveData(os, result);
667 void save(std::ostream &os)
const
671 saveData(os, myGroup);
673 saveData(os, myEdge);
674 saveData(os, myMethod);
675 saveData(os, myMeasure);
676 saveData(os, myDolength);
677 saveData(os, myLength);
678 saveData(os, myDosegs);
679 saveData(os, mySegs);
680 saveData(os, myUseattribs);
681 saveData(os, myAllequal);
682 saveData(os, myLast);
683 saveData(os, myRandomshift);
684 saveData(os, myOnlypoints);
685 saveData(os, myTreatpolysas);
686 saveData(os, myOutputsubdpoly);
687 saveData(os, myDoptdistattr);
688 saveData(os, myPtdistattr);
689 saveData(os, myDotangentattr);
690 saveData(os, myTangentattr);
691 saveData(os, myDocurveuattr);
692 saveData(os, myCurveuattr);
693 saveData(os, myDocurvenumattr);
694 saveData(os, myCurvenumattr);
707 loadData(is, myGroup);
709 loadData(is, myEdge);
710 loadData(is, myMethod);
711 loadData(is, myMeasure);
712 loadData(is, myDolength);
713 loadData(is, myLength);
714 loadData(is, myDosegs);
715 loadData(is, mySegs);
716 loadData(is, myUseattribs);
717 loadData(is, myAllequal);
718 loadData(is, myLast);
719 loadData(is, myRandomshift);
720 loadData(is, myOnlypoints);
721 loadData(is, myTreatpolysas);
722 loadData(is, myOutputsubdpoly);
723 loadData(is, myDoptdistattr);
724 loadData(is, myPtdistattr);
725 loadData(is, myDotangentattr);
726 loadData(is, myTangentattr);
727 loadData(is, myDocurveuattr);
728 loadData(is, myCurveuattr);
729 loadData(is, myDocurvenumattr);
730 loadData(is, myCurvenumattr);
740 if (!thissop)
return getGroup();
742 OP_Utils::evalOpParm(result, thissop,
"group", cookparms.
getCookTime(), 0);
750 if (!thissop)
return getLod();
752 OP_Utils::evalOpParm(result, thissop,
"lod", cookparms.
getCookTime(), 0);
760 if (!thissop)
return getEdge();
762 OP_Utils::evalOpParm(result, thissop,
"edge", cookparms.
getCookTime(), 0);
770 if (!thissop)
return getMethod();
772 OP_Utils::evalOpParm(result, thissop,
"method", cookparms.
getCookTime(), 0);
780 if (!thissop)
return getMeasure();
782 OP_Utils::evalOpParm(result, thissop,
"measure", cookparms.
getCookTime(), 0);
790 if (!thissop)
return getDolength();
792 OP_Utils::evalOpParm(result, thissop,
"dolength", cookparms.
getCookTime(), 0);
800 if (!thissop)
return getLength();
802 OP_Utils::evalOpParm(result, thissop,
"length", cookparms.
getCookTime(), 0);
810 if (!thissop)
return getDosegs();
812 OP_Utils::evalOpParm(result, thissop,
"dosegs", cookparms.
getCookTime(), 0);
820 if (!thissop)
return getSegs();
822 OP_Utils::evalOpParm(result, thissop,
"segs", cookparms.
getCookTime(), 0);
830 if (!thissop)
return getUseattribs();
832 OP_Utils::evalOpParm(result, thissop,
"useattribs", cookparms.
getCookTime(), 0);
840 if (!thissop)
return getAllequal();
842 OP_Utils::evalOpParm(result, thissop,
"allequal", cookparms.
getCookTime(), 0);
850 if (!thissop)
return getLast();
852 OP_Utils::evalOpParm(result, thissop,
"last", cookparms.
getCookTime(), 0);
860 if (!thissop)
return getRandomshift();
862 OP_Utils::evalOpParm(result, thissop,
"randomshift", cookparms.
getCookTime(), 0);
870 if (!thissop)
return getOnlypoints();
872 OP_Utils::evalOpParm(result, thissop,
"onlypoints", cookparms.
getCookTime(), 0);
880 if (!thissop)
return getTreatpolysas();
882 OP_Utils::evalOpParm(result, thissop,
"treatpolysas", cookparms.
getCookTime(), 0);
890 if (!thissop)
return getOutputsubdpoly();
892 OP_Utils::evalOpParm(result, thissop,
"outputsubdpoly", cookparms.
getCookTime(), 0);
900 if (!thissop)
return getDoptdistattr();
902 OP_Utils::evalOpParm(result, thissop,
"doptdistattr", cookparms.
getCookTime(), 0);
910 if (!thissop)
return getPtdistattr();
912 OP_Utils::evalOpParm(result, thissop,
"ptdistattr", cookparms.
getCookTime(), 0);
920 if (!thissop)
return getDotangentattr();
922 OP_Utils::evalOpParm(result, thissop,
"dotangentattr", cookparms.
getCookTime(), 0);
930 if (!thissop)
return getTangentattr();
932 OP_Utils::evalOpParm(result, thissop,
"tangentattr", cookparms.
getCookTime(), 0);
940 if (!thissop)
return getDocurveuattr();
942 OP_Utils::evalOpParm(result, thissop,
"docurveuattr", cookparms.
getCookTime(), 0);
950 if (!thissop)
return getCurveuattr();
952 OP_Utils::evalOpParm(result, thissop,
"curveuattr", cookparms.
getCookTime(), 0);
960 if (!thissop)
return getDocurvenumattr();
962 OP_Utils::evalOpParm(result, thissop,
"docurvenumattr", cookparms.
getCookTime(), 0);
970 if (!thissop)
return getCurvenumattr();
972 OP_Utils::evalOpParm(result, thissop,
"curvenumattr", cookparms.
getCookTime(), 0);
991 int64 myTreatpolysas;
992 bool myOutputsubdpoly;
995 bool myDotangentattr;
999 bool myDocurvenumattr;
static void saveData(std::ostream &os, int64 v)
bool opDosegs(const SOP_NodeVerb::CookParms &cookparms) const
UT_StringHolder opTangentattr(const SOP_NodeVerb::CookParms &cookparms) const
SOP_Node * getNode() const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_SharedPtr< UT_Ramp > &value) const override
exint getNestNumParms(TempIndex idx) const override
static void loadData(UT_IStream &is, UT_Vector2I &v)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_StringHolder &value) const override
const UT_StringHolder & getCurveuattr() const
void setNestParmValue(TempIndex idx, TempIndex instance, const fpreal &value) override
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector2D &value) const override
void doSetParmValue(TempIndex idx, TempIndex instance, const T &value)
bool getOutputsubdpoly() const
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector3D &value) const override
bool opDoptdistattr(const SOP_NodeVerb::CookParms &cookparms) const
exint bread(int32 *buffer, exint asize=1)
static void loadData(UT_IStream &is, UT_Vector3I &v)
GT_API const UT_StringHolder time
static void loadData(UT_IStream &is, UT_Vector3D &v)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector2D &value) override
static void saveData(std::ostream &os, UT_Vector3D v)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector3D &value) override
GLuint const GLfloat * val
Measure getMeasure() const
static void loadData(UT_IStream &is, UT_Matrix2D &v)
static void saveData(std::ostream &os, UT_StringHolder s)
static void loadData(UT_IStream &is, UT_Matrix4D &v)
Treatpolysas getTreatpolysas() const
bool opOutputsubdpoly(const SOP_NodeVerb::CookParms &cookparms) const
bool opOnlypoints(const SOP_NodeVerb::CookParms &cookparms) const
fpreal64 opLod(const SOP_NodeVerb::CookParms &cookparms) const
bool opDolength(const SOP_NodeVerb::CookParms &cookparms) const
Method opMethod(const SOP_NodeVerb::CookParms &cookparms) const
SYS_FORCE_INLINE const char * buffer() const
const SOP_GraphProxy * graph() const
Treatpolysas opTreatpolysas(const SOP_NodeVerb::CookParms &cookparms) const
bool getDotangentattr() const
void setMeasure(Measure val)
An output stream object that owns its own string buffer storage.
void setDoptdistattr(bool val)
void setCurveuattr(const UT_StringHolder &val)
fpreal64 getLength() const
void setLod(fpreal64 val)
static void loadData(UT_IStream &is, UT_SharedPtr< UT_Ramp > &v)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix2D &value) const override
bool opDocurvenumattr(const SOP_NodeVerb::CookParms &cookparms) const
static void saveData(std::ostream &os, bool v)
const UT_StringHolder & getPtdistattr() const
static PRM_DataItemHandle parseBinary(const char *type, UT_IStream &is)
const UT_WorkBuffer & str()
Returns a read-only reference to the underlying UT_WorkBuffer.
bool opDocurveuattr(const SOP_NodeVerb::CookParms &cookparms) const
void setRandomshift(bool val)
static void loadData(UT_IStream &is, fpreal64 &v)
bool opUseattribs(const SOP_NodeVerb::CookParms &cookparms) const
bool operator==(const BaseDimensions< T > &a, const BaseDimensions< Y > &b)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Vector4D &value) const override
const UT_StringHolder & getCurvenumattr() const
void save(std::ostream &os) const
bool operator==(const SOP_ResampleParms &src) const
void setLength(fpreal64 val)
bool opAllequal(const SOP_NodeVerb::CookParms &cookparms) const
UT_StringHolder opGroup(const SOP_NodeVerb::CookParms &cookparms) const
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_StringHolder &value) override
static void loadData(UT_IStream &is, UT_Matrix3D &v)
SYS_FORCE_INLINE const char * buffer() const
std::shared_ptr< T > UT_SharedPtr
Wrapper around std::shared_ptr.
~SOP_ResampleParms() override
GLint GLenum GLsizei GLint GLsizei const void * data
void setDolength(bool val)
Measure opMeasure(const SOP_NodeVerb::CookParms &cookparms) const
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix3D &value) override
static void saveData(std::ostream &os, UT_Matrix2D v)
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_SharedPtr< UT_Ramp > &value) override
void setTreatpolysas(Treatpolysas val)
const UT_StringHolder & getGroup() const
static void loadData(UT_IStream &is, bool &v)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix4D &value) const override
bool getDocurveuattr() const
fpreal64 opLength(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Vector2D &v)
void setNestParmValue(TempIndex idx, TempIndex instance, const exint &value) override
ParmType getNestParmType(TempIndex fieldnum) const override
bool getDocurvenumattr() const
void setTangentattr(const UT_StringHolder &val)
static void saveData(std::ostream &os, PRM_DataItemHandle s)
void getNestParmValue(TempIndex idx, TempIndex instance, fpreal &value) const override
void setDocurveuattr(bool val)
void saveBinary(std::ostream &os) const
Save string to binary stream.
bool opDotangentattr(const SOP_NodeVerb::CookParms &cookparms) const
void doGetParmValue(TempIndex idx, TempIndex instance, T &value) const
GT_API const UT_StringHolder version
DEP_MicroNode * depnode() const
bool getOnlypoints() const
void setPtdistattr(const UT_StringHolder &val)
static void loadData(UT_IStream &is, UT_Vector4I &v)
void setNestParmValue(TempIndex idx, TempIndex instance, const PRM_DataItemHandle &value) override
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector4D &value) override
static void saveData(std::ostream &os, UT_Vector4D v)
void setMethod(Method val)
const char * getNestParmName(TempIndex fieldnum) const override
bool opEdge(const SOP_NodeVerb::CookParms &cookparms) const
static void saveData(std::ostream &os, UT_Vector2D v)
void setCurvenumattr(const UT_StringHolder &val)
UT_StringHolder opCurvenumattr(const SOP_NodeVerb::CookParms &cookparms) const
static void saveData(std::ostream &os, fpreal64 v)
void copyFrom(const SOP_NodeParms *src) override
Utility class for containing a color ramp.
void setUseattribs(bool val)
GLdouble GLdouble GLdouble r
static void loadData(UT_IStream &is, UT_Vector4D &v)
bool load(UT_IStream &is)
void setOutputsubdpoly(bool val)
const UT_StringHolder & getTangentattr() const
virtual void evalOpParm(int64 &v, NodeIdx node, const char *parmname, fpreal time, DEP_MicroNode *depnode) const =0
fpreal getCookTime() const
static void saveData(std::ostream &os, UT_SharedPtr< UT_Ramp > s)
bool getDoptdistattr() const
static void loadData(UT_IStream &is, UT_StringHolder &v)
const char * findChar(int c) const
int64 opSegs(const SOP_NodeVerb::CookParms &cookparms) const
static void saveData(std::ostream &os, UT_Matrix4D v)
bool getUseattribs() const
bool getRandomshift() const
void loadFromOpSubclass(const LoadParms &loadparms) override
void setGroup(const UT_StringHolder &val)
void setDotangentattr(bool val)
UT_StringHolder opCurveuattr(const SOP_NodeVerb::CookParms &cookparms) const
bool operator!=(const SOP_ResampleParms &src) const
void setDocurvenumattr(bool val)
bool opLast(const SOP_NodeVerb::CookParms &cookparms) const
static void saveData(std::ostream &os, UT_Matrix3D v)
void buildFromOp(const SOP_GraphProxy *graph, exint nodeidx, fpreal time, DEP_MicroNode *depnode)
GLsizei const GLfloat * value
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix2D &value) override
static void loadData(UT_IStream &is, int64 &v)
void getNestParmValue(TempIndex idx, TempIndex instance, PRM_DataItemHandle &value) const override
void setOnlypoints(bool val)
const OP_Context & context() const
UT_SharedPtr< const PRM_DataItem > PRM_DataItemHandle
void getNestParmValue(TempIndex idx, TempIndex instance, exint &value) const override
void setAllequal(bool val)
UT_StringHolder opPtdistattr(const SOP_NodeVerb::CookParms &cookparms) const
SYS_FORCE_INLINE bool isstring() const
SYS_FORCE_INLINE void strncpy(const char *src, exint maxlen)
static void loadData(UT_IStream &is, PRM_DataItemHandle &v)
void getNestParmValue(TempIndex idx, TempIndex instance, UT_Matrix3D &value) const override
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Matrix4D &value) override
bool opRandomshift(const SOP_NodeVerb::CookParms &cookparms) const