aboutsummaryrefslogtreecommitdiff
path: root/iconv
diff options
context:
space:
mode:
Diffstat (limited to 'iconv')
-rw-r--r--iconv/Makefile2
-rw-r--r--iconv/gconv.h127
-rw-r--r--iconv/gconv_builtin.c4
-rw-r--r--iconv/gconv_close.c6
-rw-r--r--iconv/gconv_conf.c4
-rw-r--r--iconv/gconv_db.c10
-rw-r--r--iconv/gconv_dl.c7
-rw-r--r--iconv/gconv_int.h153
-rw-r--r--iconv/gconv_open.c6
-rw-r--r--iconv/iconv.c5
-rw-r--r--iconv/iconv_close.c4
-rw-r--r--iconv/iconv_open.c2
-rw-r--r--iconv/iconv_prog.c2
13 files changed, 196 insertions, 136 deletions
diff --git a/iconv/Makefile b/iconv/Makefile
index f355a266d7..afe48d900a 100644
--- a/iconv/Makefile
+++ b/iconv/Makefile
@@ -25,7 +25,7 @@ headers = iconv.h gconv.h
routines = iconv_open iconv iconv_close \
gconv_open gconv gconv_close gconv_db gconv_conf \
gconv_dl gconv_builtin gconv_simple
-distribute = gconv_builtin.h
+distribute = gconv_builtin.h gconv_int.h
others = iconv_prog
diff --git a/iconv/gconv.h b/iconv/gconv.h
index 139ca0d5c8..76a719785e 100644
--- a/iconv/gconv.h
+++ b/iconv/gconv.h
@@ -1,6 +1,5 @@
/* Copyright (C) 1997, 1998 Free Software Foundation, Inc.
This file is part of the GNU C Library.
- Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
@@ -17,14 +16,16 @@
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
+/* This header provides no interface for a user to the internals of
+ the gconv implementation in the libc. Therefore there is no use
+ for these definitions beside for writing additional gconv modules. */
+
#ifndef _GCONV_H
#define _GCONV_H 1
#include <features.h>
-#include <sys/types.h>
-#include <regex.h>
-
-__BEGIN_DECLS
+#define __need_size_t
+#include <stddef.h>
/* ISO 10646 value used to signal invalid value. */
#define UNKNOWN_10646_CHAR ((wchar_t) 0xfffd)
@@ -47,18 +48,6 @@ enum
};
-/* Structure for alias definition. Simply to strings. */
-struct gconv_alias
-{
- __const char *fromname;
- __const char *toname;
-};
-
-
-/* Default size of intermediate buffers. */
-#define GCONV_DEFAULT_BUFSIZE 8160
-
-
/* Forward declarations. */
struct gconv_step;
struct gconv_step_data;
@@ -101,6 +90,7 @@ struct gconv_step_data
void *data; /* Pointer to step-local data. */
};
+
/* Combine conversion step description with data. */
typedef struct gconv_info
{
@@ -109,107 +99,4 @@ typedef struct gconv_info
struct gconv_step_data *data;
} *gconv_t;
-
-/* Description for an available conversion module. */
-struct gconv_module
-{
- __const char *from_pattern;
- __const char *from_constpfx;
- size_t from_constpfx_len;
- __const regex_t *from_regex;
-
- __const char *to_string;
-
- int cost;
-
- __const char *module_name;
-};
-
-
-/* Global variables. */
-
-/* Database of alias names. */
-extern void *__gconv_alias_db;
-
-/* Array with available modules. */
-extern size_t __gconv_nmodules;
-extern struct gconv_module **__gconv_modules_db;
-
-
-/* Return in *HANDLE decriptor for transformation from FROMSET to TOSET. */
-extern int __gconv_open __P ((__const char *__toset, __const char *__fromset,
- gconv_t *__handle));
-
-/* Free resources associated with transformation descriptor CD. */
-extern int __gconv_close __P ((gconv_t cd));
-
-/* Transform at most *INBYTESLEFT bytes from buffer starting at *INBUF
- according to rules described by CD and place up to *OUTBYTESLEFT
- bytes in buffer starting at *OUTBUF. Return number of written
- characters in *CONVERTED if this pointer is not null. */
-extern int __gconv __P ((gconv_t __cd,
- __const char **__inbuf, size_t *__inbytesleft,
- char **__outbuf, size_t *__outbytesleft,
- size_t *__converted));
-
-/* Return in *HANDLE a pointer to an array with *NSTEPS elements describing
- the single steps necessary for transformation from FROMSET to TOSET. */
-extern int __gconv_find_transform __P ((__const char *__toset,
- __const char *__fromset,
- struct gconv_step **__handle,
- size_t *__nsteps));
-
-/* Read all the configuration data and cache it. */
-extern void __gconv_read_conf __P ((void));
-
-/* Comparison function to search alias. */
-extern int __gconv_alias_compare __P ((__const void *__p1,
- __const void *__p2));
-
-/* Clear reference to transformation step implementations which might
- cause the code to be unloaded. */
-extern int __gconv_close_transform __P ((struct gconv_step *__steps,
- size_t __nsteps));
-
-
-/* Find in the shared object associated with HANDLE for a function with
- name NAME. Return function pointer or NULL. */
-extern void *__gconv_find_func __P ((void *__handle, __const char *__name));
-
-/* Load shared object named by NAME. If already loaded increment reference
- count. */
-extern void *__gconv_find_shlib __P ((__const char *__name));
-
-/* Release shared object. If no further reference is available unload
- the object. */
-extern int __gconv_release_shlib __P ((void *__handle));
-
-/* Fill STEP with information about builtin module with NAME. */
-extern void __gconv_get_builtin_trans __P ((__const char *__name,
- struct gconv_step *__step));
-
-
-
-/* Builtin transformations. */
-#ifdef _LIBC
-# define __BUILTIN_TRANS(Name) \
- extern int Name __P ((struct gconv_step *__step, \
- struct gconv_step_data *__data, __const char *__inbuf,\
- size_t *__inlen, size_t *__written, int __do_flush))
-
-__BUILTIN_TRANS (__gconv_transform_dummy);
-__BUILTIN_TRANS (__gconv_transform_ucs4_utf8);
-__BUILTIN_TRANS (__gconv_transform_utf8_ucs4);
-__BUILTIN_TRANS (__gconv_transform_ucs2_ucs4);
-__BUILTIN_TRANS (__gconv_transform_ucs4_ucs2);
-# undef __BUITLIN_TRANS
-
-extern int __gconv_transform_init_rstate __P ((struct gconv_step *__step,
- struct gconv_step_data *__data));
-extern void __gconv_transform_end_rstate __P ((struct gconv_step_data *__data));
-
-#endif
-
-__END_DECLS
-
#endif /* gconv.h */
diff --git a/iconv/gconv_builtin.c b/iconv/gconv_builtin.c
index 786a3c1e26..d913579ecc 100644
--- a/iconv/gconv_builtin.c
+++ b/iconv/gconv_builtin.c
@@ -18,9 +18,10 @@
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
-#include <gconv.h>
#include <string.h>
+#include <gconv_int.h>
+
#include <assert.h>
@@ -48,6 +49,7 @@ static struct builtin_map
void
+internal_function
__gconv_get_builtin_trans (const char *name, struct gconv_step *step)
{
size_t cnt;
diff --git a/iconv/gconv_close.c b/iconv/gconv_close.c
index 912fa26d13..b6d5fbcd9d 100644
--- a/iconv/gconv_close.c
+++ b/iconv/gconv_close.c
@@ -1,5 +1,5 @@
/* Release any resource associated with given conversion descriptor.
- Copyright (C) 1997 Free Software Foundation, Inc.
+ Copyright (C) 1997, 1998 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
@@ -18,11 +18,13 @@
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
-#include <gconv.h>
#include <stdlib.h>
+#include <gconv_int.h>
+
int
+internal_function
__gconv_close (gconv_t cd)
{
struct gconv_step *srunp;
diff --git a/iconv/gconv_conf.c b/iconv/gconv_conf.c
index 0c5ceef9e2..c448a160d2 100644
--- a/iconv/gconv_conf.c
+++ b/iconv/gconv_conf.c
@@ -20,7 +20,6 @@
#include <ctype.h>
#include <errno.h>
-#include <gconv.h>
#include <search.h>
#include <stdio.h>
#include <stdlib.h>
@@ -28,6 +27,8 @@
#include <unistd.h>
#include <sys/param.h>
+#include <gconv_int.h>
+
/* This is the default path where we look for module lists. */
static const char default_gconv_path[] = GCONV_PATH;
@@ -369,6 +370,7 @@ read_conf_file (const char *filename, const char *directory, size_t dir_len,
/* Read all configuration files found in the user-specified and the default
path. */
void
+internal_function
__gconv_read_conf (void)
{
const char *user_path = __secure_getenv ("GCONV_PATH");
diff --git a/iconv/gconv_db.c b/iconv/gconv_db.c
index b1320ac7e8..5a3932c601 100644
--- a/iconv/gconv_db.c
+++ b/iconv/gconv_db.c
@@ -1,5 +1,5 @@
/* Provide access to the collection of available transformation modules.
- Copyright (C) 1997 Free Software Foundation, Inc.
+ Copyright (C) 1997, 1998 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
@@ -18,12 +18,13 @@
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
-#include <gconv.h>
#include <search.h>
#include <stdlib.h>
#include <string.h>
#include <bits/libc-lock.h>
+#include <gconv_int.h>
+
/* Simple data structure for alias mapping. We have two names, `from'
and `to'. */
@@ -93,6 +94,7 @@ static void *known_derivations;
/* Look up whether given transformation was already requested before. */
static int
+internal_function
derivation_lookup (const char *fromset, const char *toset,
struct gconv_step **handle, size_t *nsteps)
{
@@ -114,6 +116,7 @@ derivation_lookup (const char *fromset, const char *toset,
/* Add new derivation to list of known ones. */
static void
+internal_function
add_derivation (const char *fromset, const char *toset,
struct gconv_step *handle, size_t nsteps)
{
@@ -142,6 +145,7 @@ add_derivation (const char *fromset, const char *toset,
}
static void
+internal_function
free_derivation (void *p)
{
struct known_derivation *deriv = (struct known_derivation *) p;
@@ -479,6 +483,7 @@ find_derivation (const char *toset, const char *toset_expand,
int
+internal_function
__gconv_find_transform (const char *toset, const char *fromset,
struct gconv_step **handle, size_t *nsteps)
{
@@ -523,6 +528,7 @@ __gconv_find_transform (const char *toset, const char *fromset,
/* Release the entries of the modules list. */
int
+internal_function
__gconv_close_transform (struct gconv_step *steps, size_t nsteps)
{
int result = GCONV_OK;
diff --git a/iconv/gconv_dl.c b/iconv/gconv_dl.c
index a9a616663e..2a7cc92a3d 100644
--- a/iconv/gconv_dl.c
+++ b/iconv/gconv_dl.c
@@ -19,7 +19,6 @@
Boston, MA 02111-1307, USA. */
#include <dlfcn.h>
-#include <gconv.h>
#include <inttypes.h>
#include <search.h>
#include <stdlib.h>
@@ -28,6 +27,8 @@
#include <elf/ldsodefs.h>
#include <sys/param.h>
+#include <gconv_int.h>
+
/* This is a tuning parameter. If a transformation module is not used
anymore it gets not immediately unloaded. Instead we wait a certain
@@ -112,6 +113,7 @@ struct get_sym_args
};
static void
+internal_function
get_sym (void *a)
{
struct get_sym_args *args = (struct get_sym_args *) a;
@@ -123,6 +125,7 @@ get_sym (void *a)
void *
+internal_function
__gconv_find_func (void *handle, const char *name)
{
struct get_sym_args args;
@@ -139,6 +142,7 @@ __gconv_find_func (void *handle, const char *name)
/* Open the gconv database if necessary. A non-negative return value
means success. */
void *
+internal_function
__gconv_find_shlib (const char *name)
{
void *result = NULL;
@@ -234,6 +238,7 @@ do_release_shlib (const void *nodep, VISIT value, int level)
/* Notify system that a shared object is not longer needed. */
int
+internal_function
__gconv_release_shlib (void *handle)
{
/* Acquire the lock. */
diff --git a/iconv/gconv_int.h b/iconv/gconv_int.h
new file mode 100644
index 0000000000..5261284d7f
--- /dev/null
+++ b/iconv/gconv_int.h
@@ -0,0 +1,153 @@
+/* Copyright (C) 1997, 1998 Free Software Foundation, Inc.
+ This file is part of the GNU C Library.
+ Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
+
+ The GNU C Library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Library General Public License as
+ published by the Free Software Foundation; either version 2 of the
+ License, or (at your option) any later version.
+
+ The GNU C Library 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
+ Library General Public License for more details.
+
+ You should have received a copy of the GNU Library General Public
+ License along with the GNU C Library; see the file COPYING.LIB. If not,
+ write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ Boston, MA 02111-1307, USA. */
+
+#ifndef _GCONV_INT_H
+#define _GCONV_INT_H 1
+
+#include "gconv.h"
+#include <regex.h>
+
+__BEGIN_DECLS
+
+
+/* Structure for alias definition. Simply to strings. */
+struct gconv_alias
+{
+ __const char *fromname;
+ __const char *toname;
+};
+
+
+/* Default size of intermediate buffers. */
+#define GCONV_DEFAULT_BUFSIZE 8160
+
+
+/* Description for an available conversion module. */
+struct gconv_module
+{
+ __const char *from_pattern;
+ __const char *from_constpfx;
+ size_t from_constpfx_len;
+ __const regex_t *from_regex;
+
+ __const char *to_string;
+
+ int cost;
+
+ __const char *module_name;
+};
+
+
+/* Global variables. */
+
+/* Database of alias names. */
+extern void *__gconv_alias_db;
+
+/* Array with available modules. */
+extern size_t __gconv_nmodules;
+extern struct gconv_module **__gconv_modules_db;
+
+
+/* Return in *HANDLE decriptor for transformation from FROMSET to TOSET. */
+extern int __gconv_open __P ((__const char *__toset, __const char *__fromset,
+ gconv_t *__handle))
+ internal_function;
+
+/* Free resources associated with transformation descriptor CD. */
+extern int __gconv_close __P ((gconv_t cd))
+ internal_function;
+
+/* Transform at most *INBYTESLEFT bytes from buffer starting at *INBUF
+ according to rules described by CD and place up to *OUTBYTESLEFT
+ bytes in buffer starting at *OUTBUF. Return number of written
+ characters in *CONVERTED if this pointer is not null. */
+extern int __gconv __P ((gconv_t __cd,
+ __const char **__inbuf, size_t *__inbytesleft,
+ char **__outbuf, size_t *__outbytesleft,
+ size_t *__converted))
+ internal_function;
+
+/* Return in *HANDLE a pointer to an array with *NSTEPS elements describing
+ the single steps necessary for transformation from FROMSET to TOSET. */
+extern int __gconv_find_transform __P ((__const char *__toset,
+ __const char *__fromset,
+ struct gconv_step **__handle,
+ size_t *__nsteps))
+ internal_function;
+
+/* Read all the configuration data and cache it. */
+extern void __gconv_read_conf __P ((void))
+ internal_function;
+
+/* Comparison function to search alias. */
+extern int __gconv_alias_compare __P ((__const void *__p1,
+ __const void *__p2));
+
+/* Clear reference to transformation step implementations which might
+ cause the code to be unloaded. */
+extern int __gconv_close_transform __P ((struct gconv_step *__steps,
+ size_t __nsteps))
+ internal_function;
+
+
+/* Find in the shared object associated with HANDLE for a function with
+ name NAME. Return function pointer or NULL. */
+extern void *__gconv_find_func __P ((void *__handle, __const char *__name))
+ internal_function;
+
+/* Load shared object named by NAME. If already loaded increment reference
+ count. */
+extern void *__gconv_find_shlib __P ((__const char *__name))
+ internal_function;
+
+/* Release shared object. If no further reference is available unload
+ the object. */
+extern int __gconv_release_shlib __P ((void *__handle))
+ internal_function;
+
+/* Fill STEP with information about builtin module with NAME. */
+extern void __gconv_get_builtin_trans __P ((__const char *__name,
+ struct gconv_step *__step))
+ internal_function;
+
+
+
+/* Builtin transformations. */
+#ifdef _LIBC
+# define __BUILTIN_TRANS(Name) \
+ extern int Name __P ((struct gconv_step *__step, \
+ struct gconv_step_data *__data, __const char *__inbuf,\
+ size_t *__inlen, size_t *__written, int __do_flush))
+
+__BUILTIN_TRANS (__gconv_transform_dummy);
+__BUILTIN_TRANS (__gconv_transform_ucs4_utf8);
+__BUILTIN_TRANS (__gconv_transform_utf8_ucs4);
+__BUILTIN_TRANS (__gconv_transform_ucs2_ucs4);
+__BUILTIN_TRANS (__gconv_transform_ucs4_ucs2);
+# undef __BUITLIN_TRANS
+
+extern int __gconv_transform_init_rstate __P ((struct gconv_step *__step,
+ struct gconv_step_data *__data));
+extern void __gconv_transform_end_rstate __P ((struct gconv_step_data *__data));
+
+#endif
+
+__END_DECLS
+
+#endif /* gconv_int.h */
diff --git a/iconv/gconv_open.c b/iconv/gconv_open.c
index 343cb70773..ea7b3653af 100644
--- a/iconv/gconv_open.c
+++ b/iconv/gconv_open.c
@@ -1,5 +1,5 @@
/* Find matching transformation algorithms and initialize steps.
- Copyright (C) 1997 Free Software Foundation, Inc.
+ Copyright (C) 1997, 1998 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
@@ -19,11 +19,13 @@
Boston, MA 02111-1307, USA. */
#include <errno.h>
-#include <gconv.h>
#include <stdlib.h>
+#include <gconv_int.h>
+
int
+internal_function
__gconv_open (const char *toset, const char *fromset, gconv_t *handle)
{
struct gconv_step *steps;
diff --git a/iconv/iconv.c b/iconv/iconv.c
index 8804e851b6..fc0ed41b50 100644
--- a/iconv/iconv.c
+++ b/iconv/iconv.c
@@ -1,6 +1,6 @@
/* Convert characters in input buffer using conversion descriptor to
output buffer.
- Copyright (C) 1997 Free Software Foundation, Inc.
+ Copyright (C) 1997, 1998 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
@@ -21,7 +21,8 @@
#include <errno.h>
#include <iconv.h>
-#include <gconv.h>
+
+#include <gconv_int.h>
#include <assert.h>
diff --git a/iconv/iconv_close.c b/iconv/iconv_close.c
index ccd9d5f3ad..d3974c5799 100644
--- a/iconv/iconv_close.c
+++ b/iconv/iconv_close.c
@@ -1,5 +1,5 @@
/* Release any resource associated with given conversion descriptor.
- Copyright (C) 1997 Free Software Foundation, Inc.
+ Copyright (C) 1997, 1998 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1997.
@@ -21,7 +21,7 @@
#include <errno.h>
#include <iconv.h>
-#include <gconv.h>
+#include <gconv_int.h>
int
diff --git a/iconv/iconv_open.c b/iconv/iconv_open.c
index d178362ca7..cad8be6be7 100644
--- a/iconv/iconv_open.c
+++ b/iconv/iconv_open.c
@@ -24,7 +24,7 @@
#include <stdlib.h>
#include <string.h>
-#include <gconv.h>
+#include <gconv_int.h>
static inline void
diff --git a/iconv/iconv_prog.c b/iconv/iconv_prog.c
index 6b34d3460b..f26b7159e4 100644
--- a/iconv/iconv_prog.c
+++ b/iconv/iconv_prog.c
@@ -23,7 +23,6 @@
#include <errno.h>
#include <error.h>
#include <fcntl.h>
-#include <gconv.h>
#include <iconv.h>
#include <locale.h>
#include <search.h>
@@ -32,6 +31,7 @@
#include <string.h>
#include <unistd.h>
#include <sys/mman.h>
+#include <gconv_int.h>
/* Get libc version number. */
#include "../version.h"