summaryrefslogtreecommitdiff
path: root/jni/ruby/prelude.c
diff options
context:
space:
mode:
authorJari Vetoniemi <jari.vetoniemi@indooratlas.com>2020-03-16 18:49:26 +0900
committerJari Vetoniemi <jari.vetoniemi@indooratlas.com>2020-03-30 00:39:06 +0900
commitfcbf63e62c627deae76c1b8cb8c0876c536ed811 (patch)
tree64cb17de3f41a2b6fef2368028fbd00349946994 /jni/ruby/prelude.c
Fresh start
Diffstat (limited to 'jni/ruby/prelude.c')
-rw-r--r--jni/ruby/prelude.c71
1 files changed, 71 insertions, 0 deletions
diff --git a/jni/ruby/prelude.c b/jni/ruby/prelude.c
new file mode 100644
index 0000000..738cfb5
--- /dev/null
+++ b/jni/ruby/prelude.c
@@ -0,0 +1,71 @@
+/* -*-c-*-
+ THIS FILE WAS AUTOGENERATED BY template/prelude.c.tmpl. DO NOT EDIT.
+
+ sources: ./prelude, ./enc/prelude, ./gem_prelude
+*/
+#include "ruby/ruby.h"
+#include "internal.h"
+#include "vm_core.h"
+
+
+static const char prelude_name0[] = "<internal:prelude>";
+static const char prelude_code0[] =
+"class Thread\n"
+" MUTEX_FOR_THREAD_EXCLUSIVE = Mutex.new\n"
+"\n"
+"\n"
+"\n"
+"\n"
+"\n"
+"\n"
+"\n"
+" def self.exclusive\n"
+" MUTEX_FOR_THREAD_EXCLUSIVE.synchronize{\n"
+" yield\n"
+" }\n"
+" end\n"
+"end\n"
+;
+
+static const char prelude_name1[] = "<internal:enc/prelude>";
+static const char prelude_code1[] =
+"begin\n"
+" require 'unicode_normalize'\n"
+"rescue LoadError\n"
+"end\n"
+;
+
+static const char prelude_name2[] = "<internal:gem_prelude>";
+static const char prelude_code2[] =
+"require 'rubygems.rb' if defined?(Gem)\n"
+;
+
+
+static void
+prelude_eval(VALUE code, VALUE name, VALUE line)
+{
+ rb_iseq_eval(rb_iseq_compile_with_option(code, name, Qnil, line, 0, Qtrue));
+}
+
+void
+Init_prelude(void)
+{
+ prelude_eval(
+ rb_usascii_str_new(prelude_code0, sizeof(prelude_code0) - 1),
+ rb_usascii_str_new(prelude_name0, sizeof(prelude_name0) - 1),
+ INT2FIX(1));
+ prelude_eval(
+ rb_usascii_str_new(prelude_code1, sizeof(prelude_code1) - 1),
+ rb_usascii_str_new(prelude_name1, sizeof(prelude_name1) - 1),
+ INT2FIX(1));
+ prelude_eval(
+ rb_usascii_str_new(prelude_code2, sizeof(prelude_code2) - 1),
+ rb_usascii_str_new(prelude_name2, sizeof(prelude_name2) - 1),
+ INT2FIX(1));
+
+#if 0
+ puts(prelude_code0);
+ puts(prelude_code1);
+ puts(prelude_code2);
+#endif
+}