mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-29 10:32:47 +00:00
Fix problem next'ing over an external method
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@1027 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
aa7420b35b
commit
a74a6b5fdf
@ -894,6 +894,7 @@ void Interpreter::nextInstruction() { // Do the 'next' command
|
||||
// If this is a call instruction, step over the call instruction...
|
||||
// TODO: ICALL, CALL WITH, ...
|
||||
if ((*ECStack.back().CurInst)->getOpcode() == Instruction::Call) {
|
||||
unsigned StackSize = ECStack.size();
|
||||
// Step into the function...
|
||||
if (executeInstruction()) {
|
||||
// Hit a breakpoint, print current instruction, then return to user...
|
||||
@ -902,8 +903,11 @@ void Interpreter::nextInstruction() { // Do the 'next' command
|
||||
return;
|
||||
}
|
||||
|
||||
// Finish executing the function...
|
||||
finish();
|
||||
// If we we able to step into the function, finish it now. We might not be
|
||||
// able the step into a function, if it's external for example.
|
||||
if (ECStack.size() != StackSize)
|
||||
finish(); // Finish executing the function...
|
||||
|
||||
} else {
|
||||
// Normal instruction, just step...
|
||||
stepInstruction();
|
||||
|
Loading…
Reference in New Issue
Block a user