diff options
-rw-r--r-- | include/inventory.hpp | 11 | ||||
-rw-r--r-- | main.cpp | 36 | ||||
-rw-r--r-- | src/inventory.cpp | 46 | ||||
-rw-r--r-- | src/player.cpp | 2 | ||||
-rw-r--r-- | src/world.cpp | 15 |
5 files changed, 78 insertions, 32 deletions
diff --git a/include/inventory.hpp b/include/inventory.hpp index 8329d72..1de22dc 100644 --- a/include/inventory.hpp +++ b/include/inventory.hpp @@ -75,8 +75,8 @@ struct InventoryEntry { vec2 loc; /**< Used by render, to determine slot location on screen */ - InventoryEntry(void) - : item(nullptr), count(0) {} + InventoryEntry(Item* i = nullptr, int c = 0, vec2 l = vec2()) + : item(i), count(c), loc(l) {} }; struct UseItemEvent { @@ -139,8 +139,11 @@ public: */ static bool take(const std::string& name, int count); - static inline Item getItem(const std::string& s) - { return itemList[s]; } + static void makeDrop(const vec2& p, InventoryEntry& ie); + static void makeDrop(const vec2& p, const std::string& s, int c); + + static inline Item* getItem(const std::string& s) + { return &itemList[s]; } }; #endif // INVENTORY_HPP_ @@ -35,6 +35,15 @@ std::string xmlFolder = "./xml/"; */ vec2 offset; +std::size_t getUsedMem(void); +void deleteRemaining(void); +extern int balance; + +void print(void) { + std::cout << "Used memory: " << getUsedMem() << " bytes\n"; + std::cout << "New/delete balance: " << balance << '\n'; +} + /** * The main program. * Init, load, run. Die. @@ -44,6 +53,10 @@ int main(int argc, char *argv[]) static bool worldReset = false, worldDontReallyRun = false; std::string worldActuallyUseThisXMLFile; + print(); + atexit(print); + //atexit(deleteRemaining); + // handle command line args if (argc > 1) { for (int i = 1; i < argc; i++) { @@ -191,7 +204,7 @@ int main(int argc, char *argv[]) WorldSystem::die(); WindowSystem::die(); - return 0; // Calls everything passed to atexit + return 0; // Calls everything passed to atexit } constexpr int memEntries = 2048; @@ -210,11 +223,24 @@ std::size_t getUsedMem(void) return total; } +void deleteRemaining(void) +{ + for (int i = 0; i < memEntries; i++) { + if (mems[i] != nullptr) { + balance--; + std::free(mems[i]); + mems[i] = nullptr; + sizs[i] = 0; + } + } + +} + void *operator new(std::size_t n) throw (std::bad_alloc) { - auto buf = std::malloc(n); balance++; + auto buf = std::malloc(n); if (buf == nullptr) throw std::bad_alloc(); @@ -232,11 +258,10 @@ void *operator new(std::size_t n) throw (std::bad_alloc) void operator delete(void* p) throw () { if (p != nullptr) { - std::free(p); balance--; - for (int i = 0; i < memEntries; i++) { if (mems[i] == p) { + std::free(p); mems[i] = nullptr; sizs[i] = 0; break; @@ -250,11 +275,10 @@ void operator delete(void* p, std::size_t n) throw () (void)n; if (p != nullptr) { - std::free(p); balance--; - for (int i = 0; i < memEntries; i++) { if (mems[i] == p) { + std::free(p); mems[i] = nullptr; sizs[i] = 0; break; diff --git a/src/inventory.cpp b/src/inventory.cpp index 434eac6..96c1d6d 100644 --- a/src/inventory.cpp +++ b/src/inventory.cpp @@ -219,25 +219,45 @@ void InventorySystem::receive(const MouseReleaseEvent &mre) } } - auto e = game::entities.create(); - e.assign<Position>(mre.position.x, mre.position.y); - e.assign<Direction>(0, 0.1f); - e.assign<ItemDrop>(items[movingItem]); - e.assign<Sprite>(); - e.component<Sprite>()->addSpriteSegment( - SpriteData(items[movingItem].item->sprite), vec2(0, 0)); - auto dim = items[movingItem].item->sprite.getDim(); - e.assign<Solid>(HLINES(dim.x), HLINES(dim.y)); - e.assign<Visible>(); - e.assign<Physics>(); - + makeDrop(mre.position, items[movingItem]); items[movingItem].item = nullptr; items[movingItem].count = 0; - movingItem = -1; } } +void InventorySystem::makeDrop(const vec2& p, InventoryEntry& ie) +{ + auto e = game::entities.create(); + e.assign<Position>(p.x, p.y); + e.assign<Direction>(0, 0.1f); + e.assign<ItemDrop>(ie); + e.assign<Sprite>(); + e.component<Sprite>()->addSpriteSegment( + SpriteData(ie.item->sprite), vec2(0, 0)); + auto dim = ie.item->sprite.getDim(); + e.assign<Solid>(HLINES(dim.x), HLINES(dim.y)); + e.assign<Visible>(); + e.assign<Physics>(); +} + +void InventorySystem::makeDrop(const vec2& p, const std::string& s, int c) +{ + auto item = getItem(s); + auto e = game::entities.create(); + e.assign<Position>(p.x, p.y); + e.assign<Direction>(0, 0.1f); + InventoryEntry ie (item, c); + e.assign<ItemDrop>(ie); + e.assign<Sprite>(); + e.component<Sprite>()->addSpriteSegment( + SpriteData(item->sprite), vec2(0, 0)); + auto dim = item->sprite.getDim(); + e.assign<Solid>(HLINES(dim.x), HLINES(dim.y)); + e.assign<Visible>(); + e.assign<Physics>(); +} + void InventorySystem::receive(const KeyDownEvent &kde) { if (kde.keycode == SDLK_e) { diff --git a/src/player.cpp b/src/player.cpp index 0256190..01b8a7c 100644 --- a/src/player.cpp +++ b/src/player.cpp @@ -245,7 +245,7 @@ void PlayerSystem::receive(const UseItemEvent& uie) e.assign<Physics>(); auto sprite = e.assign<Sprite>(); auto tex = InventorySystem::getItem("Arrow"); - sprite->addSpriteSegment(SpriteData(tex.sprite), 0); + sprite->addSpriteSegment(SpriteData(tex->sprite), 0); auto dim = HLINES(sprite->getSpriteSize()); e.assign<Solid>(dim.x, dim.y); e.assign<Hit>(10, false); diff --git a/src/world.cpp b/src/world.cpp index bf34973..912a0c9 100644 --- a/src/world.cpp +++ b/src/world.cpp @@ -669,14 +669,13 @@ void WorldSystem::render(void) //glUniform4f(Render::worldShader.uniform[WU_tex_color], 1.0, 1.0, 1.0, 1.3 - static_cast<float>(alpha) / 255.0f); //makeWorldDrawingSimplerEvenThoughAndyDoesntThinkWeCanMakeItIntoFunctions(0, fron_tex_coord, tex_coord, 6); - // TODO make stars dynamic (make them particles??) - static const Texture starTex ("assets/style/classic/bg/star.png"); // TODO why in theme, not just std.? - const static float stardim = 24; - GLfloat* star_coord = new GLfloat[stars.size() * 5 * 6 + 1]; - GLfloat* si = &star_coord[0]; - if (worldShade > 0) { + static const Texture starTex ("assets/style/classic/bg/star.png"); // TODO why in theme, not just std.? + static const float stardim = 24; + + GLfloat* star_coord = new GLfloat[stars.size() * 5 * 6 + 1]; + auto si = &star_coord; auto xcoord = offset.x * 0.9f; for (auto &s : stars) { @@ -698,9 +697,9 @@ void WorldSystem::render(void) glVertexAttribPointer(Render::worldShader.coord, 3, GL_FLOAT, GL_FALSE, 5 * sizeof(GLfloat), &star_coord[0]); glVertexAttribPointer(Render::worldShader.tex, 2, GL_FLOAT, GL_FALSE, 5 * sizeof(GLfloat), &star_coord[3]); glDrawArrays(GL_TRIANGLES, 0, stars.size() * 6); - } - delete[] star_coord; + delete[] star_coord; + } Render::worldShader.disable(); |