2003-01-30 Adam Fedor * infrun.c (handle_inferior_event): Step through Objective-C dispatch function to method function (if found). * Makefile.in (infrun.o): Add $(objc_lang_h) Index: Makefile.in =================================================================== RCS file: /cvs/src/src/gdb/Makefile.in,v retrieving revision 1.302 diff -u -p -r1.302 Makefile.in --- Makefile.in 2 Jan 2003 20:29:15 -0000 1.302 +++ Makefile.in 3 Jan 2003 03:24:54 -0000 @@ -1795,7 +1796,8 @@ infptrace.o: infptrace.c $(defs_h) $(fra infrun.o: infrun.c $(defs_h) $(gdb_string_h) $(symtab_h) $(frame_h) \ $(inferior_h) $(breakpoint_h) $(gdb_wait_h) $(gdbcore_h) $(gdbcmd_h) \ $(cli_script_h) $(target_h) $(gdbthread_h) $(annotate_h) \ - $(symfile_h) $(top_h) $(inf_loop_h) $(regcache_h) $(value_h) + $(symfile_h) $(top_h) $(inf_loop_h) $(regcache_h) $(value_h) \ + $(objc_lang_h) inftarg.o: inftarg.c $(defs_h) $(frame_h) $(inferior_h) $(target_h) \ $(gdbcore_h) $(command_h) $(gdb_stat_h) $(gdb_wait_h) infttrace.o: infttrace.c $(defs_h) $(frame_h) $(inferior_h) $(target_h) \ Index: infrun.c =================================================================== RCS file: /cvs/src/src/gdb/infrun.c,v retrieving revision 1.95 diff -u -p -r1.95 infrun.c --- infrun.c 19 Jan 2003 17:39:16 -0000 1.95 +++ infrun.c 31 Jan 2003 03:40:37 -0000 @@ -42,6 +42,7 @@ #include "inf-loop.h" #include "regcache.h" #include "value.h" +#include "objc-lang.h" /* Prototypes for local functions */ @@ -1172,7 +1173,7 @@ context_switch (struct execution_control @@ -2430,6 +2431,32 @@ process_event_stop_test: } } + /* Determine if we are currently in the Objective-C dispatch + function. If so, get the address of the method function that + the dispatcher would call and use that as the function to + step into instead. Also skip over the trampoline for the + function (if any). This is better for the user since they + are only interested in stepping into the method function + anyway. */ + { + CORE_ADDR method_stop_pc; + + if (real_stop_pc) + find_objc_msgcall (real_stop_pc, &method_stop_pc); + else + find_objc_msgcall (stop_pc, &method_stop_pc); + + if (method_stop_pc) + ecs->stop_func_start = method_stop_pc; + + if (method_stop_pc) + { + real_stop_pc = SKIP_TRAMPOLINE_CODE (method_stop_pc); + if (real_stop_pc != 0) + ecs->stop_func_start = real_stop_pc; + } + } + /* If we have line number information for the function we are thinking of stepping into, step into it.