/* ********************************************************************** * Copyright (C) 1999, International Business Machines Corporation and others. All Rights Reserved. ********************************************************************** * Date Name Description * 11/17/99 aliu Creation. ********************************************************************** */ #ifndef UNIFLTLG_H #define UNIFLTLG_H #include "unicode/utypes.h" U_NAMESPACE_BEGIN class UnicodeFilter; /** * UnicodeFilterLogic provides logical operators on * {@link UnicodeFilter} objects. This class cannot be instantiated; * it consists only of static methods. The static methods return * filter objects that perform logical inversion (not), * intersection (and), or union (or) of the given * filter objects. * * If a UnicodeFilter* f is passed in, where f == NULL, then that * is treated as a filter that contains all Unicode characters. * Therefore, createNot(NULL) returns a filter that contains no * Unicode characters. Likewise, createAnd(g, NULL) returns g->clone(), * and createAnd(NULL, NULL) returns NULL. */ class U_I18N_API UnicodeFilterLogic { public: /** * Returns a UnicodeFilter that implements the inverse of * the given filter. * @param f may be NULL * @result always non-NULL */ static UnicodeFilter* createNot(const UnicodeFilter* f); /** * Returns a UnicodeFilter that implements a short * circuit AND of the result of the two given filters. That is, * if f.contains() is false, then g.contains() * is not called, and contains() returns false. * @param f may be NULL * @param g may be NULL * @result will be NULL if and only if f == g == NULL */ static UnicodeFilter* createAnd(const UnicodeFilter* f, const UnicodeFilter* g); /** * Returns a UnicodeFilter that implements a short * circuit AND of the result of the two given filters. That is, * if f.contains() is false, then g.contains() * is not called, and contains() returns false. * @param f may be NULL; this argument is adopted * @param g may be NULL; this argument is adopted * @result will be NULL if and only if f == g == NULL */ static UnicodeFilter* createAdoptingAnd(UnicodeFilter* adoptedF, UnicodeFilter* adoptedG); /** * Returns a UnicodeFilter that implements a short * circuit OR of the result of the two given filters. That is, if * f.contains() is true, then g.contains() is * not called, and contains() returns true. * @param f may be NULL * @param g may be NULL * @result will be NULL if and only if f == g == NULL */ static UnicodeFilter* createOr(const UnicodeFilter* f, const UnicodeFilter* g); private: // Disallow instantiation UnicodeFilterLogic(); }; inline UnicodeFilterLogic::UnicodeFilterLogic() {} U_NAMESPACE_END #endif