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

com.googlecode.cqengine.attribute.Attribute Maven / Gradle / Ivy

Go to download

Collection Query Engine: NoSQL indexing and query engine for Java collections with ultra-low latency

There is a newer version: 3.6.0
Show newest version
/**
 * Copyright 2012-2015 Niall Gallagher
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.googlecode.cqengine.attribute;

import com.googlecode.cqengine.query.option.QueryOptions;

/**
 * @author Niall Gallagher
 */
public interface Attribute {

    /**
     * Returns the type of the object which contains the attribute.
     * @return the type of the object which contains the attribute
     */
    Class getObjectType();

    /**
     * Returns the type of the attribute.
     * @return the type of the attribute
     */
    Class getAttributeType();

    /**
     * Returns the name of the attribute, as supplied to the constructor.
     * 

* @return the name of the attribute, as supplied to the constructor */ String getAttributeName(); /** * Returns the values belonging to the attribute in the given object. *

* If the attribute is a {@link SimpleAttribute}, the list returned will contain a single value for the attribute. * If the attribute is a {@link MultiValueAttribute}, the list returned will contain any number of values for the * attribute. *

* @param object The object from which the values of the attribute are required * @param queryOptions Optional parameters supplied by the application along with the operation which is causing * this attribute to be invoked (either a query, or an update to the collection) * @return The values for the attribute in the given object */ Iterable getValues(O object, QueryOptions queryOptions); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy