/**  * Copyright (c) 2018, Timothy Stack  *  * All rights reserved.  *  * Redistribution and use in source and binary forms, with or without  * modification, are permitted provided that the following conditions are met:  *  * * Redistributions of source code must retain the above copyright notice, this  * list of conditions and the following disclaimer.  * * Redistributions in binary form must reproduce the above copyright notice,  * this list of conditions and the following disclaimer in the documentation  * and/or other materials provided with the distribution.  * * Neither the name of Timothy Stack nor the names of its contributors  * may be used to endorse or promote products derived from this software  * without specific prior written permission.  *  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ''AS IS'' AND ANY  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE  * DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.  */ #include "log_level.hh" #include #include "config.h" const char* level_names[LEVEL__MAX + 1] = { "unknown", "trace", "debug5", "debug4", "debug3", "debug2", "debug", "info", "stats", "notice", "warning", "error", "critical", "fatal", "invalid", nullptr, }; log_level_t abbrev2level(const char* levelstr, ssize_t len) { if (len == 0 || levelstr[0] == '\0') { return LEVEL_UNKNOWN; } switch (toupper(levelstr[0])) { case 'T': return LEVEL_TRACE; case 'D': case 'V': if (len > 1) { switch (levelstr[len - 1]) { case '2': return LEVEL_DEBUG2; case '3': return LEVEL_DEBUG3; case '4': return LEVEL_DEBUG4; case '5': return LEVEL_DEBUG5; } } return LEVEL_DEBUG; case 'I': if (len == 7 && toupper(levelstr[1]) == 'N' && toupper(levelstr[2]) == 'V' && toupper(levelstr[3]) == 'A' && toupper(levelstr[4]) == 'L' && toupper(levelstr[5]) == 'I' && toupper(levelstr[6]) == 'D') { return LEVEL_INVALID; } return LEVEL_INFO; case 'S': return LEVEL_STATS; case 'N': return LEVEL_NOTICE; case 'W': return LEVEL_WARNING; case 'E': return LEVEL_ERROR; case 'C': return LEVEL_CRITICAL; case 'F': return LEVEL_FATAL; default: return LEVEL_UNKNOWN; } } int levelcmp(const char* l1, ssize_t l1_len, const char* l2, ssize_t l2_len) { return abbrev2level(l1, l1_len) - abbrev2level(l2, l2_len); }