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

Defined in:

ameba/rule/typing/method_return_type_restriction.cr

Constant Summary

MSG = "Method should have a return type restriction"

Constructors

Class Method Summary

Instance Method Summary

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?, literal?(node) : Bool literal?, loop?(node) loop?, name_end_location(node) name_end_location, name_location(node) name_location, name_size(node) name_size, node_source(node, code_lines) node_source, nodoc?(node) nodoc?, path_named?(node, name) : 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 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

def self.new(ctx : YAML::ParseContext, node : YAML::Nodes::Node) #

def self.new(config = nil) #

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

[View source]

Class Method Detail

def self.parsed_doc : String | Nil #

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."

Instance Method Detail

def description : String #

def description=(description : String) #

def enabled=(enabled : Bool) #

def enabled? : Bool #

def excluded : Array(String) | Nil #

def excluded=(excluded : Array(String) | Nil) #

def nodoc_methods=(nodoc_methods : Bool) #

def nodoc_methods? : Bool #

def private_methods=(private_methods : Bool) #

def private_methods? : Bool #

def protected_methods=(protected_methods : Bool) #

def protected_methods? : Bool #

def severity : Ameba::Severity #

def severity=(severity : Ameba::Severity) #

def since_version : SemanticVersion | Nil #

[View source]
def since_version=(since_version : String) #

def test(source, node : Crystal::Def) #

[View source]