Skip to content

Commit

Permalink
Replace fixed-size console paramsArray with vector
Browse files Browse the repository at this point in the history
  • Loading branch information
dgelessus committed Aug 10, 2023
1 parent 42fd1e0 commit 09b2b68
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 39 deletions.
61 changes: 27 additions & 34 deletions Sources/Plasma/FeatureLib/pfConsoleCore/pfConsoleEngine.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -57,9 +57,6 @@ You can contact Cyan Worlds, Inc. by email [email protected]
#include "plFile/plEncryptedStream.h"


const int32_t pfConsoleEngine::fMaxNumParams = 16;


//// Constructor & Destructor ////////////////////////////////////////////////

pfConsoleEngine::pfConsoleEngine()
Expand Down Expand Up @@ -187,7 +184,6 @@ bool pfConsoleEngine::ExecuteFile(const plFileName &fileName)
bool pfConsoleEngine::RunCommand(const ST::string& line, void (*PrintFn)(const ST::string&))
{
pfConsoleCmd *cmd;
pfConsoleCmdParam paramArray[ fMaxNumParams + 1 ];

pfConsoleParser parser(line);
cmd = parser.ParseCommand();
Expand All @@ -207,11 +203,11 @@ bool pfConsoleEngine::RunCommand(const ST::string& line, void (*PrintFn)(const S
return false;
}

hsSsize_t numParams = IResolveParams(cmd, std::move(*argTokens), paramArray);
auto params = IResolveParams(cmd, std::move(*argTokens));

if (numParams == -1 || (
cmd->GetSigEntry(numParams) != pfConsoleCmd::kAny
&& cmd->GetSigEntry(numParams) != pfConsoleCmd::kNone
if (!params || (
cmd->GetSigEntry(params->size()) != pfConsoleCmd::kAny
&& cmd->GetSigEntry(params->size()) != pfConsoleCmd::kNone
)) {
// Print help string and return
fErrorMsg.clear(); // Printed on next line
Expand All @@ -221,70 +217,70 @@ bool pfConsoleEngine::RunCommand(const ST::string& line, void (*PrintFn)(const S
}

/// Execute it and return
cmd->Execute( numParams, paramArray, PrintFn );
cmd->Execute(params->size(), params->data(), PrintFn);
return true;
}

//// IConvertToParam /////////////////////////////////////////////////////////
// Converts a null-terminated string representing a parameter to a
// pfConsoleCmdParam argument.

bool pfConsoleEngine::IConvertToParam(uint8_t type, ST::string string, pfConsoleCmdParam *param)
std::optional<pfConsoleCmdParam> pfConsoleEngine::IConvertToParam(uint8_t type, ST::string string)
{
if( type == pfConsoleCmd::kNone )
return false;
return {};

pfConsoleCmdParam param;
if( type == pfConsoleCmd::kAny )
{
/// Want "any"
param->SetAny(std::move(string));
param.SetAny(std::move(string));
}
else if( type == pfConsoleCmd::kString )
{
/// Want just a string
param->SetString(std::move(string));
param.SetString(std::move(string));
}
else if( type == pfConsoleCmd::kFloat )
{
ST::conversion_result res;
float value = string.to_float(res);
if (!res.ok() || !res.full_match()) {
return false;
return {};
}

param->SetFloat(value);
param.SetFloat(value);
}
else if( type == pfConsoleCmd::kInt )
{
ST::conversion_result res;
int value = string.to_int(res, 10);
if (!res.ok() || !res.full_match()) {
return false;
return {};
}

param->SetInt(value);
param.SetInt(value);
}
else if( type == pfConsoleCmd::kBool )
{
if (string.compare_i("t") == 0) {
param->SetBool(true);
param.SetBool(true);
} else if (string.compare_i("f") == 0) {
param->SetBool(false);
param.SetBool(false);
} else {
param->SetBool(string.to_bool());
param.SetBool(string.to_bool());
}
}

return true;
return param;
}

hsSsize_t pfConsoleEngine::IResolveParams(pfConsoleCmd* cmd, std::vector<ST::string> argTokens, pfConsoleCmdParam* paramArray)
std::optional<std::vector<pfConsoleCmdParam>> pfConsoleEngine::IResolveParams(pfConsoleCmd* cmd, std::vector<ST::string> argTokens)
{
size_t numParams;
for (numParams = 0; numParams < fMaxNumParams && numParams < argTokens.size(); numParams++) {
std::vector<pfConsoleCmdParam> params;
for (ST::string& argString : argTokens) {
// Special case for context variables--if we're specifying one,
// we want to just grab the value of it and return that instead
ST::string& argString = argTokens[numParams];
if (argString.starts_with("$")) {
pfConsoleContext& context = pfConsoleContext::GetRootContext();

Expand All @@ -293,22 +289,19 @@ hsSsize_t pfConsoleEngine::IResolveParams(pfConsoleCmd* cmd, std::vector<ST::str
if (idx == -1) {
fErrorMsg = ST_LITERAL("Invalid console variable name");
} else {
paramArray[numParams] = context.GetVarValue(idx);
params.push_back(context.GetVarValue(idx));
continue;
}
}

bool valid = IConvertToParam(cmd->GetSigEntry(numParams), std::move(argString), &paramArray[numParams]);
if (!valid) {
return -1;
auto param = IConvertToParam(cmd->GetSigEntry(params.size()), std::move(argString));
if (!param) {
return {};
}
params.emplace_back(std::move(*param));
}

for (size_t i = numParams; i < fMaxNumParams + 1; i++) {
paramArray[i].SetNone();
}

return numParams;
return params;
}

//// FindPartialCmd //////////////////////////////////////////////////////////
Expand Down
8 changes: 3 additions & 5 deletions Sources/Plasma/FeatureLib/pfConsoleCore/pfConsoleEngine.h
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ You can contact Cyan Worlds, Inc. by email [email protected]

#include "HeadSpin.h"

#include <optional>
#include <string_theory/string>
#include <vector>

Expand All @@ -70,11 +71,8 @@ class pfConsoleCmdGroup;
class pfConsoleEngine
{
private:

static const int32_t fMaxNumParams;

bool IConvertToParam(uint8_t type, ST::string string, pfConsoleCmdParam *param);
hsSsize_t IResolveParams(pfConsoleCmd* cmd, std::vector<ST::string> argTokens, pfConsoleCmdParam* paramArray);
std::optional<pfConsoleCmdParam> IConvertToParam(uint8_t type, ST::string string);
std::optional<std::vector<pfConsoleCmdParam>> IResolveParams(pfConsoleCmd* cmd, std::vector<ST::string> argTokens);

ST::string fErrorMsg;
ST::string fLastErrorLine;
Expand Down

0 comments on commit 09b2b68

Please sign in to comment.