5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * CDDL HEADER START
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * The contents of this file are subject to the terms of the
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Common Development and Distribution License (the "License").
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * You may not use this file except in compliance with the License.
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * or http://www.opensolaris.org/os/licensing.
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * See the License for the specific language governing permissions
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * and limitations under the License.
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * When distributing Covered Code, include this CDDL HEADER in each
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * If applicable, add the following below this CDDL HEADER, with the
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * fields enclosed by brackets "[]" replaced with your own identifying
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * information: Portions Copyright [yyyy] [name of copyright owner]
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * CDDL HEADER END
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Use is subject to license terms.
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland/* unix system includes */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * consolidation pkg command library includes
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * local pkg command library includes
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland/* Should be defined by cc -D */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland/* local static data */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Name: log_msg
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Description: Outputs messages to logging facility.
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Scope: public
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Arguments: a_type - the severity of the message
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * a_format - the printf format, plus its arguments
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Returns: none
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland/*PRINTFLIKE2*/
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterlandlog_msg(LogMsgType a_type, const char *a_format, ...)
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland /* process message based on type */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland default: /* treat unknown type as LOG_MSG_ERR */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland case LOG_MSG_INFO: /* information message */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland case LOG_MSG_DEBUG: /* debugging message */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland /* no debug messages if not verbose mode */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland /* output debug prefix to match echoDebug() format */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland (void) fprintf(stderr, "# [%6d %3d", getpid(), getzoneid());
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland /* output prefix if specified */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland /* determine size of the message in bytes */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland /* allocate storage to hold the message */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland /* generate the results of the printf conversion */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland vres = vsnprintf(rstr, vres+1, a_format, ap);
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland /* output formatted message to appropriate destination */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * nothing output, try stderr as a
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * last resort
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland (void) fprintf(stderr, ERR_LOG_FAIL, a_format);
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland /* free temporary message storage */
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Name: set_verbose
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Description: Turns on verbose output
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Scope: public
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Arguments: verbose = B_TRUE indicates verbose mode
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Returns: none
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Name: get_verbose
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Description: Returns whether or not to output verbose messages
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Scope: public
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Arguments: none
5c51f1241dbbdf2656d0e10011981411ed0c9673Moriah Waterland * Returns: B_TRUE - verbose messages should be output