diff options
| author | JAROWMR <jarorutjes07@gmail.com> | 2024-12-01 23:05:27 +0100 | 
|---|---|---|
| committer | JAROWMR <jarorutjes07@gmail.com> | 2024-12-01 23:05:27 +0100 | 
| commit | b6fdd1d644368226054094a282f5db24b31b5ba2 (patch) | |
| tree | f995c792d6b8330a7880dada88d470bd357279e7 /src/crepe/ComponentManager.cpp | |
| parent | cbd4b97d348c46f4f43fe59683a5e3d1bdbc500f (diff) | |
| parent | 647eb8e318f1ed1e3ec18505ea4df57025e6ffd5 (diff) | |
merge with master
Diffstat (limited to 'src/crepe/ComponentManager.cpp')
| -rw-r--r-- | src/crepe/ComponentManager.cpp | 35 | 
1 files changed, 31 insertions, 4 deletions
| diff --git a/src/crepe/ComponentManager.cpp b/src/crepe/ComponentManager.cpp index e4de027..5b73009 100644 --- a/src/crepe/ComponentManager.cpp +++ b/src/crepe/ComponentManager.cpp @@ -2,6 +2,7 @@  #include "util/Log.h"  #include "ComponentManager.h" +#include "types.h"  using namespace crepe;  using namespace std; @@ -10,24 +11,50 @@ ComponentManager::ComponentManager() { dbg_trace(); }  ComponentManager::~ComponentManager() { dbg_trace(); }  void ComponentManager::delete_all_components_of_id(game_object_id_t id) { +	// Do not delete persistent objects +	if (this->persistent[id]) { +		return; +	} +  	// Loop through all the types (in the unordered_map<>) -	for (auto & [type, componentArray] : this->components) { +	for (auto & [type, component_array] : this->components) {  		// Make sure that the id (that we are looking for) is within the boundaries of the vector<> -		if (id < componentArray.size()) { +		if (id < component_array.size()) {  			// Clear the components at this specific id -			componentArray[id].clear(); +			component_array[id].clear();  		}  	}  }  void ComponentManager::delete_all_components() { -	this->components.clear(); +	// Loop through all the types (in the unordered_map<>) +	for (auto & [type, component_array] : this->components) { +		// Loop through all the ids (in the vector<>) +		for (game_object_id_t id = 0; id < component_array.size(); id++) { +			// Do not delete persistent objects +			if (!this->persistent[id]) { +				// Clear the components at this specific id +				component_array[id].clear(); +			} +		} +	} +  	this->next_id = 0;  }  GameObject ComponentManager::new_object(const string & name, const string & tag,  										const vec2 & position, double rotation, double scale) { +	// Find the first available id (taking persistent objects into account) +	while (this->persistent[this->next_id]) { +		this->next_id++; +	} +  	GameObject object{*this, this->next_id, name, tag, position, rotation, scale};  	this->next_id++; +  	return object;  } + +void ComponentManager::set_persistent(game_object_id_t id, bool persistent) { +	this->persistent[id] = persistent; +} |