23 namespace SOP_ResampleEnums
36 using namespace UT::Literal;
55 using namespace UT::Literal;
73 using namespace UT::Literal;
93 myMaintainprimorder =
false;
105 myRandomshift =
false;
106 myOnlypoints =
false;
108 myOutputsubdpoly =
false;
109 myDoptdistattr =
false;
110 myPtdistattr =
"ptdist"_UTsh;
111 myDotangentattr =
false;
112 myTangentattr =
"tangentu"_UTsh;
113 myDocurveuattr =
false;
114 myCurveuattr =
"curveu"_UTsh;
115 myDocurvenumattr =
false;
116 myCurvenumattr =
"curvenum"_UTsh;
129 if (myGroup != src.myGroup)
return false;
130 if (myMaintainprimorder != src.myMaintainprimorder)
return false;
131 if (myLod != src.myLod)
return false;
132 if (myEdge != src.myEdge)
return false;
133 if (myMethod != src.myMethod)
return false;
134 if (myMeasure != src.myMeasure)
return false;
135 if (myDolength != src.myDolength)
return false;
136 if (myLength != src.myLength)
return false;
137 if (myDosegs != src.myDosegs)
return false;
138 if (mySegs != src.mySegs)
return false;
139 if (myUseattribs != src.myUseattribs)
return false;
140 if (myAllequal != src.myAllequal)
return false;
141 if (myLast != src.myLast)
return false;
142 if (myRandomshift != src.myRandomshift)
return false;
143 if (myOnlypoints != src.myOnlypoints)
return false;
144 if (myTreatpolysas != src.myTreatpolysas)
return false;
145 if (myOutputsubdpoly != src.myOutputsubdpoly)
return false;
146 if (myDoptdistattr != src.myDoptdistattr)
return false;
147 if (myPtdistattr != src.myPtdistattr)
return false;
148 if (myDotangentattr != src.myDotangentattr)
return false;
149 if (myTangentattr != src.myTangentattr)
return false;
150 if (myDocurveuattr != src.myDocurveuattr)
return false;
151 if (myCurveuattr != src.myCurveuattr)
return false;
152 if (myDocurvenumattr != src.myDocurvenumattr)
return false;
153 if (myCurvenumattr != src.myCurvenumattr)
return false;
174 graph->
evalOpParm(myGroup, nodeidx,
"group", time, graph->
isDirect()?
nullptr:depnode);
175 myMaintainprimorder =
false;
177 graph->
evalOpParm(myMaintainprimorder, nodeidx,
"maintainprimorder", time, graph->
isDirect()?
nullptr:depnode);
186 graph->
evalOpParm(myMethod, nodeidx,
"method", time, graph->
isDirect()?
nullptr:depnode);
189 graph->
evalOpParm(myMeasure, nodeidx,
"measure", time, graph->
isDirect()?
nullptr:depnode);
192 graph->
evalOpParm(myDolength, nodeidx,
"dolength", time, graph->
isDirect()?
nullptr:depnode);
194 if (
true && ( (
true&&!(((getDolength()==0)))) ) )
195 graph->
evalOpParm(myLength, nodeidx,
"length", time, graph->
isDirect()?
nullptr:depnode);
198 graph->
evalOpParm(myDosegs, nodeidx,
"dosegs", time, graph->
isDirect()?
nullptr:depnode);
200 if (
true && ( (
true&&!(((getDosegs()==0)))) ) )
204 graph->
evalOpParm(myUseattribs, nodeidx,
"useattribs", time, graph->
isDirect()?
nullptr:depnode);
206 if (
true && ( (
true&&!(((getDolength()==0))||((getEdge()==1))||((
int64(getMeasure())!=0))||((
int64(getMethod())!=0)))) ) )
207 graph->
evalOpParm(myAllequal, nodeidx,
"allequal", time, graph->
isDirect()?
nullptr:depnode);
209 if (
true && ( (
true&&!(((getDolength()==0))||((getEdge()==1))||((getDolength()==1)&&(getEdge()==0)&&(
int64(getMeasure())==0)&&(
int64(getMethod())==0)&&(getAllequal()==1)))) ) )
211 myRandomshift =
false;
212 if (
true && ( (
true&&!(((getDolength()==0))||((getEdge()==1))||((getDolength()==1)&&(getEdge()==0)&&(
int64(getMeasure())==0)&&(
int64(getMethod())==0)&&(getAllequal()==1)))) ) )
213 graph->
evalOpParm(myRandomshift, nodeidx,
"randomshift", time, graph->
isDirect()?
nullptr:depnode);
214 myOnlypoints =
false;
216 graph->
evalOpParm(myOnlypoints, nodeidx,
"onlypoints", time, graph->
isDirect()?
nullptr:depnode);
219 graph->
evalOpParm(myTreatpolysas, nodeidx,
"treatpolysas", time, graph->
isDirect()?
nullptr:depnode);
220 myOutputsubdpoly =
false;
222 graph->
evalOpParm(myOutputsubdpoly, nodeidx,
"outputsubdpoly", time, graph->
isDirect()?
nullptr:depnode);
223 myDoptdistattr =
false;
225 graph->
evalOpParm(myDoptdistattr, nodeidx,
"doptdistattr", time, graph->
isDirect()?
nullptr:depnode);
226 myPtdistattr =
"ptdist"_UTsh;
227 if (
true && ( (
true&&!(((getDoptdistattr()==0)))) ) )
228 graph->
evalOpParm(myPtdistattr, nodeidx,
"ptdistattr", time, graph->
isDirect()?
nullptr:depnode);
229 myDotangentattr =
false;
231 graph->
evalOpParm(myDotangentattr, nodeidx,
"dotangentattr", time, graph->
isDirect()?
nullptr:depnode);
232 myTangentattr =
"tangentu"_UTsh;
233 if (
true && ( (
true&&!(((getDotangentattr()==0)))) ) )
234 graph->
evalOpParm(myTangentattr, nodeidx,
"tangentattr", time, graph->
isDirect()?
nullptr:depnode);
235 myDocurveuattr =
false;
237 graph->
evalOpParm(myDocurveuattr, nodeidx,
"docurveuattr", time, graph->
isDirect()?
nullptr:depnode);
238 myCurveuattr =
"curveu"_UTsh;
239 if (
true && ( (
true&&!(((getDocurveuattr()==0)))) ) )
240 graph->
evalOpParm(myCurveuattr, nodeidx,
"curveuattr", time, graph->
isDirect()?
nullptr:depnode);
241 myDocurvenumattr =
false;
243 graph->
evalOpParm(myDocurvenumattr, nodeidx,
"docurvenumattr", time, graph->
isDirect()?
nullptr:depnode);
244 myCurvenumattr =
"curvenum"_UTsh;
245 if (
true && ( (
true&&!(((getDocurvenumattr()==0)))) ) )
246 graph->
evalOpParm(myCurvenumattr, nodeidx,
"curvenumattr", time, graph->
isDirect()?
nullptr:depnode);
262 template <
typename T>
269 if (idx.
size() != instance.
size()+1)
274 coerceValue(value, myGroup);
277 coerceValue(value, myMaintainprimorder);
280 coerceValue(value, myLod);
283 coerceValue(value, myEdge);
286 coerceValue(value, myMethod);
289 coerceValue(value, myMeasure);
292 coerceValue(value, myDolength);
295 coerceValue(value, myLength);
298 coerceValue(value, myDosegs);
301 coerceValue(value, mySegs);
304 coerceValue(value, myUseattribs);
307 coerceValue(value, myAllequal);
310 coerceValue(value, myLast);
313 coerceValue(value, myRandomshift);
316 coerceValue(value, myOnlypoints);
319 coerceValue(value, myTreatpolysas);
322 coerceValue(value, myOutputsubdpoly);
325 coerceValue(value, myDoptdistattr);
328 coerceValue(value, myPtdistattr);
331 coerceValue(value, myDotangentattr);
334 coerceValue(value, myTangentattr);
337 coerceValue(value, myDocurveuattr);
340 coerceValue(value, myCurveuattr);
343 coerceValue(value, myDocurvenumattr);
346 coerceValue(value, myCurvenumattr);
362 { doGetParmValue(idx, instance, value); }
364 { doGetParmValue(idx, instance, value); }
366 { doGetParmValue(idx, instance, value); }
368 { doGetParmValue(idx, instance, value); }
370 { doGetParmValue(idx, instance, value); }
372 { doGetParmValue(idx, instance, value); }
374 { doGetParmValue(idx, instance, value); }
376 { doGetParmValue(idx, instance, value); }
378 { doGetParmValue(idx, instance, value); }
380 { doGetParmValue(idx, instance, value); }
382 { doGetParmValue(idx, instance, value); }
384 template <
typename T>
391 if (idx.
size() != instance.
size()+1)
396 coerceValue(myGroup, ( ( value ) ));
399 coerceValue(myMaintainprimorder, ( ( value ) ));
402 coerceValue(myLod, clampMinValue(0.001, ( value ) ));
405 coerceValue(myEdge, ( ( value ) ));
408 coerceValue(myMethod, clampMinValue(0, clampMaxValue(3, value ) ));
411 coerceValue(myMeasure, clampMinValue(0, clampMaxValue(1, value ) ));
414 coerceValue(myDolength, ( ( value ) ));
417 coerceValue(myLength, clampMinValue(0, ( value ) ));
420 coerceValue(myDosegs, ( ( value ) ));
423 coerceValue(mySegs, clampMinValue(1, ( value ) ));
426 coerceValue(myUseattribs, ( ( value ) ));
429 coerceValue(myAllequal, ( ( value ) ));
432 coerceValue(myLast, ( ( value ) ));
435 coerceValue(myRandomshift, ( ( value ) ));
438 coerceValue(myOnlypoints, ( ( value ) ));
441 coerceValue(myTreatpolysas, clampMinValue(0, clampMaxValue(2, value ) ));
444 coerceValue(myOutputsubdpoly, ( ( value ) ));
447 coerceValue(myDoptdistattr, ( ( value ) ));
450 coerceValue(myPtdistattr, ( ( value ) ));
453 coerceValue(myDotangentattr, ( ( value ) ));
456 coerceValue(myTangentattr, ( ( value ) ));
459 coerceValue(myDocurveuattr, ( ( value ) ));
462 coerceValue(myCurveuattr, ( ( value ) ));
465 coerceValue(myDocurvenumattr, ( ( value ) ));
468 coerceValue(myCurvenumattr, ( ( value ) ));
475 { doSetParmValue(idx, instance, value); }
477 { doSetParmValue(idx, instance, value); }
479 { doSetParmValue(idx, instance, value); }
481 { doSetParmValue(idx, instance, value); }
483 { doSetParmValue(idx, instance, value); }
485 { doSetParmValue(idx, instance, value); }
487 { doSetParmValue(idx, instance, value); }
489 { doSetParmValue(idx, instance, value); }
491 { doSetParmValue(idx, instance, value); }
493 { doSetParmValue(idx, instance, value); }
495 { doSetParmValue(idx, instance, value); }
511 if (fieldnum.
size() < 1)
518 return "maintainprimorder";
542 return "randomshift";
546 return "treatpolysas";
548 return "outputsubdpoly";
550 return "doptdistattr";
554 return "dotangentattr";
556 return "tangentattr";
558 return "docurveuattr";
562 return "docurvenumattr";
564 return "curvenumattr";
572 if (fieldnum.
size() < 1)
573 return PARM_UNSUPPORTED;
628 return PARM_UNSUPPORTED;
664 loadData(is, rampdata);
682 int typelen = colon - data.
buffer();
696 {
int64 iv =
v; UTwrite(os, &iv); }
698 { UTwrite<fpreal64>(os, &
v); }
700 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y()); }
702 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y());
703 UTwrite<fpreal64>(os, &v.
z()); }
705 { UTwrite<fpreal64>(os, &v.
x()); UTwrite<fpreal64>(os, &v.
y());
706 UTwrite<fpreal64>(os, &v.
z()); UTwrite<fpreal64>(os, &v.
w()); }
718 if (s) s->save(ostr);
720 saveData(os, result);
727 ostr << s->getDataTypeToken();
732 saveData(os, result);
736 void save(std::ostream &os)
const
740 saveData(os, myGroup);
741 saveData(os, myMaintainprimorder);
743 saveData(os, myEdge);
744 saveData(os, myMethod);
745 saveData(os, myMeasure);
746 saveData(os, myDolength);
747 saveData(os, myLength);
748 saveData(os, myDosegs);
749 saveData(os, mySegs);
750 saveData(os, myUseattribs);
751 saveData(os, myAllequal);
752 saveData(os, myLast);
753 saveData(os, myRandomshift);
754 saveData(os, myOnlypoints);
755 saveData(os, myTreatpolysas);
756 saveData(os, myOutputsubdpoly);
757 saveData(os, myDoptdistattr);
758 saveData(os, myPtdistattr);
759 saveData(os, myDotangentattr);
760 saveData(os, myTangentattr);
761 saveData(os, myDocurveuattr);
762 saveData(os, myCurveuattr);
763 saveData(os, myDocurvenumattr);
764 saveData(os, myCurvenumattr);
777 loadData(is, myGroup);
778 loadData(is, myMaintainprimorder);
780 loadData(is, myEdge);
781 loadData(is, myMethod);
782 loadData(is, myMeasure);
783 loadData(is, myDolength);
784 loadData(is, myLength);
785 loadData(is, myDosegs);
786 loadData(is, mySegs);
787 loadData(is, myUseattribs);
788 loadData(is, myAllequal);
789 loadData(is, myLast);
790 loadData(is, myRandomshift);
791 loadData(is, myOnlypoints);
792 loadData(is, myTreatpolysas);
793 loadData(is, myOutputsubdpoly);
794 loadData(is, myDoptdistattr);
795 loadData(is, myPtdistattr);
796 loadData(is, myDotangentattr);
797 loadData(is, myTangentattr);
798 loadData(is, myDocurveuattr);
799 loadData(is, myCurveuattr);
800 loadData(is, myDocurvenumattr);
801 loadData(is, myCurvenumattr);
811 if (!thissop)
return getGroup();
813 OP_Utils::evalOpParm(result, thissop,
"group", cookparms.
getCookTime(), 0);
821 if (!thissop)
return getMaintainprimorder();
823 OP_Utils::evalOpParm(result, thissop,
"maintainprimorder", cookparms.
getCookTime(), 0);
831 if (!thissop)
return getLod();
833 OP_Utils::evalOpParm(result, thissop,
"lod", cookparms.
getCookTime(), 0);
841 if (!thissop)
return getEdge();
843 OP_Utils::evalOpParm(result, thissop,
"edge", cookparms.
getCookTime(), 0);
851 if (!thissop)
return getMethod();
853 OP_Utils::evalOpParm(result, thissop,
"method", cookparms.
getCookTime(), 0);
861 if (!thissop)
return getMeasure();
863 OP_Utils::evalOpParm(result, thissop,
"measure", cookparms.
getCookTime(), 0);
871 if (!thissop)
return getDolength();
873 OP_Utils::evalOpParm(result, thissop,
"dolength", cookparms.
getCookTime(), 0);
881 if (!thissop)
return getLength();
883 OP_Utils::evalOpParm(result, thissop,
"length", cookparms.
getCookTime(), 0);
891 if (!thissop)
return getDosegs();
893 OP_Utils::evalOpParm(result, thissop,
"dosegs", cookparms.
getCookTime(), 0);
901 if (!thissop)
return getSegs();
903 OP_Utils::evalOpParm(result, thissop,
"segs", cookparms.
getCookTime(), 0);
911 if (!thissop)
return getUseattribs();
913 OP_Utils::evalOpParm(result, thissop,
"useattribs", cookparms.
getCookTime(), 0);
921 if (!thissop)
return getAllequal();
923 OP_Utils::evalOpParm(result, thissop,
"allequal", cookparms.
getCookTime(), 0);
931 if (!thissop)
return getLast();
933 OP_Utils::evalOpParm(result, thissop,
"last", cookparms.
getCookTime(), 0);
941 if (!thissop)
return getRandomshift();
943 OP_Utils::evalOpParm(result, thissop,
"randomshift", cookparms.
getCookTime(), 0);
951 if (!thissop)
return getOnlypoints();
953 OP_Utils::evalOpParm(result, thissop,
"onlypoints", cookparms.
getCookTime(), 0);
961 if (!thissop)
return getTreatpolysas();
963 OP_Utils::evalOpParm(result, thissop,
"treatpolysas", cookparms.
getCookTime(), 0);
971 if (!thissop)
return getOutputsubdpoly();
973 OP_Utils::evalOpParm(result, thissop,
"outputsubdpoly", cookparms.
getCookTime(), 0);
981 if (!thissop)
return getDoptdistattr();
983 OP_Utils::evalOpParm(result, thissop,
"doptdistattr", cookparms.
getCookTime(), 0);
991 if (!thissop)
return getPtdistattr();
993 OP_Utils::evalOpParm(result, thissop,
"ptdistattr", cookparms.
getCookTime(), 0);
1001 if (!thissop)
return getDotangentattr();
1003 OP_Utils::evalOpParm(result, thissop,
"dotangentattr", cookparms.
getCookTime(), 0);
1011 if (!thissop)
return getTangentattr();
1013 OP_Utils::evalOpParm(result, thissop,
"tangentattr", cookparms.
getCookTime(), 0);
1021 if (!thissop)
return getDocurveuattr();
1023 OP_Utils::evalOpParm(result, thissop,
"docurveuattr", cookparms.
getCookTime(), 0);
1031 if (!thissop)
return getCurveuattr();
1033 OP_Utils::evalOpParm(result, thissop,
"curveuattr", cookparms.
getCookTime(), 0);
1041 if (!thissop)
return getDocurvenumattr();
1043 OP_Utils::evalOpParm(result, thissop,
"docurvenumattr", cookparms.
getCookTime(), 0);
1051 if (!thissop)
return getCurvenumattr();
1053 OP_Utils::evalOpParm(result, thissop,
"curvenumattr", cookparms.
getCookTime(), 0);
1059 bool myMaintainprimorder;
1073 int64 myTreatpolysas;
1074 bool myOutputsubdpoly;
1075 bool myDoptdistattr;
1077 bool myDotangentattr;
1079 bool myDocurveuattr;
1081 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
void copyFrom(const OP_NodeParms *src) 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)
constexpr SYS_FORCE_INLINE T & y() noexcept
void setNestParmValue(TempIndex idx, TempIndex instance, const UT_Vector3D &value) override
GLsizei const GLfloat * value
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 getMaintainprimorder() const
const OP_Context & context() const
bool opOutputsubdpoly(const SOP_NodeVerb::CookParms &cookparms) const
bool opOnlypoints(const SOP_NodeVerb::CookParms &cookparms) const
constexpr SYS_FORCE_INLINE T & z() noexcept
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
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)
**But if you need a result
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.
constexpr SYS_FORCE_INLINE T & x() noexcept
bool opDocurveuattr(const SOP_NodeVerb::CookParms &cookparms) const
void setRandomshift(bool val)
void setMaintainprimorder(bool val)
static void loadData(UT_IStream &is, fpreal64 &v)
bool opUseattribs(const SOP_NodeVerb::CookParms &cookparms) const
UT_SharedPtr< const PRM_DataItem > PRM_DataItemHandle
constexpr SYS_FORCE_INLINE T & x() noexcept
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.
constexpr SYS_FORCE_INLINE T & z() noexcept
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)
const OP_GraphProxy * graph() const
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)
virtual void evalOpParm(int64 &v, NodeIdx node, const char *parmname, fpreal time, DEP_MicroNode *depnode) const =0
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
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
DEP_MicroNode * depnode() const
static void saveData(std::ostream &os, fpreal64 v)
LeafData & operator=(const LeafData &)=delete
Utility class for containing a color ramp.
void setUseattribs(bool val)
constexpr SYS_FORCE_INLINE T & w() noexcept
bool opMaintainprimorder(const SOP_NodeVerb::CookParms &cookparms) const
static void loadData(UT_IStream &is, UT_Vector4D &v)
bool load(UT_IStream &is)
virtual UT_StringHolder baseGetSignature() const
void setOutputsubdpoly(bool val)
const UT_StringHolder & getTangentattr() const
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
bool isParmColorRamp(exint idx) const 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
constexpr SYS_FORCE_INLINE T & y() noexcept
static void saveData(std::ostream &os, UT_Matrix3D v)
virtual bool isDirect() const =0
Direct proxies mirror actual nodes:
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)
void getNestParmValue(TempIndex idx, TempIndex instance, exint &value) const override
void setAllequal(bool val)
constexpr SYS_FORCE_INLINE T & y() noexcept
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
constexpr SYS_FORCE_INLINE T & x() noexcept
void buildFromOp(const OP_GraphProxy *graph, exint nodeidx, fpreal time, DEP_MicroNode *depnode)
SYS_FORCE_INLINE UT_StringHolder getToken(Method enum_value)
bool opRandomshift(const SOP_NodeVerb::CookParms &cookparms) const