Skip to content

Commit c110d7a

Browse files
committed
Merge pull request git-for-windows#1915 from dscho/open-in-gdb
Add a helper function to start GDB that was already attached to the current process
2 parents c19e885 + 86dc798 commit c110d7a

File tree

2 files changed

+23
-0
lines changed

2 files changed

+23
-0
lines changed

compat/mingw.c

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,19 @@
1313

1414
static const int delay[] = { 0, 1, 10, 20, 40 };
1515

16+
void open_in_gdb(void)
17+
{
18+
static struct child_process cp = CHILD_PROCESS_INIT;
19+
extern char *_pgmptr;
20+
21+
argv_array_pushl(&cp.args, "mintty", "gdb", NULL);
22+
argv_array_pushf(&cp.args, "--pid=%d", getpid());
23+
cp.clean_on_exit = 1;
24+
if (start_command(&cp) < 0)
25+
die_errno("Could not start gdb");
26+
sleep(1);
27+
}
28+
1629
int err_win_to_posix(DWORD winerr)
1730
{
1831
int error = ENOSYS;

compat/mingw.h

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -596,6 +596,16 @@ int main(int argc, const char **argv) \
596596
} \
597597
static int mingw_main(c,v)
598598

599+
/*
600+
* For debugging: if a problem occurs, say, in a Git process that is spawned
601+
* from another Git process which in turn is spawned from yet another Git
602+
* process, it can be quite daunting to figure out what is going on.
603+
*
604+
* Call this function to open a new MinTTY (this assumes you are in Git for
605+
* Windows' SDK) with a GDB that attaches to the current process right away.
606+
*/
607+
extern void open_in_gdb(void);
608+
599609
/*
600610
* Used by Pthread API implementation for Windows
601611
*/

0 commit comments

Comments
 (0)