Java tutorial
/* * Copyright (c) 2013 The Interedition Development Group. * * This file is part of CollateX. * * CollateX is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * CollateX 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with CollateX. If not, see <http://www.gnu.org/licenses/>. */ package eu.interedition.collatex.neo4j; import com.google.common.base.Function; import com.google.common.base.Preconditions; import com.google.common.collect.Iterables; import com.google.common.collect.Iterators; import eu.interedition.collatex.VariantGraph; import org.neo4j.graphdb.Node; import org.neo4j.graphdb.Relationship; import com.google.common.base.Objects; import javax.annotation.Nullable; import java.util.Iterator; import java.util.Set; /** * @author <a href="http://gregor.middell.net/" title="Homepage">Gregor Middell</a> */ public class Neo4jVariantGraphTransposition implements VariantGraph.Transposition { private final Neo4jVariantGraph graph; private final Node node; public Neo4jVariantGraphTransposition(Neo4jVariantGraph graph, Node node) { this.graph = graph; this.node = node; } public Neo4jVariantGraphTransposition(Neo4jVariantGraph graph, Set<VariantGraph.Vertex> vertices) { this(graph, graph.database.createNode()); for (Neo4jVariantGraphVertex vertex : Iterables.filter(vertices, Neo4jVariantGraphVertex.class)) { this.node.createRelationshipTo(vertex.node, Neo4jGraphRelationships.TRANSPOSITION); } } @Override public Iterator<VariantGraph.Vertex> iterator() { return Iterators.transform(node.getRelationships(Neo4jGraphRelationships.TRANSPOSITION).iterator(), new Function<Relationship, VariantGraph.Vertex>() { @Override public VariantGraph.Vertex apply(@Nullable Relationship relationship) { return graph.vertexWrapper.apply(relationship.getEndNode()); } }); } @Override public void delete() { for (Relationship r : node.getRelationships(Neo4jGraphRelationships.TRANSPOSITION)) { r.delete(); } node.delete(); } @Override public int hashCode() { return node.hashCode(); } @Override public boolean equals(Object obj) { if (obj != null && obj instanceof Neo4jVariantGraphTransposition) { return node.equals(((Neo4jVariantGraphTransposition) obj).node); } return super.equals(obj); } @Override public String toString() { return Objects.toStringHelper(this).addValue(node).toString(); } }