diff options
| author | Loek Le Blansch <loek@pipeframe.xyz> | 2024-10-31 18:41:30 +0100 | 
|---|---|---|
| committer | Loek Le Blansch <loek@pipeframe.xyz> | 2024-10-31 18:41:30 +0100 | 
| commit | 8e3367b186e60eb1e33bf58a066823cb00a7566e (patch) | |
| tree | c4038a31993767276efec5fa1b1a37dff3b79465 /src/example/components_internal.cpp | |
| parent | b7df77d6cc26cb9ee46891d7108f01734b3104dd (diff) | |
| parent | 35ef3ba91ce9e00466508f2388f4c1dd2321b505 (diff) | |
Merge branch 'master' into poc/audio-miniaudio
Diffstat (limited to 'src/example/components_internal.cpp')
| -rw-r--r-- | src/example/components_internal.cpp | 61 | 
1 files changed, 61 insertions, 0 deletions
| diff --git a/src/example/components_internal.cpp b/src/example/components_internal.cpp new file mode 100644 index 0000000..3c68974 --- /dev/null +++ b/src/example/components_internal.cpp @@ -0,0 +1,61 @@ +/** \file + *  + * Standalone example for usage of the internal ECS + */ + +#include <cassert> +#include <chrono> + +#include <crepe/Component.h> +#include <crepe/ComponentManager.h> + +#include <crepe/api/GameObject.h> +#include <crepe/api/Rigidbody.h> +#include <crepe/api/Sprite.h> + +#include <crepe/util/log.h> + +using namespace crepe::api; +using namespace crepe; +using namespace std; + +#define OBJ_COUNT 100000 + +int main() { +	dbg_trace(); + +	auto & mgr = ComponentManager::get_instance(); + +	auto start_adding = chrono::high_resolution_clock::now(); + +	GameObject * game_object[OBJ_COUNT]; + +	for (int i = 0; i < OBJ_COUNT; ++i) { +		game_object[i] = new GameObject(i, "Name", "Tag", 0); + +		game_object[i]->add_component<Sprite>("test"); +		game_object[i]->add_component<Rigidbody>(0, 0, i); +	} + +	auto stop_adding = chrono::high_resolution_clock::now(); + +	auto sprites = mgr.get_components_by_type<Sprite>(); +	for (auto sprite : sprites) { +		assert(true); +	} + +	auto stop_looping = chrono::high_resolution_clock::now(); + +	for (int i = 0; i < OBJ_COUNT; ++i) { +		delete game_object[i]; +	} + +	auto add_time = chrono::duration_cast<chrono::microseconds>(stop_adding +																- start_adding); +	auto loop_time = chrono::duration_cast<chrono::microseconds>(stop_looping +																 - stop_adding); +	printf("add time:  %ldus\n", add_time.count()); +	printf("loop time: %ldus\n", loop_time.count()); + +	return 0; +} |