class
Ameba::Rule::Lint::VoidOutsideLib
- Ameba::Rule::Lint::VoidOutsideLib
- Ameba::Rule::Base
- Reference
- Object
Overview
A rule that disallows uses of Void
outside C lib bindings.
Usages of these outside of C lib bindings don't make sense,
and can sometimes break the compiler. Nil
should be used instead in these cases.
Pointer(Void)
is the only case that's allowed per this rule.
These are considered invalid:
def foo(bar : Void) : Slice(Void)?
end
alias Baz = Void
struct Qux < Void
end
YAML configuration example:
Lint/VoidOutsideLib:
Enabled: true
Included Modules
- Ameba::AST::Util
- YAML::Serializable
- YAML::Serializable::Strict
Defined in:
ameba/rule/lint/void_outside_lib.crConstant Summary
-
MSG =
"`Void` is not allowed in this context"
Constructors
- .new(ctx : YAML::ParseContext, node : YAML::Nodes::Node)
-
.new(config = nil)
A rule that disallows uses of
Void
outside C lib bindings.
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)
- #severity : Ameba::Severity
- #severity=(severity : Ameba::Severity)
- #since_version : SemanticVersion | Nil
- #since_version=(since_version : String)
- #test(source, node : Crystal::Path)
- #test(source, node : Crystal::Generic)
- #test(source, node : Crystal::Union)
- #test(source)
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, *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
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 disallows uses of Void
outside C lib bindings.
Usages of these outside of C lib bindings don't make sense,
and can sometimes break the compiler. Nil
should be used instead in these cases.
Pointer(Void)
is the only case that's allowed per this rule.
These are considered invalid:
def foo(bar : Void) : Slice(Void)?
end
alias Baz = Void
struct Qux < Void
end
YAML configuration example:
Lint/VoidOutsideLib:
Enabled: true
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."