class Ameba::Rule::Typing::MethodParameterTypeRestriction
Overview
A rule that enforces method parameters have type restrictions, with optional enforcement of block parameters.
For example, this is considered invalid:
def add(a, b)
a + b
end
And this is considered valid:
def add(a : String, b : String)
a + b
end
When the config options PrivateMethods
and ProtectedMethods
are true, this rule is also applied to private and protected methods, respectively.
The BlockParameters
configuration option will extend this to block parameters, where these are invalid:
def exec(&)
end
def exec(&block)
end
And this is valid:
def exec(&block : String -> String)
yield "cmd"
end
The config option DefaultValue
controls whether this rule applies to parameters that have a default value.
YAML configuration example:
Typing/MethodParameterTypeRestriction:
Enabled: true
DefaultValue: false
BlockParameters: false
PrivateMethods: false
ProtectedMethods: false
Included Modules
- YAML::Serializable
- YAML::Serializable::Strict
Defined in:
ameba/rule/typing/method_parameter_type_restriction.crConstant Summary
-
MSG =
"Method parameter should have a type restriction"
Constructors
- .new(ctx : YAML::ParseContext, node : YAML::Nodes::Node)
-
.new(config = nil)
A rule that enforces method parameters have type restrictions, with optional enforcement of block parameters.
Class Method Summary
-
.parsed_doc : String | Nil
Returns documentation for this rule, if there is any.
Instance Method Summary
- #block_parameters=(block_parameters : Bool)
- #block_parameters? : Bool
- #default_value=(default_value : Bool)
- #default_value? : Bool
- #description : String
- #description=(description : String)
- #enabled=(enabled : Bool)
- #enabled? : Bool
- #excluded : Array(String) | Nil
- #excluded=(excluded : Array(String) | Nil)
- #private_methods=(private_methods : Bool)
- #private_methods? : Bool
- #protected_methods=(protected_methods : Bool)
- #protected_methods? : Bool
- #severity : Ameba::Severity
- #severity=(severity : Ameba::Severity)
- #since_version : SemanticVersion | Nil
- #since_version=(since_version : String)
- #test(source, node : Crystal::Def)
Instance methods inherited from class Ameba::Rule::Base
==(other)
==,
catch(source : Source)
catch,
excluded?(source)
excluded?,
group
group,
hash
hash,
name
name,
special?
special?,
test(source : Source, node : Crystal::ASTNode, *opts)test(source : Source) test
Class methods inherited from class Ameba::Rule::Base
default_severity : Ameba::Severity
default_severity
Macros inherited from class Ameba::Rule::Base
issue_for(*args, **kwargs, &block)
issue_for
Macros inherited from module Ameba::Config::RuleConfig
properties(&block)
properties
Constructor Detail
A rule that enforces method parameters have type restrictions, with optional enforcement of block parameters.
For example, this is considered invalid:
def add(a, b)
a + b
end
And this is considered valid:
def add(a : String, b : String)
a + b
end
When the config options PrivateMethods
and ProtectedMethods
are true, this rule is also applied to private and protected methods, respectively.
The BlockParameters
configuration option will extend this to block parameters, where these are invalid:
def exec(&)
end
def exec(&block)
end
And this is valid:
def exec(&block : String -> String)
yield "cmd"
end
The config option DefaultValue
controls whether this rule applies to parameters that have a default value.
YAML configuration example:
Typing/MethodParameterTypeRestriction:
Enabled: true
DefaultValue: false
BlockParameters: false
PrivateMethods: false
ProtectedMethods: false
Class Method Detail
Returns documentation for this rule, if there is any.
module Ameba
# This is a test rule.
# Does nothing.
class MyRule < Ameba::Rule::Base
def test(source)
end
end
end
MyRule.parsed_doc # => "This is a test rule.\nDoes nothing."