document error/progname interaction
[gnulib.git] / doc / gnulib.texi
1 \input texinfo   @c -*-texinfo-*-
2 @comment $Id: gnulib.texi,v 1.31 2007-01-03 18:51:20 karl Exp $
3 @comment %**start of header
4 @setfilename gnulib.info
5 @settitle GNU Gnulib
6 @syncodeindex fn cp
7 @syncodeindex pg cp
8 @comment %**end of header
9
10 @set UPDATED $Date: 2007-01-03 18:51:20 $
11
12 @copying
13 This manual is for GNU Gnulib (updated @value{UPDATED}),
14 which is a library of common routines intended to be shared at the
15 source level.
16
17 Copyright @copyright{} 2004, 2005, 2006, 2007 Free Software Foundation, Inc.
18
19 Permission is granted to copy, distribute and/or modify this document
20 under the terms of the GNU Free Documentation License, Version 1.1 or
21 any later version published by the Free Software Foundation; with no
22 Invariant Sections, with no Front-Cover Texts, and with no Back-Cover
23 Texts.  A copy of the license is included in the section entitled
24 ``GNU Free Documentation License.''
25 @end copying
26
27 @dircategory Software development
28 @direntry
29 * Gnulib: (gnulib).             Source files to share among distributions.
30 @end direntry
31
32 @titlepage
33 @title GNU Gnulib
34 @subtitle updated @value{UPDATED}
35 @author @email{bug-gnulib@@gnu.org}
36 @page
37 @vskip 0pt plus 1filll
38 @insertcopying
39 @end titlepage
40
41 @contents
42
43 @ifnottex
44 @node Top
45 @top GNU Gnulib
46
47 @insertcopying
48 @end ifnottex
49
50 @menu
51 * Introduction::
52 * Invoking gnulib-tool::
53 * Miscellaneous Notes::
54 * Particular Modules::          Documentation of Individual Modules
55 * Copying This Manual::
56 * Index::
57 @end menu
58
59 @node Introduction
60 @chapter Introduction
61
62 Gnulib is a source code library. It provides basic functionalities to
63 programs and libraries.  Currently (as of October 2006) more than 30
64 packages make use of Gnulib.
65
66 Resources:
67
68 @itemize
69 @item Gnulib is hosted at Savannah:
70       @url{http://savannah.gnu.org/projects/gnulib}.  Get the sources
71       through CVS from there.
72 @item The Gnulib home page:
73       @url{http://www.gnu.org/software/gnulib/}.
74 @end itemize
75
76 @menu
77 * Library vs. Reusable Code::
78 * Portability and Application Code::
79 * Modules::
80 * Various Kinds of Modules::
81 * Collaborative Development::
82 * Copyright::
83 * Steady Development::
84 * Openness::
85 @end menu
86
87 @include gnulib-intro.texi
88
89
90 @include gnulib-tool.texi
91
92
93 @node Miscellaneous Notes
94 @chapter Miscellaneous Notes
95
96 @menu
97 * Comments::
98 * Header files::
99 * Out of memory handling::
100 * Library version handling::
101 * Windows sockets::
102 * Libtool and Windows::
103 * License Texinfo sources::
104 @end menu
105
106
107 @node Comments
108 @section Comments
109
110 @cindex comments describing functions
111 @cindex describing functions, locating
112 Where to put comments describing functions: Because of risk of
113 divergence, we prefer to keep most function describing comments in
114 only one place: just above the actual function definition.  Some
115 people prefer to put that documentation in the .h file.  In any case,
116 it should appear in just one place unless you can ensure that the
117 multiple copies will always remain identical.
118
119
120 @node Header files
121 @section Header files
122
123 @cindex double inclusion of header files
124 @cindex header file include protection
125 It is a tradition to use CPP tricks to avoid parsing the same header
126 file more than once, which might cause warnings.  The trick is to wrap
127 the content of the header file (say, @file{foo.h}) in a block, as in:
128
129 @example
130 #ifndef FOO_H
131 # define FOO_H
132 ...
133 body of header file goes here
134 ...
135 #endif /* FOO_H */
136 @end example
137
138 Whether to use @code{FOO_H} or @code{_FOO_H} is a matter of taste and
139 style.  The C89 and C99 standards reserve all identifiers that begin with an
140 underscore and either an uppercase letter or another underscore, for
141 any use.  Thus, in theory, an application might not safely assume that
142 @code{_FOO_H} has not already been defined by a library.  On the other
143 hand, using @code{FOO_H} will likely lead the higher risk of
144 collisions with other symbols (e.g., @code{KEY_H}, @code{XK_H}, @code{BPF_H},
145 which are CPP macro constants, or @code{COFF_LONG_H}, which is a CPP
146 macro function).  Your preference may depend on whether you consider
147 the header file under discussion as part of the application (which has
148 its own namespace for CPP symbols) or a supporting library (that
149 shouldn't interfere with the application's CPP symbol namespace).
150
151 @cindex C++ header files
152 @cindex Header files and C++
153 Adapting C header files for use in C++ applications can use another
154 CPP trick, as in:
155
156 @example
157 # ifdef __cplusplus
158 extern "C"
159 @{
160 # endif
161 ...
162 body of header file goes here
163 ...
164 # ifdef __cplusplus
165 @}
166 # endif
167 @end example
168
169 The idea here is that @code{__cplusplus} is defined only by C++
170 implementations, which will wrap the header file in an @samp{extern "C"}
171 block.  Again, whether to use this trick is a matter of taste and
172 style.  While the above can be seen as harmless, it could be argued
173 that the header file is written in C, and any C++ application using it
174 should explicitly use the @samp{extern "C"} block itself.  Your
175 preference might depend on whether you consider the API exported by
176 your header file as something available for C programs only, or for C
177 and C++ programs alike.
178
179 @subheading Include ordering
180
181 When writing a gnulib module, or even in general, a good way to order
182 the @samp{#include} directives is the following.
183
184 @itemize
185 @item First comes the #include "..." specifying the module being implemented.
186 @item Then come all the #include <...> of system or system-replacement headers,
187 in arbitrary order.
188 @item Then come all the #include "..." of gnulib and private headers, in
189 arbitrary order.
190 @end itemize
191
192
193 @node Out of memory handling
194 @section Out of memory handling
195
196 @cindex Out of Memory handling
197 @cindex Memory allocation failure
198 The GSS API does not have a standard error code for the out of memory
199 error condition.  Instead of adding a non-standard error code, this
200 library has chosen to adopt a different strategy.  Out of memory
201 handling happens in rare situations, but performing the out of memory
202 error handling after almost all API function invocations pollute your
203 source code and might make it harder to spot more serious problems.
204 The strategy chosen improve code readability and robustness.
205
206 @cindex Aborting execution
207 For most applications, aborting the application with an error message
208 when the out of memory situation occur is the best that can be wished
209 for.  This is how the library behaves by default.
210
211 @vindex xalloc_fail_func
212 However, we realize that some applications may not want to have the
213 GSS library abort execution in any situation.  The GSS library support
214 a hook to let the application regain control and perform its own
215 cleanups when an out of memory situation has occurred.  The application
216 can define a function (having a @code{void} prototype, i.e., no return
217 value and no parameters) and set the library variable
218 @code{xalloc_fail_func} to that function.  The variable should be
219 declared as follows.
220
221 @example
222 extern void (*xalloc_fail_func) (void);
223 @end example
224
225 The GSS library will invoke this function if an out of memory error
226 occurs.  Note that after this the GSS library is in an undefined
227 state, so you must unload or restart the application to continue call
228 GSS library functions.  The hook is only intended to allow the
229 application to log the situation in a special way.  Of course, care
230 must be taken to not allocate more memory, as that will likely also
231 fail.
232
233
234 @node Library version handling
235 @section Library version handling
236
237 The module @samp{check-version} can be useful when your gnulib
238 application is a system library.  You will typically wrap the call to
239 the @code{check_version} function through a library API, your library
240 header file may contain:
241
242 @example
243 #define STRINGPREP_VERSION "0.5.18"
244 ...
245   extern const char *stringprep_check_version (const char *req_version);
246 @end example
247
248 To avoid ELF symbol collisions with other libraries that use the
249 @samp{check-version} module, add to @file{config.h} through a
250 AC_DEFINE something like:
251
252 @example
253 AC_DEFINE(check_version, stringprep_check_version,
254           [Rename check_version.])
255 @end example
256
257 The @code{stringprep_check_version} function will thus be implemented
258 by the @code{check_version} module.
259
260 There are two uses of the interface.  The first is a way to provide
261 for applications to find out the version number of the library it
262 uses.  The application may contain diagnostic code such as:
263
264 @example
265   printf ("Stringprep version: header %s library %s",
266           STRINGPREP_VERSION,
267           stringprep_check_version (NULL));
268 @end example
269
270 Separating the library and header file version can be useful when
271 searching for version mismatch related problems.
272
273 The second uses is as a rudimentary test of proper library version, by
274 making sure the application get a library version that is the same, or
275 newer, than the header file used when building the application.  This
276 doesn't catch all problems, libraries may change backwards incompatibly
277 in later versions, but enable applications to require a certain
278 minimum version before it may proceed.
279
280 Typical uses look like:
281
282 @example
283        /* Check version of libgcrypt. */
284        if (!gcry_check_version (GCRYPT_VERSION))
285          die ("version mismatch\n");
286 @end example
287
288
289 @node Windows sockets
290 @section Windows sockets
291
292 There are several issues when building applications that should work
293 under Windows.  The most problematic part is for applications that use
294 sockets.
295
296 Hopefully, we can add helpful notes to this section that will help you
297 port your application to Windows using gnulib.
298
299 @subsection Getaddrinfo and WINVER
300
301 This was written for the getaddrinfo module, but may be applicable to
302 other functions too.
303
304 The getaddrinfo function exists in ws2tcpip.h and -lws2_32 on Windows
305 XP.  The function declaration is present if @code{WINVER >= 0x0501}.
306 Windows 2000 does not have getaddrinfo in its @file{WS2_32.dll}.
307
308 Thus, if you want to assume Windows XP or later, you can add
309 AC_DEFINE(WINVER, 0x0501) to avoid compiling to (partial) getaddrinfo
310 implementation.
311
312 If you want to support Windows 2000, don't do anything, but be aware
313 that gnulib will use its own (partial) getaddrinfo implementation even
314 on Windows XP.  Currently the code does not attempt to determine if
315 the getaddrinfo function is available during runtime.
316
317 Todo: Make getaddrinfo.c open the WS2_32.DLL and check for the
318 getaddrinfo symbol and use it if present, otherwise fall back to our
319 own implementation.
320
321
322 @node Libtool and Windows
323 @section Libtool and Windows
324
325 If you want it to be possible to cross-compile your program to MinGW
326 and you use Libtool, you need to put:
327
328 @example
329 AC_LIBTOOL_WIN32_DLL
330 @end example
331
332 in your @file{configure.ac}.  This sets the correct names for the
333 @code{OBJDUMP}, @code{DLLTOOL}, and @code{AS} tools for the build.
334
335 If you are building a library, you will also need to pass
336 @code{-no-undefined} to make sure Libtool produces a DLL for your
337 library.  From a @file{Makefile.am}:
338
339 @example
340 libgsasl_la_LDFLAGS += -no-undefined
341 @end example
342
343
344 @node License Texinfo sources
345 @section License Texinfo sources
346
347 Gnulib provides copies of the GNU GPL, GNU LGPL, and GNU FDL licenses
348 in Texinfo form.  (The master location is
349 @url{http://www.gnu.org/licenses/}).  These Texinfo documents have
350 various node names and structures built into them; for your manual,
351 you might like to change these.  It's ok to do this, and a convenient
352 way to do so is to use a context diff and the @option{--local-dir}
353 option to @command{gnulib-tool}.
354
355 Of course the license texts themselves should not be changed at all.
356
357
358 @node Particular Modules
359 @chapter Particular Modules
360
361 @menu
362 * Quoting::
363 * ctime::
364 * error and progname::
365 * gcd::
366 * inet_ntoa::
367 * Regular expressions::
368 @end menu
369
370 @include quote.texi
371 @include error.texi
372 @include ctime.texi
373 @include gcd.texi
374 @include inet_ntoa.texi
375
376 @node Regular expressions
377 @section Regular expressions
378
379 Gnulib supports many different types of regular expressions; although
380 the underlying features are the same or identical, the syntax used
381 varies.  The descriptions given here for the different types are
382 generated automatically.
383
384 @include regexprops-generic.texi
385
386
387 @node Copying This Manual
388 @appendix Copying This Manual
389
390 @menu
391 * GNU Free Documentation License::  License for copying this manual.
392 @end menu
393
394 @include fdl.texi
395
396
397 @node Index
398 @unnumbered Index
399
400 @printindex cp
401
402 @bye