mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-02 07:50:18 +00:00
5b82669229
Sat Jan 25 02:05:19 1997 Eirik Fuller <eirik@netcom.com> * sysdeps/unix/sysv/linux/alpha/ioperm.c: Rename T2_SPARSE_BASE and T2_DENSE_BASE to T2_SPARSE_MEM and T2_DENSE_MEM resp. Thu Jan 23 11:13:46 1997 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de> * sysdeps/unix/sysv/linux/usleep.c: Normalize the time specification. Fri Jan 24 14:33:45 1997 Ulrich Drepper <drepper@cygnus.com> * sysdeps/generic/socketbits.h: Also make SOCK_* constants available as macros so that #ifdef works. * sysdeps/unix/sysv/linux/socketbits.h: Likewise. 1997-01-23 Paul Eggert <eggert@twinsun.com> * login/utmp_db.c, manual/time.texi, shlib-versions, sunrpc/rpc/svc.h, sunrpc/rpcsvc/sm_inter.x, sysdeps/generic/abort.c, sysdeps/libm-ieee754/e_sinhl.c, sysdeps/unix/sysv/linux/net/route.h, sysdeps/unix/sysv/linux/sparc/__sigtrampoline.S: Spell fixes.
58 lines
1.8 KiB
C
58 lines
1.8 KiB
C
/* Copyright (C) 1991, 1992, 1993, 1997 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. */
|
|
|
|
#include <errno.h>
|
|
#include <limits.h>
|
|
#include <stdarg.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <hurd/fd.h>
|
|
|
|
/* Write formatted output to file descriptor D according to the format string
|
|
FORMAT, using the argument list in ARG. */
|
|
int
|
|
vdprintf (int d, const char *format, va_list arg)
|
|
{
|
|
int done;
|
|
FILE f;
|
|
struct hurd_fd *fd;
|
|
|
|
HURD_CRITICAL_BEGIN;
|
|
fd = _hurd_fd_get (d);
|
|
HURD_CRITICAL_END;
|
|
|
|
if (!fd)
|
|
return 0;
|
|
|
|
/* Create an unbuffered stream talking to D on the stack. */
|
|
memset ((void *) &f, 0, sizeof (f));
|
|
f.__magic = _IOMAGIC;
|
|
f.__mode.__write = 1;
|
|
f.__cookie = fd;
|
|
f.__room_funcs = __default_room_functions;
|
|
f.__io_funcs = __default_io_functions;
|
|
f.__seen = 1;
|
|
f.__userbuf = 1;
|
|
|
|
/* vfprintf will use a buffer on the stack for the life of the call,
|
|
and flush it when finished. */
|
|
done = vfprintf (&f, format, arg);
|
|
|
|
return done;
|
|
}
|