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

com.hp.autonomy.aci.content.fieldtext.FieldText Maven / Gradle / Ivy

/*
 * Copyright 2009-2015 Hewlett-Packard Development Company, L.P.
 * Licensed under the MIT License (the "License"); you may not use this file except in compliance with the License.
 */
package com.hp.autonomy.aci.content.fieldtext;

/**
 * Interface for representing IDOL FieldText expressions. These expressions are made up of specifiers combined with AND,
 * OR, XOR, NOT and brackets. e.g.
 *
 * 
 *    MATCH{xls,doc}:EXT+AND+EQUAL{4}:TAG
 * 
* * The {@link FieldTextBuilder} class can be used to combine FieldText specifiers into more complex expressions. * However, it is often unnecessary to explicitly instantiate a {@link FieldTextBuilder} as the {@code FieldText} * interface forces all specifiers to provide support for combining expressions. *

* The {@link Specifier} class provides both a generic object for representing a specifier as well as being a suitable * base class for other specifiers. *

* Example: * *

 *    FieldText ft = new MATCH("EXT", "xls", "doc").AND(new EQUAL("TAG", 4));
 *    String fieldText = ft.toString();
 * 
* */ public interface FieldText { /** * Combines two FieldText expressions ({@code this} and {@code fieldText}) using the AND operator. This should * return a {@code FieldText} object equivalent to: * *
(this) AND (fieldText)
* * Calling this method might alter the {@code FieldText} object on which it is called. * * @param fieldText A fieldtext expression or specifier. * @return The combined expression. */ FieldText AND(FieldText fieldText); /** * Combines two FieldText expressions ({@code this} and {@code fieldText}) using the OR operator. This should return * a {@code FieldText} object equivalent to: * *
(this) OR (fieldText)
* * Calling this method might alter the {@code FieldText} object on which it is called. * * @param fieldText A fieldtext expression or specifier. * @return The combined expression. */ FieldText OR(FieldText fieldText); /** * Applies a NOT operator to this FieldText expression. This should return a {@code FieldText} object equivalent to: * *
NOT (this)
* * Calling this method might alter the {@code FieldText} object on which it is called. * * @return The negated expression. */ FieldText NOT(); /** * Combines two FieldText expressions ({@code this} and {@code fieldText}) using the XOR operator. This should * return a {@code FieldText} object equivalent to: * *
(this) XOR (fieldText)
* * Calling this method might alter the {@code FieldText} object on which it is called. * * @param fieldText A fieldtext expression or specifier. * @return The combined expression. */ FieldText XOR(FieldText fieldText); // Currently IDOL doesn't support chaining BEFOREs/AFTERs, which makes them tricky to implement well. Until someone // requests them we'll leave them out for now // // FieldText BEFORE(FieldText fieldText); // FieldText AFTER(FieldText fieldText); /* * Combines two FieldText specifiers ({@code this} and {@code fieldText}) using the WHEN operator. Both specifiers * must have a size of 1 or an exception will be thrown. The returned {@code FieldText} object will be equivalent * to: * *
this WHEN fieldText
* * Calling this method might alter the {@code FieldText} object on which it is called. * * @param fieldText A fieldtext expression or specifier. * @return The combined expression. * @throws IllegalStateException If {@code this} does not have a size of 1 * @throws IllegalArgumentException If {@code fieldText} does not have a size of 1 */ FieldText WHEN(FieldText fieldText); /* * Combines two FieldText expressions (this and fieldText) * using the WHENn operator. This should return a FieldText object * equivalent to: * *
(this) WHENn (fieldText)
* * Calling this method might alter the FieldText object on which it * is called. * * @param depth The n in WHENn * @param fieldText A fieldtext expression or specifier. * @return The combined expression. * @throws IllegalStateException If {@code this} does not have a size of 1 * @throws IllegalArgumentException If {@code fieldText} does not have a size of 1 */ FieldText WHEN(int depth, FieldText fieldText); /** * The size is defined as the number of specifiers in the FieldText expression. An individual specifier would have a * size of 1. * * @return The size of the expression. */ int size(); /** * A {@code FieldText} object is empty if its size is zero. * * @return {@code true} if and only if size is 0. */ boolean isEmpty(); /** * Should return the {@code String} representation of the FieldText expression, exactly as it should be sent to * IDOL. * * @return The {@code String} representation. */ @Override String toString(); /** * {@code FieldText} objects are considered equal if their {@code String} representations are equal. * * @param obj An object to test for equality. * @return {@code true} if and only if {@code obj} is a {@code FieldText} object with the same {@code toString()} * value as this object. */ @Override boolean equals(Object obj); /** * The hashcode should be that of the {@code String} representation. * * @return The hashcode of the {@code String} representation. */ @Override int hashCode(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy