/******************************************************************************* * Copyright (c) 2000, 2010 QNX Software Systems and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * QNX Software Systems - Initial API and implementation *******************************************************************************/ package org.eclipse.cdt.debug.mi.core.event; import org.eclipse.cdt.debug.mi.core.MISession; import org.eclipse.cdt.debug.mi.core.output.MIConst; import org.eclipse.cdt.debug.mi.core.output.MIExecAsyncOutput; import org.eclipse.cdt.debug.mi.core.output.MIFrame; import org.eclipse.cdt.debug.mi.core.output.MIResult; import org.eclipse.cdt.debug.mi.core.output.MIResultRecord; import org.eclipse.cdt.debug.mi.core.output.MITuple; import org.eclipse.cdt.debug.mi.core.output.MIValue; /** * ^stopped,reason="breakpoint-hit",bkptno="1",thread-id="0",frame={addr="0x08048468",func="main",args=[{name="argc",value="1"},{name="argv",value="0xbffff18c"}],file="hello.c",line="4"} * */ public class MIBreakpointHitEvent extends MIStoppedEvent { int bkptno; MIFrame frame; public MIBreakpointHitEvent(MISession source, MIExecAsyncOutput record) { super(source, record); parse(); } public MIBreakpointHitEvent(MISession source, MIResultRecord record) { super(source, record); parse(); } /** * This constructor is used for catchpoint hits with gdb < 7.0. In that * environment, we have to get creative as gdb doesn't send us a reason with * the stopped event. Fortunately, a stream record tells us the target has * stopped because of a catchpoint and the associated breakpoint number. * * @since 7.0 */ public MIBreakpointHitEvent(MISession source, MIExecAsyncOutput record, int bkptNumber) { super(source, record); parse(); bkptno = bkptNumber; assert bkptNumber > 0; // we know gdb bkpt numbers are 1-based } public int getNumber() { return bkptno; } public MIFrame getMIFrame() { return frame; } public String toString() { StringBuffer buffer = new StringBuffer(); buffer.append("number=").append(bkptno).append('\n'); //$NON-NLS-1$ buffer.append("thread-id=").append(getThreadId()).append('\n'); //$NON-NLS-1$ buffer.append(frame.toString()); return buffer.toString(); } void parse () { MIResult[] results = null; MIExecAsyncOutput exec = getMIExecAsyncOutput(); MIResultRecord rr = getMIResultRecord(); if (exec != null) { results = exec.getMIResults(); } else if (rr != null) { results = rr.getMIResults(); } if (results != null) { for (int i = 0; i < results.length; i++) { String var = results[i].getVariable(); MIValue value = results[i].getMIValue(); String str = ""; //$NON-NLS-1$ if (value != null && value instanceof MIConst) { str = ((MIConst)value).getString(); } if (var.equals("bkptno")) { //$NON-NLS-1$ try { bkptno = Integer.parseInt(str.trim()); } catch (NumberFormatException e) { } } else if (var.equals("thread-id")) { //$NON-NLS-1$ try { int id = Integer.parseInt(str.trim()); setThreadId(id); } catch (NumberFormatException e) { } } else if (var.equals("frame")) { //$NON-NLS-1$ if (value instanceof MITuple) { frame = new MIFrame((MITuple)value); } } } } } }