/* Copyright 2009 by the Oxford University Computing Laboratory
This file is part of HermiT.
HermiT is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
HermiT is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with HermiT. If not, see <http://www.gnu.org/licenses/>.
*/
package org.semanticweb.HermiT.debugger.commands;
import java.io.PrintWriter;
import org.semanticweb.HermiT.debugger.Debugger;
import org.semanticweb.HermiT.tableau.Node;
public class ShowSubtreeCommand extends AbstractCommand {
public ShowSubtreeCommand(Debugger debugger) {
super(debugger);
}
public String getCommandName() {
return "showSubtree";
}
public String[] getDescription() {
return new String[] {
"nodeID","shows the subtree rooted at nodeID"
};
}
public void printHelp(PrintWriter writer) {
writer.println("usage: showSubtree nodeID");
writer.println(" Shows the subtree of the model rooted at the given node.");
writer.println(" black: root node");
writer.println(" darkgrey: named node");
writer.println(" green: blockable node (not blocked)");
writer.println(" light gray: inactive node");
writer.println(" cyan: blocked node");
writer.println(" red: node with unprocessed existentials");
writer.println(" magenta: description graph node");
writer.println(" blue: concrete/data value node");
}
public void execute(String[] args) {
if (args.length<2) {
m_debugger.getOutput().println("Node ID is missing.");
return;
}
int nodeID;
try {
nodeID=Integer.parseInt(args[1]);
}
catch (NumberFormatException e) {
m_debugger.getOutput().println("Invalid ID of the first node.");
return;
}
Node subtreeRoot=m_debugger.getTableau().getNode(nodeID);
if (subtreeRoot==null) {
m_debugger.getOutput().println("Node with ID '"+nodeID+"' not found.");
return;
}
new SubtreeViewer(m_debugger,subtreeRoot);
}
}