1 /***************************************************************************
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
10 * Copyright (C) 2002 by Gary Czvitkovicz
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation; either version 2
15 * of the License, or (at your option) any later version.
17 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
18 * KIND, either express or implied.
20 ****************************************************************************/
23 * Minimal printf and snprintf formatting functions
25 * These support %c %s %d and %x
26 * Field width and zero-padding flag only
35 /* ALSA library requires a more advanced snprintf, so let's not
36 override it in simulator for Linux. Note that Cygwin requires
37 our snprintf or it produces garbled output after a while. */
40 unsigned char *ptr
; /* where to store it */
41 size_t bytes
; /* amount already stored */
42 size_t max
; /* max amount to store */
45 static int sprfunc(void *ptr
, unsigned char letter
)
47 struct for_snprintf
*pr
= (struct for_snprintf
*)ptr
;
48 if(pr
->bytes
< pr
->max
) {
54 return false; /* filled buffer */
58 int snprintf(char *buf
, size_t size
, const char *fmt
, ...)
62 struct for_snprintf pr
;
64 pr
.ptr
= (unsigned char *)buf
;
69 ok
= format(sprfunc
, &pr
, fmt
, ap
);
72 /* make sure it ends with a trailing zero */
73 pr
.ptr
[(pr
.bytes
< pr
.max
) ? 0 : -1] = '\0';
78 int vsnprintf(char *buf
, size_t size
, const char *fmt
, va_list ap
)
81 struct for_snprintf pr
;
83 pr
.ptr
= (unsigned char *)buf
;
87 ok
= format(sprfunc
, &pr
, fmt
, ap
);
89 /* make sure it ends with a trailing zero */
90 pr
.ptr
[(pr
.bytes
< pr
.max
) ? 0 : -1] = '\0';