X-Git-Url: http://de.git.xonotic.org/?a=blobdiff_plain;f=qcsrc%2Fcommon%2Fplayerstats.qh;h=e77cdbff594f42c874f836d57d47ee537bcb370c;hb=2718fac2d710f2c4e63a6de3cfe0ffc66dc7d6a3;hp=bf3d4f2d764cb14e6a2a2cfb9e8d659f981940c9;hpb=cd1ccb7c3ac08760ccc361d6c863fcc2ade4ac2e;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/common/playerstats.qh b/qcsrc/common/playerstats.qh index bf3d4f2d7..e77cdbff5 100644 --- a/qcsrc/common/playerstats.qh +++ b/qcsrc/common/playerstats.qh @@ -1,3 +1,32 @@ +#ifndef PLAYERSTATS_H +#define PLAYERSTATS_H + +#ifdef SVQC +//float PS_PM_IN_DB = -1; // playerstats_prematch_in_db // db for info COLLECTED at the beginning of a match +int PS_GR_OUT_DB = -1; // playerstats_gamereport_out_db // db of info SENT at the end of a match +//float PS_GR_IN_DB = -1; // playerstats_gamereport_in_db // db for info COLLECTED at the end of a match +int PS_B_IN_DB = -1; // playerstats_playerbasic_in_db // db for info COLLECTED for basic player info (ELO) +#endif + +#ifdef MENUQC +int PS_D_IN_DB = -1; // playerstats_playerdetail_in_db // db for info COLLECTED for detailed player profile display +#endif + +#ifdef SVQC +//string PS_PM_IN_EVL; // playerstats_prematch_in_events_last +string PS_GR_OUT_TL; // playerstats_gamereport_out_teams_last +string PS_GR_OUT_PL; // playerstats_gamereport_out_players_last +string PS_GR_OUT_EVL; // playerstats_gamereport_out_events_last +//string PS_GR_IN_PL; // playerstats_gamereport_in_players_last +//string PS_GR_IN_EVL; // playerstats_gamereport_in_events_last +//string PS_B_IN_PL; // playerstats_playerbasic_in_players_last +//string PS_B_IN_EVL; // playerstats_playerbasic_in_events_last +#endif + +#ifdef MENUQC +string PS_D_IN_EVL; // playerstats_playerdetail_in_events_last +#endif + #ifdef SVQC // time the player was alive and kicking @@ -25,57 +54,66 @@ const string PLAYERSTATS_ACHIEVEMENT_FIRSTBLOOD = "achievement-firstblood"; const string PLAYERSTATS_ACHIEVEMENT_FIRSTVICTIM = "achievement-firstvictim"; // delay map switch until this is set -float playerstats_waitforme; +float PlayerStats_GameReport_DelayMapVote; // call at initialization -void PlayerStats_Init(); +void PlayerStats_GameReport_Init(); // add a new player -void PlayerStats_AddPlayer(entity e); +void PlayerStats_GameReport_AddPlayer(entity e); // add a new team -void PlayerStats_AddTeam(float t); +void PlayerStats_GameReport_AddTeam(float t); // add a new event -void PlayerStats_AddEvent(string event_id); +void PlayerStats_GameReport_AddEvent(string event_id); // call on each event to track, or at player disconnect OR match end for "global stuff" -float PlayerStats_Event(entity e, string event_id, float value); - -// add a team score -float PlayerStats_TeamScore(float t, string event_id, float value); +#define PS_GR_P_ADDVAL(ent,eventid,val) PlayerStats_GameReport_Event(ent.playerstats_id, eventid, val) +#define PS_GR_T_ADDVAL(team,eventid,val) PlayerStats_GameReport_Event(sprintf("team#%d", team), eventid, val) +float PlayerStats_GameReport_Event(string prefix, string event_id, float value); -// call at game over -void PlayerStats_Shutdown(); // send stats to the server - -void PlayerStats_Accuracy(entity p); +void PlayerStats_GameReport_Accuracy(entity p); // call this whenever a player leaves -void PlayerStats_AddGlobalInfo(entity p); +void PlayerStats_GameReport_FinalizePlayer(entity p); // call this at the end of the match -void PlayerStats_EndMatch(float finished); - -#endif //SVQC +void PlayerStats_GameReport(float finished); +void PlayerStats_GameReport_Handler(entity fh, entity pass, float status); +.string playerstats_id; +//string autocvar_g_playerstats_uri; -//// WIP -zykure ///////////////////////////////////////////////////// +string autocvar_g_playerstats_gamereport_ladder; +string autocvar_g_playerstats_gamereport_uri = "http://stats.xonotic.org/stats/submit"; +const float PS_B_STATUS_ERROR = -2; +const float PS_B_STATUS_IDLE = -1; +const float PS_B_STATUS_WAITING = 0; +const float PS_B_STATUS_RECEIVED = 1; +const float PS_B_STATUS_UPDATING = 2; +.float playerstats_basicstatus; +string autocvar_g_playerstats_playerbasic_uri = "http://stats.xonotic.org"; -const string playerinfo_uri = "http://localhost:6543"; // FIXME - -string PlayerInfo_GetItem(entity e, string item_id); -string PlayerInfo_GetItemLocal(string item_id); - -void PlayerInfo_Init(); -#ifdef SVQC -void PlayerInfo_Basic(entity p); -#endif +void PlayerStats_PlayerBasic(entity joiningplayer, float newrequest); +void PlayerStats_PlayerBasic_CheckUpdate(entity joiningplayer); +void PlayerStats_PlayerBasic_Handler(entity fh, entity p, float status); +#endif //SVQC #ifdef MENUQC -void PlayerInfo_Details(); +float PS_D_NEXTUPDATETIME; +float PS_D_LASTGAMECOUNT; +const float PS_D_STATUS_ERROR = -2; +const float PS_D_STATUS_IDLE = -1; +const float PS_D_STATUS_WAITING = 0; +const float PS_D_STATUS_RECEIVED = 1; +float PlayerStats_PlayerDetail_Status = PS_D_STATUS_IDLE; +string autocvar_g_playerstats_playerdetail_uri = "http://stats.xonotic.org/player/me"; +float autocvar_g_playerstats_playerdetail_autoupdatetime = 1800; // automatically update every 30 minutes anyway +void PlayerStats_PlayerDetail(void); +void PlayerStats_PlayerDetail_CheckUpdate(void); +void PlayerStats_PlayerDetail_Handler(entity fh, entity p, float status); #endif -#ifdef CSQC -//void PlayerInfo_Details(); #endif