]> git.xonotic.org Git - xonotic/xonotic-data.pk3dir.git/blobdiff - qcsrc/menu/xonotic/statslist.c
Merge branch 'master' into mirceakitsune/playermodel_ubot
[xonotic/xonotic-data.pk3dir.git] / qcsrc / menu / xonotic / statslist.c
diff --git a/qcsrc/menu/xonotic/statslist.c b/qcsrc/menu/xonotic/statslist.c
deleted file mode 100644 (file)
index 9882448..0000000
+++ /dev/null
@@ -1,362 +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, 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
-