/* * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a * aplicativos mainframe. Registro no INPI sob o nome G3270. Registro no INPI sob o nome G3270. * * Copyright (C) <2008> * * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob * os termos da GPL v.2 - Licença Pública Geral GNU, conforme publicado pela * Free Software Foundation. * * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para * obter mais detalhes. * * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin * St, Fifth Floor, Boston, MA 02110-1301 USA * * Este programa está nomeado como log.c e possui 151 linhas de código. * * Contatos: * * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) * erico.mendonca@gmail.com (Erico Mascarenhas Mendonça) * licinio@bb.com.br (Licínio Luis Branco) * kraucer@bb.com.br (Kraucer Fernandes Mazuco) * macmiranda@bb.com.br (Marco Aurélio Caldas Miranda) * */ #include #ifdef WIN32 #include #include #endif // WIN32 #include #include #include #include #include #include #include /*---[ Constants ]------------------------------------------------------------------------------------------*/ static LIB3270_LOG_HANDLER loghandler = default_loghandler; static void *loguserdata = NULL; /*---[ Implementacao ]--------------------------------------------------------------------------------------*/ static void write_log(const H3270 *session, const char *module, int rc, const char *fmt, va_list args) { // 'mount' message. char *message = lib3270_vsprintf(fmt,args); // Write log if(session) { if(session->log.file) { // Has log file. Use it if possible. FILE *f = fopen(session->log.file, "a"); if(f) { time_t ltime = time(0); char timestamp[80]; #ifdef HAVE_LOCALTIME_R struct tm tm; strftime(timestamp, 79, "%x %X", localtime_r(<ime,&tm)); #else strftime(timestamp, 79, "%x %X", localtime(<ime)); #endif // HAVE_LOCALTIME_R fprintf(f,"%s %s\t%s\n",timestamp,module,message); fclose(f); } } session->log.handler(session,session->log.userdata,module ? module : LIB3270_STRINGIZE_VALUE_OF(PRODUCT_NAME),rc,message); } else { loghandler(session, loguserdata, (module ? module : LIB3270_STRINGIZE_VALUE_OF(PRODUCT_NAME)),rc,message); } lib3270_free(message); } LIB3270_EXPORT const char * lib3270_get_log_filename(const H3270 * hSession) { return hSession->log.file; } LIB3270_EXPORT int lib3270_set_log_filename(H3270 * hSession, const char *filename) { if(!hSession) { return EINVAL; } if(hSession->log.file) { lib3270_free(hSession->log.file); } hSession->log.file = NULL; if(filename && *filename) { hSession->log.file = lib3270_strdup(filename); } return 0; } LIB3270_EXPORT void lib3270_set_log_handler(H3270 *session, const LIB3270_LOG_HANDLER handler, void *userdata) { if(session) { session->log.handler = (handler ? handler : loghandler); session->log.userdata = userdata; } else { loghandler = (handler ? handler : default_loghandler); loguserdata = userdata; } } LIB3270_EXPORT int lib3270_write_log(const H3270 *session, const char *module, const char *fmt, ...) { va_list arg_ptr; va_start(arg_ptr, fmt); write_log(session,module ? module : LIB3270_STRINGIZE_VALUE_OF(PRODUCT_NAME),0,fmt,arg_ptr); va_end(arg_ptr); return 0; } LIB3270_EXPORT int lib3270_write_rc(const H3270 *session, const char *module, int rc, const char *fmt, ...) { va_list arg_ptr; va_start(arg_ptr, fmt); write_log(session,module ? module : LIB3270_STRINGIZE_VALUE_OF(PRODUCT_NAME),rc,fmt,arg_ptr); va_end(arg_ptr); return rc; } LIB3270_EXPORT void lib3270_write_va_log(const H3270 *session, const char *module, const char *fmt, va_list arg) { write_log(session,module ? module : LIB3270_STRINGIZE_VALUE_OF(PRODUCT_NAME),0,fmt,arg); }