class Ameba::Config

Overview

A configuration entry for Ameba::Runner.

Config can be loaded from configuration YAML file and adjusted.

config = Config.load
config.formatter = my_formatter

By default config loads .ameba.yml file located in a current working directory.

If it cannot be found until reaching the root directory, then it will be searched for in the user’s global config locations, which consists of a dotfile or a config file inside the XDG Base Directory specification.

If both files exist, the dotfile will be selected.

As an example, if Ameba is invoked from inside /path/to/project/lib/utils, then it will use the config as specified inside the first of the following files:

Included Modules

Defined in:

ameba/config.cr

Constant Summary

AVAILABLE_FORMATTERS = {progress: Formatter::DotFormatter, todo: Formatter::TODOFormatter, flycheck: Formatter::FlycheckFormatter, silent: Formatter::BaseFormatter, disabled: Formatter::DisabledFormatter, json: Formatter::JSONFormatter, "github-actions": Formatter::GitHubActionsFormatter}
DEFAULT_GLOBS = ["**/*.cr", "!lib"] of ::String
DEFAULT_PATH = Path[Dir.current] / FILENAME
DEFAULT_PATHS = {Path["~"] / FILENAME, Path[XDG_CONFIG_HOME] / "ameba/config.yml"}
FILENAME = ".ameba.yml"
XDG_CONFIG_HOME = ENV.fetch("XDG_CONFIG_HOME", "~/.config")

Class Method Summary

Instance Method Summary

Instance methods inherited from module Ameba::GlobUtils

expand(globs) expand, find_files_by_globs(globs) find_files_by_globs

Class Method Detail

def self.formatter_names #

[View source]
def self.load(path = nil, colors = true, skip_reading_config = false) #

Loads YAML configuration file by path.

config = Ameba::Config.load

[View source]

Instance Method Detail

def autocorrect=(autocorrect : Bool) #

Returns true if correctable issues should be autocorrected.


[View source]
def autocorrect? : Bool #

Returns true if correctable issues should be autocorrected.


[View source]
def excluded : Array(String) #

Represents a list of paths to exclude from globs. Can have wildcards.

config = Ameba::Config.load
config.excluded = ["spec", "src/server/*.cr"]

[View source]
def excluded=(excluded : Array(String)) #

Represents a list of paths to exclude from globs. Can have wildcards.

config = Ameba::Config.load
config.excluded = ["spec", "src/server/*.cr"]

[View source]
def formatter : Formatter::BaseFormatter #

Returns a formatter to be used while inspecting files. If formatter is not set, it will return default formatter.

config = Ameba::Config.load
config.formatter = custom_formatter
config.formatter

[View source]
def formatter=(name : String | Symbol) #

Sets formatter by name.

config = Ameba::Config.load
config.formatter = :progress

[View source]
def formatter=(formatter : Formatter::BaseFormatter) #

Returns a formatter to be used while inspecting files. If formatter is not set, it will return default formatter.

config = Ameba::Config.load
config.formatter = custom_formatter
config.formatter

[View source]
def globs : Array(String) #

Returns a list of paths (with wildcards) to files. Represents a list of sources to be inspected. If globs are not set, it will return default list of files.

config = Ameba::Config.load
config.globs = ["**/*.cr"]
config.globs

[View source]
def globs=(globs : Array(String)) #

Returns a list of paths (with wildcards) to files. Represents a list of sources to be inspected. If globs are not set, it will return default list of files.

config = Ameba::Config.load
config.globs = ["**/*.cr"]
config.globs

[View source]
def rules : Array(Rule::Base) #

[View source]
def severity : Ameba::Severity #

[View source]
def severity=(severity : Ameba::Severity) #

[View source]
def sources #

Returns a list of sources matching globs and excluded sections.

config = Ameba::Config.load
config.sources # => list of default sources
config.globs = ["**/*.cr"]
config.excluded = ["spec"]
config.sources # => list of sources pointing to files found by the wildcards

[View source]
def stdin_filename : String | Nil #

Returns a filename if reading source file from STDIN.


[View source]
def stdin_filename=(stdin_filename : String | Nil) #

Returns a filename if reading source file from STDIN.


[View source]
def update_rule(name, enabled = true, excluded = nil) #

Updates rule properties.

config = Ameba::Config.load
config.update_rule "MyRuleName", enabled: false

[View source]
def update_rules(names, enabled = true, excluded = nil) #

Updates rules properties.

config = Ameba::Config.load
config.update_rules %w[Rule1 Rule2], enabled: true

also it allows to update groups of rules:

config.update_rules %w[Group1 Group2], enabled: true

[View source]
def version : SemanticVersion | Nil #

Returns an ameba version to be used by Ameba::Runner.


[View source]
def version=(version : SemanticVersion | Nil) #

Returns an ameba version to be used by Ameba::Runner.


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

Sets version from string.

config = Ameba::Config.load
config.version = "1.6.0"

[View source]