mirror of
https://github.com/owasp-modsecurity/ModSecurity.git
synced 2025-08-13 21:36:00 +03:00
Instantiates the Class variable earlier
Avoid the instantiation for every call
This commit is contained in:
parent
ba6b972ca8
commit
9a8fc3116a
@ -33,10 +33,16 @@ namespace collection {
|
||||
|
||||
class Variable {
|
||||
public:
|
||||
Variable(const std::string *key) :
|
||||
m_key(key),
|
||||
m_value(),
|
||||
m_dynamic_value(false),
|
||||
m_dynamic(false) { }
|
||||
Variable(const std::string *key, const std::string *value) :
|
||||
m_key(key),
|
||||
m_value(value),
|
||||
m_dynamic_value(false) { }
|
||||
m_dynamic_value(false),
|
||||
m_dynamic(false) { }
|
||||
|
||||
~Variable() {
|
||||
if (m_dynamic_value) {
|
||||
@ -47,6 +53,7 @@ class Variable {
|
||||
const std::string *m_key;
|
||||
const std::string *m_value;
|
||||
bool m_dynamic_value;
|
||||
bool m_dynamic;
|
||||
};
|
||||
|
||||
} // namespace collection
|
||||
|
10
src/rule.cc
10
src/rule.cc
@ -420,8 +420,10 @@ std::vector<const collection::Variable *> Rule::getFinalVars(
|
||||
trasn->debug(9, "Variable: " + *key +
|
||||
" is part of the exclusion list, skipping...");
|
||||
#endif
|
||||
if (v->m_dynamic) {
|
||||
delete v;
|
||||
v = NULL;
|
||||
}
|
||||
continue;
|
||||
}
|
||||
|
||||
@ -439,8 +441,10 @@ std::vector<const collection::Variable *> Rule::getFinalVars(
|
||||
}
|
||||
}
|
||||
if (ignoreVariable) {
|
||||
if (v->m_dynamic) {
|
||||
delete v;
|
||||
v = NULL;
|
||||
}
|
||||
continue;
|
||||
}
|
||||
|
||||
@ -458,8 +462,10 @@ std::vector<const collection::Variable *> Rule::getFinalVars(
|
||||
}
|
||||
}
|
||||
if (ignoreVariable) {
|
||||
if (v->m_dynamic) {
|
||||
delete v;
|
||||
v = NULL;
|
||||
}
|
||||
continue;
|
||||
}
|
||||
|
||||
@ -636,8 +642,10 @@ end_clean:
|
||||
while (finalVars.empty() == false) {
|
||||
auto *a = finalVars.back();
|
||||
finalVars.pop_back();
|
||||
if (a->m_dynamic) {
|
||||
delete a;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
|
||||
@ -654,8 +662,10 @@ end_exec:
|
||||
while (finalVars.empty() == false) {
|
||||
auto *a = finalVars.back();
|
||||
finalVars.pop_back();
|
||||
if (a->m_dynamic) {
|
||||
delete a;
|
||||
}
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user