/*
**********************************************************************
* 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