本文整理汇总了C++中TdfParser类的典型用法代码示例。如果您正苦于以下问题:C++ TdfParser类的具体用法?C++ TdfParser怎么用?C++ TdfParser使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了TdfParser类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: Parse
void ShaderDef::Parse(const TdfParser& tdf, bool needNormalMap)
{
string path = "map\\terrain\\";
int numStages = atoi(tdf.SGetValueDef("0", path + "NumTextureStages").c_str());
bool autoBumpMap = !!atoi(tdf.SGetValueDef("1", path + "AutoBumpmapStages").c_str());
bool autoSpecular = !!atoi(tdf.SGetValueDef("1", path + "AutoSpecularStages").c_str());
specularExponent = atof(tdf.SGetValueDef("8", path + "SpecularExponent").c_str());
LoadStages(numStages, "texstage", tdf, stages);
if (needNormalMap) {
// generate the bumpmap stages from the texture stages?
if (autoBumpMap)
{
for (uint a=0;a<stages.size();a++)
{
Stage& st = stages[a];
if (a && st.operation != Alpha && st.operation != Blend)
continue;
normalMapStages.push_back (Stage());
Stage& bmst = normalMapStages.back();
bmst.operation = st.operation;
bmst.sourceName = st.sourceName;
}
}
else {
// otherwise load them from the bmstage list
numStages = atoi(tdf.SGetValueDef("0", path + "NumBumpmapStages").c_str());
LoadStages(numStages, "bmstage", tdf, normalMapStages);
}
}
}
示例2: catch
CWeaponDefHandler::CWeaponDefHandler()
{
std::vector<std::string> tafiles = CFileHandler::FindFiles("weapons/", "*.tdf");
//std::cout << " getting files from weapons/*.tdf ... " << std::endl;
TdfParser tasunparser;
for(unsigned int i=0; i<tafiles.size(); i++)
{
try {
tasunparser.LoadFile(tafiles[i]);
}catch( TdfParser::parse_error const& e) {
std::cout << "Exception:" << e.what() << std::endl;
} catch(...) {
std::cout << "Unknown exception in parse process of " << tafiles[i] <<" caught." << std::endl;
}
}
std::vector<std::string> weaponlist = tasunparser.GetSectionList("");
weaponDefs = SAFE_NEW WeaponDef[weaponlist.size()+1];
for(std::size_t taid=0; taid<weaponlist.size(); taid++)
{
ParseTAWeapon(&tasunparser, weaponlist[taid], taid);
}
}
示例3: TdfParser
void CSyncer::ParseUnit(const string& fileName)
{
TdfParser *p = new TdfParser();
p->LoadFile(fileName);
delete p;
}
示例4: OpenTDF
void CReadMap::OpenTDF (const std::string& mapname, TdfParser& parser)
{
string extension = mapname.substr(mapname.length()-3);
if (extension == "smf")
parser.LoadFile (string("maps/")+mapname.substr(0,mapname.find_last_of('.'))+".smd");
else if(extension == "sm3")
parser.LoadFile (string("maps/")+mapname);
}
示例5: transform
int CSyncer::ProcessUnits(bool checksum)
{
if (!populated) {
//Populate the list of unit files to consider
files = CFileHandler::FindFiles("units/*.fbi");
populated = true;
}
if (files.size() == 0) {
return 0;
}
string curFile = files.back();
files.pop_back();
size_t len = curFile.find_last_of("/")+1;
string unitName = curFile.substr(len, curFile.size() - 4 - len);
transform(unitName.begin(), unitName.end(), unitName.begin(), (int (*)(int))tolower);
string perror("");
TdfParser *parser = new TdfParser();
try {
parser->LoadFile("units/" + unitName + ".fbi");
} catch (TdfParser::parse_error& pe) {
perror = unitName + " (" + string(pe.what()) + ")";
}
Unit u;
if (checksum) {
u.fbi = CalculateCRC("units/" + unitName + ".fbi");
u.cob = CalculateCRC("scripts/" + unitName + ".cob");
//The model filenames has to be figured out from the fbi file
string modelName = parser->SGetValueDef(unitName, "unitinfo\\Objectname");
string deadName = parser->SGetValueDef(unitName + "_dead", "unitinfo\\Corpse");
u.model = CalculateCRC("objects3d/" + modelName + ".3do");
u.model += CalculateCRC("objects3d/" + deadName + ".3do");
}
u.fullName = parser->SGetValueDef("unknown", "unitinfo\\Name");
if (perror.length() > 0)
u.fullName = perror;
units[unitName] = u;
delete parser;
//If we are done, map id numbers to names
if (files.size() == 0) {
MapUnitIds();
}
return (int)files.size();
}
示例6: time
void Log::Open(){
//char buffer[1000];
if( Lmagic != 95768){
Lmagic = 95768;
First = true;
}
time_t now1;
time(&now1);
struct tm *now2;
now2 = localtime(&now1);
std::string filename = G->info->datapath + slash + "Logs" + slash;
// DDD MMM DD HH:MM:SS YYYY_X - NTAI.log
filename += to_string(now2->tm_mon+1)+"-" +to_string(now2->tm_mday) + "-" +to_string(now2->tm_year + 1900) +"-" +to_string(now2->tm_hour) +"_" +to_string(now2->tm_min) +"["+to_string(G->Cached->team)+"]XE10.1.log";
logFile.open(filename.c_str());
if(logFile.is_open() == false){
logFile.close();
logFile.open(filename.c_str());
if(logFile.is_open() == false){
iprint(std::string("Error!!! ") + filename + std::string(" refused to open!"));
verbose = true;
return;
}
}
header(" :: NTAI XE10.1 Log File \n :: Programmed and maintained by AF/T.Nowell \n :: Copyright (C) 2004 Tom Nowell/AF \n");
logFile << " :: Game started: " << now2->tm_mday << "." << now2->tm_mon << "." << 1900 + now2->tm_year << " " << now2->tm_hour << ":" << now2->tm_min << ":" << now2->tm_sec << std::endl << std::endl << std::flush;
int size = G->cb->GetFileSize("modinfo.tdf");
char* c = new char[size];
if(size > 0){
G->cb->ReadFile(filename.c_str(),c,size);
TdfParser cp;
cp.LoadBuffer(c,(std::size_t)size);
std::string tempstr = "";
cp.SGetValue(tempstr, "MOD\\Name");
logFile << " :: " << tempstr << std::endl << std::flush;
tempstr = "";
cp.SGetValue(tempstr, "MOD\\Description");
logFile << " :: " << tempstr << std::endl << std::flush;
}
if(First == true) logFile << " :: First instance of NTAI" << std::endl;
logFile << std::endl << std::flush;
}
示例7: LoadAllyTeams
void CGameSetup::LoadAllyTeams(const TdfParser& file)
{
// i = allyteam index in game (no gaps), a = allyteam index in script
int i = 0;
for (int a = 0; a < MAX_TEAMS; ++a) {
char section[50];
sprintf(section,"GAME\\ALLYTEAM%i",a);
string s(section);
if (!file.SectionExist(s))
continue;
AllyTeam data;
std::map<std::string, std::string> setup = file.GetAllValues(s);
for (std::map<std::string, std::string>::const_iterator it = setup.begin(); it != setup.end(); ++it)
data.SetValue(it->first, it->second);
allyStartingData.push_back(data);
allyteamRemap[a] = i;
++i;
}
{
const size_t numAllyTeams = allyStartingData.size();
for (size_t a = 0; a < numAllyTeams; ++a) {
allyStartingData[a].allies.resize(numAllyTeams, false);
allyStartingData[a].allies[a] = true; // each team is allied with itself
std::ostringstream section;
section << "GAME\\ALLYTEAM" << a << "\\";
const size_t numAllies = atoi(file.SGetValueDef("0", section.str() + "NumAllies").c_str());
for (size_t b = 0; b < numAllies; ++b) {
std::ostringstream key;
key << "GAME\\ALLYTEAM" << a << "\\Ally" << b;
const int other = atoi(file.SGetValueDef("0",key.str()).c_str());
allyStartingData[a].allies[allyteamRemap[other]] = true;
}
}
}
unsigned allyCount = 0;
if (file.GetValue(allyCount, "GAME\\NumAllyTeams") && (allyStartingData.size() != allyCount)) {
LOG_L(L_WARNING, "Incorrect number of ally teams in GameSetup script");
}
}
示例8: LoadUnitRestrictions
void CGameSetup::LoadUnitRestrictions(const TdfParser& file)
{
int numRestrictions;
file.GetDef(numRestrictions, "0", "GAME\\NumRestrictions");
for (int i = 0; i < numRestrictions; ++i) {
char key[100];
sprintf(key, "GAME\\RESTRICT\\Unit%d", i);
string resName = file.SGetValueDef("", key);
sprintf(key, "GAME\\RESTRICT\\Limit%d", i);
int resLimit;
file.GetDef(resLimit, "0", key);
restrictedUnits[resName] = resLimit;
}
}
示例9: LoadMutators
void CGameSetup::LoadMutators(const TdfParser& file, std::vector<std::string>& mutatorsList)
{
for (int a = 0; a < 10; ++a) {
std::string s = file.SGetValueDef("", IntToString(a, "GAME\\MUTATOR%i"));
if (s.empty()) break;
mutatorsList.push_back(s);
}
}
示例10: LoadStages
void ShaderDef::LoadStages(int numStages,const char *stagename, const TdfParser& tdf, std::vector<ShaderDef::Stage>& stages)
{
for (int a=0;a<numStages;a++)
{
string path = "map\\terrain\\";
char num[10];
SNPRINTF(num, 10, "%d", a);
string ts = path + stagename + num + "\\";
string opstr = tdf.SGetValueDef("mul", ts + "operation");
struct { StageOp op; const char *str; } tbl[] =
{
{ Mul, "mul" },
{ Add, "add" },
{ Alpha, "alpha" },
{ Blend, "blend" },
{ Mul, 0 },
};
StageOp operation = Mul;
for (int i = 0; tbl[i].str; i++)
{
if (opstr == tbl[i].str) {
operation = tbl[i].op;
break;
}
}
if (operation == Blend)
{
// insert an alpha stage before the blend stage
stages.push_back(Stage());
stages.back().sourceName = tdf.SGetValueDef(string(), ts + "blender");
stages.back().operation = Alpha;
}
stages.push_back(Stage());
stages.back().sourceName = tdf.SGetValueDef(string(), ts + "source");
stages.back().operation = operation;
if (stages.back().sourceName.empty())
throw content_error(ts + " does not have a source texture");
}
}
示例11: LoadPlayers
void CGameSetup::LoadPlayers(const TdfParser& file, std::set<std::string>& nameList)
{
numDemoPlayers = 0;
// i = player index in game (no gaps), a = player index in script
int i = 0;
for (int a = 0; a < MAX_PLAYERS; ++a) {
char section[50];
sprintf(section, "GAME\\PLAYER%i", a);
string s(section);
if (!file.SectionExist(s)) {
continue;
}
PlayerBase data;
// expects lines of form team=x rather than team=TEAMx
// team field is relocated in RemapTeams
std::map<std::string, std::string> setup = file.GetAllValues(s);
for (std::map<std::string, std::string>::const_iterator it = setup.begin(); it != setup.end(); ++it)
data.SetValue(it->first, it->second);
// do checks for sanity
if (data.name.empty())
throw content_error(str( boost::format("GameSetup: No name given for Player %i") %a ));
if (nameList.find(data.name) != nameList.end())
throw content_error(str(boost::format("GameSetup: Player %i has name %s which is already taken") %a %data.name.c_str() ));
nameList.insert(data.name);
if (data.isFromDemo)
numDemoPlayers++;
playerStartingData.push_back(data);
playerRemap[a] = i;
++i;
}
unsigned playerCount = 0;
if (file.GetValue(playerCount, "GAME\\NumPlayers") && playerStartingData.size() != playerCount) {
LOG_L(L_WARNING,
_STPF_ " players in GameSetup script (NumPlayers says %i)",
playerStartingData.size(), playerCount);
}
}
示例12: LoadSkirmishAIs
void CGameSetup::LoadSkirmishAIs(const TdfParser& file, std::set<std::string>& nameList)
{
// i = AI index in game (no gaps), a = AI index in script
for (int a = 0; a < MAX_PLAYERS; ++a) {
char section[50];
sprintf(section, "GAME\\AI%i\\", a);
string s(section);
if (!file.SectionExist(s.substr(0, s.length() - 1))) {
continue;
}
SkirmishAIData data;
data.team = atoi(file.SGetValueDef("-1", s + "Team").c_str());
if (data.team == -1) {
throw content_error("missing AI.Team in GameSetup script");
}
data.hostPlayer = atoi(file.SGetValueDef("-1", s + "Host").c_str());
if (data.hostPlayer == -1) {
throw content_error("missing AI.Host in GameSetup script");
}
data.shortName = file.SGetValueDef("", s + "ShortName");
if (data.shortName == "") {
throw content_error("missing AI.ShortName in GameSetup script");
}
data.version = file.SGetValueDef("", s + "Version");
if (file.SectionExist(s + "Options")) {
data.options = file.GetAllValues(s + "Options");
std::map<std::string, std::string>::const_iterator kv;
for (kv = data.options.begin(); kv != data.options.end(); ++kv) {
data.optionKeys.push_back(kv->first);
}
}
// get the visible name (comparable to player-name)
std::string name = file.SGetValueDef(data.shortName, s + "Name");
int instanceIndex = 0;
std::string name_unique = name;
while (nameList.find(name_unique) != nameList.end()) {
name_unique = name + "_" + IntToString(instanceIndex++);
// so we possibly end up with something like myBot_0, or RAI_2
}
data.name = name_unique;
nameList.insert(data.name);
skirmishAIStartingData.push_back(data);
}
}
示例13: content_error
CSensorHandler::CSensorHandler()
{
TdfParser tdfparser;
try {
tdfparser.LoadFile("gamedata/sensors.tdf");
} catch (content_error) {
// No need to do anything here, we just continue
// getting default values from the empty tdfparser.
}
tdfparser.GetDef(losMipLevel, "1", "Sensors\\Los\\LosMipLevel");
//loshandler->losMipLevel = losMipLevel;
tdfparser.GetDef(airMipLevel, "2", "Sensors\\Los\\AirLosMipLevel");
//loshandler->airLosMipLevel = airLosMipLevel;
// losMipLevel is used as index to readmap->mipHeightmap,
// so the max value is CReadMap::numHeightMipMaps - 1
if (losMipLevel < 0 || losMipLevel >= 7)
throw content_error("Sensors\\Los\\LosMipLevel out of bounds. "
"The minimum value is 0. The maximum value is 6.");
// airLosMipLevel doesn't have such restrictions, it's just used in various
// bitshifts with signed integers
if (airMipLevel < 0 || airMipLevel > 30)
throw content_error("Sensors\\Los\\AirLosMipLevel out of bounds. "
"The minimum value is 0. The maximum value is 30.");
tdfparser.GetDef(losMul, "1", "Sensors\\Los\\LosMul");
tdfparser.GetDef(airLosMul, "1", "Sensors\\Los\\AirLosMul");
}
示例14: LoadSound
void CUnitDefHandler::LoadSound(TdfParser &tdfparser, GuiSound &gsound, std::string sunname)
{
soundcategory.GetDef(gsound.name, "", tdfparser.SGetValueDef("", "UNITINFO\\SoundCategory")+"\\"+sunname);
if(gsound.name.compare("")==0)
gsound.id = 0;
else
{
CFileHandler file("sounds/"+gsound.name+".wav");
if(file.FileExists())
gsound.id = sound->GetWaveId(gsound.name+".wav");
else
gsound.id = 0;
}
gsound.volume = 5.0f;
}
示例15: ParseSettings
void CReadMap::ParseSettings(TdfParser& resources)
{
gs->sunVector=mapDefParser.GetFloat3(float3(0,1,2),"MAP\\LIGHT\\SunDir");
gs->sunVector.Normalize();
gs->sunVector4[0]=gs->sunVector[0];
gs->sunVector4[1]=gs->sunVector[1];
gs->sunVector4[2]=gs->sunVector[2];
gs->sunVector4[3]=0;
gs->gravity=-atof(mapDefParser.SGetValueDef("130","MAP\\Gravity").c_str())/(GAME_SPEED*GAME_SPEED);
float3 fogColor=mapDefParser.GetFloat3(float3(0.7,0.7,0.8),"MAP\\ATMOSPHERE\\FogColor");
FogLand[0]=fogColor[0];
FogLand[1]=fogColor[1];
FogLand[2]=fogColor[2];
mapDefParser.GetDef(skyBox, "", "MAP\\ATMOSPHERE\\SkyBox");
std::string tmp;
mapDefParser.GetDef(tmp, "", "MAP\\WATER\\WaterPlaneColor");
if(tmp.empty())
hasWaterPlane=0;
else
{
hasWaterPlane = 1;
waterPlaneColor = mapDefParser.GetFloat3(float3(0.0,0.4,0.0),"MAP\\WATER\\WaterPlaneColor");
}
mapDefParser.GetDef(tidalStrength, "0", "MAP\\TidalStrength");
waterSurfaceColor=mapDefParser.GetFloat3(float3(0.75,0.8,0.85),"MAP\\WATER\\WaterSurfaceColor");
waterAbsorb=mapDefParser.GetFloat3(float3(0,0,0),"MAP\\WATER\\WaterAbsorb");
waterBaseColor=mapDefParser.GetFloat3(float3(0,0,0),"MAP\\WATER\\WaterBaseColor");
waterMinColor=mapDefParser.GetFloat3(float3(0,0,0),"MAP\\WATER\\WaterMinColor");
mapDefParser.GetDef(waterTexture, "", "MAP\\WATER\\WaterTexture");
if(waterTexture.empty()) //default water is ocean.jpg in bitmaps, map specific water textures is saved in the map dir
waterTexture = "bitmaps/"+resources.SGetValueDef("ocean.jpg","resources\\graphics\\maps\\watertex");
else
waterTexture = "maps/" + waterTexture;
ambientColor=mapDefParser.GetFloat3(float3(0.5,0.5,0.5),"MAP\\LIGHT\\GroundAmbientColor");
sunColor=mapDefParser.GetFloat3(float3(0.5,0.5,0.5),"MAP\\LIGHT\\GroundSunColor");
mapDefParser.GetDef(shadowDensity, "0.8", "MAP\\LIGHT\\GroundShadowDensity");
mapDefParser.GetDef(maxMetal,"0.02","MAP\\MaxMetal");
mapDefParser.GetDef(extractorRadius,"500","MAP\\ExtractorRadius");
mapDefParser.GetDef(voidWater, "0", "MAP\\voidWater");
}