From e7a52e7c7c4a2069f78892826aae93c9653fbe30 Mon Sep 17 00:00:00 2001 From: John Cortell Date: Fri, 30 Apr 2010 15:54:48 +0000 Subject: [PATCH] Bug 311118: Attach does not work with MinGW gdb 7.0 --- .../command/MIRunControlEventProcessor_7_0.java | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/dsf-gdb/org.eclipse.cdt.dsf.gdb/src/org/eclipse/cdt/dsf/mi/service/command/MIRunControlEventProcessor_7_0.java b/dsf-gdb/org.eclipse.cdt.dsf.gdb/src/org/eclipse/cdt/dsf/mi/service/command/MIRunControlEventProcessor_7_0.java index cfb4e6b1fd9..936f332dfee 100644 --- a/dsf-gdb/org.eclipse.cdt.dsf.gdb/src/org/eclipse/cdt/dsf/mi/service/command/MIRunControlEventProcessor_7_0.java +++ b/dsf-gdb/org.eclipse.cdt.dsf.gdb/src/org/eclipse/cdt/dsf/mi/service/command/MIRunControlEventProcessor_7_0.java @@ -294,10 +294,15 @@ public class MIRunControlEventProcessor_7_0 IContainerDMContext containerDmc = null; if (groupId == null) { // MI does not currently provide the group-id in these events - if (threadId != null) { - containerDmc = procService.createContainerContextFromThreadId(fControlDmc, threadId); - procDmc = DMContexts.getAncestorOfType(containerDmc, IProcessDMContext.class); + + // In some cases, gdb sends a bare stopped event. Likely a bug, but + // we need to react to it all the same. See bug 311118. + if (threadId == null) { + threadId = "all"; //$NON-NLS-1$ } + + containerDmc = procService.createContainerContextFromThreadId(fControlDmc, threadId); + procDmc = DMContexts.getAncestorOfType(containerDmc, IProcessDMContext.class); } else { // This code would only trigger if the groupId was provided by MI procDmc = procService.createProcessContext(fControlDmc, groupId);