ObjectivelyMVC 0.1.0
Object oriented MVC framework for OpenGL, SDL2 and GNU C
Log.h
Go to the documentation of this file.
1/*
2 * ObjectivelyMVC: Object oriented MVC framework for OpenGL, SDL2 and GNU C.
3 * Copyright (C) 2014 Jay Dolan <jay@jaydolan.com>
4 *
5 * This software is provided 'as-is', without any express or implied
6 * warranty. In no event will the authors be held liable for any damages
7 * arising from the use of this software.
8 *
9 * Permission is granted to anyone to use this software for any purpose,
10 * including commercial applications, and to alter it and redistribute it
11 * freely, subject to the following restrictions:
12 *
13 * 1. The origin of this software must not be misrepresented; you must not
14 * claim that you wrote the original software. If you use this software
15 * in a product, an acknowledgment in the product documentation would be
16 * appreciated but is not required.
17 *
18 * 2. Altered source versions must be plainly marked as such, and must not be
19 * misrepresented as being the original software.
20 *
21 * 3. This notice may not be removed or altered from any source distribution.
22 */
23
24#pragma once
25
26#include <SDL_log.h>
27
33#define LOG_CATEGORY_MVC (SDL_LOG_CATEGORY_CUSTOM + 69)
34
35#define MVC_LogSetPriority(priority) SDL_LogSetPriority(LOG_CATEGORY_MVC, priority)
36
37#define MVC_LogEnabled(priority) \
38 (SDL_LogGetPriority(LOG_CATEGORY_MVC) <= priority)
39
40#define MVC_LogMessage(priority, fmt, ...) \
41 SDL_LogMessage(LOG_CATEGORY_MVC, priority, "%s:%s "fmt, _Class()->def.name, __func__, ## __VA_ARGS__)
42
43#define MVC_LogVerbose(fmt, ...) \
44 SDL_LogVerbose(LOG_CATEGORY_MVC, "%s:%s: "fmt, _Class()->def.name, __func__, ## __VA_ARGS__)
45
46#define MVC_LogDebug(fmt, ...) \
47 SDL_LogDebug(LOG_CATEGORY_MVC, "%s:%s: "fmt, _Class()->def.name, __func__, ## __VA_ARGS__)
48
49#define MVC_LogInfo(fmt, ...) \
50 SDL_LogInfo(LOG_CATEGORY_MVC, "%s:%s: "fmt, _Class()->def.name, __func__, ## __VA_ARGS__)
51
52#define MVC_LogWarn(fmt, ...) \
53 SDL_LogWarn(LOG_CATEGORY_MVC, "%s:%s: "fmt, _Class()->def.name, __func__, ## __VA_ARGS__)
54
55#define MVC_LogError(fmt, ...) \
56 SDL_LogError(LOG_CATEGORY_MVC, "%s:%s: "fmt, _Class()->def.name, __func__, ## __VA_ARGS__)
57
58#define MVC_LogCritical(fmt, ...) \
59 SDL_LogCritical(LOG_CATEGORY_MVC, "%s:%s: "fmt, _Class()->def.name, __func__, ## __VA_ARGS__)