summaryrefslogtreecommitdiff
path: root/iseq.c
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-01-17 08:48:52 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-01-17 08:48:52 +0000
commitdbee678630736a5d873cde1f262bf2cfc87e8dfe (patch)
tree2658d8158be06293836cb8338131a8cc73a1ed0e /iseq.c
parentca46eab09073c2d91bb21939b32aa6d767dafa36 (diff)
* some refactoring around yarvcore and proc.
* eval_proc.c: renamed to proc.c. * common.mk: ditto. * yarvcore.h, yarvcore.c: rename or remove some global variables removed: mYarvCore, mYarvInsns renamed: cYarvISeq -> rb_cISeq, cYarvProc -> rb_cProc, cYarvBinding -> rb_cBinding ::YarvCore module is removed and ::YarvCore::VM class becomes ::VM. And change/remove some functions which added with YARV. * compile.c: ditto. * eval.c: ditto. * iseq.c: ditto. * vm.c: ditto. * inits.c: rename Init_yarvcore to Init_vm. * yarvcore.c, proc.c: move some functions and initialization from yarvcore.c to proc.c. * intern.h, proc.c: add global function rb_binding_new(void). git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@11541 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'iseq.c')
-rw-r--r--iseq.c32
1 files changed, 17 insertions, 15 deletions
diff --git a/iseq.c b/iseq.c
index 73902416fd..e199e49864 100644
--- a/iseq.c
+++ b/iseq.c
@@ -20,6 +20,8 @@
// #define MARK_FREE_DEBUG 1
#include "gc.h"
+VALUE rb_cISeq;
+
static void
compile_data_free(struct iseq_compile_data *compile_data)
{
@@ -262,7 +264,7 @@ yarv_iseq_new_with_bopt_and_opt(NODE *node, VALUE name, VALUE file_name,
const yarv_compile_option_t *option)
{
yarv_iseq_t *iseq;
- VALUE self = iseq_alloc(cYarvISeq);
+ VALUE self = iseq_alloc(rb_cISeq);
GetISeqPtr(self, iseq);
iseq->self = self;
@@ -300,7 +302,7 @@ VALUE iseq_build_from_ary(yarv_iseq_t *iseq, VALUE line,
VALUE
iseq_load(VALUE self, VALUE data, VALUE parent, VALUE opt)
{
- VALUE iseqval = iseq_alloc(cYarvISeq);
+ VALUE iseqval = iseq_alloc(rb_cISeq);
VALUE magic, version1, version2, format_type, misc;
VALUE name, filename, line;
@@ -569,7 +571,7 @@ insn_operand_intern(yarv_iseq_t *iseq,
op = ID2SYM(op);
case TS_VALUE: /* VALUE */
ret = rb_inspect(op);
- if (CLASS_OF(op) == cYarvISeq) {
+ if (CLASS_OF(op) == rb_cISeq) {
rb_ary_push(child, op);
}
break;
@@ -1328,18 +1330,18 @@ void
Init_ISeq(void)
{
/* declare YARVCore::InstructionSequence */
- cYarvISeq = rb_define_class_under(mYarvCore, "InstructionSequence", rb_cObject);
- rb_define_alloc_func(cYarvISeq, iseq_alloc);
- rb_define_method(cYarvISeq, "inspect", iseq_inspect, 0);
- rb_define_method(cYarvISeq, "disasm", iseq_disasm, 0);
- rb_define_method(cYarvISeq, "to_a", iseq_to_a, 0);
- rb_define_method(cYarvISeq, "eval", iseq_eval, 0);
-
- rb_define_singleton_method(cYarvISeq, "load", iseq_s_load, -1);
- rb_define_singleton_method(cYarvISeq, "compile", iseq_s_compile, -1);
- rb_define_singleton_method(cYarvISeq, "new", iseq_s_compile, -1);
- rb_define_singleton_method(cYarvISeq, "compile_file", iseq_s_compile_file, -1);
- rb_define_singleton_method(cYarvISeq, "compile_option=",
+ rb_cISeq = rb_define_class_under(rb_cVM, "InstructionSequence", rb_cObject);
+ rb_define_alloc_func(rb_cISeq, iseq_alloc);
+ rb_define_method(rb_cISeq, "inspect", iseq_inspect, 0);
+ rb_define_method(rb_cISeq, "disasm", iseq_disasm, 0);
+ rb_define_method(rb_cISeq, "to_a", iseq_to_a, 0);
+ rb_define_method(rb_cISeq, "eval", iseq_eval, 0);
+
+ rb_define_singleton_method(rb_cISeq, "load", iseq_s_load, -1);
+ rb_define_singleton_method(rb_cISeq, "compile", iseq_s_compile, -1);
+ rb_define_singleton_method(rb_cISeq, "new", iseq_s_compile, -1);
+ rb_define_singleton_method(rb_cISeq, "compile_file", iseq_s_compile_file, -1);
+ rb_define_singleton_method(rb_cISeq, "compile_option=",
iseq_s_compile_option_set, 1);
}