bg_lib.c (39177B)
1 // 2 // 3 // bg_lib,c -- standard C library replacement routines used by code 4 // compiled for the virtual machine 5 6 #include "q_shared.h" 7 8 /*- 9 * Copyright (c) 1992, 1993 10 * The Regents of the University of California. All rights reserved. 11 * 12 * Redistribution and use in source and binary forms, with or without 13 * modification, are permitted provided that the following conditions 14 * are met: 15 * 1. Redistributions of source code must retain the above copyright 16 * notice, this list of conditions and the following disclaimer. 17 * 2. Redistributions in binary form must reproduce the above copyright 18 * notice, this list of conditions and the following disclaimer in the 19 * documentation and/or other materials provided with the distribution. 20 * 3. All advertising materials mentioning features or use of this software 21 * must display the following acknowledgement: 22 * This product includes software developed by the University of 23 * California, Berkeley and its contributors. 24 * 4. Neither the name of the University nor the names of its contributors 25 * may be used to endorse or promote products derived from this software 26 * without specific prior written permission. 27 * 28 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 29 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 30 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 31 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 32 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 33 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 34 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 35 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 36 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 37 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 38 * SUCH DAMAGE. 39 */ 40 41 #if defined(LIBC_SCCS) && !defined(lint) 42 #if 0 43 static char sccsid[] = "@(#)qsort.c 8.1 (Berkeley) 6/4/93"; 44 #endif 45 static const char rcsid[] = 46 #endif /* LIBC_SCCS and not lint */ 47 48 // bk001127 - needed for DLL's 49 #if !defined( Q3_VM ) 50 typedef int cmp_t(const void *, const void *); 51 #endif 52 53 static char* med3(char *, char *, char *, cmp_t *); 54 static void swapfunc(char *, char *, int, int); 55 56 #ifndef min 57 #define min(a, b) (a) < (b) ? a : b 58 #endif 59 60 /* 61 * Qsort routine from Bentley & McIlroy's "Engineering a Sort Function". 62 */ 63 #define swapcode(TYPE, parmi, parmj, n) { \ 64 long i = (n) / sizeof (TYPE); \ 65 register TYPE *pi = (TYPE *) (parmi); \ 66 register TYPE *pj = (TYPE *) (parmj); \ 67 do { \ 68 register TYPE t = *pi; \ 69 *pi++ = *pj; \ 70 *pj++ = t; \ 71 } while (--i > 0); \ 72 } 73 74 #define SWAPINIT(a, es) swaptype = ((char *)a - (char *)0) % sizeof(long) || \ 75 es % sizeof(long) ? 2 : es == sizeof(long)? 0 : 1; 76 77 static void 78 swapfunc(a, b, n, swaptype) 79 char *a, *b; 80 int n, swaptype; 81 { 82 if(swaptype <= 1) 83 swapcode(long, a, b, n) 84 else 85 swapcode(char, a, b, n) 86 } 87 88 #define swap(a, b) \ 89 if (swaptype == 0) { \ 90 long t = *(long *)(a); \ 91 *(long *)(a) = *(long *)(b); \ 92 *(long *)(b) = t; \ 93 } else \ 94 swapfunc(a, b, es, swaptype) 95 96 #define vecswap(a, b, n) if ((n) > 0) swapfunc(a, b, n, swaptype) 97 98 static char * 99 med3(a, b, c, cmp) 100 char *a, *b, *c; 101 cmp_t *cmp; 102 { 103 return cmp(a, b) < 0 ? 104 (cmp(b, c) < 0 ? b : (cmp(a, c) < 0 ? c : a )) 105 :(cmp(b, c) > 0 ? b : (cmp(a, c) < 0 ? a : c )); 106 } 107 108 void 109 qsort(a, n, es, cmp) 110 void *a; 111 size_t n, es; 112 cmp_t *cmp; 113 { 114 char *pa, *pb, *pc, *pd, *pl, *pm, *pn; 115 int d, r, swaptype, swap_cnt; 116 117 loop: SWAPINIT(a, es); 118 swap_cnt = 0; 119 if (n < 7) { 120 for (pm = (char *)a + es; pm < (char *)a + n * es; pm += es) 121 for (pl = pm; pl > (char *)a && cmp(pl - es, pl) > 0; 122 pl -= es) 123 swap(pl, pl - es); 124 return; 125 } 126 pm = (char *)a + (n / 2) * es; 127 if (n > 7) { 128 pl = a; 129 pn = (char *)a + (n - 1) * es; 130 if (n > 40) { 131 d = (n / 8) * es; 132 pl = med3(pl, pl + d, pl + 2 * d, cmp); 133 pm = med3(pm - d, pm, pm + d, cmp); 134 pn = med3(pn - 2 * d, pn - d, pn, cmp); 135 } 136 pm = med3(pl, pm, pn, cmp); 137 } 138 swap(a, pm); 139 pa = pb = (char *)a + es; 140 141 pc = pd = (char *)a + (n - 1) * es; 142 for (;;) { 143 while (pb <= pc && (r = cmp(pb, a)) <= 0) { 144 if (r == 0) { 145 swap_cnt = 1; 146 swap(pa, pb); 147 pa += es; 148 } 149 pb += es; 150 } 151 while (pb <= pc && (r = cmp(pc, a)) >= 0) { 152 if (r == 0) { 153 swap_cnt = 1; 154 swap(pc, pd); 155 pd -= es; 156 } 157 pc -= es; 158 } 159 if (pb > pc) 160 break; 161 swap(pb, pc); 162 swap_cnt = 1; 163 pb += es; 164 pc -= es; 165 } 166 if (swap_cnt == 0) { /* Switch to insertion sort */ 167 for (pm = (char *)a + es; pm < (char *)a + n * es; pm += es) 168 for (pl = pm; pl > (char *)a && cmp(pl - es, pl) > 0; 169 pl -= es) 170 swap(pl, pl - es); 171 return; 172 } 173 174 pn = (char *)a + n * es; 175 r = min(pa - (char *)a, pb - pa); 176 vecswap(a, pb - r, r); 177 r = min(pd - pc, pn - pd - es); 178 vecswap(pb, pn - r, r); 179 if ((r = pb - pa) > es) 180 qsort(a, r / es, es, cmp); 181 if ((r = pd - pc) > es) { 182 /* Iterate rather than recurse to save stack space */ 183 a = pn - r; 184 n = r / es; 185 goto loop; 186 } 187 /* qsort(pn - r, r / es, es, cmp);*/ 188 } 189 190 //================================================================================== 191 192 193 // this file is excluded from release builds because of intrinsics 194 195 // bk001211 - gcc errors on compiling strcpy: parse error before `__extension__' 196 #if defined ( Q3_VM ) 197 198 size_t strlen( const char *string ) { 199 const char *s; 200 201 s = string; 202 while ( *s ) { 203 s++; 204 } 205 return s - string; 206 } 207 208 209 char *strcat( char *strDestination, const char *strSource ) { 210 char *s; 211 212 s = strDestination; 213 while ( *s ) { 214 s++; 215 } 216 while ( *strSource ) { 217 *s++ = *strSource++; 218 } 219 *s = 0; 220 return strDestination; 221 } 222 223 char *strcpy( char *strDestination, const char *strSource ) { 224 char *s; 225 226 s = strDestination; 227 while ( *strSource ) { 228 *s++ = *strSource++; 229 } 230 *s = 0; 231 return strDestination; 232 } 233 234 235 int strcmp( const char *string1, const char *string2 ) { 236 while ( *string1 == *string2 && *string1 && *string2 ) { 237 string1++; 238 string2++; 239 } 240 return *string1 - *string2; 241 } 242 243 244 char *strchr( const char *string, int c ) { 245 while ( *string ) { 246 if ( *string == c ) { 247 return ( char * )string; 248 } 249 string++; 250 } 251 return (char *)0; 252 } 253 254 char *strstr( const char *string, const char *strCharSet ) { 255 while ( *string ) { 256 int i; 257 258 for ( i = 0 ; strCharSet[i] ; i++ ) { 259 if ( string[i] != strCharSet[i] ) { 260 break; 261 } 262 } 263 if ( !strCharSet[i] ) { 264 return (char *)string; 265 } 266 string++; 267 } 268 return (char *)0; 269 } 270 #endif // bk001211 271 272 // bk001120 - presumably needed for Mac 273 //#if !defined(_MSC_VER) && !defined(__linux__) 274 // bk001127 - undid undo 275 #if defined ( Q3_VM ) 276 int tolower( int c ) { 277 if ( c >= 'A' && c <= 'Z' ) { 278 c += 'a' - 'A'; 279 } 280 return c; 281 } 282 283 284 int toupper( int c ) { 285 if ( c >= 'a' && c <= 'z' ) { 286 c += 'A' - 'a'; 287 } 288 return c; 289 } 290 291 #endif 292 //#ifndef _MSC_VER 293 294 void *memmove( void *dest, const void *src, size_t count ) { 295 int i; 296 297 if ( dest > src ) { 298 for ( i = count-1 ; i >= 0 ; i-- ) { 299 ((char *)dest)[i] = ((char *)src)[i]; 300 } 301 } else { 302 for ( i = 0 ; i < count ; i++ ) { 303 ((char *)dest)[i] = ((char *)src)[i]; 304 } 305 } 306 return dest; 307 } 308 309 310 #if 0 311 312 double floor( double x ) { 313 return (int)(x + 0x40000000) - 0x40000000; 314 } 315 316 void *memset( void *dest, int c, size_t count ) { 317 while ( count-- ) { 318 ((char *)dest)[count] = c; 319 } 320 return dest; 321 } 322 323 void *memcpy( void *dest, const void *src, size_t count ) { 324 while ( count-- ) { 325 ((char *)dest)[count] = ((char *)src)[count]; 326 } 327 return dest; 328 } 329 330 char *strncpy( char *strDest, const char *strSource, size_t count ) { 331 char *s; 332 333 s = strDest; 334 while ( *strSource && count ) { 335 *s++ = *strSource++; 336 count--; 337 } 338 while ( count-- ) { 339 *s++ = 0; 340 } 341 return strDest; 342 } 343 344 double sqrt( double x ) { 345 float y; 346 float delta; 347 float maxError; 348 349 if ( x <= 0 ) { 350 return 0; 351 } 352 353 // initial guess 354 y = x / 2; 355 356 // refine 357 maxError = x * 0.001; 358 359 do { 360 delta = ( y * y ) - x; 361 y -= delta / ( 2 * y ); 362 } while ( delta > maxError || delta < -maxError ); 363 364 return y; 365 } 366 367 368 float sintable[1024] = { 369 0.000000,0.001534,0.003068,0.004602,0.006136,0.007670,0.009204,0.010738, 370 0.012272,0.013805,0.015339,0.016873,0.018407,0.019940,0.021474,0.023008, 371 0.024541,0.026075,0.027608,0.029142,0.030675,0.032208,0.033741,0.035274, 372 0.036807,0.038340,0.039873,0.041406,0.042938,0.044471,0.046003,0.047535, 373 0.049068,0.050600,0.052132,0.053664,0.055195,0.056727,0.058258,0.059790, 374 0.061321,0.062852,0.064383,0.065913,0.067444,0.068974,0.070505,0.072035, 375 0.073565,0.075094,0.076624,0.078153,0.079682,0.081211,0.082740,0.084269, 376 0.085797,0.087326,0.088854,0.090381,0.091909,0.093436,0.094963,0.096490, 377 0.098017,0.099544,0.101070,0.102596,0.104122,0.105647,0.107172,0.108697, 378 0.110222,0.111747,0.113271,0.114795,0.116319,0.117842,0.119365,0.120888, 379 0.122411,0.123933,0.125455,0.126977,0.128498,0.130019,0.131540,0.133061, 380 0.134581,0.136101,0.137620,0.139139,0.140658,0.142177,0.143695,0.145213, 381 0.146730,0.148248,0.149765,0.151281,0.152797,0.154313,0.155828,0.157343, 382 0.158858,0.160372,0.161886,0.163400,0.164913,0.166426,0.167938,0.169450, 383 0.170962,0.172473,0.173984,0.175494,0.177004,0.178514,0.180023,0.181532, 384 0.183040,0.184548,0.186055,0.187562,0.189069,0.190575,0.192080,0.193586, 385 0.195090,0.196595,0.198098,0.199602,0.201105,0.202607,0.204109,0.205610, 386 0.207111,0.208612,0.210112,0.211611,0.213110,0.214609,0.216107,0.217604, 387 0.219101,0.220598,0.222094,0.223589,0.225084,0.226578,0.228072,0.229565, 388 0.231058,0.232550,0.234042,0.235533,0.237024,0.238514,0.240003,0.241492, 389 0.242980,0.244468,0.245955,0.247442,0.248928,0.250413,0.251898,0.253382, 390 0.254866,0.256349,0.257831,0.259313,0.260794,0.262275,0.263755,0.265234, 391 0.266713,0.268191,0.269668,0.271145,0.272621,0.274097,0.275572,0.277046, 392 0.278520,0.279993,0.281465,0.282937,0.284408,0.285878,0.287347,0.288816, 393 0.290285,0.291752,0.293219,0.294685,0.296151,0.297616,0.299080,0.300543, 394 0.302006,0.303468,0.304929,0.306390,0.307850,0.309309,0.310767,0.312225, 395 0.313682,0.315138,0.316593,0.318048,0.319502,0.320955,0.322408,0.323859, 396 0.325310,0.326760,0.328210,0.329658,0.331106,0.332553,0.334000,0.335445, 397 0.336890,0.338334,0.339777,0.341219,0.342661,0.344101,0.345541,0.346980, 398 0.348419,0.349856,0.351293,0.352729,0.354164,0.355598,0.357031,0.358463, 399 0.359895,0.361326,0.362756,0.364185,0.365613,0.367040,0.368467,0.369892, 400 0.371317,0.372741,0.374164,0.375586,0.377007,0.378428,0.379847,0.381266, 401 0.382683,0.384100,0.385516,0.386931,0.388345,0.389758,0.391170,0.392582, 402 0.393992,0.395401,0.396810,0.398218,0.399624,0.401030,0.402435,0.403838, 403 0.405241,0.406643,0.408044,0.409444,0.410843,0.412241,0.413638,0.415034, 404 0.416430,0.417824,0.419217,0.420609,0.422000,0.423390,0.424780,0.426168, 405 0.427555,0.428941,0.430326,0.431711,0.433094,0.434476,0.435857,0.437237, 406 0.438616,0.439994,0.441371,0.442747,0.444122,0.445496,0.446869,0.448241, 407 0.449611,0.450981,0.452350,0.453717,0.455084,0.456449,0.457813,0.459177, 408 0.460539,0.461900,0.463260,0.464619,0.465976,0.467333,0.468689,0.470043, 409 0.471397,0.472749,0.474100,0.475450,0.476799,0.478147,0.479494,0.480839, 410 0.482184,0.483527,0.484869,0.486210,0.487550,0.488889,0.490226,0.491563, 411 0.492898,0.494232,0.495565,0.496897,0.498228,0.499557,0.500885,0.502212, 412 0.503538,0.504863,0.506187,0.507509,0.508830,0.510150,0.511469,0.512786, 413 0.514103,0.515418,0.516732,0.518045,0.519356,0.520666,0.521975,0.523283, 414 0.524590,0.525895,0.527199,0.528502,0.529804,0.531104,0.532403,0.533701, 415 0.534998,0.536293,0.537587,0.538880,0.540171,0.541462,0.542751,0.544039, 416 0.545325,0.546610,0.547894,0.549177,0.550458,0.551738,0.553017,0.554294, 417 0.555570,0.556845,0.558119,0.559391,0.560662,0.561931,0.563199,0.564466, 418 0.565732,0.566996,0.568259,0.569521,0.570781,0.572040,0.573297,0.574553, 419 0.575808,0.577062,0.578314,0.579565,0.580814,0.582062,0.583309,0.584554, 420 0.585798,0.587040,0.588282,0.589521,0.590760,0.591997,0.593232,0.594466, 421 0.595699,0.596931,0.598161,0.599389,0.600616,0.601842,0.603067,0.604290, 422 0.605511,0.606731,0.607950,0.609167,0.610383,0.611597,0.612810,0.614022, 423 0.615232,0.616440,0.617647,0.618853,0.620057,0.621260,0.622461,0.623661, 424 0.624859,0.626056,0.627252,0.628446,0.629638,0.630829,0.632019,0.633207, 425 0.634393,0.635578,0.636762,0.637944,0.639124,0.640303,0.641481,0.642657, 426 0.643832,0.645005,0.646176,0.647346,0.648514,0.649681,0.650847,0.652011, 427 0.653173,0.654334,0.655493,0.656651,0.657807,0.658961,0.660114,0.661266, 428 0.662416,0.663564,0.664711,0.665856,0.667000,0.668142,0.669283,0.670422, 429 0.671559,0.672695,0.673829,0.674962,0.676093,0.677222,0.678350,0.679476, 430 0.680601,0.681724,0.682846,0.683965,0.685084,0.686200,0.687315,0.688429, 431 0.689541,0.690651,0.691759,0.692866,0.693971,0.695075,0.696177,0.697278, 432 0.698376,0.699473,0.700569,0.701663,0.702755,0.703845,0.704934,0.706021, 433 0.707107,0.708191,0.709273,0.710353,0.711432,0.712509,0.713585,0.714659, 434 0.715731,0.716801,0.717870,0.718937,0.720003,0.721066,0.722128,0.723188, 435 0.724247,0.725304,0.726359,0.727413,0.728464,0.729514,0.730563,0.731609, 436 0.732654,0.733697,0.734739,0.735779,0.736817,0.737853,0.738887,0.739920, 437 0.740951,0.741980,0.743008,0.744034,0.745058,0.746080,0.747101,0.748119, 438 0.749136,0.750152,0.751165,0.752177,0.753187,0.754195,0.755201,0.756206, 439 0.757209,0.758210,0.759209,0.760207,0.761202,0.762196,0.763188,0.764179, 440 0.765167,0.766154,0.767139,0.768122,0.769103,0.770083,0.771061,0.772036, 441 0.773010,0.773983,0.774953,0.775922,0.776888,0.777853,0.778817,0.779778, 442 0.780737,0.781695,0.782651,0.783605,0.784557,0.785507,0.786455,0.787402, 443 0.788346,0.789289,0.790230,0.791169,0.792107,0.793042,0.793975,0.794907, 444 0.795837,0.796765,0.797691,0.798615,0.799537,0.800458,0.801376,0.802293, 445 0.803208,0.804120,0.805031,0.805940,0.806848,0.807753,0.808656,0.809558, 446 0.810457,0.811355,0.812251,0.813144,0.814036,0.814926,0.815814,0.816701, 447 0.817585,0.818467,0.819348,0.820226,0.821103,0.821977,0.822850,0.823721, 448 0.824589,0.825456,0.826321,0.827184,0.828045,0.828904,0.829761,0.830616, 449 0.831470,0.832321,0.833170,0.834018,0.834863,0.835706,0.836548,0.837387, 450 0.838225,0.839060,0.839894,0.840725,0.841555,0.842383,0.843208,0.844032, 451 0.844854,0.845673,0.846491,0.847307,0.848120,0.848932,0.849742,0.850549, 452 0.851355,0.852159,0.852961,0.853760,0.854558,0.855354,0.856147,0.856939, 453 0.857729,0.858516,0.859302,0.860085,0.860867,0.861646,0.862424,0.863199, 454 0.863973,0.864744,0.865514,0.866281,0.867046,0.867809,0.868571,0.869330, 455 0.870087,0.870842,0.871595,0.872346,0.873095,0.873842,0.874587,0.875329, 456 0.876070,0.876809,0.877545,0.878280,0.879012,0.879743,0.880471,0.881197, 457 0.881921,0.882643,0.883363,0.884081,0.884797,0.885511,0.886223,0.886932, 458 0.887640,0.888345,0.889048,0.889750,0.890449,0.891146,0.891841,0.892534, 459 0.893224,0.893913,0.894599,0.895284,0.895966,0.896646,0.897325,0.898001, 460 0.898674,0.899346,0.900016,0.900683,0.901349,0.902012,0.902673,0.903332, 461 0.903989,0.904644,0.905297,0.905947,0.906596,0.907242,0.907886,0.908528, 462 0.909168,0.909806,0.910441,0.911075,0.911706,0.912335,0.912962,0.913587, 463 0.914210,0.914830,0.915449,0.916065,0.916679,0.917291,0.917901,0.918508, 464 0.919114,0.919717,0.920318,0.920917,0.921514,0.922109,0.922701,0.923291, 465 0.923880,0.924465,0.925049,0.925631,0.926210,0.926787,0.927363,0.927935, 466 0.928506,0.929075,0.929641,0.930205,0.930767,0.931327,0.931884,0.932440, 467 0.932993,0.933544,0.934093,0.934639,0.935184,0.935726,0.936266,0.936803, 468 0.937339,0.937872,0.938404,0.938932,0.939459,0.939984,0.940506,0.941026, 469 0.941544,0.942060,0.942573,0.943084,0.943593,0.944100,0.944605,0.945107, 470 0.945607,0.946105,0.946601,0.947094,0.947586,0.948075,0.948561,0.949046, 471 0.949528,0.950008,0.950486,0.950962,0.951435,0.951906,0.952375,0.952842, 472 0.953306,0.953768,0.954228,0.954686,0.955141,0.955594,0.956045,0.956494, 473 0.956940,0.957385,0.957826,0.958266,0.958703,0.959139,0.959572,0.960002, 474 0.960431,0.960857,0.961280,0.961702,0.962121,0.962538,0.962953,0.963366, 475 0.963776,0.964184,0.964590,0.964993,0.965394,0.965793,0.966190,0.966584, 476 0.966976,0.967366,0.967754,0.968139,0.968522,0.968903,0.969281,0.969657, 477 0.970031,0.970403,0.970772,0.971139,0.971504,0.971866,0.972226,0.972584, 478 0.972940,0.973293,0.973644,0.973993,0.974339,0.974684,0.975025,0.975365, 479 0.975702,0.976037,0.976370,0.976700,0.977028,0.977354,0.977677,0.977999, 480 0.978317,0.978634,0.978948,0.979260,0.979570,0.979877,0.980182,0.980485, 481 0.980785,0.981083,0.981379,0.981673,0.981964,0.982253,0.982539,0.982824, 482 0.983105,0.983385,0.983662,0.983937,0.984210,0.984480,0.984749,0.985014, 483 0.985278,0.985539,0.985798,0.986054,0.986308,0.986560,0.986809,0.987057, 484 0.987301,0.987544,0.987784,0.988022,0.988258,0.988491,0.988722,0.988950, 485 0.989177,0.989400,0.989622,0.989841,0.990058,0.990273,0.990485,0.990695, 486 0.990903,0.991108,0.991311,0.991511,0.991710,0.991906,0.992099,0.992291, 487 0.992480,0.992666,0.992850,0.993032,0.993212,0.993389,0.993564,0.993737, 488 0.993907,0.994075,0.994240,0.994404,0.994565,0.994723,0.994879,0.995033, 489 0.995185,0.995334,0.995481,0.995625,0.995767,0.995907,0.996045,0.996180, 490 0.996313,0.996443,0.996571,0.996697,0.996820,0.996941,0.997060,0.997176, 491 0.997290,0.997402,0.997511,0.997618,0.997723,0.997825,0.997925,0.998023, 492 0.998118,0.998211,0.998302,0.998390,0.998476,0.998559,0.998640,0.998719, 493 0.998795,0.998870,0.998941,0.999011,0.999078,0.999142,0.999205,0.999265, 494 0.999322,0.999378,0.999431,0.999481,0.999529,0.999575,0.999619,0.999660, 495 0.999699,0.999735,0.999769,0.999801,0.999831,0.999858,0.999882,0.999905, 496 0.999925,0.999942,0.999958,0.999971,0.999981,0.999989,0.999995,0.999999 497 }; 498 499 double sin( double x ) { 500 int index; 501 int quad; 502 503 index = 1024 * x / (M_PI * 0.5); 504 quad = ( index >> 10 ) & 3; 505 index &= 1023; 506 switch ( quad ) { 507 case 0: 508 return sintable[index]; 509 case 1: 510 return sintable[1023-index]; 511 case 2: 512 return -sintable[index]; 513 case 3: 514 return -sintable[1023-index]; 515 } 516 return 0; 517 } 518 519 520 double cos( double x ) { 521 int index; 522 int quad; 523 524 index = 1024 * x / (M_PI * 0.5); 525 quad = ( index >> 10 ) & 3; 526 index &= 1023; 527 switch ( quad ) { 528 case 3: 529 return sintable[index]; 530 case 0: 531 return sintable[1023-index]; 532 case 1: 533 return -sintable[index]; 534 case 2: 535 return -sintable[1023-index]; 536 } 537 return 0; 538 } 539 540 541 /* 542 void create_acostable( void ) { 543 int i; 544 FILE *fp; 545 float a; 546 547 fp = fopen("c:\\acostable.txt", "w"); 548 fprintf(fp, "float acostable[] = {"); 549 for (i = 0; i < 1024; i++) { 550 if (!(i & 7)) 551 fprintf(fp, "\n"); 552 a = acos( (float) -1 + i / 512 ); 553 fprintf(fp, "%1.8f,", a); 554 } 555 fprintf(fp, "\n}\n"); 556 fclose(fp); 557 } 558 */ 559 560 float acostable[] = { 561 3.14159265,3.07908248,3.05317551,3.03328655,3.01651113,3.00172442,2.98834964,2.97604422, 562 2.96458497,2.95381690,2.94362719,2.93393068,2.92466119,2.91576615,2.90720289,2.89893629, 563 2.89093699,2.88318015,2.87564455,2.86831188,2.86116621,2.85419358,2.84738169,2.84071962, 564 2.83419760,2.82780691,2.82153967,2.81538876,2.80934770,2.80341062,2.79757211,2.79182724, 565 2.78617145,2.78060056,2.77511069,2.76969824,2.76435988,2.75909250,2.75389319,2.74875926, 566 2.74368816,2.73867752,2.73372510,2.72882880,2.72398665,2.71919677,2.71445741,2.70976688, 567 2.70512362,2.70052613,2.69597298,2.69146283,2.68699438,2.68256642,2.67817778,2.67382735, 568 2.66951407,2.66523692,2.66099493,2.65678719,2.65261279,2.64847088,2.64436066,2.64028133, 569 2.63623214,2.63221238,2.62822133,2.62425835,2.62032277,2.61641398,2.61253138,2.60867440, 570 2.60484248,2.60103507,2.59725167,2.59349176,2.58975488,2.58604053,2.58234828,2.57867769, 571 2.57502832,2.57139977,2.56779164,2.56420354,2.56063509,2.55708594,2.55355572,2.55004409, 572 2.54655073,2.54307530,2.53961750,2.53617701,2.53275354,2.52934680,2.52595650,2.52258238, 573 2.51922417,2.51588159,2.51255441,2.50924238,2.50594525,2.50266278,2.49939476,2.49614096, 574 2.49290115,2.48967513,2.48646269,2.48326362,2.48007773,2.47690482,2.47374472,2.47059722, 575 2.46746215,2.46433933,2.46122860,2.45812977,2.45504269,2.45196720,2.44890314,2.44585034, 576 2.44280867,2.43977797,2.43675809,2.43374890,2.43075025,2.42776201,2.42478404,2.42181622, 577 2.41885841,2.41591048,2.41297232,2.41004380,2.40712480,2.40421521,2.40131491,2.39842379, 578 2.39554173,2.39266863,2.38980439,2.38694889,2.38410204,2.38126374,2.37843388,2.37561237, 579 2.37279910,2.36999400,2.36719697,2.36440790,2.36162673,2.35885335,2.35608768,2.35332964, 580 2.35057914,2.34783610,2.34510044,2.34237208,2.33965094,2.33693695,2.33423003,2.33153010, 581 2.32883709,2.32615093,2.32347155,2.32079888,2.31813284,2.31547337,2.31282041,2.31017388, 582 2.30753373,2.30489988,2.30227228,2.29965086,2.29703556,2.29442632,2.29182309,2.28922580, 583 2.28663439,2.28404881,2.28146900,2.27889490,2.27632647,2.27376364,2.27120637,2.26865460, 584 2.26610827,2.26356735,2.26103177,2.25850149,2.25597646,2.25345663,2.25094195,2.24843238, 585 2.24592786,2.24342836,2.24093382,2.23844420,2.23595946,2.23347956,2.23100444,2.22853408, 586 2.22606842,2.22360742,2.22115104,2.21869925,2.21625199,2.21380924,2.21137096,2.20893709, 587 2.20650761,2.20408248,2.20166166,2.19924511,2.19683280,2.19442469,2.19202074,2.18962092, 588 2.18722520,2.18483354,2.18244590,2.18006225,2.17768257,2.17530680,2.17293493,2.17056692, 589 2.16820274,2.16584236,2.16348574,2.16113285,2.15878367,2.15643816,2.15409630,2.15175805, 590 2.14942338,2.14709226,2.14476468,2.14244059,2.14011997,2.13780279,2.13548903,2.13317865, 591 2.13087163,2.12856795,2.12626757,2.12397047,2.12167662,2.11938600,2.11709859,2.11481435, 592 2.11253326,2.11025530,2.10798044,2.10570867,2.10343994,2.10117424,2.09891156,2.09665185, 593 2.09439510,2.09214129,2.08989040,2.08764239,2.08539725,2.08315496,2.08091550,2.07867884, 594 2.07644495,2.07421383,2.07198545,2.06975978,2.06753681,2.06531651,2.06309887,2.06088387, 595 2.05867147,2.05646168,2.05425445,2.05204979,2.04984765,2.04764804,2.04545092,2.04325628, 596 2.04106409,2.03887435,2.03668703,2.03450211,2.03231957,2.03013941,2.02796159,2.02578610, 597 2.02361292,2.02144204,2.01927344,2.01710710,2.01494300,2.01278113,2.01062146,2.00846399, 598 2.00630870,2.00415556,2.00200457,1.99985570,1.99770895,1.99556429,1.99342171,1.99128119, 599 1.98914271,1.98700627,1.98487185,1.98273942,1.98060898,1.97848051,1.97635399,1.97422942, 600 1.97210676,1.96998602,1.96786718,1.96575021,1.96363511,1.96152187,1.95941046,1.95730088, 601 1.95519310,1.95308712,1.95098292,1.94888050,1.94677982,1.94468089,1.94258368,1.94048818, 602 1.93839439,1.93630228,1.93421185,1.93212308,1.93003595,1.92795046,1.92586659,1.92378433, 603 1.92170367,1.91962459,1.91754708,1.91547113,1.91339673,1.91132385,1.90925250,1.90718266, 604 1.90511432,1.90304746,1.90098208,1.89891815,1.89685568,1.89479464,1.89273503,1.89067683, 605 1.88862003,1.88656463,1.88451060,1.88245794,1.88040664,1.87835668,1.87630806,1.87426076, 606 1.87221477,1.87017008,1.86812668,1.86608457,1.86404371,1.86200412,1.85996577,1.85792866, 607 1.85589277,1.85385809,1.85182462,1.84979234,1.84776125,1.84573132,1.84370256,1.84167495, 608 1.83964848,1.83762314,1.83559892,1.83357582,1.83155381,1.82953289,1.82751305,1.82549429, 609 1.82347658,1.82145993,1.81944431,1.81742973,1.81541617,1.81340362,1.81139207,1.80938151, 610 1.80737194,1.80536334,1.80335570,1.80134902,1.79934328,1.79733848,1.79533460,1.79333164, 611 1.79132959,1.78932843,1.78732817,1.78532878,1.78333027,1.78133261,1.77933581,1.77733985, 612 1.77534473,1.77335043,1.77135695,1.76936428,1.76737240,1.76538132,1.76339101,1.76140148, 613 1.75941271,1.75742470,1.75543743,1.75345090,1.75146510,1.74948002,1.74749565,1.74551198, 614 1.74352900,1.74154672,1.73956511,1.73758417,1.73560389,1.73362426,1.73164527,1.72966692, 615 1.72768920,1.72571209,1.72373560,1.72175971,1.71978441,1.71780969,1.71583556,1.71386199, 616 1.71188899,1.70991653,1.70794462,1.70597325,1.70400241,1.70203209,1.70006228,1.69809297, 617 1.69612416,1.69415584,1.69218799,1.69022062,1.68825372,1.68628727,1.68432127,1.68235571, 618 1.68039058,1.67842588,1.67646160,1.67449772,1.67253424,1.67057116,1.66860847,1.66664615, 619 1.66468420,1.66272262,1.66076139,1.65880050,1.65683996,1.65487975,1.65291986,1.65096028, 620 1.64900102,1.64704205,1.64508338,1.64312500,1.64116689,1.63920905,1.63725148,1.63529416, 621 1.63333709,1.63138026,1.62942366,1.62746728,1.62551112,1.62355517,1.62159943,1.61964388, 622 1.61768851,1.61573332,1.61377831,1.61182346,1.60986877,1.60791422,1.60595982,1.60400556, 623 1.60205142,1.60009739,1.59814349,1.59618968,1.59423597,1.59228235,1.59032882,1.58837536, 624 1.58642196,1.58446863,1.58251535,1.58056211,1.57860891,1.57665574,1.57470259,1.57274945, 625 1.57079633,1.56884320,1.56689007,1.56493692,1.56298375,1.56103055,1.55907731,1.55712403, 626 1.55517069,1.55321730,1.55126383,1.54931030,1.54735668,1.54540297,1.54344917,1.54149526, 627 1.53954124,1.53758710,1.53563283,1.53367843,1.53172389,1.52976919,1.52781434,1.52585933, 628 1.52390414,1.52194878,1.51999323,1.51803748,1.51608153,1.51412537,1.51216900,1.51021240, 629 1.50825556,1.50629849,1.50434117,1.50238360,1.50042576,1.49846765,1.49650927,1.49455060, 630 1.49259163,1.49063237,1.48867280,1.48671291,1.48475270,1.48279215,1.48083127,1.47887004, 631 1.47690845,1.47494650,1.47298419,1.47102149,1.46905841,1.46709493,1.46513106,1.46316677, 632 1.46120207,1.45923694,1.45727138,1.45530538,1.45333893,1.45137203,1.44940466,1.44743682, 633 1.44546850,1.44349969,1.44153038,1.43956057,1.43759024,1.43561940,1.43364803,1.43167612, 634 1.42970367,1.42773066,1.42575709,1.42378296,1.42180825,1.41983295,1.41785705,1.41588056, 635 1.41390346,1.41192573,1.40994738,1.40796840,1.40598877,1.40400849,1.40202755,1.40004594, 636 1.39806365,1.39608068,1.39409701,1.39211264,1.39012756,1.38814175,1.38615522,1.38416795, 637 1.38217994,1.38019117,1.37820164,1.37621134,1.37422025,1.37222837,1.37023570,1.36824222, 638 1.36624792,1.36425280,1.36225684,1.36026004,1.35826239,1.35626387,1.35426449,1.35226422, 639 1.35026307,1.34826101,1.34625805,1.34425418,1.34224937,1.34024364,1.33823695,1.33622932, 640 1.33422072,1.33221114,1.33020059,1.32818904,1.32617649,1.32416292,1.32214834,1.32013273, 641 1.31811607,1.31609837,1.31407960,1.31205976,1.31003885,1.30801684,1.30599373,1.30396951, 642 1.30194417,1.29991770,1.29789009,1.29586133,1.29383141,1.29180031,1.28976803,1.28773456, 643 1.28569989,1.28366400,1.28162688,1.27958854,1.27754894,1.27550809,1.27346597,1.27142257, 644 1.26937788,1.26733189,1.26528459,1.26323597,1.26118602,1.25913471,1.25708205,1.25502803, 645 1.25297262,1.25091583,1.24885763,1.24679802,1.24473698,1.24267450,1.24061058,1.23854519, 646 1.23647833,1.23440999,1.23234015,1.23026880,1.22819593,1.22612152,1.22404557,1.22196806, 647 1.21988898,1.21780832,1.21572606,1.21364219,1.21155670,1.20946958,1.20738080,1.20529037, 648 1.20319826,1.20110447,1.19900898,1.19691177,1.19481283,1.19271216,1.19060973,1.18850553, 649 1.18639955,1.18429178,1.18218219,1.18007079,1.17795754,1.17584244,1.17372548,1.17160663, 650 1.16948589,1.16736324,1.16523866,1.16311215,1.16098368,1.15885323,1.15672081,1.15458638, 651 1.15244994,1.15031147,1.14817095,1.14602836,1.14388370,1.14173695,1.13958808,1.13743709, 652 1.13528396,1.13312866,1.13097119,1.12881153,1.12664966,1.12448556,1.12231921,1.12015061, 653 1.11797973,1.11580656,1.11363107,1.11145325,1.10927308,1.10709055,1.10490563,1.10271831, 654 1.10052856,1.09833638,1.09614174,1.09394462,1.09174500,1.08954287,1.08733820,1.08513098, 655 1.08292118,1.08070879,1.07849378,1.07627614,1.07405585,1.07183287,1.06960721,1.06737882, 656 1.06514770,1.06291382,1.06067715,1.05843769,1.05619540,1.05395026,1.05170226,1.04945136, 657 1.04719755,1.04494080,1.04268110,1.04041841,1.03815271,1.03588399,1.03361221,1.03133735, 658 1.02905939,1.02677830,1.02449407,1.02220665,1.01991603,1.01762219,1.01532509,1.01302471, 659 1.01072102,1.00841400,1.00610363,1.00378986,1.00147268,0.99915206,0.99682798,0.99450039, 660 0.99216928,0.98983461,0.98749636,0.98515449,0.98280898,0.98045980,0.97810691,0.97575030, 661 0.97338991,0.97102573,0.96865772,0.96628585,0.96391009,0.96153040,0.95914675,0.95675912, 662 0.95436745,0.95197173,0.94957191,0.94716796,0.94475985,0.94234754,0.93993099,0.93751017, 663 0.93508504,0.93265556,0.93022170,0.92778341,0.92534066,0.92289341,0.92044161,0.91798524, 664 0.91552424,0.91305858,0.91058821,0.90811309,0.90563319,0.90314845,0.90065884,0.89816430, 665 0.89566479,0.89316028,0.89065070,0.88813602,0.88561619,0.88309116,0.88056088,0.87802531, 666 0.87548438,0.87293806,0.87038629,0.86782901,0.86526619,0.86269775,0.86012366,0.85754385, 667 0.85495827,0.85236686,0.84976956,0.84716633,0.84455709,0.84194179,0.83932037,0.83669277, 668 0.83405893,0.83141877,0.82877225,0.82611928,0.82345981,0.82079378,0.81812110,0.81544172, 669 0.81275556,0.81006255,0.80736262,0.80465570,0.80194171,0.79922057,0.79649221,0.79375655, 670 0.79101352,0.78826302,0.78550497,0.78273931,0.77996593,0.77718475,0.77439569,0.77159865, 671 0.76879355,0.76598029,0.76315878,0.76032891,0.75749061,0.75464376,0.75178826,0.74892402, 672 0.74605092,0.74316887,0.74027775,0.73737744,0.73446785,0.73154885,0.72862033,0.72568217, 673 0.72273425,0.71977644,0.71680861,0.71383064,0.71084240,0.70784376,0.70483456,0.70181469, 674 0.69878398,0.69574231,0.69268952,0.68962545,0.68654996,0.68346288,0.68036406,0.67725332, 675 0.67413051,0.67099544,0.66784794,0.66468783,0.66151492,0.65832903,0.65512997,0.65191753, 676 0.64869151,0.64545170,0.64219789,0.63892987,0.63564741,0.63235028,0.62903824,0.62571106, 677 0.62236849,0.61901027,0.61563615,0.61224585,0.60883911,0.60541564,0.60197515,0.59851735, 678 0.59504192,0.59154856,0.58803694,0.58450672,0.58095756,0.57738911,0.57380101,0.57019288, 679 0.56656433,0.56291496,0.55924437,0.55555212,0.55183778,0.54810089,0.54434099,0.54055758, 680 0.53675018,0.53291825,0.52906127,0.52517867,0.52126988,0.51733431,0.51337132,0.50938028, 681 0.50536051,0.50131132,0.49723200,0.49312177,0.48897987,0.48480547,0.48059772,0.47635573, 682 0.47207859,0.46776530,0.46341487,0.45902623,0.45459827,0.45012983,0.44561967,0.44106652, 683 0.43646903,0.43182577,0.42713525,0.42239588,0.41760600,0.41276385,0.40786755,0.40291513, 684 0.39790449,0.39283339,0.38769946,0.38250016,0.37723277,0.37189441,0.36648196,0.36099209, 685 0.35542120,0.34976542,0.34402054,0.33818204,0.33224495,0.32620390,0.32005298,0.31378574, 686 0.30739505,0.30087304,0.29421096,0.28739907,0.28042645,0.27328078,0.26594810,0.25841250, 687 0.25065566,0.24265636,0.23438976,0.22582651,0.21693146,0.20766198,0.19796546,0.18777575, 688 0.17700769,0.16554844,0.15324301,0.13986823,0.12508152,0.10830610,0.08841715,0.06251018, 689 } 690 691 double acos( double x ) { 692 int index; 693 694 if (x < -1) 695 x = -1; 696 if (x > 1) 697 x = 1; 698 index = (float) (1.0 + x) * 511.9; 699 return acostable[index]; 700 } 701 702 double atan2( double y, double x ) { 703 float base; 704 float temp; 705 float dir; 706 float test; 707 int i; 708 709 if ( x < 0 ) { 710 if ( y >= 0 ) { 711 // quad 1 712 base = M_PI / 2; 713 temp = x; 714 x = y; 715 y = -temp; 716 } else { 717 // quad 2 718 base = M_PI; 719 x = -x; 720 y = -y; 721 } 722 } else { 723 if ( y < 0 ) { 724 // quad 3 725 base = 3 * M_PI / 2; 726 temp = x; 727 x = -y; 728 y = temp; 729 } 730 } 731 732 if ( y > x ) { 733 base += M_PI/2; 734 temp = x; 735 x = y; 736 y = temp; 737 dir = -1; 738 } else { 739 dir = 1; 740 } 741 742 // calcualte angle in octant 0 743 if ( x == 0 ) { 744 return base; 745 } 746 y /= x; 747 748 for ( i = 0 ; i < 512 ; i++ ) { 749 test = sintable[i] / sintable[1023-i]; 750 if ( test > y ) { 751 break; 752 } 753 } 754 755 return base + dir * i * ( M_PI/2048); 756 } 757 758 759 #endif 760 761 #ifdef Q3_VM 762 // bk001127 - guarded this tan replacement 763 // ld: undefined versioned symbol name tan@@GLIBC_2.0 764 double tan( double x ) { 765 return sin(x) / cos(x); 766 } 767 #endif 768 769 770 static int randSeed = 0; 771 772 void srand( unsigned seed ) { 773 randSeed = seed; 774 } 775 776 int rand( void ) { 777 randSeed = (69069 * randSeed + 1); 778 return randSeed & 0x7fff; 779 } 780 781 double atof( const char *string ) { 782 float sign; 783 float value; 784 int c; 785 786 787 // skip whitespace 788 while ( *string <= ' ' ) { 789 if ( !*string ) { 790 return 0; 791 } 792 string++; 793 } 794 795 // check sign 796 switch ( *string ) { 797 case '+': 798 string++; 799 sign = 1; 800 break; 801 case '-': 802 string++; 803 sign = -1; 804 break; 805 default: 806 sign = 1; 807 break; 808 } 809 810 // read digits 811 value = 0; 812 c = string[0]; 813 if ( c != '.' ) { 814 do { 815 c = *string++; 816 if ( c < '0' || c > '9' ) { 817 break; 818 } 819 c -= '0'; 820 value = value * 10 + c; 821 } while ( 1 ); 822 } else { 823 string++; 824 } 825 826 // check for decimal point 827 if ( c == '.' ) { 828 double fraction; 829 830 fraction = 0.1; 831 do { 832 c = *string++; 833 if ( c < '0' || c > '9' ) { 834 break; 835 } 836 c -= '0'; 837 value += c * fraction; 838 fraction *= 0.1; 839 } while ( 1 ); 840 841 } 842 843 // not handling 10e10 notation... 844 845 return value * sign; 846 } 847 848 double _atof( const char **stringPtr ) { 849 const char *string; 850 float sign; 851 float value; 852 int c = '0'; // bk001211 - uninitialized use possible 853 854 string = *stringPtr; 855 856 // skip whitespace 857 while ( *string <= ' ' ) { 858 if ( !*string ) { 859 *stringPtr = string; 860 return 0; 861 } 862 string++; 863 } 864 865 // check sign 866 switch ( *string ) { 867 case '+': 868 string++; 869 sign = 1; 870 break; 871 case '-': 872 string++; 873 sign = -1; 874 break; 875 default: 876 sign = 1; 877 break; 878 } 879 880 // read digits 881 value = 0; 882 if ( string[0] != '.' ) { 883 do { 884 c = *string++; 885 if ( c < '0' || c > '9' ) { 886 break; 887 } 888 c -= '0'; 889 value = value * 10 + c; 890 } while ( 1 ); 891 } 892 893 // check for decimal point 894 if ( c == '.' ) { 895 double fraction; 896 897 fraction = 0.1; 898 do { 899 c = *string++; 900 if ( c < '0' || c > '9' ) { 901 break; 902 } 903 c -= '0'; 904 value += c * fraction; 905 fraction *= 0.1; 906 } while ( 1 ); 907 908 } 909 910 // not handling 10e10 notation... 911 *stringPtr = string; 912 913 return value * sign; 914 } 915 916 917 // bk001120 - presumably needed for Mac 918 //#if !defined ( _MSC_VER ) && ! defined ( __linux__ ) 919 920 // bk001127 - undid undo 921 #if defined ( Q3_VM ) 922 int atoi( const char *string ) { 923 int sign; 924 int value; 925 int c; 926 927 928 // skip whitespace 929 while ( *string <= ' ' ) { 930 if ( !*string ) { 931 return 0; 932 } 933 string++; 934 } 935 936 // check sign 937 switch ( *string ) { 938 case '+': 939 string++; 940 sign = 1; 941 break; 942 case '-': 943 string++; 944 sign = -1; 945 break; 946 default: 947 sign = 1; 948 break; 949 } 950 951 // read digits 952 value = 0; 953 do { 954 c = *string++; 955 if ( c < '0' || c > '9' ) { 956 break; 957 } 958 c -= '0'; 959 value = value * 10 + c; 960 } while ( 1 ); 961 962 // not handling 10e10 notation... 963 964 return value * sign; 965 } 966 967 968 int _atoi( const char **stringPtr ) { 969 int sign; 970 int value; 971 int c; 972 const char *string; 973 974 string = *stringPtr; 975 976 // skip whitespace 977 while ( *string <= ' ' ) { 978 if ( !*string ) { 979 return 0; 980 } 981 string++; 982 } 983 984 // check sign 985 switch ( *string ) { 986 case '+': 987 string++; 988 sign = 1; 989 break; 990 case '-': 991 string++; 992 sign = -1; 993 break; 994 default: 995 sign = 1; 996 break; 997 } 998 999 // read digits 1000 value = 0; 1001 do { 1002 c = *string++; 1003 if ( c < '0' || c > '9' ) { 1004 break; 1005 } 1006 c -= '0'; 1007 value = value * 10 + c; 1008 } while ( 1 ); 1009 1010 // not handling 10e10 notation... 1011 1012 *stringPtr = string; 1013 1014 return value * sign; 1015 } 1016 1017 int abs( int n ) { 1018 return n < 0 ? -n : n; 1019 } 1020 1021 double fabs( double x ) { 1022 return x < 0 ? -x : x; 1023 } 1024 1025 1026 1027 //========================================================= 1028 1029 1030 #define ALT 0x00000001 /* alternate form */ 1031 #define HEXPREFIX 0x00000002 /* add 0x or 0X prefix */ 1032 #define LADJUST 0x00000004 /* left adjustment */ 1033 #define LONGDBL 0x00000008 /* long double */ 1034 #define LONGINT 0x00000010 /* long integer */ 1035 #define QUADINT 0x00000020 /* quad integer */ 1036 #define SHORTINT 0x00000040 /* short integer */ 1037 #define ZEROPAD 0x00000080 /* zero (as opposed to blank) pad */ 1038 #define FPT 0x00000100 /* floating point number */ 1039 1040 #define to_digit(c) ((c) - '0') 1041 #define is_digit(c) ((unsigned)to_digit(c) <= 9) 1042 #define to_char(n) ((n) + '0') 1043 1044 void AddInt( char **buf_p, int val, int width, int flags ) { 1045 char text[32]; 1046 int digits; 1047 int signedVal; 1048 char *buf; 1049 1050 digits = 0; 1051 signedVal = val; 1052 if ( val < 0 ) { 1053 val = -val; 1054 } 1055 do { 1056 text[digits++] = '0' + val % 10; 1057 val /= 10; 1058 } while ( val ); 1059 1060 if ( signedVal < 0 ) { 1061 text[digits++] = '-'; 1062 } 1063 1064 buf = *buf_p; 1065 1066 if( !( flags & LADJUST ) ) { 1067 while ( digits < width ) { 1068 *buf++ = ( flags & ZEROPAD ) ? '0' : ' '; 1069 width--; 1070 } 1071 } 1072 1073 while ( digits-- ) { 1074 *buf++ = text[digits]; 1075 width--; 1076 } 1077 1078 if( flags & LADJUST ) { 1079 while ( width-- ) { 1080 *buf++ = ( flags & ZEROPAD ) ? '0' : ' '; 1081 } 1082 } 1083 1084 *buf_p = buf; 1085 } 1086 1087 void AddFloat( char **buf_p, float fval, int width, int prec ) { 1088 char text[32]; 1089 int digits; 1090 float signedVal; 1091 char *buf; 1092 int val; 1093 1094 // get the sign 1095 signedVal = fval; 1096 if ( fval < 0 ) { 1097 fval = -fval; 1098 } 1099 1100 // write the float number 1101 digits = 0; 1102 val = (int)fval; 1103 do { 1104 text[digits++] = '0' + val % 10; 1105 val /= 10; 1106 } while ( val ); 1107 1108 if ( signedVal < 0 ) { 1109 text[digits++] = '-'; 1110 } 1111 1112 buf = *buf_p; 1113 1114 while ( digits < width ) { 1115 *buf++ = ' '; 1116 width--; 1117 } 1118 1119 while ( digits-- ) { 1120 *buf++ = text[digits]; 1121 } 1122 1123 *buf_p = buf; 1124 1125 if (prec < 0) 1126 prec = 6; 1127 // write the fraction 1128 digits = 0; 1129 while (digits < prec) { 1130 fval -= (int) fval; 1131 fval *= 10.0; 1132 val = (int) fval; 1133 text[digits++] = '0' + val % 10; 1134 } 1135 1136 if (digits > 0) { 1137 buf = *buf_p; 1138 *buf++ = '.'; 1139 for (prec = 0; prec < digits; prec++) { 1140 *buf++ = text[prec]; 1141 } 1142 *buf_p = buf; 1143 } 1144 } 1145 1146 1147 void AddString( char **buf_p, char *string, int width, int prec ) { 1148 int size; 1149 char *buf; 1150 1151 buf = *buf_p; 1152 1153 if ( string == NULL ) { 1154 string = "(null)"; 1155 prec = -1; 1156 } 1157 1158 if ( prec >= 0 ) { 1159 for( size = 0; size < prec; size++ ) { 1160 if( string[size] == '\0' ) { 1161 break; 1162 } 1163 } 1164 } 1165 else { 1166 size = strlen( string ); 1167 } 1168 1169 width -= size; 1170 1171 while( size-- ) { 1172 *buf++ = *string++; 1173 } 1174 1175 while( width-- > 0 ) { 1176 *buf++ = ' '; 1177 } 1178 1179 *buf_p = buf; 1180 } 1181 1182 /* 1183 vsprintf 1184 1185 I'm not going to support a bunch of the more arcane stuff in here 1186 just to keep it simpler. For example, the '*' and '$' are not 1187 currently supported. I've tried to make it so that it will just 1188 parse and ignore formats we don't support. 1189 */ 1190 int vsprintf( char *buffer, const char *fmt, va_list argptr ) { 1191 int *arg; 1192 char *buf_p; 1193 char ch; 1194 int flags; 1195 int width; 1196 int prec; 1197 int n; 1198 char sign; 1199 1200 buf_p = buffer; 1201 arg = (int *)argptr; 1202 1203 while( qtrue ) { 1204 // run through the format string until we hit a '%' or '\0' 1205 for ( ch = *fmt; (ch = *fmt) != '\0' && ch != '%'; fmt++ ) { 1206 *buf_p++ = ch; 1207 } 1208 if ( ch == '\0' ) { 1209 goto done; 1210 } 1211 1212 // skip over the '%' 1213 fmt++; 1214 1215 // reset formatting state 1216 flags = 0; 1217 width = 0; 1218 prec = -1; 1219 sign = '\0'; 1220 1221 rflag: 1222 ch = *fmt++; 1223 reswitch: 1224 switch( ch ) { 1225 case '-': 1226 flags |= LADJUST; 1227 goto rflag; 1228 case '.': 1229 n = 0; 1230 while( is_digit( ( ch = *fmt++ ) ) ) { 1231 n = 10 * n + ( ch - '0' ); 1232 } 1233 prec = n < 0 ? -1 : n; 1234 goto reswitch; 1235 case '0': 1236 flags |= ZEROPAD; 1237 goto rflag; 1238 case '1': 1239 case '2': 1240 case '3': 1241 case '4': 1242 case '5': 1243 case '6': 1244 case '7': 1245 case '8': 1246 case '9': 1247 n = 0; 1248 do { 1249 n = 10 * n + ( ch - '0' ); 1250 ch = *fmt++; 1251 } while( is_digit( ch ) ); 1252 width = n; 1253 goto reswitch; 1254 case 'c': 1255 *buf_p++ = (char)*arg; 1256 arg++; 1257 break; 1258 case 'd': 1259 case 'i': 1260 AddInt( &buf_p, *arg, width, flags ); 1261 arg++; 1262 break; 1263 case 'f': 1264 AddFloat( &buf_p, *(double *)arg, width, prec ); 1265 #ifdef __LCC__ 1266 arg += 1; // everything is 32 bit in my compiler 1267 #else 1268 arg += 2; 1269 #endif 1270 break; 1271 case 's': 1272 AddString( &buf_p, (char *)*arg, width, prec ); 1273 arg++; 1274 break; 1275 case '%': 1276 *buf_p++ = ch; 1277 break; 1278 default: 1279 *buf_p++ = (char)*arg; 1280 arg++; 1281 break; 1282 } 1283 } 1284 1285 done: 1286 *buf_p = 0; 1287 return buf_p - buffer; 1288 } 1289 1290 /* this is really crappy */ 1291 int sscanf( const char *buffer, const char *fmt, ... ) { 1292 int cmd; 1293 int **arg; 1294 int count; 1295 1296 arg = (int **)&fmt + 1; 1297 count = 0; 1298 1299 while ( *fmt ) { 1300 if ( fmt[0] != '%' ) { 1301 fmt++; 1302 continue; 1303 } 1304 1305 cmd = fmt[1]; 1306 fmt += 2; 1307 1308 switch ( cmd ) { 1309 case 'i': 1310 case 'd': 1311 case 'u': 1312 **arg = _atoi( &buffer ); 1313 break; 1314 case 'f': 1315 *(float *)*arg = _atof( &buffer ); 1316 break; 1317 } 1318 arg++; 1319 } 1320 1321 return count; 1322 } 1323 1324 #endif