mirror of
https://github.com/corda/corda.git
synced 2025-01-07 13:38:47 +00:00
fix handling of native methods in stack walking code
This commit is contained in:
parent
0974c36008
commit
78e48996b5
@ -215,10 +215,8 @@ class MyStackWalker: public Processor::StackWalker {
|
|||||||
if (trace and trace->nativeMethod) {
|
if (trace and trace->nativeMethod) {
|
||||||
method_ = trace->nativeMethod;
|
method_ = trace->nativeMethod;
|
||||||
state = NativeMethod;
|
state = NativeMethod;
|
||||||
} else if (ip_) {
|
|
||||||
state = Next;
|
|
||||||
} else {
|
} else {
|
||||||
state = Finish;
|
state = Next;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -228,16 +226,14 @@ class MyStackWalker: public Processor::StackWalker {
|
|||||||
if (method_) {
|
if (method_) {
|
||||||
state = Method;
|
state = Method;
|
||||||
} else if (trace) {
|
} else if (trace) {
|
||||||
base = trace->base;
|
|
||||||
stack = static_cast<void**>(trace->stack);
|
stack = static_cast<void**>(trace->stack);
|
||||||
ip_ = (stack ? *static_cast<void**>(stack) : 0);
|
ip_ = (stack ? *static_cast<void**>(stack) : 0);
|
||||||
|
base = trace->base;
|
||||||
|
trace = trace->next;
|
||||||
|
|
||||||
if (trace->nativeMethod) {
|
if (trace and trace->nativeMethod) {
|
||||||
method_ = trace->nativeMethod;
|
method_ = trace->nativeMethod;
|
||||||
state = NativeMethod;
|
state = NativeMethod;
|
||||||
} else {
|
|
||||||
trace = trace->next;
|
|
||||||
state = Next;
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
state = Finish;
|
state = Finish;
|
||||||
@ -266,30 +262,23 @@ class MyStackWalker: public Processor::StackWalker {
|
|||||||
stack = static_cast<void**>(base) + 1;
|
stack = static_cast<void**>(base) + 1;
|
||||||
ip_ = (stack ? *static_cast<void**>(stack) : 0);
|
ip_ = (stack ? *static_cast<void**>(stack) : 0);
|
||||||
base = *static_cast<void**>(base);
|
base = *static_cast<void**>(base);
|
||||||
state = Next;
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NativeMethod:
|
case NativeMethod:
|
||||||
trace = trace->next;
|
|
||||||
state = Next;
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
abort(t);
|
abort(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
state = Next;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual object method() {
|
virtual object method() {
|
||||||
switch (state) {
|
// fprintf(stderr, "method %s.%s\n", &byteArrayBody
|
||||||
case Method:
|
// (t, className(t, methodClass(t, method_)), 0),
|
||||||
|
// &byteArrayBody(t, methodName(t, method_), 0));
|
||||||
return method_;
|
return method_;
|
||||||
|
|
||||||
case NativeMethod:
|
|
||||||
return trace->nativeMethod;
|
|
||||||
|
|
||||||
default:
|
|
||||||
abort(t);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual int ip() {
|
virtual int ip() {
|
||||||
|
Loading…
Reference in New Issue
Block a user