1 /* 2 * Copyright (c) 2016, 2021, Oracle and/or its affiliates. 3 * 4 * This program is free software; you can redistribute it and/or modify 5 * it under the terms of the GNU General Public License, version 2.0, 6 * as published by the Free Software Foundation. 7 * 8 * This program is also distributed with certain software (including 9 * but not limited to OpenSSL) that is licensed under separate terms, 10 * as designated in a particular file or component or in included license 11 * documentation. The authors of MySQL hereby grant you an additional 12 * permission to link the program and your derivative works with the 13 * separately licensed software that they have included with MySQL. 14 * 15 * This program is distributed in the hope that it will be useful, 16 * but WITHOUT ANY WARRANTY; without even the implied warranty of 17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18 * GNU General Public License, version 2.0, for more details. 19 * 20 * You should have received a copy of the GNU General Public License 21 * along with this program; if not, write to the Free Software 22 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 23 * 02110-1301 USA 24 */ 25 26 27 #ifndef _XPL_LOG_H_ 28 #define _XPL_LOG_H_ 29 30 #ifndef XPLUGIN_DISABLE_LOG 31 32 #include <mysql/plugin.h> 33 #include <mysql/service_my_plugin_log.h> 34 35 namespace xpl 36 { 37 38 extern MYSQL_PLUGIN plugin_handle; 39 40 void plugin_log_message(MYSQL_PLUGIN *p, const plugin_log_level, const char *); 41 42 } // namespace xpl 43 44 #define log_error(...)\ 45 my_plugin_log_message(&xpl::plugin_handle, MY_ERROR_LEVEL, __VA_ARGS__) 46 47 48 #define log_warning(...)\ 49 my_plugin_log_message(&xpl::plugin_handle, MY_WARNING_LEVEL, __VA_ARGS__) 50 51 52 #define log_info(...)\ 53 my_plugin_log_message(&xpl::plugin_handle, MY_INFORMATION_LEVEL, __VA_ARGS__) 54 55 56 #ifdef XPLUGIN_LOG_DEBUG 57 #define log_debug(...) my_plugin_log_message(&xpl::plugin_handle, MY_INFORMATION_LEVEL, __VA_ARGS__) 58 #else 59 #define log_debug(...) do {} while(0) 60 #endif 61 62 63 #else // XPLUGIN_DISABLE_LOG 64 65 66 #define log_debug(...) do {} while(0) 67 #define log_info(...) do {} while(0) 68 #define log_warning(...) do {} while(0) 69 #define log_error(...) do {} while(0) 70 71 72 #endif // XPLUGIN_DISABLE_LOG 73 74 75 #endif // _XPL_LOG_H_ 76