1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00
ruby--ruby/enc/trans/japanese.trans
yugui 3fa3f9abb9 Supports static linking of extensions and encodings again.
Fixes --with-static-linked-ext.

Patch by Google Inc. [ruby-core:45073].

* Makefile.in (ENCOBJS, EXTOBJS): New variables to specify static
  linked libraries. Also reintroduces extinit.o, introduces encinit.o
  introduces encinit.o

* common.mk: Builds static libraries rather than shared objects if
  specified.

* configure.in (LD): new substitution. 
  Avoids PIE if s

* enc/depend: Supports static linked libraries
  (libencs, libenc, libtrans): New target.

* enc/encinit.c.erb: new template to generate the initialization of
  statically linked encodings.

* enc/make_encmake.rb (--module): new flag to specify whether static
  or dynamic.

* transcode_data.h (TRANS_INIT): New macro to get rid of the name
  collision of encoding initializers and transcoder initializers.

* ext/extmk.rb: Fixes the behavior on $extstatic is true.

* lib/mkmf.rb (clean-static): new target to clean up static linked
  libraries.

* ruby.c (process_options): New initializes statically linked
  encodings here.



git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@35662 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2012-05-16 05:39:06 +00:00

97 lines
2.2 KiB
Text

#include "transcode_data.h"
<%
map = {}
map["{00-7f}"] = :nomap
map["{a1-fe}{a1-fe}"] = :func_so
map["8e{a1-df}"] = :func_so
map["8e{e0-fe}"] = :undef
map["8f{a1-fe}{a1-fe}"] = :undef
transcode_generate_node(ActionMap.parse(map), "eucjp2sjis")
map = {}
map["{00-7f}"] = :nomap
map["{81-9f,e0-ef}{40-7e,80-fc}"] = :func_so
map["{f0-fc}{40-7e,80-fc}"] = :undef
map["{a1-df}"] = :func_so
transcode_generate_node(ActionMap.parse(map), "sjis2eucjp")
%>
<%= transcode_generated_code %>
static ssize_t
fun_so_eucjp2sjis(void *statep, const unsigned char *s, size_t l, unsigned char *o, size_t osize)
{
if (s[0] == 0x8e) {
o[0] = s[1];
return 1;
}
else {
int h, m, l;
m = s[0] & 1;
h = (s[0]+m) >> 1;
h += s[0] < 0xdf ? 0x30 : 0x70;
l = s[1] - m * 94 - 3;
if (0x7f <= l)
l++;
o[0] = h;
o[1] = l;
return 2;
}
}
static ssize_t
fun_so_sjis2eucjp(void *statep, const unsigned char *s, size_t l, unsigned char *o, size_t osize)
{
if (l == 1) {
o[0] = '\x8e';
o[1] = s[0];
return 2;
}
else {
int h, l;
h = s[0];
l = s[1];
if (0xe0 <= h)
h -= 64;
l += l < 0x80 ? 0x61 : 0x60;
h = h * 2 - 0x61;
if (0xfe < l) {
l -= 94;
h += 1;
}
o[0] = h;
o[1] = l;
return 2;
}
}
static const rb_transcoder
rb_eucjp2sjis = {
"EUC-JP", "Shift_JIS", eucjp2sjis,
TRANSCODE_TABLE_INFO,
1, /* input_unit_length */
3, /* max_input */
2, /* max_output */
asciicompat_converter, /* asciicompat_type */
0, NULL, NULL, /* state_size, state_init, state_fini */
NULL, NULL, NULL, fun_so_eucjp2sjis
};
static const rb_transcoder
rb_sjis2eucjp = {
"Shift_JIS", "EUC-JP", sjis2eucjp,
TRANSCODE_TABLE_INFO,
1, /* input_unit_length */
2, /* max_input */
2, /* max_output */
asciicompat_converter, /* asciicompat_type */
0, NULL, NULL, /* state_size, state_init, state_fini */
NULL, NULL, NULL, fun_so_sjis2eucjp
};
TRANS_INIT(japanese)
{
rb_register_transcoder(&rb_eucjp2sjis);
rb_register_transcoder(&rb_sjis2eucjp);
}