Thu Jan 25 21:10:39 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>

* db/Makefile (subdir-dirs): Renamed from dbdirs.

	* Makerules (distinfo-vars): Add subdir-dirs.

	* MakeTAGS: Remove vpath directives.
	(all-dirs): Prepend $(subdir-dirs).
	(all-sources, all-headers): Use wildcard to find sources.
Thu Jan 25 21:10:39 1996  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de>

	* db/Makefile (subdir-dirs): Renamed from dbdirs.

	* Makerules (distinfo-vars): Add subdir-dirs.

	* MakeTAGS: Remove vpath directives.
	(all-dirs): Prepend $(subdir-dirs).
	(all-sources, all-headers): Use wildcard to find sources.

Mon Jan 29 10:44:38 1996  Roland McGrath  <roland@churchy.gnu.ai.mit.edu>

	* malloc/Makefile (CFLAGS-vm-limit.c, CFLAGS-ralloc.c): New
	variables.

	* mach/msgserver.c: Declare DEMUX arg with prototype.
This commit is contained in:
Roland McGrath 1996-01-29 16:05:21 +00:00
parent dc825f85f4
commit 19c3f20809
8 changed files with 103 additions and 99 deletions

View File

@ -1,3 +1,20 @@
Thu Jan 25 21:10:39 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* db/Makefile (subdir-dirs): Renamed from dbdirs.
* Makerules (distinfo-vars): Add subdir-dirs.
* MakeTAGS: Remove vpath directives.
(all-dirs): Prepend $(subdir-dirs).
(all-sources, all-headers): Use wildcard to find sources.
Mon Jan 29 10:44:38 1996 Roland McGrath <roland@churchy.gnu.ai.mit.edu>
* malloc/Makefile (CFLAGS-vm-limit.c, CFLAGS-ralloc.c): New
variables.
* mach/msgserver.c: Declare DEMUX arg with prototype.
Sun Jan 28 17:25:38 1996 Roland McGrath <roland@churchy.gnu.ai.mit.edu> Sun Jan 28 17:25:38 1996 Roland McGrath <roland@churchy.gnu.ai.mit.edu>
* setjmp/setjmp.h (jmp_buf): Give a tag in the struct defn, to * setjmp/setjmp.h (jmp_buf): Give a tag in the struct defn, to

View File

@ -49,16 +49,12 @@ endif
# Find all sysdep dirs there are, but putting the ones # Find all sysdep dirs there are, but putting the ones
# we are configured to use first and preserving their order. # we are configured to use first and preserving their order.
all-dirs := $(objdir) \ all-dirs := $(subdir-dirs) \
$(objdir) \
$(sysdep-dirs) \ $(sysdep-dirs) \
$(source_dirs) \ $(source_dirs) \
$(filter-out $(sysdep-dirs),$(sysdep_dirs)) $(filter-out $(sysdep-dirs),$(sysdep_dirs))
vpath %.h $(all-dirs)
vpath %.c $(all-dirs)
vpath %.S $(all-dirs)
vpath %.s $(all-dirs)
# Find all the subdirs there are, but putting the ones # Find all the subdirs there are, but putting the ones
# we are configured to use first and preserving their order. # we are configured to use first and preserving their order.
ifndef subdir ifndef subdir
@ -83,15 +79,17 @@ all-dist := $(filter-out %.h %.c %.s %.S,$(all-dist))
# All different versions of $(sources), preserving the configured sysdep # All different versions of $(sources), preserving the configured sysdep
# directory order. # directory order.
all-sources = $(shell find . $(all-dirs) -maxdepth 1 \( -name fnord \ all-sources = $(wildcard $(sort $(sources) $(sources:.c=.S) \
$(foreach file,$(sort $(sources) $(sources:.c=.S) \ $(sources:.c=.s))) \
$(sources:.c=.s)),\ $(foreach dir,$(all-dirs),\
-o -name $(file)) \ $(wildcard \
\) -print) $(addprefix $(dir)/,\
$(sort $(sources) $(sources:.c=.S) \
$(sources:.c=.s)))))
all-headers = $(shell find . $(all-dirs) -maxdepth 1 \( -name fnord \ all-headers = $(wildcard $(headers)) \
$(foreach file,$(headers),-o -name $(file)) \ $(foreach dir,$(all-dirs),\
\) -print) $(wildcard $(addprefix $(dir)/,$(headers))))
tags_sources := $(strip $(tags_sources)) tags_sources := $(strip $(tags_sources))

