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
endAnd this is considered valid:
def add(a : String, b : String)
  a + b
endWhen 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.
The BlockParameters configuration option will extend this to block parameters, where these are invalid:
def exec(&)
end
def exec(&block)
endAnd this is valid:
def exec(&block : String -> String)
  yield "cmd"
endThe 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
  NodocMethods: falseIncluded Modules
- Ameba::AST::Util
- 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)
- #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 parameters have type restrictions, with optional enforcement of block parameters.
For example, this is considered invalid:
def add(a, b)
  a + b
endAnd this is considered valid:
def add(a : String, b : String)
  a + b
endWhen 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.
The BlockParameters configuration option will extend this to block parameters, where these are invalid:
def exec(&)
end
def exec(&block)
endAnd this is valid:
def exec(&block : String -> String)
  yield "cmd"
endThe 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
  NodocMethods: falseClass 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."