X-Git-Url: http://git.xonotic.org/?a=blobdiff_plain;ds=sidebyside;f=qcsrc%2Fmenu%2Fxonotic%2Fstatslist.c;fp=qcsrc%2Fmenu%2Fxonotic%2Fstatslist.c;h=0000000000000000000000000000000000000000;hb=e3507f4fdbc2b3e15b663365e57e0aa60f3cf1a6;hp=c7b744a66710697c02782151b8607edda74d1ab8;hpb=02013c593abe7ccb7c6502148df33b34390d8216;p=xonotic%2Fxonotic-data.pk3dir.git diff --git a/qcsrc/menu/xonotic/statslist.c b/qcsrc/menu/xonotic/statslist.c deleted file mode 100644 index c7b744a66..000000000 --- a/qcsrc/menu/xonotic/statslist.c +++ /dev/null @@ -1,351 +0,0 @@ -#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, doubleClickListBoxItem, 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) -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_doubleClickListBoxItem(entity me, float i, vector where) -{ - //DemoConfirm_ListClick_Check_Gamestatus(me); -} - -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 -