/******************************************************************************* This file is Part of the ZEngine Library for 2D game development. Copyright (C) 2002, 2003 James Turk Licensed under a BSD-style license. The maintainer of this library is James Turk (james@conceptofzero.net) and the home of this Library is http://www.zengine.sourceforge.net *******************************************************************************/ /*! \file ZE_Utility.h \brief Definition file for ZEngine Utilities. Definition file for ZEngine Utilities which are used throughout the engine and can be used in conjunction with ZEngine.
$Id: ZE_Utility.h,v 1.8 2003/10/13 21:40:05 cozman Exp $
\author James Turk **/ #ifndef __ze_utility_h__ #define __ze_utility_h__ #include "ZE_Includes.h" namespace ZE { /*! \brief Parses a std::string and interprets variable arguments, similar to sprintf. Takes % identifiers out of fmtstr and parses them, replacing them with cooresponding values in the variable arguments list. For more detail view stdarg documentation. \param fmtstr defines format of resulting std::string \param ... variable number of arguments after fmtstr \return std::string of parsed and combined std::string **/ std::string FormatStr(const char *fmtstr, ...); /*! \brief Extracts a SDL_RWops memory structure from a zip archive. Attempts to open a file from within a zipfile and return a SDL_RWops which can be used to load a resource from memory. Used internally, generally shouldn't be called by users. \param zipname Name of zip-format archive to open. \param filename Name of file within archive to access. \return On success, pointer to SDL_RWops, on failure, NULL. \since 0.8.5 **/ SDL_RWops* RWFromZip(std::string zipname, std::string filename); /*! \brief Rounds a number up to the nearest power of two. Rounds a number up to the next highest power of two, used for OpenGL textures. (From testgl.c) Used internally, generally shouldn't be called by users. \param in Number to round up. \return num rounded up to closest power of two. \since 0.8.6 **/ int PowerOfTwo(int num); /*! \brief Converts an SDL_Surface to an OpenGL texture ID. Given an SDL_Surface returns a texture ID representing the OpenGL texture assigned to that surface. Also returns texture coordinates via texcoord parameter. (From SDL_GL_LoadTexture in testgl.c) Used internally, generally shouldn't be called by users. \param surface SDL_Surface to assign an OpenGL ID, returns unmodified. \param texcoord Should be an array of 4 GLfloat, assigned texture coordinates for OpenGL use. \return OpenGL texture ID for SDL_Surface, 0 if an error occurs. \since 0.8.6 **/ GLuint SurfaceToTexture(SDL_Surface *surface, GLfloat *texcoord); /*! \brief Properly free SDL_Surface. Safely free an SDL_Surface* and set it to NULL. \param image Image to free and set to NULL. **/ void FreeImage(SDL_Surface *&image); #ifdef USE_SDL_MIXER /*! \brief Properly free Mix_Chunk. Safely free a Mix_Chunk* and set it to NULL. \param chunk Chunk to free and set to NULL. **/ void FreeSound(Mix_Chunk *&chunk); /*! \brief Properly free Mix_Music. Safely free a Mix_Music* and set it to NULL. \param music Music to free and set to NULL. **/ void FreeMusic(Mix_Music *&music); #endif #ifdef USE_SDL_TTF /*! \brief Properly free TTF_Font. Safely free a TTF_Font* and set it to NULL. \param font Font to free and set to NULL. **/ void FreeFont(TTF_Font *&font); #endif } #endif //__ze_utility_h__