Sunset old state system finally.

This commit is contained in:
2023-11-02 12:36:14 -05:00
parent 62d207d066
commit 239f7b2fb9
32 changed files with 212 additions and 420 deletions

View File

@ -13,8 +13,7 @@ namespace Dawn {
public: public:
const std::string name; const std::string name;
bool_t loaded = false; bool_t loaded = false;
Event<> eventLoaded; StateEvent<> eventLoaded;
StateEvent<> event2Loaded;
/** /**
* Create an abstract Asset object. * Create an abstract Asset object.

View File

@ -15,7 +15,7 @@ void AssetManager::update() {
this->syncTick(); this->syncTick();
} }
void AssetManager::queueLoad(std::vector<Asset*> assets) { void AssetManager::queueLoad(const std::vector<Asset*> assets) {
std::merge( std::merge(
this->assetsToLoad.begin(), this->assetsToLoad.end(), this->assetsToLoad.begin(), this->assetsToLoad.end(),
assets.begin(), assets.end(), assets.begin(), assets.end(),
@ -27,7 +27,7 @@ void AssetManager::queueLoad(Asset *asset) {
this->assetsToLoad.push_back(asset); this->assetsToLoad.push_back(asset);
} }
void AssetManager::queueUnload(std::vector<Asset*> assets) { void AssetManager::queueUnload(const std::vector<Asset*> assets) {
std::cout << std::cout <<
"Asset list was queued to unload, but is not yet implemented" << "Asset list was queued to unload, but is not yet implemented" <<
std::endl; std::endl;
@ -46,60 +46,45 @@ void AssetManager::queueUnload(Asset *asset) {
} }
void AssetManager::queueSwap( void AssetManager::queueSwap(
std::vector<Asset*> newAssets, const std::vector<Asset*> newAssets,
std::vector<Asset*> oldAssets const std::vector<Asset*> oldAssets
) { ) {
std::vector<Asset*> unload; std::vector<Asset*> unload;
std::vector<Asset*> load; std::vector<Asset*> load;
// Determine assets to unload. // Determine assets to unload.
auto itUnload = oldAssets.begin(); std::for_each(oldAssets.begin(), oldAssets.end(), [&](Asset *asset){
while(itUnload != oldAssets.end()) { auto it = std::find(newAssets.begin(), newAssets.end(), asset);
auto inNewAssets = std::find(newAssets.begin(), newAssets.end(), *itUnload); if(it == newAssets.end()) unload.push_back(asset);
if(inNewAssets == newAssets.end()) unload.push_back(*itUnload); });
++itUnload;
}
// Determine assets to load // Determine assets to load
auto itLoad = newAssets.begin(); std::for_each(newAssets.begin(), newAssets.end(), [&](Asset *asset){
while(itLoad != newAssets.end()) { auto it = std::find(oldAssets.begin(), oldAssets.end(), asset);
auto inOldAssets = std::find(oldAssets.begin(), oldAssets.end(), *itLoad); if(it == oldAssets.end()) load.push_back(asset);
if(inOldAssets == oldAssets.end()) load.push_back(*itLoad); });
++itLoad;
}
this->queueUnload(unload); this->queueUnload(unload);
this->queueLoad(load); this->queueLoad(load);
} }
void AssetManager::syncTick() { void AssetManager::syncTick() {
auto it = this->assetsToLoad.begin(); std::erase_if(assetsToLoad, [&](auto &asset){
while(it != this->assetsToLoad.end()) {
auto asset = *it;
if(asset->loaded) { if(asset->loaded) {
it = this->assetsToLoad.erase(it);
asset->eventLoaded.invoke(); asset->eventLoaded.invoke();
asset->event2Loaded.invoke(); return true;
continue;
} }
asset->updateSync(); asset->updateSync();
asset->updateAsync();//TODO: Make Async asset->updateAsync();//TODO: Make Async
if(asset->loaded) { if(asset->loaded) {
it = this->assetsToLoad.erase(it);
asset->eventLoaded.invoke(); asset->eventLoaded.invoke();
asset->event2Loaded.invoke(); return true;
continue;
} }
++it; return asset->loaded;
} });
// auto it = this->assetsNotLoaded.begin();
// auto it2 = this->assetsToUnload.begin();
// while(it2 != this->assetsToUnload.end()) {
// ++it2;
// }
} }
void AssetManager::syncLoad() { void AssetManager::syncLoad() {
@ -109,9 +94,7 @@ void AssetManager::syncLoad() {
} }
AssetManager::~AssetManager() { AssetManager::~AssetManager() {
auto it = this->assets.begin(); std::for_each(this->assets.begin(), this->assets.end(), [&](auto &item){
while(it != this->assets.end()) { delete item.second;
delete it->second; });
++it;
}
} }

View File

@ -30,7 +30,13 @@ namespace Dawn {
* *
* @param assets Assets to load. * @param assets Assets to load.
*/ */
void queueLoad(std::vector<Asset*> assets); void queueLoad(const std::vector<Asset*> assets);
/**
* Queue a loading of a single asset. Does not actually begin loading.
*
* @param assets Assets to load.
*/
void queueLoad(Asset *assets); void queueLoad(Asset *assets);
/** /**
@ -38,7 +44,13 @@ namespace Dawn {
* *
* @param assets Assets to unload. * @param assets Assets to unload.
*/ */
void queueUnload(std::vector<Asset*> assets); void queueUnload(const std::vector<Asset*> assets);
/**
* Takes a single asset to queue to unload. Does not immediately unload.
*
* @param assets Assets to unload.
*/
void queueUnload(Asset* assets); void queueUnload(Asset* assets);
/** /**
@ -49,8 +61,8 @@ namespace Dawn {
* @param oldAssets Old list of assets to no longer maintain. * @param oldAssets Old list of assets to no longer maintain.
*/ */
void queueSwap( void queueSwap(
std::vector<Asset*> newAssets, const std::vector<Asset*> newAssets,
std::vector<Asset*> oldAssets const std::vector<Asset*> oldAssets
); );
/** /**

View File

@ -7,15 +7,14 @@
using namespace Dawn; using namespace Dawn;
IAssetLoader::IAssetLoader(std::string fileName) { IAssetLoader::IAssetLoader(const std::string fileName) : fileName(fileName) {
assertTrue( assertTrue(
fileName.size() > 0, fileName.size() > 0,
"IAssetLoader::IAssetLoader: fileName must be greater than 0" "IAssetLoader::IAssetLoader: fileName must be greater than 0"
); );
this->fileName = fileName;
} }
size_t IAssetLoader::setPosition(size_t position) { size_t IAssetLoader::setPosition(const size_t position) {
assertTrue( assertTrue(
position >= 0, position >= 0,
"IAssetLoader::setPosition: position must be greater than or equal to 0" "IAssetLoader::setPosition: position must be greater than or equal to 0"

View File

@ -24,7 +24,7 @@ namespace Dawn {
* *
* @param fileName File name of the asset that is to be loaded. * @param fileName File name of the asset that is to be loaded.
*/ */
IAssetLoader(std::string fileName); IAssetLoader(const std::string fileName);
/** /**
* Platform-centric method to open a file buffer to an asset. * Platform-centric method to open a file buffer to an asset.
@ -43,7 +43,7 @@ namespace Dawn {
* @param size Length of the data buffer (How many bytes to read). * @param size Length of the data buffer (How many bytes to read).
* @return The count of bytes read. * @return The count of bytes read.
*/ */
virtual size_t read(uint8_t *buffer, size_t size) = 0; virtual size_t read(uint8_t *buffer, const size_t size) = 0;
/** /**
* Get the size of the asset. * Get the size of the asset.
@ -57,7 +57,7 @@ namespace Dawn {
* @param n Count of bytes to progress the read head by. * @param n Count of bytes to progress the read head by.
* @return Count of bytes progressed. * @return Count of bytes progressed.
*/ */
virtual size_t skip(size_t n) = 0; virtual size_t skip(const size_t n) = 0;
/** /**
* Rewind the read head to the beginning of the file. * Rewind the read head to the beginning of the file.
@ -70,7 +70,7 @@ namespace Dawn {
* *
* @param absolutePosition Absolute position to set the read head to. * @param absolutePosition Absolute position to set the read head to.
*/ */
size_t setPosition(size_t absolutePosition); size_t setPosition(const size_t absolutePosition);
/** /**
* Returns the current position of the read head. * Returns the current position of the read head.
@ -89,13 +89,14 @@ namespace Dawn {
* @return The count of bytes read. * @return The count of bytes read.
*/ */
template<class T> template<class T>
size_t loadBufferedCallback(T *instance, bool_t (T::*callback)(uint8_t n)) { size_t loadBufferedCallback(
std::function<bool_t(uint8_t n)> callback
) {
uint8_t buffer[1024]; uint8_t buffer[1024];
size_t read, length; size_t read, length;
int32_t i; int32_t i;
bool_t result; bool_t result;
assertNotNull(instance, "Instance cannot be null.");
assertNotNull(callback, "Callback cannot be null."); assertNotNull(callback, "Callback cannot be null.");
// Open the buffer. // Open the buffer.
@ -107,7 +108,7 @@ namespace Dawn {
// Buffer from input // Buffer from input
while((read = this->read(buffer, 1024)) != 0) { while((read = this->read(buffer, 1024)) != 0) {
for(i = 0; i < read; i++) { for(i = 0; i < read; i++) {
result = ((*instance).*(callback))(buffer[i]); result = callback(buffer[i]);
if(!result) { if(!result) {
length += i; length += i;
break; break;

View File

@ -64,7 +64,7 @@ void LanguageAsset::updateAsync() {
this->loaded = true; this->loaded = true;
} }
std::string LanguageAsset::getValue(std::string key) { std::string LanguageAsset::getValue(const std::string key) {
assertTrue( assertTrue(
this->state == LANGUAGE_ASSET_LOAD_STATE_READY_TO_READ, this->state == LANGUAGE_ASSET_LOAD_STATE_READY_TO_READ,
"State must be LANGUAGE_ASSET_LOAD_STATE_READY_TO_READ" "State must be LANGUAGE_ASSET_LOAD_STATE_READY_TO_READ"

View File

@ -31,6 +31,6 @@ namespace Dawn {
LanguageAsset(const std::string name); LanguageAsset(const std::string name);
void updateSync() override; void updateSync() override;
void updateAsync() override; void updateAsync() override;
std::string getValue(std::string key); std::string getValue(const std::string key);
}; };
} }

View File

@ -142,13 +142,15 @@ void TrueTypeAsset::updateAsync() {
// Now we are at the first byte of the first style. // Now we are at the first byte of the first style.
this->state = TRUE_TYPE_ASSET_STATE_ADJUSTING_OFFSETS; this->state = TRUE_TYPE_ASSET_STATE_ADJUSTING_OFFSETS;
auto itStyle = assetStyles.begin(); std::for_each(
while(itStyle != assetStyles.end()) { assetStyles.begin(),
(*itStyle).dataOffset = styleListBegin; assetStyles.end(),
styleListBegin += (*itStyle).dataSize; [&](struct TrueTypeAssetStyle &style){
styleListBegin += 1; // Vertical bar style.dataOffset = styleListBegin;
++itStyle; styleListBegin += style.dataSize;
} styleListBegin += 1;
}
);
// Init FreeType // Init FreeType
this->state = TRUE_TYPE_ASSET_STATE_INIT_FREETYPE; this->state = TRUE_TYPE_ASSET_STATE_INIT_FREETYPE;
@ -160,7 +162,7 @@ void TrueTypeAsset::updateAsync() {
this->loaded = true; this->loaded = true;
} }
usagelockid_t TrueTypeAsset::lock(struct TrueTypeFaceTextureStyle style) { usagelockid_t TrueTypeAsset::lock(const struct TrueTypeFaceTextureStyle style) {
assertTrue(this->state == TRUE_TYPE_ASSET_STATE_READY, "Asset is not ready"); assertTrue(this->state == TRUE_TYPE_ASSET_STATE_READY, "Asset is not ready");
// Try and find an existing texture that matches this style // Try and find an existing texture that matches this style
@ -214,22 +216,24 @@ usagelockid_t TrueTypeAsset::lock(struct TrueTypeFaceTextureStyle style) {
return lock; return lock;
} }
TrueTypeFaceTexture * TrueTypeAsset::getTexture(usagelockid_t id) { TrueTypeFaceTexture * TrueTypeAsset::getTexture(const usagelockid_t id) {
auto it = this->textureByLock.find(id); auto it = this->textureByLock.find(id);
assertTrue(it != this->textureByLock.end(), "Could not find texture"); assertTrue(it != this->textureByLock.end(), "Could not find texture");
return it->second; return it->second;
} }
void TrueTypeAsset::unlock(usagelockid_t id) { void TrueTypeAsset::unlock(const usagelockid_t id) {
this->locks.removeLock(id); this->locks.removeLock(id);
} }
TrueTypeAsset::~TrueTypeAsset() { TrueTypeAsset::~TrueTypeAsset() {
auto it = this->textures.begin(); std::for_each(
while(it != this->textures.end()) { this->textures.begin(),
delete (*it); this->textures.end(),
it++; [](TrueTypeFaceTexture *texture){
} delete texture;
}
);
FT_Done_FreeType(this->fontLibrary); FT_Done_FreeType(this->fontLibrary);
} }

View File

@ -55,7 +55,7 @@ namespace Dawn {
* @param style Style to lock. * @param style Style to lock.
* @return A unique lock ID for this style. * @return A unique lock ID for this style.
*/ */
usagelockid_t lock(struct TrueTypeFaceTextureStyle style); usagelockid_t lock(const struct TrueTypeFaceTextureStyle style);
/** /**
* Get a texture by a previous lock ID. * Get a texture by a previous lock ID.
@ -63,14 +63,14 @@ namespace Dawn {
* @param lock Lock to get the texture of. * @param lock Lock to get the texture of.
* @return Matching texture by this ID. * @return Matching texture by this ID.
*/ */
TrueTypeFaceTexture * getTexture(usagelockid_t lock); TrueTypeFaceTexture * getTexture(const usagelockid_t lock);
/** /**
* Releases a previously held font lock. * Releases a previously held font lock.
* *
* @param lock Lock to release/unlock. * @param lock Lock to release/unlock.
*/ */
void unlock(usagelockid_t lock); void unlock(const usagelockid_t lock);
~TrueTypeAsset(); ~TrueTypeAsset();
}; };

View File

@ -7,7 +7,8 @@
using namespace Dawn; using namespace Dawn;
IAudioManager::IAudioManager(DawnGame *game) { IAudioManager::IAudioManager() {
assertNotNull(game, "Game cannot be null."); }
this->game = game;
IAudioManager::~IAudioManager() {
} }

View File

@ -10,16 +10,11 @@ namespace Dawn {
class DawnGame; class DawnGame;
class IAudioManager { class IAudioManager {
protected:
DawnGame *game;
public: public:
/** /**
* Construct a new IAudioManager. * Construct a new IAudioManager.
*
* @param game The game instance.
*/ */
IAudioManager(DawnGame *game); IAudioManager();
/** /**
* Initializes the audio manager system. * Initializes the audio manager system.
@ -30,5 +25,10 @@ namespace Dawn {
* Ticks/Update the audio manager system. * Ticks/Update the audio manager system.
*/ */
virtual void update() = 0; virtual void update() = 0;
/**
* Deinitializes the audio manager system.
*/
virtual ~IAudioManager();
}; };
} }

View File

@ -6,7 +6,7 @@
#pragma once #pragma once
#include "util/flag.hpp" #include "util/flag.hpp"
#include "display/Color.hpp" #include "display/Color.hpp"
#include "event/Event.hpp" #include "state/StateEvent.hpp"
#define RENDER_TARGET_CLEAR_FLAG_COLOR FLAG_DEFINE(0) #define RENDER_TARGET_CLEAR_FLAG_COLOR FLAG_DEFINE(0)
#define RENDER_TARGET_CLEAR_FLAG_DEPTH FLAG_DEFINE(1) #define RENDER_TARGET_CLEAR_FLAG_DEPTH FLAG_DEFINE(1)
@ -14,7 +14,7 @@
namespace Dawn { namespace Dawn {
class RenderTarget { class RenderTarget {
public: public:
Event<RenderTarget*, float_t, float_t> eventRenderTargetResized; StateEvent<RenderTarget*, float_t, float_t> eventRenderTargetResized;
/** /**
* Return the width of the render target. * Return the width of the render target.

View File

@ -7,7 +7,6 @@
#include "dawnlibs.hpp" #include "dawnlibs.hpp"
#include "assert/assert.hpp" #include "assert/assert.hpp"
#include "util/flag.hpp" #include "util/flag.hpp"
#include "event/Event.hpp"
#include "state/StateEvent.hpp" #include "state/StateEvent.hpp"
namespace Dawn { namespace Dawn {

View File

@ -5,8 +5,6 @@
#pragma once #pragma once
#include "state/StateEvent.hpp" #include "state/StateEvent.hpp"
#include "Easing.hpp"
#include "util/mathutils.hpp"
namespace Dawn { namespace Dawn {
struct Animation { struct Animation {
@ -15,8 +13,7 @@ namespace Dawn {
bool_t finished = false; bool_t finished = false;
float_t time = 0; float_t time = 0;
float_t duration = 0; float_t duration = 0;
Event<> eventAnimationEnd; StateEvent<> eventAnimationEnd;
StateEvent<> event2AnimationEnd;
/** /**
* Ticks the animation along. Delta is whatever you want to update the * Ticks the animation along. Delta is whatever you want to update the
@ -26,7 +23,7 @@ namespace Dawn {
* *
* @param delta Time delta (in seconds) to tick the animaiton by. * @param delta Time delta (in seconds) to tick the animaiton by.
*/ */
virtual void tick(float_t delta) = 0; virtual void tick(const float_t delta) = 0;
/** /**
* Restart a running animation. * Restart a running animation.

View File

@ -8,4 +8,5 @@ target_sources(${DAWN_TARGET_NAME}
PRIVATE PRIVATE
Animation.cpp Animation.cpp
TiledSpriteAnimation.cpp TiledSpriteAnimation.cpp
easing.cpp
) )

View File

@ -1,78 +0,0 @@
/**
* Copyright (c) 2021 Dominic Masters
*
* This software is released under the MIT License.
* https://opensource.org/licenses/MIT
*/
#pragma once
#include "dawnlibs.hpp"
typedef float_t easefunction_t(float_t t);
/**
* Returns the ease time for a given real time duration span.
* @param start At what point in time the animation started
* @param current The current point in time the animation is at.
* @param duration The total duration on the animation.
* @returns The easing time (0-1 time) that the animation is at.
*/
static inline float_t easeTimeToEase(
float_t start,
float_t current,
float_t duration
) {
return (current - start) / duration;
}
static inline float_t easeLinear(float_t t) {
return t;
}
static inline float_t easeInQuad(float_t t) {
return t * t;
}
static inline float_t easeOutQuad(float_t t) {
return t * (2 - t);
}
static inline float_t easeOutCubic(float_t t) {
return 1 - powf(1 - t, 3);
}
static inline float_t easeInOutQuad(float_t t) {
return t < .5 ? 2 * t * t : -1 + (4 - 2 * t) * t;
}
static inline float_t easeInCubic(float_t t) {
return t * t * t;
}
static inline float_t easeInOutCubic(float_t t) {
return t < .5 ? 4 * t * t * t : (t - 1) * (2 * t - 2) * (2 * t - 2) + 1;
}
static inline float_t easeInQuart(float_t t) {
return t * t * t * t;
}
static inline float_t easeOutQuart(float_t t) {
return 1 - (t-1)*(t-1)*(t-1)*(t-1);
}
static inline float_t easeInOutQuart(float_t t) {
return t < .5 ? 8*t*t*t*t : 1-8*(t-1)*(t-1)*(t-1)*(t-1);
}
static inline float_t easeInQuint(float_t t) {
return t*t*t*t*t;
}
static inline float_t easeOutQuint(float_t t) {
return 1 + (t-1)*(t-1)*(t-1)*(t-1)*(t-1);
}
static inline float_t easeInOutQuint(float_t t) {
return t<.5 ? 16*t*t*t*t*t : 1+16*(t-1)*(t-1)*(t-1)*(t-1)*(t-1);
}

View File

@ -5,6 +5,8 @@
#pragma once #pragma once
#include "Animation.hpp" #include "Animation.hpp"
#include "easing.hpp"
#include "util/mathutils.hpp"
namespace Dawn { namespace Dawn {
template<typename T> template<typename T>
@ -195,7 +197,6 @@ namespace Dawn {
// Animation end. // Animation end.
this->finished = true; this->finished = true;
this->eventAnimationEnd.invoke(); this->eventAnimationEnd.invoke();
this->event2AnimationEnd.invoke();
} }
void clear() override { void clear() override {

View File

@ -13,7 +13,7 @@ TiledSpriteAnimation::TiledSpriteAnimation(TiledSprite *sprite) :
{ {
} }
void TiledSpriteAnimation::tick(float_t delta) { void TiledSpriteAnimation::tick(const float_t delta) {
SimpleAnimation::tick(delta); SimpleAnimation::tick(delta);
this->sprite->tile = frame; this->sprite->tile = frame;
} }

View File

@ -20,6 +20,6 @@ namespace Dawn {
*/ */
TiledSpriteAnimation(TiledSprite *sprite); TiledSpriteAnimation(TiledSprite *sprite);
void tick(float_t delta) override; void tick(const float_t delta) override;
}; };
} }

View File

@ -0,0 +1,66 @@
// Copyright (c) 2023 Dominic Masters
//
// This software is released under the MIT License.
// https://opensource.org/licenses/MIT
#include "easing.hpp"
float_t easeTimeToEase(
const float_t start,
const float_t current,
const float_t duration
) {
return (current - start) / duration;
}
float_t easeLinear(const float_t t) {
return t;
}
float_t easeInQuad(const float_t t) {
return t * t;
}
float_t easeOutQuad(const float_t t) {
return t * (2 - t);
}
float_t easeOutCubic(const float_t t) {
return 1 - powf(1 - t, 3);
}
float_t easeInOutQuad(const float_t t) {
return t < .5 ? 2 * t * t : -1 + (4 - 2 * t) * t;
}
float_t easeInCubic(const float_t t) {
return t * t * t;
}
float_t easeInOutCubic(const float_t t) {
return t < .5 ? 4 * t * t * t : (t - 1) * (2 * t - 2) * (2 * t - 2) + 1;
}
float_t easeInQuart(const float_t t) {
return t * t * t * t;
}
float_t easeOutQuart(const float_t t) {
return 1 - (t-1)*(t-1)*(t-1)*(t-1);
}
float_t easeInOutQuart(const float_t t) {
return t < .5 ? 8*t*t*t*t : 1-8*(t-1)*(t-1)*(t-1)*(t-1);
}
float_t easeInQuint(const float_t t) {
return t*t*t*t*t;
}
float_t easeOutQuint(const float_t t) {
return 1 + (t-1)*(t-1)*(t-1)*(t-1)*(t-1);
}
float_t easeInOutQuint(const float_t t) {
return t<.5 ? 16*t*t*t*t*t : 1+16*(t-1)*(t-1)*(t-1)*(t-1)*(t-1);
}

View File

@ -0,0 +1,37 @@
/**
* Copyright (c) 2021 Dominic Masters
*
* This software is released under the MIT License.
* https://opensource.org/licenses/MIT
*/
#pragma once
#include "dawnlibs.hpp"
typedef float_t easefunction_t(const float_t t);
/**
* Returns the ease time for a given real time duration span.
* @param start At what point in time the animation started
* @param current The current point in time the animation is at.
* @param duration The total duration on the animation.
* @returns The easing time (0-1 time) that the animation is at.
*/
float_t easeTimeToEase(
const float_t start,
const float_t current,
const float_t duration
);
float_t easeLinear(const float_t t);
float_t easeInQuad(const float_t t);
float_t easeOutQuad(const float_t t);
float_t easeOutCubic(const float_t t);
float_t easeInOutQuad(const float_t t);
float_t easeInCubic(const float_t t);
float_t easeInOutCubic(const float_t t);
float_t easeInQuart(const float_t t);
float_t easeOutQuart(const float_t t);
float_t easeInOutQuart(const float_t t);
float_t easeInQuint(const float_t t);
float_t easeOutQuint(const float_t t);
float_t easeInOutQuint(const float_t t);

View File

@ -1,129 +0,0 @@
// Copyright (c) 2022 Dominic Masters
//
// This software is released under the MIT License.
// https://opensource.org/licenses/MIT
#pragma once
#include "dawnlibs.hpp"
#include "assert/assert.hpp"
namespace Dawn {
template<typename... A>
struct IEventListener {
/**
* Abstracted method for C++ template reasons. Invokes the listener.
*
* @deprecated
* @param args Arguments to pass to the listener.
*/
virtual void invoke(A... args) = 0;
};
template <class T, typename... A>
struct EventListener : public IEventListener<A...> {
T *instance;
void (T::*callback)(A... args);
/**
* Construct a new event listener structure.
*
* @deprecated
* @param instance Instance that the callback belongs to.
* @param callback Callback method that invokes back.
*/
EventListener(T *instance, void (T::*callback)(A... args)) {
assertNotNull(instance, "EventListener::EventListener: Instance cannot be null");
this->instance = instance;
this->callback = callback;
}
void invoke(A... args) {
((*this->instance).*(this->callback))(args...);
}
};
/** @deprecated */
template<typename...A>
class Event {
private:
std::vector<IEventListener<A...>*> listeners;
public:
/**
* Add a listener to this event.
*
* @deprecated
* @tparam T The class that will receive the event.
* @param instance Instance of type T that will receive the callback.
* @param callback Callback method attached to T to receive the event.
* @return The initialized event listener. You don't really need this.
*/
template<class T>
EventListener<T, A...> * addListener(
T *instance,
void (T::*callback)(A... args)
) {
assertNotNull(instance, "Event::addListener: Instance cannot be null");
auto listener = new EventListener<T,A...>(instance, callback);
assertNotNull(listener, "Event::addListener: Listener could not be created (Memory filled?)");
this->listeners.push_back(listener);
return listener;
}
/**
* Removes an event listener from this event.
*
* @deprecated
* @tparam T The class that was once receiving the event.
* @param instance Instance of type T that did receive the callback.
* @param callback Callback method attached to T for the event.
*/
template<class T>
void removeListener(
T *instance,
void (T::*callback)(A... args)
) {
auto it = this->listeners.begin();
while(it != this->listeners.end()) {
auto listener = static_cast<EventListener<T,A...>*>(*it);
if(listener->instance != instance || listener->callback != callback) {
++it;
continue;
}
this->listeners.erase(it);
delete listener;
break;
}
}
/**
* Invokes the event and emits to all of the listeners.
*
* @deprecated
* @param args Arguments for this event to pass to the listeners.
*/
void invoke(A... args) {
auto it = this->listeners.begin();
while(it != this->listeners.end()) {
(*it)->invoke(args...);
++it;
}
}
/**
* Disposes the event instance. Will also destroy all of the event
* listeners.
*/
~Event() {
auto it = this->listeners.begin();
while(it != this->listeners.end()) {
delete *it;
++it;
}
}
};
}

View File

@ -21,7 +21,9 @@ void LocaleManager::init() {
if(this->loadingAsset->loaded) { if(this->loadingAsset->loaded) {
this->onLanguageLoaded(); this->onLanguageLoaded();
} else { } else {
this->loadingAsset->eventLoaded.addListener(this, &LocaleManager::onLanguageLoaded); eventTeardownLanguageLoaded = useEvent([&]() {
this->onLanguageLoaded();
}, this->loadingAsset->eventLoaded);
} }
} }
} }
@ -38,7 +40,7 @@ void LocaleManager::setLocale(struct Locale locale) {
// Are we already loading something? Stop it. // Are we already loading something? Stop it.
if(this->loadingAsset != nullptr) { if(this->loadingAsset != nullptr) {
this->loadingAsset->eventLoaded.removeListener(this, &LocaleManager::onLanguageLoaded); eventTeardownLanguageLoaded();
this->game->assetManager.queueUnload(this->loadingAsset); this->game->assetManager.queueUnload(this->loadingAsset);
this->loadingAsset = nullptr; this->loadingAsset = nullptr;
} }
@ -47,7 +49,9 @@ void LocaleManager::setLocale(struct Locale locale) {
if(this->loadingAsset->loaded) { if(this->loadingAsset->loaded) {
this->onLanguageLoaded(); this->onLanguageLoaded();
} else { } else {
this->loadingAsset->eventLoaded.addListener(this, &LocaleManager::onLanguageLoaded); eventTeardownLanguageLoaded = useEvent([&]() {
this->onLanguageLoaded();
}, this->loadingAsset->eventLoaded);
} }
} }
} }
@ -65,7 +69,7 @@ std::string LocaleManager::getString(std::string key) {
void LocaleManager::onLanguageLoaded() { void LocaleManager::onLanguageLoaded() {
// Unload the previously loaded language // Unload the previously loaded language
if(this->currentlyLoadedAsset != nullptr) { if(this->currentlyLoadedAsset != nullptr) {
this->currentlyLoadedAsset->eventLoaded.removeListener(this, &LocaleManager::onLanguageLoaded); eventTeardownLanguageLoaded();
this->game->assetManager.queueUnload(this->currentlyLoadedAsset); this->game->assetManager.queueUnload(this->currentlyLoadedAsset);
} }

View File

@ -6,6 +6,7 @@
#pragma once #pragma once
#include "state/StateEvent.hpp" #include "state/StateEvent.hpp"
#include "asset/assets/LanguageAsset.hpp" #include "asset/assets/LanguageAsset.hpp"
#include "state/StateOwner.hpp"
namespace Dawn { namespace Dawn {
class DawnGame; class DawnGame;
@ -14,13 +15,14 @@ namespace Dawn {
std::string language; std::string language;
}; };
class LocaleManager { class LocaleManager : public StateOwner {
private: private:
DawnGame *game; DawnGame *game;
LanguageAsset *asset; LanguageAsset *asset;
struct Locale locale; struct Locale locale;
LanguageAsset *currentlyLoadedAsset = nullptr; LanguageAsset *currentlyLoadedAsset = nullptr;
LanguageAsset *loadingAsset = nullptr; LanguageAsset *loadingAsset = nullptr;
std::function<void()> eventTeardownLanguageLoaded;
/** Listens for when the pending language loads. */ /** Listens for when the pending language loads. */
void onLanguageLoaded(); void onLanguageLoaded();

View File

@ -4,7 +4,6 @@
// https://opensource.org/licenses/MIT // https://opensource.org/licenses/MIT
#pragma once #pragma once
#include "event/Event.hpp"
#include "asset/Asset.hpp" #include "asset/Asset.hpp"
#include "display/shader/ShaderManager.hpp" #include "display/shader/ShaderManager.hpp"
#include "scene/debug/SceneDebugLine.hpp" #include "scene/debug/SceneDebugLine.hpp"

View File

@ -5,7 +5,6 @@
#pragma once #pragma once
#include "display/Transform.hpp" #include "display/Transform.hpp"
#include "event/Event.hpp"
#include "scene/Scene.hpp" #include "scene/Scene.hpp"
#include "util/array.hpp" #include "util/array.hpp"

View File

@ -84,7 +84,7 @@ void Camera::onStart() {
this->eventRenderTargetResized.invoke(rt->getWidth(), rt->getHeight()); this->eventRenderTargetResized.invoke(rt->getWidth(), rt->getHeight());
// Subscribe to new render target resized. // Subscribe to new render target resized.
return evtResized = useEventLegacy([&](RenderTarget *rt, float_t w, float_t h){ return evtResized = useEvent([&](RenderTarget *rt, float_t w, float_t h){
this->projectionNeedsUpdating = true; this->projectionNeedsUpdating = true;
this->eventRenderTargetResized.invoke(w, h); this->eventRenderTargetResized.invoke(w, h);
}, rt->eventRenderTargetResized); }, rt->eventRenderTargetResized);
@ -102,7 +102,7 @@ void Camera::onStart() {
// Sub to evt legacy, we don't invoke the useTeardown to avoid invoking // Sub to evt legacy, we don't invoke the useTeardown to avoid invoking
// the state event for this camera when we don't need to. // the state event for this camera when we don't need to.
if(!this->getRenderTarget()) return; if(!this->getRenderTarget()) return;
evtResized = useEventLegacy([&](RenderTarget *rt, float_t w, float_t h){ evtResized = useEvent([&](RenderTarget *rt, float_t w, float_t h){
this->projectionNeedsUpdating = true; this->projectionNeedsUpdating = true;
this->eventRenderTargetResized.invoke(w, h); this->eventRenderTargetResized.invoke(w, h);
}, getRenderTarget()->eventRenderTargetResized); }, getRenderTarget()->eventRenderTargetResized);

View File

@ -43,7 +43,7 @@ void SimpleRenderTargetQuad::onStart() {
); );
// Subscribe to resize event. // Subscribe to resize event.
evtResized = useEventLegacy([&](RenderTarget *target, float_t w, float_t h){ evtResized = useEvent([&](RenderTarget *target, float_t w, float_t h){
QuadMesh::bufferQuadMesh( QuadMesh::bufferQuadMesh(
&this->meshHost->mesh, &this->meshHost->mesh,
glm::vec2(0, 0), glm::vec2(0, 0), glm::vec2(0, 0), glm::vec2(0, 0),

View File

@ -58,7 +58,7 @@ void SubSceneCameraAlign::onStart() {
this->realign(); this->realign();
return evtRenderResized = useEventLegacy([&](RenderTarget *t, float_t w, float_t h) { return evtRenderResized = useEvent([&](RenderTarget *t, float_t w, float_t h) {
this->realign(); this->realign();
}, renderTarget->eventRenderTargetResized); }, renderTarget->eventRenderTargetResized);
}, this->renderTarget); }, this->renderTarget);

View File

@ -5,28 +5,15 @@
#pragma once #pragma once
#include "assert/assert.hpp" #include "assert/assert.hpp"
#include "event/Event.hpp"
namespace Dawn { namespace Dawn {
class IStateEvent; class IStateEvent;
template<typename...A> template<typename...A>
class StateEvent; class StateEvent;
template<typename ...A>
class StateOwnerEventLegacy;
class IStateOwnerEventLegacy {
public:
virtual void removeListener() = 0;
virtual void teardown() = 0;
virtual ~IStateOwnerEventLegacy() {}
};
class IStateOwner { class IStateOwner {
public: public:
virtual void _stateEventDisposed(IStateEvent *evt) = 0; virtual void _stateEventDisposed(IStateEvent *evt) = 0;
virtual void _stateLegacyEventDisposed(IStateOwnerEventLegacy *evt) = 0;
}; };
template<typename...A> template<typename...A>

View File

@ -8,42 +8,9 @@
#include "StateProperty.hpp" #include "StateProperty.hpp"
namespace Dawn { namespace Dawn {
template<typename ...A>
class StateOwnerEventLegacy : public IStateOwnerEventLegacy {
public:
IStateOwner *owner;
Event<A...> *event;
std::function<void(A...)> fn;
/**
* Function used to simply remove the event listener from the legacy
* event, does not deal with the state owner.
*/
void removeListener() override {
event->removeListener(this, &StateOwnerEventLegacy::callback);
}
/**
* Function that can be used to tear down this legacy event.
*/
void teardown() override {
this->removeListener();
owner->_stateLegacyEventDisposed(this);
}
/**
* Callbaack method that is invoked by the legacy event.
* @param args Arguments received by legacy event.
*/
void callback(A... args) {
this->fn(args...);
}
};
class StateOwner : public IStateOwner { class StateOwner : public IStateOwner {
private: private:
std::vector<IStateEvent*> eventsSubscribed; std::vector<IStateEvent*> eventsSubscribed;
std::vector<IStateOwnerEventLegacy*> eventLegacyBridge;
protected: protected:
/** /**
@ -62,17 +29,9 @@ namespace Dawn {
(*it)->_stateOwnerDestroyed(this); (*it)->_stateOwnerDestroyed(this);
++it; ++it;
} }
auto itBridge = this->eventLegacyBridge.begin();
while(itBridge != this->eventLegacyBridge.end()) {
(*itBridge)->removeListener();
delete *itBridge;
++itBridge;
}
this->_stateProviderListeners.clear(); this->_stateProviderListeners.clear();
this->eventsSubscribed.clear(); this->eventsSubscribed.clear();
this->eventLegacyBridge.clear();
} }
public: public:
@ -95,24 +54,6 @@ namespace Dawn {
} }
} }
/**
* Called by legacy events when they are being disposed in a way that was
* not called by this state owner disposing.
*
* @param evt Event that is being disposed.
*/
void _stateLegacyEventDisposed(IStateOwnerEventLegacy *evt) override {
auto it = this->eventLegacyBridge.begin();
while(it != this->eventLegacyBridge.end()) {
if(*it == evt) {
this->eventLegacyBridge.erase(it);
break;
} else {
++it;
}
}
}
/** /**
* Listen for changes to a state property and invoke the provided func * Listen for changes to a state property and invoke the provided func
* when the value is changed. * when the value is changed.
@ -230,38 +171,6 @@ namespace Dawn {
return listener.unsub; return listener.unsub;
} }
/**
* Listen for callback of a legacy styled event. This will be removed in
* the future in favour of everything using State Events. This uses a lot
* more memory than the new state event listener.
*
* @deprecated In favour of StateEvent<>
* @tparam F The type of the callback function.
* @tparam A Argument types for the event.
* @param fn Callback function to be invoked when the event is triggered.
* @param event Event that will be listened to.
* @return A method that, when invoked, will unsubscribe from the event.
*/
template<typename F, typename... A>
std::function<void()> useEventLegacy(
F fn,
Event<A...> &event
) {
// This is a legacy feature to make upgrading to the new useEffect a bit
// easier for me. For the time being I am just bodging this together to
// do what I need here.
auto bridge = new StateOwnerEventLegacy<A...>();
bridge->owner = this;
bridge->event = &event;
bridge->fn = fn;
event.addListener(bridge, &StateOwnerEventLegacy<A...>::callback);
eventLegacyBridge.push_back(bridge);
return std::bind([&](IStateOwnerEventLegacy *evt){
evt->teardown();
}, bridge);
}
/** /**
* State Owner teardown function. Mostly just used to remove any lingering * State Owner teardown function. Mostly just used to remove any lingering

View File

@ -5,8 +5,8 @@
#pragma once #pragma once
#include "dawnlibs.hpp" #include "dawnlibs.hpp"
#include "event/Event.hpp"
#include "state/StateProvider.hpp" #include "state/StateProvider.hpp"
#include "state/StateEvent.hpp"
namespace Dawn { namespace Dawn {
struct IntervalProviderData { struct IntervalProviderData {
@ -23,9 +23,8 @@ namespace Dawn {
StateProviderSet<float_t> timeoutProvider; StateProviderSet<float_t> timeoutProvider;
StateProviderSet<struct IntervalProviderData> intervalProvider; StateProviderSet<struct IntervalProviderData> intervalProvider;
StateEvent<> eventTimePaused;
Event<> eventTimePaused; StateEvent<> eventTimeResumed;
Event<> eventTimeResumed;
/** /**
* Constructor for the Time Manager. * Constructor for the Time Manager.