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