class
Ameba::Rule::Typing::MethodReturnTypeRestriction
Overview
A rule that enforces method definitions have a return type restriction.
For example, this are considered invalid:
def hello(name = "World")
"Hello #{name}"
end
And this is valid:
def hello(name = "World") : String
"Hello #{name}"
end
When the config options PrivateMethods and ProtectedMethods
are true, this rule is also applied to private and protected methods, respectively.
The NodocMethods configuration option controls whether this rule applies to
methods with a :nodoc: directive.
YAML configuration example:
Typing/MethodReturnTypeRestriction:
Enabled: true
PrivateMethods: false
ProtectedMethods: false
NodocMethods: false
Included Modules
- Ameba::AST::Util
- YAML::Serializable
- YAML::Serializable::Strict
Defined in:
ameba/rule/typing/method_return_type_restriction.crConstant Summary
-
MSG =
"Method should have a return type restriction"
Constructors
- .new(ctx : YAML::ParseContext, node : YAML::Nodes::Node)
-
.new(config = nil)
A rule that enforces method definitions have a return type restriction.
- .new(*, __context_for_yaml_serializable ctx : YAML::ParseContext, __node_for_yaml_serializable node : YAML::Nodes::Node)
Class Method Summary
-
.parsed_doc : String | Nil
Returns documentation for this rule, if there is any.
Instance Method Summary
- #description : String
- #description=(description : String)
- #enabled=(enabled : Bool)
- #enabled? : Bool
- #excluded : Array(String) | Nil
- #excluded=(excluded : Array(String) | Nil)
- #nodoc_methods=(nodoc_methods : Bool)
- #nodoc_methods? : Bool
- #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 module Ameba::AST::Util
abort?(node)
abort?,
control_exp_code(node : Crystal::ControlExpression, code_lines)
control_exp_code,
dynamic_literal?(node) : Bool
dynamic_literal?,
exit?(node)
exit?,
flow_command?(node, in_loop)
flow_command?,
flow_expression?(node, in_loop = false)
flow_expression?,
has_block?(node) : Bool
has_block?,
literal?(node) : Bool
literal?,
loop?(node)
loop?,
name_end_location(node)
name_end_location,
name_location(node)
name_location,
name_location_or(token : Crystal::Token, name, *, adjust_location_column_number = nil)name_location_or(node : Crystal::ASTNode, *, adjust_location_column_number = nil) name_location_or, name_size(node) name_size, node_source(node, code_lines) node_source, nodoc?(node) nodoc?, path_named?(node, *names : String) : Bool path_named?, raise?(node) raise?, source_between(loc, end_loc, code_lines) : String | Nil source_between, static_literal?(node) : Bool static_literal?
Instance methods inherited from class Ameba::Rule::Base
==(other)
==,
catch(source : Source)
catch,
excluded?(source)
excluded?,
group
group,
hash(hasher)
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 definitions have a return type restriction.
For example, this are considered invalid:
def hello(name = "World")
"Hello #{name}"
end
And this is valid:
def hello(name = "World") : String
"Hello #{name}"
end
When the config options PrivateMethods and ProtectedMethods
are true, this rule is also applied to private and protected methods, respectively.
The NodocMethods configuration option controls whether this rule applies to
methods with a :nodoc: directive.
YAML configuration example:
Typing/MethodReturnTypeRestriction:
Enabled: true
PrivateMethods: false
ProtectedMethods: false
NodocMethods: 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."