Anyway , cut a long story short, this is the fixed script, thanks to
help from Alexander & Mike - sorry for misdirecting some reply emails
to the list .
Primarily, an un-quoted symbol should have been quoted, and
 a '(list ...)' should have been a '(cons ...)' .

These are the sort of problems I'd expect the picolisp debugger to
help discover -
ie. we should really track down what is making it coredump in the
non-'+'-suffixed
'(argv)' case when no error was reported when debugging is enabled by
'+' argv suffix - that was my only picolisp specific complaint .

Really, I am going to prioritize working for my own use on gdb debugger
extension that understands the picolisp debugger and can hook into it,
combined with a SIGSEGV + SIGBUS + SIGILL ... fatal signal handler
that, if the fatal signal is in a picolisp code section, will inform picolisp
debugger & make it print the stack & current environments & gdb back-trace
 to a (set of) Emacs or Vim buffer(s) if on a terminal or to a file(s) .

This is really better than digging coredumps out of the systemd 'coredumpctl'
compressed archive, and manually entering gdb commands to inspect picolisp
memory - really, some GDB <-> picolisp integration is needed, along with a
Emacs / Vi / HTML GUI for it , IMHO .

Compare picolisp's debugging facilities with those of SBCL + Slime - they
are a bit primitive by comparison . I really think there should eventually be
a core-dumping fatal signal handler that can throw a picolisp Exception ,
that can be optionally installed, then this can be trapped by scripts and
they could then potentially restart themselves after logging this occurence .
I will work on this .

Best Regards,
Jason

Eventually, I'd make proper '+Route+' Class objects from these
 idx tree IP/PFX indexed idx tree assoc lists .

Attachment: L_RT.l
Description: Binary data

Reply via email to