aboutsummaryrefslogtreecommitdiffstats
path: root/tool/ruby_vm
diff options
context:
space:
mode:
authorshyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2019-01-31 04:46:03 +0000
committershyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2019-01-31 04:46:03 +0000
commit72e318f118d5cfde0e66a41acd3a2070fcaf4348 (patch)
treef5add3859cdf9bcf5d78f0bececb6c81f6257ac7 /tool/ruby_vm
parent69431818f4166e0f2c35b8cec142e83bad603e13 (diff)
downloadruby-72e318f118d5cfde0e66a41acd3a2070fcaf4348.tar.gz
_insn_name_info.erb: use C99
C99 allows string literals of at least 4095 characters (cf: ISO/IEC 9899:1999 section 5.2.4.1) so the previous complex struct layout is no longer necessary. Just dump the verbatim memory contents we want. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@66957 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'tool/ruby_vm')
-rw-r--r--tool/ruby_vm/views/_insn_name_info.erb42
1 files changed, 15 insertions, 27 deletions
diff --git a/tool/ruby_vm/views/_insn_name_info.erb b/tool/ruby_vm/views/_insn_name_info.erb
index bcf570717f..767346093e 100644
--- a/tool/ruby_vm/views/_insn_name_info.erb
+++ b/tool/ruby_vm/views/_insn_name_info.erb
@@ -12,39 +12,27 @@
% c.pop
%
CONSTFUNC(MAYBE_UNUSED(static const char *insn_name(VALUE insn)));
-extern const char *rb_vm_insn_name_info;
-MJIT_SYMBOL_EXPORT_BEGIN
-extern const unsigned short rb_vm_insn_name_offset[];
-MJIT_SYMBOL_EXPORT_END
#ifdef RUBY_VM_INSNS_INFO
-const unsigned short rb_vm_insn_name_offset[] = {
-% c.each_slice 12 do |d|
- <%= d.map {|i| sprintf("%4d", i) }.join(', ') %>,
-% end
-};
-const int rb_vm_max_insn_name_size = <%= RubyVM::Instructions.map {|i| i.name.size }.max %>;
-ASSERT_VM_INSTRUCTION_SIZE(rb_vm_insn_name_offset);
+const int rb_vm_max_insn_name_size = <%= a.map(&:size).max %>;
+#endif
-PACKED_STRUCT(struct rb_vm_insn_name_info_tag {
-% b.each_slice 3 do |d|
- <%= d.map {|i|
- sprintf("const char L%03d[%2d]", i, a[i].length + 1)
- }.join('; ') %>;
+const char *
+insn_name(VALUE i)
+{
+ static const char x[] =
+% a.each do |i|
+ <%=cstr i%> "\0"
% end
-});
+ ;
-static const struct rb_vm_insn_name_info_tag rb_vm_insn_name_base = {
-% a.each_slice 2 do |d|
- <%= d.map {|i| sprintf("%-30s", cstr(i)) }.join(', ') %>,
+ static const unsigned short y[] = {
+% c.each_slice 12 do |d|
+ <%= d.map {|i| sprintf("%4d", i) }.join(', ') %>,
% end
-};
+ };
-const char *rb_vm_insn_name_info = (const char *)&rb_vm_insn_name_base;
-#endif
+ ASSERT_VM_INSTRUCTION_SIZE(y);
-const char *
-insn_name(VALUE i)
-{
- return &rb_vm_insn_name_info[rb_vm_insn_name_offset[i]];
+ return &x[y[i]];
}