1 // =========================================================
2 // Reply messages for common commands, re-worked by Samual
3 // Last updated: December 30th, 2011
4 // =========================================================
6 // These strings are set usually during init in g_world.qc,
7 // or also by some game modes or other functions manually,
8 // and their purpose is to output information to clients
9 // without using any extra processing time.
11 // See common.qc for their proper commands
13 // todo: Re-write this to be more user friendly... I'll probably do it after it is merged.
15 string getrecords(float page) // 50 records per page
22 for (i = page * 200; i < MapInfo_count && i < page * 200 + 200; ++i)
24 if (MapInfo_Get_ByID(i))
26 r = stof(db_get(ServerProgsDB, strcat(MapInfo_Map_bspname, "/captimerecord/time")));
32 h = db_get(ServerProgsDB, strcat(MapInfo_Map_bspname, "/captimerecord/netname"));
33 s = strcat(s, strpad(32, MapInfo_Map_bspname), " ", strpad(-6, ftos_decimals(r, 2)), " ", h, "\n");
41 for (i = page * 200; i < MapInfo_count && i < page * 200 + 200; ++i)
43 if (MapInfo_Get_ByID(i))
45 r = race_readTime(MapInfo_Map_bspname, 1);
50 h = race_readName(MapInfo_Map_bspname, 1);
51 s = strcat(s, strpad(32, MapInfo_Map_bspname), " ", strpad(-8, TIME_ENCODED_TOSTRING(r)), " ", h, "\n");
59 for (i = page * 200; i < MapInfo_count && i < page * 200 + 200; ++i)
61 if (MapInfo_Get_ByID(i))
63 r = race_readTime(MapInfo_Map_bspname, 1);
68 h = race_readName(MapInfo_Map_bspname, 1);
69 s = strcat(s, strpad(32, MapInfo_Map_bspname), " ", strpad(-8, TIME_ENCODED_TOSTRING(r)), " ", h, "\n");
77 if (s == "" && page == 0)
78 return "No records are available on this server.\n";
90 for (i = 1; i <= RANKINGS_CNT; ++i)
92 t = race_readTime(map, i);
97 n = race_readName(map, i);
98 p = race_placeName(i);
99 s = strcat(s, strpad(8, p), " ", strpad(-8, TIME_ENCODED_TOSTRING(t)), " ", n, "\n");
102 MapInfo_ClearTemps();
105 return strcat("No records are available for the map: ", map, "\n");
107 return strcat("Records for ", map, ":\n", s);
112 float i, j, k, uidcnt, thiscnt;
113 string s, temp_s, rr, myuid, thisuid;
120 for(k = 0; k < MapInfo_count; ++k)
122 if(MapInfo_Get_ByID(k))
124 for(i = 0; i <= LADDER_CNT; ++i) // i = 0 because it is the speed award
126 if(i == 0) // speed award
128 if(stof(db_get(ServerProgsDB, strcat(MapInfo_Map_bspname, rr, "speed/speed"))) == 0)
131 myuid = db_get(ServerProgsDB, strcat(MapInfo_Map_bspname, rr, "speed/crypto_idfp"));
133 else // normal record, if it exists (else break)
135 if(race_readTime(MapInfo_Map_bspname, i) == 0)
138 myuid = race_readUID(MapInfo_Map_bspname, i);
141 // string s contains:
142 // arg 0 = # of speed recs
143 // arg 1 = # of 1st place recs
144 // arg 2 = # of 2nd place recs
146 // LADDER_CNT+1 = total points
148 temp_s = db_get(TemporaryDB, strcat("ladder", myuid));
152 db_put(TemporaryDB, strcat("uid", ftos(uidcnt)), myuid);
155 for(j = 0; j <= LADDER_CNT + 1; ++j)
157 if(j != LADDER_CNT + 1)
158 temp_s = strcat(temp_s, "0 ");
160 temp_s = strcat(temp_s, "0");
164 tokenize_console(temp_s);
167 if(i == 0) // speed award
169 for(j = 0; j <= LADDER_CNT; ++j) // loop over each arg in the string
171 if(j == 0) // speed award
172 s = strcat(s, ftos(stof(argv(j)) +1)); // add 1 to speed rec count and write
174 s = strcat(s, " ", argv(j)); // just copy over everything else
179 for(j = 0; j <= LADDER_CNT; ++j) // loop over each arg in the string
182 s = strcat(s, argv(j)); // speed award, dont prefix with " "
183 else if(j == i) // wanted rec!
184 s = strcat(s, " ", ftos(stof(argv(j)) +1)); // update argv(j)
186 s = strcat(s, " ", argv(j)); // just copy over everything else
190 // total points are (by default) calculated like this:
191 // speedrec = floor(100 / 10) = 10 points
192 // 1st place = floor(100 / 1) = 100 points
193 // 2nd place = floor(100 / 2) = 50 points
194 // 3rd place = floor(100 / 3) = 33 points
195 // 4th place = floor(100 / 4) = 25 points
196 // 5th place = floor(100 / 5) = 20 points
200 s = strcat(s, " ", ftos(stof(argv(LADDER_CNT+1)) + LADDER_FIRSTPOINT / 10)); // speed award, add LADDER_FIRSTPOINT / 10 points
202 s = strcat(s, " ", ftos(stof(argv(LADDER_CNT+1)) + floor(LADDER_FIRSTPOINT / i))); // record, add LADDER_FIRSTPOINT / i points
204 db_put(TemporaryDB, strcat("ladder", myuid), s);
209 for(i = 0; i <= uidcnt; ++i) // for each known uid
211 thisuid = db_get(TemporaryDB, strcat("uid", ftos(i)));
212 temp_s = db_get(TemporaryDB, strcat("ladder", thisuid));
213 tokenize_console(temp_s);
214 thiscnt = stof(argv(LADDER_CNT+1));
216 if(thiscnt > top_scores[LADDER_SIZE-1])
218 for(j = 0; j < LADDER_SIZE; ++j) // for each place in ladder
220 if(thiscnt > top_scores[j])
222 for(k = LADDER_SIZE-1; k >= j; --k)
224 top_uids[k] = top_uids[k-1];
225 top_scores[k] = top_scores[k-1];
228 top_uids[j] = thisuid;
229 top_scores[j] = thiscnt;
236 s = "^3-----------------------\n\n";
238 s = strcat(s, "Pos ^3|");
239 s = strcat(s, " ^7Total ^3|");
241 for(i = 1; i <= LADDER_CNT; ++i)
242 { s = strcat(s, " ^7", race_placeName(i), " ^3|"); }
244 s = strcat(s, " ^7Speed awards ^3| ^7Name");
245 s = strcat(s, "\n^3----+--------");
247 for(i = 1; i <= min(9, LADDER_CNT); ++i)
248 { s = strcat(s, "+-----"); }
251 for(i = 1; i <= LADDER_CNT - 9; ++i)
252 { s = strcat(s, "+------"); }
255 s = strcat(s, "+--------------+--------------------\n");
257 for(i = 0; i < LADDER_SIZE; ++i)
259 temp_s = db_get(TemporaryDB, strcat("ladder", top_uids[i]));
260 tokenize_console(temp_s);
262 if(argv(LADDER_CNT+1) == "") // total is 0, skip
265 s = strcat(s, strpad(4, race_placeName(i+1)), "^3| ^7"); // pos
266 s = strcat(s, strpad(7, argv(LADDER_CNT+1)), "^3| ^7"); // total
268 for(j = 1; j <= min(9, LADDER_CNT); ++j)
269 { s = strcat(s, strpad(4, argv(j)), "^3| ^7"); } // 1st, 2nd, 3rd etc cnt
272 for(j = 10; j <= LADDER_CNT; ++j)
273 { s = strcat(s, strpad(4, argv(j)), " ^3| ^7"); } // 1st, 2nd, 3rd etc cnt
276 s = strcat(s, strpad(13, argv(0)), "^3| ^7"); // speed award cnt
277 s = strcat(s, uid2name(top_uids[i]), "\n"); // name
280 MapInfo_ClearTemps();
283 return "No ladder on this server!\n";
285 return strcat("Top ", ftos(LADDER_SIZE), " ladder rankings:\n", s);