Class: Inch::CodeObject::Provider::YARD::Docstring
- Inherits:
-
Object
- Object
- Inch::CodeObject::Provider::YARD::Docstring
- Defined in:
- lib/inch/code_object/provider/yard/docstring.rb
Instance Method Summary collapse
- #code_examples ⇒ Object
- #contains_code_example? ⇒ Boolean
- #describes_parameter?(name) ⇒ Boolean
- #describes_return? ⇒ Boolean
- #empty? ⇒ Boolean
-
#initialize(text) ⇒ Docstring
constructor
A new instance of Docstring.
- #mentions_parameter?(name) ⇒ Boolean
- #mentions_return? ⇒ Boolean
- #parse_code_examples ⇒ Object
Constructor Details
#initialize(text) ⇒ Docstring
Returns a new instance of Docstring.
6 7 8 |
# File 'lib/inch/code_object/provider/yard/docstring.rb', line 6 def initialize(text) @text = text.to_s end |
Instance Method Details
#code_examples ⇒ Object
18 19 20 |
# File 'lib/inch/code_object/provider/yard/docstring.rb', line 18 def code_examples @code_examples ||= parse_code_examples end |
#contains_code_example? ⇒ Boolean
14 15 16 |
# File 'lib/inch/code_object/provider/yard/docstring.rb', line 14 def contains_code_example? !code_examples.empty? end |
#describes_parameter?(name) ⇒ Boolean
22 23 24 25 26 |
# File 'lib/inch/code_object/provider/yard/docstring.rb', line 22 def describes_parameter?(name) describe_parameter_regexps(name).any? do |pattern| @text.index(pattern) end end |
#describes_return? ⇒ Boolean
38 39 40 |
# File 'lib/inch/code_object/provider/yard/docstring.rb', line 38 def describes_return? @text.lines.to_a.last =~ /^Returns\ (\w+\s){2,}/ end |
#empty? ⇒ Boolean
10 11 12 |
# File 'lib/inch/code_object/provider/yard/docstring.rb', line 10 def empty? @text.strip.empty? end |
#mentions_parameter?(name) ⇒ Boolean
28 29 30 31 32 |
# File 'lib/inch/code_object/provider/yard/docstring.rb', line 28 def mentions_parameter?(name) mention_parameter_regexps(name).any? do |pattern| @text.index(pattern) end end |
#mentions_return? ⇒ Boolean
34 35 36 |
# File 'lib/inch/code_object/provider/yard/docstring.rb', line 34 def mentions_return? @text.lines.to_a.last =~ /^Returns\ / end |
#parse_code_examples ⇒ Object
42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 |
# File 'lib/inch/code_object/provider/yard/docstring.rb', line 42 def parse_code_examples code_examples = [] example = nil @text.lines.each_with_index do |line, index| if line =~/^\s*+$/ code_examples << example if example example = [] elsif line =~/^\ {2,}\S+/ example << line if example else code_examples << example if example example = nil end end code_examples << example if example code_examples.delete_if(&:empty?).map(&:join) end |