1*9781SMoriah.Waterland@Sun.COM /* 2*9781SMoriah.Waterland@Sun.COM * CDDL HEADER START 3*9781SMoriah.Waterland@Sun.COM * 4*9781SMoriah.Waterland@Sun.COM * The contents of this file are subject to the terms of the 5*9781SMoriah.Waterland@Sun.COM * Common Development and Distribution License (the "License"). 6*9781SMoriah.Waterland@Sun.COM * You may not use this file except in compliance with the License. 7*9781SMoriah.Waterland@Sun.COM * 8*9781SMoriah.Waterland@Sun.COM * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9*9781SMoriah.Waterland@Sun.COM * or http://www.opensolaris.org/os/licensing. 10*9781SMoriah.Waterland@Sun.COM * See the License for the specific language governing permissions 11*9781SMoriah.Waterland@Sun.COM * and limitations under the License. 12*9781SMoriah.Waterland@Sun.COM * 13*9781SMoriah.Waterland@Sun.COM * When distributing Covered Code, include this CDDL HEADER in each 14*9781SMoriah.Waterland@Sun.COM * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15*9781SMoriah.Waterland@Sun.COM * If applicable, add the following below this CDDL HEADER, with the 16*9781SMoriah.Waterland@Sun.COM * fields enclosed by brackets "[]" replaced with your own identifying 17*9781SMoriah.Waterland@Sun.COM * information: Portions Copyright [yyyy] [name of copyright owner] 18*9781SMoriah.Waterland@Sun.COM * 19*9781SMoriah.Waterland@Sun.COM * CDDL HEADER END 20*9781SMoriah.Waterland@Sun.COM */ 21*9781SMoriah.Waterland@Sun.COM 22*9781SMoriah.Waterland@Sun.COM /* 23*9781SMoriah.Waterland@Sun.COM * Copyright 2009 Sun Microsystems, Inc. All rights reserved. 24*9781SMoriah.Waterland@Sun.COM * Use is subject to license terms. 25*9781SMoriah.Waterland@Sun.COM */ 26*9781SMoriah.Waterland@Sun.COM 27*9781SMoriah.Waterland@Sun.COM /* Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T */ 28*9781SMoriah.Waterland@Sun.COM /* All Rights Reserved */ 29*9781SMoriah.Waterland@Sun.COM 30*9781SMoriah.Waterland@Sun.COM 31*9781SMoriah.Waterland@Sun.COM 32*9781SMoriah.Waterland@Sun.COM #include <stdio.h> 33*9781SMoriah.Waterland@Sun.COM #include <string.h> 34*9781SMoriah.Waterland@Sun.COM #include <stdarg.h> 35*9781SMoriah.Waterland@Sun.COM #include "pkglocale.h" 36*9781SMoriah.Waterland@Sun.COM 37*9781SMoriah.Waterland@Sun.COM /*VARARGS*/ 38*9781SMoriah.Waterland@Sun.COM void 39*9781SMoriah.Waterland@Sun.COM logerr(char *fmt, ...) 40*9781SMoriah.Waterland@Sun.COM { 41*9781SMoriah.Waterland@Sun.COM va_list ap; 42*9781SMoriah.Waterland@Sun.COM char *pt, buffer[2048]; 43*9781SMoriah.Waterland@Sun.COM int flag; 44*9781SMoriah.Waterland@Sun.COM char *estr = pkg_gt("ERROR:"); 45*9781SMoriah.Waterland@Sun.COM char *wstr = pkg_gt("WARNING:"); 46*9781SMoriah.Waterland@Sun.COM char *nstr = pkg_gt("NOTE:"); 47*9781SMoriah.Waterland@Sun.COM 48*9781SMoriah.Waterland@Sun.COM va_start(ap, fmt); 49*9781SMoriah.Waterland@Sun.COM flag = 0; 50*9781SMoriah.Waterland@Sun.COM /* This may have to use the i18n strcmp() routines. */ 51*9781SMoriah.Waterland@Sun.COM if (strncmp(fmt, estr, strlen(estr)) && 52*9781SMoriah.Waterland@Sun.COM strncmp(fmt, wstr, strlen(wstr)) && 53*9781SMoriah.Waterland@Sun.COM strncmp(fmt, nstr, strlen(nstr))) { 54*9781SMoriah.Waterland@Sun.COM flag++; 55*9781SMoriah.Waterland@Sun.COM (void) fprintf(stderr, " "); 56*9781SMoriah.Waterland@Sun.COM } 57*9781SMoriah.Waterland@Sun.COM /* 58*9781SMoriah.Waterland@Sun.COM * NOTE: internationalization in next line REQUIRES that caller of 59*9781SMoriah.Waterland@Sun.COM * this routine be in the same internationalization domain 60*9781SMoriah.Waterland@Sun.COM * as this library. 61*9781SMoriah.Waterland@Sun.COM */ 62*9781SMoriah.Waterland@Sun.COM (void) vsprintf(buffer, fmt, ap); 63*9781SMoriah.Waterland@Sun.COM 64*9781SMoriah.Waterland@Sun.COM va_end(ap); 65*9781SMoriah.Waterland@Sun.COM 66*9781SMoriah.Waterland@Sun.COM for (pt = buffer; *pt; pt++) { 67*9781SMoriah.Waterland@Sun.COM (void) putc(*pt, stderr); 68*9781SMoriah.Waterland@Sun.COM if (flag && (*pt == '\n') && pt[1]) 69*9781SMoriah.Waterland@Sun.COM (void) fprintf(stderr, " "); 70*9781SMoriah.Waterland@Sun.COM } 71*9781SMoriah.Waterland@Sun.COM (void) putc('\n', stderr); 72*9781SMoriah.Waterland@Sun.COM } 73