aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-05-31 10:14:38 +0000
committernaruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-05-31 10:14:38 +0000
commit0682fab6a2ad52f51a440336e99a9abe28e7c050 (patch)
treeeb4a076875f13a6f651362c36661f973c3162e61
parent075530a6850ebf899e8874d7675fd900577c9554 (diff)
downloadruby-0682fab6a2ad52f51a440336e99a9abe28e7c050.tar.gz
* enc/utf_16{be,le}.c (utf16{be,le}_code_to_mbc):
fix codepoint to bytes. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@16717 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--enc/utf_16be.c14
-rw-r--r--enc/utf_16le.c15
3 files changed, 17 insertions, 17 deletions
diff --git a/ChangeLog b/ChangeLog
index 5f7f90d898..0662224a04 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Sat May 31 19:11:39 2008 NARUSE, Yui <naruse@ruby-lang.org>
+
+ * enc/utf_16{be,le}.c (utf16{be,le}_code_to_mbc):
+ fix codepoint to bytes.
+
Sat May 31 18:28:17 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
* suppress warnings with -Wwrite-string.
diff --git a/enc/utf_16be.c b/enc/utf_16be.c
index 2ef3199633..f80711d9bd 100644
--- a/enc/utf_16be.c
+++ b/enc/utf_16be.c
@@ -132,14 +132,12 @@ utf16be_code_to_mbc(OnigCodePoint code, UChar *buf,
UChar* p = buf;
if (code > 0xffff) {
- unsigned int plane, high;
-
- plane = code >> 16;
- *p++ = (plane >> 2) + 0xd8;
- high = (code & 0xff00) >> 8;
- *p++ = ((plane & 0x03) << 6) + (high >> 2);
- *p++ = (high & 0x02) + 0xdc;
- *p = (UChar )(code & 0xff);
+ unsigned int high = (code >> 10) + 0xD7C0;
+ unsigned int low = (code & 0x3FF) + 0xDC00;
+ *p++ = (high >> 8) & 0xFF;
+ *p++ = high & 0xFF;
+ *p++ = (low >> 8) & 0xFF;
+ *p++ = low & 0xFF;
return 4;
}
else {
diff --git a/enc/utf_16le.c b/enc/utf_16le.c
index 33bfe08f47..c3712f4e18 100644
--- a/enc/utf_16le.c
+++ b/enc/utf_16le.c
@@ -126,15 +126,12 @@ utf16le_code_to_mbc(OnigCodePoint code, UChar *buf,
UChar* p = buf;
if (code > 0xffff) {
- unsigned int plane, high;
-
- plane = code >> 16;
- high = (code & 0xff00) >> 8;
-
- *p++ = ((plane & 0x03) << 6) + (high >> 2);
- *p++ = (plane >> 2) + 0xd8;
- *p++ = (UChar )(code & 0xff);
- *p = (high & 0x02) + 0xdc;
+ unsigned int high = (code >> 10) + 0xD7C0;
+ unsigned int low = (code & 0x3FF) + 0xDC00;
+ *p++ = high & 0xFF;
+ *p++ = (high >> 8) & 0xFF;
+ *p++ = low & 0xFF;
+ *p++ = (low >> 8) & 0xFF;
return 4;
}
else {