View File

@ -681,7 +681,7 @@ distinfo: Makefile $(..)Makerules
define distinfo-vars define distinfo-vars
rm -f $@.new rm -f $@.new
$(foreach var,subdir sources elided-routines headers distribute \ $(foreach var,subdir subdir-dirs sources elided-routines headers distribute \
dont_distribute generated others tests, dont_distribute generated others tests,
echo >> $@.new '$(var) := $($(var))') echo >> $@.new '$(var) := $($(var))')
echo >> $@.new 'sources := $$(sources) $$(addsuffix .c,$$(elided-routines))' echo >> $@.new 'sources := $$(sources) $$(addsuffix .c,$$(elided-routines))'

View File

@ -5,8 +5,8 @@
subdir = db subdir = db
dbdirs = btree db hash mpool recno subdir-dirs = btree db hash mpool recno
vpath %.c $(dbdirs) vpath %.c $(subdir-dirs)
routines := bt_close bt_conv bt_debug bt_delete bt_get bt_open bt_overflow \ routines := bt_close bt_conv bt_debug bt_delete bt_get bt_open bt_overflow \
bt_page bt_put bt_search bt_seq bt_split bt_utils \ bt_page bt_put bt_search bt_seq bt_split bt_utils \

View File

@ -21,35 +21,38 @@ Cambridge, MA 02139, USA. */
93/12/06 to use stack space instead of malloc, and to handle 93/12/06 to use stack space instead of malloc, and to handle
large messages with MACH_RCV_LARGE. */ large messages with MACH_RCV_LARGE. */
/* /*
* Mach Operating System * Mach Operating System
* Copyright (c) 1991,1990 Carnegie Mellon University * Copyright (c) 1991,1990 Carnegie Mellon University
* All Rights Reserved. * All Rights Reserved.
* *
* Permission to use, copy, modify and distribute this software and its * Permission to use, copy, modify and distribute this software and its
* documentation is hereby granted, provided that both the copyright * documentation is hereby granted, provided that both the copyright
* notice and this permission notice appear in all copies of the * notice and this permission notice appear in all copies of the
* software, derivative works or modified versions, and any portions * software, derivative works or modified versions, and any portions
* thereof, and that both notices appear in supporting documentation. * thereof, and that both notices appear in supporting documentation.
* *
* CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
* CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR
* ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
* *
* Carnegie Mellon requests users of this software to return to * Carnegie Mellon requests users of this software to return to
* *
* Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
* School of Computer Science * School of Computer Science
* Carnegie Mellon University * Carnegie Mellon University
* Pittsburgh PA 15213-3890 * Pittsburgh PA 15213-3890
* *
* any improvements or extensions that they make and grant Carnegie Mellon * any improvements or extensions that they make and grant Carnegie Mellon
* the rights to redistribute these changes. * the rights to redistribute these changes.
*/ */
/* /*
* HISTORY * HISTORY
* $Log$ * $Log$
* Revision 1.3 1995/01/21 15:00:57 roland * Revision 1.4 1996/01/29 15:44:23 roland
* Declare DEMUX arg with prototype.
*
* Revision 1.3 1995/01/21 15:00:57 roland
* Converted to use weak aliases with macros from libc-symbols.h. * Converted to use weak aliases with macros from libc-symbols.h.
* *
* Revision 1.2 1994/10/10 07:20:14 roland * Revision 1.2 1994/10/10 07:20:14 roland
@ -60,14 +63,14 @@ Cambridge, MA 02139, USA. */
* *
* Revision 2.4 91/05/14 17:53:22 mrt * Revision 2.4 91/05/14 17:53:22 mrt
* Correcting copyright * Correcting copyright
* *
* Revision 2.3 91/02/14 14:17:47 mrt * Revision 2.3 91/02/14 14:17:47 mrt
* Added new Mach copyright * Added new Mach copyright
* [91/02/13 12:44:20 mrt] * [91/02/13 12:44:20 mrt]
* *
* Revision 2.2 90/08/06 17:23:58 rpd * Revision 2.2 90/08/06 17:23:58 rpd
* Created. * Created.
* *
*/ */
@ -183,7 +186,7 @@ weak_alias (__mach_msg_server_timeout, mach_msg_server_timeout)
mach_msg_return_t mach_msg_return_t
__mach_msg_server (demux, max_size, rcv_name) __mach_msg_server (demux, max_size, rcv_name)
boolean_t (*demux) (); boolean_t (*demux) (mach_msg_header_t *in, mach_msg_header_t *out);
mach_msg_size_t max_size; mach_msg_size_t max_size;
mach_port_t rcv_name; mach_port_t rcv_name;
{ {

View File

@ -8,7 +8,7 @@ representing a communications channel to a file, device, or process.
@menu @menu
* Streams:: About the data type representing a stream. * Streams:: About the data type representing a stream.
* Standard Streams:: Streams to the standard input and output * Standard Streams:: Streams to the standard input and output
devices are created for you. devices are created for you.
* Opening Streams:: How to create a stream to talk to a file. * Opening Streams:: How to create a stream to talk to a file.
* Closing Streams:: Close a stream when you are finished with it. * Closing Streams:: Close a stream when you are finished with it.
@ -28,7 +28,7 @@ representing a communications channel to a file, device, or process.
* Portable Positioning:: Random access on peculiar ANSI C systems. * Portable Positioning:: Random access on peculiar ANSI C systems.
* Stream Buffering:: How to control buffering of streams. * Stream Buffering:: How to control buffering of streams.
* Other Kinds of Streams:: Streams that do not necessarily correspond * Other Kinds of Streams:: Streams that do not necessarily correspond
to an open file. to an open file.
@end menu @end menu
@node Streams @node Streams
@ -127,7 +127,7 @@ reopening it. @xref{Opening Streams}.
@cindex opening a stream @cindex opening a stream
Opening a file with the @code{fopen} function creates a new stream and Opening a file with the @code{fopen} function creates a new stream and
establishes a connection between the stream and a file. This may establishes a connection between the stream and a file. This may
involve creating a new file. involve creating a new file.
@pindex stdio.h @pindex stdio.h
Everything described in this section is declared in the header file Everything described in this section is declared in the header file
@ -267,7 +267,7 @@ This function causes @var{stream} to be closed and the connection to
the corresponding file to be broken. Any buffered output is written the corresponding file to be broken. Any buffered output is written
and any buffered input is discarded. The @code{fclose} function returns and any buffered input is discarded. The @code{fclose} function returns
a value of @code{0} if the file was closed successfully, and @code{EOF} a value of @code{0} if the file was closed successfully, and @code{EOF}
if an error was detected. if an error was detected.
It is important to check for errors when you call @code{fclose} to close It is important to check for errors when you call @code{fclose} to close
an output stream, because real, everyday errors can be detected at this an output stream, because real, everyday errors can be detected at this
@ -302,7 +302,7 @@ These functions are declared in the header file @file{stdio.h}.
@comment ANSI @comment ANSI
@deftypefun int fputc (int @var{c}, FILE *@var{stream}) @deftypefun int fputc (int @var{c}, FILE *@var{stream})
The @code{fputc} function converts the character @var{c} to type The @code{fputc} function converts the character @var{c} to type
@code{unsigned char}, and writes it to the stream @var{stream}. @code{unsigned char}, and writes it to the stream @var{stream}.
@code{EOF} is returned if a write error occurs; otherwise the @code{EOF} is returned if a write error occurs; otherwise the
character @var{c} is returned. character @var{c} is returned.
@end deftypefun @end deftypefun
@ -397,7 +397,7 @@ variable without loss of information.
This function reads the next character as an @code{unsigned char} from This function reads the next character as an @code{unsigned char} from
the stream @var{stream} and returns its value, converted to an the stream @var{stream} and returns its value, converted to an
@code{int}. If an end-of-file condition or read error occurs, @code{int}. If an end-of-file condition or read error occurs,
@code{EOF} is returned instead. @code{EOF} is returned instead.
@end deftypefun @end deftypefun
@comment stdio.h @comment stdio.h
@ -589,7 +589,7 @@ the input stream without removing it from the stream. This is called
the input it will read next. the input it will read next.
Using stream I/O, you can peek ahead at input by first reading it and Using stream I/O, you can peek ahead at input by first reading it and
then @dfn{unreading} it (also called @dfn{pushing it back} on the stream). then @dfn{unreading} it (also called @dfn{pushing it back} on the stream).
Unreading a character makes it available to be input again from the stream, Unreading a character makes it available to be input again from the stream,
by the next call to @code{fgetc} or other input function on that stream. by the next call to @code{fgetc} or other input function on that stream.
@ -645,7 +645,7 @@ so that the next input characters will be @samp{9} and @samp{b}.
@node How Unread @node How Unread
@subsection Using @code{ungetc} To Do Unreading @subsection Using @code{ungetc} To Do Unreading
The function to unread a character is called @code{ungetc}, because it The function to unread a character is called @code{ungetc}, because it
reverses the action of @code{getc}. reverses the action of @code{getc}.
@ -792,7 +792,7 @@ useful for printing error messages, tables of data, and the like.
* Dynamic Output:: Functions that allocate memory for the output. * Dynamic Output:: Functions that allocate memory for the output.
* Variable Arguments Output:: @code{vprintf} and friends. * Variable Arguments Output:: @code{vprintf} and friends.
* Parsing a Template String:: What kinds of args does a given template * Parsing a Template String:: What kinds of args does a given template
call for? call for?
* Example of Parsing:: Sample program using @code{parse_printf_format}. * Example of Parsing:: Sample program using @code{parse_printf_format}.
@end menu @end menu
@ -886,12 +886,12 @@ In more detail, output conversion specifications consist of an
initial @samp{%} character followed in sequence by: initial @samp{%} character followed in sequence by:
@itemize @bullet @itemize @bullet
@item @item
Zero or more @dfn{flag characters} that modify the normal behavior of Zero or more @dfn{flag characters} that modify the normal behavior of
the conversion specification. the conversion specification.
@cindex flag character (@code{printf}) @cindex flag character (@code{printf})
@item @item
An optional decimal integer specifying the @dfn{minimum field width}. An optional decimal integer specifying the @dfn{minimum field width}.
If the normal conversion produces fewer characters than this, the field If the normal conversion produces fewer characters than this, the field
is padded with spaces to the specified width. This is a @emph{minimum} is padded with spaces to the specified width. This is a @emph{minimum}
@ -906,7 +906,7 @@ printed) is used as the field width. The value must be an @code{int}.
If the value is negative, this means to set the @samp{-} flag (see If the value is negative, this means to set the @samp{-} flag (see
below) and to use the absolute value as the field width. below) and to use the absolute value as the field width.
@item @item
An optional @dfn{precision} to specify the number of digits to be An optional @dfn{precision} to specify the number of digits to be
written for the numeric conversions. If the precision is specified, it written for the numeric conversions. If the precision is specified, it
consists of a period (@samp{.}) followed optionally by a decimal integer consists of a period (@samp{.}) followed optionally by a decimal integer
@ -932,7 +932,7 @@ types.)
A character that specifies the conversion to be applied. A character that specifies the conversion to be applied.
@end itemize @end itemize
The exact options that are permitted and how they are interpreted vary The exact options that are permitted and how they are interpreted vary
between the different conversion specifiers. See the descriptions of the between the different conversion specifiers. See the descriptions of the
individual conversions for information about the particular options that individual conversions for information about the particular options that
they use. they use.
@ -941,7 +941,7 @@ With the @samp{-Wformat} option, the GNU C compiler checks calls to
@code{printf} and related functions. It examines the format string and @code{printf} and related functions. It examines the format string and
verifies that the correct number and types of arguments are supplied. verifies that the correct number and types of arguments are supplied.
There is also a GNU C syntax to tell the compiler that a function you There is also a GNU C syntax to tell the compiler that a function you
write uses a @code{printf}-style format string. write uses a @code{printf}-style format string.
@xref{Function Attributes, , Declaring Attributes of Functions, @xref{Function Attributes, , Declaring Attributes of Functions,
gcc.info, Using GNU CC}, for more information. gcc.info, Using GNU CC}, for more information.
@ -1355,7 +1355,7 @@ prints:
@end smallexample @end smallexample
@noindent @noindent
and sets @code{nchar} to @code{7}, because @samp{3 bears} is seven and sets @code{nchar} to @code{7}, because @samp{3 bears} is seven
characters. characters.
@ -1521,7 +1521,7 @@ Since that method is impossible, we provide alternative functions, the
@code{vprintf} series, which lets you pass a @code{va_list} to describe @code{vprintf} series, which lets you pass a @code{va_list} to describe
``all of my arguments after the first five.'' ``all of my arguments after the first five.''
When it is sufficient to define a macro rather than a real function, When it is sufficient to define a macro rather than a real function,
the GNU C compiler provides a way to do this much more easily with macros. the GNU C compiler provides a way to do this much more easily with macros.
For example: For example:
@ -1610,7 +1610,7 @@ as for @code{vprintf}.@refill
Here's an example showing how you might use @code{vfprintf}. This is a Here's an example showing how you might use @code{vfprintf}. This is a
function that prints error messages to the stream @code{stderr}, along function that prints error messages to the stream @code{stderr}, along
with a prefix indicating the name of the program with a prefix indicating the name of the program
(@pxref{Error Messages}, for a description of (@pxref{Error Messages}, for a description of
@code{program_invocation_short_name}). @code{program_invocation_short_name}).
@smallexample @smallexample
@ -1838,7 +1838,7 @@ validate_args (char *format, int nargs, OBJECT *args)
error ("too few arguments (at least %d required)", nwanted); error ("too few arguments (at least %d required)", nwanted);
return 0; return 0;
@} @}
/* @r{Check the C type wanted for each argument} /* @r{Check the C type wanted for each argument}
@r{and see if the object given is suitable.} */ @r{and see if the object given is suitable.} */
for (i = 0; i < nwanted; i++) for (i = 0; i < nwanted; i++)
@ -1899,16 +1899,16 @@ The facilities of this section are declared in the header file
@file{printf.h}. @file{printf.h}.
@menu @menu
* Registering New Conversions:: Using @code{register_printf_function} * Registering New Conversions:: Using @code{register_printf_function}
to register a new output conversion. to register a new output conversion.
* Conversion Specifier Options:: The handler must be able to get * Conversion Specifier Options:: The handler must be able to get
the options specified in the the options specified in the
template when it is called. template when it is called.
* Defining the Output Handler:: Defining the handler and arginfo * Defining the Output Handler:: Defining the handler and arginfo
functions that are passed as arguments functions that are passed as arguments
to @code{register_printf_function}. to @code{register_printf_function}.
* Printf Extension Example:: How to define a @code{printf} * Printf Extension Example:: How to define a @code{printf}
handler function. handler function.
@end menu @end menu
@strong{Portability Note:} The ability to extend the syntax of @strong{Portability Note:} The ability to extend the syntax of
@ -2063,7 +2063,7 @@ argument list containing the values to be printed to your handler.
Unlike most other functions that can be passed an explicit variable Unlike most other functions that can be passed an explicit variable
argument list, this is a @emph{pointer} to a @code{va_list}, rather than argument list, this is a @emph{pointer} to a @code{va_list}, rather than
the @code{va_list} itself. Thus, you should fetch arguments by the @code{va_list} itself. Thus, you should fetch arguments by
means of @code{va_arg (@var{type}, *ap_pointer)}. means of @code{va_arg (*ap_pointer, @var{type})}.
(Passing a pointer here allows the function that calls your handler (Passing a pointer here allows the function that calls your handler
function to update its own @code{va_list} variable to account for the function to update its own @code{va_list} variable to account for the
@ -2082,7 +2082,7 @@ This is the data type that a handler function should have.
If you are going to use @w{@code{parse_printf_format}} in your If you are going to use @w{@code{parse_printf_format}} in your
application, you should also define a function to pass as the application, you should also define a function to pass as the
@var{arginfo-function} argument for each new conversion you install with @var{arginfo-function} argument for each new conversion you install with
@code{register_printf_function}. @code{register_printf_function}.
You should define these functions with a prototype like: You should define these functions with a prototype like:
@ -2109,7 +2109,7 @@ the number and type of arguments used by a conversion specifier.
@subsection @code{printf} Extension Example @subsection @code{printf} Extension Example
Here is an example showing how to define a @code{printf} handler function. Here is an example showing how to define a @code{printf} handler function.
This program defines a data structure called a @code{Widget} and This program defines a data structure called a @code{Widget} and
defines the @samp{%W} conversion to print information about @w{@code{Widget *}} defines the @samp{%W} conversion to print information about @w{@code{Widget *}}
arguments, including the pointer value and the name stored in the data arguments, including the pointer value and the name stored in the data
structure. The @samp{%W} conversion supports the minimum field width and structure. The @samp{%W} conversion supports the minimum field width and
@ -2279,7 +2279,7 @@ rather than a pointer to an @code{int}.
A character that specifies the conversion to be applied. A character that specifies the conversion to be applied.
@end itemize @end itemize
The exact options that are permitted and how they are interpreted vary The exact options that are permitted and how they are interpreted vary
between the different conversion specifiers. See the descriptions of the between the different conversion specifiers. See the descriptions of the
individual conversions for information about the particular options that individual conversions for information about the particular options that
they allow. they allow.
@ -2288,7 +2288,7 @@ With the @samp{-Wformat} option, the GNU C compiler checks calls to
@code{scanf} and related functions. It examines the format string and @code{scanf} and related functions. It examines the format string and
verifies that the correct number and types of arguments are supplied. verifies that the correct number and types of arguments are supplied.
There is also a GNU C syntax to tell the compiler that a function you There is also a GNU C syntax to tell the compiler that a function you
write uses a @code{scanf}-style format string. write uses a @code{scanf}-style format string.
@xref{Function Attributes, , Declaring Attributes of Functions, @xref{Function Attributes, , Declaring Attributes of Functions,
gcc.info, Using GNU CC}, for more information. gcc.info, Using GNU CC}, for more information.
@ -2442,7 +2442,7 @@ Specifies that the argument is of type @code{long double *}.
@subsection String Input Conversions @subsection String Input Conversions
This section describes the @code{scanf} input conversions for reading This section describes the @code{scanf} input conversions for reading
string and character values: @samp{%s}, @samp{%[}, and @samp{%c}. string and character values: @samp{%s}, @samp{%[}, and @samp{%c}.
You have two options for how to receive the input from these You have two options for how to receive the input from these
conversions: conversions:
@ -2503,15 +2503,15 @@ character and a following @samp{]} character, using the same syntax used
in regular expressions. As special cases: in regular expressions. As special cases:
@itemize @bullet @itemize @bullet
@item @item
A literal @samp{]} character can be specified as the first character A literal @samp{]} character can be specified as the first character
of the set. of the set.
@item @item
An embedded @samp{-} character (that is, one that is not the first or An embedded @samp{-} character (that is, one that is not the first or
last character of the set) is used to specify a range of characters. last character of the set) is used to specify a range of characters.
@item @item
If a caret character @samp{^} immediately follows the initial @samp{[}, If a caret character @samp{^} immediately follows the initial @samp{[},
then the set of allowed input characters is the everything @emph{except} then the set of allowed input characters is the everything @emph{except}
the characters listed. the characters listed.
@ -2536,7 +2536,7 @@ the standard whitespace characters. This is slightly different from
@samp{%[} reports a matching failure while @samp{%s} simply discards the @samp{%[} reports a matching failure while @samp{%s} simply discards the
initial whitespace. initial whitespace.
@item %25[a-z] @item %25[a-z]
Matches up to 25 lowercase characters. Matches up to 25 lowercase characters.
@end table @end table
@ -2960,7 +2960,7 @@ thing you can rely on is that you can use it subsequently as the
@var{offset} argument to @code{fseek} to move back to the same file @var{offset} argument to @code{fseek} to move back to the same file
position. position.
@item @item
In a call to @code{fseek} on a text stream, either the @var{offset} must In a call to @code{fseek} on a text stream, either the @var{offset} must
either be zero; or @var{whence} must be @code{SEEK_SET} and the either be zero; or @var{whence} must be @code{SEEK_SET} and the
@var{offset} must be the result of an earlier call to @code{ftell} on @var{offset} must be the result of an earlier call to @code{ftell} on
@ -3103,7 +3103,7 @@ When you try to do output and the output buffer is full.
@item @item
When the stream is closed. @xref{Closing Streams}. When the stream is closed. @xref{Closing Streams}.
@item @item
When the program terminates by calling @code{exit}. When the program terminates by calling @code{exit}.
@xref{Normal Termination}. @xref{Normal Termination}.
@ -3212,7 +3212,7 @@ to use for the @var{size} argument to @code{setvbuf}. This value is
guaranteed to be at least @code{256}. guaranteed to be at least @code{256}.
The value of @code{BUFSIZ} is chosen on each system so as to make stream The value of @code{BUFSIZ} is chosen on each system so as to make stream
I/O efficient. So it is a good idea to use @code{BUFSIZ} as the size I/O efficient. So it is a good idea to use @code{BUFSIZ} as the size
for the buffer when you call @code{setvbuf}. for the buffer when you call @code{setvbuf}.
Actually, you can get an even better value to use for the buffer size Actually, you can get an even better value to use for the buffer size
@ -3281,7 +3281,7 @@ specific to GNU. Other systems or C implementations might or might not
provide equivalent functionality. provide equivalent functionality.
@menu @menu
* String Streams:: Streams that get data from or put data in * String Streams:: Streams that get data from or put data in
a string or memory buffer. a string or memory buffer.
* Obstack Streams:: Streams that store data in an obstack. * Obstack Streams:: Streams that store data in an obstack.
* Custom Streams:: Defining your own streams with an arbitrary * Custom Streams:: Defining your own streams with an arbitrary
@ -3456,9 +3456,9 @@ programmed by you. We call these @dfn{custom streams}.
@menu @menu
* Streams and Cookies:: The @dfn{cookie} records where to fetch or * Streams and Cookies:: The @dfn{cookie} records where to fetch or
store data that is read or written. store data that is read or written.
* Hook Functions:: How you should define the four @dfn{hook * Hook Functions:: How you should define the four @dfn{hook
functions} that a custom stream needs. functions} that a custom stream needs.
@end menu @end menu
@node Streams and Cookies @node Streams and Cookies
@ -3481,7 +3481,7 @@ functions don't know what's inside the cookie, but your functions will
know. know.
When you create a custom stream, you must specify the cookie pointer, When you create a custom stream, you must specify the cookie pointer,
and also the four hook functions stored in a structure of type and also the four hook functions stored in a structure of type
@code{cookie_io_functions_t}. @code{cookie_io_functions_t}.
These facilities are declared in @file{stdio.h}. These facilities are declared in @file{stdio.h}.
@ -3490,7 +3490,7 @@ These facilities are declared in @file{stdio.h}.
@comment stdio.h @comment stdio.h
@comment GNU @comment GNU
@deftp {Data Type} {cookie_io_functions_t} @deftp {Data Type} {cookie_io_functions_t}
This is a structure type that holds the functions that define the This is a structure type that holds the functions that define the
communications protocol between the stream and its cookie. It has communications protocol between the stream and its cookie. It has
the following members: the following members:
@ -3576,7 +3576,7 @@ the GNU library, @code{fpos_t} is equivalent to @code{off_t} or
@code{long int}, and simply represents the number of bytes from the @code{long int}, and simply represents the number of bytes from the
beginning of the file. beginning of the file.
After doing the seek operation, your function should store the resulting After doing the seek operation, your function should store the resulting
file position relative to the beginning of the file in @var{position}. file position relative to the beginning of the file in @var{position}.
Your function should return a value of @code{0} on success and @code{-1} Your function should return a value of @code{0} on success and @code{-1}
to indicate an error. to indicate an error.

View File

@ -1,5 +1,5 @@
/* error.h -- declaration for error-reporting function /* error.h -- declaration for error-reporting function
Copyright (C) 1995 Software Foundation, Inc. Copyright (C) 1995, 1996 Software Foundation, Inc.
This file is part of the GNU C Library. Its master source is NOT part of This file is part of the GNU C Library. Its master source is NOT part of
the C library, however. The master source lives in /gd/gnu/lib. the C library, however. The master source lives in /gd/gnu/lib.
@ -35,11 +35,23 @@ Cambridge, MA 02139, USA. */
# endif # endif
#endif #endif
#if __STDC__ #if defined (__STDC__) && __STDC__
void error (int, int, const char *, ...) \
__attribute__ ((__format__ (__printf__, 3, 4))); /* Print a message with `fprintf (stderr, FORMAT, ...)';
if ERRNUM is nonzero, follow it with ": " and strerror (ERRNUM).
If STATUS is nonzero, terminate the program with `exit (STATUS)'. */
extern void error (int status, int errnum, const char *format, ...)
__attribute__ ((__format__ (__printf__, 3, 4)));
/* If NULL, error will flush stdout, then print on stderr the program
name, a colon and a space. Otherwise, error will call this
function without parameters instead. */
extern void (*error_print_progname) (void);
#else #else
void error (); void error ();
extern void (*error_print_progname) ();
#endif #endif
/* This variable is incremented each time `error' is called. */ /* This variable is incremented each time `error' is called. */

View File

@ -1,26 +0,0 @@
/* O_*, F_*, FD_* bit values for Linux.
Copyright (C) 1995 Free Software Foundation, Inc.
This file is part of the GNU C Library.
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 _FCNTLBITS_H
#define _FCNTLBITS_H 1
#include <sys/types.h>
#include <linux/fcntl.h>
#endif /* fcntlbits.h */