新增mk_ini配置文件相关接口

This commit is contained in:
ziyue 2023-02-11 11:39:26 +08:00
parent b3ba6d4214
commit 9629dbd969
4 changed files with 178 additions and 7 deletions

View File

@ -117,6 +117,7 @@ API_EXPORT void API_CALL mk_set_log(int file_max_size, int file_max_count);
/** /**
* *
* @deprecated 使mk_ini_set_option替代
* @param key * @param key
* @param val * @param val
*/ */
@ -124,6 +125,7 @@ API_EXPORT void API_CALL mk_set_option(const char *key, const char *val);
/** /**
* *
* @deprecated 使mk_ini_get_option替代
* @param key * @param key
*/ */
API_EXPORT const char * API_CALL mk_get_option(const char *key); API_EXPORT const char * API_CALL mk_get_option(const char *key);

View File

@ -18,16 +18,21 @@
extern "C" { extern "C" {
#endif #endif
/**
* mk api内部malloc的资源
*/
API_EXPORT void API_CALL mk_free(void *ptr);
/** /**
* *
* @return 使free * @return 使mk_free
*/ */
API_EXPORT char* API_CALL mk_util_get_exe_path(); API_EXPORT char* API_CALL mk_util_get_exe_path();
/** /**
* *
* @param relative_path ,null * @param relative_path ,null
* @return 使free * @return 使mk_free
*/ */
API_EXPORT char* API_CALL mk_util_get_exe_dir(const char *relative_path); API_EXPORT char* API_CALL mk_util_get_exe_dir(const char *relative_path);
@ -40,7 +45,7 @@ API_EXPORT uint64_t API_CALL mk_util_get_current_millisecond();
/** /**
* *
* @param fmt %Y-%m-%d %H:%M:%S * @param fmt %Y-%m-%d %H:%M:%S
* @return 使free * @return 使mk_free
*/ */
API_EXPORT char* API_CALL mk_util_get_current_time_string(const char *fmt); API_EXPORT char* API_CALL mk_util_get_current_time_string(const char *fmt);
@ -48,9 +53,82 @@ API_EXPORT char* API_CALL mk_util_get_current_time_string(const char *fmt);
* *
* @param buf * @param buf
* @param len * @param len
* @return 使free * @return 使mk_free
*/ */
API_EXPORT char* API_CALL mk_util_hex_dump(const void *buf, int len); API_EXPORT char* API_CALL mk_util_hex_dump(const void *buf, int len);
///////////////////////////////////////////mk ini/////////////////////////////////////////////
typedef void* mk_ini;
/**
* ini配置对象
*/
API_EXPORT mk_ini API_CALL mk_ini_create();
/**
* ini配置
* @return ini配置mk_ini_release释放它
*/
API_EXPORT mk_ini API_CALL mk_ini_default();
/**
* ini配置文件内容
* @param ini ini对象
* @param str
*/
API_EXPORT void API_CALL mk_ini_load_string(mk_ini ini, const char *str);
/**
* ini配置文件
* @param ini ini对象
* @param file
*/
API_EXPORT void API_CALL mk_ini_load_file(mk_ini ini, const char *file);
/**
* ini配置对象
*/
API_EXPORT void API_CALL mk_ini_release(mk_ini ini);
/**
*
* @param ini
* @param key field.key
* @param value
*/
API_EXPORT void API_CALL mk_ini_set_option(mk_ini ini, const char *key, const char *value);
API_EXPORT void API_CALL mk_ini_set_option_int(mk_ini ini, const char *key, int value);
/**
*
* @param ini
* @param key field.key
* @return NULL
*/
API_EXPORT const char *API_CALL mk_ini_get_option(mk_ini ini, const char *key);
/**
*
* @param ini
* @param key field.key
* @return 1: 0:
*/
API_EXPORT int API_CALL mk_ini_del_option(mk_ini ini, const char *key);
/**
*
* @param ini
* @return mk_free
*/
API_EXPORT char *API_CALL mk_ini_dump_string(mk_ini ini);
/**
*
* @param ini
* @param file
*/
API_EXPORT void API_CALL mk_ini_dump_file(mk_ini ini, const char *file);
///////////////////////////////////////////日志///////////////////////////////////////////// ///////////////////////////////////////////日志/////////////////////////////////////////////
/** /**
@ -67,9 +145,9 @@ API_EXPORT void API_CALL mk_log_printf(int level, const char *file, const char *
// 以下宏可以替换printf使用 // 以下宏可以替换printf使用
#define log_printf(lev, ...) mk_log_printf(lev, __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__) #define log_printf(lev, ...) mk_log_printf(lev, __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__)
#define log_trace(...) log_printf(0, ##__VA_ARGS__) #define log_trace(...) log_printf(0, ##__VA_ARGS__)
#define log_debug(...) log_printf(1, ##__VA_ARGS__) #define log_debug(...) log_printf(1, ##__VA_ARGS__)
#define log_info(...) log_printf(2, ##__VA_ARGS__) #define log_info(...) log_printf(2, ##__VA_ARGS__)
#define log_warn(...) log_printf(3, ##__VA_ARGS__) #define log_warn(...) log_printf(3, ##__VA_ARGS__)
#define log_error(...) log_printf(4, ##__VA_ARGS__) #define log_error(...) log_printf(4, ##__VA_ARGS__)
#ifdef __cplusplus #ifdef __cplusplus

View File

@ -158,6 +158,8 @@ API_EXPORT void API_CALL mk_set_option(const char *key, const char *val) {
return; return;
} }
mINI::Instance()[key] = val; mINI::Instance()[key] = val;
//广播配置文件热加载
NoticeCenter::Instance().emitEvent(Broadcast::kBroadcastReloadConfig);
} }
API_EXPORT const char * API_CALL mk_get_option(const char *key) API_EXPORT const char * API_CALL mk_get_option(const char *key)

View File

@ -13,15 +13,22 @@
#include "mk_util.h" #include "mk_util.h"
#include "Util/util.h" #include "Util/util.h"
#include "Util/mini.h"
#include "Util/logger.h" #include "Util/logger.h"
#include "Common/config.h"
using namespace std; using namespace std;
using namespace toolkit; using namespace toolkit;
using namespace mediakit;
#ifndef _WIN32 #ifndef _WIN32
#define _strdup strdup #define _strdup strdup
#endif #endif
API_EXPORT void API_CALL mk_free(void *ptr) {
free(ptr);
}
API_EXPORT char* API_CALL mk_util_get_exe_path(){ API_EXPORT char* API_CALL mk_util_get_exe_path(){
return _strdup(exePath().data()); return _strdup(exePath().data());
} }
@ -47,6 +54,88 @@ API_EXPORT char* API_CALL mk_util_hex_dump(const void *buf, int len){
return _strdup(hexdump(buf,len).data()); return _strdup(hexdump(buf,len).data());
} }
API_EXPORT mk_ini API_CALL mk_ini_create() {
return new mINI;
}
API_EXPORT mk_ini API_CALL mk_ini_default() {
return &(mINI::Instance());
}
static void emit_ini_file_reload(mk_ini ini) {
if (ini == mk_ini_default()) {
// 广播配置文件热加载
NoticeCenter::Instance().emitEvent(Broadcast::kBroadcastReloadConfig);
}
}
API_EXPORT void API_CALL mk_ini_load_string(mk_ini ini, const char *str) {
assert(str);
auto ptr = (mINI *)ini;
ptr->parse(str);
emit_ini_file_reload(ini);
}
API_EXPORT void API_CALL mk_ini_load_file(mk_ini ini, const char *file) {
assert(file);
auto ptr = (mINI *)ini;
ptr->parseFile(file);
emit_ini_file_reload(ini);
}
API_EXPORT void API_CALL mk_ini_release(mk_ini ini) {
assert(ini);
delete (mINI *)ini;
}
API_EXPORT void API_CALL mk_ini_set_option(mk_ini ini, const char *key, const char *value) {
assert(ini && key && value);
auto ptr = (mINI *)ini;
(*ptr)[key] = value;
emit_ini_file_reload(ini);
}
API_EXPORT void API_CALL mk_ini_set_option_int(mk_ini ini, const char *key, int value) {
assert(ini && key);
auto ptr = (mINI *)ini;
(*ptr)[key] = value;
emit_ini_file_reload(ini);
}
API_EXPORT const char *API_CALL mk_ini_get_option(mk_ini ini, const char *key) {
assert(ini && key);
auto ptr = (mINI *)ini;
auto it = ptr->find(key);
if (it == ptr->end()) {
return nullptr;
}
return it->second.data();
}
API_EXPORT int API_CALL mk_ini_del_option(mk_ini ini, const char *key) {
assert(ini && key);
auto ptr = (mINI *)ini;
auto it = ptr->find(key);
if (it == ptr->end()) {
return false;
}
ptr->erase(it);
emit_ini_file_reload(ini);
return true;
}
API_EXPORT char *API_CALL mk_ini_dump_string(mk_ini ini) {
assert(ini);
auto ptr = (mINI *)ini;
return _strdup(ptr->dump().data());
}
API_EXPORT void API_CALL mk_ini_dump_file(mk_ini ini, const char *file) {
assert(ini && file);
auto ptr = (mINI *)ini;
ptr->dumpFile(file);
}
API_EXPORT void API_CALL mk_log_printf(int level, const char *file, const char *function, int line, const char *fmt, ...) { API_EXPORT void API_CALL mk_log_printf(int level, const char *file, const char *function, int line, const char *fmt, ...) {
va_list ap; va_list ap;
va_start(ap, fmt); va_start(ap, fmt);