From a48d0bc96c7a0069ff4d4cc2f3945b23a9a49b73 Mon Sep 17 00:00:00 2001 From: ValekoZ Date: Thu, 7 Dec 2023 19:13:07 +0100 Subject: [PATCH] [target-remote] Add post-hook for `extended-remote` too --- gef.py | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/gef.py b/gef.py index 37adf3c46..bb8043095 100644 --- a/gef.py +++ b/gef.py @@ -11223,19 +11223,18 @@ def target_remote_posthook(): GefTmuxSetup() - # `target remote` commands cannot be disabled, so print a warning message instead - errmsg = "Using `target remote` with GEF does not work, use `gef-remote` instead. You've been warned." - hook = f"""pi if calling_function() != "connect": err("{errmsg}")""" - gdb.execute(f"define target hook-remote\n{hook}\nend") - gdb.execute(f"define target hook-extended-remote\n{hook}\nend") - - # Register a post-hook for `target remote` that initialize the remote session - gdb.execute(""" - define target hookpost-remote + warnmsg = "Using `target remote` with GEF should work in most cases, but use `gef-remote` if you can." + hook = f""" + define target hookpost-{{}} pi target_remote_posthook() context + pi if calling_function() != "connect": warn("{warnmsg}") end - """) + """ + + # Register a post-hook for `target remote` that initialize the remote session + gdb.execute(hook.format("remote")) + gdb.execute(hook.format("extended-remote")) # restore saved breakpoints (if any) bkp_fpath = pathlib.Path(gef.config["gef.autosave_breakpoints_file"]).expanduser().absolute()