summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-08-12 08:17:27 +0000
committerakr <akr@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-08-12 08:17:27 +0000
commitabef7fa890df87d69e38311b7d0626d790a396aa (patch)
tree190a2eb58688f03ba7005fe1e367a3068c78c25d
parent5b3278b74a1a7edb0885b0ccbfe86ab8f3a53813 (diff)
* transcode.c (trans_open_i): check the result of rb_transcoding_open.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@18526 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog4
-rw-r--r--transcode.c6
2 files changed, 9 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 441ccdab78..35678740ac 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Tue Aug 12 17:16:58 2008 Tanaka Akira <akr@fsij.org>
+
+ * transcode.c (trans_open_i): check the result of rb_transcoding_open.
+
Tue Aug 12 16:23:32 2008 Narihiro Nakamura <authorNari@gmail.com>
* gc.c (gc_profile_result): use rb_str_catf.
diff --git a/transcode.c b/transcode.c
index df198b1194..c05bb7d823 100644
--- a/transcode.c
+++ b/transcode.c
@@ -608,6 +608,7 @@ trans_open_i(const char *from, const char *to, int depth, void *arg)
rb_trans_t **tsp = (rb_trans_t **)arg;
rb_trans_t *ts;
int i;
+ rb_transcoding *tc;
if (!*tsp) {
ts = *tsp = ALLOC(rb_trans_t);
@@ -627,7 +628,10 @@ trans_open_i(const char *from, const char *to, int depth, void *arg)
ts = *tsp;
}
- ts->elems[depth].tc = rb_transcoding_open(from, to, 0);
+ ts->elems[depth].tc = tc = rb_transcoding_open(from, to, 0);
+ if (!tc) {
+ rb_raise(rb_eArgError, "transcoding open failed (from %s to %s)", from, to);
+ }
if (depth < ts->num_trans-1) {
int bufsize = 4096;
unsigned char *p;