X-Git-Url: http://de.git.xonotic.org/?p=xonotic%2Fxonotic-data.pk3dir.git;a=blobdiff_plain;f=qcsrc%2Fcommon%2Fteams.qh;h=c1ef62d95079a669b82ac7b54a388ca3ed8743bf;hp=95f8f2006f30a26ce57761f8bd513cc13d82b6fb;hb=7994091f96667574af4e4d4873369edf2559ad1e;hpb=f4803dbafcdd9f29092535640728e3de19a987da diff --git a/qcsrc/common/teams.qh b/qcsrc/common/teams.qh index 95f8f2006f..c1ef62d950 100644 --- a/qcsrc/common/teams.qh +++ b/qcsrc/common/teams.qh @@ -1,47 +1,45 @@ #ifdef TEAMNUMBERS_THAT_ARENT_STUPID -const float FL_TEAM_1 = 1; // red -const float FL_TEAM_2 = 2; // blue -const float FL_TEAM_3 = 3; // yellow -const float FL_TEAM_4 = 4; // pink -const float FL_SPECTATOR = 5; - -// TO BE PHASED OUT IF WE SWITCH TO USE "TEAMNUMBERS_THAT_ARENT_STUPID" -#define TEAM_SV_TO_CL(num) num -#define TEAM_CL_TO_SV(num) num +const float NUM_TEAM_1 = 1; // red +const float NUM_TEAM_2 = 2; // blue +const float NUM_TEAM_3 = 3; // yellow +const float NUM_TEAM_4 = 4; // pink +const float NUM_SPECTATOR = 5; #else #ifdef CSQC -const float FL_TEAM_1 = 4; // red -const float FL_TEAM_2 = 13; // blue -const float FL_TEAM_3 = 12; // yellow -const float FL_TEAM_4 = 9; // pink +const float NUM_TEAM_1 = 4; // red +const float NUM_TEAM_2 = 13; // blue +const float NUM_TEAM_3 = 12; // yellow +const float NUM_TEAM_4 = 9; // pink #else -const float FL_TEAM_1 = 5; // red -const float FL_TEAM_2 = 14; // blue -const float FL_TEAM_3 = 13; // yellow -const float FL_TEAM_4 = 10; // pink +const float NUM_TEAM_1 = 5; // red +const float NUM_TEAM_2 = 14; // blue +const float NUM_TEAM_3 = 13; // yellow +const float NUM_TEAM_4 = 10; // pink #endif -const float FL_SPECTATOR = 1337; - -// TO BE PHASED OUT IF WE SWITCH TO USE "TEAMNUMBERS_THAT_ARENT_STUPID" -#define TEAM_SV_TO_CL(num) (num - 1) -#define TEAM_CL_TO_SV(num) (num + 1) +const float NUM_SPECTATOR = 1337; #endif const string COL_TEAM_1 = "^1"; const string COL_TEAM_2 = "^4"; const string COL_TEAM_3 = "^3"; const string COL_TEAM_4 = "^6"; -const string STR_TEAM_1 = _("Red"); -const string STR_TEAM_2 = _("Blue"); -const string STR_TEAM_3 = _("Yellow"); -const string STR_TEAM_4 = _("Pink"); -const string STR_TEAM = _("Team"); -const string STR_NEUTRAL = _("Neutral"); - -#define APP_TEAM_NUM_2(num,prefix) ((num == FL_TEAM_1) ? prefix##RED : prefix##BLUE) -#define APP_TEAM_NUM_4(num,prefix) ((num == FL_TEAM_1) ? prefix##RED : ((num == FL_TEAM_2) ? prefix##BLUE : ((num == FL_TEAM_3) ? prefix##YELLOW : prefix##PINK))) -#define APP_TEAM_ENT_2(ent,prefix) ((ent.team == FL_TEAM_1) ? prefix##RED : prefix##BLUE) -#define APP_TEAM_ENT_4(ent,prefix) ((ent.team == FL_TEAM_1) ? prefix##RED : ((ent.team == FL_TEAM_2) ? prefix##BLUE : ((ent.team == FL_TEAM_3) ? prefix##YELLOW : prefix##PINK))) +const string NAME_TEAM_1 = _("Red"); +const string NAME_TEAM_2 = _("Blue"); +const string NAME_TEAM_3 = _("Yellow"); +const string NAME_TEAM_4 = _("Pink"); +const string NAME_TEAM = _("Team"); +const string NAME_NEUTRAL = _("Neutral"); + +// used for replacement in filenames or such where the name CANNOT be allowed to be translated +const string STATIC_NAME_TEAM_1 = "Red"; +const string STATIC_NAME_TEAM_2 = "Blue"; +const string STATIC_NAME_TEAM_3 = "Yellow"; +const string STATIC_NAME_TEAM_4 = "Pink"; + +#define APP_TEAM_NUM_2(num,prefix) ((num == NUM_TEAM_1) ? prefix##RED : prefix##BLUE) +#define APP_TEAM_NUM_4(num,prefix) ((num == NUM_TEAM_1) ? prefix##RED : ((num == NUM_TEAM_2) ? prefix##BLUE : ((num == NUM_TEAM_3) ? prefix##YELLOW : prefix##PINK))) +#define APP_TEAM_ENT_2(ent,prefix) ((ent.team == NUM_TEAM_1) ? prefix##RED : prefix##BLUE) +#define APP_TEAM_ENT_4(ent,prefix) ((ent.team == NUM_TEAM_1) ? prefix##RED : ((ent.team == NUM_TEAM_2) ? prefix##BLUE : ((ent.team == NUM_TEAM_3) ? prefix##YELLOW : prefix##PINK))) #ifdef CSQC float teamplay; @@ -52,10 +50,10 @@ string Team_ColorCode(float teamid) { switch(teamid) { - case FL_TEAM_1: return COL_TEAM_1; - case FL_TEAM_2: return COL_TEAM_2; - case FL_TEAM_3: return COL_TEAM_3; - case FL_TEAM_4: return COL_TEAM_4; + case NUM_TEAM_1: return COL_TEAM_1; + case NUM_TEAM_2: return COL_TEAM_2; + case NUM_TEAM_3: return COL_TEAM_3; + case NUM_TEAM_4: return COL_TEAM_4; } return "^7"; @@ -66,15 +64,15 @@ vector Team_ColorRGB(float teamid) switch(teamid) { #ifdef TEAMNUMBERS_THAT_ARENT_STUPID - case FL_TEAM_1: return '1 0 0'; // red - case FL_TEAM_2: return '0 0 1'; // blue - case FL_TEAM_3: return '1 1 0'; // yellow - case FL_TEAM_4: return '1 0 1'; // pink + case NUM_TEAM_1: return '1 0 0'; // red + case NUM_TEAM_2: return '0 0 1'; // blue + case NUM_TEAM_3: return '1 1 0'; // yellow + case NUM_TEAM_4: return '1 0 1'; // pink #else - case FL_TEAM_1: return '1 0.0625 0.0625'; - case FL_TEAM_2: return '0.0625 0.0625 1'; - case FL_TEAM_3: return '1 1 0.0625'; - case FL_TEAM_4: return '1 0.0625 1'; + case NUM_TEAM_1: return '1 0.0625 0.0625'; + case NUM_TEAM_2: return '0.0625 0.0625 1'; + case NUM_TEAM_3: return '1 1 0.0625'; + case NUM_TEAM_4: return '1 0.0625 1'; #endif } @@ -85,23 +83,37 @@ string Team_ColorName(float teamid) { switch(teamid) { - case FL_TEAM_1: return STR_TEAM_1; - case FL_TEAM_2: return STR_TEAM_2; - case FL_TEAM_3: return STR_TEAM_3; - case FL_TEAM_4: return STR_TEAM_4; + case NUM_TEAM_1: return NAME_TEAM_1; + case NUM_TEAM_2: return NAME_TEAM_2; + case NUM_TEAM_3: return NAME_TEAM_3; + case NUM_TEAM_4: return NAME_TEAM_4; + } + + return NAME_NEUTRAL; +} + +// used for replacement in filenames or such where the name CANNOT be allowed to be translated +string Static_Team_ColorName(float teamid) +{ + switch(teamid) + { + case NUM_TEAM_1: return STATIC_NAME_TEAM_1; + case NUM_TEAM_2: return STATIC_NAME_TEAM_2; + case NUM_TEAM_3: return STATIC_NAME_TEAM_3; + case NUM_TEAM_4: return STATIC_NAME_TEAM_4; } - return STR_NEUTRAL; + return NAME_NEUTRAL; } float Team_ColorToTeam(string team_color) { switch(strtolower(team_color)) { - case "red": return FL_TEAM_1; - case "blue": return FL_TEAM_2; - case "yellow": return FL_TEAM_3; - case "pink": return FL_TEAM_4; + case "red": return NUM_TEAM_1; + case "blue": return NUM_TEAM_2; + case "yellow": return NUM_TEAM_3; + case "pink": return NUM_TEAM_4; case "auto": return 0; } @@ -112,10 +124,10 @@ float Team_NumberToTeam(float number) { switch(number) { - case 1: return FL_TEAM_1; - case 2: return FL_TEAM_2; - case 3: return FL_TEAM_3; - case 4: return FL_TEAM_4; + case 1: return NUM_TEAM_1; + case 2: return NUM_TEAM_2; + case 3: return NUM_TEAM_3; + case 4: return NUM_TEAM_4; } return -1; @@ -125,10 +137,10 @@ float Team_TeamToNumber(float teamid) { switch(teamid) { - case FL_TEAM_1: return 1; - case FL_TEAM_2: return 2; - case FL_TEAM_3: return 3; - case FL_TEAM_4: return 4; + case NUM_TEAM_1: return 1; + case NUM_TEAM_2: return 2; + case NUM_TEAM_3: return 3; + case NUM_TEAM_4: return 4; } return -1; @@ -143,8 +155,15 @@ float Team_TeamToNumber(float teamid) #define Team_ColorName_Lower(teamid) strtolower(Team_ColorName(teamid)) #define Team_ColorName_Upper(teamid) strtoupper(Team_ColorName(teamid)) -#define Team_FullName(teamid) strcat(Team_ColorName(teamid), " ", STR_TEAM, "^7") -#define Team_ColoredFullName(teamid) strcat(Team_ColorCode(teamid), Team_ColorName(teamid), " ", STR_TEAM, "^7") +// used for replacement in filenames or such where the name CANNOT be allowed to be translated +#define Static_Team_ColorName_Lower(teamid) strtolower(Static_Team_ColorName(teamid)) +#define Static_Team_ColorName_Upper(teamid) strtoupper(Static_Team_ColorName(teamid)) + +#define Team_FullName(teamid) strcat(Team_ColorName(teamid), " ", NAME_TEAM, "^7") +#define Team_ColoredFullName(teamid) strcat(Team_ColorCode(teamid), Team_ColorName(teamid), " ", NAME_TEAM, "^7") #define Team_NumberToFullName(number) Team_FullName(Team_NumberToTeam(number)) #define Team_NumberToColoredFullName(number) Team_ColoredFullName(Team_NumberToTeam(number)) + +// replace these flags in a string with the strings provided +#define TCR(input,teamcolor,teamtext) strreplace("^TC", teamcolor, strreplace("^TT", teamtext, input))