Codechange: Use std::string in console commands/aliases registration, and std::map instead our sorted linked list #9057
+191
−237
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.
Multiple commits to ease reviewing, but should be squashed I think.
Motivation / Problem
When registering a command or alias in console, memory is manually allocated to store the data in global custom sorted linked lists. And we rely on OS to free this memory at exit.
Also, underscores are removed from commands/aliases names on registration, but each access needs to remove underscores to find them (and some were forgetting the removal, at least
info_cmd
). And names inlist_cmds
output didn't match names shown inhelp
.Description
std::string
is used to store names, and alias command.Custom sorted linked list is replaced with
std::map
enclosed inside a static struct.Map key uses names without underscores, but commands/aliases themselves store the name with underscores for display.
Underscore removal is handled inside the accessors, so the caller doesn't have to care about it.
Limitations
Checklist for review
Some things are not automated, and forgotten often. This list is a reminder for the reviewers.