summaryrefslogtreecommitdiff
path: root/vm.c
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-05-22 09:49:19 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-05-22 09:49:19 +0000
commit6bfaf6e20957d57f88500b78e3ae67719cc99941 (patch)
tree983ca8cd325837f7f8f61cb5b8239c724dc30f3c /vm.c
parentbef510ada0eda7612d7ece1d079b9a3333c1bbe2 (diff)
merges r23472 from trunk into ruby_1_9_1.
-- * vm.c (rb_vm_get_sourceline): should not access out of bound. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_1@23534 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'vm.c')
-rw-r--r--vm.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/vm.c b/vm.c
index 9732206523..89093ceb3b 100644
--- a/vm.c
+++ b/vm.c
@@ -672,11 +672,12 @@ rb_vm_get_sourceline(const rb_control_frame_t *cfp)
const rb_iseq_t *iseq = cfp->iseq;
if (RUBY_VM_NORMAL_ISEQ_P(iseq)) {
- int i;
- int pos = cfp->pc - cfp->iseq->iseq_encoded;
+ rb_num_t i;
+ size_t pos = cfp->pc - cfp->iseq->iseq_encoded;
for (i = 0; i < iseq->insn_info_size; i++) {
if (iseq->insn_info_table[i].position == pos) {
+ if (i == 0) goto found;
line_no = iseq->insn_info_table[i - 1].line_no;
goto found;
}
@@ -1462,7 +1463,7 @@ static VALUE *thread_recycle_stack_slot[RECYCLE_MAX];
static int thread_recycle_stack_count = 0;
static VALUE *
-thread_recycle_stack(int size)
+thread_recycle_stack(size_t size)
{
if (thread_recycle_stack_count) {
return thread_recycle_stack_slot[--thread_recycle_stack_count];
@@ -1675,7 +1676,7 @@ vm_define_method(rb_thread_t *th, VALUE obj, ID id, VALUE iseqval,
{
NODE *newbody;
VALUE klass = cref->nd_clss;
- int noex = cref->nd_visi;
+ int noex = (int)cref->nd_visi;
rb_iseq_t *miseq;
GetISeqPtr(iseqval, miseq);