package edu.stanford.nlp.trees.tregex.tsurgeon; import java.util.List; import edu.stanford.nlp.trees.Tree; import edu.stanford.nlp.trees.tregex.TregexMatcher; import edu.stanford.nlp.util.ArrayUtils; import edu.stanford.nlp.util.CollectionUtils; import edu.stanford.nlp.util.Function; /** * @author Roger Levy (rog@stanford.edu) */ class ReplaceNode extends TsurgeonPattern { public ReplaceNode(TsurgeonPattern oldNode, TsurgeonPattern ... newNodes) { super("replace", ArrayUtils.concatenate(new TsurgeonPattern[] { oldNode }, newNodes)); } public ReplaceNode(TsurgeonPattern oldNode, List<AuxiliaryTree> trees) { this(oldNode, CollectionUtils.transformAsList(trees, convertAuxiliaryToHold).toArray(new TsurgeonPattern[trees.size()])); } private static final Function<AuxiliaryTree, HoldTreeNode> convertAuxiliaryToHold = new Function<AuxiliaryTree, HoldTreeNode>() { public HoldTreeNode apply(AuxiliaryTree t) { return new HoldTreeNode(t); } }; @Override public Tree evaluate(Tree t, TregexMatcher m) { Tree oldNode = children[0].evaluate(t,m); if (oldNode==t) { if (children.length > 2) { throw new TsurgeonRuntimeException("Attempted to replace a root node with more than one node, unable to proceed"); } return children[1].evaluate(t, m); } Tree parent = oldNode.parent(t); int i = parent.objectIndexOf(oldNode); parent.removeChild(i); for (int j = 1; j < children.length; ++j) { Tree newNode = children[j].evaluate(t, m); parent.insertDtr(newNode.deepCopy(), i + j - 1); } return t; } }