2008-06-06 15:43:15 +02:00
|
|
|
// stdafx.h : include file for standard system include files,
|
|
|
|
// or project specific include files that are used frequently, but
|
|
|
|
// are changed infrequently
|
|
|
|
//
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#if defined(_WIN32)
|
|
|
|
const bool debug=true;
|
|
|
|
#else
|
|
|
|
const bool debug=false;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "targetver.h"
|
|
|
|
|
|
|
|
//#include "assert.h"
|
|
|
|
|
|
|
|
// you can catch these
|
|
|
|
class AssertionException {
|
|
|
|
public:
|
|
|
|
AssertionException() { }
|
|
|
|
};
|
|
|
|
|
|
|
|
void asserted(const char *msg, const char *file, unsigned line);
|
|
|
|
void wasserted(const char *msg, const char *file, unsigned line);
|
|
|
|
|
|
|
|
#ifdef assert
|
|
|
|
#undef assert
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define assert(_Expression) (void)( (!!(_Expression)) || (asserted(#_Expression, __FILE__, __LINE__), 0) )
|
|
|
|
|
|
|
|
#define xassert(_Expression) (void)( (!!(_Expression)) || (asserted(#_Expression, __FILE__, __LINE__), 0) )
|
|
|
|
|
|
|
|
#define yassert 1
|
|
|
|
|
|
|
|
/* warning only - keeps going */
|
|
|
|
#define wassert(_Expression) (void)( (!!(_Expression)) || (wasserted(#_Expression, __FILE__, __LINE__), 0) )
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <sstream>
|
|
|
|
#include <signal.h>
|
|
|
|
|
|
|
|
typedef char _TCHAR;
|
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
#include <fstream>
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
#include "time.h"
|
|
|
|
#include <map>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
#include <set>
|
|
|
|
|
|
|
|
#if !defined(_WIN32)
|
|
|
|
typedef int HANDLE;
|
|
|
|
inline void strcpy_s(char *dst, unsigned len, const char *src) { strcpy(dst, src); }
|
|
|
|
#else
|
|
|
|
typedef void *HANDLE;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
//#if defined(CHAR)
|
|
|
|
//#error CHAR already defined?
|
|
|
|
//#endif
|
|
|
|
|
|
|
|
//#if defined(_WIN32_WINNT)
|
|
|
|
//typedef wchar_t CHAR;
|
|
|
|
//#else
|
|
|
|
// more to be done...linux unicode is 32 bit.
|
|
|
|
//typedef unsigned short CHAR; // 16 bit unicode
|
|
|
|
//#endif
|
|
|
|
|
|
|
|
#define null (0)
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
// for debugging
|
|
|
|
typedef struct _Ints { int i[100]; } *Ints;
|
|
|
|
typedef struct _Chars { char c[200]; } *Chars;
|
|
|
|
|
|
|
|
typedef char CHARS[400];
|
|
|
|
|
|
|
|
typedef struct _OWS {
|
|
|
|
int size;
|
|
|
|
char type;
|
|
|
|
char string[400];
|
|
|
|
} *OWS;
|
|
|
|
|
2008-06-06 16:47:39 +02:00
|
|
|
//extern ofstream problems;
|
2008-06-06 15:43:15 +02:00
|
|
|
|
|
|
|
class Client;
|
|
|
|
extern Client *client;
|
|
|
|
extern const char *curNs;
|
|
|
|
|
|
|
|
// not threadsafe
|
2008-06-06 16:47:39 +02:00
|
|
|
inline ostream& problem() {
|
|
|
|
ostream& problems = cout;
|
2008-06-06 15:43:15 +02:00
|
|
|
time_t t;
|
|
|
|
time(&t);
|
|
|
|
string now(ctime(&t),0,20);
|
2008-06-10 19:13:05 +02:00
|
|
|
problems << "~ " << now;
|
2008-06-06 15:43:15 +02:00
|
|
|
if( client )
|
|
|
|
problems << curNs << ' ';
|
|
|
|
return problems;
|
|
|
|
}
|
|
|
|
|
2008-06-08 16:58:19 +02:00
|
|
|
/* for now, running on win32 means development not production --
|
|
|
|
use this to log things just there.
|
|
|
|
*/
|
2008-06-10 22:57:25 +02:00
|
|
|
#if defined(_WIN32)
|
2008-06-08 16:58:19 +02:00
|
|
|
#define DEV if( 1 )
|
|
|
|
#else
|
2008-06-10 22:57:25 +02:00
|
|
|
#define DEV if( 1 )
|
2008-06-08 16:58:19 +02:00
|
|
|
#endif
|
|
|
|
|
2008-06-06 15:43:15 +02:00
|
|
|
#define DEBUGGING if( 0 )
|
|
|
|
|
|
|
|
extern unsigned occasion;
|
|
|
|
|
|
|
|
#define OCCASIONALLY if( ++occasion % 16 == 0 )
|