Added support for loading Corruption particle dependencies
This commit is contained in:
parent
ac2430e61c
commit
98cd617b3e
|
@ -679,7 +679,7 @@
|
||||||
</AreaName>
|
</AreaName>
|
||||||
<AreaName>
|
<AreaName>
|
||||||
<Key>8ABEB3C3</Key>
|
<Key>8ABEB3C3</Key>
|
||||||
<Value>10_over1lavaarea</Value>
|
<Value>10_over_1alavaarea</Value>
|
||||||
</AreaName>
|
</AreaName>
|
||||||
<AreaName>
|
<AreaName>
|
||||||
<Key>901040DF</Key>
|
<Key>901040DF</Key>
|
||||||
|
|
|
@ -95,6 +95,7 @@ public:
|
||||||
case eTexture: pRes = CTextureDecoder::LoadTXTR(rInput, pEntry); break;
|
case eTexture: pRes = CTextureDecoder::LoadTXTR(rInput, pEntry); break;
|
||||||
case eWorld: pRes = CWorldLoader::LoadMLVL(rInput, pEntry); break;
|
case eWorld: pRes = CWorldLoader::LoadMLVL(rInput, pEntry); break;
|
||||||
|
|
||||||
|
case eBurstFireData:
|
||||||
case eParticle:
|
case eParticle:
|
||||||
case eParticleElectric:
|
case eParticleElectric:
|
||||||
case eParticleSorted:
|
case eParticleSorted:
|
||||||
|
@ -103,6 +104,7 @@ public:
|
||||||
case eParticleDecal:
|
case eParticleDecal:
|
||||||
case eParticleWeapon:
|
case eParticleWeapon:
|
||||||
case eParticleCollisionResponse:
|
case eParticleCollisionResponse:
|
||||||
|
case eUserEvaluatorData:
|
||||||
pRes = CUnsupportedParticleLoader::LoadParticle(rInput, pEntry);
|
pRes = CUnsupportedParticleLoader::LoadParticle(rInput, pEntry);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -14,6 +14,7 @@ bool CUnsupportedParticleLoader::ParseParticleParameter(IInputStream& rPART)
|
||||||
// Bool
|
// Bool
|
||||||
case FOURCC('AAPH'):
|
case FOURCC('AAPH'):
|
||||||
case FOURCC('CIND'):
|
case FOURCC('CIND'):
|
||||||
|
case FOURCC('DBPS'):
|
||||||
case FOURCC('FXLL'):
|
case FOURCC('FXLL'):
|
||||||
case FOURCC('INDM'):
|
case FOURCC('INDM'):
|
||||||
case FOURCC('LINE'):
|
case FOURCC('LINE'):
|
||||||
|
@ -21,12 +22,20 @@ bool CUnsupportedParticleLoader::ParseParticleParameter(IInputStream& rPART)
|
||||||
case FOURCC('MBLR'):
|
case FOURCC('MBLR'):
|
||||||
case FOURCC('OPTS'):
|
case FOURCC('OPTS'):
|
||||||
case FOURCC('ORNT'):
|
case FOURCC('ORNT'):
|
||||||
|
case FOURCC('ORTC'):
|
||||||
case FOURCC('PMAB'):
|
case FOURCC('PMAB'):
|
||||||
|
case FOURCC('PMLT'):
|
||||||
case FOURCC('PMOO'):
|
case FOURCC('PMOO'):
|
||||||
|
case FOURCC('PMTF'):
|
||||||
case FOURCC('PMUS'):
|
case FOURCC('PMUS'):
|
||||||
case FOURCC('RDOP'):
|
case FOURCC('RDOP'):
|
||||||
case FOURCC('RSOP'):
|
case FOURCC('RSOP'):
|
||||||
case FOURCC('SORT'):
|
case FOURCC('SORT'):
|
||||||
|
case FOURCC('STOP'):
|
||||||
|
case FOURCC('VGD1'):
|
||||||
|
case FOURCC('VGD2'):
|
||||||
|
case FOURCC('VGD3'):
|
||||||
|
case FOURCC('VGD4'):
|
||||||
case FOURCC('VMD1'):
|
case FOURCC('VMD1'):
|
||||||
case FOURCC('VMD2'):
|
case FOURCC('VMD2'):
|
||||||
case FOURCC('VMD3'):
|
case FOURCC('VMD3'):
|
||||||
|
@ -42,22 +51,28 @@ bool CUnsupportedParticleLoader::ParseParticleParameter(IInputStream& rPART)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
// Int
|
// Int
|
||||||
|
case FOURCC('ALSC'):
|
||||||
|
case FOURCC('AMSC'):
|
||||||
case FOURCC('CSSD'):
|
case FOURCC('CSSD'):
|
||||||
|
case FOURCC('HJAK'):
|
||||||
case FOURCC('LFOT'):
|
case FOURCC('LFOT'):
|
||||||
case FOURCC('LTME'):
|
case FOURCC('LTME'):
|
||||||
case FOURCC('LTYP'):
|
case FOURCC('LTYP'):
|
||||||
case FOURCC('MAXP'):
|
case FOURCC('MAXP'):
|
||||||
|
case FOURCC('MBDM'):
|
||||||
case FOURCC('MBSP'):
|
case FOURCC('MBSP'):
|
||||||
case FOURCC('NCSY'):
|
case FOURCC('NCSY'):
|
||||||
case FOURCC('NDSY'):
|
case FOURCC('NDSY'):
|
||||||
|
case FOURCC('PBDM'):
|
||||||
case FOURCC('PISY'):
|
case FOURCC('PISY'):
|
||||||
case FOURCC('PSIV'):
|
|
||||||
case FOURCC('PSLT'):
|
case FOURCC('PSLT'):
|
||||||
case FOURCC('PSWT'):
|
case FOURCC('PSWT'):
|
||||||
case FOURCC('SEED'):
|
case FOURCC('SEED'):
|
||||||
case FOURCC('SESD'):
|
case FOURCC('SESD'):
|
||||||
case FOURCC('SISY'):
|
case FOURCC('SISY'):
|
||||||
case FOURCC('SSSD'):
|
case FOURCC('SSSD'):
|
||||||
|
case FOURCC('VSPC'):
|
||||||
|
case FOURCC('XJAK'):
|
||||||
case FOURCC('XTAD'):
|
case FOURCC('XTAD'):
|
||||||
ParseIntFunction(rPART);
|
ParseIntFunction(rPART);
|
||||||
break;
|
break;
|
||||||
|
@ -72,8 +87,10 @@ bool CUnsupportedParticleLoader::ParseParticleParameter(IInputStream& rPART)
|
||||||
case FOURCC('ADV7'):
|
case FOURCC('ADV7'):
|
||||||
case FOURCC('ADV8'):
|
case FOURCC('ADV8'):
|
||||||
case FOURCC('ADV9'):
|
case FOURCC('ADV9'):
|
||||||
|
case FOURCC('EADV'):
|
||||||
case FOURCC('FXBR'):
|
case FOURCC('FXBR'):
|
||||||
case FOURCC('GRTE'):
|
case FOURCC('GRTE'):
|
||||||
|
case FOURCC('ISVF'):
|
||||||
case FOURCC('LENG'):
|
case FOURCC('LENG'):
|
||||||
case FOURCC('LFOR'):
|
case FOURCC('LFOR'):
|
||||||
case FOURCC('LINT'):
|
case FOURCC('LINT'):
|
||||||
|
@ -81,6 +98,7 @@ bool CUnsupportedParticleLoader::ParseParticleParameter(IInputStream& rPART)
|
||||||
case FOURCC('PSTS'):
|
case FOURCC('PSTS'):
|
||||||
case FOURCC('ROTA'):
|
case FOURCC('ROTA'):
|
||||||
case FOURCC('SIZE'):
|
case FOURCC('SIZE'):
|
||||||
|
case FOURCC('SVEO'):
|
||||||
case FOURCC('WIDT'):
|
case FOURCC('WIDT'):
|
||||||
ParseFloatFunction(rPART);
|
ParseFloatFunction(rPART);
|
||||||
break;
|
break;
|
||||||
|
@ -96,6 +114,7 @@ bool CUnsupportedParticleLoader::ParseParticleParameter(IInputStream& rPART)
|
||||||
case FOURCC('PMRT'):
|
case FOURCC('PMRT'):
|
||||||
case FOURCC('PMSC'):
|
case FOURCC('PMSC'):
|
||||||
case FOURCC('POFS'):
|
case FOURCC('POFS'):
|
||||||
|
case FOURCC('PSIV'):
|
||||||
case FOURCC('PSOV'):
|
case FOURCC('PSOV'):
|
||||||
case FOURCC('SEPO'):
|
case FOURCC('SEPO'):
|
||||||
case FOURCC('SSPO'):
|
case FOURCC('SSPO'):
|
||||||
|
@ -172,6 +191,7 @@ bool CUnsupportedParticleLoader::ParseElectricParameter(IInputStream& rELSC)
|
||||||
ParseBitfieldFunction(rELSC);
|
ParseBitfieldFunction(rELSC);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case FOURCC('BLDM'):
|
||||||
case FOURCC('LIFE'):
|
case FOURCC('LIFE'):
|
||||||
case FOURCC('SCNT'):
|
case FOURCC('SCNT'):
|
||||||
case FOURCC('SLIF'):
|
case FOURCC('SLIF'):
|
||||||
|
@ -324,9 +344,13 @@ bool CUnsupportedParticleLoader::ParseSwooshParameter(IInputStream& rSWHC)
|
||||||
ParseBitfieldFunction(rSWHC);
|
ParseBitfieldFunction(rSWHC);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case FOURCC('ALSC'):
|
||||||
case FOURCC('LENG'):
|
case FOURCC('LENG'):
|
||||||
case FOURCC('PSLT'):
|
case FOURCC('PSLT'):
|
||||||
|
case FOURCC('SBDM'):
|
||||||
case FOURCC('SIDE'):
|
case FOURCC('SIDE'):
|
||||||
|
case FOURCC('SPLN'):
|
||||||
|
case FOURCC('TSPN'):
|
||||||
ParseIntFunction(rSWHC);
|
ParseIntFunction(rSWHC);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -334,9 +358,10 @@ bool CUnsupportedParticleLoader::ParseSwooshParameter(IInputStream& rSWHC)
|
||||||
case FOURCC('LRAD'):
|
case FOURCC('LRAD'):
|
||||||
case FOURCC('ROTM'):
|
case FOURCC('ROTM'):
|
||||||
case FOURCC('RRAD'):
|
case FOURCC('RRAD'):
|
||||||
case FOURCC('SPLN'):
|
|
||||||
case FOURCC('TIME'):
|
case FOURCC('TIME'):
|
||||||
case FOURCC('TSPN'):
|
case FOURCC('XROT'):
|
||||||
|
case FOURCC('YROT'):
|
||||||
|
case FOURCC('ZROT'):
|
||||||
ParseFloatFunction(rSWHC);
|
ParseFloatFunction(rSWHC);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -442,6 +467,7 @@ bool CUnsupportedParticleLoader::ParseWeaponParameter(IInputStream& rWPSC)
|
||||||
case FOURCC('AS11'):
|
case FOURCC('AS11'):
|
||||||
case FOURCC('AS12'):
|
case FOURCC('AS12'):
|
||||||
case FOURCC('AS13'):
|
case FOURCC('AS13'):
|
||||||
|
case FOURCC('BEAM'):
|
||||||
case FOURCC('BHBT'):
|
case FOURCC('BHBT'):
|
||||||
case FOURCC('DP1C'):
|
case FOURCC('DP1C'):
|
||||||
case FOURCC('DP2C'):
|
case FOURCC('DP2C'):
|
||||||
|
@ -458,8 +484,10 @@ bool CUnsupportedParticleLoader::ParseWeaponParameter(IInputStream& rWPSC)
|
||||||
case FOURCC('RWPE'):
|
case FOURCC('RWPE'):
|
||||||
case FOURCC('SPS1'):
|
case FOURCC('SPS1'):
|
||||||
case FOURCC('SPS2'):
|
case FOURCC('SPS2'):
|
||||||
|
case FOURCC('SREL'):
|
||||||
case FOURCC('SVBD'):
|
case FOURCC('SVBD'):
|
||||||
case FOURCC('SWTR'):
|
case FOURCC('SWTR'):
|
||||||
|
case FOURCC('TCND'):
|
||||||
case FOURCC('VMD2'):
|
case FOURCC('VMD2'):
|
||||||
ParseBoolFunction(rWPSC);
|
ParseBoolFunction(rWPSC);
|
||||||
break;
|
break;
|
||||||
|
@ -472,6 +500,8 @@ bool CUnsupportedParticleLoader::ParseWeaponParameter(IInputStream& rWPSC)
|
||||||
case FOURCC('B1SE'):
|
case FOURCC('B1SE'):
|
||||||
case FOURCC('B2RT'):
|
case FOURCC('B2RT'):
|
||||||
case FOURCC('B2SE'):
|
case FOURCC('B2SE'):
|
||||||
|
case FOURCC('FADD'):
|
||||||
|
case FOURCC('FADS'):
|
||||||
case FOURCC('FOFF'):
|
case FOURCC('FOFF'):
|
||||||
case FOURCC('RNGE'):
|
case FOURCC('RNGE'):
|
||||||
case FOURCC('TLEN'):
|
case FOURCC('TLEN'):
|
||||||
|
@ -522,6 +552,7 @@ bool CUnsupportedParticleLoader::ParseWeaponParameter(IInputStream& rWPSC)
|
||||||
case FOURCC('ASW3'):
|
case FOURCC('ASW3'):
|
||||||
case FOURCC('COLR'):
|
case FOURCC('COLR'):
|
||||||
case FOURCC('OHEF'):
|
case FOURCC('OHEF'):
|
||||||
|
case FOURCC('PSFX'):
|
||||||
ParseAssetFunction(rWPSC);
|
ParseAssetFunction(rWPSC);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -609,17 +640,28 @@ bool CUnsupportedParticleLoader::ParseCollisionResponseParameter(IInputStream& r
|
||||||
case FOURCC('3LAV'):
|
case FOURCC('3LAV'):
|
||||||
case FOURCC('1MUD'):
|
case FOURCC('1MUD'):
|
||||||
case FOURCC('3MUD'):
|
case FOURCC('3MUD'):
|
||||||
|
case FOURCC('1PRJ'):
|
||||||
|
case FOURCC('3PRJ'):
|
||||||
case FOURCC('1SAN'):
|
case FOURCC('1SAN'):
|
||||||
case FOURCC('3SAN'):
|
case FOURCC('3SAN'):
|
||||||
|
case FOURCC('1WOD'):
|
||||||
|
case FOURCC('3WOD'):
|
||||||
case FOURCC('CHDL'):
|
case FOURCC('CHDL'):
|
||||||
case FOURCC('CODL'):
|
case FOURCC('CODL'):
|
||||||
case FOURCC('CRTS'):
|
case FOURCC('CRTS'):
|
||||||
|
case FOURCC('CSSD'):
|
||||||
case FOURCC('DCHR'):
|
case FOURCC('DCHR'):
|
||||||
|
case FOURCC('DCSD'):
|
||||||
case FOURCC('DDCL'):
|
case FOURCC('DDCL'):
|
||||||
case FOURCC('DEFS'):
|
case FOURCC('DEFS'):
|
||||||
case FOURCC('DENM'):
|
case FOURCC('DENM'):
|
||||||
|
case FOURCC('DESD'):
|
||||||
case FOURCC('DESH'):
|
case FOURCC('DESH'):
|
||||||
|
case FOURCC('DSND'):
|
||||||
|
case FOURCC('DSSD'):
|
||||||
case FOURCC('ENDL'):
|
case FOURCC('ENDL'):
|
||||||
|
case FOURCC('GLAS'):
|
||||||
|
case FOURCC('GLDL'):
|
||||||
case FOURCC('GODL'):
|
case FOURCC('GODL'):
|
||||||
case FOURCC('GOOO'):
|
case FOURCC('GOOO'):
|
||||||
case FOURCC('GRAS'):
|
case FOURCC('GRAS'):
|
||||||
|
@ -628,6 +670,12 @@ bool CUnsupportedParticleLoader::ParseCollisionResponseParameter(IInputStream& r
|
||||||
case FOURCC('ICEE'):
|
case FOURCC('ICEE'):
|
||||||
case FOURCC('MEDL'):
|
case FOURCC('MEDL'):
|
||||||
case FOURCC('MTLS'):
|
case FOURCC('MTLS'):
|
||||||
|
case FOURCC('P3SD'):
|
||||||
|
case FOURCC('PLAY'):
|
||||||
|
case FOURCC('PLSD'):
|
||||||
|
case FOURCC('PLY3'):
|
||||||
|
case FOURCC('SNDL'):
|
||||||
|
case FOURCC('SNEE'):
|
||||||
case FOURCC('TALP'):
|
case FOURCC('TALP'):
|
||||||
case FOURCC('WATR'):
|
case FOURCC('WATR'):
|
||||||
case FOURCC('WODL'):
|
case FOURCC('WODL'):
|
||||||
|
@ -645,6 +693,111 @@ bool CUnsupportedParticleLoader::ParseCollisionResponseParameter(IInputStream& r
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool CUnsupportedParticleLoader::ParseBurstFireParameter(IInputStream& rBFRC)
|
||||||
|
{
|
||||||
|
u32 ParamOffset = rBFRC.Tell();
|
||||||
|
CFourCC Param = rBFRC.ReadLong();
|
||||||
|
if (Param == FOURCC('_END')) return false;
|
||||||
|
|
||||||
|
switch (Param.ToLong())
|
||||||
|
{
|
||||||
|
case FOURCC('BTMI'):
|
||||||
|
ParseIntFunction(rBFRC);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FOURCC('B0CH'):
|
||||||
|
case FOURCC('B1CH'):
|
||||||
|
case FOURCC('B2CH'):
|
||||||
|
case FOURCC('B3CH'):
|
||||||
|
case FOURCC('B4CH'):
|
||||||
|
case FOURCC('B5CH'):
|
||||||
|
case FOURCC('B6CH'):
|
||||||
|
case FOURCC('B7CH'):
|
||||||
|
case FOURCC('B0VL'):
|
||||||
|
case FOURCC('B1VL'):
|
||||||
|
case FOURCC('B2VL'):
|
||||||
|
case FOURCC('B3VL'):
|
||||||
|
case FOURCC('B4VL'):
|
||||||
|
case FOURCC('B5VL'):
|
||||||
|
case FOURCC('B6VL'):
|
||||||
|
case FOURCC('B7VL'):
|
||||||
|
case FOURCC('OVLH'):
|
||||||
|
case FOURCC('OVLW'):
|
||||||
|
case FOURCC('SHVR'):
|
||||||
|
ParseFloatFunction(rBFRC);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
Log::FileError(rBFRC.GetSourceString(), ParamOffset, "Unknown BFRC parameter: " + Param.ToString());
|
||||||
|
DEBUG_BREAK;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool CUnsupportedParticleLoader::ParseUserEvaluatorParameter(IInputStream& rUSRC)
|
||||||
|
{
|
||||||
|
u32 ParamOffset = rUSRC.Tell();
|
||||||
|
CFourCC Param = rUSRC.ReadLong();
|
||||||
|
if (Param == FOURCC('_END')) return false;
|
||||||
|
|
||||||
|
switch (Param.ToLong())
|
||||||
|
{
|
||||||
|
case FOURCC('IPM0'):
|
||||||
|
case FOURCC('IPM1'):
|
||||||
|
case FOURCC('IPM2'):
|
||||||
|
case FOURCC('IPM3'):
|
||||||
|
case FOURCC('IPM4'):
|
||||||
|
ParseIntFunction(rUSRC);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FOURCC('RPM0'):
|
||||||
|
case FOURCC('RPM1'):
|
||||||
|
case FOURCC('RPM2'):
|
||||||
|
case FOURCC('RPM3'):
|
||||||
|
case FOURCC('RPM4'):
|
||||||
|
case FOURCC('RPM5'):
|
||||||
|
case FOURCC('RPM6'):
|
||||||
|
case FOURCC('RPM7'):
|
||||||
|
case FOURCC('RPM8'):
|
||||||
|
case FOURCC('RPM9'):
|
||||||
|
ParseFloatFunction(rUSRC);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FOURCC('VEC0'):
|
||||||
|
case FOURCC('VEC1'):
|
||||||
|
case FOURCC('VEC2'):
|
||||||
|
ParseVectorFunction(rUSRC);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FOURCC('MVC0'):
|
||||||
|
case FOURCC('MVC1'):
|
||||||
|
ParseModVectorFunction(rUSRC);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FOURCC('CLR1'):
|
||||||
|
ParseColorFunction(rUSRC);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FOURCC('TEX0'):
|
||||||
|
case FOURCC('TEX1'):
|
||||||
|
ParseUVFunction(rUSRC);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case FOURCC('EMT1'):
|
||||||
|
ParseEmitterFunction(rUSRC);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
Log::FileError(rUSRC.GetSourceString(), ParamOffset, "Unknown USRC parameter: " + Param.ToString());
|
||||||
|
DEBUG_BREAK;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
// ************ FUNCTION LOADING ************
|
// ************ FUNCTION LOADING ************
|
||||||
void CUnsupportedParticleLoader::ParseBoolFunction(IInputStream& rFile)
|
void CUnsupportedParticleLoader::ParseBoolFunction(IInputStream& rFile)
|
||||||
{
|
{
|
||||||
|
@ -769,6 +922,7 @@ void CUnsupportedParticleLoader::ParseFloatFunction(IInputStream& rFile)
|
||||||
case FOURCC('PAP7'):
|
case FOURCC('PAP7'):
|
||||||
case FOURCC('PAP8'):
|
case FOURCC('PAP8'):
|
||||||
case FOURCC('PAP9'):
|
case FOURCC('PAP9'):
|
||||||
|
case FOURCC('PEA0'):
|
||||||
case FOURCC('PRLW'):
|
case FOURCC('PRLW'):
|
||||||
case FOURCC('PSLL'):
|
case FOURCC('PSLL'):
|
||||||
break;
|
break;
|
||||||
|
@ -805,6 +959,11 @@ void CUnsupportedParticleLoader::ParseFloatFunction(IInputStream& rFile)
|
||||||
ParseIntFunction(rFile);
|
ParseIntFunction(rFile);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case FOURCC('MULV'):
|
||||||
|
ParseFloatFunction(rFile);
|
||||||
|
ParseIntFunction(rFile);
|
||||||
|
break;
|
||||||
|
|
||||||
case FOURCC('CHAN'):
|
case FOURCC('CHAN'):
|
||||||
ParseFloatFunction(rFile);
|
ParseFloatFunction(rFile);
|
||||||
ParseFloatFunction(rFile);
|
ParseFloatFunction(rFile);
|
||||||
|
@ -1073,6 +1232,7 @@ void CUnsupportedParticleLoader::ParseModVectorFunction(IInputStream& rFile)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FOURCC('EXPL'):
|
case FOURCC('EXPL'):
|
||||||
|
case FOURCC('SWLC'):
|
||||||
ParseFloatFunction(rFile);
|
ParseFloatFunction(rFile);
|
||||||
ParseFloatFunction(rFile);
|
ParseFloatFunction(rFile);
|
||||||
break;
|
break;
|
||||||
|
@ -1085,8 +1245,8 @@ void CUnsupportedParticleLoader::ParseModVectorFunction(IInputStream& rFile)
|
||||||
case FOURCC('PULS'):
|
case FOURCC('PULS'):
|
||||||
ParseIntFunction(rFile);
|
ParseIntFunction(rFile);
|
||||||
ParseIntFunction(rFile);
|
ParseIntFunction(rFile);
|
||||||
ParseFloatFunction(rFile);
|
ParseModVectorFunction(rFile);
|
||||||
ParseFloatFunction(rFile);
|
ParseModVectorFunction(rFile);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FOURCC('SPHV'):
|
case FOURCC('SPHV'):
|
||||||
|
@ -1147,6 +1307,7 @@ void CUnsupportedParticleLoader::ParseColorFunction(IInputStream& rFile)
|
||||||
ParseFloatFunction(rFile);
|
ParseFloatFunction(rFile);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case FOURCC('CFDL'):
|
||||||
case FOURCC('ISWT'):
|
case FOURCC('ISWT'):
|
||||||
case FOURCC('MULT'):
|
case FOURCC('MULT'):
|
||||||
ParseColorFunction(rFile);
|
ParseColorFunction(rFile);
|
||||||
|
@ -1215,6 +1376,13 @@ void CUnsupportedParticleLoader::ParseUVFunction(IInputStream& rFile)
|
||||||
ParseBoolFunction(rFile);
|
ParseBoolFunction(rFile);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case FOURCC('TEXP'):
|
||||||
|
ParseAssetFunction(rFile);
|
||||||
|
ParseIntFunction(rFile);
|
||||||
|
ParseIntFunction(rFile);
|
||||||
|
ParseFloatFunction(rFile);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
Log::FileError(rFile.GetSourceString(), FuncOffset, "Unknown UV function: " + Func.ToString());
|
Log::FileError(rFile.GetSourceString(), FuncOffset, "Unknown UV function: " + Func.ToString());
|
||||||
DEBUG_BREAK;
|
DEBUG_BREAK;
|
||||||
|
@ -1370,17 +1538,6 @@ void CUnsupportedParticleLoader::ParseKeyframeEmitterData(IInputStream& rFile, c
|
||||||
}
|
}
|
||||||
|
|
||||||
// ************ STATIC ************
|
// ************ STATIC ************
|
||||||
enum {
|
|
||||||
kGPSM = FOURCC('GPSM'),
|
|
||||||
kELSM = FOURCC('ELSM'),
|
|
||||||
kSRSM = FOURCC('SRSM'),
|
|
||||||
kSPSM = FOURCC('SPSM'),
|
|
||||||
kSWSH = FOURCC('SWSH'),
|
|
||||||
kDPSM = FOURCC('DPSM'),
|
|
||||||
kWPSM = FOURCC('WPSM'),
|
|
||||||
kCRSM = FOURCC('CRSM')
|
|
||||||
};
|
|
||||||
|
|
||||||
CDependencyGroup* CUnsupportedParticleLoader::LoadParticle(IInputStream& rFile, CResourceEntry *pEntry)
|
CDependencyGroup* CUnsupportedParticleLoader::LoadParticle(IInputStream& rFile, CResourceEntry *pEntry)
|
||||||
{
|
{
|
||||||
CFourCC Magic = rFile.ReadLong();
|
CFourCC Magic = rFile.ReadLong();
|
||||||
|
@ -1389,7 +1546,7 @@ CDependencyGroup* CUnsupportedParticleLoader::LoadParticle(IInputStream& rFile,
|
||||||
CUnsupportedParticleLoader Loader;
|
CUnsupportedParticleLoader Loader;
|
||||||
Loader.mpGroup = new CDependencyGroup(pEntry);
|
Loader.mpGroup = new CDependencyGroup(pEntry);
|
||||||
|
|
||||||
if (pEntry->Game() >= eCorruptionProto)
|
if (pEntry->Game() >= eReturns)
|
||||||
return Loader.mpGroup;
|
return Loader.mpGroup;
|
||||||
|
|
||||||
while (true)
|
while (true)
|
||||||
|
@ -1406,9 +1563,12 @@ CDependencyGroup* CUnsupportedParticleLoader::LoadParticle(IInputStream& rFile,
|
||||||
case FOURCC('DPSM'): ShouldContinue = Loader.ParseDecalParameter(rFile); break;
|
case FOURCC('DPSM'): ShouldContinue = Loader.ParseDecalParameter(rFile); break;
|
||||||
case FOURCC('WPSM'): ShouldContinue = Loader.ParseWeaponParameter(rFile); break;
|
case FOURCC('WPSM'): ShouldContinue = Loader.ParseWeaponParameter(rFile); break;
|
||||||
case FOURCC('CRSM'): ShouldContinue = Loader.ParseCollisionResponseParameter(rFile); break;
|
case FOURCC('CRSM'): ShouldContinue = Loader.ParseCollisionResponseParameter(rFile); break;
|
||||||
|
case FOURCC('BFRE'): ShouldContinue = Loader.ParseBurstFireParameter(rFile); break;
|
||||||
|
case FOURCC('USER'): ShouldContinue = Loader.ParseUserEvaluatorParameter(rFile); break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
Log::Error("Unrecognized particle system magic: " + Magic.ToString());
|
Log::Error("Unrecognized particle system magic: " + Magic.ToString());
|
||||||
|
ShouldContinue = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,8 @@ class CUnsupportedParticleLoader
|
||||||
bool ParseDecalParameter(IInputStream& rDPSC);
|
bool ParseDecalParameter(IInputStream& rDPSC);
|
||||||
bool ParseWeaponParameter(IInputStream& rWPSC);
|
bool ParseWeaponParameter(IInputStream& rWPSC);
|
||||||
bool ParseCollisionResponseParameter(IInputStream& rCRSC);
|
bool ParseCollisionResponseParameter(IInputStream& rCRSC);
|
||||||
|
bool ParseBurstFireParameter(IInputStream& rBFRC);
|
||||||
|
bool ParseUserEvaluatorParameter(IInputStream& rUSRC);
|
||||||
|
|
||||||
// Function Loading
|
// Function Loading
|
||||||
void ParseBoolFunction(IInputStream& rFile);
|
void ParseBoolFunction(IInputStream& rFile);
|
||||||
|
|
|
@ -555,14 +555,11 @@ void CWorldEditor::OnActiveProjectChanged(CGameProject *pProj)
|
||||||
AllowBloom ? SetFakeBloom() : SetNoBloom();
|
AllowBloom ? SetFakeBloom() : SetNoBloom();
|
||||||
ui->menuBloom->setEnabled(AllowBloom);
|
ui->menuBloom->setEnabled(AllowBloom);
|
||||||
|
|
||||||
if (!pProj)
|
// Update recent projects list
|
||||||
{
|
UpdateOpenRecentActions();
|
||||||
// Update recent projects list
|
|
||||||
UpdateOpenRecentActions();
|
|
||||||
|
|
||||||
// Reset editor mode
|
// Reset editor mode
|
||||||
ChangeEditMode(eWEM_EditWorldInfo);
|
ChangeEditMode(eWEM_EditWorldInfo);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CWorldEditor::OnLinksModified(const QList<CScriptObject*>& rkInstances)
|
void CWorldEditor::OnLinksModified(const QList<CScriptObject*>& rkInstances)
|
||||||
|
|
|
@ -3,8 +3,8 @@
|
||||||
<name>LUAScript</name>
|
<name>LUAScript</name>
|
||||||
<properties>
|
<properties>
|
||||||
<struct ID="0x255A4580" template="Structs/EditorProperties.xml"/>
|
<struct ID="0x255A4580" template="Structs/EditorProperties.xml"/>
|
||||||
<property ID="0x2BF9AE74" type="asset" extensions="UNKN"/>
|
<property ID="0x2BF9AE74" type="asset" extensions="MLVL"/>
|
||||||
<property ID="0x567A48F4" type="asset" extensions="UNKN"/>
|
<property ID="0x567A48F4" type="asset" extensions="MLVL"/>
|
||||||
<property ID="0xED4A2787" type="string"/>
|
<property ID="0xED4A2787" type="string"/>
|
||||||
<property ID="0x9FACEA01" type="string"/>
|
<property ID="0x9FACEA01" type="string"/>
|
||||||
<property ID="0xEA46B664" type="string"/>
|
<property ID="0xEA46B664" type="string"/>
|
||||||
|
|
Loading…
Reference in New Issue