Skip to content

Commit

Permalink
linter: configuration: Ignore incorrect rules
Browse files Browse the repository at this point in the history
Change the behaviour after observing an incorrect rule in a
configuration file.

  Previously: error out and go back to the default configuration
  Now: ignore the incorrect rule and parse the rest of the file
  • Loading branch information
IEncinas10 committed Dec 21, 2023
1 parent 4e8133d commit 33b246f
Show file tree
Hide file tree
Showing 3 changed files with 27 additions and 17 deletions.
31 changes: 16 additions & 15 deletions verilog/analysis/verilog_linter_configuration.cc
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,7 @@ bool RuleBundle::ParseConfiguration(absl::string_view text, char separator,
// Clear the vector to overwrite any existing value.
rules.clear();

bool parsed_correctly = true;
for (absl::string_view part :
absl::StrSplit(text, separator, absl::SkipEmpty())) {
if (separator == '\n') {
Expand All @@ -108,9 +109,8 @@ bool RuleBundle::ParseConfiguration(absl::string_view text, char separator,
part = absl::StripAsciiWhitespace(part);
while (!part.empty() && part[part.size() - 1] == ',') {
// Not fatal, just report
if (!error->empty()) error->append("\n");
error->append(absl::StrCat(
"Ignoring stray comma at end of configuration `", part, "`"));
absl::StrAppend(error, error->empty() ? "" : "\n", kStrayCommaWarning,
" `", part, "`");
part = part.substr(0, part.size() - 1);
}

Expand All @@ -119,8 +119,8 @@ bool RuleBundle::ParseConfiguration(absl::string_view text, char separator,
// '+' to enable rule.
// Note that part is guaranteed to be at least one character because
// of absl::SkipEmpty()
const bool has_prefix = (part[0] == '+' || part[0] == '-');
const bool prefix_minus = (part[0] == '-');
const bool has_prefix = (part[0] == '+' || prefix_minus);

RuleSetting setting = {!prefix_minus, ""};

Expand Down Expand Up @@ -148,15 +148,19 @@ bool RuleBundle::ParseConfiguration(absl::string_view text, char separator,

// Check if text is a valid lint rule.
if (rule_iter == rule_name_set.end()) {
*error = absl::StrCat("invalid flag \"", rule_name, "\"");
return false;
absl::StrAppend(error, error->empty() ? "" : "\n", kInvalidFlagMessage,
" \"", rule_name, "\"");
// If the rule doesn't exist just ignore it. Take note of this information
// so it can be reported but keep parsing configuration.
parsed_correctly = false;
continue;
}
// Map keys must use canonical registered string_views for guaranteed
// lifetime, not just any string-equivalent copy.
rules[*rule_iter] = setting;
}

return true;
return parsed_correctly;
}

// Parse and unparse for RuleBundle (for commandlineflags)
Expand Down Expand Up @@ -312,15 +316,12 @@ absl::Status LinterConfiguration::AppendFromFile(
if (config_or.ok()) {
RuleBundle local_rules_bundle;
std::string error;
if (local_rules_bundle.ParseConfiguration(*config_or, '\n', &error)) {
if (!error.empty()) {
std::cerr << "Warnings in parse configuration: " << error << std::endl;
}
UseRuleBundle(local_rules_bundle);
} else {
std::cerr << "Unable to fully parse configuration: " << error
<< std::endl;
local_rules_bundle.ParseConfiguration(*config_or, '\n', &error);
// Log warnings and errors
if (!error.empty()) {
std::cerr << error;
}
UseRuleBundle(local_rules_bundle);
return absl::OkStatus();
}

Expand Down
9 changes: 9 additions & 0 deletions verilog/analysis/verilog_linter_configuration.h
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,15 @@ struct RuleSetting {
std::string configuration;
};

// Error to be shown when an invalid flag is
// encountered while parsing a configuration
inline constexpr absl::string_view kInvalidFlagMessage = "[ERR] Invalid flag";

// Warning to be shown when an stray comma is
// encountered while parsing a configuration
inline constexpr absl::string_view kStrayCommaWarning =
"[WARN] Ignoring stray comma at the end of configuration";

// Enum denoting a ruleset
// kNone no rules are enabled
// kDefault default ruleset is enabled
Expand Down
4 changes: 2 additions & 2 deletions verilog/analysis/verilog_linter_configuration_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -768,7 +768,7 @@ TEST(RuleBundleTest, ParseRuleBundleReject) {
std::string error;
bool success = bundle.ParseConfiguration(text, ',', &error);
EXPECT_FALSE(success);
EXPECT_EQ(error, "invalid flag \"bad-flag\"");
EXPECT_EQ(error, absl::StrCat(kInvalidFlagMessage, " \"bad-flag\""));
}

TEST(RuleBundleTest, ParseRuleBundleAcceptMultiline) {
Expand All @@ -789,7 +789,7 @@ TEST(RuleBundleTest, ParseRuleBundleRejectMultiline) {
std::string error;
bool success = bundle.ParseConfiguration(text, '\n', &error);
EXPECT_FALSE(success);
EXPECT_EQ(error, "invalid flag \"bad-flag\"");
EXPECT_EQ(error, absl::StrCat(kInvalidFlagMessage, " \"bad-flag\""));
}

TEST(RuleBundleTest, ParseRuleBundleSkipComments) {
Expand Down

0 comments on commit 33b246f

Please sign in to comment.