94 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /***********************************************************************
 | |
|  * 
 | |
|  *  Copyright (C) 2006 Novell, Inc. All Rights Reserved.
 | |
|  *
 | |
|  *  This library is free software; you can redistribute it and/or
 | |
|  *  modify it under the terms of the GNU Lesser General Public
 | |
|  *  License as published by the Free Software Foundation; version 2.1
 | |
|  *  of the License.
 | |
|  *
 | |
|  *  This library 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
 | |
|  *  Library Lesser General Public License for more details.
 | |
|  *
 | |
|  *  You should have received a copy of the GNU Lesser General Public
 | |
|  *  License along with this library; if not, Novell, Inc.
 | |
|  * 
 | |
|  *  To contact Novell about this file by physical or electronic mail, 
 | |
|  *  you may find current contact information at www.novell.com.
 | |
|  * 
 | |
|  *  Author: Juan Carlos Luciani <jluciani@novell.com>
 | |
|  *
 | |
|  ***********************************************************************/
 | |
| 
 | |
| #define _GNU_SOURCE
 | |
| 
 | |
| //===[ Include files ]=====================================================
 | |
| 
 | |
| #include <stdio.h>
 | |
| #include <stdlib.h>
 | |
| #include <stdbool.h>
 | |
| #include <string.h>
 | |
| #include <syslog.h>
 | |
| #include <pthread.h>
 | |
| #include <string.h>
 | |
| #include <ctype.h>
 | |
| #include <errno.h>
 | |
| #include <dlfcn.h>
 | |
| 
 | |
| //===[ Type definitions ]==================================================
 | |
| 
 | |
| #define HANDLE void*
 | |
| 
 | |
| #ifndef CONTAINING_RECORD
 | |
| #define CONTAINING_RECORD(address, type, field) ((type *)(     \
 | |
|              (char*)(address) -                                \
 | |
|              (char*)(&((type *)0)->field)))
 | |
| #endif
 | |
| 
 | |
| //
 | |
| // DbgTrace macro define
 | |
| //
 | |
| /*#define DbgTrace(LEVEL, X, Y) {                          \
 | |
| char printBuff[256];                                     \
 | |
|    if (LEVEL == 0 || DebugLevel >= LEVEL)                \
 | |
|    {                                                     \
 | |
|       _snprintf(printBuff, sizeof(printBuff), X, Y);     \
 | |
|       fprintf(stderr, "CASA_IdenToken %s", printBuff);    \
 | |
|    }                                                     \
 | |
| }*/
 | |
| #define DbgTrace(LEVEL, X, Y) {                                                  \
 | |
|    if (LEVEL == 0 || DebugLevel >= LEVEL)                                        \
 | |
|    {                                                                             \
 | |
|       openlog("CASA_IdenToken", LOG_CONS | LOG_NOWAIT | LOG_ODELAY, LOG_USER);   \
 | |
|       syslog(LOG_USER | LOG_INFO, X, Y);                                         \
 | |
|       closelog();                                                                \
 | |
|    }                                                                             \
 | |
| }
 | |
| 
 | |
| 
 | |
| // Deal with function name mapping issues
 | |
| #define _snprintf snprintf
 | |
| 
 | |
| 
 | |
| //
 | |
| // Module synchronization
 | |
| // 
 | |
| extern pthread_mutex_t  g_hModuleMutex;
 | |
| 
 | |
| #define AcquireModuleMutex    pthread_mutex_lock(&g_hModuleMutex)
 | |
| #define ReleaseModuleMutex    pthread_mutex_unlock(&g_hModuleMutex)
 | |
| 
 | |
| 
 | |
| //===[ Inlines functions   ]===============================================
 | |
| 
 | |
| //===[ Function prototypes ]===============================================
 | |
| 
 | |
| //===[ Global externals ]==================================================
 | |
| 
 | |
| //===[ External prototypes ]===============================================
 | |
| 
 | |
| //=========================================================================
 | |
| 
 |