diff options
author | naruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-08-04 00:50:59 +0000 |
---|---|---|
committer | naruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-08-04 00:50:59 +0000 |
commit | b3d7273dc1f7e29a759de8dd88cd00f99a66bed1 (patch) | |
tree | dc22ba0d8d5d8f40e161cbb68f297bc6a50427a3 | |
parent | e00b83ceb91048da8549399c11618345ce32d9cc (diff) |
Add functions and macros for second encoding definitions.
* encoding.c (rb_enc_set_base): Add for setting base encoding
with their names. this is internal function.
* template/encdb.h.tmpl: specify ENC_SET_BASE for second
encodings in each encoding files.
* enc/encdb.c (rb_enc_set_base): add a declaration.
(ENC_SET_BASE): ditto.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@24383 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 11 | ||||
-rw-r--r-- | enc/encdb.c | 2 | ||||
-rw-r--r-- | encoding.c | 12 | ||||
-rw-r--r-- | template/encdb.h.tmpl | 6 |
4 files changed, 30 insertions, 1 deletions
@@ -1,3 +1,14 @@ +Tue Aug 4 09:33:54 2009 NARUSE, Yui <naruse@ruby-lang.org> + + * encoding.c (rb_enc_set_base): Add for setting base encoding + with their names. this is internal function. + + * template/encdb.h.tmpl: specify ENC_SET_BASE for second encodings in + each encoding files. + + * enc/encdb.c (rb_enc_set_base): add a declaration. + (ENC_SET_BASE): ditto. + Tue Aug 4 06:30:01 2009 Yukihiro Matsumoto <matz@ruby-lang.org> * hash.c (rb_hash_replace): should copy compare_by_identity status as well. diff --git a/enc/encdb.c b/enc/encdb.c index 35f4c93b55..476b55dafe 100644 --- a/enc/encdb.c +++ b/enc/encdb.c @@ -13,10 +13,12 @@ int rb_encdb_replicate(const char *alias, const char *orig); int rb_encdb_alias(const char *alias, const char *orig); int rb_encdb_dummy(const char *name); void rb_encdb_declare(const char *name); +void rb_enc_set_base(const char *name, const char *orig); #define ENC_REPLICATE(name, orig) rb_encdb_replicate(name, orig) #define ENC_ALIAS(name, orig) rb_encdb_alias(name, orig) #define ENC_DUMMY(name) rb_encdb_dummy(name) #define ENC_DEFINE(name) rb_encdb_declare(name) +#define ENC_SET_BASE(name) rb_enc_set_base(name) void Init_encdb(void) diff --git a/encoding.c b/encoding.c index 5e54ce7218..49326b6625 100644 --- a/encoding.c +++ b/encoding.c @@ -275,6 +275,18 @@ set_base_encoding(int index, rb_encoding *base) return enc; } +/* for encdb.h + * Set base encoding for encodings which are not replicas + * but not in their own files. + */ +void +rb_enc_set_base(const char *name, const char *orig) +{ + int idx = rb_enc_registered(name); + int origidx = rb_enc_registered(orig); + set_base_encoding(idx, rb_enc_from_index(origidx)); +} + int rb_enc_replicate(const char *name, rb_encoding *encoding) { diff --git a/template/encdb.h.tmpl b/template/encdb.h.tmpl index e65b651050..4275a4c2f0 100644 --- a/template/encdb.h.tmpl +++ b/template/encdb.h.tmpl @@ -34,11 +34,15 @@ encdirs.each do |encdir| next if files[fn] files[fn] = true open(File.join(encdir,fn)) do |f| - orig = nil name = nil f.each_line do |line| if (/^OnigEncodingDefine/ =~ line)..(/"(.*?)"/ =~ line) if $1 + if name + lines << %[ENC_SET_BASE("#$1", "#{name}");] + else + name = $1 + end check_duplication(defs, $1, fn, $.) encodings << $1 count += 1 |