Queue<RuleGraph> q = new LinkedList<RuleGraph>();
q.add(merge);
int i=1;
while(!q.isEmpty()){
RuleGraph graph = q.poll();
Node root = graph.getRoot();
if (root instanceof BondNode){
Iterator<Entry<Link, RuleGraph>> children = sorted(graph.getChildren()).iterator();
Entry<Link, RuleGraph> entry1 = children.next();
Entry<Link, RuleGraph> entry2 = children.next();
Node a = entry1.getValue().getRoot();
Node b = entry2.getValue().getRoot();
get(rhs,a).add(new Site(a.getName(), entry1.getKey().getDst(), null, ""+i));
get(rhs,b).add(new Site(b.getName(), entry2.getKey().getDst(), null, ""+i));
i++;
q.add(entry1.getValue());
q.add(entry2.getValue());
} else {
ordering.add(root);
String agent = root.getName();
List<Site> sitesL = get(lhs, root);
List<Site> sitesR = get(rhs, root);
addAll(sitesL, root.getSitesL());
addAll(sitesR, root.getSitesR());
for(Entry<Link, RuleGraph> e : sorted(graph.getChildren())){
if (e.getValue() == null){
String siteName = e.getKey().getSrc();
sitesL.add(new Site(agent, siteName, null, "_"));
sitesR.add(new Site(agent, siteName, null, "_"));
} else {