mirror of
https://https.git.savannah.gnu.org/git/findutils.git
synced 2026-01-26 15:39:06 +00:00
Run 'make update-copyright'. * lib/regexprops.c (copying): Update the year number manually. * tests/sample-test: Adjust to use the single most recent year. * All other files: Update copyright years via the above make run.
69 lines
2.5 KiB
C
69 lines
2.5 KiB
C
/* locatedb.h -- declarations for the locate database
|
|
Copyright (C) 1994-2026 Free Software Foundation, Inc.
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef INC_LOCATEDB_H
|
|
# define INC_LOCATEDB_H 1
|
|
|
|
/* The magic string at the start of a locate database, to make sure
|
|
it's in the right format. The 02 is the database format version number.
|
|
This string has the same format as a database entry, but you can't
|
|
concatenate databases even if you remove it, since the differential count
|
|
in the first entry of the second database will be wrong. */
|
|
# define LOCATEDB_MAGIC "\0LOCATE02"
|
|
|
|
/* Common-prefix length differences in the ranges
|
|
0..127, -127..-1 (0x00..0x7f, 0x81..0xff) fit into one byte.
|
|
This value (which is -128) indicates that the difference is
|
|
too large to fit into one byte, and a two-byte integer follows. */
|
|
# define LOCATEDB_ESCAPE 0x80
|
|
# define LOCATEDB_ONEBYTE_MAX (127)
|
|
# define LOCATEDB_ONEBYTE_MIN (-127)
|
|
|
|
|
|
/* If it is ever possible to try to encode LOCATEDB_MAGIC as a
|
|
* single-byte offset, then an unfortunate length of common prefix
|
|
* will produce a spurious escape character, desynchronising the data
|
|
* stream. We use a compile-time check in the preprocessor to prevent
|
|
* this.
|
|
*/
|
|
# if LOCATEDB_ESCAPE <= LOCATEDB_ONEBYTE_MAX
|
|
# error "You have a bad combination of LOCATEDB_ESCAPE and LOCATEDB_ONEBYTE_MAX, see above"
|
|
# endif
|
|
|
|
/* These are used for old, bigram-encoded databases: */
|
|
|
|
/* Means the differential count follows in a 2-byte int instead. */
|
|
# define LOCATEDB_OLD_ESCAPE 30
|
|
|
|
/* Offset added to differential counts to encode them as positive numbers. */
|
|
# define LOCATEDB_OLD_OFFSET 14
|
|
|
|
typedef enum
|
|
{
|
|
GetwordEndianStateInitial = 0,
|
|
GetwordEndianStateNative = 1,
|
|
GetwordEndianStateSwab = 2
|
|
} GetwordEndianState;
|
|
|
|
int getword (FILE *fp, const char *filename,
|
|
size_t maxvalue,
|
|
GetwordEndianState *endian_state_flag);
|
|
|
|
# define SLOCATE_DB_MAGIC_LEN 2
|
|
|
|
#endif /* !INC_LOCATEDB_H */
|