head 1.3; access; symbols PETIDOMO_4_0b6:1.3 PETIDOMO_4_0b5:1.3 PETIDOMO_4_0b4:1.3 PETIDOMO_4_0b3:1.3 BEFORETHL:1.3 petidomo-2-2:1.1.1.1 petidomo:1.1.1; locks; strict; comment @ * @; 1.3 date 2000.12.13.17.37.56; author simons; state Exp; branches; next 1.2; 1.2 date 2000.12.13.15.45.25; author simons; state Exp; branches; next 1.1; 1.1 date 2000.12.13.13.19.07; author simons; state Exp; branches 1.1.1.1; next ; 1.1.1.1 date 2000.12.13.13.19.07; author simons; state Exp; branches; next ; desc @@ 1.3 log @Added correct GPL copyright headers. @ text @/* $Source$ $Revision$ Copyright (C) 2000 by CyberSolutions GmbH, Germany. This file is part of OpenPetidomo. OpenPetidomo 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. OpenPetidomo 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 OpenPetidomo; see the file COPYING. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include #include #include "text.h" #if !defined(HAVE_VSNPRINTF) && defined(HAVE___VSNPRINTF) # define vsnprintf __vsnprintf #endif /* Use sprintf() without worrying about buffer size. One problem when dealing a lot with texts and strings is the buffer handling. Usually a programmer will frequently have to format several strings into a new one using sprintf(3), without knowing how long the resulting string will become. text_easy_sprintf() will solve this problem. The syntax is very much like sprintf(), except for that the target buffer is allocated by the routine and returned to the caller. RETURNS: A buffer holding the formatted string or NULL if the memory allocation failed. NOTE: The returned buffer has been allocated with malloc(3) and should be freed when not needed anymore. AUTHOR: Peter Simons */ char * text_easy_sprintf(const char * fmt /* Format string in printf(3) syntax. */, ... /* Parameter list. */) { char * buffer, * result; size_t buffer_size; va_list ap; int rc; /* Sanity checks. */ assert(fmt != NULL); if (fmt == NULL) return NULL; /* Do the work. */ va_start(ap, fmt); for (buffer_size = 0, result = NULL; TRUE; free(buffer)) { /* forever */ /* Allocate the internal buffer. */ buffer_size += 8 * 1024; buffer = malloc(buffer_size); if (buffer == NULL) goto leave; /* Format the string into it. */ rc = vsnprintf(buffer, buffer_size, fmt, ap); /* Success? */ if (rc < buffer_size) { /* Yes. */ result = strdup(buffer); free(buffer); goto leave; } /* No. */ } leave: va_end(ap); return result; } @ 1.2 log @Imported latest version. @ text @d2 22 a23 36 * $Source: /home/cvs/lib/libtext/easy_sprintf.c,v $ * $Revision: 1.1.1.1 $ * $Date: 1999/08/23 07:40:17 $ * * Copyright (c) 1996-99 by Peter Simons * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed by Peter Simons. * * 4. The name of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ @ 1.1 log @Initial revision @ text @d2 3 a4 3 * $Source: /usr/local/libdata/cvs/c-lib/libtext/easy_sprintf.c,v $ * $Revision: 1.6 $ * $Date: 1997/12/13 12:18:52 $ d6 31 a36 2 * Copyright (C) 1996,97 by CyberSolutions GmbH. * All rights reserved. @ 1.1.1.1 log @Imported Petidomo 2.2 as found on www.petidomo.com. @ text @@