diff options
author | ser <ser@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-05-16 15:17:31 +0000 |
---|---|---|
committer | ser <ser@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-05-16 15:17:31 +0000 |
commit | 1c3030fe2c56383fd9c61ea1b9b574bc06f0351c (patch) | |
tree | 5add8b63369553228f3348398c7681f22c58cbec /lib/rexml/parseexception.rb | |
parent | 60316f16e1da9344575d63c22017d8c7d8b1d147 (diff) | |
download | ruby-1c3030fe2c56383fd9c61ea1b9b574bc06f0351c.tar.gz ruby-1c3030fe2c56383fd9c61ea1b9b574bc06f0351c.tar.xz ruby-1c3030fe2c56383fd9c61ea1b9b574bc06f0351c.zip |
------------------------------------------------------------------------
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@6329 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/rexml/parseexception.rb')
-rw-r--r-- | lib/rexml/parseexception.rb | 82 |
1 files changed, 42 insertions, 40 deletions
diff --git a/lib/rexml/parseexception.rb b/lib/rexml/parseexception.rb index 66a421454..feb7a7e63 100644 --- a/lib/rexml/parseexception.rb +++ b/lib/rexml/parseexception.rb @@ -1,49 +1,51 @@ module REXML - class ParseException < RuntimeError - attr_accessor :source, :parser, :continued_exception + class ParseException < RuntimeError + attr_accessor :source, :parser, :continued_exception - def initialize( message, source=nil, parser=nil, exception=nil ) - super(message) - @source = source - @parser = parser - @continued_exception = exception - end + def initialize( message, source=nil, parser=nil, exception=nil ) + super(message) + @source = source + @parser = parser + @continued_exception = exception + end - def to_s - # Quote the original exception, if there was one - if @continued_exception - err = @continued_exception.inspect - err << "\n" - err << @continued_exception.backtrace.join("\n") - err << "\n...\n" - else - err = "" - end + def to_s + # Quote the original exception, if there was one + if @continued_exception + err = @continued_exception.inspect + err << "\n" + err << @continued_exception.backtrace.join("\n") + err << "\n...\n" + else + err = "" + end - # Get the stack trace and error message - err << super + # Get the stack trace and error message + err << super - # Add contextual information - if @source - err << "\nLine: #{line}\n" - err << "Position: #{position}\n" - err << "Last 80 unconsumed characters:\n" - err << @source.buffer[0..80].gsub(/\n/, ' ') - end - - err - end + # Add contextual information + if @source + err << "\nLine: #{line}\n" + err << "Position: #{position}\n" + err << "Last 80 unconsumed characters:\n" + err << @source.buffer[0..80].gsub(/\n/, ' ') + end + + err + end - def position - @source.current_line[0] if @source and @source.current_line - end + def position + @source.current_line[0] if @source and defined? @source.current_line and + @source.current_line + end - def line - @source.current_line[2] if @source and @source.current_line - end + def line + @source.current_line[2] if @source and defined? @source.current_line and + @source.current_line + end - def context - @source.current_line - end - end + def context + @source.current_line + end + end end |