diff options
author | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-12-23 14:06:00 +0000 |
---|---|---|
committer | akr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-12-23 14:06:00 +0000 |
commit | cf36df97fb74f60b321fe5617b3805078393c028 (patch) | |
tree | 51038152f32fdf52be12e5f11593d29c6b63fd63 /encoding.c | |
parent | 40a6b594100fb75a2dbd3d2e205142779e1283ce (diff) | |
download | ruby-cf36df97fb74f60b321fe5617b3805078393c028.tar.gz |
* encoding.c (rb_enc_codepoint): implemented to raise invalid
encoding.
* include/ruby/encoding.h (rb_enc_codepoint): macro is replaced as a
declaration.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@14524 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'encoding.c')
-rw-r--r-- | encoding.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/encoding.c b/encoding.c index 52f311f1ca..c926dac142 100644 --- a/encoding.c +++ b/encoding.c @@ -661,6 +661,15 @@ rb_enc_ascget(const char *p, const char *e, int *len, rb_encoding *enc) return c; } +int rb_enc_codepoint(const char *p, const char *e, rb_encoding *enc) +{ + int r = rb_enc_precise_mbclen(p, e, enc); + if (MBCLEN_CHARFOUND(r)) + return ONIGENC_MBC_TO_CODE(enc,(UChar*)p,(UChar*)e); + else + rb_raise(rb_eArgError, "invalid mbstring sequence"); +} + int rb_enc_codelen(int c, rb_encoding *enc) { |