2007-01-15 12:09:25 -08:00
|
|
|
/*
|
|
|
|
This file is part of Warzone 2100.
|
|
|
|
Copyright (C) 1999-2004 Eidos Interactive
|
|
|
|
Copyright (C) 2005-2007 Warzone Resurrection Project
|
|
|
|
|
|
|
|
Warzone 2100 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 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
Warzone 2100 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 Warzone 2100; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*/
|
2006-09-25 09:46:28 -07:00
|
|
|
/*! \file frame.h
|
|
|
|
* \brief The framework library initialisation and shutdown routines.
|
2007-06-28 10:47:08 -07:00
|
|
|
*/
|
|
|
|
#ifndef _frame_h
|
|
|
|
#define _frame_h
|
|
|
|
|
2007-08-21 05:30:00 -07:00
|
|
|
#include "wzglobal.h"
|
2007-04-10 05:44:50 -07:00
|
|
|
|
2007-08-21 05:59:05 -07:00
|
|
|
/* This one must be invoked *after* wzglobal.h to get _GNU_SOURCE! */
|
2007-02-19 06:10:44 -08:00
|
|
|
#include <string.h>
|
2007-04-10 10:36:16 -07:00
|
|
|
#include <locale.h>
|
2007-04-15 11:48:13 -07:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <ctype.h>
|
2007-02-19 06:10:44 -08:00
|
|
|
|
2007-10-26 10:05:29 -07:00
|
|
|
// Provides the safer functions strlcpy and strlcat
|
|
|
|
#include "strlfuncs.h"
|
|
|
|
|
2007-04-10 10:36:16 -07:00
|
|
|
#include "gettext.h"
|
2007-04-23 08:21:18 -07:00
|
|
|
|
|
|
|
#if !defined(LC_MESSAGES)
|
|
|
|
# define LC_MESSAGES 0
|
|
|
|
#endif
|
|
|
|
|
2007-04-10 10:36:16 -07:00
|
|
|
#define _(String) gettext(String)
|
|
|
|
#define N_(String) gettext_noop(String)
|
|
|
|
|
|
|
|
// Context sensitive strings
|
|
|
|
#define P_(Context, String) pgettext(Context, String)
|
|
|
|
// Non literal context sensitive strings
|
|
|
|
#define PE_(Context, String) pgettext_expr(Context, String)
|
|
|
|
// Make xgettext recognize the context
|
|
|
|
#define NP_(Context, String) gettext_noop(String)
|
2006-03-17 17:59:59 -08:00
|
|
|
|
2007-04-10 10:36:16 -07:00
|
|
|
|
|
|
|
#include "macros.h"
|
2007-06-28 10:47:08 -07:00
|
|
|
#include "types.h"
|
|
|
|
#include "debug.h"
|
|
|
|
|
|
|
|
#include "treap.h"
|
2007-11-11 12:58:10 -08:00
|
|
|
#include "printf_ext.h"
|
2006-09-23 10:24:55 -07:00
|
|
|
|
2007-06-28 10:47:08 -07:00
|
|
|
#include "fractions.h"
|
|
|
|
#include "trig.h"
|
2007-08-15 14:26:05 -07:00
|
|
|
#include <physfs.h>
|
2007-06-28 10:47:08 -07:00
|
|
|
|
2007-04-10 07:06:14 -07:00
|
|
|
|
2007-06-28 10:47:08 -07:00
|
|
|
/* Initialise the frame work library */
|
2006-11-03 17:11:26 -08:00
|
|
|
extern BOOL frameInitialise(
|
|
|
|
const char *pWindowName,// The text to appear in the window title bar
|
|
|
|
UDWORD width, // The display width
|
|
|
|
UDWORD height, // The display height
|
|
|
|
UDWORD bitDepth, // The display bit depth
|
|
|
|
BOOL fullScreen // Whether to start full screen or windowed
|
|
|
|
);
|
2007-06-28 10:47:08 -07:00
|
|
|
|
|
|
|
/* Shut down the framework library.
|
|
|
|
* This clears up all the Direct Draw stuff and ensures
|
|
|
|
* that Windows gets restored properly after Full screen mode.
|
|
|
|
*/
|
|
|
|
extern void frameShutDown(void);
|
|
|
|
|
2007-05-12 14:47:06 -07:00
|
|
|
|
|
|
|
typedef enum _focus_state
|
2007-06-28 10:47:08 -07:00
|
|
|
{
|
2007-05-12 14:47:06 -07:00
|
|
|
FOCUS_OUT, // Window does not have the focus
|
|
|
|
FOCUS_IN, // Window has got the focus
|
|
|
|
} FOCUS_STATE;
|
|
|
|
|
2007-06-28 10:47:08 -07:00
|
|
|
|
|
|
|
/* Call this each cycle to allow the framework to deal with
|
|
|
|
* windows messages, and do general house keeping.
|
|
|
|
*
|
|
|
|
* Returns FRAME_STATUS.
|
|
|
|
*/
|
2007-05-12 14:47:06 -07:00
|
|
|
extern void frameUpdate(void);
|
2007-06-28 10:47:08 -07:00
|
|
|
|
|
|
|
/* Set the current cursor from a Resource ID
|
|
|
|
* This is the same as calling:
|
|
|
|
* frameSetCursor(LoadCursor(MAKEINTRESOURCE(resID)));
|
|
|
|
* but with a bit of extra error checking.
|
|
|
|
*/
|
2006-11-03 17:11:26 -08:00
|
|
|
extern void frameSetCursorFromRes(SWORD resID);
|
2007-06-28 10:47:08 -07:00
|
|
|
|
|
|
|
/* Returns the current frame we're on - used to establish whats on screen */
|
2007-05-12 16:41:29 -07:00
|
|
|
extern UDWORD frameGetFrameNumber(void);
|
2007-06-28 10:47:08 -07:00
|
|
|
|
2006-08-27 12:01:34 -07:00
|
|
|
/**
|
|
|
|
* Average framerate of the last seconds
|
|
|
|
*
|
|
|
|
* \return Average framerate
|
|
|
|
*/
|
|
|
|
extern UDWORD frameGetAverageRate(void);
|
2007-06-28 10:47:08 -07:00
|
|
|
|
|
|
|
|
|
|
|
/* Load the file with name pointed to by pFileName into a memory buffer. */
|
2006-12-31 12:29:24 -08:00
|
|
|
extern BOOL loadFile(const char *pFileName, // The filename
|
2006-08-12 09:52:37 -07:00
|
|
|
char **ppFileData, // A buffer containing the file contents
|
2007-06-28 10:47:08 -07:00
|
|
|
UDWORD *pFileSize); // The size of this buffer
|
|
|
|
|
2007-08-15 14:26:05 -07:00
|
|
|
extern PHYSFS_file* openLoadFile(const char* fileName, bool hard_fail);
|
|
|
|
extern PHYSFS_file* openSaveFile(const char* fileName);
|
|
|
|
|
2007-06-28 10:47:08 -07:00
|
|
|
/* Save the data in the buffer into the given file */
|
|
|
|
extern BOOL saveFile(const char *pFileName, const char *pFileData, UDWORD fileSize);
|
|
|
|
|
|
|
|
// load a file from disk into a fixed memory buffer
|
2006-09-13 14:16:17 -07:00
|
|
|
BOOL loadFileToBuffer(const char *pFileName, char *pFileBuffer, UDWORD bufferSize, UDWORD *pSize);
|
2007-06-28 10:47:08 -07:00
|
|
|
|
|
|
|
// as above but returns quietly if no file found
|
2006-09-13 14:16:17 -07:00
|
|
|
BOOL loadFileToBufferNoError(const char *pFileName, char *pFileBuffer, UDWORD bufferSize,
|
2007-06-28 10:47:08 -07:00
|
|
|
UDWORD *pSize);
|
|
|
|
|
|
|
|
extern SDWORD ftol(float f);
|
|
|
|
|
2006-11-03 17:11:26 -08:00
|
|
|
UDWORD HashString( const char *String );
|
|
|
|
UDWORD HashStringIgnoreCase( const char *String );
|
2007-06-28 10:47:08 -07:00
|
|
|
|
2006-08-12 03:45:49 -07:00
|
|
|
|
|
|
|
/* Endianness hacks */
|
2007-05-13 15:37:13 -07:00
|
|
|
// TODO Use SDL_SwapXXXX instead
|
2006-08-12 03:45:49 -07:00
|
|
|
|
|
|
|
#ifdef __BIG_ENDIAN__
|
2006-11-24 17:26:05 -08:00
|
|
|
static inline void endian_uword(UWORD *uword) {
|
2006-08-12 03:45:49 -07:00
|
|
|
UBYTE tmp, *ptr;
|
|
|
|
|
|
|
|
ptr = (UBYTE *) uword;
|
|
|
|
tmp = ptr[0];
|
|
|
|
ptr[0] = ptr[1];
|
|
|
|
ptr[1] = tmp;
|
|
|
|
}
|
2006-11-24 17:26:05 -08:00
|
|
|
#else
|
|
|
|
# define endian_uword(x)
|
|
|
|
#endif
|
2006-08-12 03:45:49 -07:00
|
|
|
|
|
|
|
#ifdef __BIG_ENDIAN__
|
2006-11-24 17:26:05 -08:00
|
|
|
static inline void endian_sword(SWORD *sword) {
|
2006-08-12 03:45:49 -07:00
|
|
|
UBYTE tmp, *ptr;
|
|
|
|
|
|
|
|
ptr = (UBYTE *) sword;
|
|
|
|
tmp = ptr[0];
|
|
|
|
ptr[0] = ptr[1];
|
|
|
|
ptr[1] = tmp;
|
|
|
|
}
|
2006-11-24 17:26:05 -08:00
|
|
|
#else
|
|
|
|
# define endian_sword(x)
|
|
|
|
#endif
|
2006-08-12 03:45:49 -07:00
|
|
|
|
|
|
|
#ifdef __BIG_ENDIAN__
|
2006-11-24 17:26:05 -08:00
|
|
|
static inline void endian_udword(UDWORD *udword) {
|
2006-08-12 03:45:49 -07:00
|
|
|
UBYTE tmp, *ptr;
|
|
|
|
|
|
|
|
ptr = (UBYTE *) udword;
|
|
|
|
tmp = ptr[0];
|
|
|
|
ptr[0] = ptr[3];
|
|
|
|
ptr[3] = tmp;
|
|
|
|
tmp = ptr[1];
|
|
|
|
ptr[1] = ptr[2];
|
|
|
|
ptr[2] = tmp;
|
|
|
|
}
|
2006-11-24 17:26:05 -08:00
|
|
|
#else
|
|
|
|
# define endian_udword(x)
|
|
|
|
#endif
|
2006-08-12 03:45:49 -07:00
|
|
|
|
|
|
|
#ifdef __BIG_ENDIAN__
|
2006-11-24 17:26:05 -08:00
|
|
|
static inline void endian_sdword(SDWORD *sdword) {
|
2006-08-12 03:45:49 -07:00
|
|
|
UBYTE tmp, *ptr;
|
|
|
|
|
|
|
|
ptr = (UBYTE *) sdword;
|
|
|
|
tmp = ptr[0];
|
|
|
|
ptr[0] = ptr[3];
|
|
|
|
ptr[3] = tmp;
|
|
|
|
tmp = ptr[1];
|
|
|
|
ptr[1] = ptr[2];
|
|
|
|
ptr[2] = tmp;
|
|
|
|
}
|
2006-11-24 17:26:05 -08:00
|
|
|
#else
|
|
|
|
# define endian_sdword(x)
|
|
|
|
#endif
|
2006-08-12 03:45:49 -07:00
|
|
|
|
|
|
|
#ifdef __BIG_ENDIAN__
|
2007-05-19 14:32:19 -07:00
|
|
|
static inline void endian_fract(float *fract) {
|
2006-08-12 03:45:49 -07:00
|
|
|
UBYTE tmp, *ptr;
|
|
|
|
|
|
|
|
ptr = (UBYTE *) fract;
|
|
|
|
tmp = ptr[0];
|
|
|
|
ptr[0] = ptr[3];
|
|
|
|
ptr[3] = tmp;
|
|
|
|
tmp = ptr[1];
|
|
|
|
ptr[1] = ptr[2];
|
|
|
|
ptr[2] = ptr[1];
|
|
|
|
}
|
2006-11-24 17:26:05 -08:00
|
|
|
#else
|
|
|
|
# define endian_fract(x)
|
|
|
|
#endif
|
2006-08-12 03:45:49 -07:00
|
|
|
|
2007-03-29 02:45:11 -07:00
|
|
|
void setupExceptionHandler(const char * programCommand);
|
2006-08-12 03:45:49 -07:00
|
|
|
|
2007-08-15 14:26:05 -07:00
|
|
|
static inline bool PHYSFS_writeSBE8(PHYSFS_file* file, int8_t val)
|
|
|
|
{
|
|
|
|
return (PHYSFS_write(file, &val, sizeof(int8_t), 1) == 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool PHYSFS_writeUBE8(PHYSFS_file* file, uint8_t val)
|
|
|
|
{
|
|
|
|
return (PHYSFS_write(file, &val, sizeof(uint8_t), 1) == 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool PHYSFS_readSBE8(PHYSFS_file* file, int8_t* val)
|
|
|
|
{
|
|
|
|
return (PHYSFS_read(file, val, sizeof(int8_t), 1) == 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool PHYSFS_readUBE8(PHYSFS_file* file, uint8_t* val)
|
|
|
|
{
|
|
|
|
return (PHYSFS_read(file, val, sizeof(uint8_t), 1) == 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool PHYSFS_writeBEFloat(PHYSFS_file* file, float val)
|
|
|
|
{
|
2007-08-16 02:09:30 -07:00
|
|
|
// For the purpose of endian conversions a IEEE754 float can be considered
|
|
|
|
// the same to a 32bit integer.
|
2007-08-17 15:17:16 -07:00
|
|
|
// We're using a union here to prevent type punning of pointers.
|
|
|
|
union {
|
|
|
|
float f;
|
|
|
|
uint32_t i;
|
|
|
|
} writeValue;
|
|
|
|
writeValue.f = val;
|
|
|
|
return (PHYSFS_writeUBE32(file, writeValue.i) != 0);
|
2007-08-15 14:26:05 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool PHYSFS_readBEFloat(PHYSFS_file* file, float* val)
|
|
|
|
{
|
2007-08-16 02:09:30 -07:00
|
|
|
// For the purpose of endian conversions a IEEE754 float can be considered
|
|
|
|
// the same to a 32bit integer.
|
2007-08-15 14:26:05 -07:00
|
|
|
uint32_t* readValue = (uint32_t*)val;
|
|
|
|
return (PHYSFS_readUBE32(file, readValue) != 0);
|
|
|
|
}
|
|
|
|
|
2007-06-28 10:47:08 -07:00
|
|
|
#endif
|