diff options
author | vvvv <[email protected]> | 2025-02-10 14:34:20 +0300 |
---|---|---|
committer | vvvv <[email protected]> | 2025-02-10 15:36:34 +0300 |
commit | 5079f75b9e1bdf35a019a79274547b338254846f (patch) | |
tree | 34f119737745c70ee33650178a918a0c78f343be /yql/essentials/public/fastcheck/linter.cpp | |
parent | 117df4d33f3cf98f8452c32e1099dde7fb91c3e3 (diff) |
YQL-19553 CLI for yql linter
init
commit_hash:a21a71769ad2095e40909c69255a3cf38eabc179
Diffstat (limited to 'yql/essentials/public/fastcheck/linter.cpp')
-rw-r--r-- | yql/essentials/public/fastcheck/linter.cpp | 54 |
1 files changed, 40 insertions, 14 deletions
diff --git a/yql/essentials/public/fastcheck/linter.cpp b/yql/essentials/public/fastcheck/linter.cpp index 971e6fd9777..a32814e3ec3 100644 --- a/yql/essentials/public/fastcheck/linter.cpp +++ b/yql/essentials/public/fastcheck/linter.cpp @@ -4,11 +4,15 @@ #include <yql/essentials/ast/yql_ast.h> #include <yql/essentials/ast/yql_expr.h> +#include <util/string/split.h> + #include <functional> namespace NYql { namespace NFastCheck { +namespace { + class TCheckRunnerFactory : public ICheckRunnerFactory { public: using TRunnerFactoryFunction = std::function<std::unique_ptr<ICheckRunner>()>; @@ -41,22 +45,13 @@ private: TSet<TString> CheckNames_; }; -TCheckRunnerFactory& GetCheckRunnerFactory() { - return *Singleton<TCheckRunnerFactory>(); -}; - -const TSet<TString>& ListChecks() { - return GetCheckRunnerFactory().ListChecks(); -} - -TChecksResponse RunChecks(const TChecksRequest& request) { - auto filters = request.Filters.GetOrElse(TVector<TCheckFilter>(1, TCheckFilter{.Include = true, .CheckNameGlob = "*"})); - const auto& fullChecks = ListChecks(); +TSet<TString> GetEnabledChecks(const TSet<TString>& allChecks, const TMaybe<TVector<TCheckFilter>>& filters) { + auto usedFilters = filters.GetOrElse(TVector<TCheckFilter>(1, TCheckFilter{.Include = true, .CheckNameGlob = "*"})); TSet<TString> enabledChecks; - for (const auto& f : filters) { + for (const auto& f : usedFilters) { if (f.CheckNameGlob == "*") { if (f.Include) { - enabledChecks = fullChecks; + enabledChecks = allChecks; } else { enabledChecks.clear(); } @@ -65,7 +60,7 @@ TChecksResponse RunChecks(const TChecksRequest& request) { Y_ENSURE(f.CheckNameGlob.find('*') == TString::npos); Y_ENSURE(f.CheckNameGlob.find('?') == TString::npos); if (f.Include) { - if (fullChecks.contains(f.CheckNameGlob)) { + if (allChecks.contains(f.CheckNameGlob)) { enabledChecks.insert(f.CheckNameGlob); } } else { @@ -74,6 +69,37 @@ TChecksResponse RunChecks(const TChecksRequest& request) { } } + return enabledChecks; +} + +TCheckRunnerFactory& GetCheckRunnerFactory() { + return *Singleton<TCheckRunnerFactory>(); +}; + +} + +TVector<TCheckFilter> ParseChecks(const TString& checks) { + TVector<TCheckFilter> res; + for (TStringBuf one: StringSplitter(checks).SplitByString(",")) { + TCheckFilter f; + TStringBuf afterPrefix = one; + if (one.AfterPrefix("-", afterPrefix)) { + f.Include = false; + } + + f.CheckNameGlob = afterPrefix; + res.push_back(f); + } + + return res; +} + +TSet<TString> ListChecks(const TMaybe<TVector<TCheckFilter>>& filters) { + return GetEnabledChecks(GetCheckRunnerFactory().ListChecks(), filters); +} + +TChecksResponse RunChecks(const TChecksRequest& request) { + auto enabledChecks = GetEnabledChecks(GetCheckRunnerFactory().ListChecks(), request.Filters); TChecksResponse res; for (const auto& c : enabledChecks) { auto checkRunner = GetCheckRunnerFactory().MakeRunner(c); |