1*c217d954SCole Faust /*
2*c217d954SCole Faust * Copyright (c) 2017 Arm Limited.
3*c217d954SCole Faust *
4*c217d954SCole Faust * SPDX-License-Identifier: MIT
5*c217d954SCole Faust *
6*c217d954SCole Faust * Permission is hereby granted, free of charge, to any person obtaining a copy
7*c217d954SCole Faust * of this software and associated documentation files (the "Software"), to
8*c217d954SCole Faust * deal in the Software without restriction, including without limitation the
9*c217d954SCole Faust * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10*c217d954SCole Faust * sell copies of the Software, and to permit persons to whom the Software is
11*c217d954SCole Faust * furnished to do so, subject to the following conditions:
12*c217d954SCole Faust *
13*c217d954SCole Faust * The above copyright notice and this permission notice shall be included in all
14*c217d954SCole Faust * copies or substantial portions of the Software.
15*c217d954SCole Faust *
16*c217d954SCole Faust * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*c217d954SCole Faust * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18*c217d954SCole Faust * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19*c217d954SCole Faust * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20*c217d954SCole Faust * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21*c217d954SCole Faust * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22*c217d954SCole Faust * SOFTWARE.
23*c217d954SCole Faust */
24*c217d954SCole Faust #include "Exceptions.h"
25*c217d954SCole Faust
26*c217d954SCole Faust #include "Utils.h"
27*c217d954SCole Faust
28*c217d954SCole Faust #include <map>
29*c217d954SCole Faust #include <sstream>
30*c217d954SCole Faust
31*c217d954SCole Faust namespace arm_compute
32*c217d954SCole Faust {
33*c217d954SCole Faust namespace test
34*c217d954SCole Faust {
35*c217d954SCole Faust namespace framework
36*c217d954SCole Faust {
log_level_from_name(const std::string & name)37*c217d954SCole Faust LogLevel log_level_from_name(const std::string &name)
38*c217d954SCole Faust {
39*c217d954SCole Faust static const std::map<std::string, LogLevel> levels =
40*c217d954SCole Faust {
41*c217d954SCole Faust { "none", LogLevel::NONE },
42*c217d954SCole Faust { "config", LogLevel::CONFIG },
43*c217d954SCole Faust { "tests", LogLevel::TESTS },
44*c217d954SCole Faust { "errors", LogLevel::ERRORS },
45*c217d954SCole Faust { "debug", LogLevel::DEBUG },
46*c217d954SCole Faust { "measurements", LogLevel::MEASUREMENTS },
47*c217d954SCole Faust { "all", LogLevel::ALL },
48*c217d954SCole Faust };
49*c217d954SCole Faust
50*c217d954SCole Faust try
51*c217d954SCole Faust {
52*c217d954SCole Faust return levels.at(tolower(name));
53*c217d954SCole Faust }
54*c217d954SCole Faust catch(const std::out_of_range &)
55*c217d954SCole Faust {
56*c217d954SCole Faust throw std::invalid_argument(name);
57*c217d954SCole Faust }
58*c217d954SCole Faust }
59*c217d954SCole Faust
operator >>(::std::istream & stream,LogLevel & level)60*c217d954SCole Faust ::std::istream &operator>>(::std::istream &stream, LogLevel &level)
61*c217d954SCole Faust {
62*c217d954SCole Faust std::string value;
63*c217d954SCole Faust stream >> value;
64*c217d954SCole Faust level = log_level_from_name(value);
65*c217d954SCole Faust return stream;
66*c217d954SCole Faust }
67*c217d954SCole Faust
operator <<(::std::ostream & stream,LogLevel level)68*c217d954SCole Faust ::std::ostream &operator<<(::std::ostream &stream, LogLevel level)
69*c217d954SCole Faust {
70*c217d954SCole Faust switch(level)
71*c217d954SCole Faust {
72*c217d954SCole Faust case LogLevel::NONE:
73*c217d954SCole Faust stream << "NONE";
74*c217d954SCole Faust break;
75*c217d954SCole Faust case LogLevel::CONFIG:
76*c217d954SCole Faust stream << "CONFIG";
77*c217d954SCole Faust break;
78*c217d954SCole Faust case LogLevel::TESTS:
79*c217d954SCole Faust stream << "TESTS";
80*c217d954SCole Faust break;
81*c217d954SCole Faust case LogLevel::ERRORS:
82*c217d954SCole Faust stream << "ERRORS";
83*c217d954SCole Faust break;
84*c217d954SCole Faust case LogLevel::DEBUG:
85*c217d954SCole Faust stream << "DEBUG";
86*c217d954SCole Faust break;
87*c217d954SCole Faust case LogLevel::MEASUREMENTS:
88*c217d954SCole Faust stream << "MEASUREMENTS";
89*c217d954SCole Faust break;
90*c217d954SCole Faust case LogLevel::ALL:
91*c217d954SCole Faust stream << "ALL";
92*c217d954SCole Faust break;
93*c217d954SCole Faust default:
94*c217d954SCole Faust throw std::invalid_argument("Unsupported log level");
95*c217d954SCole Faust }
96*c217d954SCole Faust
97*c217d954SCole Faust return stream;
98*c217d954SCole Faust }
99*c217d954SCole Faust
to_string(LogLevel level)100*c217d954SCole Faust std::string to_string(LogLevel level)
101*c217d954SCole Faust {
102*c217d954SCole Faust std::stringstream stream;
103*c217d954SCole Faust stream << level;
104*c217d954SCole Faust return stream.str();
105*c217d954SCole Faust }
106*c217d954SCole Faust
FileNotFound(const std::string & msg)107*c217d954SCole Faust FileNotFound::FileNotFound(const std::string &msg)
108*c217d954SCole Faust : std::runtime_error{ msg }
109*c217d954SCole Faust {
110*c217d954SCole Faust }
111*c217d954SCole Faust
TestError(const std::string & msg,LogLevel level,std::string context)112*c217d954SCole Faust TestError::TestError(const std::string &msg, LogLevel level, std::string context)
113*c217d954SCole Faust : std::runtime_error{ msg }, _level{ level }, _msg{ msg }, _context{ std::move(context) }, _combined{ "ERROR: " + msg }
114*c217d954SCole Faust {
115*c217d954SCole Faust if(!_context.empty())
116*c217d954SCole Faust {
117*c217d954SCole Faust _combined += "\nCONTEXT:\n" + _context;
118*c217d954SCole Faust }
119*c217d954SCole Faust }
120*c217d954SCole Faust
level() const121*c217d954SCole Faust LogLevel TestError::level() const
122*c217d954SCole Faust {
123*c217d954SCole Faust return _level;
124*c217d954SCole Faust }
125*c217d954SCole Faust
what() const126*c217d954SCole Faust const char *TestError::what() const noexcept
127*c217d954SCole Faust {
128*c217d954SCole Faust return _combined.c_str();
129*c217d954SCole Faust }
130*c217d954SCole Faust
131*c217d954SCole Faust } // namespace framework
132*c217d954SCole Faust } // namespace test
133*c217d954SCole Faust } // namespace arm_compute
134