// Git clone a new chocolate-doom repo. Run patch command outside directory.
// patch -p0  < chocolate-heretic-plus.patch
// Recommend renaming the chocolate-heretic binary and moving it to where 
// 	the other chocolate-doom binaries are.


diff -ruN chocolate-doom/src/heretic/doomdef.h chocolate-heretic-plus/src/heretic/doomdef.h
--- chocolate-doom/src/heretic/doomdef.h	2021-09-07 11:40:49.919189808 -0400
+++ chocolate-heretic-plus/src/heretic/doomdef.h	2021-09-07 11:10:48.673117656 -0400
@@ -547,7 +547,7 @@
 
 extern ticcmd_t *netcmds;
 
-#define SAVEGAMESIZE 0x30000
+#define SAVEGAMESIZE 0x30000*16
 #define SAVESTRINGSIZE 24
 
 extern mapthing_t *deathmatch_p;
diff -ruN chocolate-doom/src/heretic/p_spec.h chocolate-heretic-plus/src/heretic/p_spec.h
--- chocolate-doom/src/heretic/p_spec.h	2021-09-07 11:40:49.943190740 -0400
+++ chocolate-heretic-plus/src/heretic/p_spec.h	2021-09-07 11:10:48.677117813 -0400
@@ -55,7 +55,7 @@
 //
 //      Animating line specials
 //
-#define	MAXLINEANIMS		64
+#define	MAXLINEANIMS		64*256
 extern short numlinespecials;
 extern line_t *linespeciallist[MAXLINEANIMS];
 
@@ -183,8 +183,8 @@
     void *soundorg;
 } button_t;
 
-#define	MAXSWITCHES	50      // max # of wall switches in a level
-#define	MAXBUTTONS	16      // 4 players, 4 buttons each at once, max.
+#define	MAXSWITCHES	50*4      // max # of wall switches in a level
+#define	MAXBUTTONS	16*4      // 4 players, 4 buttons each at once, max.
 #define BUTTONTIME	35      // 1 second
 
 extern button_t buttonlist[MAXBUTTONS];
@@ -233,7 +233,7 @@
 
 #define	PLATWAIT	3
 #define	PLATSPEED	FRACUNIT
-#define	MAXPLATS	30
+#define	MAXPLATS	30*256
 
 extern plat_t *activeplats[MAXPLATS];
 
diff -ruN chocolate-doom/src/heretic/r_bsp.c chocolate-heretic-plus/src/heretic/r_bsp.c
--- chocolate-doom/src/heretic/r_bsp.c	2021-09-07 11:40:49.943190740 -0400
+++ chocolate-heretic-plus/src/heretic/r_bsp.c	2021-09-07 11:40:18.381964420 -0400
@@ -448,7 +448,7 @@
     }
 
     // check for solidsegs overflow - extremely unsatisfactory!
-    if(newend > &solidsegs[32])
+    if(newend > &solidsegs[32*16])
         I_Error("R_Subsector: solidsegs overflow (vanilla may crash here)\n");
 }
 
diff -ruN chocolate-doom/src/heretic/r_local.h chocolate-heretic-plus/src/heretic/r_local.h
--- chocolate-doom/src/heretic/r_local.h	2021-09-07 11:40:49.947190896 -0400
+++ chocolate-heretic-plus/src/heretic/r_local.h	2021-09-07 11:10:48.677117813 -0400
@@ -147,8 +147,8 @@
 
 typedef byte lighttable_t;      // this could be wider for >8 bit display
 
-#define	MAXVISPLANES	128
-#define	MAXOPENINGS		SCREENWIDTH*64
+#define	MAXVISPLANES	128*8
+#define	MAXOPENINGS		SCREENWIDTH*64*8
 
 typedef struct
 {
@@ -184,7 +184,7 @@
 #define SIL_TOP		2
 #define	SIL_BOTH	3
 
-#define	MAXDRAWSEGS		256
+#define	MAXDRAWSEGS		256*8
 
 // A vissprite_t is a thing that will be drawn during a refresh
 typedef struct vissprite_s
@@ -400,7 +400,7 @@
 //
 // R_things.c
 //
-#define	MAXVISSPRITES	128
+#define	MAXVISSPRITES	128*8
 
 extern vissprite_t vissprites[MAXVISSPRITES], *vissprite_p;
 extern vissprite_t vsprsortedhead;
