diff options
author | David Heinemeier Hansson <david@loudthinking.com> | 2005-05-09 11:20:19 +0000 |
---|---|---|
committer | David Heinemeier Hansson <david@loudthinking.com> | 2005-05-09 11:20:19 +0000 |
commit | b167248b21a8da63be871ec6815d117a8efa25f3 (patch) | |
tree | 3d977fdddeb85e189406ac4a8e9cb08562795fcf /actionpack | |
parent | 979880dd24d74cd2e99a06eab6c9969a1b5b2ceb (diff) | |
download | rails-b167248b21a8da63be871ec6815d117a8efa25f3.tar.gz rails-b167248b21a8da63be871ec6815d117a8efa25f3.tar.bz2 rails-b167248b21a8da63be871ec6815d117a8efa25f3.zip |
Fixed the HTML scanner used by assert_tag where a infinite loop could be caused by a stray less-than sign in the input #1270 [Jamis Buck]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@1297 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'actionpack')
-rw-r--r-- | actionpack/CHANGELOG | 2 | ||||
-rw-r--r-- | actionpack/lib/action_controller/vendor/html-scanner/html/node.rb | 5 | ||||
-rw-r--r-- | actionpack/lib/action_controller/vendor/html-scanner/html/tokenizer.rb | 14 |
3 files changed, 17 insertions, 4 deletions
diff --git a/actionpack/CHANGELOG b/actionpack/CHANGELOG index cc2029c2c2..0751b162df 100644 --- a/actionpack/CHANGELOG +++ b/actionpack/CHANGELOG @@ -1,5 +1,7 @@ *SVN* +* Fixed the HTML scanner used by assert_tag where a infinite loop could be caused by a stray less-than sign in the input #1270 [Jamis Buck] + * Added functionality to assert_tag, so you can now do tests on the siblings of a node, to assert that some element comes before or after the element in question, or just to assert that some element exists as a sibling #1226 [Jamis Buck] * Added better error handling for regexp caching expiration diff --git a/actionpack/lib/action_controller/vendor/html-scanner/html/node.rb b/actionpack/lib/action_controller/vendor/html-scanner/html/node.rb index e6362655e8..edfc57d8b6 100644 --- a/actionpack/lib/action_controller/vendor/html-scanner/html/node.rb +++ b/actionpack/lib/action_controller/vendor/html-scanner/html/node.rb @@ -277,7 +277,10 @@ module HTML#:nodoc: "</#{@name}>" else s = "<#{@name}" - @attributes.each { |k,v| s << " #{k}='#{v.to_s.gsub(/'/,"\\\\'")}'" } + @attributes.each do |k,v| + s << " #{k}" + s << "='#{v.gsub(/'/,"\\\\'")}'" if String === v + end s << " /" if @closing == :self s << ">" @children.each { |child| s << child.to_s } diff --git a/actionpack/lib/action_controller/vendor/html-scanner/html/tokenizer.rb b/actionpack/lib/action_controller/vendor/html-scanner/html/tokenizer.rb index 45066319f5..ce49b9c7e0 100644 --- a/actionpack/lib/action_controller/vendor/html-scanner/html/tokenizer.rb +++ b/actionpack/lib/action_controller/vendor/html-scanner/html/tokenizer.rb @@ -63,7 +63,7 @@ module HTML#:nodoc: # Scan all text up to the next < character and return it. def scan_text - @scanner.scan(/[^<]*/) + @scanner.getch + (@scanner.scan(/[^<]*/) || "") end # Counts the number of newlines in the text and updates the current line @@ -78,9 +78,17 @@ module HTML#:nodoc: def consume_quoted_regions text = "" loop do - match = @scanner.scan_until(/['">]/) or break + match = @scanner.scan_until(/['"<>]/) or break + + delim = @scanner.matched + if delim == "<" + match = match.chop + @scanner.pos -= 1 + end + text << match - break if (delim = @scanner.matched) == ">" + break if delim == "<" || delim == ">" + # consume the conqued region while match = @scanner.scan_until(/[\\#{delim}]/) text << match |