/*******************************************************************************
* Copyright (c) 2000, 2006 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.output;
import java.util.ArrayList;
import java.util.List;
/**
* Represent a GDB Tuple MI assembly response.
*/
public class MISrcAsm {
int line;
String file = ""; //$NON-NLS-1$
MIAsm[] asm;
public MISrcAsm(MITuple tuple) {
parse(tuple);
}
public int getLine() {
return line;
}
public String getFile() {
return file;
}
public MIAsm[] getMIAsms() {
return asm;
}
public String toString() {
StringBuffer buffer = new StringBuffer();
buffer.append("src_and_asm_line={"); //$NON-NLS-1$
buffer.append("line=\"").append(line).append('"'); //$NON-NLS-1$
buffer.append(",file=\"" + file + "\","); //$NON-NLS-1$ //$NON-NLS-2$
buffer.append("line_asm_insn=["); //$NON-NLS-1$
for (int i = 0; i < asm.length; i++) {
if (i != 0) {
buffer.append(',');
}
buffer.append(asm[i].toString());
}
buffer.append(']');
buffer.append('}');
return buffer.toString();
}
void parse(MITuple tuple) {
List aList = new ArrayList();
MIResult[] results = tuple.getMIResults();
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).getCString();
}
if (var.equals("line_asm_insn")) { //$NON-NLS-1$
if (value instanceof MIList) {
MIList list = (MIList)value;
MIValue[] values = list.getMIValues();
for (int j = 0; j < values.length; j++) {
if (values[j] instanceof MITuple) {
aList.add(new MIAsm((MITuple)values[j]));
}
}
}
} if (var.equals("line")) { //$NON-NLS-1$
try {
line = Integer.parseInt(str.trim());
} catch (NumberFormatException e) {
}
} else if (var.equals("file")) { //$NON-NLS-1$
file = str;
}
}
asm = (MIAsm[])aList.toArray(new MIAsm[aList.size()]);
}
}