Class: MarkdownLint::Style
- Inherits:
-
Object
- Object
- MarkdownLint::Style
- Defined in:
- lib/mdl/style.rb
Overview
defines a style
Instance Attribute Summary collapse
-
#rules ⇒ Object
readonly
Returns the value of attribute rules.
Class Method Summary collapse
Instance Method Summary collapse
- #all ⇒ Object
- #exclude_rule(id) ⇒ Object
- #exclude_tag(tag) ⇒ Object
-
#initialize(all_rules) ⇒ Style
constructor
A new instance of Style.
- #rule(id, params = {}) ⇒ Object
- #tag(tag) ⇒ Object
Constructor Details
#initialize(all_rules) ⇒ Style
Returns a new instance of Style.
8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
# File 'lib/mdl/style.rb', line 8 def initialize(all_rules) @tagged_rules = {} @aliases = {} all_rules.each do |id, r| r..each do |t| @tagged_rules[t] ||= Set.new @tagged_rules[t] << id end r.aliases.each do |a| @aliases[a] = id end end @all_rules = all_rules @rules = Set.new end |
Instance Attribute Details
#rules ⇒ Object (readonly)
Returns the value of attribute rules.
6 7 8 |
# File 'lib/mdl/style.rb', line 6 def rules @rules end |
Class Method Details
.load(style_file, rules) ⇒ Object
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 |
# File 'lib/mdl/style.rb', line 54 def self.load(style_file, rules) unless style_file.include?('/') || style_file.end_with?('.rb') tmp = File.("../styles/#{style_file}.rb", __FILE__) unless File.exist?(tmp) warn "#{style_file} does not appear to be a built-in style." + ' If you meant to pass in your own style file, it must contain' + " a '/' or end in '.rb'. See https://github.com/markdownlint/" + 'markdownlint/blob/main/docs/configuration.md' exit(1) end style_file = tmp end unless File.exist?(style_file) warn "Style '#{style_file}' does not exist." exit(1) end style = new(rules) style.instance_eval(File.read(style_file), style_file) rules.select! { |r| style.rules.include?(r) } style end |
Instance Method Details
#all ⇒ Object
24 25 26 |
# File 'lib/mdl/style.rb', line 24 def all @rules.merge(@all_rules.keys) end |
#exclude_rule(id) ⇒ Object
41 42 43 44 |
# File 'lib/mdl/style.rb', line 41 def exclude_rule(id) id = @aliases[id] if @aliases[id] @rules.delete(id) end |
#exclude_tag(tag) ⇒ Object
50 51 52 |
# File 'lib/mdl/style.rb', line 50 def exclude_tag(tag) @rules.subtract(@tagged_rules[tag]) end |
#rule(id, params = {}) ⇒ Object
28 29 30 31 32 33 34 35 36 37 38 39 |
# File 'lib/mdl/style.rb', line 28 def rule(id, params = {}) if block_given? raise '"rule" does not take a block. Should this definition go in a ' + 'ruleset instead?' end id = @aliases[id] if @aliases[id] raise "No such rule: #{id}" unless @all_rules[id] @rules << id @all_rules[id].params(params) end |
#tag(tag) ⇒ Object
46 47 48 |
# File 'lib/mdl/style.rb', line 46 def tag(tag) @rules.merge(@tagged_rules[tag]) end |