summaryrefslogtreecommitdiffstats
path: root/yql/essentials/public/fastcheck/linter.cpp
diff options
context:
space:
mode:
authorvvvv <[email protected]>2025-02-10 14:34:20 +0300
committervvvv <[email protected]>2025-02-10 15:36:34 +0300
commit5079f75b9e1bdf35a019a79274547b338254846f (patch)
tree34f119737745c70ee33650178a918a0c78f343be /yql/essentials/public/fastcheck/linter.cpp
parent117df4d33f3cf98f8452c32e1099dde7fb91c3e3 (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.cpp54
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);