|
|
| |
WordKey(3) |
FreeBSD Library Functions Manual |
WordKey(3) |
WordKey - inverted index key.
#include <WordKey.h>
#define WORD_KEY_DOCID 1
#define WORD_KEY_LOCATION 2
WordList* words = ...;
WordKey key = words->Key("word 100 20");
WordKey searchKey;
words->Dict()->SerialExists("dog", searchKey.Get(WORD_KEY_WORD));
searchKey.Set(WORD_KEY_LOCATION, 5);
WordCursor* cursor = words->Key(searchKey);
Describes the key used to store a entry in the inverted index. Each field in the
key has a bit in the set member that says if it is set or not. This bit
allows to say that a particular field is undefined regardless of the
actual value stored. The methods IsDefined, SetDefined and
Undefined are used to manipulate the defined status of a field.
The Pack and Unpack methods are used to convert to and from the
disk storage representation of the key.
Although constructors may be used, the prefered way to create a
WordKey object is by using the WordContext::Key method.
The following constants are defined:
- WORD_KEY_WORD
- the index of the word identifier with the key for Set and Get
methods.
- WORD_KEY_VALUE_INVALID
- a value that is invalid for any field of the key.
The ASCII description is a string with fields separated by tabs or white space.
Example: 200 <UNDEF> 1 4 2
Field 1: The word identifier or <UNDEF> if not defined
Field 2 to the end: numerical value of the field or <UNDEF> if
not defined
- WordKey(WordContext* ncontext)
- Constructor. Build an empty key. The ncontext argument must be a
pointer to a valid WordContext object.
- WordKey(WordContext* ncontext, const String& desc)
- Constructor. Initialize from an ASCII description of a key. See ASCII
FORMAT section. The ncontext argument must be a pointer to a
valid WordContext object.
- void Clear()
- Reset to empty key.
- inline int NFields() const
- Convenience functions to access the total number of fields in a key (see
WordKeyInfo(3) ).
- inline WordKeyNum MaxValue(int position)
- Convenience functions to access the maximum possible value for field at
position. in a key (see WordKeyInfo(3) ).
- inline WordContext* GetContext()
- Return a pointer to the WordContext object used to create this
instance.
- inline const WordContext* GetContext() const
- Return a pointer to the WordContext object used to create this instance as
a const.
- inline WordKeyNum Get(int position) const
- Return value of numerical field at position as const.
- inline WordKeyNum& Get(int position)
- Return value of numerical field at position.
- inline const WordKeyNum & operator[] (int position) const
- Return value of numerical field at position as const.
- inline WordKeyNum & operator[] (int position)
- Return value of numerical field at position.
- inline void Set(int position, WordKeyNum val)
- Set value of numerical field at position to val.
- int IsDefined(int position) const
- Returns true if field at position is defined , false
otherwise.
- void SetDefined(int position)
- Value in field position becomes defined. A bit is set in the
bit field describing the defined/undefined state of the value and the
actual value of the field is not modified.
- void Undefined(int position)
- Value in field position becomes undefined. A bit is set in
the bit field describing the defined/undefined state of the value and the
actual value of the field is not modified.
- int Set(const String& bufferin)
- Set the whole structure from ASCII string in bufferin. See ASCII
FORMAT section. Return OK if successfull, NOTOK otherwise.
- int Get(String& bufferout) const
- Convert the whole structure to an ASCII string description in
bufferout. See ASCII FORMAT section. Return OK if
successfull, NOTOK otherwise.
- String Get() const
- Convert the whole structure to an ASCII string description and return it.
See ASCII FORMAT section.
- int Unpack(const char* string, int length)
- Set structure from disk storage format as found in string buffer or
length length. Return OK if successfull, NOTOK otherwise.
- inline int Unpack(const String& data)
- Set structure from disk storage format as found in data string.
Return OK if successfull, NOTOK otherwise.
- int Pack(String& data) const
- Convert object into disk storage format as found in and place the result
in data string. Return OK if successfull, NOTOK otherwise.
- int Merge(const WordKey& other)
- Copy each defined field from other into the object, if the
corresponding field of the object is not defined. Return OK if
successfull, NOTOK otherwise.
- int PrefixOnly()
- Undefine all fields found after the first undefined field. The resulting
key has a set of defined fields followed by undefined fields. Returns
NOTOK if the word is not defined because the resulting key would be empty
and this is considered an error. Returns OK on success.
- int SetToFollowing(int position = WORD_FOLLOWING_MAX)
- Implement ++ on a key.
It behaves like arithmetic but follows these rules:
position
- 1
If position is not specified it is equivalent to NFields() - 1. It returns
OK if successfull, NOTOK if position out of range or
WORD_FOLLOWING_ATEND if the maximum possible value was reached.
- int Filled() const
- Return true if all the fields are defined , false otherwise.
- int Empty() const
- Return true if no fields are defined , false otherwise.
- int Equal(const WordKey& other) const
- Return true if the object and other are equal. Only fields defined
in both keys are compared.
- int ExactEqual(const WordKey& other) const
- Return true if the object and other are equal. All fields are
compared. If a field is defined in object and not defined in the
object, the key are not considered equal.
- int Cmp(const WordKey& other) const
- Compare object and other as in strcmp. Undefined fields are
ignored. Returns a positive number if object is greater than
other , zero if they are equal, a negative number if object
is lower than other.
- int PackEqual(const WordKey& other) const
- Return true if the object and other are equal. The packed string
are compared. An undefined numerical field will be 0 and therefore
undistinguishable from a defined field whose value is 0.
- int Outbound(int position, int increment)
- Return true if adding increment in field at position makes
it overflow or underflow, false if it fits.
- int Overflow(int position, int increment)
- Return true if adding positive increment to field at
position makes it overflow, false if it fits.
- int Underflow(int position, int increment)
- Return true if subtracting positive increment to field at
position makes it underflow, false if it fits.
- int Prefix() const
- Return OK if the key may be used as a prefix for search. In other words
return OK if the fields set in the key are all contiguous, starting from
the first field. Otherwise returns NOTOK
- static int Compare(WordContext* context, const String& a, const
String& b)
- Compare a and b in the Berkeley DB fashion. a and
b are packed keys. The semantics of the returned int is as of
strcmp and is driven by the key description found in WordKeyInfo.
Returns a positive number if a is greater than b , zero if
they are equal, a negative number if a is lower than b.
- static int Compare(WordContext* context, const unsigned char *a, int
a_length, const unsigned char *b, int b_length)
- Compare a and b in the Berkeley DB fashion. a and
b are packed keys. The semantics of the returned int is as of
strcmp and is driven by the key description found in WordKeyInfo.
Returns a positive number if a is greater than b , zero if
they are equal, a negative number if a is lower than b.
- int Diff(const WordKey& other, int& position, int&
lower)
- Compare object defined fields with other key defined fields only,
ignore fields that are not defined in object or other. Return 1 if
different 0 if equal. If different, position is set to the field
number that differ, lower is set to 1 if Get( position ) is
lower than other.Get( position ) otherwise lower is set to 0.
- int Write(FILE* f) const
- Print object in ASCII form on f (uses Get method). See
ASCII FORMAT section.
- void Print() const
- Print object in ASCII form on stdout (uses Get method). See
ASCII FORMAT section.
Loic Dachary loic@gnu.org
The Ht://Dig group http://dev.htdig.org/
htdb_dump(1), htdb_stat(1), htdb_load(1), mifluzdump(1), mifluzload(1),
mifluzsearch(1), mifluzdict(1), WordContext(3), WordList(3), WordDict(3),
WordListOne(3), WordKeyInfo(3), WordType(3), WordDBInfo(3), WordRecordInfo(3),
WordRecord(3), WordReference(3), WordCursor(3), WordCursorOne(3),
WordMonitor(3), Configuration(3), mifluz(3)
Visit the GSP FreeBSD Man Page Interface. Output converted with ManDoc. |