2016-06-15 18:58:17 +00:00
|
|
|
// Copyright (C) 2016 and later: Unicode, Inc. and others.
|
|
|
|
// License & terms of use: http://www.unicode.org/copyright.html
|
2010-12-31 18:21:36 +00:00
|
|
|
/*
|
|
|
|
*******************************************************************************
|
2016-05-31 21:45:07 +00:00
|
|
|
* Copyright (C) 2010-2012, International Business Machines
|
|
|
|
* Corporation and others. All Rights Reserved.
|
2010-12-31 18:21:36 +00:00
|
|
|
*******************************************************************************
|
|
|
|
* file name: udicttrie.h
|
|
|
|
* encoding: US-ASCII
|
|
|
|
* tab size: 8 (not used)
|
|
|
|
* indentation:4
|
|
|
|
*
|
|
|
|
* created on: 2010dec17
|
|
|
|
* created by: Markus W. Scherer
|
|
|
|
*/
|
|
|
|
|
2011-01-05 21:05:47 +00:00
|
|
|
#ifndef __USTRINGTRIE_H__
|
|
|
|
#define __USTRINGTRIE_H__
|
2010-12-31 18:21:36 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* \file
|
|
|
|
* \brief C API: Helper definitions for dictionary trie APIs.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "unicode/utypes.h"
|
|
|
|
|
2011-08-01 02:20:46 +00:00
|
|
|
|
2010-12-31 18:21:36 +00:00
|
|
|
/**
|
2011-01-05 21:05:47 +00:00
|
|
|
* Return values for BytesTrie::next(), UCharsTrie::next() and similar methods.
|
|
|
|
* @see USTRINGTRIE_MATCHES
|
|
|
|
* @see USTRINGTRIE_HAS_VALUE
|
|
|
|
* @see USTRINGTRIE_HAS_NEXT
|
2012-02-20 04:28:17 +00:00
|
|
|
* @stable ICU 4.8
|
2010-12-31 18:21:36 +00:00
|
|
|
*/
|
2011-01-05 21:05:47 +00:00
|
|
|
enum UStringTrieResult {
|
2010-12-31 18:21:36 +00:00
|
|
|
/**
|
|
|
|
* The input unit(s) did not continue a matching string.
|
2011-01-27 21:41:03 +00:00
|
|
|
* Once current()/next() return USTRINGTRIE_NO_MATCH,
|
|
|
|
* all further calls to current()/next() will also return USTRINGTRIE_NO_MATCH,
|
|
|
|
* until the trie is reset to its original state or to a saved state.
|
2012-02-20 04:28:17 +00:00
|
|
|
* @stable ICU 4.8
|
2010-12-31 18:21:36 +00:00
|
|
|
*/
|
2011-01-05 21:05:47 +00:00
|
|
|
USTRINGTRIE_NO_MATCH,
|
2010-12-31 18:21:36 +00:00
|
|
|
/**
|
|
|
|
* The input unit(s) continued a matching string
|
|
|
|
* but there is no value for the string so far.
|
|
|
|
* (It is a prefix of a longer string.)
|
2012-02-20 04:28:17 +00:00
|
|
|
* @stable ICU 4.8
|
2010-12-31 18:21:36 +00:00
|
|
|
*/
|
2011-01-05 21:05:47 +00:00
|
|
|
USTRINGTRIE_NO_VALUE,
|
2010-12-31 18:21:36 +00:00
|
|
|
/**
|
|
|
|
* The input unit(s) continued a matching string
|
|
|
|
* and there is a value for the string so far.
|
|
|
|
* This value will be returned by getValue().
|
|
|
|
* No further input byte/unit can continue a matching string.
|
2012-02-20 04:28:17 +00:00
|
|
|
* @stable ICU 4.8
|
2010-12-31 18:21:36 +00:00
|
|
|
*/
|
2011-01-05 21:05:47 +00:00
|
|
|
USTRINGTRIE_FINAL_VALUE,
|
2010-12-31 18:21:36 +00:00
|
|
|
/**
|
|
|
|
* The input unit(s) continued a matching string
|
|
|
|
* and there is a value for the string so far.
|
|
|
|
* This value will be returned by getValue().
|
|
|
|
* Another input byte/unit can continue a matching string.
|
2012-02-20 04:28:17 +00:00
|
|
|
* @stable ICU 4.8
|
2010-12-31 18:21:36 +00:00
|
|
|
*/
|
2011-01-05 21:05:47 +00:00
|
|
|
USTRINGTRIE_INTERMEDIATE_VALUE
|
2010-12-31 18:21:36 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2011-01-05 21:05:47 +00:00
|
|
|
* Same as (result!=USTRINGTRIE_NO_MATCH).
|
|
|
|
* @param result A result from BytesTrie::first(), UCharsTrie::next() etc.
|
2010-12-31 18:21:36 +00:00
|
|
|
* @return true if the input bytes/units so far are part of a matching string/byte sequence.
|
2012-02-20 04:28:17 +00:00
|
|
|
* @stable ICU 4.8
|
2010-12-31 18:21:36 +00:00
|
|
|
*/
|
2011-01-05 21:05:47 +00:00
|
|
|
#define USTRINGTRIE_MATCHES(result) ((result)!=USTRINGTRIE_NO_MATCH)
|
2010-12-31 18:21:36 +00:00
|
|
|
|
|
|
|
/**
|
2011-01-05 21:05:47 +00:00
|
|
|
* Equivalent to (result==USTRINGTRIE_INTERMEDIATE_VALUE || result==USTRINGTRIE_FINAL_VALUE) but
|
2010-12-31 18:21:36 +00:00
|
|
|
* this macro evaluates result exactly once.
|
2011-01-05 21:05:47 +00:00
|
|
|
* @param result A result from BytesTrie::first(), UCharsTrie::next() etc.
|
2010-12-31 18:21:36 +00:00
|
|
|
* @return true if there is a value for the input bytes/units so far.
|
2011-01-05 21:05:47 +00:00
|
|
|
* @see BytesTrie::getValue
|
|
|
|
* @see UCharsTrie::getValue
|
2012-02-20 04:28:17 +00:00
|
|
|
* @stable ICU 4.8
|
2010-12-31 18:21:36 +00:00
|
|
|
*/
|
2011-01-05 21:05:47 +00:00
|
|
|
#define USTRINGTRIE_HAS_VALUE(result) ((result)>=USTRINGTRIE_FINAL_VALUE)
|
2010-12-31 18:21:36 +00:00
|
|
|
|
|
|
|
/**
|
2011-01-05 21:05:47 +00:00
|
|
|
* Equivalent to (result==USTRINGTRIE_NO_VALUE || result==USTRINGTRIE_INTERMEDIATE_VALUE) but
|
2010-12-31 18:21:36 +00:00
|
|
|
* this macro evaluates result exactly once.
|
2011-01-05 21:05:47 +00:00
|
|
|
* @param result A result from BytesTrie::first(), UCharsTrie::next() etc.
|
2010-12-31 18:21:36 +00:00
|
|
|
* @return true if another input byte/unit can continue a matching string.
|
2012-02-20 04:28:17 +00:00
|
|
|
* @stable ICU 4.8
|
2010-12-31 18:21:36 +00:00
|
|
|
*/
|
2011-01-05 21:05:47 +00:00
|
|
|
#define USTRINGTRIE_HAS_NEXT(result) ((result)&1)
|
2010-12-31 18:21:36 +00:00
|
|
|
|
2011-01-05 21:05:47 +00:00
|
|
|
#endif /* __USTRINGTRIE_H__ */
|