Class: REXML::IOSource

Inherits:
Source
  • Object
show all
Defined in:
lib/rexml/source.rb

Overview

A Source that wraps an IO. See the Source class for method documentation

Instance Attribute Summary

Attributes inherited from Source

#encoding, #line

Attributes included from Encoding

#encoding

Instance Method Summary collapse

Methods inherited from Source

#buffer, #buffer_encoding=, #position, #position=

Methods included from Encoding

#decode, #encode

Constructor Details

#initialize(arg, block_size = 500, encoding = nil) ⇒ IOSource

block_size has been deprecated



144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
# File 'lib/rexml/source.rb', line 144

def initialize(arg, block_size=500, encoding=nil)
  @er_source = @source = arg
  @to_utf = false
  @pending_buffer = nil

  if encoding
    super("", encoding)
  else
    super(@source.read(3) || "")
  end

  if !@to_utf and
      @orig.respond_to?(:force_encoding) and
      @source.respond_to?(:external_encoding) and
      @source.external_encoding != ::Encoding::UTF_8
    @force_utf8 = true
  else
    @force_utf8 = false
  end
end

Instance Method Details

#current_lineObject



217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
# File 'lib/rexml/source.rb', line 217

def current_line
  begin
    pos = @er_source.pos        # The byte position in the source
    lineno = @er_source.lineno  # The XML < position in the source
    @er_source.rewind
    line = 0                    # The \r\n position in the source
    begin
      while @er_source.pos < pos
        @er_source.readline
        line += 1
      end
    rescue
    end
    @er_source.seek(pos)
  rescue IOError
    pos = -1
    line = -1
  end
  [pos, lineno, line]
end

#empty?Boolean



212
213
214
# File 'lib/rexml/source.rb', line 212

def empty?
  super and ( @source.nil? || @source.eof? )
end

#ensure_bufferObject



189
190
191
# File 'lib/rexml/source.rb', line 189

def ensure_buffer
  read if @scanner.eos? && @source
end

#match(pattern, cons = false) ⇒ Object

Note: When specifying a string for ‘pattern’, it must not include ‘>’ except in the following formats:

  • “>”

  • “XXX>” (X is any string excluding ‘>’)



196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
# File 'lib/rexml/source.rb', line 196

def match( pattern, cons=false )
  while true
    if cons
      md = @scanner.scan(pattern)
    else
      md = @scanner.check(pattern)
    end
    break if md
    return nil if pattern.is_a?(String)
    return nil if @source.nil?
    return nil unless read
  end

  md.nil? ? nil : @scanner
end

#read(term = nil) ⇒ Object



165
166
167
168
169
170
171
172
173
# File 'lib/rexml/source.rb', line 165

def read(term = nil)
  begin
    @scanner << readline(term)
    true
  rescue Exception, NameError
    @source = nil
    false
  end
end

#read_until(term) ⇒ Object



175
176
177
178
179
180
181
182
183
184
185
186
187
# File 'lib/rexml/source.rb', line 175

def read_until(term)
  pattern = Regexp.union(term)
  begin
    until str = @scanner.scan_until(pattern)
      @scanner << readline(term)
    end
  rescue EOFError
    @scanner.rest
  else
    read if @scanner.eos? and !@source.eof?
    str
  end
end