]> git.ipfire.org Git - thirdparty/gcc.git/blame - intl/intl-compat.c
[C++] Protect call to copy_attributes_to_builtin (PR91505)
[thirdparty/gcc.git] / intl / intl-compat.c
CommitLineData
1e12d536 1/* intl-compat.c - Stub functions to call gettext functions from GNU gettext
2 Library.
3 Copyright (C) 1995, 2000-2003 Software Foundation, Inc.
4
5 This program is free software; you can redistribute it and/or modify it
6 under the terms of the GNU Library General Public License as published
7 by the Free Software Foundation; either version 2, or (at your option)
8 any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Library General Public License for more details.
14
15 You should have received a copy of the GNU Library General Public
16 License along with this program; if not, write to the Free Software
729b154c 17 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301,
1e12d536 18 USA. */
19
20#ifdef HAVE_CONFIG_H
21# include <config.h>
22#endif
23
24#include "gettextP.h"
25
26/* @@ end of prolog @@ */
27
28/* This file redirects the gettext functions (without prefix) to those
29 defined in the included GNU libintl library (with "libintl_" prefix).
30 It is compiled into libintl in order to make the AM_GNU_GETTEXT test
31 of gettext <= 0.11.2 work with the libintl library >= 0.11.3 which
32 has the redirections primarily in the <libintl.h> include file.
33 It is also compiled into libgnuintl so that libgnuintl.so can be used
34 as LD_PRELOADable library on glibc systems, to provide the extra
35 features that the functions in the libc don't have (namely, logging). */
36
37
38#undef gettext
39#undef dgettext
40#undef dcgettext
41#undef ngettext
42#undef dngettext
43#undef dcngettext
44#undef textdomain
45#undef bindtextdomain
46#undef bind_textdomain_codeset
47
48
49/* When building a DLL, we must export some functions. Note that because
50 the functions are only defined for binary backward compatibility, we
51 don't need to use __declspec(dllimport) in any case. */
52#if defined _MSC_VER && BUILDING_DLL
53# define DLL_EXPORTED __declspec(dllexport)
54#else
55# define DLL_EXPORTED
56#endif
57
58
59DLL_EXPORTED
60char *
61gettext (msgid)
62 const char *msgid;
63{
64 return libintl_gettext (msgid);
65}
66
67
68DLL_EXPORTED
69char *
70dgettext (domainname, msgid)
71 const char *domainname;
72 const char *msgid;
73{
74 return libintl_dgettext (domainname, msgid);
75}
76
77
78DLL_EXPORTED
79char *
80dcgettext (domainname, msgid, category)
81 const char *domainname;
82 const char *msgid;
83 int category;
84{
85 return libintl_dcgettext (domainname, msgid, category);
86}
87
88
89DLL_EXPORTED
90char *
91ngettext (msgid1, msgid2, n)
92 const char *msgid1;
93 const char *msgid2;
94 unsigned long int n;
95{
96 return libintl_ngettext (msgid1, msgid2, n);
97}
98
99
100DLL_EXPORTED
101char *
102dngettext (domainname, msgid1, msgid2, n)
103 const char *domainname;
104 const char *msgid1;
105 const char *msgid2;
106 unsigned long int n;
107{
108 return libintl_dngettext (domainname, msgid1, msgid2, n);
109}
110
111
112DLL_EXPORTED
113char *
114dcngettext (domainname, msgid1, msgid2, n, category)
115 const char *domainname;
116 const char *msgid1;
117 const char *msgid2;
118 unsigned long int n;
119 int category;
120{
121 return libintl_dcngettext (domainname, msgid1, msgid2, n, category);
122}
123
124
125DLL_EXPORTED
126char *
127textdomain (domainname)
128 const char *domainname;
129{
130 return libintl_textdomain (domainname);
131}
132
133
134DLL_EXPORTED
135char *
136bindtextdomain (domainname, dirname)
137 const char *domainname;
138 const char *dirname;
139{
140 return libintl_bindtextdomain (domainname, dirname);
141}
142
143
144DLL_EXPORTED
145char *
146bind_textdomain_codeset (domainname, codeset)
147 const char *domainname;
148 const char *codeset;
149{
150 return libintl_bind_textdomain_codeset (domainname, codeset);
151}