| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571 | /* -*- mode: c; tab-width: 4; c-basic-offset: 3; c-file-style: "linux" -*- *///// Copyright (c) 2009, Wei Mingzhi <whistler_wmz@users.sf.net>.// Portions Copyright (c) 2004, Pierre-Marie Baty.// Portions Copyright (c) 2009, netwan.//// All rights reserved.//// This file is part of SDLPAL.//// SDLPAL is free software: you can redistribute it and/or modify// it under the terms of the GNU General Public License as published by// the Free Software Foundation, either version 3 of the License, or// (at your option) any later version.//// This program is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the// GNU General Public License for more details.//// You should have received a copy of the GNU General Public License// along with this program.  If not, see <http://www.gnu.org/licenses/>.//#include "util.h"#include "input.h"#ifdef PAL_HAS_NATIVEMIDI#include "midi.h"#endif#if SDL_VERSION_ATLEAST(2, 0, 0)#include "SDL_messagebox.h"#endifvoidtrim(   char *str)/*++  Purpose:    Remove the leading and trailing spaces in a string.  Parameters:    str - the string to proceed.  Return value:    None.--*/{   int pos = 0;   char *dest = str;   //   // skip leading blanks   //   while (str[pos] <= ' ' && str[pos] > 0)      pos++;   while (str[pos])   {      *(dest++) = str[pos];      pos++;   }   *(dest--) = '\0'; // store the null   //   // remove trailing blanks   //   while (dest >= str && *dest <= ' ' && *dest > 0)      *(dest--) = '\0';}char *va(   const char *format,   ...)/*++  Purpose:    Does a varargs printf into a temp buffer, so we don't need to have    varargs versions of all text functions.  Parameters:    format - the format string.  Return value:    Pointer to the result string.--*/{   static char string[256];   va_list     argptr;   va_start(argptr, format);   vsnprintf(string, 256, format, argptr);   va_end(argptr);   return string;}/* * RNG code based on RACC by Pierre-Marie Baty. * http://racc.bots-united.com * * Copyright (c) 2004, Pierre-Marie Baty * All rights reserved. * * Redistribution and use in source and binary forms, with or * without modification, are permitted provided that the following * conditions are met: * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * Neither the name of the RACC nor the names of its contributors * may be used to endorse or promote products derived from this * software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. *///// Our random number generator's seed.//static int glSeed = 0;static voidlsrand(   unsigned int iInitialSeed)/*++  Purpose:    This function initializes the random seed based on the initial seed value passed in the    iInitialSeed parameter.  Parameters:    [IN]  iInitialSeed - The initial random seed.  Return value:    None.--*/{   //   // fill in the initial seed of the random number generator   //   glSeed = 1664525L * iInitialSeed + 1013904223L;}static intlrand(   void)/*++  Purpose:    This function is the equivalent of the rand() standard C library function, except that    whereas rand() works only with short integers (i.e. not above 32767), this function is    able to generate 32-bit random numbers.  Parameters:    None.  Return value:    The generated random number.--*/{   if (glSeed == 0) // if the random seed isn't initialized...      lsrand((unsigned int)time(NULL)); // initialize it first   glSeed = 1664525L * glSeed + 1013904223L; // do some twisted math (infinite suite)   return ((glSeed >> 1) + 1073741824L); // and return the result.}intRandomLong(   int from,   int to)/*++  Purpose:    This function returns a random integer number between (and including) the starting and    ending values passed by parameters from and to.  Parameters:    from - the starting value.    to - the ending value.  Return value:    The generated random number.--*/{   if (to <= from)      return from;   return from + lrand() / (INT_MAX / (to - from + 1));}floatRandomFloat(   float from,   float to)/*++  Purpose:    This function returns a random floating-point number between (and including) the starting    and ending values passed by parameters from and to.  Parameters:    from - the starting value.    to - the ending value.  Return value:    The generated random number.--*/{   if (to <= from)      return from;   return from + (float)lrand() / (INT_MAX / (to - from));}voidUTIL_Delay(   unsigned int ms){   unsigned int t = SDL_GetTicks() + ms;   while (PAL_PollEvent(NULL));   while (SDL_GetTicks() < t)   {      SDL_Delay(1);      while (PAL_PollEvent(NULL));   }#ifdef PAL_HAS_NATIVEMIDI   MIDI_CheckLoop();#endif}voidTerminateOnError(   const char *fmt,   ...)// This function terminates the game because of an error and// prints the message string pointed to by fmt both in the// console and in a messagebox.{   va_list argptr;   char string[256];   extern VOID PAL_Shutdown(VOID);   // concatenate all the arguments in one string   va_start(argptr, fmt);   vsnprintf(string, sizeof(string), fmt, argptr);   va_end(argptr);   fprintf(stderr, "\nFATAL ERROR: %s\n", string);#if SDL_VERSION_ATLEAST(2, 0, 0)   SDL_ShowSimpleMessageBox(0, "FATAL ERROR", string, NULL);#else#ifdef _WIN32   MessageBoxA(0, string, "FATAL ERROR", MB_ICONERROR);#endif#ifdef __linux__   system(va("beep; xmessage -center \"FATAL ERROR: %s\"", string));#endif#if defined(__SYMBIAN32__)   UTIL_WriteLog(LOG_DEBUG,"[0x%08x][%s][%s] - %s",(long)TerminateOnError,"TerminateOnError",__FILE__, string);   SDL_Delay(3000);#endif#endif#ifdef _DEBUG   assert(!"TerminateOnError()"); // allows jumping to debugger#endifPAL_Shutdown();#if defined (NDS)   while (1);#else   exit(255);#endif}void *UTIL_malloc(   size_t               buffer_size){   // handy wrapper for operations we always forget, like checking malloc's returned pointer.   void *buffer;   // first off, check if buffer size is valid   if (buffer_size == 0)      TerminateOnError("UTIL_malloc() called with invalid buffer size: %d\n", buffer_size);   buffer = malloc(buffer_size); // allocate real memory space   // last check, check if malloc call succeeded   if (buffer == NULL)      TerminateOnError("UTIL_malloc() failure for %d bytes (out of memory?)\n", buffer_size);   return buffer; // nothing went wrong, so return buffer pointer}void *UTIL_calloc(   size_t               n,   size_t               size){   // handy wrapper for operations we always forget, like checking calloc's returned pointer.   void *buffer;   // first off, check if buffer size is valid   if (n == 0 || size == 0)      TerminateOnError ("UTIL_calloc() called with invalid parameters\n");   buffer = calloc(n, size); // allocate real memory space   // last check, check if malloc call succeeded   if (buffer == NULL)      TerminateOnError("UTIL_calloc() failure for %d bytes (out of memory?)\n", size * n);   return buffer; // nothing went wrong, so return buffer pointer}FILE *UTIL_OpenRequiredFile(   LPCSTR            lpszFileName)/*++  Purpose:    Open a required file. If fails, quit the program.  Parameters:    [IN]  lpszFileName - file name to open.  Return value:    Pointer to the file.--*/{   FILE         *fp;   fp = fopen(va("%s%s", PAL_PREFIX, lpszFileName), "rb");#ifndef _WIN32   if (fp == NULL)   {	  //	  // try converting the filename to upper-case.	  //	  char *pBuf = strdup(lpszFileName);	  char *p = pBuf;	  while (*p)	  {		 if (*p >= 'a' && *p <= 'z')		 {			*p -= 'a' - 'A';		 }		 p++;	  }	  fp = fopen(va("%s%s", PAL_PREFIX, pBuf), "rb");	  free(pBuf);   }#endif   if (fp == NULL)   {      TerminateOnError("File not found: %s!\n", lpszFileName);   }   return fp;}FILE *UTIL_OpenFile(   LPCSTR            lpszFileName)/*++  Purpose:    Open a file. If fails, return NULL.  Parameters:    [IN]  lpszFileName - file name to open.  Return value:    Pointer to the file.--*/{   FILE         *fp;   fp = fopen(va("%s%s", PAL_PREFIX, lpszFileName), "rb");#ifndef _WIN32   if (fp == NULL)   {	  //	  // try converting the filename to upper-case.	  //	  char *pBuf = strdup(lpszFileName);	  char *p = pBuf;	  while (*p)	  {		 if (*p >= 'a' && *p <= 'z')		 {			*p -= 'a' - 'A';		 }		 p++;	  }	  fp = fopen(va("%s%s", PAL_PREFIX, pBuf), "rb");	  free(pBuf);   }#endif   return fp;}VOIDUTIL_CloseFile(   FILE             *fp)/*++  Purpose:    Close a file.  Parameters:    [IN]  fp - file handle to be closed.  Return value:    None.--*/{   if (fp != NULL)   {      fclose(fp);   }}#ifdef ENABLE_LOGstatic FILE *pLogFile = NULL;FILE *UTIL_OpenLog(   VOID){   if ((pLogFile = fopen(_PATH_LOG, "a+")) == NULL)   {      return NULL;   }   return pLogFile;}VOIDUTIL_CloseLog(   VOID){   if (pLogFile != NULL)   {      fclose(pLogFile);   }}VOIDUTIL_WriteLog(   int             Priority,   const char     *Fmt,   ...){   va_list       vaa;   time_t        lTime;   struct tm    *curTime;   char          szDateBuf[260];   time(&lTime);   if ((Priority < LOG_EMERG) || (Priority >= LOG_LAST_PRIORITY))   {      return;   }   curTime = localtime(&lTime);   strftime(szDateBuf, 128, "%Y-%m-%d   %H:%M:%S", curTime);   szDateBuf[strlen(szDateBuf) - 1] = '\0'; //remove the   va_start(vaa,Fmt);   fprintf(pLogFile, "[%s]", szDateBuf);   vfprintf(pLogFile, Fmt, vaa);   fprintf(pLogFile, "\n");   fflush(pLogFile);   va_end(vaa);}#endif
 |