Class: Rails::SourceAnnotationExtractor::Annotation
- Inherits:
-
Struct
- Object
- Struct
- Rails::SourceAnnotationExtractor::Annotation
- Defined in:
- lib/rails/source_annotation_extractor.rb
Instance Attribute Summary collapse
-
#line ⇒ Object
Returns the value of attribute line.
-
#tag ⇒ Object
Returns the value of attribute tag.
-
#text ⇒ Object
Returns the value of attribute text.
Class Method Summary collapse
- .directories ⇒ Object
- .extensions ⇒ Object
-
.register_directories(*dirs) ⇒ Object
Registers additional directories to be included Rails::SourceAnnotationExtractor::Annotation.register_directories(“spec”, “another”).
-
.register_extensions(*exts, &block) ⇒ Object
Registers new Annotations File Extensions Rails::SourceAnnotationExtractor::Annotation.register_extensions(“css”, “scss”, “sass”, “less”, “js”) { |tag| ///s*(##tag):?s*(.*)$/ }.
-
.register_tags(*additional_tags) ⇒ Object
Registers additional tags Rails::SourceAnnotationExtractor::Annotation.register_tags(“TESTME”, “DEPRECATEME”).
- .tags ⇒ Object
Instance Method Summary collapse
-
#to_s(options = {}) ⇒ Object
Returns a representation of the annotation that looks like this:.
Instance Attribute Details
#line ⇒ Object
Returns the value of attribute line
54 55 56 |
# File 'lib/rails/source_annotation_extractor.rb', line 54 def line @line end |
#tag ⇒ Object
Returns the value of attribute tag
54 55 56 |
# File 'lib/rails/source_annotation_extractor.rb', line 54 def tag @tag end |
#text ⇒ Object
Returns the value of attribute text
54 55 56 |
# File 'lib/rails/source_annotation_extractor.rb', line 54 def text @text end |
Class Method Details
.directories ⇒ Object
55 56 57 |
# File 'lib/rails/source_annotation_extractor.rb', line 55 def self.directories @@directories ||= %w(app config db lib test) end |
.extensions ⇒ Object
75 76 77 |
# File 'lib/rails/source_annotation_extractor.rb', line 75 def self.extensions @@extensions ||= {} end |
.register_directories(*dirs) ⇒ Object
Registers additional directories to be included
Rails::SourceAnnotationExtractor::Annotation.register_directories("spec", "another")
61 62 63 |
# File 'lib/rails/source_annotation_extractor.rb', line 61 def self.register_directories(*dirs) directories.push(*dirs) end |
.register_extensions(*exts, &block) ⇒ Object
Registers new Annotations File Extensions
Rails::SourceAnnotationExtractor::Annotation.register_extensions("css", "scss", "sass", "less", "js") { |tag| /\/\/\s*(#{tag}):?\s*(.*)$/ }
81 82 83 |
# File 'lib/rails/source_annotation_extractor.rb', line 81 def self.register_extensions(*exts, &block) extensions[/\.(#{exts.join("|")})$/] = block end |
.register_tags(*additional_tags) ⇒ Object
Registers additional tags
Rails::SourceAnnotationExtractor::Annotation.("TESTME", "DEPRECATEME")
71 72 73 |
# File 'lib/rails/source_annotation_extractor.rb', line 71 def self.(*) .push(*) end |
.tags ⇒ Object
65 66 67 |
# File 'lib/rails/source_annotation_extractor.rb', line 65 def self. @@tags ||= %w(OPTIMIZE FIXME TODO) end |
Instance Method Details
#to_s(options = {}) ⇒ Object
Returns a representation of the annotation that looks like this:
[126] [TODO] This algorithm is simple and clearly correct, make it faster.
If options
has a flag :tag
the tag is shown as in the example above. Otherwise the string contains just line and text.
107 108 109 110 111 |
# File 'lib/rails/source_annotation_extractor.rb', line 107 def to_s( = {}) s = +"[#{line.to_s.rjust([:indent])}] " s << "[#{tag}] " if [:tag] s << text end |