add: logger
This commit is contained in:
parent
f03b3f7fb7
commit
18804da4d8
8 changed files with 159 additions and 39 deletions
|
@ -7,6 +7,9 @@ option(WIRING_PI_DEBUG "Use WiringPi Debugging Tool" OFF)
|
|||
|
||||
SET(CMAKE_C_FLAGS "-Wall -Wextra -lwiringPi -luuid -llmdb -g")
|
||||
|
||||
string(LENGTH "${CMAKE_SOURCE_DIR}/" SOURCE_PATH_SIZE)
|
||||
add_definitions("-DSOURCE_PATH_SIZE=${SOURCE_PATH_SIZE}")
|
||||
|
||||
if(WIRING_PI_DEBUG)
|
||||
add_compile_definitions("WIRING_PI_DEBUG")
|
||||
endif(WIRING_PI_DEBUG)
|
||||
|
@ -16,3 +19,9 @@ aux_source_directory(models MODEL_SRC)
|
|||
|
||||
target_sources(controller PRIVATE ${SRC_DIR} ${MODEL_SRC})
|
||||
target_include_directories(controller PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
||||
|
||||
add_custom_target(run
|
||||
COMMAND controller
|
||||
DEPENDS controller
|
||||
WORKING_DIRECTORY ${CMAKE_PROJECT_DIR}
|
||||
)
|
||||
|
|
18
include/colors.h
Normal file
18
include/colors.h
Normal file
|
@ -0,0 +1,18 @@
|
|||
#ifndef CONTROLLER_COLORS_H
|
||||
#define CONTROLLER_COLORS_H
|
||||
|
||||
#define COLOR_RED "\033[0;31m"
|
||||
#define COLORB_RED "\033[1;31m"
|
||||
#define COLOR_GREEN "\033[0;32m"
|
||||
#define COLORB_GREEN "\033[1;32m"
|
||||
#define COLOR_YELLOW "\033[0;33m"
|
||||
#define COLORB_YELLOW "\033[1;33m"
|
||||
#define COLOR_BLUE "\033[0;34m"
|
||||
#define COLORB_BLUE "\033[1;34m"
|
||||
#define COLOR_MAGENTA "\033[0;35m"
|
||||
#define COLORB_MAGENTA "\033[1;35m"
|
||||
#define COLOR_CYAN "\033[0;36m"
|
||||
#define COLORB_CYAN "\033[1;36m"
|
||||
#define COLOR_NONE "\033[0m"
|
||||
|
||||
#endif //CONTROLLER_COLORS_H
|
|
@ -1,6 +1,8 @@
|
|||
#ifndef CONTROLLER_CONFIG_H
|
||||
#define CONTROLLER_CONFIG_H
|
||||
|
||||
#include <log_levels.h>
|
||||
|
||||
#define CONTROLLER_FILE_NAME "emgauwa-controller.dat"
|
||||
#define CONTROLLER_FILE_VERSION 1
|
||||
#define CONTROLLER_FILE_HEADER_SIZE 4
|
||||
|
@ -12,4 +14,6 @@
|
|||
#define TEST_KEY "blubb"
|
||||
#define TEST_VALUE "bla bla bla"
|
||||
|
||||
#define LOG_LEVEL LOG_LEVEL_TRACE
|
||||
|
||||
#endif //CONTROLLER_CONFIG_H
|
||||
|
|
11
include/log_levels.h
Normal file
11
include/log_levels.h
Normal file
|
@ -0,0 +1,11 @@
|
|||
#ifndef CONTROLLER_LOG_LEVEL_H
|
||||
#define CONTROLLER_LOG_LEVEL_H
|
||||
|
||||
#define LOG_LEVEL_TRACE 5
|
||||
#define LOG_LEVEL_DEBUG 4
|
||||
#define LOG_LEVEL_INFO 3
|
||||
#define LOG_LEVEL_WARN 2
|
||||
#define LOG_LEVEL_ERROR 1
|
||||
#define LOG_LEVEL_FATAL 0
|
||||
|
||||
#endif //CONTROLLER_LOG_LEVEL_H
|
46
include/logger.h
Normal file
46
include/logger.h
Normal file
|
@ -0,0 +1,46 @@
|
|||
#ifndef CONTROLLER_LOGGER_H
|
||||
#define CONTROLLER_LOGGER_H
|
||||
|
||||
#include <colors.h>
|
||||
#include <config.h>
|
||||
#include <macros.h>
|
||||
|
||||
#define _LOGGER_MESSAGE(msg) COLOR_NONE " %s:%s:%d: " msg "\n", __FILENAME__, __func__, __LINE__
|
||||
|
||||
#if LOG_LEVEL >= LOG_LEVEL_TRACE
|
||||
#define LOG_TRACE(msg, ...) printf(COLOR_GREEN "[TRACE]" _LOGGER_MESSAGE(msg), ##__VA_ARGS__)
|
||||
#else
|
||||
#define LOG_TRACE(msg, ...)
|
||||
#endif
|
||||
|
||||
#if LOG_LEVEL >= LOG_LEVEL_DEBUG
|
||||
#define LOG_DEBUG(msg, ...) printf(COLOR_BLUE "[DEBUG]" _LOGGER_MESSAGE(msg), ##__VA_ARGS__)
|
||||
#else
|
||||
#define LOG_DEBUG(msg, ...)
|
||||
#endif
|
||||
|
||||
#if LOG_LEVEL >= LOG_LEVEL_INFO
|
||||
#define LOG_INFO(msg, ...) printf(COLOR_CYAN "[INFO] " _LOGGER_MESSAGE(msg), ##__VA_ARGS__)
|
||||
#else
|
||||
#define LOG_INFO(msg, ...)
|
||||
#endif
|
||||
|
||||
#if LOG_LEVEL >= LOG_LEVEL_WARN
|
||||
#define LOG_WARN(msg, ...) printf(COLOR_YELLOW "[WARN] " _LOGGER_MESSAGE(msg), ##__VA_ARGS__)
|
||||
#else
|
||||
#define LOG_WARN(msg, ...)
|
||||
#endif
|
||||
|
||||
#if LOG_LEVEL >= LOG_LEVEL_ERROR
|
||||
#define LOG_ERROR(msg, ...) printf(COLOR_RED "[ERROR]" _LOGGER_MESSAGE(msg), ##__VA_ARGS__)
|
||||
#else
|
||||
#define LOG_ERROR(msg, ...)
|
||||
#endif
|
||||
|
||||
#if LOG_LEVEL >= LOG_LEVEL_FATAL
|
||||
#define LOG_FATAL(msg, ...) printf(COLOR_MAGENTA "[FATAL]" _LOGGER_MESSAGE(msg), ##__VA_ARGS__)
|
||||
#else
|
||||
#define LOG_FATAL(msg, ...)
|
||||
#endif
|
||||
|
||||
#endif //CONTROLLER_LOGGER_H
|
|
@ -1,6 +1,13 @@
|
|||
#ifndef CONTROLLER_MACROS_H
|
||||
#define CONTROLLER_MACROS_H
|
||||
|
||||
#define LOG_ERROR(msg) printf("ERROR: \"%s\" in function %s in file %s:%d\n", msg, __func__, __FILE__, __LINE__)
|
||||
#include <colors.h>
|
||||
#include <logger.h>
|
||||
|
||||
#ifndef SOURCE_PATH_SIZE
|
||||
#define SOURCE_PATH_SIZE 0
|
||||
#endif
|
||||
|
||||
#define __FILENAME__ (__FILE__ + SOURCE_PATH_SIZE)
|
||||
|
||||
#endif //CONTROLLER_MACROS_H
|
||||
|
|
6
main.c
6
main.c
|
@ -3,6 +3,7 @@
|
|||
#include <stdio.h>
|
||||
#include <lmdb.h>
|
||||
|
||||
#include <logger.h>
|
||||
#include <models/controller.h>
|
||||
|
||||
int
|
||||
|
@ -32,9 +33,8 @@ main(int argc, char** argv)
|
|||
exit(1);
|
||||
}
|
||||
|
||||
controller *this = controller_read(mdb_env);
|
||||
(void)this;
|
||||
//controller_save(this);
|
||||
controller *this_cntrlr = controller_read(mdb_env);
|
||||
controller_save(this_cntrlr, mdb_env);
|
||||
|
||||
mdb_env_close(mdb_env);
|
||||
|
||||
|
|
|
@ -27,11 +27,26 @@ controller_create(void)
|
|||
return result;
|
||||
}
|
||||
|
||||
void
|
||||
controller_read_single(MDB_txn *mdb_txn, MDB_dbi mdb_dbi, controller_db_key key_meta, MDB_val *value)
|
||||
{
|
||||
int err;
|
||||
MDB_val key;
|
||||
|
||||
key.mv_size = sizeof(controller_db_key);
|
||||
key.mv_data = &key_meta;
|
||||
|
||||
if((err = mdb_get(mdb_txn, mdb_dbi, &key, value)) != 0)
|
||||
{
|
||||
fprintf(stderr, "mdb_get error %s\n", mdb_strerror(err));
|
||||
exit(1);
|
||||
}
|
||||
}
|
||||
|
||||
controller*
|
||||
controller_read(MDB_env *mdb_env)
|
||||
{
|
||||
int err;
|
||||
int meta_key_data;
|
||||
MDB_txn *mdb_txn;
|
||||
MDB_dbi mdb_dbi;
|
||||
|
||||
|
@ -59,44 +74,53 @@ controller_read(MDB_env *mdb_env)
|
|||
|
||||
new_controller = malloc(sizeof(*new_controller));
|
||||
|
||||
MDB_val key;
|
||||
MDB_val value;
|
||||
|
||||
key.mv_size = sizeof(controller_db_key);
|
||||
|
||||
meta_key_data = KEY_META_UUID;
|
||||
key.mv_data = &meta_key_data;
|
||||
if((err = mdb_get(mdb_txn, mdb_dbi, &key, &value)) != 0)
|
||||
{
|
||||
fprintf(stderr, "mdb_get error %s\n", mdb_strerror(err));
|
||||
}
|
||||
controller_read_single(mdb_txn, mdb_dbi, KEY_META_UUID, &value);
|
||||
memmove(new_controller->uuid, (uuid_t*)value.mv_data, sizeof(uuid_t));
|
||||
|
||||
meta_key_data = KEY_META_NAME;
|
||||
key.mv_data = &meta_key_data;
|
||||
if((err = mdb_get(mdb_txn, mdb_dbi, &key, &value)) != 0)
|
||||
{
|
||||
fprintf(stderr, "mdb_get error %s\n", mdb_strerror(err));
|
||||
}
|
||||
controller_read_single(mdb_txn, mdb_dbi, KEY_META_NAME, &value);
|
||||
strncpy(new_controller->name, (char*)value.mv_data, CONTROLLER_NAME_LENGTH);
|
||||
new_controller->name[CONTROLLER_NAME_LENGTH] = '\0';
|
||||
|
||||
controller_read_single(mdb_txn, mdb_dbi, KEY_META_PORT, &value);
|
||||
new_controller->port = ((uint16_t*)value.mv_data)[0];
|
||||
|
||||
controller_read_single(mdb_txn, mdb_dbi, KEY_META_RELAY_COUNT, &value);
|
||||
new_controller->relay_count = ((uint8_t*)value.mv_data)[0];
|
||||
|
||||
controller_debug(new_controller);
|
||||
|
||||
mdb_txn_abort(mdb_txn); // transaction is read only
|
||||
|
||||
return NULL;
|
||||
return new_controller;
|
||||
}
|
||||
|
||||
int
|
||||
controller_save_single(MDB_txn *mdb_txn, MDB_dbi mdb_dbi, controller_db_key key_meta, MDB_val value)
|
||||
{
|
||||
int err;
|
||||
|
||||
MDB_val key;
|
||||
key.mv_size = sizeof(controller_db_key);
|
||||
key.mv_data = &key_meta;
|
||||
|
||||
if((err = mdb_put(mdb_txn, mdb_dbi, &key, &value, 0)) != 0)
|
||||
{
|
||||
fprintf(stderr, "mdb_put error %s\n", mdb_strerror(err));
|
||||
mdb_txn_abort(mdb_txn);
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
int
|
||||
controller_save(controller *cntrlr, MDB_env *mdb_env)
|
||||
{
|
||||
int err;
|
||||
int meta_key_data;
|
||||
|
||||
MDB_txn *mdb_txn;
|
||||
MDB_dbi mdb_dbi;
|
||||
MDB_val key;
|
||||
MDB_val value;
|
||||
|
||||
controller_debug(cntrlr);
|
||||
|
@ -113,31 +137,31 @@ controller_save(controller *cntrlr, MDB_env *mdb_env)
|
|||
exit(1);
|
||||
}
|
||||
|
||||
key.mv_size = sizeof(controller_db_key);
|
||||
|
||||
meta_key_data = KEY_META_UUID;
|
||||
key.mv_data = &meta_key_data;
|
||||
|
||||
value.mv_size = sizeof(cntrlr->uuid);
|
||||
value.mv_data = cntrlr->uuid;
|
||||
|
||||
if((err = mdb_put(mdb_txn, mdb_dbi, &key, &value, 0)) != 0)
|
||||
if(controller_save_single(mdb_txn, mdb_dbi, KEY_META_UUID, value))
|
||||
{
|
||||
fprintf(stderr, "mdb_put error %s\n", mdb_strerror(err));
|
||||
mdb_txn_abort(mdb_txn);
|
||||
return 1;
|
||||
}
|
||||
|
||||
meta_key_data = KEY_META_NAME;
|
||||
key.mv_data = &meta_key_data;
|
||||
|
||||
value.mv_size = sizeof(char) * strlen(cntrlr->name);
|
||||
value.mv_data = cntrlr->name;
|
||||
|
||||
if((err = mdb_put(mdb_txn, mdb_dbi, &key, &value, 0)) != 0)
|
||||
if(controller_save_single(mdb_txn, mdb_dbi, KEY_META_NAME, value))
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
|
||||
value.mv_size = sizeof(cntrlr->port);
|
||||
value.mv_data = &cntrlr->port;
|
||||
if(controller_save_single(mdb_txn, mdb_dbi, KEY_META_PORT, value))
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
|
||||
value.mv_size = sizeof(cntrlr->relay_count);
|
||||
value.mv_data = &cntrlr->relay_count;
|
||||
if(controller_save_single(mdb_txn, mdb_dbi, KEY_META_RELAY_COUNT, value))
|
||||
{
|
||||
fprintf(stderr, "mdb_put error %s\n", mdb_strerror(err));
|
||||
mdb_txn_abort(mdb_txn);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -153,4 +177,5 @@ controller_debug(controller *cntrlr)
|
|||
uuid_unparse(cntrlr->uuid, uuid_str);
|
||||
printf("%s @ %p\n", uuid_str, cntrlr);
|
||||
printf("name: %s\n", cntrlr->name);
|
||||
printf("port: %5d relays: %3d\n", cntrlr->port, cntrlr->relay_count);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue