aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--brice.dat5
-rw-r--r--include/brice.hpp1
-rw-r--r--include/coolarray.hpp2
-rw-r--r--main.cpp15
-rw-r--r--src/brice.cpp6
-rw-r--r--src/mob.cpp11
-rw-r--r--xml/playerSpawnHill1.xml20
-rw-r--r--xml/playerSpawnHill1_Building1.xml37
-rw-r--r--xml/playerSpawnHill2.xml13
9 files changed, 55 insertions, 55 deletions
diff --git a/brice.dat b/brice.dat
index 4bfeac6..e69de29 100644
--- a/brice.dat
+++ b/brice.dat
@@ -1,5 +0,0 @@
-2
-canJump
-1
-canSprint
-1
diff --git a/include/brice.hpp b/include/brice.hpp
index 5f82fec..dc3ea96 100644
--- a/include/brice.hpp
+++ b/include/brice.hpp
@@ -11,6 +11,7 @@ namespace game {
bool setValue(const std::string& id, const std::string& value);
+ void briceClear(void);
void briceSave(void);
void briceLoad(void);
diff --git a/include/coolarray.hpp b/include/coolarray.hpp
index 3e167b7..5388aab 100644
--- a/include/coolarray.hpp
+++ b/include/coolarray.hpp
@@ -16,7 +16,7 @@ public:
_capacity = 0;
}
- CoolArray(size_t n, const T& value) {
+ CoolArray(size_t n, const T& value=0) {
buffer = new T[n];
_size = n;
_capacity = n;
diff --git a/main.cpp b/main.cpp
index fdecea9..4dac3b8 100644
--- a/main.cpp
+++ b/main.cpp
@@ -260,18 +260,19 @@ int main(int argc, char *argv[])
for (const auto &xf : xmlFiles) {
if (xf[0] != '.') {
XMLDocument xmld;
- xmld.LoadFile(xf.c_str());
+ auto file = xmlFolder + xf;
+ xmld.LoadFile(file.c_str());
auto xmle = xmld.FirstChildElement("World");
- if (xmle == nullptr)
+ if (xmle == nullptr) {
xmle = xmld.FirstChildElement("IndoorWorld");
- if (xmle == nullptr)
- continue;
+ if (xmle == nullptr)
+ continue;
+ }
xmle = xmle->FirstChildElement();
- std::cout << xmle->Name() << '\n';
while (xmle) {
xmle->DeleteAttribute("x");
xmle->DeleteAttribute("y");
@@ -280,9 +281,11 @@ int main(int argc, char *argv[])
xmle->DeleteAttribute("dindex");
xmle = xmle->NextSiblingElement();
}
- xmld.SaveFile(xf.c_str(), false);
+ xmld.SaveFile(file.c_str(), false);
}
}
+
+ game::briceClear();
}
if (currentWorld == nullptr) {
diff --git a/src/brice.cpp b/src/brice.cpp
index 07cd05d..d5ac46d 100644
--- a/src/brice.cpp
+++ b/src/brice.cpp
@@ -33,6 +33,12 @@ namespace game {
}
}
+ void briceClear(void) {
+ std::ofstream out ("brice.dat", std::ios::out);
+ out.close();
+ brice.clear();
+ }
+
void briceSave(void) {
std::ofstream out ("brice.dat", std::ios::out | std::ios::binary);
std::string data = std::to_string(brice.size()) + '\n';
diff --git a/src/mob.cpp b/src/mob.cpp
index ed9fbf4..7701086 100644
--- a/src/mob.cpp
+++ b/src/mob.cpp
@@ -350,11 +350,20 @@ void Trigger::act(void)
xml.LoadFile(currentXML.c_str());
exml = xml.FirstChildElement("Trigger");
- while(exml->StrAttribute("id") != id)
+ while(exml && exml->StrAttribute("id") != id)
exml = exml->NextSiblingElement();
player->vel.x = 0;
+ if (exml == nullptr) {
+ auto id = xmle->StrAttribute("cid");
+ if (!id.empty()) {
+ game::setValue(id, xmle->StrAttribute("cvalue"));
+ game::briceUpdate();
+ }
+ return;
+ }
+
ui::toggleBlackFast();
ui::waitForCover();
diff --git a/xml/playerSpawnHill1.xml b/xml/playerSpawnHill1.xml
index c5d88d6..d7889fc 100644
--- a/xml/playerSpawnHill1.xml
+++ b/xml/playerSpawnHill1.xml
@@ -5,13 +5,13 @@
<link right="playerSpawnHill2.xml"/>
<time>12000</time>
<hill peakx="0" peaky="1000" width="50"/>
- <rabbit spawnx="300" aggressive="false" maxHealth="100" health="32"/>
- <bird spawny="500" x="808.80286" y="295.4079" health="1"/>
- <cat x="0" y="64.496956" alive="1"/>
+ <rabbit spawnx="300" aggressive="false" maxHealth="100"/>
+ <bird spawny="500"/>
+ <cat/>
<!--<trigger x="-300" id="Test"/>-->
- <npc name="Ralph" hasDialog="true" spawnx="300" health="1" x="-10.007523" y="65.396942" dindex="2"/>
- <npc name="Johnny" hasDialog="false" spawnx="300" health="1" x="824.5191" y="71.996918" dindex="0"/>
- <npc name="Big Dave" hasDialog="true" spawnx="300" health="1" x="377.85727" y="62.197029" dindex="9999"/>
+ <npc name="Ralph" hasDialog="true" spawnx="300"/>
+ <npc name="Johnny" hasDialog="false" spawnx="300"/>
+ <npc name="Big Dave" hasDialog="true" spawnx="300"/>
<page spawnx="-200" id="assets/pages/gootaGoFast.png" cid="canSprint" cvalue="1"/>
<page spawnx="-500" id="assets/pages/gootaJump.png" cid="canJump" cvalue="1"/>
<village name="Big Dave&apos;s bagel emporium! The greatest place on earth!">
@@ -38,14 +38,14 @@ And it wasn't stormy.
<Dialog name="Ralph">
<text id="0" nextid="1">
Hello there! My name is Ralph.
- <gotox>300</gotox>
+ <gotox>300</gotox>
</text>
<text id="1" nextid="2" call="Johnny" callid="0" pause="true">
You should go talk to my friend Johnny. He's a pretty chill dude.
</text>
<text id="2">
Niice.
- <quest check="Your First Quest" fail="3"/></text>
+ <quest check="Your First Quest" fail="3"/></text>
<text id="3">
Go check out Johnny. He's cool.
</text>
@@ -54,7 +54,7 @@ And it wasn't stormy.
<Dialog name="Johnny">
<text id="0" nextid="1" pause="true">
Sup bro! Have a quest. To complete it, just go talk to Ralph again.
- <quest assign="Your First Quest">
+ <quest assign="Your First Quest">
Dank MayMay,2
Wood Sword,1
</quest>
@@ -68,5 +68,5 @@ And it wasn't stormy.
<text id="0" pause="true">
Hey friend! It's dangerous out there, here take these!
Wait, promise you'll stop by my stand in the local market!
- <give id="Wood Sword" count="1"/> <give id="Hunters Bow" count="1"/> <give id="Crude Arrow" count="110"/> <give id="Fried Chicken" count="1"/> <give id="Mossy Torch" count="1"/></text>
+ <give id="Wood Sword" count="1"/> <give id="Hunters Bow" count="1"/> <give id="Crude Arrow" count="110"/> <give id="Fried Chicken" count="1"/> <give id="Mossy Torch" count="1"/></text>
</Dialog>
diff --git a/xml/playerSpawnHill1_Building1.xml b/xml/playerSpawnHill1_Building1.xml
index 0cf04c1..800f007 100644
--- a/xml/playerSpawnHill1_Building1.xml
+++ b/xml/playerSpawnHill1_Building1.xml
@@ -1,37 +1,26 @@
<?xml version="1.0"?>
<IndoorWorld>
- <style background="1" bgm="assets/music/theme_jazz.wav" />
- <link outside="playerSpawnHill1.xml"/>
-
- <floor width="300" />
- <floor width="200" start="100" />
-
- <npc name="Bob" hasDialog="true" floor="2" />
-
+ <style background="1" bgm="assets/music/theme_jazz.wav"/>
+ <link outside="playerSpawnHill1.xml"/>
+ <floor width="300"/>
+ <floor width="200" start="100"/>
+ <npc name="Bob" hasDialog="true" floor="2"/>
</IndoorWorld>
<Dialog name="Bob">
- <text id="0" nextid="1" pause="true">
+ <text id="0" nextid="1" pause="true">
Hey. Have a Dank MayMay :)
- <give id="Dank MayMay" count="1" />
- </text>
-
- <text id="1" nextid="2">
+ <give id="Dank MayMay" count="1"/></text>
+ <text id="1" nextid="2">
What? You want another Dank MayMay?
</text>
-
- <text id="2" nextid="3" pause="true">
+ <text id="2" nextid="3" pause="true">
K.
- <give id="Dank MayMay" count="1" />
- </text>
-
- <text id="3" nextid="4">
+ <give id="Dank MayMay" count="1"/></text>
+ <text id="3" nextid="4">
Well... I'm out of Dank MayMays.
</text>
-
- <text id="4">
+ <text id="4">
Have a sword though.
- <give id="Wood Sword" count="1"/>
- </text>
-
+ <give id="Wood Sword" count="1"/></text>
</Dialog>
diff --git a/xml/playerSpawnHill2.xml b/xml/playerSpawnHill2.xml
index 4829087..c0ef541 100644
--- a/xml/playerSpawnHill2.xml
+++ b/xml/playerSpawnHill2.xml
@@ -1,11 +1,8 @@
<?xml version="1.0"?>
<World>
- <style background="0" bgm="assets/music/embark.wav" folder="assets/style/rustic/"/>
- <generation type="Random" width="1000" />
- <structure type="5" inside="playerSpawnHill1_Building1.xml"/>
-
- <npc name="Swag" x="0" />
-
- <link left="playerSpawnHill1.xml" />
-
+ <style background="0" bgm="assets/music/embark.wav" folder="assets/style/rustic/"/>
+ <generation type="Random" width="1000"/>
+ <structure type="5" inside="playerSpawnHill1_Building1.xml"/>
+ <npc name="Swag"/>
+ <link left="playerSpawnHill1.xml"/>
</World>