From 8448c3367b4de278f2dff5dcbfc1d83d1eccfc06 Mon Sep 17 00:00:00 2001 From: WerWolv Date: Sun, 14 Aug 2022 19:12:46 +0200 Subject: [PATCH] fix: In variables resetting on evaluation --- .../source/content/views/view_pattern_editor.cpp | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/plugins/builtin/source/content/views/view_pattern_editor.cpp b/plugins/builtin/source/content/views/view_pattern_editor.cpp index ea90507cc..07e090593 100644 --- a/plugins/builtin/source/content/views/view_pattern_editor.cpp +++ b/plugins/builtin/source/content/views/view_pattern_editor.cpp @@ -403,10 +403,14 @@ namespace hex::plugin::builtin { if (this->m_hasUnevaluatedChanges && this->m_runningEvaluators == 0 && this->m_runningParsers == 0) { this->m_hasUnevaluatedChanges = false; - if (this->m_runAutomatically) - this->evaluatePattern(this->m_textEditor.GetText()); - else - std::thread([this, code = this->m_textEditor.GetText()] { this->parsePattern(code); }).detach(); + + std::thread([this, code = this->m_textEditor.GetText()]{ + this->parsePattern(code); + + if (this->m_runAutomatically) + this->evaluatePattern(code); + }).detach(); + } } @@ -767,8 +771,6 @@ namespace hex::plugin::builtin { } void ViewPatternEditor::parsePattern(const std::string &code) { - auto task = ImHexApi::Tasks::createTask("hex.builtin.view.pattern_editor.evaluating", 1); - this->m_runningParsers++; auto ast = this->m_parserRuntime->parseString(code); @@ -821,8 +823,6 @@ namespace hex::plugin::builtin { for (const auto &[id, name, value, type] : this->m_envVarEntries) envVars.insert({ name, value }); - this->parsePattern(code); - std::map inVariables; for (auto &[name, variable] : this->m_patternVariables) { if (variable.inVariable)