diff options
author | davidflanagan <davidflanagan@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-11-07 22:55:27 +0000 |
---|---|---|
committer | davidflanagan <davidflanagan@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-11-07 22:55:27 +0000 |
commit | 6d5dc3f8044e7748c5d8205461981db367bd410c (patch) | |
tree | dc893f9d48e6056055582a4b0e3ca7c0d943bc68 /test/ruby/test_mixed_unicode_escapes.rb | |
parent | e1e01256b4243e478a9caa1624b98efefea2ec36 (diff) | |
download | ruby-6d5dc3f8044e7748c5d8205461981db367bd410c.tar.gz ruby-6d5dc3f8044e7748c5d8205461981db367bd410c.tar.xz ruby-6d5dc3f8044e7748c5d8205461981db367bd410c.zip |
* parse.y: patch, based on Nobu's, work to support \u escapes
also modifications for better coderange detection
* test/ruby/test_unicode_escapes.rb: test cases
* test/ruby/test_mixed_unicode_escapes.rb: mixed encoding test cases
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@13836 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'test/ruby/test_mixed_unicode_escapes.rb')
-rw-r--r-- | test/ruby/test_mixed_unicode_escapes.rb | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/test/ruby/test_mixed_unicode_escapes.rb b/test/ruby/test_mixed_unicode_escapes.rb new file mode 100644 index 000000000..e80e6fb14 --- /dev/null +++ b/test/ruby/test_mixed_unicode_escapes.rb @@ -0,0 +1,25 @@ +# -*- coding: sjis -*- +# This test is in a differnt file than TestUnicodeEscapes +# So that we can have a different coding comment above + +require 'test/unit' + +class TestMixedUnicodeEscape < Test::Unit::TestCase + def test_basic + # Unicode escapes do work in an sjis encoded file, but only + # if they don't contain other multi-byte chars + assert_equal("A", "\u0041") + # 8-bit character escapes are okay. + assert_equal("B\xFF", "\u0042\xFF") + + # sjis mb chars mixed with Unicode shound not work + assert_raise(SyntaxError) { eval %q("\u1234")} + assert_raise(SyntaxError) { eval %q("\u{1234}")} + + # String interpolation turns into an expression and we get + # a different kind of error, but we still can't mix these + assert_raise(ArgumentError) { eval %q("\u{1234}#{nil}")} + assert_raise(ArgumentError) { eval %q("#{nil}\u1234")} + + end +end |