00001 /* 00002 * See the dyninst/COPYRIGHT file for copyright information. 00003 * 00004 * We provide the Paradyn Tools (below described as "Paradyn") 00005 * on an AS IS basis, and do not warrant its validity or performance. 00006 * We reserve the right to update, modify, or discontinue this 00007 * software at any time. We shall have no obligation to supply such 00008 * updates or modifications or any other form of support to you. 00009 * 00010 * By your use of Paradyn, you understand and agree that we (or any 00011 * other person or entity with proprietary rights in Paradyn) are 00012 * under no obligation to provide either maintenance services, 00013 * update services, notices of latent defects, or correction of 00014 * defects for Paradyn. 00015 * 00016 * This library is free software; you can redistribute it and/or 00017 * modify it under the terms of the GNU Lesser General Public 00018 * License as published by the Free Software Foundation; either 00019 * version 2.1 of the License, or (at your option) any later version. 00020 * 00021 * This library is distributed in the hope that it will be useful, 00022 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00023 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00024 * Lesser General Public License for more details. 00025 * 00026 * You should have received a copy of the GNU Lesser General Public 00027 * License along with this library; if not, write to the Free Software 00028 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 00029 */ 00030 00031 /************************************************************************ 00032 * lprintf.c: printf-like error functions. 00033 ************************************************************************/ 00034 00035 00036 /************************************************************************ 00037 * header files. 00038 ************************************************************************/ 00039 00040 #include "common/h/headers.h" 00041 #include "common/h/lprintf.h" 00042 #include <stdio.h> 00043 #include <stdarg.h> 00044 #include <errno.h> 00045 00046 /************************************************************************ 00047 * void log_msg(const char* msg) 00048 * void log_printf(void (*pfunc)(const char *), const char* fmt, ...) 00049 * void log_perror(void (*pfunc)(const char *), const char* msg) 00050 * 00051 * error printing functions. 00052 ************************************************************************/ 00053 00054 static char log_buffer[8192]; 00055 00056 void log_msg(const char* msg) { 00057 fprintf(stderr, "%s", msg); 00058 } 00059 00060 void 00061 log_printf(void (*pfunc)(const char *), const char* fmt, ...) { 00062 va_list ap; 00063 va_start(ap, fmt); 00064 vsprintf(log_buffer, fmt, ap); 00065 va_end(ap); 00066 pfunc(log_buffer); 00067 } 00068 00069 void 00070 log_perror(void (*pfunc)(const char *), const char* msg) { 00071 sprintf(log_buffer, "%s: %s\n", msg, strerror(errno)); 00072 pfunc(log_buffer); 00073 }
1.6.1