76cfb8d60d125c348c3e8fc33dbca5a9f33fadb9
[platform/core/ml/nnfw.git] / runtime / onert / core / include / util / logging.h
1 /*
2  * Copyright (c) 2018 Samsung Electronics Co., Ltd. All Rights Reserved
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 #ifndef __ONERT_UTIL_LOGGING_H__
18 #define __ONERT_UTIL_LOGGING_H__
19
20 #include <iostream>
21
22 #include "util/ConfigSource.h"
23
24 namespace onert
25 {
26 namespace util
27 {
28 namespace logging
29 {
30
31 class Context
32 {
33 public:
34   Context() noexcept : _enabled{false}
35   {
36     const auto env = util::getConfigBool(util::config::ONERT_LOG_ENABLE);
37
38     if (env)
39     {
40       _enabled = true;
41     }
42   }
43
44   static Context &get() noexcept;
45
46 public:
47   bool enabled(void) const { return _enabled; }
48
49 private:
50   bool _enabled;
51 };
52
53 static Context &ctx = Context::get();
54
55 } // namespace logging
56 } // namespace util
57 } // namespace onert
58
59 #define VERBOSE(name)                        \
60   if (::onert::util::logging::ctx.enabled()) \
61   std::cout << "[" << #name << "] "
62
63 #define VERBOSE_F()                          \
64   if (::onert::util::logging::ctx.enabled()) \
65   std::cout << "[" << __func__ << "] "
66
67 #endif // __ONERT_UTIL_LOGGING_H__