Class: REXML::Source
Overview
A Source can be searched for patterns, and wraps buffers and other objects and provides consumption of text
Direct Known Subclasses
Instance Attribute Summary collapse
-
#encoding ⇒ Object
Returns the value of attribute encoding.
-
#line ⇒ Object
readonly
The line number of the last consumed text.
Instance Method Summary collapse
-
#buffer ⇒ Object
The current buffer (what we’re going to read next).
- #buffer_encoding=(encoding) ⇒ Object
-
#current_line ⇒ Object
The current line in the source.
- #drop_parsed_content ⇒ Object
-
#empty? ⇒ Boolean
True if the Source is exhausted.
- #ensure_buffer ⇒ Object
-
#initialize(arg, encoding = nil) ⇒ Source
constructor
Constructor value, overriding all encoding detection.
- #match(pattern, cons = false) ⇒ Object
- #match?(pattern, cons = false) ⇒ Boolean
- #position ⇒ Object
- #position=(pos) ⇒ Object
- #read(term = nil) ⇒ Object
- #read_until(term) ⇒ Object
Methods included from Encoding
Constructor Details
#initialize(arg, encoding = nil) ⇒ Source
Constructor value, overriding all encoding detection
81 82 83 84 85 86 87 88 89 90 91 |
# File 'lib/rexml/source.rb', line 81 def initialize(arg, encoding=nil) @orig = arg @scanner = StringScanner.new(@orig) if encoding self.encoding = encoding else detect_encoding end @line = 0 @encoded_terms = {} end |
Instance Attribute Details
#encoding ⇒ Object
Returns the value of attribute encoding.
65 66 67 |
# File 'lib/rexml/source.rb', line 65 def encoding @encoding end |
#line ⇒ Object (readonly)
The line number of the last consumed text
64 65 66 |
# File 'lib/rexml/source.rb', line 64 def line @line end |
Instance Method Details
#buffer ⇒ Object
The current buffer (what we’re going to read next)
94 95 96 |
# File 'lib/rexml/source.rb', line 94 def buffer @scanner.rest end |
#buffer_encoding=(encoding) ⇒ Object
104 105 106 |
# File 'lib/rexml/source.rb', line 104 def buffer_encoding=(encoding) @scanner.string.force_encoding(encoding) end |
#current_line ⇒ Object
Returns the current line in the source.
161 162 163 164 165 166 |
# File 'lib/rexml/source.rb', line 161 def current_line lines = @orig.split res = lines.grep @scanner.rest[0..30] res = res[-1] if res.kind_of? Array lines.index( res ) if res end |
#drop_parsed_content ⇒ Object
98 99 100 101 102 |
# File 'lib/rexml/source.rb', line 98 def drop_parsed_content if @scanner.pos > Private::SCANNER_RESET_SIZE @scanner.string = @scanner.rest end end |
#empty? ⇒ Boolean
Returns true if the Source is exhausted.
156 157 158 |
# File 'lib/rexml/source.rb', line 156 def empty? @scanner.eos? end |
#ensure_buffer ⇒ Object
128 129 |
# File 'lib/rexml/source.rb', line 128 def ensure_buffer end |
#match(pattern, cons = false) ⇒ Object
131 132 133 134 135 136 137 |
# File 'lib/rexml/source.rb', line 131 def match(pattern, cons=false) if cons @scanner.scan(pattern).nil? ? nil : @scanner else @scanner.check(pattern).nil? ? nil : @scanner end end |
#match?(pattern, cons = false) ⇒ Boolean
139 140 141 142 143 144 145 |
# File 'lib/rexml/source.rb', line 139 def match?(pattern, cons=false) if cons !@scanner.skip(pattern).nil? else !@scanner.match?(pattern).nil? end end |
#position ⇒ Object
147 148 149 |
# File 'lib/rexml/source.rb', line 147 def position @scanner.pos end |
#position=(pos) ⇒ Object
151 152 153 |
# File 'lib/rexml/source.rb', line 151 def position=(pos) @scanner.pos = pos end |
#read(term = nil) ⇒ Object
115 116 |
# File 'lib/rexml/source.rb', line 115 def read(term = nil) end |
#read_until(term) ⇒ Object
118 119 120 121 122 123 124 125 126 |
# File 'lib/rexml/source.rb', line 118 def read_until(term) pattern = Private::PRE_DEFINED_TERM_PATTERNS[term] || /#{Regexp.escape(term)}/ data = @scanner.scan_until(pattern) unless data data = @scanner.rest @scanner.pos = @scanner.string.bytesize end data end |