From 1db72b5e45cc25eb183817f05a2ee631d8fff837 Mon Sep 17 00:00:00 2001
From: Treeki <treeki@gmail.com>
Date: Sun, 30 Sep 2012 01:04:08 +0200
Subject: added world stars, still needs fixed positioning though

---
 include/game.h                |  3 ++-
 src/fileselect.S              |  2 +-
 src/koopatlas/hud.cpp         | 46 +++++++++++++++++++++++++++++++++++++++++--
 src/koopatlas/hud.h           |  3 ++-
 src/koopatlas/pathmanager.cpp |  1 +
 5 files changed, 50 insertions(+), 5 deletions(-)

diff --git a/include/game.h b/include/game.h
index ef6aba4..91dd77a 100755
--- a/include/game.h
+++ b/include/game.h
@@ -160,6 +160,7 @@ bool IsWideScreen();
 #define COND_COIN1 1
 #define COND_COIN2 2
 #define COND_COIN3 4
+#define COND_COIN_ALL 7
 #define COND_NORMAL 0x10
 #define COND_SECRET 0x20
 #define COND_SGNORMAL 0x80
@@ -244,7 +245,7 @@ public:
 			GXColor hudTextColours[2]; // 0x730
 			s16 hudHintH, hudHintS, hudHintL; // 0x738
 			u8 currentMapMusic; // 0x73E
-			u8 _padding; // 0x73F
+			u8 newerWorldID; // 0x73F
 		};
 	};
 	u8 toad_location[10];		// 0x742
diff --git a/src/fileselect.S b/src/fileselect.S
index 6ee1c39..8e9249e 100644
--- a/src/fileselect.S
+++ b/src/fileselect.S
@@ -306,7 +306,7 @@ DefaultSavefileInfoData:
 .long 0x173714FF,0x3C9135FF
 .long 0xFFFF99FF,0x1FB423FF
 .short 0x75,0x2E,0xB
-.byte 0,0
+.byte 0,1
 
 DefaultSavefileInfoDataEnd:
 .long 0
diff --git a/src/koopatlas/hud.cpp b/src/koopatlas/hud.cpp
index b309e44..7046e77 100644
--- a/src/koopatlas/hud.cpp
+++ b/src/koopatlas/hud.cpp
@@ -210,9 +210,10 @@ int dWMHud_c::onCreate() {
 			"StarCoinOff0", "StarCoinOff1", "StarCoinOff2",
 			"StarCoinOn0", "StarCoinOn1", "StarCoinOn2",
 			"P_marioFace_00", "P_luigiFace_00",
-			"P_BkinoFace_00", "P_YkinoFace_00"
+			"P_BkinoFace_00", "P_YkinoFace_00",
+			"Star0", "Star1", "Star2"
 		};
-		layout.getPictures(pictureNames, &Header_Centre, 15);
+		layout.getPictures(pictureNames, &Header_Centre, 18);
 
 		static const char *textBoxNames[] = {
 			"LevelName", "LevelNameS",
@@ -483,6 +484,47 @@ void dWMHud_c::loadFooterInfo() {
 	WorldName->colour2 = save->hudTextColours[1];
 
 	footerCol.colourise(save->hudHintH, save->hudHintS, save->hudHintL);
+
+	// figure out if stars are needed
+	// Star 0: world is complete
+	// Star 1: all exits complete
+	// Star 2: all star coins obtained
+	
+	int lastLevelID = 27; // airship
+	if (save->newerWorldID >= 10)
+		lastLevelID = 24; // fortress
+	else if (save->newerWorldID == 8)
+		lastLevelID = 25; // final castle
+
+	dLevelInfo_c *linfo = &dScKoopatlas_c::instance->levelInfo;
+	dLevelInfo_c::entry_s *lastLevel = linfo->searchByDisplayNum(save->newerWorldID, lastLevelID);
+	bool lastComplete = false;
+	if (lastLevel) {
+		lastComplete = (save->GetLevelCondition(lastLevel->worldSlot,lastLevel->levelSlot) & COND_NORMAL);
+	}
+
+	// now calculate the other two
+	bool haveExits = true, haveCoins = true;
+
+	dLevelInfo_c::section_s *sect = linfo->getSectionByIndex(save->newerWorldID);
+
+	for (int i = 0; i < sect->levelCount; i++) {
+		dLevelInfo_c::entry_s *entry = &sect->levels[i];
+		u32 conds = save->GetLevelCondition(entry->worldSlot, entry->levelSlot);
+
+		if (((entry->flags & 0x10) && !(conds & COND_NORMAL)) ||
+				((entry->flags & 0x20) && !(conds & COND_SECRET)))
+					haveExits = false;
+
+		if (entry->flags & 2) {
+			if ((conds & COND_COIN_ALL) != COND_COIN_ALL)
+				haveCoins = false;
+		}
+	}
+
+	Star[0]->SetVisible(lastComplete);
+	Star[1]->SetVisible(haveExits);
+	Star[2]->SetVisible(haveCoins);
 }
 
 
diff --git a/src/koopatlas/hud.h b/src/koopatlas/hud.h
index 5996b88..ee64133 100644
--- a/src/koopatlas/hud.h
+++ b/src/koopatlas/hud.h
@@ -70,7 +70,8 @@ class dWMHud_c : public dBase_c {
 			*StarCoinOff[3],
 			*StarCoinOn[3],
 			*P_marioFace_00, *P_luigiFace_00,
-			*P_BkinoFace_00, *P_YkinoFace_00;
+			*P_BkinoFace_00, *P_YkinoFace_00,
+			*Star[3];
 
 		nw4r::lyt::TextBox
 			*LevelName, *LevelNameS,
diff --git a/src/koopatlas/pathmanager.cpp b/src/koopatlas/pathmanager.cpp
index c691a89..995c906 100644
--- a/src/koopatlas/pathmanager.cpp
+++ b/src/koopatlas/pathmanager.cpp
@@ -615,6 +615,7 @@ void dWMPathManager_c::moveThroughPath() {
 					OSReport("Found!\n");
 					strncpy(save->newerWorldName, world->name, 36);
 					save->newerWorldName[35] = 0;
+					save->newerWorldID = world->worldID;
 					save->currentMapMusic = world->trackID;
 
 					for (int i = 0; i < 2; i++) {
-- 
cgit v1.2.3