Make RuleConfig#properties accept only Call nodes

Add optional named argument `as`, in order to specify the property type
This commit is contained in:
Sijawusz Pur Rahnama 2023-12-28 04:45:46 +01:00
parent 47088b10ca
commit 55f3ec53b7
4 changed files with 18 additions and 17 deletions

View file

@ -6,7 +6,7 @@ module Ameba
# Dummy Rule which does nothing. # Dummy Rule which does nothing.
class DummyRule < Rule::Base class DummyRule < Rule::Base
properties do properties do
description : String = "Dummy rule that does nothing." description "Dummy rule that does nothing."
dummy true dummy true
end end
@ -92,7 +92,7 @@ module Ameba
class PerfRule < Rule::Performance::Base class PerfRule < Rule::Performance::Base
properties do properties do
description : String = "Sample performance rule" description "Sample performance rule"
end end
def test(source) def test(source)

View file

@ -247,20 +247,20 @@ class Ameba::Config
# Define rule properties # Define rule properties
macro properties(&block) macro properties(&block)
{% definitions = [] of NamedTuple %} {% definitions = [] of NamedTuple %}
{% if block.body.is_a? Assign %} {% if (prop = block.body).is_a? Call %}
{% definitions << {var: block.body.target, value: block.body.value} %} {% if (named_args = prop.named_args) && (type = named_args.select(&.name.== "as".id).first) %}
{% elsif block.body.is_a? Call %} {% definitions << {var: prop.name, value: prop.args.first, type: type.value} %}
{% definitions << {var: block.body.name, value: block.body.args.first} %} {% else %}
{% elsif block.body.is_a? TypeDeclaration %} {% definitions << {var: prop.name, value: prop.args.first} %}
{% definitions << {var: block.body.var, value: block.body.value, type: block.body.type} %} {% end %}
{% elsif block.body.is_a? Expressions %} {% elsif block.body.is_a? Expressions %}
{% for prop in block.body.expressions %} {% for prop in block.body.expressions %}
{% if prop.is_a? Assign %} {% if prop.is_a? Call %}
{% definitions << {var: prop.target, value: prop.value} %} {% if (named_args = prop.named_args) && (type = named_args.select(&.name.== "as".id).first) %}
{% elsif prop.is_a? Call %} {% definitions << {var: prop.name, value: prop.args.first, type: type.value} %}
{% definitions << {var: prop.name, value: prop.args.first} %} {% else %}
{% elsif prop.is_a? TypeDeclaration %} {% definitions << {var: prop.name, value: prop.args.first} %}
{% definitions << {var: prop.var, value: prop.value, type: prop.type} %} {% end %}
{% end %} {% end %}
{% end %} {% end %}
{% end %} {% end %}

View file

@ -15,7 +15,8 @@ module Ameba::Rule::Lint
class Typos < Base class Typos < Base
properties do properties do
description "Reports typos found in source files" description "Reports typos found in source files"
bin_path : String? = nil
bin_path nil, as: String?
fail_on_error false fail_on_error false
end end

View file

@ -39,8 +39,8 @@ module Ameba::Rule::Style
exclude_operators true exclude_operators true
exclude_setters false exclude_setters false
max_line_length : Int32? = nil # 100 max_line_length nil, as: Int32?
max_length : Int32? = 50 max_length 50, as: Int32?
end end
MSG = "Use short block notation instead: `%s`" MSG = "Use short block notation instead: `%s`"