X-Git-Url: http://git.pond.sub.org/?p=empserver;a=blobdiff_plain;f=include%2Fmisc.h;h=9f4771b3e27431b6c151a211a4d7897e7c02d50c;hp=c5c7eb93aa300e0ae0b83f1b5045b73659a25aef;hb=87952c7f7c263dd2f4155982a3079dd5c1848663;hpb=fa38aef7000d6c96565602adf09bd90f2ec978fb diff --git a/include/misc.h b/include/misc.h index c5c7eb93a..9f4771b3e 100644 --- a/include/misc.h +++ b/include/misc.h @@ -1,11 +1,11 @@ /* * Empire - A multi-player, client/server Internet based war game. - * Copyright (C) 1986-2006, Dave Pare, Jeff Bailey, Thomas Ruschak, - * Ken Stevens, Steve McClure + * Copyright (C) 1986-2020, Dave Pare, Jeff Bailey, Thomas Ruschak, + * Ken Stevens, Steve McClure, Markus Armbruster * - * This program is free software; you can redistribute it and/or modify + * Empire 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 + * 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, @@ -14,8 +14,7 @@ * 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, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * along with this program. If not, see . * * --- * @@ -27,109 +26,86 @@ * * misc.h: Misc. definitions which don't really belong anywhere, * but have to go somewhere! - * + * * Known contributors to this file: - * Doug Hay, 1998 + * Doug Hay, 1998 + * Markus Armbruster, 2004-2020 */ #ifndef MISC_H #define MISC_H -#include - #define MAX(a,b) ((a) > (b) ? (a) : (b)) #define MIN(a,b) ((a) < (b) ? (a) : (b)) -#if defined(_WIN32) -typedef long ssize_t; - -/* integral mismatch, due to misuse of sector short */ -#ifndef __GNUC__ -#pragma warning (disable : 4761 ) -#endif - -#include - -#define random rand -#define srandom srand - -#ifdef __GNUC__ -#include -#else -#define strncasecmp(s1, s2, s3) _strnicmp((s1), (s2), (s3)) -#endif -#define mkdir(dir,perm) _mkdir((dir)) - -typedef int pid_t; -#define vsnprintf _vsnprintf -#define snprintf _snprintf +#define LIMIT_TO(val, min, max) \ + ((val) < (min) ? (min) : (val) > (max) ? (max) : (val)) +#ifdef _WIN32 +#include "w32misc.h" #endif /* _WIN32 */ -/* This is the structure we use to keep track of the global mobility - things, such as when the server is supposed to start/stop updating - mobility and the timestamp of when the game was last up. These - times are in seconds. */ -struct mob_acc_globals { - time_t timestamp; /* Last timestamp of when the game was up */ - time_t starttime; /* When we should start updating mobility again. */ -}; - #ifdef __GNUC__ #define ATTRIBUTE(attrs) __attribute__ (attrs) #else #define ATTRIBUTE(attrs) #endif -/* - * This uses a lot of thread stack with some versions of GNU libc, - * which can lead to nasty heap smashes (observed with 2.2.93). - * Disabled for now, until we readjust thread stack sizes. - */ -#if 0 -#define RESOLVE_IPADDRESS /* resolve ip addresses into hostnames */ -#endif - #ifndef bit -#define bit(x) (1<<(x)) +#define bit(x) (1U<<(x)) #endif #define minutes(x) (60*(x)) #define hours(x) (60*60*(x)) #define days(x) (60*60*24*(x)) -extern int debug; - /* - * If EXPR is true, an internal error occured. - * Return EXPR != 0. + * If @expr is true, an internal error occured. + * Return @expr != 0. * Usage: if (CANT_HAPPEN(...)) ; */ -#define CANT_HAPPEN(expr) ((expr) ? oops(#expr, __FILE__, __LINE__) : 0) +#define CANT_HAPPEN(expr) ((expr) ? oops(#expr, __FILE__, __LINE__), 1 : 0) /* * Report internal error. * Usage: CANT_REACH(); ; */ -#define CANT_REACH() (void)oops(NULL, __FILE__, __LINE__) +#define CANT_REACH() oops(NULL, __FILE__, __LINE__) + +extern void oops(char *, char *, int); +extern void (*oops_handler)(void); + +/* + * Assert constant expression @cond, return 1. + * If @cond is zero, force a compilation error. + */ +#define BUILD_ASSERT_ONE(cond) \ + (sizeof(char[1 - 2 * !(cond)])) + +/* + * Assert constant expression @cond. + * If @cond is zero, force a compilation error. + */ +#define BUILD_ASSERT(cond) \ + ((void)BUILD_ASSERT_ONE(cond)) -extern int oops(char *, char *, int); +/* + * Number of elements in ARRAY. + */ +#define ARRAY_SIZE(array) (sizeof(array) / sizeof(array[0])) + +void exit_nomem(void) ATTRIBUTE((noreturn)); /* return codes from command routines */ -#define RET_OK 0 /* command completed sucessfully */ -#define RET_FAIL 1 /* command completed unsucessfully [?] */ -#define RET_SYN 2 /* syntax error in command */ -#define RET_SYS 3 /* system error (missing file, etc) */ +#define RET_OK 0 /* command completed sucessfully */ +#define RET_FAIL 1 /* command completed unsucessfully [?] */ +#define RET_SYN 2 /* syntax error in command */ extern char *getstarg(char *input, char *prompt, char buf[]); extern char *getstring(char *prompt, char buf[]); extern char *ugetstring(char *prompt, char buf[]); - + extern char *prbuf(char *format, ...) ATTRIBUTE((format (printf, 1, 2))); -#define AGREE_FREE 0 -#define AGREE_PROPOSED 1 -#define AGREE_SIGNED 2 - #endif