1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
|
/* @(#)sprintf.c 1.13 00/05/07 Copyright 1985 J. Schilling */
/*
* Copyright (c) 1985 J. Schilling
*/
/*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2, or (at your option)
* any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; see the file COPYING. If not, write to
* the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
*/
#include <mconfig.h>
#include <vadefs.h>
#include <standard.h>
#include <schily.h>
/*
* Do not include stdio.h, BSD systems define sprintf the wrong way!
*/
EXPORT int sprintf __PR((char *, const char *, ...));
#ifdef PROTOTYPES
static void _cput(char c, long ba)
#else
static void _cput(c, ba)
char c;
long ba;
#endif
{
*(*(char **) ba)++ = c;
}
/* VARARGS2 */
#ifdef PROTOTYPES
int sprintf(char *buf, const char *form, ...)
#else
int sprintf(buf, form, va_alist)
char *buf;
char *form;
va_dcl
#endif
{
va_list args;
int cnt;
char *bp = buf;
#ifdef PROTOTYPES
va_start(args, form);
#else
va_start(args);
#endif
cnt = format(_cput, (long)&bp, form, args);
va_end(args);
*bp = '\0';
return (cnt);
}
|