X-Git-Url: http://4ch.mooo.com/gitweb/?a=blobdiff_plain;f=src%2Flib%2F16_head.h;h=0a71c965a040b9a467d81f3b1023f977f19220bc;hb=d48c3f2da3fb828320dc2817d5ab0e5848d07905;hp=84a4a9eba1de7a53fba390ab1786bf4fa3d44577;hpb=3b3f3b4bc62245426ea4dec22cbfaa7cfbf13645;p=16.git diff --git a/src/lib/16_head.h b/src/lib/16_head.h old mode 100644 new mode 100755 index 84a4a9eb..0a71c965 --- a/src/lib/16_head.h +++ b/src/lib/16_head.h @@ -1,5 +1,5 @@ /* Project 16 Source Code~ - * Copyright (C) 2012-2015 sparky4 & pngwen & andrius4669 + * Copyright (C) 2012-2018 sparky4 & pngwen & andrius4669 & joncampbell123 & yakui-lover * * This file is part of Project 16. * @@ -20,37 +20,46 @@ * */ -#if !defined(__LARGE__) && !defined(__COMPACT__) && !defined(__HUGE__) -#error Invalid memory model for compiling project 16 -#endif +//#if !defined(__LARGE__) && !defined(__COMPACT__) && !defined(__HUGE__) +//#error Invalid memory model for compiling project 16 +//#endif #if !defined(__i86__) && defined(__i386__) #error i8088 only #endif -#ifndef _LIBHEAD_H_ -#define _LIBHEAD_H_ -#include +#ifndef __16_HEAD_H__ +#define __16_HEAD_H__ #include #include -#include // just for wait -#include // just for wait #include -#include +#include // this is where Open Watcom hides the outp() etc. functions // just for wait +#include // just for wait #include -#include #include +#include #include #include +#include +#include +#include +#include +#ifdef __WATCOMC__ +#include +#include #include +#include //16_vrs.h +#endif +#ifdef __BORLANDC__ +#include +#include +#define TILEWH 16 +#endif +#include "src/lib/16_t.h" +#include "src/lib/16_tdef.h" #include "src/lib/nyan/kitten.h" -#include "src/lib/types.h" -//0000 test type def wwww -struct list { - struct list __based(__self) *next; - int value; -}; +#define VERSION __DATE__ " " __TIME__ /* Control codes for all keys on the keyboard */ //here temperarly @@ -144,45 +153,70 @@ struct list { #define KEY_MENU (0x75) */ -static dword far* clockdw= (dword far*) 0x046C; /* 18.2hz clock */ +//static word far* clockw= (word far*) 0x046C; /* 18.2hz clock */ extern int profilehandle,debughandle; //make it into game global -#define __DEBUG__ +//#define OLD16_VL #define nil ((void *)0) -#define peekb(segm,ofs) (*(byte far*)MK_FP((segm),(ofs))) -#define peekw(segm,ofs) (*(word far*)MK_FP((segm),(ofs))) -#define pokeb(segm,ofs,value) (peekb((segm),(ofs)) = (byte)(value)) -#define pokew(segm,ofs,value) (peekw((segm),(ofs)) = (word)(value)) +#ifdef __WATCOMC__ +//----#define _FCORELEFT 0x90000UL+16UL +extern union REGS CPURegs; + +#define _AX CPURegs.x.ax +#define _BX CPURegs.x.bx +#define _CX CPURegs.x.cx +#define _DX CPURegs.x.dx + +#define _SI CPURegs.x.si +#define _DI CPURegs.x.di + +#define _AH CPURegs.h.ah +#define _AL CPURegs.h.al +#define _BH CPURegs.h.bh +#define _BL CPURegs.h.bl +#define _CH CPURegs.h.ch +#define _CL CPURegs.h.cl +#define _DH CPURegs.h.dh +#define _DL CPURegs.h.dl + +#define _CFLAG CPURegs.x.cflag + +#define geninterrupt(n) int86(n,&CPURegs,&CPURegs); + typedef union REGPACK regs_t; -//typedef struct SREGS sregs_t; -//sregs_t sregs; -typedef enum {false,true} boolean; -//I hope this is correct! -typedef void __based(__self) * memptr; -typedef struct -{ - int old_mode; //old video mode before game! - word frames_per_second; - clock_t t; - dword tiku; - word far* clock; - //handles for log files of the game gose here if wwww - //int heaphandle; -} global_game_variables_t; - -/* local function */ -void wait(clock_t wait); +#endif +// local function // long int filesize(FILE *fp); +void clrstdin(); +char *remove_ext(char* mystr, char dot, char sep); +void rotateR(byte arr[], byte n); +void rotateL(byte arr[], byte n); void printmeminfoline(byte *strc, const byte *pee, size_t h_total, size_t h_used, size_t h_free); -void print_normal_entry(char *text, dword total, dword used, dword free, byte *str); -void convert(const char *format, dword num); int US_CheckParm(char *parm,char **strings); +byte dirchar(byte in); +void print_mem(void const *vp, size_t n); +void hres (void); +void regidump(); + +//from https://stackoverflow.com/questions/111928/is-there-a-printf-converter-to-print-in-binary-format +//printf("Leading text "BYTE_TO_BINARY_PATTERN, BYTE_TO_BINARY(byte)); +//For multi-byte types +//printf("m: "BYTE_TO_BINARY_PATTERN" "BYTE_TO_BINARY_PATTERN"\n", BYTE_TO_BINARY(m>>8), BYTE_TO_BINARY(m)); +#define BYTE_TO_BINARY_PATTERN "%c%c%c%c%c%c%c%c" +#define BYTE_TO_BINARY(byte) \ + (byte & 0x80 ? '1' : '0'), \ + (byte & 0x40 ? '1' : '0'), \ + (byte & 0x20 ? '1' : '0'), \ + (byte & 0x10 ? '1' : '0'), \ + (byte & 0x08 ? '1' : '0'), \ + (byte & 0x04 ? '1' : '0'), \ + (byte & 0x02 ? '1' : '0'), \ + (byte & 0x01 ? '1' : '0') -extern void CA_OpenDebug (void); -extern void CA_CloseDebug (void); +#define PRINT_OPAQUE_STRUCT(p) print_mem((p), sizeof(*(p))) -#endif/*_LIBHEAD_H_*/ +#endif/*__16_HEAD_H__*/