All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.neo4j.graphdb.Label Maven / Gradle / Ivy

There is a newer version: 5.25.1
Show newest version
/*
 * Copyright (c) "Neo4j"
 * Neo4j Sweden AB [http://neo4j.com]
 *
 * This file is part of Neo4j.
 *
 * Neo4j 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.
 *
 * This program 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 this program.  If not, see .
 */
package org.neo4j.graphdb;

import org.neo4j.annotations.api.PublicApi;

/**
 * A label is a grouping facility for {@link Node} where all nodes having a label
 * are part of the same group. Labels on nodes are optional and any node can
 * have an arbitrary number of labels attached to it.
 *
 * Objects of classes implementing this interface can be used as label
 * representations in your code.
 *
 * It's very important to note that a label is uniquely identified
 * by its name, not by any particular instance that implements this interface.
 * This means that the proper way to check if two labels are equal
 * is by invoking equals() on their {@link #name() names}, NOT by
 * using Java's identity operator (==) or equals() on
 * the {@link Label} instances. A consequence of this is that you can NOT
 * use {@link Label} instances in hashed collections such as
 * {@link java.util.HashMap HashMap} and {@link java.util.HashSet HashSet}.
 * 

* However, you usually want to check whether a specific node * instance has a certain label. That is best achieved with the * {@link Node#hasLabel(Label)} method. * * For labels that your application know up front you should specify using an enum, * and since the name is accessed using the {@link #name()} method it fits nicely. * * public enum MyLabels implements Label * { * PERSON, * RESTAURANT; * } * * * For labels that your application don't know up front you can make use of * {@link #label(String)}, or your own implementation of this interface, * as it's just the name that matters. * * @see Node */ @PublicApi public interface Label { /** * Returns the name of the label. The name uniquely identifies a * label, i.e. two different Label instances with different object identifiers * (and possibly even different classes) are semantically equivalent if they * have {@link String#equals(Object) equal} names. * * @return the name of the label */ String name(); /** * Instantiates a new {@linkplain Label} with the given name. * * @param name the name of the label * @return a {@link Label} instance for the given name * @throws IllegalArgumentException if name is {@code null} */ static Label label( String name ) { if ( name == null ) { throw new IllegalArgumentException( "A label cannot have a null name" ); } return new Label() { @Override public String name() { return name; } @Override public String toString() { return name; } @Override public boolean equals( Object that ) { if ( this == that ) { return true; } if ( that == null || that.getClass() != getClass() ) { return false; } return name.equals( ((Label) that).name() ); } @Override public int hashCode() { return name.hashCode(); } }; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy