class Ameba::Source
- Ameba::Source
- Reference
- Object
Overview
An entity that represents a Crystal source file. Has path, lines of code and issues reported by rules.
Included Modules
Defined in:
ameba/source.crConstructors
Instance Method Summary
-
#ast
Returns AST nodes constructed by
Crystal::Parser
. -
#code : String
Crystal code (content of a source file).
- #fullpath
-
#lines
Returns lines of code splitted by new line character.
-
#matches_path?(filepath)
Returns true if filepath matches the source's path, false if it does not.
-
#path : String
Path to the source file.
Instance methods inherited from module Ameba::Reportable
add_issue(rule, location : Crystal::Location?, end_location : Crystal::Location?, message, status = nil)add_issue(rule, location : Tuple(Int32, Int32), end_location : Tuple(Int32, Int32), message, **args)
add_issue(rule, location : Tuple(Int32, Int32), message, **args)
add_issue(rule, node : Crystal::ASTNode, message, **args)
add_issue(rule, token : Crystal::Token, message, **args) add_issue, issues issues, valid? valid?
Instance methods inherited from module Ameba::InlineComments
comment?(line_number : Int32)
comment?,
location_disabled?(location, rule)
location_disabled?,
parse_inline_directive(line)
parse_inline_directive
Constructor Detail
Creates a new source by #code
and #path
.
For example:
path = "./src/source.cr"
Ameba::Source.new File.read(path), path
Instance Method Detail
Returns AST nodes constructed by Crystal::Parser
.
source = Ameba::Source.new code, path
source.ast
Returns lines of code splitted by new line character.
Since #code
is immutable and can't be changed, this
method caches lines in an instance variable, so calling
it second time will not perform a split, but will return
lines instantly.
source = Ameba::Source.new "a = 1\nb = 2", path
source.lines # => ["a = 1", "b = 2"]
Returns true if filepath matches the source's path, false if it does not.