shithub: cstory

Download patch

ref: cc8e875cb12bbc9f7d6d21c41b4d8dc88a1e0536
parent: 2701c001ad7c0d0da368f49119de361e90e59927
parent: a5bf854408b35310569b22d294642e007d4a5782
author: Clownacy <Clownacy@users.noreply.github.com>
date: Sat Jun 27 15:28:09 EDT 2020

Merge branch 'accurate' into portable

--- a/src/Game.cpp
+++ b/src/Game.cpp
@@ -337,7 +337,7 @@
 #endif
 
 	g_GameFlags = 0;
-	gMC.equip |= 0x100;
+	gMC.equip |= EQUIP_NIKUMARU_COUNTER;	// Give the player the Nikumaru Counter so the timer appears on-screen
 
 	// Start loop
 	wait = 0;
@@ -619,7 +619,7 @@
 
 				gMC.cond &= ~1;
 			}
-			else if (gMC.equip & 2 && gKeyTrg & gKeyMap)
+			else if (gMC.equip & EQUIP_MAP && gKeyTrg & gKeyMap)
 			{
 				BackupSurface(SURFACE_ID_SCREEN_GRAB, &grcGame);
 
--- a/src/MyChar.cpp
+++ b/src/MyChar.cpp
@@ -217,7 +217,7 @@
 
 	// Draw player
 	RECT rect = gMC.rect;
-	if (gMC.equip & 0x40)
+	if (gMC.equip & EQUIP_MIMIGA_MASK)
 	{
 		rect.top += 32;
 		rect.bottom += 32;
@@ -232,7 +232,7 @@
 	};
 
 	++gMC.bubble;
-	if (gMC.equip & 0x10 && gMC.flag & 0x100)
+	if (gMC.equip & EQUIP_AIR_TANK && gMC.flag & 0x100)
 		PutBitmap3(&grcGame, (gMC.x / 0x200) - 12 - (fx / 0x200), (gMC.y / 0x200) - 12 - (fy / 0x200), &rcBubble[gMC.bubble / 2 % 2], SURFACE_ID_CARET);
 	else if (gMC.unit == 1)
 		PutBitmap3(&grcGame, (gMC.x / 0x200) - 12 - (fx / 0x200), (gMC.y / 0x200) - 12 - (fy / 0x200), &rcBubble[gMC.bubble / 2 % 2], SURFACE_ID_CARET);
@@ -291,11 +291,11 @@
 		// Stop boosting and refuel
 		gMC.boost_sw = 0;
 
-		if (gMC.equip & 1)
+		if (gMC.equip & EQUIP_BOOSTER_0_8)
 		{
 			gMC.boost_cnt = 50;
 		}
-		else if (gMC.equip & 0x20)
+		else if (gMC.equip & EQUIP_BOOSTER_2_0)
 		{
 			gMC.boost_cnt = 50;
 		}
@@ -354,10 +354,10 @@
 		// Start boosting
 		if (bKey)
 		{
-			if (gMC.equip & 0x21 && gKeyTrg & gKeyJump && gMC.boost_cnt != 0)
+			if (gMC.equip & (EQUIP_BOOSTER_0_8 | EQUIP_BOOSTER_2_0) && gKeyTrg & gKeyJump && gMC.boost_cnt != 0)
 			{
 				// Booster 0.8
-				if (gMC.equip & 1)
+				if (gMC.equip & EQUIP_BOOSTER_0_8)
 				{
 					gMC.boost_sw = 1;
 
@@ -366,7 +366,7 @@
 				}
 
 				// Booster 2.0
-				if (gMC.equip & 0x20)
+				if (gMC.equip & EQUIP_BOOSTER_2_0)
 				{
 					if (gKey & gKeyUp)
 					{
@@ -414,7 +414,7 @@
 		}
 
 		// Slow down when stopped boosting (Booster 2.0)
-		if (gMC.equip & 0x20 && gMC.boost_sw != 0 && (!(gKey & gKeyJump) || gMC.boost_cnt == 0))
+		if (gMC.equip & EQUIP_BOOSTER_2_0 && gMC.boost_sw != 0 && (!(gKey & gKeyJump) || gMC.boost_cnt == 0))
 		{
 			if (gMC.boost_sw == 1)
 				gMC.xm /= 2;
@@ -475,7 +475,7 @@
 		gMC.ym += 0x55;
 
 	// Booster 2.0 forces and effects
-	if (gMC.equip & 0x20 && gMC.boost_sw != 0)
+	if (gMC.equip & EQUIP_BOOSTER_2_0 && gMC.boost_sw != 0)
 	{
 		if (gMC.boost_sw == 1)
 		{
@@ -525,7 +525,7 @@
 		gMC.ym += gravity1;
 	}
 	// Booster 0.8
-	else if (gMC.equip & 1 && gMC.boost_sw != 0 && gMC.ym > -0x400)
+	else if (gMC.equip & EQUIP_BOOSTER_0_8 && gMC.boost_sw != 0 && gMC.ym > -0x400)
 	{
 		// Upwards force
 		gMC.ym -= 0x20;
@@ -809,7 +809,7 @@
 
 void AirProcess(void)
 {
-	if (gMC.equip & 0x10)
+	if (gMC.equip & EQUIP_AIR_TANK)
 	{
 		gMC.air = 1000;
 		gMC.air_get = 0;
--- a/src/MyChar.h
+++ b/src/MyChar.h
@@ -5,6 +5,20 @@
 // TODO - When I add bitmask constants for gMC.flags...
 // 0x100 is a 'player is underwater' flag
 
+// gMC.equip
+enum
+{
+	EQUIP_BOOSTER_0_8 = 1,
+	EQUIP_MAP = 2,
+	EQUIP_ARMS_BARRIER = 4,
+	EQUIP_TURBOCHARGE = 8,
+	EQUIP_AIR_TANK = 0x10,
+	EQUIP_BOOSTER_2_0 = 0x20,
+	EQUIP_MIMIGA_MASK = 0x40,
+	EQUIP_WHIMSICAL_STAR = 0x80,
+	EQUIP_NIKUMARU_COUNTER = 0x100
+};
+
 typedef struct MYCHAR
 {
 	unsigned char cond;
--- a/src/MycParam.cpp
+++ b/src/MycParam.cpp
@@ -48,7 +48,7 @@
 		{
 			gArmsData[gSelectedArms].exp = gArmsLevelTable[arms_code].exp[lv];
 
-			if (gMC.equip & 0x80)
+			if (gMC.equip & EQUIP_WHIMSICAL_STAR)
 			{
 				if (gMC.star < 3)
 					++gMC.star;
@@ -136,11 +136,11 @@
 	gMC.life -= (short)damage;
 
 	// Lose a whimsical star
-	if (gMC.equip & 0x80 && gMC.star > 0)
+	if (gMC.equip & EQUIP_WHIMSICAL_STAR && gMC.star > 0)
 		gMC.star = (short)gMC.star - 1;	// For some reason, this does a cast to short. Might not be accurate to the original source code (possibly, Pixel was just being careful about int size/conversion, or this is from some weird macro)
 
 	// Lose experience
-	if (gMC.equip & 4)
+	if (gMC.equip & EQUIP_ARMS_BARRIER)
 		gArmsData[gSelectedArms].exp -= damage;
 	else
 		gArmsData[gSelectedArms].exp -= damage * 2;
@@ -373,7 +373,7 @@
 		{112, 80, 144, 88},
 	};
 
-	if (gMC.equip & 0x10)
+	if (gMC.equip & EQUIP_AIR_TANK)
 		return;
 
 	if (gMC.air_get != 0)
@@ -400,7 +400,7 @@
 		{128, 104, 160, 112},
 	};
 
-	if (gMC.equip & 0x100)
+	if (gMC.equip & EQUIP_NIKUMARU_COUNTER)
 	{
 		// Draw clock and increase time
 		if (g_GameFlags & 2)
@@ -439,7 +439,7 @@
 	char path[MAX_PATH];
 
 	// Quit if player doesn't have the Nikumaru Counter
-	if (!(gMC.equip & 0x100))
+	if (!(gMC.equip & EQUIP_NIKUMARU_COUNTER))
 		return TRUE;
 
 	// Get last time
--- a/src/NpcAct100.cpp
+++ b/src/NpcAct100.cpp
@@ -842,7 +842,7 @@
 		npc->rect = rcRight[npc->ani_no];
 
 	// Use a different sprite if the player is wearing the Mimiga Mask
-	if (gMC.equip & 0x40)
+	if (gMC.equip & EQUIP_MIMIGA_MASK)
 	{
 		npc->rect.top += 32;
 		npc->rect.bottom += 32;
@@ -919,7 +919,7 @@
 		npc->rect = rcRight[npc->ani_no];
 
 	// Use a different sprite if the player is wearing the Mimiga Mask
-	if (gMC.equip & 0x40)
+	if (gMC.equip & EQUIP_MIMIGA_MASK)
 	{
 		npc->rect.top += 32;
 		npc->rect.bottom += 32;
--- a/src/NpcAct140.cpp
+++ b/src/NpcAct140.cpp
@@ -1277,7 +1277,7 @@
 	}
 
 	// Use a different sprite if the player is wearing the Mimiga Mask
-	if (gMC.equip & 0x40)
+	if (gMC.equip & EQUIP_MIMIGA_MASK)
 	{
 		npc->rect.top += 32;
 		npc->rect.bottom += 32;
--- a/src/NpcAct200.cpp
+++ b/src/NpcAct200.cpp
@@ -999,7 +999,7 @@
 	npc->rect = rcRight[npc->ani_no];
 
 	// Use different sprite if player is wearing the Mimiga Mask
-	if (gMC.equip & 0x40)
+	if (gMC.equip & EQUIP_MIMIGA_MASK)
 	{
 		if (npc->ani_no > 1)
 		{
--- a/src/NpcAct280.cpp
+++ b/src/NpcAct280.cpp
@@ -443,7 +443,7 @@
 			else
 				npc->ani_no = 5;
 
-			if (gMC.equip & 0x20)
+			if (gMC.equip & EQUIP_BOOSTER_2_0)
 			{
 				if (npc->act_wait % 10 == 1)
 				{
@@ -1436,7 +1436,7 @@
 		case 1:
 			++npc->act_wait;
 
-			if (gMC.equip & 0x20)
+			if (gMC.equip & EQUIP_BOOSTER_2_0)
 			{
 				npc->x = gMC.x + (64 * 0x200);
 
@@ -1456,7 +1456,7 @@
 
 			if (npc->act_wait > 24)
 			{
-				if (gMC.equip & 0x20)
+				if (gMC.equip & EQUIP_BOOSTER_2_0)
 					x = npc->x + (Random(-14, 14) * 0x200 * 0x10);
 				else
 					x = npc->x + (Random(-11, 11) * 0x200 * 0x10);
--- a/src/Shoot.cpp
+++ b/src/Shoot.cpp
@@ -357,7 +357,7 @@
 	{
 		++wait;
 
-		if (gMC.equip & 8)
+		if (gMC.equip & EQUIP_TURBOCHARGE)
 		{
 			if (wait > 1)
 			{
@@ -915,7 +915,7 @@
 
 	if (gKey & gKeyShot)
 	{
-		if (gMC.equip & 8)
+		if (gMC.equip & EQUIP_TURBOCHARGE)
 			AddExpMyChar(3);
 		else
 			AddExpMyChar(2);
--- a/src/Star.cpp
+++ b/src/Star.cpp
@@ -112,7 +112,7 @@
 		star[i].x += star[i].xm;
 		star[i].y += star[i].ym;
 
-		if (i < gMC.star && (gMC.equip & 0x80) && (g_GameFlags & 2) && a == i)
+		if (i < gMC.star && (gMC.equip & EQUIP_WHIMSICAL_STAR) && (g_GameFlags & 2) && a == i)
 			SetBullet(45, star[a].x, star[a].y, 0);
 	}
 }
@@ -130,7 +130,7 @@
 	if (gMC.cond & 2)
 		return;
 
-	if (!(gMC.equip & 0x80))
+	if (!(gMC.equip & EQUIP_WHIMSICAL_STAR))
 		return;
 
 	for (i = 0; i < 3; ++i)