[Lazarus] Strange effect when debugging...

Martin Frb lazarus at mfriebe.de
Fri Aug 2 18:23:28 CEST 2024


On 02/08/2024 17:53, Michael Van Canneyt via lazarus wrote:
>
> Hi,
>
> Does lazarus (or gdb) start a binary twice sometimes when initializing 
> debugging ?
...
> When I kill the prior process, the second F9 works at once, as do all 
> other
> attempts to run it.
>
> But if I stop the IDE and restart it, I have the same behaviour again: 
> first
> attempt to run fails.
>
> In the anchordockingdsgn IDE, when I switch project, run the new 
> project and then return to the first project (which could not be 
> debugged), all works again OK.
>
> What is puzzling is that this only happens with the IDE that has 
> anchordocking enabled.
> If I recompile the IDE after removing the anchordocking package, 
> debugging works
> at once.

I don't think it is the debugger (neither of them). Except, if the IDE 
would internally start 2 instance of the debugger (then there would 
likely be mem leaks on exit).

I don't know if it is anything to do with ... but with anchordocking, I 
have seen some keystrokes been send to the wrong control. The questions 
then would be: Could a keystroke (F9) be duplicated? If the IDE received 
two times F9 in a short enough time, would there be a race condition 
were the first is in progress, but hasn't flagged the state internally, 
so the 2nd would also go ahead?
(If that happens, and if that happens with the gdb backend, then there 
would have to be 2 instances of gdb.exe running. Assuming that both runs 
were triggered as "with debugger" and not one "without debugger")

Otherwise maybe the output of the IDE to console does have hints.

----
Of course, I assume you ensured that before you tried to start, there 
wasn't any old instance already.


More information about the lazarus mailing list