2015-04-16 13:22:58 -04:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2015 Moritz Grimm <mgrimm@mrsserver.net>
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, and distribute this software for any
|
|
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
|
|
* copyright notice and this permission notice appear in all copies.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __LOG_H__
|
|
|
|
#define __LOG_H__
|
|
|
|
|
|
|
|
#include "attributes.h"
|
|
|
|
|
|
|
|
enum log_levels {
|
|
|
|
ALERT,
|
|
|
|
ERROR,
|
|
|
|
WARNING,
|
|
|
|
NOTICE,
|
|
|
|
INFO,
|
|
|
|
DEBUG
|
|
|
|
};
|
|
|
|
|
Refactor configuration (work in progress)
* Move -m and -n command line options into the config file
* Restructure configuration file:
- Group into "server", "stream", "media", "metadata", "decoders", and
"encoders"
- Untangle decoder and encoder:
o Decoders match on file extensions and convert to a canonical "internal"
format
o Encoders create one of the supported stream formats, potentially using
different parameters (like bitrate)
- Consistently specify stream format
- Enable reencoding by selecting an encoder
* Architecturally separate configuration file storage from parsing
- Allows for different configuration back-ends in the future, like
YAML, SQL, REST API, ...
* Support roll-back in case of error on (re)load
* Anticipate HTTPS support
2015-05-02 06:48:53 -04:00
|
|
|
int log_init(void);
|
2015-04-16 13:22:58 -04:00
|
|
|
void log_exit(void);
|
|
|
|
|
|
|
|
void log_syserr(enum log_levels, int, const char *);
|
|
|
|
|
|
|
|
void log_alert(const char *, ...)
|
|
|
|
ATTRIBUTE_NONNULL(1)
|
|
|
|
ATTRIBUTE_FORMAT(printf, 1, 2);
|
|
|
|
void log_error(const char *, ...)
|
|
|
|
ATTRIBUTE_NONNULL(1)
|
|
|
|
ATTRIBUTE_FORMAT(printf, 1, 2);
|
|
|
|
void log_warning(const char *, ...)
|
|
|
|
ATTRIBUTE_NONNULL(1)
|
|
|
|
ATTRIBUTE_FORMAT(printf, 1, 2);
|
|
|
|
void log_notice(const char *, ...)
|
|
|
|
ATTRIBUTE_NONNULL(1)
|
|
|
|
ATTRIBUTE_FORMAT(printf, 1, 2);
|
|
|
|
void log_info(const char *, ...)
|
|
|
|
ATTRIBUTE_NONNULL(1)
|
|
|
|
ATTRIBUTE_FORMAT(printf, 1, 2);
|
|
|
|
void log_debug(const char *, ...)
|
|
|
|
ATTRIBUTE_NONNULL(1)
|
|
|
|
ATTRIBUTE_FORMAT(printf, 1, 2);
|
|
|
|
|
|
|
|
#endif /* __LOG_H__ */
|