/*******************************************************************************
* Copyright (c) 2007, 2011 Wind River Systems, Inc. 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:
* Wind River Systems - initial API and implementation
*******************************************************************************/
package org.eclipse.tm.internal.tcf.debug.ui.model;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import org.eclipse.debug.internal.ui.viewers.model.provisional.IChildrenCountUpdate;
import org.eclipse.debug.internal.ui.viewers.model.provisional.IChildrenUpdate;
import org.eclipse.debug.internal.ui.viewers.model.provisional.IHasChildrenUpdate;
import org.eclipse.debug.ui.IDebugUIConstants;
import org.eclipse.tm.tcf.services.IMemory;
import org.eclipse.tm.tcf.services.IRunControl;
public class TCFNodeLaunch extends TCFNode implements ISymbolOwner {
private final TCFChildrenExecContext children;
private final TCFChildren filtered_children;
private final Map<String,TCFNodeSymbol> symbols = new HashMap<String,TCFNodeSymbol>();
TCFNodeLaunch(final TCFModel model) {
super(model);
children = new TCFChildrenExecContext(this);
filtered_children = new TCFChildren(this) {
@Override
protected boolean startDataRetrieval() {
Set<String> filter = launch.getContextFilter();
if (filter == null) {
if (!children.validate(this)) return false;
set(null, children.getError(), children.getData());
return true;
}
Map<String,TCFNode> nodes = new HashMap<String,TCFNode>();
for (String id : filter) {
if (!model.createNode(id, this)) return false;
if (isValid()) {
// Ignore invalid IDs
reset();
}
else {
nodes.put(id, model.getNode(id));
}
}
set(null, null, nodes);
return true;
}
@Override
public void dispose() {
getNodes().clear();
super.dispose();
}
};
}
@Override
void dispose() {
ArrayList<TCFNodeSymbol> l = new ArrayList<TCFNodeSymbol>(symbols.values());
for (TCFNodeSymbol s : l) s.dispose();
assert symbols.size() == 0;
super.dispose();
}
@Override
protected boolean getData(IChildrenCountUpdate result, Runnable done) {
if (IDebugUIConstants.ID_DEBUG_VIEW.equals(result.getPresentationContext().getId())) {
if (!filtered_children.validate(done)) return false;
result.setChildCount(filtered_children.size());
}
else {
result.setChildCount(0);
}
return true;
}
@Override
protected boolean getData(IChildrenUpdate result, Runnable done) {
if (IDebugUIConstants.ID_DEBUG_VIEW.equals(result.getPresentationContext().getId())) {
return filtered_children.getData(result, done);
}
return true;
}
@Override
protected boolean getData(IHasChildrenUpdate result, Runnable done) {
if (IDebugUIConstants.ID_DEBUG_VIEW.equals(result.getPresentationContext().getId())) {
if (!filtered_children.validate(done)) return false;
result.setHasChilren(filtered_children.size() > 0);
}
else {
result.setHasChilren(false);
}
return true;
}
void onContextAdded(IRunControl.RunControlContext context) {
children.onContextAdded(context);
}
void onContextAdded(IMemory.MemoryContext context) {
children.onContextAdded(context);
}
void onAnyContextSuspendedOrChanged() {
for (TCFNodeSymbol s : symbols.values()) s.onMemoryMapChanged();
}
void onAnyContextAddedOrRemoved() {
filtered_children.reset();
}
public void addSymbol(TCFNodeSymbol s) {
assert symbols.get(s.id) == null;
symbols.put(s.id, s);
}
public void removeSymbol(TCFNodeSymbol s) {
assert symbols.get(s.id) == s;
symbols.remove(s.id);
}
public TCFChildren getChildren() {
return children;
}
public TCFChildren getFilteredChildren() {
return filtered_children;
}
}