+++ /dev/null
-#ifdef INTERFACE
-CLASS(XonoticStatsList) EXTENDS(XonoticListBox)
- METHOD(XonoticStatsList, configureXonoticStatsList, void(entity))
- ATTRIB(XonoticStatsList, rowsPerItem, float, 1.4)
- METHOD(XonoticStatsList, resizeNotify, void(entity, vector, vector, vector, vector))
- METHOD(XonoticStatsList, drawListBoxItem, void(entity, float, vector, float))
- METHOD(XonoticStatsList, getStats, void(entity))
- METHOD(XonoticStatsList, clickListBoxItem, void(entity, float, vector))
- METHOD(XonoticStatsList, keyDown, float(entity, float, float, float))
- METHOD(XonoticStatsList, destroy, void(entity))
- METHOD(XonoticStatsList, showNotify, void(entity))
-
- ATTRIB(XonoticStatsList, listStats, float, -1)
- ATTRIB(XonoticStatsList, realFontSize, vector, '0 0 0')
- ATTRIB(XonoticStatsList, realUpperMargin, float, 0)
- ATTRIB(XonoticStatsList, columnNameOrigin, float, 0)
- ATTRIB(XonoticStatsList, columnNameSize, float, 0)
-
- ATTRIB(XonoticStatsList, lastClickedDemo, float, -1)
- ATTRIB(XonoticStatsList, lastClickedTime, float, 0)
-ENDCLASS(XonoticStatsList)
-
-entity statslist; // for reference elsewhere
-entity makeXonoticStatsList();
-#endif
-
-#ifdef IMPLEMENTATION
-
-entity makeXonoticStatsList()
-{
- entity me;
- me = spawnXonoticStatsList();
- me.configureXonoticStatsList(me);
- return me;
-}
-
-void XonoticStatsList_configureXonoticStatsList(entity me)
-{
- me.configureXonoticListBox(me);
- me.getStats(me);
-}
-
-string XonoticStatsList_convertDate(string input)
-{
- // 2013-12-21
- // 0123456789
- if(strlen(input) != 10)
- return input;
-
- string monthname = "";
-
- switch(stof(substring(input, 5, 2)))
- {
- case 1: monthname = _("January"); break;
- case 2: monthname = _("February"); break;
- case 3: monthname = _("March"); break;
- case 4: monthname = _("April"); break;
- case 5: monthname = _("May"); break;
- case 6: monthname = _("June"); break;
- case 7: monthname = _("July"); break;
- case 8: monthname = _("August"); break;
- case 9: monthname = _("September"); break;
- case 10: monthname = _("October"); break;
- case 11: monthname = _("November"); break;
- case 12: monthname = _("December"); break;
- default: return input; // failed, why?
- }
-
- return sprintf(
- "%s %s, %d",
- monthname,
- count_ordinal(stof(substring(input, 8, 2))),
- stof(substring(input, 0, 4))
- );
-}
-
-void XonoticStatsList_getStats(entity me)
-{
- dprint("XonoticStatsList_getStats() at time: ", ftos(time), "\n");
- // delete the old buffer if it exists
- if(me.listStats >= 0)
- buf_del(me.listStats);
-
- // create the new buffer if we have a stats buffer
- if(PS_D_IN_DB >= 0)
- me.listStats = buf_create();
-
- // now confirmation, if we didn't create a buffer then just return now
- if(me.listStats < 0)
- {
- me.nItems = 0;
- return;
- }
-
- float order = 0;
- string e = "", en = "", data = "";
-
- string outstr = ""; // NOTE: out string MUST use underscores for spaces here, we'll replace them later
- string orderstr = "";
-
- float out_total_matches = -1;
- float out_total_wins = -1;
- float out_total_losses = -1;
-
- float out_total_kills = -1;
- float out_total_deaths = -1;
-
- for(e = PS_D_IN_EVL; (en = db_get(PS_D_IN_DB, e)) != ""; e = en)
- {
- order = 0;
- outstr = "";
- orderstr = "";
- data = db_get(PS_D_IN_DB, sprintf("#%s", e));
-
- // non-gamemode specific stuff
- switch(e)
- {
- case "overall/joined_dt":
- {
- order = 1;
- outstr = _("Joined:");
- data = XonoticStatsList_convertDate(car(data));
- break;
- }
- case "overall/last_seen_dt":
- {
- order = 1;
- outstr = _("Last_Seen:");
- data = XonoticStatsList_convertDate(car(data));
- break;
- }
- case "overall/alivetime":
- {
- order = 1;
- outstr = _("Time_Played:");
- data = process_time(3, stof(data));
- break;
- }
- case "overall/favorite-map":
- {
- order = 2;
- outstr = _("Favorite_Map:");
- data = car(data);
- break;
- }
- case "overall/matches":
- {
- order = -1;
- out_total_matches = stof(data);
- break;
- }
- case "overall/wins":
- {
- order = -1;
- out_total_wins = stof(data);
- break;
- }
- case "overall/total-kills":
- {
- order = -1;
- out_total_kills = stof(data);
- break;
- }
- case "overall/total-deaths":
- {
- order = -1;
- out_total_deaths = stof(data);
- break;
- }
- }
-
- if((order == -1) && (out_total_matches >= 0) && (out_total_wins >= 0))
- {
- bufstr_add(me.listStats, sprintf("003Matches: %d", out_total_matches), TRUE);
-
- if(out_total_matches > 0) // don't show extra info if there are no matches played
- {
- out_total_losses = max(0, (out_total_matches - out_total_wins));
- bufstr_add(me.listStats, sprintf("003Wins/Losses: %d/%d", out_total_wins, out_total_losses), TRUE);
- bufstr_add(me.listStats, sprintf("004Win_Percentage: %d%%", ((out_total_wins / out_total_matches) * 100)), TRUE);
- }
-
- out_total_matches = -1;
- out_total_wins = -1;
- out_total_losses = -1;
- continue;
- }
-
- if((order == -1) && (out_total_kills >= 0) && (out_total_deaths >= 0))
- {
- bufstr_add(me.listStats, sprintf("005Kills/Deaths: %d/%d", out_total_kills, out_total_deaths), TRUE);
-
- // if there are no deaths, just show kill count
- if(out_total_deaths > 0)
- bufstr_add(me.listStats, sprintf("006Kill_Ratio: %.2f", (out_total_kills / out_total_deaths)), TRUE);
- else
- bufstr_add(me.listStats, sprintf("006Kill_Ratio: %.2f", out_total_kills), TRUE);
-
- out_total_kills = -1;
- out_total_deaths = -1;
- continue;
- }
-
- // game mode specific stuff
- if(order > 0)
- {
- orderstr = sprintf("%03d", order);
- }
- else
- {
- float dividerpos = strstrofs(e, "/", 0);
-
- string gametype = substring(e, 0, dividerpos);
- if(gametype == "overall") { continue; }
-
- string event = substring(e, (dividerpos + 1), strlen(e) - (dividerpos + 1));
-
- // if we are ranked, read these sets of possible options
- if(stof(db_get(PS_D_IN_DB, sprintf("#%s/rank", gametype))))
- {
- switch(event)
- {
- case "matches":
- {
- order = 1;
- outstr = sprintf(_("%s_Matches:"), strtoupper(gametype));
- //data = sprintf(_("%d (unranked)"), data);
- break;
- }
- case "elo":
- {
- order = 2;
- outstr = sprintf(_("%s_ELO:"), strtoupper(gametype));
- data = sprintf("%d", stof(data));
- break;
- }
- case "rank":
- {
- order = 3;
- outstr = sprintf(_("%s_Rank:"), strtoupper(gametype));
- data = sprintf("%d", stof(data));
- break;
- }
- case "percentile":
- {
- order = 4;
- outstr = sprintf(_("%s_Percentile:"), strtoupper(gametype));
- data = sprintf("%d%%", stof(data));
- break;
- }
-
- #if 0
- case "favorite-map":
- {
- order = 5;
- outstr = sprintf(_("%s_Favorite_Map:"), strtoupper(gametype));
- //data = sprintf(_("%d (unranked)"), data);
- break;
- }
- #endif
-
- default: continue; // nothing to see here
- }
-
- // now set up order for sorting later
- orderstr = sprintf("%2.2s%d", gametype, order);
- }
- else if(event == "matches")
- {
- outstr = sprintf(_("%s_Matches:"), strtoupper(gametype));
- data = sprintf(_("%d (unranked)"), stof(data));
-
- // unranked game modes ALWAYS get put last
- orderstr = "zzz";
- }
- else { continue; }
- }
-
- bufstr_add(me.listStats, sprintf("%s%s %s", orderstr, outstr, data), TRUE);
- }
-
- me.nItems = buf_getsize(me.listStats);
- if(me.nItems > 0)
- buf_sort(me.listStats, 128, FALSE);
-}
-
-void XonoticStatsList_destroy(entity me)
-{
- if(me.nItems > 0)
- buf_del(me.listStats);
-}
-
-void XonoticStatsList_resizeNotify(entity me, vector relOrigin, vector relSize, vector absOrigin, vector absSize)
-{
- me.itemAbsSize = '0 0 0';
- SUPER(XonoticStatsList).resizeNotify(me, relOrigin, relSize, absOrigin, absSize);
-
- me.realFontSize_y = me.fontSize / (me.itemAbsSize_y = (absSize_y * me.itemHeight));
- me.realFontSize_x = me.fontSize / (me.itemAbsSize_x = (absSize_x * (1 - me.controlWidth)));
- me.realUpperMargin = 0.5 * (1 - me.realFontSize_y);
-
-#if 0
- me.columnNameOrigin = me.realFontSize_x;
- me.columnNameSize = 0.5 - me.realFontSize_x; // end halfway at maximum length
- me.columnDataOrigin = me.columnNameOrigin + me.columnNameSize;
- me.columnDataSize = 1 - me.columnNameSize - me.realFontSize_x; // fill the rest of the control
-#else
- me.columnNameOrigin = me.realFontSize_x;
- me.columnNameSize = 1 - 2 * me.realFontSize_x;
-#endif
-}
-
-void XonoticStatsList_drawListBoxItem(entity me, float i, vector absSize, float isSelected)
-{
- if(isSelected)
- draw_Fill('0 0 0', '1 1 0', SKINCOLOR_LISTBOX_SELECTED, SKINALPHA_LISTBOX_SELECTED);
-
- string data = bufstr_get(me.listStats, i);
- string s = car(data);
- string d = cdr(data);
-
- s = substring(s, 3, strlen(s) - 3);
- s = strreplace("_", " ", s);
- s = draw_TextShortenToWidth(s, 0.5 * me.columnNameSize, 0, me.realFontSize);
- draw_Text(me.realUpperMargin * eY + me.columnNameOrigin * eX, s, me.realFontSize, '1 1 1', SKINALPHA_TEXT, 1);
-
- d = draw_TextShortenToWidth(d, me.columnNameSize - draw_TextWidth(s, 0, me.realFontSize), 0, me.realFontSize);
- draw_Text(me.realUpperMargin * eY + (me.columnNameOrigin + 1 * (me.columnNameSize - draw_TextWidth(d, 0, me.realFontSize))) * eX, d, me.realFontSize, '1 1 1', SKINALPHA_TEXT, 1);
-}
-
-void XonoticStatsList_showNotify(entity me)
-{
- PlayerStats_PlayerDetail_CheckUpdate();
-}
-
-void XonoticStatsList_clickListBoxItem(entity me, float i, vector where)
-{
- if(i == me.lastClickedDemo)
- if(time < me.lastClickedTime + 0.3)
- {
- // DOUBLE CLICK!
- me.setSelected(me, i);
- //DemoConfirm_ListClick_Check_Gamestatus(me);
- }
- me.lastClickedDemo = i;
- me.lastClickedTime = time;
-}
-
-float XonoticStatsList_keyDown(entity me, float scan, float ascii, float shift)
-{
- if(scan == K_ENTER || scan == K_KP_ENTER)
- {
- //DemoConfirm_ListClick_Check_Gamestatus(me);
- return 1;
- }
- else
- {
- return SUPER(XonoticStatsList).keyDown(me, scan, ascii, shift);
- }
-}
-#endif
-