2013-01-02 19:01:50 +00:00
|
|
|
/* Copyright (C) 1998-2013 Free Software Foundation, Inc.
|
1998-04-30 16:57:48 +00:00
|
|
|
This file is part of the GNU C Library.
|
|
|
|
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
|
|
|
|
|
2005-12-07 05:49:17 +00:00
|
|
|
This program is free software; you can redistribute it and/or modify
|
2007-07-16 00:56:07 +00:00
|
|
|
it under the terms of the GNU General Public License as published
|
|
|
|
by the Free Software Foundation; version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
1998-04-30 16:57:48 +00:00
|
|
|
|
2005-12-07 05:49:17 +00:00
|
|
|
This program is distributed in the hope that it will be useful,
|
1998-04-30 16:57:48 +00:00
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2005-12-07 05:49:17 +00:00
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
1998-04-30 16:57:48 +00:00
|
|
|
|
2005-12-07 05:49:17 +00:00
|
|
|
You should have received a copy of the GNU General Public License
|
2012-02-09 23:18:22 +00:00
|
|
|
along with this program; if not, see <http://www.gnu.org/licenses/>. */
|
1998-04-30 16:57:48 +00:00
|
|
|
|
|
|
|
#ifndef _REPERTOIREMAP_H
|
|
|
|
#define _REPERTOIREMAP_H 1
|
|
|
|
|
|
|
|
#include <obstack.h>
|
1999-08-31 07:04:41 +00:00
|
|
|
#include <stdint.h>
|
1998-04-30 16:57:48 +00:00
|
|
|
|
1999-08-31 07:04:41 +00:00
|
|
|
#include "charmap.h"
|
1998-04-30 16:57:48 +00:00
|
|
|
#include "simple-hash.h"
|
|
|
|
|
|
|
|
struct repertoire_t
|
|
|
|
{
|
1999-08-31 07:04:41 +00:00
|
|
|
const char *name;
|
1998-04-30 16:57:48 +00:00
|
|
|
struct obstack mem_pool;
|
|
|
|
hash_table char_table;
|
1999-08-31 07:04:41 +00:00
|
|
|
hash_table reverse_table;
|
|
|
|
hash_table seq_table;
|
1998-04-30 16:57:48 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
1999-08-31 07:04:41 +00:00
|
|
|
/* We need one value to mark the error case. Let's use 0xffffffff.
|
|
|
|
I.e., it is placed in the last page of ISO 10646. For now only the
|
|
|
|
first is used and we have plenty of room. */
|
|
|
|
#define ILLEGAL_CHAR_VALUE ((uint32_t) 0xffffffffu)
|
|
|
|
|
|
|
|
/* Another value is needed to signal that a value is not yet determined. */
|
|
|
|
#define UNINITIALIZED_CHAR_VALUE ((uint32_t) 0xfffffffeu)
|
|
|
|
|
|
|
|
|
1998-04-30 16:57:48 +00:00
|
|
|
/* Prototypes for repertoire map handling functions. */
|
1999-08-31 07:04:41 +00:00
|
|
|
extern struct repertoire_t *repertoire_read (const char *filename);
|
|
|
|
|
2000-01-17 08:39:58 +00:00
|
|
|
/* Report missing repertoire map. */
|
|
|
|
extern void repertoire_complain (const char *name);
|
|
|
|
|
1999-08-31 07:04:41 +00:00
|
|
|
/* Return UCS4 value of character with given NAME. */
|
|
|
|
extern uint32_t repertoire_find_value (const struct repertoire_t *repertoire,
|
|
|
|
const char *name, size_t len);
|
|
|
|
|
|
|
|
/* Return symbol for given UCS4 value. */
|
|
|
|
extern const char *repertoire_find_symbol (const struct repertoire_t *repertoire,
|
|
|
|
uint32_t ucs);
|
|
|
|
|
|
|
|
/* Query the has table to memoize mapping from UCS4 to byte sequences. */
|
|
|
|
extern struct charseq *repertoire_find_seq (const struct repertoire_t *rep,
|
|
|
|
uint32_t ucs);
|
1998-04-30 16:57:48 +00:00
|
|
|
|
|
|
|
#endif /* repertoiremap.h */
|