mirror of
https://github.com/eclipse-cdt/cdt
synced 2025-04-22 22:22:11 +02:00
Fixed 283333; View doesn't update when user makes model change
This commit is contained in:
parent
7920146a21
commit
02f13c474b
1 changed files with 43 additions and 0 deletions
|
@ -42,12 +42,55 @@ public class TimersVMProvider extends AbstractDMVMProvider {
|
||||||
/** Enumeration of possible layouts for the timers view model */
|
/** Enumeration of possible layouts for the timers view model */
|
||||||
public enum ViewLayout { TRIGGERS_AT_TOP, TIMERS_AT_TOP }
|
public enum ViewLayout { TRIGGERS_AT_TOP, TIMERS_AT_TOP }
|
||||||
|
|
||||||
|
/** Have we registered ourselves as a listener for DM events? */
|
||||||
|
private boolean fRegisteredEventListener;
|
||||||
|
|
||||||
public TimersVMProvider(AbstractVMAdapter adapter, IPresentationContext presentationContext, DsfSession session) {
|
public TimersVMProvider(AbstractVMAdapter adapter, IPresentationContext presentationContext, DsfSession session) {
|
||||||
super(adapter, presentationContext, session);
|
super(adapter, presentationContext, session);
|
||||||
|
|
||||||
|
// Add ourselves as listener for DM events events.
|
||||||
|
try {
|
||||||
|
session.getExecutor().execute(new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
if (DsfSession.isSessionActive(getSession().getId())) {
|
||||||
|
getSession().addServiceEventListener(TimersVMProvider.this, null);
|
||||||
|
fRegisteredEventListener = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} catch (RejectedExecutionException e) {
|
||||||
|
// Session shut down, not much we can do but wait to be disposed.
|
||||||
|
}
|
||||||
|
|
||||||
// Set the initial view layout.
|
// Set the initial view layout.
|
||||||
setViewLayout(ViewLayout.TIMERS_AT_TOP);
|
setViewLayout(ViewLayout.TIMERS_AT_TOP);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see org.eclipse.cdt.dsf.ui.viewmodel.AbstractVMProvider#dispose()
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void dispose() {
|
||||||
|
// Remove ourselves as listener for DM events events. In practice, we
|
||||||
|
// get called after the session has shut down, so we'll end up with a
|
||||||
|
// RejectedExecutionException. We put this here all the same for
|
||||||
|
// completeness sake.
|
||||||
|
try {
|
||||||
|
getSession().getExecutor().execute(new Runnable() {
|
||||||
|
public void run() {
|
||||||
|
if (fRegisteredEventListener && DsfSession.isSessionActive(getSession().getId())) {
|
||||||
|
getSession().removeServiceEventListener(TimersVMProvider.this);
|
||||||
|
fRegisteredEventListener = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} catch (RejectedExecutionException e) {
|
||||||
|
// Session shut down, not much we can do but wait to be disposed.
|
||||||
|
}
|
||||||
|
|
||||||
|
super.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Configures a new layout for the timers view model.
|
* Configures a new layout for the timers view model.
|
||||||
* @param layout New layout to use.
|
* @param layout New layout to use.
|
||||||
|
|
Loading…
Add table
Reference in a new issue