#include "EmberPch.h" #include "VariationList.h" #include "Variations01.h" #include "Variations02.h" #include "Variations03.h" #include "Variations04.h" #include "Variations05.h" #include "Variations06.h" #include "Variations07.h" #include "VariationsDC.h" namespace EmberNs { #define ADDPREPOSTREGVAR(varName) \ m_Variations.push_back(new varName##Variation()); \ m_Variations.push_back(new Pre##varName##Variation()); \ m_Variations.push_back(new Post##varName##Variation()); /// /// Constructor which initializes all of the variation objects and stores them in the list. /// template VariationList::VariationList() { m_Variations.reserve(size_t(eVariationId::LAST_VAR)); ADDPREPOSTREGVAR(Linear) ADDPREPOSTREGVAR(Sinusoidal) ADDPREPOSTREGVAR(Spherical) ADDPREPOSTREGVAR(Swirl) ADDPREPOSTREGVAR(Horseshoe) ADDPREPOSTREGVAR(Polar) ADDPREPOSTREGVAR(Handkerchief) ADDPREPOSTREGVAR(Heart) ADDPREPOSTREGVAR(Disc) ADDPREPOSTREGVAR(Spiral) ADDPREPOSTREGVAR(Hyperbolic) ADDPREPOSTREGVAR(Diamond) ADDPREPOSTREGVAR(Ex) ADDPREPOSTREGVAR(Julia) ADDPREPOSTREGVAR(Bent) ADDPREPOSTREGVAR(Waves) ADDPREPOSTREGVAR(Fisheye) ADDPREPOSTREGVAR(Popcorn) ADDPREPOSTREGVAR(Exponential) ADDPREPOSTREGVAR(Power) ADDPREPOSTREGVAR(Cosine) ADDPREPOSTREGVAR(Rings) ADDPREPOSTREGVAR(Fan) ADDPREPOSTREGVAR(Blob) ADDPREPOSTREGVAR(Pdj) ADDPREPOSTREGVAR(Fan2) ADDPREPOSTREGVAR(Rings2) ADDPREPOSTREGVAR(Eyefish) ADDPREPOSTREGVAR(Bubble) ADDPREPOSTREGVAR(Cylinder) ADDPREPOSTREGVAR(Perspective) ADDPREPOSTREGVAR(Noise) ADDPREPOSTREGVAR(JuliaNGeneric) ADDPREPOSTREGVAR(JuliaScope) ADDPREPOSTREGVAR(Blur) ADDPREPOSTREGVAR(GaussianBlur) ADDPREPOSTREGVAR(RadialBlur) ADDPREPOSTREGVAR(Pie) ADDPREPOSTREGVAR(Ngon) ADDPREPOSTREGVAR(Curl) ADDPREPOSTREGVAR(Rectangles) ADDPREPOSTREGVAR(Arch) ADDPREPOSTREGVAR(Tangent) ADDPREPOSTREGVAR(Square) ADDPREPOSTREGVAR(Rays) ADDPREPOSTREGVAR(Blade) ADDPREPOSTREGVAR(Secant2) ADDPREPOSTREGVAR(TwinTrian) ADDPREPOSTREGVAR(Cross) ADDPREPOSTREGVAR(Disc2) ADDPREPOSTREGVAR(SuperShape) ADDPREPOSTREGVAR(Flower) ADDPREPOSTREGVAR(Conic) ADDPREPOSTREGVAR(Parabola) ADDPREPOSTREGVAR(Bent2) ADDPREPOSTREGVAR(Bipolar) ADDPREPOSTREGVAR(Boarders) ADDPREPOSTREGVAR(Butterfly) ADDPREPOSTREGVAR(Cell) ADDPREPOSTREGVAR(Cpow) ADDPREPOSTREGVAR(Curve) ADDPREPOSTREGVAR(Edisc) ADDPREPOSTREGVAR(Elliptic) ADDPREPOSTREGVAR(Escher) ADDPREPOSTREGVAR(Foci) ADDPREPOSTREGVAR(LazySusan) ADDPREPOSTREGVAR(Loonie) ADDPREPOSTREGVAR(Modulus) ADDPREPOSTREGVAR(Oscilloscope) ADDPREPOSTREGVAR(Polar2) ADDPREPOSTREGVAR(Popcorn2) ADDPREPOSTREGVAR(Scry) ADDPREPOSTREGVAR(Separation) ADDPREPOSTREGVAR(Split) ADDPREPOSTREGVAR(Splits) ADDPREPOSTREGVAR(Stripes) ADDPREPOSTREGVAR(Wedge) ADDPREPOSTREGVAR(WedgeJulia) ADDPREPOSTREGVAR(WedgeSph) ADDPREPOSTREGVAR(Whorl) ADDPREPOSTREGVAR(Waves2) ADDPREPOSTREGVAR(Exp) ADDPREPOSTREGVAR(Log) ADDPREPOSTREGVAR(Sin) ADDPREPOSTREGVAR(Cos) ADDPREPOSTREGVAR(Tan) ADDPREPOSTREGVAR(Sec) ADDPREPOSTREGVAR(Csc) ADDPREPOSTREGVAR(Cot) ADDPREPOSTREGVAR(Sinh) ADDPREPOSTREGVAR(Cosh) ADDPREPOSTREGVAR(Tanh) ADDPREPOSTREGVAR(Sech) ADDPREPOSTREGVAR(Csch) ADDPREPOSTREGVAR(Coth) ADDPREPOSTREGVAR(Auger) ADDPREPOSTREGVAR(Flux) ADDPREPOSTREGVAR(Hemisphere) ADDPREPOSTREGVAR(Epispiral) ADDPREPOSTREGVAR(Bwraps) ADDPREPOSTREGVAR(BlurCircle) ADDPREPOSTREGVAR(BlurZoom) ADDPREPOSTREGVAR(BlurPixelize) ADDPREPOSTREGVAR(Crop) ADDPREPOSTREGVAR(BCircle) ADDPREPOSTREGVAR(BlurLinear) ADDPREPOSTREGVAR(BlurSquare) ADDPREPOSTREGVAR(Boarders2) ADDPREPOSTREGVAR(Cardioid) ADDPREPOSTREGVAR(Checks) ADDPREPOSTREGVAR(Circlize) ADDPREPOSTREGVAR(Circlize2) ADDPREPOSTREGVAR(CosWrap) ADDPREPOSTREGVAR(DeltaA) ADDPREPOSTREGVAR(Expo) ADDPREPOSTREGVAR(Extrude) ADDPREPOSTREGVAR(FDisc) ADDPREPOSTREGVAR(Fibonacci) ADDPREPOSTREGVAR(Fibonacci2) ADDPREPOSTREGVAR(Glynnia) ADDPREPOSTREGVAR(GridOut) ADDPREPOSTREGVAR(Hole) ADDPREPOSTREGVAR(Hypertile) ADDPREPOSTREGVAR(Hypertile1) ADDPREPOSTREGVAR(Hypertile2) ADDPREPOSTREGVAR(Hypertile3D) ADDPREPOSTREGVAR(Hypertile3D1) ADDPREPOSTREGVAR(Hypertile3D2) ADDPREPOSTREGVAR(IDisc) ADDPREPOSTREGVAR(Julian2) ADDPREPOSTREGVAR(JuliaQ) ADDPREPOSTREGVAR(Murl) ADDPREPOSTREGVAR(Murl2) ADDPREPOSTREGVAR(NPolar) ADDPREPOSTREGVAR(Ortho) ADDPREPOSTREGVAR(Poincare) ADDPREPOSTREGVAR(Poincare3D) ADDPREPOSTREGVAR(Polynomial) ADDPREPOSTREGVAR(PSphere) ADDPREPOSTREGVAR(Rational3) ADDPREPOSTREGVAR(Ripple) ADDPREPOSTREGVAR(Sigmoid) ADDPREPOSTREGVAR(SinusGrid) ADDPREPOSTREGVAR(Stwin) ADDPREPOSTREGVAR(TwoFace) ADDPREPOSTREGVAR(Unpolar) ADDPREPOSTREGVAR(WavesN) ADDPREPOSTREGVAR(XHeart) ADDPREPOSTREGVAR(Barycentroid) ADDPREPOSTREGVAR(BiSplit) ADDPREPOSTREGVAR(Crescents) ADDPREPOSTREGVAR(Mask) ADDPREPOSTREGVAR(Cpow2) ADDPREPOSTREGVAR(Curl3D) ADDPREPOSTREGVAR(Disc3D) ADDPREPOSTREGVAR(Funnel) ADDPREPOSTREGVAR(Linear3D) ADDPREPOSTREGVAR(PowBlock) ADDPREPOSTREGVAR(Squirrel) ADDPREPOSTREGVAR(Ennepers) ADDPREPOSTREGVAR(SphericalN) ADDPREPOSTREGVAR(Kaleidoscope) ADDPREPOSTREGVAR(GlynnSim1) ADDPREPOSTREGVAR(GlynnSim2) ADDPREPOSTREGVAR(GlynnSim3) ADDPREPOSTREGVAR(Starblur) ADDPREPOSTREGVAR(Sineblur) ADDPREPOSTREGVAR(Circleblur) ADDPREPOSTREGVAR(CropN) ADDPREPOSTREGVAR(ShredRad) ADDPREPOSTREGVAR(Blob2) ADDPREPOSTREGVAR(Julia3D) ADDPREPOSTREGVAR(Julia3Dz) ADDPREPOSTREGVAR(LinearT) ADDPREPOSTREGVAR(LinearT3D) ADDPREPOSTREGVAR(Ovoid) ADDPREPOSTREGVAR(Ovoid3D) ADDPREPOSTREGVAR(Spirograph) ADDPREPOSTREGVAR(Petal) ADDPREPOSTREGVAR(RoundSpher) ADDPREPOSTREGVAR(RoundSpher3D) ADDPREPOSTREGVAR(SpiralWing) ADDPREPOSTREGVAR(Squarize) ADDPREPOSTREGVAR(Sschecks) ADDPREPOSTREGVAR(PhoenixJulia) ADDPREPOSTREGVAR(Mobius) ADDPREPOSTREGVAR(MobiusN) ADDPREPOSTREGVAR(MobiusStrip) ADDPREPOSTREGVAR(Lissajous) ADDPREPOSTREGVAR(Svf) ADDPREPOSTREGVAR(Target) ADDPREPOSTREGVAR(Taurus) ADDPREPOSTREGVAR(Collideoscope) ADDPREPOSTREGVAR(BMod) ADDPREPOSTREGVAR(BSwirl) ADDPREPOSTREGVAR(BTransform) ADDPREPOSTREGVAR(BCollide) ADDPREPOSTREGVAR(Eclipse) ADDPREPOSTREGVAR(FlipCircle) ADDPREPOSTREGVAR(FlipY) ADDPREPOSTREGVAR(ECollide) ADDPREPOSTREGVAR(EJulia) ADDPREPOSTREGVAR(EMod) ADDPREPOSTREGVAR(EMotion) ADDPREPOSTREGVAR(EPush) ADDPREPOSTREGVAR(ERotate) ADDPREPOSTREGVAR(EScale) ADDPREPOSTREGVAR(ESwirl) ADDPREPOSTREGVAR(LazyTravis) ADDPREPOSTREGVAR(Squish) ADDPREPOSTREGVAR(Circus) ADDPREPOSTREGVAR(Tancos) ADDPREPOSTREGVAR(Rippled) ADDPREPOSTREGVAR(RotateX) ADDPREPOSTREGVAR(RotateY) ADDPREPOSTREGVAR(RotateZ) ADDPREPOSTREGVAR(Flatten) ADDPREPOSTREGVAR(Zblur) ADDPREPOSTREGVAR(Blur3D) ADDPREPOSTREGVAR(ZScale) ADDPREPOSTREGVAR(ZTranslate) ADDPREPOSTREGVAR(ZCone) ADDPREPOSTREGVAR(MirrorX) ADDPREPOSTREGVAR(MirrorY) ADDPREPOSTREGVAR(MirrorZ) ADDPREPOSTREGVAR(Depth) ADDPREPOSTREGVAR(Spherical3D) ADDPREPOSTREGVAR(RBlur) ADDPREPOSTREGVAR(JuliaNab) ADDPREPOSTREGVAR(Sintrange) ADDPREPOSTREGVAR(Voron) ADDPREPOSTREGVAR(Waffle) ADDPREPOSTREGVAR(Square3D) ADDPREPOSTREGVAR(SuperShape3D) ADDPREPOSTREGVAR(Sphyp3D) ADDPREPOSTREGVAR(Circlecrop) ADDPREPOSTREGVAR(Julian3Dx) ADDPREPOSTREGVAR(Fourth) ADDPREPOSTREGVAR(Mobiq) ADDPREPOSTREGVAR(Spherivoid) ADDPREPOSTREGVAR(Farblur) ADDPREPOSTREGVAR(CurlSP) ADDPREPOSTREGVAR(Heat) ADDPREPOSTREGVAR(Interference2) ADDPREPOSTREGVAR(Sinq) ADDPREPOSTREGVAR(Sinhq) ADDPREPOSTREGVAR(Secq) ADDPREPOSTREGVAR(Sechq) ADDPREPOSTREGVAR(Tanq) ADDPREPOSTREGVAR(Tanhq) ADDPREPOSTREGVAR(Cosq) ADDPREPOSTREGVAR(Coshq) ADDPREPOSTREGVAR(Cotq) ADDPREPOSTREGVAR(Cothq) ADDPREPOSTREGVAR(Cscq) ADDPREPOSTREGVAR(Cschq) ADDPREPOSTREGVAR(Estiq) ADDPREPOSTREGVAR(Loq) ADDPREPOSTREGVAR(Curvature) ADDPREPOSTREGVAR(Qode) ADDPREPOSTREGVAR(BlurHeart) ADDPREPOSTREGVAR(Truchet) ADDPREPOSTREGVAR(Gdoffs) ADDPREPOSTREGVAR(Octagon) ADDPREPOSTREGVAR(Trade) ADDPREPOSTREGVAR(Juliac) ADDPREPOSTREGVAR(Blade3D) ADDPREPOSTREGVAR(Blob3D) ADDPREPOSTREGVAR(Blocky) ADDPREPOSTREGVAR(Bubble2) ADDPREPOSTREGVAR(CircleLinear) ADDPREPOSTREGVAR(CircleRand) ADDPREPOSTREGVAR(CircleTrans1) ADDPREPOSTREGVAR(Cubic3D) ADDPREPOSTREGVAR(CubicLattice3D) ADDPREPOSTREGVAR(Foci3D) ADDPREPOSTREGVAR(Ho) ADDPREPOSTREGVAR(Julia3Dq) ADDPREPOSTREGVAR(Line) ADDPREPOSTREGVAR(Loonie2) ADDPREPOSTREGVAR(Loonie3) ADDPREPOSTREGVAR(Loonie3D) ADDPREPOSTREGVAR(Mcarpet) ADDPREPOSTREGVAR(Waves23D) ADDPREPOSTREGVAR(Pie3D) ADDPREPOSTREGVAR(Popcorn23D) ADDPREPOSTREGVAR(Sinusoidal3D) ADDPREPOSTREGVAR(Scry3D) ADDPREPOSTREGVAR(Shredlin) ADDPREPOSTREGVAR(SplitBrdr) ADDPREPOSTREGVAR(Wdisc) ADDPREPOSTREGVAR(Falloff) ADDPREPOSTREGVAR(Falloff2) ADDPREPOSTREGVAR(Falloff3) ADDPREPOSTREGVAR(Xtrb) ADDPREPOSTREGVAR(Hexaplay3D) ADDPREPOSTREGVAR(Hexnix3D) ADDPREPOSTREGVAR(Hexcrop) ADDPREPOSTREGVAR(Hexes) ADDPREPOSTREGVAR(Nblur) ADDPREPOSTREGVAR(Octapol) ADDPREPOSTREGVAR(Crob) ADDPREPOSTREGVAR(BubbleT3D) ADDPREPOSTREGVAR(Synth) ADDPREPOSTREGVAR(Crackle) m_Variations.push_back(new PostSmartcropVariation());//Post only ADDPREPOSTREGVAR(Xerf) ADDPREPOSTREGVAR(Erf) ADDPREPOSTREGVAR(W) ADDPREPOSTREGVAR(X) ADDPREPOSTREGVAR(Y) ADDPREPOSTREGVAR(Z) ADDPREPOSTREGVAR(Splits3D) ADDPREPOSTREGVAR(Waves2B) ADDPREPOSTREGVAR(JacCn) ADDPREPOSTREGVAR(JacDn) ADDPREPOSTREGVAR(JacSn) ADDPREPOSTREGVAR(PressureWave) ADDPREPOSTREGVAR(Gamma) ADDPREPOSTREGVAR(PRose3D) ADDPREPOSTREGVAR(LogDB) //ADDPREPOSTREGVAR(LinearXZ) //ADDPREPOSTREGVAR(LinearYZ) //DC are special. ADDPREPOSTREGVAR(DCBubble) ADDPREPOSTREGVAR(DCCarpet) ADDPREPOSTREGVAR(DCCube) ADDPREPOSTREGVAR(DCCylinder) ADDPREPOSTREGVAR(DCGridOut) ADDPREPOSTREGVAR(DCLinear) ADDPREPOSTREGVAR(DCPerlin) ADDPREPOSTREGVAR(DCTriangle) ADDPREPOSTREGVAR(DCZTransl) for (auto var : m_Variations) const_cast*>(var)->Precalc();//Modify once here, then const after this. std::sort(m_Variations.begin(), m_Variations.end(), [&](const Variation* var1, const Variation* var2) { return var1->VariationId() < var2->VariationId(); }); m_RegVariations.reserve(m_Variations.size() / 3); m_PreVariations.reserve(m_Variations.size() / 3); m_PostVariations.reserve(m_Variations.size() / 3); m_ParametricVariations.reserve(size_t(m_Variations.size() * .90));//This is a rough guess at how many are parametric. m_NonParametricVariations.reserve(size_t(m_Variations.size() * 0.20));//This is a rough guess at how many are not parametric. These don't add to 1 just to allow extra padding. //Place pointers to variations in vectors specific to their type. //Many of the elements in m_ParametricVariations will be present in the reg, pre and post vectors. //Note that these are not new copies, rather just pointers to the original instances in m_Variations. for (auto var : m_Variations) { if (var->VarType() == eVariationType::VARTYPE_REG) m_RegVariations.push_back(var); else if (var->VarType() == eVariationType::VARTYPE_PRE) m_PreVariations.push_back(var); else if (var->VarType() == eVariationType::VARTYPE_POST) m_PostVariations.push_back(var); if (auto parVar = dynamic_cast*>(var)) { bool b = false; auto& params = parVar->ParamsVec(); //Some non-parametric variations are actually stored as ParametricVariation just to hold some precalcs. //So to populate parametric, check to see at least one parameter was not a precalc, if so, treat this as parametric. for (auto& param : params) { if (!param.IsPrecalc()) { m_ParametricVariations.push_back(parVar); b = true; break; } } if (!b) m_NonParametricVariations.push_back(var);//Only get here if all parameters were non-precalc, so treat this as non-parametric. } else m_NonParametricVariations.push_back(var); } } /// /// Delete each element of the list. /// template VariationList::~VariationList() { ClearVec(m_Variations);//No need to delete parametric because they point to the entries in original vector. } /// /// Get a pointer to the variation at the specified index. /// /// The index in the list to retrieve /// A pointer to the variation at the index if in range, else nullptr. template const Variation* VariationList::GetVariation(size_t index) const { return index < m_Variations.size() ? m_Variations[index] : nullptr; } /// /// Get a pointer to the variation of a specified type at the specified index. /// /// The index in the list to retrieve /// The type of variation to retrieve /// A pointer to the variation of the specified type at the index if in range, else nullptr. template const Variation* VariationList::GetVariation(size_t index, eVariationType varType) const { switch (varType) { case eVariationType::VARTYPE_REG: return index < m_RegVariations.size() ? m_RegVariations[index] : nullptr; break; case eVariationType::VARTYPE_PRE: return index < m_PreVariations.size() ? m_PreVariations[index] : nullptr; break; case eVariationType::VARTYPE_POST: return index < m_PostVariations.size() ? m_PostVariations[index] : nullptr; break; default: return nullptr; break; } } /// /// Get a pointer to a copy of the variation at the specified index. /// Optionally specify a weight to assign the new copy. /// /// The index in the list to make a copy of /// The weight to assign the new copy. Default: 1 /// A pointer to the variation at the index if in range, else nullptr. template Variation* VariationList::GetVariationCopy(size_t index, T weight) const { return MakeCopyWithWeight(GetVariation(index), weight); } template Variation* VariationList::GetVariationCopy(size_t index, eVariationType varType, T weight) const { return MakeCopyWithWeight(GetVariation(index, varType), weight); } /// /// Get a pointer to the variation with the specified ID. /// /// The ID to search for /// A pointer to the variation if found, else nullptr. template const Variation* VariationList::GetVariation(eVariationId id) const { for (auto var : m_Variations) if (var && id == var->VariationId()) return var; return nullptr; } /// /// Get a pointer to a copy of the variation with the specified ID. /// Optionally specify a weight to assign the new copy. /// /// The id of the variation in the list to make a copy of /// The weight to assign the new copy. Default: 1 /// A pointer to the variation with a matching ID, else nullptr. template Variation* VariationList::GetVariationCopy(eVariationId id, T weight) const { return MakeCopyWithWeight(GetVariation(id), weight); } /// /// Get a pointer to the variation with the specified name. /// /// The name to search for /// A pointer to the variation if found, else nullptr. template const Variation* VariationList::GetVariation(const string& name) const { return SearchVarName(m_Variations, name); } /// /// Get a pointer to a copy of the variation with the specified name. /// Optionally specify a weight to assign the new copy. /// /// The name of the variation in the list to make a copy of /// The weight to assign the new copy. Default: 1 /// A pointer to the variation with a matching name, else nullptr. template Variation* VariationList::GetVariationCopy(const string& name, T weight) const { return MakeCopyWithWeight(GetVariation(name), weight); } /// /// Get a parametric variation at the specified index. /// Note this is the index in the parametric variations list, not in the master list. /// /// The index in the parametric variations list to retrieve /// The parametric variation at the index specified if in range, else nullptr. template const ParametricVariation* VariationList::GetParametricVariation(size_t index) const { return index < m_ParametricVariations.size() ? m_ParametricVariations[index] : nullptr; } /// /// Get a parametric variation with the specified name. /// /// The name of the variation in the parametric variations list to retrieve /// The parametric variation with a matching name, else nullptr. template const ParametricVariation* VariationList::GetParametricVariation(const string& name) const { return SearchVarName(m_ParametricVariations, name); } /// /// Get a pointer to a copy of the parametric variation at the specified index. /// Optionally specify a weight to assign the new copy. /// /// The index in the list to make a copy of /// The weight to assign the new copy. Default: 1 /// A pointer to the parametric variation at the index if in range, else nullptr. template ParametricVariation* VariationList::GetParametricVariationCopy(eVariationId id, T weight) const { return dynamic_cast*>(MakeCopyWithWeight(GetVariation(id), weight)); } /// /// Get a pointer to the pre variation with the specified name. /// /// The name to search for /// A pointer to the pre variation if found, else nullptr. template const Variation* VariationList::GetPreVariation(const string& name) const { return SearchVarName(m_PreVariations, name); } /// /// Get a pointer to the post variation with the specified name. /// /// The name to search for /// A pointer to the post variation if found, else nullptr. template const Variation* VariationList::GetPostVariation(const string& name) const { return SearchVarName(m_PostVariations, name); } /// /// Get the index of the variation with the specified name. /// /// The name of the variation whose index is returned /// The index of the variation with the matching name, else -1 template int VariationList::GetVariationIndex(const string& name) const { for (size_t i = 0; i < m_Variations.size() && m_Variations[i]; i++) if (!_stricmp(name.c_str(), m_Variations[i]->Name().c_str())) return int(i); return -1; } /// /// Accessors. /// template size_t VariationList::Size() const { return m_Variations.size(); } template size_t VariationList::RegSize() const { return m_RegVariations.size(); } template size_t VariationList::PreSize() const { return m_PreVariations.size(); } template size_t VariationList::PostSize() const { return m_PostVariations.size(); } template size_t VariationList::ParametricSize() const { return m_ParametricVariations.size(); } template size_t VariationList::NonParametricSize() const { return m_NonParametricVariations.size(); } template const vector*>& VariationList::AllVars() const { return m_Variations; } template const vector*>& VariationList::RegVars() const { return m_RegVariations; } template const vector*>& VariationList::PreVars() const { return m_PreVariations; } template const vector*>& VariationList::PostVars() const { return m_PostVariations; } template const vector*>& VariationList::NonParametricVariations() const { return m_NonParametricVariations; } template const vector*>& VariationList::ParametricVariations() const { return m_ParametricVariations; } /// /// Make a dyncamically allocated copy of a variation and assign it a specified weight. /// Return a pointer to the new copy. /// /// The variation to copy /// The weight to assign it /// A pointer to the new variation copy if success, else nullptr. template Variation* VariationList::MakeCopyWithWeight(const Variation* var, T weight) const { if (var) { auto var2 = var->Copy(); var2->m_Weight = weight; return var2; } return nullptr; } /// /// Search the passed in container of variations for a name which matches the passed in name. /// Note that since the elements of vars is a nested template, they can be Variation* /// or anything which derives from that. /// /// The vector of variations to search /// The name to search for /// True if found, else false. template template