Trivial: speedup npc::get_monster_faction #45423
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Summary
SUMMARY: Performance "speedup npc::get_monster_faction"
Purpose of change
Currently
npc::get_monster_faction
constructsstring_id
from raw string each time it's called.This is an unnecessary waste of CPU time.
Describe the solution
Change
faction_template::mon_faction
type fromstd::string
tomfaction_str_id
. This avoids on-demandstring_id
creation and saves some memory.Describe alternatives you've considered
None.
Testing
Checked that game compiles and loads.
Additional context
Note: profiled on top of #45376 for full effect (generic factory caches
is_valid
lookups).Before:
data:image/s3,"s3://crabby-images/3604c/3604cd52abcfcbbb3af24e4976c2fff48b81ea40" alt="image"
After:
data:image/s3,"s3://crabby-images/05b3e/05b3e1d6877f5bae0f121af164b5859e48543862" alt="image"