1*2d543d20SAndroid Build Coastguard Worker /* Author: Joshua Brindle <[email protected]> 2*2d543d20SAndroid Build Coastguard Worker * Jason Tang <[email protected]> 3*2d543d20SAndroid Build Coastguard Worker * Ivan Gyurdiev <[email protected]> 4*2d543d20SAndroid Build Coastguard Worker * 5*2d543d20SAndroid Build Coastguard Worker * Copyright (C) 2005 Tresys Technology, LLC 6*2d543d20SAndroid Build Coastguard Worker * Copyright (C) 2005 Red Hat Inc. 7*2d543d20SAndroid Build Coastguard Worker * 8*2d543d20SAndroid Build Coastguard Worker * This library is free software; you can redistribute it and/or 9*2d543d20SAndroid Build Coastguard Worker * modify it under the terms of the GNU Lesser General Public 10*2d543d20SAndroid Build Coastguard Worker * License as published by the Free Software Foundation; either 11*2d543d20SAndroid Build Coastguard Worker * version 2.1 of the License, or (at your option) any later version. 12*2d543d20SAndroid Build Coastguard Worker * 13*2d543d20SAndroid Build Coastguard Worker * This library is distributed in the hope that it will be useful, 14*2d543d20SAndroid Build Coastguard Worker * but WITHOUT ANY WARRANTY; without even the implied warranty of 15*2d543d20SAndroid Build Coastguard Worker * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 16*2d543d20SAndroid Build Coastguard Worker * Lesser General Public License for more details. 17*2d543d20SAndroid Build Coastguard Worker * 18*2d543d20SAndroid Build Coastguard Worker * You should have received a copy of the GNU Lesser General Public 19*2d543d20SAndroid Build Coastguard Worker * License along with this library; if not, write to the Free Software 20*2d543d20SAndroid Build Coastguard Worker * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA 21*2d543d20SAndroid Build Coastguard Worker */ 22*2d543d20SAndroid Build Coastguard Worker 23*2d543d20SAndroid Build Coastguard Worker #ifndef _SEMANAGE_INTERNAL_DEBUG_H_ 24*2d543d20SAndroid Build Coastguard Worker #define _SEMANAGE_INTERNAL_DEBUG_H_ 25*2d543d20SAndroid Build Coastguard Worker 26*2d543d20SAndroid Build Coastguard Worker #include <stdio.h> 27*2d543d20SAndroid Build Coastguard Worker #include <semanage/debug.h> 28*2d543d20SAndroid Build Coastguard Worker #include <sepol/debug.h> 29*2d543d20SAndroid Build Coastguard Worker #include "handle.h" 30*2d543d20SAndroid Build Coastguard Worker 31*2d543d20SAndroid Build Coastguard Worker #define STATUS_SUCCESS 0 32*2d543d20SAndroid Build Coastguard Worker #define STATUS_ERR -1 33*2d543d20SAndroid Build Coastguard Worker #define STATUS_NODATA 1 34*2d543d20SAndroid Build Coastguard Worker 35*2d543d20SAndroid Build Coastguard Worker #define msg_write(handle_arg, level_arg, \ 36*2d543d20SAndroid Build Coastguard Worker channel_arg, func_arg, ...) do { \ 37*2d543d20SAndroid Build Coastguard Worker \ 38*2d543d20SAndroid Build Coastguard Worker if ((handle_arg)->msg_callback) { \ 39*2d543d20SAndroid Build Coastguard Worker (handle_arg)->msg_fname = func_arg; \ 40*2d543d20SAndroid Build Coastguard Worker (handle_arg)->msg_channel = channel_arg; \ 41*2d543d20SAndroid Build Coastguard Worker (handle_arg)->msg_level = level_arg; \ 42*2d543d20SAndroid Build Coastguard Worker \ 43*2d543d20SAndroid Build Coastguard Worker (handle_arg)->msg_callback( \ 44*2d543d20SAndroid Build Coastguard Worker (handle_arg)->msg_callback_arg, \ 45*2d543d20SAndroid Build Coastguard Worker handle_arg, __VA_ARGS__); \ 46*2d543d20SAndroid Build Coastguard Worker } \ 47*2d543d20SAndroid Build Coastguard Worker } while(0) 48*2d543d20SAndroid Build Coastguard Worker 49*2d543d20SAndroid Build Coastguard Worker #define ERR(handle, ...) \ 50*2d543d20SAndroid Build Coastguard Worker msg_write(handle, SEMANAGE_MSG_ERR, "libsemanage", \ 51*2d543d20SAndroid Build Coastguard Worker __FUNCTION__, __VA_ARGS__) 52*2d543d20SAndroid Build Coastguard Worker 53*2d543d20SAndroid Build Coastguard Worker #define INFO(handle, ...) \ 54*2d543d20SAndroid Build Coastguard Worker msg_write(handle, SEMANAGE_MSG_INFO, "libsemanage", \ 55*2d543d20SAndroid Build Coastguard Worker __FUNCTION__, __VA_ARGS__) 56*2d543d20SAndroid Build Coastguard Worker 57*2d543d20SAndroid Build Coastguard Worker #define WARN(handle, ...) \ 58*2d543d20SAndroid Build Coastguard Worker msg_write(handle, SEMANAGE_MSG_WARN, "libsemanage", \ 59*2d543d20SAndroid Build Coastguard Worker __FUNCTION__, __VA_ARGS__) 60*2d543d20SAndroid Build Coastguard Worker 61*2d543d20SAndroid Build Coastguard Worker #ifdef __GNUC__ 62*2d543d20SAndroid Build Coastguard Worker __attribute__ ((format(printf, 3, 4))) 63*2d543d20SAndroid Build Coastguard Worker #endif 64*2d543d20SAndroid Build Coastguard Worker extern void semanage_msg_default_handler(void *varg, 65*2d543d20SAndroid Build Coastguard Worker semanage_handle_t * handle, 66*2d543d20SAndroid Build Coastguard Worker const char *fmt, ...); 67*2d543d20SAndroid Build Coastguard Worker 68*2d543d20SAndroid Build Coastguard Worker #ifdef __GNUC__ 69*2d543d20SAndroid Build Coastguard Worker __attribute__ ((format(printf, 3, 4))) 70*2d543d20SAndroid Build Coastguard Worker #endif 71*2d543d20SAndroid Build Coastguard Worker extern void semanage_msg_relay_handler(void *varg, 72*2d543d20SAndroid Build Coastguard Worker sepol_handle_t * handle, 73*2d543d20SAndroid Build Coastguard Worker const char *fmt, ...); 74*2d543d20SAndroid Build Coastguard Worker 75*2d543d20SAndroid Build Coastguard Worker #endif 76