/*******************************************************************************
* 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);
}
}
}
}
}
}