mirror of
https://github.com/eclipse-cdt/cdt
synced 2025-04-29 19:45:01 +02:00
Refactor of MISignal to MISigHandle to not to confuse
with cli "signal SIGNAL".
This commit is contained in:
parent
9f080ee5e6
commit
4e6954c190
4 changed files with 69 additions and 36 deletions
|
@ -21,23 +21,23 @@ import org.eclipse.cdt.debug.mi.core.command.MIInfoSignals;
|
|||
import org.eclipse.cdt.debug.mi.core.event.MIEvent;
|
||||
import org.eclipse.cdt.debug.mi.core.event.MISignalChangedEvent;
|
||||
import org.eclipse.cdt.debug.mi.core.output.MIInfoSignalsInfo;
|
||||
import org.eclipse.cdt.debug.mi.core.output.MISignal;
|
||||
import org.eclipse.cdt.debug.mi.core.output.MISigHandle;
|
||||
|
||||
/**
|
||||
*/
|
||||
public class SignalManager extends SessionObject implements ICDISignalManager {
|
||||
|
||||
boolean autoupdate;
|
||||
MISignal[] noSigs = new MISignal[0];
|
||||
List signalsList = Collections.synchronizedList(new ArrayList(5));
|
||||
MISigHandle[] noSigs = new MISigHandle[0];
|
||||
List signalsList = null;
|
||||
|
||||
public SignalManager(Session session) {
|
||||
super(session);
|
||||
autoupdate = false;
|
||||
}
|
||||
|
||||
MISignal[] getMISignals() throws CDIException {
|
||||
MISignal[] miSigs = noSigs;
|
||||
MISigHandle[] getMISignals() throws CDIException {
|
||||
MISigHandle[] miSigs = noSigs;
|
||||
Session session = (Session)getSession();
|
||||
MISession mi = session.getMISession();
|
||||
CommandFactory factory = mi.getCommandFactory();
|
||||
|
@ -55,8 +55,8 @@ public class SignalManager extends SessionObject implements ICDISignalManager {
|
|||
return miSigs;
|
||||
}
|
||||
|
||||
MISignal getMISignal(String name) throws CDIException {
|
||||
MISignal sig = null;
|
||||
MISigHandle getMISignal(String name) throws CDIException {
|
||||
MISigHandle sig = null;
|
||||
Session session = (Session)getSession();
|
||||
MISession mi = session.getMISession();
|
||||
CommandFactory factory = mi.getCommandFactory();
|
||||
|
@ -67,7 +67,7 @@ public class SignalManager extends SessionObject implements ICDISignalManager {
|
|||
if (info == null) {
|
||||
throw new CDIException("No answer");
|
||||
}
|
||||
MISignal[] miSigs = info.getMISignals();
|
||||
MISigHandle[] miSigs = info.getMISignals();
|
||||
if (miSigs.length > 0) {
|
||||
sig = miSigs[0];
|
||||
}
|
||||
|
@ -83,19 +83,21 @@ public class SignalManager extends SessionObject implements ICDISignalManager {
|
|||
* @param mISignal
|
||||
* @return boolean
|
||||
*/
|
||||
private boolean hasSignalChanged(ICDISignal sig, MISignal miSignal) {
|
||||
return !sig.getName().equals(miSignal.getName()) ; /* ||
|
||||
private boolean hasSignalChanged(ICDISignal sig, MISigHandle miSignal) {
|
||||
return !sig.getName().equals(miSignal.getName()) ||
|
||||
sig.isStopSet() != miSignal.isStop() ||
|
||||
sig.isIgnore() == miSignal.isPass(); */
|
||||
sig.isIgnore() != !miSignal.isPass();
|
||||
}
|
||||
|
||||
public ICDISignal findSignal(String name) {
|
||||
ICDISignal sig = null;
|
||||
ICDISignal[] sigs = (ICDISignal[])signalsList.toArray(new ICDISignal[0]);
|
||||
for (int i = 0; i < sigs.length; i++) {
|
||||
if (sigs[i].getName().equals(name)) {
|
||||
sig = sigs[i];
|
||||
break;
|
||||
if (signalsList != null) {
|
||||
ICDISignal[] sigs = (ICDISignal[])signalsList.toArray(new ICDISignal[0]);
|
||||
for (int i = 0; i < sigs.length; i++) {
|
||||
if (sigs[i].getName().equals(name)) {
|
||||
sig = sigs[i];
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
return sig;
|
||||
|
@ -105,9 +107,11 @@ public class SignalManager extends SessionObject implements ICDISignalManager {
|
|||
ICDISignal sig = findSignal(name);
|
||||
if (sig == null) {
|
||||
try {
|
||||
MISignal miSig = getMISignal(name);
|
||||
MISigHandle miSig = getMISignal(name);
|
||||
sig = new Signal(this, miSig);
|
||||
signalsList.add(sig);
|
||||
if (signalsList != null) {
|
||||
signalsList.add(sig);
|
||||
}
|
||||
} catch (CDIException e) {
|
||||
}
|
||||
}
|
||||
|
@ -138,12 +142,17 @@ public class SignalManager extends SessionObject implements ICDISignalManager {
|
|||
} catch (MIException e) {
|
||||
throw new MI2CDIException(e);
|
||||
}
|
||||
((Signal)sig).getMISignal().handle(isIgnore, isStop);
|
||||
mi.fireEvent(new MISignalChangedEvent(sig.getName()));
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.cdt.debug.core.cdi.ICDISignalManager#getSignals()
|
||||
*/
|
||||
public ICDISignal[] getSignals() throws CDIException {
|
||||
if (signalsList == null) {
|
||||
update();
|
||||
}
|
||||
return (ICDISignal[])signalsList.toArray(new ICDISignal[0]);
|
||||
}
|
||||
|
||||
|
@ -165,8 +174,11 @@ public class SignalManager extends SessionObject implements ICDISignalManager {
|
|||
* @see org.eclipse.cdt.debug.core.cdi.ICDISignalManager#update()
|
||||
*/
|
||||
public void update() throws CDIException {
|
||||
if (signalsList == null) {
|
||||
signalsList = Collections.synchronizedList(new ArrayList(5));
|
||||
}
|
||||
Session session = (Session)getSession();
|
||||
MISignal[] miSigs = getMISignals();
|
||||
MISigHandle[] miSigs = getMISignals();
|
||||
List eventList = new ArrayList(miSigs.length);
|
||||
for (int i = 0; i < miSigs.length; i++) {
|
||||
ICDISignal sig = findSignal(miSigs[i].getName());
|
||||
|
@ -186,4 +198,10 @@ public class SignalManager extends SessionObject implements ICDISignalManager {
|
|||
mi.fireEvents(events);
|
||||
}
|
||||
|
||||
/**
|
||||
* Method signal.
|
||||
*/
|
||||
public void signal() {
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -8,58 +8,68 @@ package org.eclipse.cdt.debug.mi.core.cdi.model;
|
|||
import org.eclipse.cdt.debug.core.cdi.CDIException;
|
||||
import org.eclipse.cdt.debug.core.cdi.model.ICDISignal;
|
||||
import org.eclipse.cdt.debug.mi.core.cdi.SignalManager;
|
||||
import org.eclipse.cdt.debug.mi.core.output.MISignal;
|
||||
import org.eclipse.cdt.debug.mi.core.output.MISigHandle;
|
||||
|
||||
/**
|
||||
*/
|
||||
public class Signal extends CObject implements ICDISignal {
|
||||
|
||||
SignalManager mgr;
|
||||
MISignal sig;
|
||||
MISigHandle sig;
|
||||
|
||||
public Signal(SignalManager m, MISignal s) {
|
||||
public Signal(SignalManager m, MISigHandle s) {
|
||||
super(m.getSession().getCurrentTarget());
|
||||
mgr = m;
|
||||
sig = s;
|
||||
}
|
||||
|
||||
public void setMISignal(MISignal s) {
|
||||
public void setMISignal(MISigHandle s) {
|
||||
sig = s;
|
||||
}
|
||||
|
||||
public MISigHandle getMISignal() {
|
||||
return sig;
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.cdt.debug.core.cdi.ICDISignalReceived#getMeaning()
|
||||
* @see org.eclipse.cdt.debug.core.cdi.ICDISignal#getMeaning()
|
||||
*/
|
||||
public String getMeaning() {
|
||||
public String getDescription() {
|
||||
return sig.getDescription();
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.cdt.debug.core.cdi.ICDISignalReceived#getName()
|
||||
* @see org.eclipse.cdt.debug.core.cdi.ICDISignal#getName()
|
||||
*/
|
||||
public String getName() {
|
||||
return sig.getName();
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.cdt.debug.core.cdi.ICDISignalReceived#handle()
|
||||
* @see org.eclipse.cdt.debug.core.cdi.ICDISignal#handle()
|
||||
*/
|
||||
public void handle(boolean ignore, boolean stop) throws CDIException {
|
||||
mgr.handle(this, ignore, stop);
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.cdt.debug.core.cdi.ICDISignalReceived#isIgnore()
|
||||
* @see org.eclipse.cdt.debug.core.cdi.ICDISignal#isIgnore()
|
||||
*/
|
||||
public boolean isIgnore() {
|
||||
return !sig.isPass();
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.eclipse.cdt.debug.core.cdi.ICDISignalReceived#isStopSet()
|
||||
* @see org.eclipse.cdt.debug.core.cdi.ICDISignal#isStopSet()
|
||||
*/
|
||||
public boolean isStopSet() {
|
||||
return sig.isStop();
|
||||
}
|
||||
|
||||
/**
|
||||
* Continue program giving it signal specified by the argument.
|
||||
*/
|
||||
public void signal() {
|
||||
mgr.signal();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -24,14 +24,14 @@ import java.util.StringTokenizer;
|
|||
*/
|
||||
public class MIInfoSignalsInfo extends MIInfo {
|
||||
|
||||
MISignal[] signals;
|
||||
MISigHandle[] signals;
|
||||
|
||||
public MIInfoSignalsInfo(MIOutput out) {
|
||||
super(out);
|
||||
parse();
|
||||
}
|
||||
|
||||
public MISignal[] getMISignals() {
|
||||
public MISigHandle[] getMISignals() {
|
||||
return signals;
|
||||
}
|
||||
|
||||
|
@ -49,9 +49,9 @@ public class MIInfoSignalsInfo extends MIInfo {
|
|||
}
|
||||
}
|
||||
}
|
||||
signals = new MISignal[aList.size()];
|
||||
signals = new MISigHandle[aList.size()];
|
||||
for (int i = 0; i < aList.size(); i++) {
|
||||
signals[i] = (MISignal)aList.get(i);
|
||||
signals[i] = (MISigHandle)aList.get(i);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -93,7 +93,7 @@ public class MIInfoSignalsInfo extends MIInfo {
|
|||
break;
|
||||
}
|
||||
}
|
||||
MISignal s = new MISignal(signal, stop, print, pass, desc.trim());
|
||||
MISigHandle s = new MISigHandle(signal, stop, print, pass, desc.trim());
|
||||
aList.add(s);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -8,7 +8,7 @@ package org.eclipse.cdt.debug.mi.core.output;
|
|||
/**
|
||||
* GDB/MI shared information
|
||||
*/
|
||||
public class MISignal {
|
||||
public class MISigHandle {
|
||||
|
||||
String signal = "";
|
||||
boolean stop;
|
||||
|
@ -16,7 +16,7 @@ public class MISignal {
|
|||
boolean pass;
|
||||
String description = "";
|
||||
|
||||
public MISignal (String name, boolean stp, boolean prnt, boolean ps, String desc) {
|
||||
public MISigHandle (String name, boolean stp, boolean prnt, boolean ps, String desc) {
|
||||
signal = name;
|
||||
stop = stp;
|
||||
print = prnt;
|
||||
|
@ -40,6 +40,11 @@ public class MISignal {
|
|||
return pass;
|
||||
}
|
||||
|
||||
public void handle(boolean isIgnore, boolean isStop) {
|
||||
pass = !isIgnore;
|
||||
stop = isStop;
|
||||
}
|
||||
|
||||
public String getDescription() {
|
||||
return description;
|
||||
}
|
Loading…
Add table
Reference in a new issue