// // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions // are met: // * Redistributions of source code must retain the above copyright // notice, this list of conditions and the following disclaimer. // * Redistributions in binary form must reproduce the above copyright // notice, this list of conditions and the following disclaimer in the // documentation and/or other materials provided with the distribution. // * Neither the name of NVIDIA CORPORATION nor the names of its // contributors may be used to endorse or promote products derived // from this software without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ``AS IS'' AND ANY // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // // Copyright (c) 2018 NVIDIA Corporation. All rights reserved. // This file was generated by NvParameterized/scripts/GenParameterized.pl #include "ClothingCookedPhysX3Param.h" #include #include using namespace NvParameterized; namespace nvidia { namespace clothing { using namespace ClothingCookedPhysX3ParamNS; const char* const ClothingCookedPhysX3ParamFactory::vptr = NvParameterized::getVptr(); const uint32_t NumParamDefs = 43; static NvParameterized::DefinitionImpl* ParamDefTable; // now allocated in buildTree [NumParamDefs]; static const size_t ParamLookupChildrenTable[] = { 1, 2, 3, 5, 7, 9, 11, 13, 21, 26, 28, 30, 32, 34, 36, 37, 38, 42, 4, 6, 8, 10, 12, 14, 15, 16, 17, 18, 19, 20, 22, 23, 24, 25, 27, 29, 31, 33, 35, 39, 40, 41, }; #define TENUM(type) nvidia::##type #define CHILDREN(index) &ParamLookupChildrenTable[index] static const NvParameterized::ParamLookupNode ParamLookupTable[NumParamDefs] = { { TYPE_STRUCT, false, 0, CHILDREN(0), 18 }, { TYPE_U32, false, (size_t)(&((ParametersStruct*)0)->physicalMeshId), NULL, 0 }, // physicalMeshId { TYPE_U32, false, (size_t)(&((ParametersStruct*)0)->numVertices), NULL, 0 }, // numVertices { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->deformableRestLengths), CHILDREN(18), 1 }, // deformableRestLengths { TYPE_F32, false, 1 * sizeof(float), NULL, 0 }, // deformableRestLengths[] { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->deformableIndices), CHILDREN(19), 1 }, // deformableIndices { TYPE_U32, false, 1 * sizeof(uint32_t), NULL, 0 }, // deformableIndices[] { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->selfCollisionIndices), CHILDREN(20), 1 }, // selfCollisionIndices { TYPE_U32, false, 1 * sizeof(uint32_t), NULL, 0 }, // selfCollisionIndices[] { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->selfCollisionNormalIndices), CHILDREN(21), 1 }, // selfCollisionNormalIndices { TYPE_U32, false, 1 * sizeof(uint32_t), NULL, 0 }, // selfCollisionNormalIndices[] { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->selfCollisionNormalSetSizes), CHILDREN(22), 1 }, // selfCollisionNormalSetSizes { TYPE_U32, false, 1 * sizeof(uint32_t), NULL, 0 }, // selfCollisionNormalSetSizes[] { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->deformableSets), CHILDREN(23), 1 }, // deformableSets { TYPE_STRUCT, false, 1 * sizeof(SetDesc_Type), CHILDREN(24), 6 }, // deformableSets[] { TYPE_U32, false, (size_t)(&((SetDesc_Type*)0)->fiberEnd), NULL, 0 }, // deformableSets[].fiberEnd { TYPE_U32, false, (size_t)(&((SetDesc_Type*)0)->longestFiber), NULL, 0 }, // deformableSets[].longestFiber { TYPE_U32, false, (size_t)(&((SetDesc_Type*)0)->shortestFiber), NULL, 0 }, // deformableSets[].shortestFiber { TYPE_U32, false, (size_t)(&((SetDesc_Type*)0)->numEdges), NULL, 0 }, // deformableSets[].numEdges { TYPE_F32, false, (size_t)(&((SetDesc_Type*)0)->avgEdgeLength), NULL, 0 }, // deformableSets[].avgEdgeLength { TYPE_U32, false, (size_t)(&((SetDesc_Type*)0)->avgFiberLength), NULL, 0 }, // deformableSets[].avgFiberLength { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->deformablePhaseDescs), CHILDREN(30), 1 }, // deformablePhaseDescs { TYPE_STRUCT, false, 1 * sizeof(PhaseDesc_Type), CHILDREN(31), 3 }, // deformablePhaseDescs[] { TYPE_U32, false, (size_t)(&((PhaseDesc_Type*)0)->phaseType), NULL, 0 }, // deformablePhaseDescs[].phaseType { TYPE_U32, false, (size_t)(&((PhaseDesc_Type*)0)->setIndex), NULL, 0 }, // deformablePhaseDescs[].setIndex { TYPE_U32, false, (size_t)(&((PhaseDesc_Type*)0)->restValueOffset), NULL, 0 }, // deformablePhaseDescs[].restValueOffset { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->tetherAnchors), CHILDREN(34), 1 }, // tetherAnchors { TYPE_U32, false, 1 * sizeof(uint32_t), NULL, 0 }, // tetherAnchors[] { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->tetherLengths), CHILDREN(35), 1 }, // tetherLengths { TYPE_F32, false, 1 * sizeof(float), NULL, 0 }, // tetherLengths[] { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->deformableInvVertexWeights), CHILDREN(36), 1 }, // deformableInvVertexWeights { TYPE_F32, false, 1 * sizeof(float), NULL, 0 }, // deformableInvVertexWeights[] { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->virtualParticleIndices), CHILDREN(37), 1 }, // virtualParticleIndices { TYPE_U32, false, 1 * sizeof(uint32_t), NULL, 0 }, // virtualParticleIndices[] { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->virtualParticleWeights), CHILDREN(38), 1 }, // virtualParticleWeights { TYPE_F32, false, 1 * sizeof(float), NULL, 0 }, // virtualParticleWeights[] { TYPE_U32, false, (size_t)(&((ParametersStruct*)0)->cookedDataVersion), NULL, 0 }, // cookedDataVersion { TYPE_POINTER, false, (size_t)(&((ParametersStruct*)0)->fabricCPU), NULL, 0 }, // fabricCPU { TYPE_ARRAY, true, (size_t)(&((ParametersStruct*)0)->fabricGPU), CHILDREN(39), 1 }, // fabricGPU { TYPE_STRUCT, false, 1 * sizeof(FabricGPU_Type), CHILDREN(40), 2 }, // fabricGPU[] { TYPE_POINTER, false, (size_t)(&((FabricGPU_Type*)0)->fabricGPU), NULL, 0 }, // fabricGPU[].fabricGPU { TYPE_POINTER, false, (size_t)(&((FabricGPU_Type*)0)->factory), NULL, 0 }, // fabricGPU[].factory { TYPE_REF, false, (size_t)(&((ParametersStruct*)0)->nextCookedData), NULL, 0 }, // nextCookedData }; bool ClothingCookedPhysX3Param::mBuiltFlag = false; NvParameterized::MutexType ClothingCookedPhysX3Param::mBuiltFlagMutex; ClothingCookedPhysX3Param::ClothingCookedPhysX3Param(NvParameterized::Traits* traits, void* buf, int32_t* refCount) : NvParameters(traits, buf, refCount) { //mParameterizedTraits->registerFactory(className(), &ClothingCookedPhysX3ParamFactoryInst); if (!buf) //Do not init data if it is inplace-deserialized { initDynamicArrays(); initStrings(); initReferences(); initDefaults(); } } ClothingCookedPhysX3Param::~ClothingCookedPhysX3Param() { freeStrings(); freeReferences(); freeDynamicArrays(); } void ClothingCookedPhysX3Param::destroy() { // We cache these fields here to avoid overwrite in destructor bool doDeallocateSelf = mDoDeallocateSelf; NvParameterized::Traits* traits = mParameterizedTraits; int32_t* refCount = mRefCount; void* buf = mBuffer; this->~ClothingCookedPhysX3Param(); NvParameters::destroy(this, traits, doDeallocateSelf, refCount, buf); } const NvParameterized::DefinitionImpl* ClothingCookedPhysX3Param::getParameterDefinitionTree(void) { if (!mBuiltFlag) // Double-checked lock { NvParameterized::MutexType::ScopedLock lock(mBuiltFlagMutex); if (!mBuiltFlag) { buildTree(); } } return(&ParamDefTable[0]); } const NvParameterized::DefinitionImpl* ClothingCookedPhysX3Param::getParameterDefinitionTree(void) const { ClothingCookedPhysX3Param* tmpParam = const_cast(this); if (!mBuiltFlag) // Double-checked lock { NvParameterized::MutexType::ScopedLock lock(mBuiltFlagMutex); if (!mBuiltFlag) { tmpParam->buildTree(); } } return(&ParamDefTable[0]); } NvParameterized::ErrorType ClothingCookedPhysX3Param::getParameterHandle(const char* long_name, Handle& handle) const { ErrorType Ret = NvParameters::getParameterHandle(long_name, handle); if (Ret != ERROR_NONE) { return(Ret); } size_t offset; void* ptr; getVarPtr(handle, ptr, offset); if (ptr == NULL) { return(ERROR_INDEX_OUT_OF_RANGE); } return(ERROR_NONE); } NvParameterized::ErrorType ClothingCookedPhysX3Param::getParameterHandle(const char* long_name, Handle& handle) { ErrorType Ret = NvParameters::getParameterHandle(long_name, handle); if (Ret != ERROR_NONE) { return(Ret); } size_t offset; void* ptr; getVarPtr(handle, ptr, offset); if (ptr == NULL) { return(ERROR_INDEX_OUT_OF_RANGE); } return(ERROR_NONE); } void ClothingCookedPhysX3Param::getVarPtr(const Handle& handle, void*& ptr, size_t& offset) const { ptr = getVarPtrHelper(&ParamLookupTable[0], const_cast(¶meters()), handle, offset); } /* Dynamic Handle Indices */ void ClothingCookedPhysX3Param::freeParameterDefinitionTable(NvParameterized::Traits* traits) { if (!traits) { return; } if (!mBuiltFlag) // Double-checked lock { return; } NvParameterized::MutexType::ScopedLock lock(mBuiltFlagMutex); if (!mBuiltFlag) { return; } for (uint32_t i = 0; i < NumParamDefs; ++i) { ParamDefTable[i].~DefinitionImpl(); } traits->free(ParamDefTable); mBuiltFlag = false; } #define PDEF_PTR(index) (&ParamDefTable[index]) void ClothingCookedPhysX3Param::buildTree(void) { uint32_t allocSize = sizeof(NvParameterized::DefinitionImpl) * NumParamDefs; ParamDefTable = (NvParameterized::DefinitionImpl*)(mParameterizedTraits->alloc(allocSize)); memset(ParamDefTable, 0, allocSize); for (uint32_t i = 0; i < NumParamDefs; ++i) { NV_PARAM_PLACEMENT_NEW(ParamDefTable + i, NvParameterized::DefinitionImpl)(*mParameterizedTraits); } // Initialize DefinitionImpl node: nodeIndex=0, longName="" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[0]; ParamDef->init("", TYPE_STRUCT, "STRUCT", true); } // Initialize DefinitionImpl node: nodeIndex=1, longName="physicalMeshId" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[1]; ParamDef->init("physicalMeshId", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Physical mesh ID", true); ParamDefTable[1].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=2, longName="numVertices" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[2]; ParamDef->init("numVertices", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Vertex count", true); ParamDefTable[2].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=3, longName="deformableRestLengths" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[3]; ParamDef->init("deformableRestLengths", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Deformable rest lengths", true); ParamDefTable[3].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=4, longName="deformableRestLengths[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[4]; ParamDef->init("deformableRestLengths", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Deformable rest lengths", true); ParamDefTable[4].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=5, longName="deformableIndices" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[5]; ParamDef->init("deformableIndices", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Deformable indices", true); ParamDefTable[5].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=6, longName="deformableIndices[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[6]; ParamDef->init("deformableIndices", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Deformable indices", true); ParamDefTable[6].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=7, longName="selfCollisionIndices" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[7]; ParamDef->init("selfCollisionIndices", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Self collision indices", true); ParamDefTable[7].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=8, longName="selfCollisionIndices[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[8]; ParamDef->init("selfCollisionIndices", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Self collision indices", true); ParamDefTable[8].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=9, longName="selfCollisionNormalIndices" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[9]; ParamDef->init("selfCollisionNormalIndices", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Self collision normal indices", true); ParamDefTable[9].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=10, longName="selfCollisionNormalIndices[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[10]; ParamDef->init("selfCollisionNormalIndices", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Self collision normal indices", true); ParamDefTable[10].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=11, longName="selfCollisionNormalSetSizes" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[11]; ParamDef->init("selfCollisionNormalSetSizes", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Self collision normal set sizes", true); ParamDefTable[11].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=12, longName="selfCollisionNormalSetSizes[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[12]; ParamDef->init("selfCollisionNormalSetSizes", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Self collision normal set sizes", true); ParamDefTable[12].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=13, longName="deformableSets" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[13]; ParamDef->init("deformableSets", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Deformable sets", true); ParamDefTable[13].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=14, longName="deformableSets[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[14]; ParamDef->init("deformableSets", TYPE_STRUCT, "SetDesc", true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Deformable sets", true); ParamDefTable[14].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=15, longName="deformableSets[].fiberEnd" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[15]; ParamDef->init("fiberEnd", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Fiber end", true); ParamDefTable[15].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=16, longName="deformableSets[].longestFiber" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[16]; ParamDef->init("longestFiber", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Longest fiber", true); ParamDefTable[16].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=17, longName="deformableSets[].shortestFiber" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[17]; ParamDef->init("shortestFiber", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Shortest fiber", true); ParamDefTable[17].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=18, longName="deformableSets[].numEdges" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[18]; ParamDef->init("numEdges", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Edge count", true); ParamDefTable[18].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=19, longName="deformableSets[].avgEdgeLength" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[19]; ParamDef->init("avgEdgeLength", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Average edge length", true); ParamDefTable[19].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=20, longName="deformableSets[].avgFiberLength" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[20]; ParamDef->init("avgFiberLength", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Average fiber length", true); ParamDefTable[20].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=21, longName="deformablePhaseDescs" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[21]; ParamDef->init("deformablePhaseDescs", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Deformable phase descriptions", true); ParamDefTable[21].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=22, longName="deformablePhaseDescs[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[22]; ParamDef->init("deformablePhaseDescs", TYPE_STRUCT, "PhaseDesc", true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Deformable phase descriptions", true); ParamDefTable[22].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=23, longName="deformablePhaseDescs[].phaseType" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[23]; ParamDef->init("phaseType", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Phase type", true); ParamDefTable[23].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=24, longName="deformablePhaseDescs[].setIndex" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[24]; ParamDef->init("setIndex", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Set index", true); ParamDefTable[24].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=25, longName="deformablePhaseDescs[].restValueOffset" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[25]; ParamDef->init("restValueOffset", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Rest value offset", true); ParamDefTable[25].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=26, longName="tetherAnchors" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[26]; ParamDef->init("tetherAnchors", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Tether anchors", true); ParamDefTable[26].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=27, longName="tetherAnchors[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[27]; ParamDef->init("tetherAnchors", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Tether anchors", true); ParamDefTable[27].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=28, longName="tetherLengths" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[28]; ParamDef->init("tetherLengths", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Tether lengths", true); ParamDefTable[28].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=29, longName="tetherLengths[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[29]; ParamDef->init("tetherLengths", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Tether lengths", true); ParamDefTable[29].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=30, longName="deformableInvVertexWeights" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[30]; ParamDef->init("deformableInvVertexWeights", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Deformable inverse vertex weights", true); ParamDefTable[30].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=31, longName="deformableInvVertexWeights[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[31]; ParamDef->init("deformableInvVertexWeights", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Deformable inverse vertex weights", true); ParamDefTable[31].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=32, longName="virtualParticleIndices" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[32]; ParamDef->init("virtualParticleIndices", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Virtual particle indices", true); ParamDefTable[32].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=33, longName="virtualParticleIndices[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[33]; ParamDef->init("virtualParticleIndices", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Virtual particle indices", true); ParamDefTable[33].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=34, longName="virtualParticleWeights" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[34]; ParamDef->init("virtualParticleWeights", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Virtual particle weights", true); ParamDefTable[34].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=35, longName="virtualParticleWeights[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[35]; ParamDef->init("virtualParticleWeights", TYPE_F32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Virtual particle weights", true); ParamDefTable[35].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=36, longName="cookedDataVersion" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[36]; ParamDef->init("cookedDataVersion", TYPE_U32, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS #else static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("shortDescription", "Cooked data version", true); ParamDefTable[36].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=37, longName="fabricCPU" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[37]; ParamDef->init("fabricCPU", TYPE_POINTER, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("DONOTSERIALIZE", uint64_t(1), true); ParamDefTable[37].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("DONOTSERIALIZE", uint64_t(1), true); HintTable[1].init("shortDescription", "Fabric CPU pointer", true); ParamDefTable[37].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=38, longName="fabricGPU" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[38]; ParamDef->init("fabricGPU", TYPE_ARRAY, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("DONOTSERIALIZE", uint64_t(1), true); ParamDefTable[38].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("DONOTSERIALIZE", uint64_t(1), true); HintTable[1].init("shortDescription", "Fabric GPU array", true); ParamDefTable[38].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ ParamDef->setArraySize(-1); } // Initialize DefinitionImpl node: nodeIndex=39, longName="fabricGPU[]" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[39]; ParamDef->init("fabricGPU", TYPE_STRUCT, "FabricGPU", true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("DONOTSERIALIZE", uint64_t(1), true); ParamDefTable[39].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("DONOTSERIALIZE", uint64_t(1), true); HintTable[1].init("shortDescription", "Fabric GPU array", true); ParamDefTable[39].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=40, longName="fabricGPU[].fabricGPU" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[40]; ParamDef->init("fabricGPU", TYPE_POINTER, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("DONOTSERIALIZE", uint64_t(1), true); ParamDefTable[40].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("DONOTSERIALIZE", uint64_t(1), true); HintTable[1].init("shortDescription", "Runtime pointer to shared fabric.", true); ParamDefTable[40].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=41, longName="fabricGPU[].factory" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[41]; ParamDef->init("factory", TYPE_POINTER, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("DONOTSERIALIZE", uint64_t(1), true); ParamDefTable[41].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("DONOTSERIALIZE", uint64_t(1), true); HintTable[1].init("shortDescription", "Runtime pointer to the factory the fabric has been created with.", true); ParamDefTable[41].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ } // Initialize DefinitionImpl node: nodeIndex=42, longName="nextCookedData" { NvParameterized::DefinitionImpl* ParamDef = &ParamDefTable[42]; ParamDef->init("nextCookedData", TYPE_REF, NULL, true); #ifdef NV_PARAMETERIZED_HIDE_DESCRIPTIONS static HintImpl HintTable[1]; static Hint* HintPtrTable[1] = { &HintTable[0], }; HintTable[0].init("INCLUDED", uint64_t(1), true); ParamDefTable[42].setHints((const NvParameterized::Hint**)HintPtrTable, 1); #else static HintImpl HintTable[2]; static Hint* HintPtrTable[2] = { &HintTable[0], &HintTable[1], }; HintTable[0].init("INCLUDED", uint64_t(1), true); HintTable[1].init("shortDescription", "Daisy-chain together multiple cooked data objects", true); ParamDefTable[42].setHints((const NvParameterized::Hint**)HintPtrTable, 2); #endif /* NV_PARAMETERIZED_HIDE_DESCRIPTIONS */ static const char* const RefVariantVals[] = { "ClothingCookedPhysX3Param" }; ParamDefTable[42].setRefVariantVals((const char**)RefVariantVals, 1); } // SetChildren for: nodeIndex=0, longName="" { static Definition* Children[18]; Children[0] = PDEF_PTR(1); Children[1] = PDEF_PTR(2); Children[2] = PDEF_PTR(3); Children[3] = PDEF_PTR(5); Children[4] = PDEF_PTR(7); Children[5] = PDEF_PTR(9); Children[6] = PDEF_PTR(11); Children[7] = PDEF_PTR(13); Children[8] = PDEF_PTR(21); Children[9] = PDEF_PTR(26); Children[10] = PDEF_PTR(28); Children[11] = PDEF_PTR(30); Children[12] = PDEF_PTR(32); Children[13] = PDEF_PTR(34); Children[14] = PDEF_PTR(36); Children[15] = PDEF_PTR(37); Children[16] = PDEF_PTR(38); Children[17] = PDEF_PTR(42); ParamDefTable[0].setChildren(Children, 18); } // SetChildren for: nodeIndex=3, longName="deformableRestLengths" { static Definition* Children[1]; Children[0] = PDEF_PTR(4); ParamDefTable[3].setChildren(Children, 1); } // SetChildren for: nodeIndex=5, longName="deformableIndices" { static Definition* Children[1]; Children[0] = PDEF_PTR(6); ParamDefTable[5].setChildren(Children, 1); } // SetChildren for: nodeIndex=7, longName="selfCollisionIndices" { static Definition* Children[1]; Children[0] = PDEF_PTR(8); ParamDefTable[7].setChildren(Children, 1); } // SetChildren for: nodeIndex=9, longName="selfCollisionNormalIndices" { static Definition* Children[1]; Children[0] = PDEF_PTR(10); ParamDefTable[9].setChildren(Children, 1); } // SetChildren for: nodeIndex=11, longName="selfCollisionNormalSetSizes" { static Definition* Children[1]; Children[0] = PDEF_PTR(12); ParamDefTable[11].setChildren(Children, 1); } // SetChildren for: nodeIndex=13, longName="deformableSets" { static Definition* Children[1]; Children[0] = PDEF_PTR(14); ParamDefTable[13].setChildren(Children, 1); } // SetChildren for: nodeIndex=14, longName="deformableSets[]" { static Definition* Children[6]; Children[0] = PDEF_PTR(15); Children[1] = PDEF_PTR(16); Children[2] = PDEF_PTR(17); Children[3] = PDEF_PTR(18); Children[4] = PDEF_PTR(19); Children[5] = PDEF_PTR(20); ParamDefTable[14].setChildren(Children, 6); } // SetChildren for: nodeIndex=21, longName="deformablePhaseDescs" { static Definition* Children[1]; Children[0] = PDEF_PTR(22); ParamDefTable[21].setChildren(Children, 1); } // SetChildren for: nodeIndex=22, longName="deformablePhaseDescs[]" { static Definition* Children[3]; Children[0] = PDEF_PTR(23); Children[1] = PDEF_PTR(24); Children[2] = PDEF_PTR(25); ParamDefTable[22].setChildren(Children, 3); } // SetChildren for: nodeIndex=26, longName="tetherAnchors" { static Definition* Children[1]; Children[0] = PDEF_PTR(27); ParamDefTable[26].setChildren(Children, 1); } // SetChildren for: nodeIndex=28, longName="tetherLengths" { static Definition* Children[1]; Children[0] = PDEF_PTR(29); ParamDefTable[28].setChildren(Children, 1); } // SetChildren for: nodeIndex=30, longName="deformableInvVertexWeights" { static Definition* Children[1]; Children[0] = PDEF_PTR(31); ParamDefTable[30].setChildren(Children, 1); } // SetChildren for: nodeIndex=32, longName="virtualParticleIndices" { static Definition* Children[1]; Children[0] = PDEF_PTR(33); ParamDefTable[32].setChildren(Children, 1); } // SetChildren for: nodeIndex=34, longName="virtualParticleWeights" { static Definition* Children[1]; Children[0] = PDEF_PTR(35); ParamDefTable[34].setChildren(Children, 1); } // SetChildren for: nodeIndex=38, longName="fabricGPU" { static Definition* Children[1]; Children[0] = PDEF_PTR(39); ParamDefTable[38].setChildren(Children, 1); } // SetChildren for: nodeIndex=39, longName="fabricGPU[]" { static Definition* Children[2]; Children[0] = PDEF_PTR(40); Children[1] = PDEF_PTR(41); ParamDefTable[39].setChildren(Children, 2); } mBuiltFlag = true; } void ClothingCookedPhysX3Param::initStrings(void) { } void ClothingCookedPhysX3Param::initDynamicArrays(void) { deformableRestLengths.buf = NULL; deformableRestLengths.isAllocated = true; deformableRestLengths.elementSize = sizeof(float); deformableRestLengths.arraySizes[0] = 0; deformableIndices.buf = NULL; deformableIndices.isAllocated = true; deformableIndices.elementSize = sizeof(uint32_t); deformableIndices.arraySizes[0] = 0; selfCollisionIndices.buf = NULL; selfCollisionIndices.isAllocated = true; selfCollisionIndices.elementSize = sizeof(uint32_t); selfCollisionIndices.arraySizes[0] = 0; selfCollisionNormalIndices.buf = NULL; selfCollisionNormalIndices.isAllocated = true; selfCollisionNormalIndices.elementSize = sizeof(uint32_t); selfCollisionNormalIndices.arraySizes[0] = 0; selfCollisionNormalSetSizes.buf = NULL; selfCollisionNormalSetSizes.isAllocated = true; selfCollisionNormalSetSizes.elementSize = sizeof(uint32_t); selfCollisionNormalSetSizes.arraySizes[0] = 0; deformableSets.buf = NULL; deformableSets.isAllocated = true; deformableSets.elementSize = sizeof(SetDesc_Type); deformableSets.arraySizes[0] = 0; deformablePhaseDescs.buf = NULL; deformablePhaseDescs.isAllocated = true; deformablePhaseDescs.elementSize = sizeof(PhaseDesc_Type); deformablePhaseDescs.arraySizes[0] = 0; tetherAnchors.buf = NULL; tetherAnchors.isAllocated = true; tetherAnchors.elementSize = sizeof(uint32_t); tetherAnchors.arraySizes[0] = 0; tetherLengths.buf = NULL; tetherLengths.isAllocated = true; tetherLengths.elementSize = sizeof(float); tetherLengths.arraySizes[0] = 0; deformableInvVertexWeights.buf = NULL; deformableInvVertexWeights.isAllocated = true; deformableInvVertexWeights.elementSize = sizeof(float); deformableInvVertexWeights.arraySizes[0] = 0; virtualParticleIndices.buf = NULL; virtualParticleIndices.isAllocated = true; virtualParticleIndices.elementSize = sizeof(uint32_t); virtualParticleIndices.arraySizes[0] = 0; virtualParticleWeights.buf = NULL; virtualParticleWeights.isAllocated = true; virtualParticleWeights.elementSize = sizeof(float); virtualParticleWeights.arraySizes[0] = 0; fabricGPU.buf = NULL; fabricGPU.isAllocated = true; fabricGPU.elementSize = sizeof(FabricGPU_Type); fabricGPU.arraySizes[0] = 0; } void ClothingCookedPhysX3Param::initDefaults(void) { freeStrings(); freeReferences(); freeDynamicArrays(); physicalMeshId = uint32_t(0); numVertices = uint32_t(0); cookedDataVersion = uint32_t(0); fabricCPU = NULL; initDynamicArrays(); initStrings(); initReferences(); } void ClothingCookedPhysX3Param::initReferences(void) { nextCookedData = NULL; } void ClothingCookedPhysX3Param::freeDynamicArrays(void) { if (deformableRestLengths.isAllocated && deformableRestLengths.buf) { mParameterizedTraits->free(deformableRestLengths.buf); } if (deformableIndices.isAllocated && deformableIndices.buf) { mParameterizedTraits->free(deformableIndices.buf); } if (selfCollisionIndices.isAllocated && selfCollisionIndices.buf) { mParameterizedTraits->free(selfCollisionIndices.buf); } if (selfCollisionNormalIndices.isAllocated && selfCollisionNormalIndices.buf) { mParameterizedTraits->free(selfCollisionNormalIndices.buf); } if (selfCollisionNormalSetSizes.isAllocated && selfCollisionNormalSetSizes.buf) { mParameterizedTraits->free(selfCollisionNormalSetSizes.buf); } if (deformableSets.isAllocated && deformableSets.buf) { mParameterizedTraits->free(deformableSets.buf); } if (deformablePhaseDescs.isAllocated && deformablePhaseDescs.buf) { mParameterizedTraits->free(deformablePhaseDescs.buf); } if (tetherAnchors.isAllocated && tetherAnchors.buf) { mParameterizedTraits->free(tetherAnchors.buf); } if (tetherLengths.isAllocated && tetherLengths.buf) { mParameterizedTraits->free(tetherLengths.buf); } if (deformableInvVertexWeights.isAllocated && deformableInvVertexWeights.buf) { mParameterizedTraits->free(deformableInvVertexWeights.buf); } if (virtualParticleIndices.isAllocated && virtualParticleIndices.buf) { mParameterizedTraits->free(virtualParticleIndices.buf); } if (virtualParticleWeights.isAllocated && virtualParticleWeights.buf) { mParameterizedTraits->free(virtualParticleWeights.buf); } if (fabricGPU.isAllocated && fabricGPU.buf) { mParameterizedTraits->free(fabricGPU.buf); } } void ClothingCookedPhysX3Param::freeStrings(void) { } void ClothingCookedPhysX3Param::freeReferences(void) { if (nextCookedData) { nextCookedData->destroy(); } } } // namespace clothing } // namespace nvidia