// Chocolate-heretic Blasphemer Version 0.4
// Chocolate-heretic-plus bumps limits and removes crashing menu. 
// 
// Designed so that Blasphemer will not crash with normal usage and settings.
// Make a new directory and run these two commands in it.
//
// $ git clone https://github.com/chocolate-doom/chocolate-doom chocolate-heretic-plus
// $ patch -p0  < chocolate-heretic-plus-sbv4.patch
//
// Recommend renaming the chocolate-heretic binary and moving it to where 
// 	the other chocolate-doom binaries are.
//
// Re-enabled mouse control credits:
// https://github.com/JNechaevsky/russian-doom/commit/d380b40d142173d00797bb8fd5f2af43351826c3


diff -ruN chocolate-doom/src/heretic/doomdef.h chocolate-heretic-plus/src/heretic/doomdef.h
--- chocolate-doom/src/heretic/doomdef.h	2021-09-20 08:36:24.282387781 -0400
+++ chocolate-heretic-plus/src/heretic/doomdef.h	2021-09-20 08:34:03.444920931 -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/mn_menu.c chocolate-heretic-plus/src/heretic/mn_menu.c
--- chocolate-doom/src/heretic/mn_menu.c	2021-09-20 08:36:24.290388093 -0400
+++ chocolate-heretic-plus/src/heretic/mn_menu.c	2021-09-20 08:34:14.201338451 -0400
@@ -932,7 +932,7 @@
 {
     if (option == RIGHT_DIR)
     {
-        if (mouseSensitivity < 9)
+        if (mouseSensitivity < 255) // [crispy] extended range
         {
             mouseSensitivity++;
         }
@@ -1691,6 +1691,22 @@
                                            : "M_SLDMD2"), PU_CACHE));
     }
     V_DrawPatch(x2, y, W_CacheLumpName(DEH_String("M_SLDRT"), PU_CACHE));
-    V_DrawPatch(x + 4 + slot * 8, y + 7,
-                W_CacheLumpName(DEH_String("M_SLDKB"), PU_CACHE));
+
+    // [JN] Colorizing slider gem...
+    // Most left position (dull green gem)
+    if (slot == 0)
+    {
+        V_DrawPatch(x + 4 + slot * 8, y + 7, W_CacheLumpName(DEH_String("M_SLDKB"), PU_CACHE));
+    }
+    // [JN] Most right position that is "out of bounds" (red gem).
+    // Only the mouse sensitivity menu requires this trick.
+    else if (CurrentMenu == &OptionsMenu && slot > 8)
+    {
+        slot = 8;
+        V_DrawPatch(x + 4 + slot * 8, y + 7, W_CacheLumpName(DEH_String("M_SLDKB"), PU_CACHE));
+    }
+    // [JN] Standard function (green gem)
+    else
+    V_DrawPatch(x + 4 + slot * 8, y + 7, W_CacheLumpName(DEH_String("M_SLDKB"), PU_CACHE));
+
 }
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-20 08:36:24.302388559 -0400
+++ chocolate-heretic-plus/src/heretic/p_spec.h	2021-09-20 08:34:03.444920931 -0400
@@ -55,7 +55,7 @@
 //
 //      Animating line specials
 //
-#define	MAXLINEANIMS		64
+#define	MAXLINEANIMS		64*256
 extern short numlinespecials;
 extern line_t *linespeciallist[MAXLINEANIMS];
 
@@ -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-20 08:36:24.302388559 -0400
+++ chocolate-heretic-plus/src/heretic/r_bsp.c	2021-09-20 08:34:03.448921086 -0400
@@ -67,7 +67,7 @@
 // render overage and then bomb out by detecting the overflow after the 
 // fact. -haleyjd
 //#define MAXSEGS 32
-#define MAXSEGS (SCREENWIDTH / 2 + 1)
+#define MAXSEGS (SCREENWIDTH / 2 + 1)*8
 
 cliprange_t solidsegs[MAXSEGS], *newend;        // newend is one past the last valid seg
 
@@ -448,7 +448,7 @@
     }
 
     // check for solidsegs overflow - extremely unsatisfactory!
-    if(newend > &solidsegs[32])
+    if(newend > &solidsegs[32*8])
         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-20 08:36:24.306388714 -0400
+++ chocolate-heretic-plus/src/heretic/r_local.h	2021-09-20 08:34:03.448921086 -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;
