From 0c5d6ea9cbde99f3e7eef9ba66c1aa18e7c56f59 Mon Sep 17 00:00:00 2001 From: Igor Khanin Date: Wed, 20 Dec 2023 17:30:23 +0200 Subject: [PATCH 1/2] Support runtime pluggable logging callback Allow setting up a callback function that receives logging messages, with the current behavior of printing to stdout and stderr as a default. --- include/logging/logging.h | 33 +++++++++++++ include/logging/logging_t.h | 16 ------- src/common/Makefile | 6 +-- .../cosigner/asymmetric_eddsa_cosigner.cpp | 2 +- .../asymmetric_eddsa_cosigner_client.cpp | 2 +- .../asymmetric_eddsa_cosigner_server.cpp | 2 +- .../cmp_ecdsa_offline_signing_service.cpp | 2 +- .../cmp_ecdsa_online_signing_service.cpp | 2 +- .../cosigner/cmp_ecdsa_signing_service.cpp | 2 +- .../cosigner/cmp_offline_refresh_service.cpp | 2 +- src/common/cosigner/cmp_setup_service.cpp | 2 +- src/common/cosigner/cosigner_exception.cpp | 2 +- .../cosigner/eddsa_online_signing_service.cpp | 2 +- src/common/cosigner/mta.cpp | 2 +- src/common/cosigner/utils.cpp | 2 +- src/common/lib.lds | 1 + src/common/logging/logging.c | 46 +++++++++++++++++++ 17 files changed, 95 insertions(+), 31 deletions(-) create mode 100644 include/logging/logging.h delete mode 100644 include/logging/logging_t.h create mode 100644 src/common/logging/logging.c diff --git a/include/logging/logging.h b/include/logging/logging.h new file mode 100644 index 0000000..939ae67 --- /dev/null +++ b/include/logging/logging.h @@ -0,0 +1,33 @@ +#pragma once + +typedef enum { + COSIGNER_LOG_LEVEL_FATAL = 50000, + COSIGNER_LOG_LEVEL_ERROR = 40000, + COSIGNER_LOG_LEVEL_WARN = 30000, + COSIGNER_LOG_LEVEL_INFO = 20000, + COSIGNER_LOG_LEVEL_DEBUG = 10000, + COSIGNER_LOG_LEVEL_TRACE = 5000, +} COSIGNER_LOG_LEVEL; + +typedef void (*cosigner_log_callback)(int level, const char* file, int line, const char* func, const char* message, void* userp); + +#ifdef __cplusplus +extern "C" { +#endif //__cplusplus + +void cosigner_log_init(cosigner_log_callback cb, void* userp); + +void cosigner_log_msg(int level, const char* file, int line, const char* func, const char* message, ...) + __attribute__ ((format (printf, 5, 6))); + +#ifdef __cplusplus +} +#endif //__cplusplus + +#define LOG(level, message, ...) cosigner_log_msg((level), __FILE__, __LINE__, __func__, (message), ##__VA_ARGS__) +#define LOG_TRACE(message, ...) LOG(COSIGNER_LOG_LEVEL_TRACE, message, ##__VA_ARGS__) +#define LOG_DEBUG(message, ...) LOG(COSIGNER_LOG_LEVEL_DEBUG, message, ##__VA_ARGS__) +#define LOG_INFO(message, ...) LOG(COSIGNER_LOG_LEVEL_INFO, message, ##__VA_ARGS__) +#define LOG_WARN(message, ...) LOG(COSIGNER_LOG_LEVEL_WARN, message, ##__VA_ARGS__) +#define LOG_ERROR(message, ...) LOG(COSIGNER_LOG_LEVEL_ERROR, message, ##__VA_ARGS__) +#define LOG_FATAL(message, ...) LOG(COSIGNER_LOG_LEVEL_FATAL, message, ##__VA_ARGS__) diff --git a/include/logging/logging_t.h b/include/logging/logging_t.h deleted file mode 100644 index 8c8c5de..0000000 --- a/include/logging/logging_t.h +++ /dev/null @@ -1,16 +0,0 @@ -// This file can be replaced with other logging system integration - -#ifndef LOGGING_T_H_ -#define LOGGING_T_H_ - -#include - -#define LOG(level, message, ...) do {printf((message), ##__VA_ARGS__);putchar('\n');} while(0) -#define LOG_DEBUG(message, ...) do {printf((message), ##__VA_ARGS__);putchar('\n');} while(0) -#define LOG_TRACE(message, ...) do {printf((message), ##__VA_ARGS__);putchar('\n');} while(0) -#define LOG_INFO(message, ...) do {printf((message), ##__VA_ARGS__);putchar('\n');} while(0) -#define LOG_WARN(message, ...) do {printf((message), ##__VA_ARGS__);putchar('\n');} while(0) -#define LOG_ERROR(message, ...) do {fprintf(stderr, (message), ##__VA_ARGS__);putchar('\n');} while(0) -#define LOG_FATAL(message, ...) do {fprintf(stderr, (message), ##__VA_ARGS__);putchar('\n');} while(0) - -#endif diff --git a/src/common/Makefile b/src/common/Makefile index cd68bb6..fddb99a 100644 --- a/src/common/Makefile +++ b/src/common/Makefile @@ -11,9 +11,9 @@ endif COMMON_CFLAGS := $(COMMON_CFLAGS) C_Files := crypto/shamir_secret_sharing/verifiable_secret_sharing.c crypto/paillier/paillier.c crypto/paillier/paillier_zkp.c crypto/GFp_curve_algebra/GFp_curve_algebra.c \ - crypto/commitments/commitments.c crypto/zero_knowledge_proof/schnorr.c crypto/zero_knowledge_proof/range_proofs.c crypto/zero_knowledge_proof/diffie_hellman_log.c \ - crypto/commitments/ring_pedersen.c crypto/ed25519_algebra/ed25519_algebra.c crypto/drng/drng.c crypto/keccak1600/keccak1600.c - + crypto/commitments/commitments.c crypto/zero_knowledge_proof/schnorr.c crypto/zero_knowledge_proof/range_proofs.c crypto/zero_knowledge_proof/diffie_hellman_log.c \ + crypto/commitments/ring_pedersen.c crypto/ed25519_algebra/ed25519_algebra.c crypto/drng/drng.c crypto/keccak1600/keccak1600.c logging/logging.c + C_Objects := $(C_Files:.c=.o) Cpp_Files := cosigner/cosigner_exception.cpp cosigner/cmp_setup_service.cpp cosigner/cmp_offline_refresh_service.cpp cosigner/utils.cpp \ diff --git a/src/common/cosigner/asymmetric_eddsa_cosigner.cpp b/src/common/cosigner/asymmetric_eddsa_cosigner.cpp index 1a72722..09f6203 100644 --- a/src/common/cosigner/asymmetric_eddsa_cosigner.cpp +++ b/src/common/cosigner/asymmetric_eddsa_cosigner.cpp @@ -2,7 +2,7 @@ #include "cosigner/cmp_key_persistency.h" #include "cosigner/cosigner_exception.h" #include "cosigner/platform_service.h" -#include "logging/logging_t.h" +#include "logging/logging.h" #include diff --git a/src/common/cosigner/asymmetric_eddsa_cosigner_client.cpp b/src/common/cosigner/asymmetric_eddsa_cosigner_client.cpp index ea01267..d824ad4 100644 --- a/src/common/cosigner/asymmetric_eddsa_cosigner_client.cpp +++ b/src/common/cosigner/asymmetric_eddsa_cosigner_client.cpp @@ -3,7 +3,7 @@ #include "cosigner/cosigner_exception.h" #include "cosigner/platform_service.h" #include "cosigner/mpc_globals.h" -#include "logging/logging_t.h" +#include "logging/logging.h" #include "utils.h" #include diff --git a/src/common/cosigner/asymmetric_eddsa_cosigner_server.cpp b/src/common/cosigner/asymmetric_eddsa_cosigner_server.cpp index 362cad9..dc30d6e 100644 --- a/src/common/cosigner/asymmetric_eddsa_cosigner_server.cpp +++ b/src/common/cosigner/asymmetric_eddsa_cosigner_server.cpp @@ -4,7 +4,7 @@ #include "cosigner/platform_service.h" #include "cosigner/mpc_globals.h" #include "utils.h" -#include "logging/logging_t.h" +#include "logging/logging.h" #include diff --git a/src/common/cosigner/cmp_ecdsa_offline_signing_service.cpp b/src/common/cosigner/cmp_ecdsa_offline_signing_service.cpp index 0109a86..0bedf6e 100644 --- a/src/common/cosigner/cmp_ecdsa_offline_signing_service.cpp +++ b/src/common/cosigner/cmp_ecdsa_offline_signing_service.cpp @@ -6,7 +6,7 @@ #include "utils.h" #include "crypto/GFp_curve_algebra/GFp_curve_algebra.h" #include "crypto/zero_knowledge_proof/range_proofs.h" -#include "logging/logging_t.h" +#include "logging/logging.h" namespace fireblocks { diff --git a/src/common/cosigner/cmp_ecdsa_online_signing_service.cpp b/src/common/cosigner/cmp_ecdsa_online_signing_service.cpp index 21bb43a..899ab52 100644 --- a/src/common/cosigner/cmp_ecdsa_online_signing_service.cpp +++ b/src/common/cosigner/cmp_ecdsa_online_signing_service.cpp @@ -6,7 +6,7 @@ #include "crypto/GFp_curve_algebra/GFp_curve_algebra.h" #include "crypto/zero_knowledge_proof/range_proofs.h" #include "utils.h" -#include "logging/logging_t.h" +#include "logging/logging.h" namespace fireblocks { diff --git a/src/common/cosigner/cmp_ecdsa_signing_service.cpp b/src/common/cosigner/cmp_ecdsa_signing_service.cpp index 7278a82..1a9d158 100644 --- a/src/common/cosigner/cmp_ecdsa_signing_service.cpp +++ b/src/common/cosigner/cmp_ecdsa_signing_service.cpp @@ -4,7 +4,7 @@ #include "crypto/GFp_curve_algebra/GFp_curve_algebra.h" #include "crypto/zero_knowledge_proof/diffie_hellman_log.h" #include "crypto/zero_knowledge_proof/range_proofs.h" -#include "logging/logging_t.h" +#include "logging/logging.h" #include diff --git a/src/common/cosigner/cmp_offline_refresh_service.cpp b/src/common/cosigner/cmp_offline_refresh_service.cpp index 7e5c5b9..b752e67 100644 --- a/src/common/cosigner/cmp_offline_refresh_service.cpp +++ b/src/common/cosigner/cmp_offline_refresh_service.cpp @@ -6,7 +6,7 @@ #include "cosigner/platform_service.h" #include "cosigner/prf.h" #include "crypto/elliptic_curve_algebra/elliptic_curve256_algebra.h" -#include "logging/logging_t.h" +#include "logging/logging.h" namespace fireblocks { diff --git a/src/common/cosigner/cmp_setup_service.cpp b/src/common/cosigner/cmp_setup_service.cpp index 8bf373d..0594b17 100644 --- a/src/common/cosigner/cmp_setup_service.cpp +++ b/src/common/cosigner/cmp_setup_service.cpp @@ -2,7 +2,7 @@ #include "cosigner/cosigner_exception.h" #include "utils.h" #include "crypto/zero_knowledge_proof/schnorr.h" -#include "logging/logging_t.h" +#include "logging/logging.h" #include diff --git a/src/common/cosigner/cosigner_exception.cpp b/src/common/cosigner/cosigner_exception.cpp index 32b9f15..6fc99f2 100644 --- a/src/common/cosigner/cosigner_exception.cpp +++ b/src/common/cosigner/cosigner_exception.cpp @@ -1,6 +1,6 @@ #include "cosigner/cosigner_exception.h" #include "crypto/paillier/paillier.h" -#include "logging/logging_t.h" +#include "logging/logging.h" namespace fireblocks { diff --git a/src/common/cosigner/eddsa_online_signing_service.cpp b/src/common/cosigner/eddsa_online_signing_service.cpp index 8bb4f91..4aaa8aa 100644 --- a/src/common/cosigner/eddsa_online_signing_service.cpp +++ b/src/common/cosigner/eddsa_online_signing_service.cpp @@ -4,7 +4,7 @@ #include "cosigner/mpc_globals.h" #include "cosigner/platform_service.h" #include "utils.h" -#include "logging/logging_t.h" +#include "logging/logging.h" extern "C" int gettimeofday(struct timeval *tv, struct timezone *tz); diff --git a/src/common/cosigner/mta.cpp b/src/common/cosigner/mta.cpp index 3d3a088..0b078c0 100644 --- a/src/common/cosigner/mta.cpp +++ b/src/common/cosigner/mta.cpp @@ -6,7 +6,7 @@ #include "../crypto/paillier/paillier_internal.h" #ifndef TEST_ONLY -#include "logging/logging_t.h" +#include "logging/logging.h" #else #define LOG_ERROR(message, ...) printf((message), ##__VA_ARGS__);putchar('\n') #endif diff --git a/src/common/cosigner/utils.cpp b/src/common/cosigner/utils.cpp index e9b220b..50d735b 100644 --- a/src/common/cosigner/utils.cpp +++ b/src/common/cosigner/utils.cpp @@ -2,7 +2,7 @@ #include "cosigner/cmp_key_persistency.h" #include "cosigner/cosigner_exception.h" #include "cosigner/platform_service.h" -#include "logging/logging_t.h" +#include "logging/logging.h" namespace fireblocks { diff --git a/src/common/lib.lds b/src/common/lib.lds index b4d420f..d52fbff 100644 --- a/src/common/lib.lds +++ b/src/common/lib.lds @@ -14,6 +14,7 @@ libcosigner.so range_proof_*; schnorr_zkp_*; derive_*; + cosigner_log_*; _ZN10fireblocks6common8cosigner17*; _ZN10fireblocks6common8cosigner2*; _ZN10fireblocks6common8cosigner32*; diff --git a/src/common/logging/logging.c b/src/common/logging/logging.c new file mode 100644 index 0000000..0c08ca0 --- /dev/null +++ b/src/common/logging/logging.c @@ -0,0 +1,46 @@ +#include "logging/logging.h" + +#include +#include + +#define MAX_LOG_SIZE 4096 + +static void default_log_callback(int level, const char* file, int line, const char* func, const char* message, void* userp) +{ + (void)file; + (void)line; + (void)func; + (void)userp; + + if (level >= COSIGNER_LOG_LEVEL_ERROR) + fprintf(stderr, "%s\n", message); + else + printf("%s\n", message); +} + +static cosigner_log_callback log_callback = default_log_callback; +static void* log_callback_user_data_pointer = NULL; + +void cosigner_log_init(cosigner_log_callback cb, void* userp) +{ + log_callback = cb; + log_callback_user_data_pointer = userp; +} + +void cosigner_log_msg(int level, const char* file, int line, const char* func, const char* message, ...) +{ + va_list args; + char buffer[MAX_LOG_SIZE] = { '\0' }; + + if (log_callback == NULL) + return; + + if (message != NULL) + { + va_start(args, message); + vsnprintf(buffer, MAX_LOG_SIZE, message, args); + va_end(args); + } + + log_callback(level, file, line, func, buffer, log_callback_user_data_pointer); +} From 1dd05ccfe4bdea65ff845256ea192a738262f1cf Mon Sep 17 00:00:00 2001 From: Igor Khanin Date: Thu, 21 Dec 2023 10:05:19 +0200 Subject: [PATCH 2/2] Revert file name to logging_t --- include/logging/{logging.h => logging_t.h} | 0 src/common/Makefile | 2 +- src/common/cosigner/asymmetric_eddsa_cosigner.cpp | 2 +- src/common/cosigner/asymmetric_eddsa_cosigner_client.cpp | 2 +- src/common/cosigner/asymmetric_eddsa_cosigner_server.cpp | 2 +- src/common/cosigner/cmp_ecdsa_offline_signing_service.cpp | 2 +- src/common/cosigner/cmp_ecdsa_online_signing_service.cpp | 2 +- src/common/cosigner/cmp_ecdsa_signing_service.cpp | 2 +- src/common/cosigner/cmp_offline_refresh_service.cpp | 2 +- src/common/cosigner/cmp_setup_service.cpp | 2 +- src/common/cosigner/cosigner_exception.cpp | 2 +- src/common/cosigner/eddsa_online_signing_service.cpp | 2 +- src/common/cosigner/mta.cpp | 2 +- src/common/cosigner/utils.cpp | 2 +- src/common/logging/{logging.c => logging_t.c} | 2 +- 15 files changed, 14 insertions(+), 14 deletions(-) rename include/logging/{logging.h => logging_t.h} (100%) rename src/common/logging/{logging.c => logging_t.c} (97%) diff --git a/include/logging/logging.h b/include/logging/logging_t.h similarity index 100% rename from include/logging/logging.h rename to include/logging/logging_t.h diff --git a/src/common/Makefile b/src/common/Makefile index fddb99a..d1eb327 100644 --- a/src/common/Makefile +++ b/src/common/Makefile @@ -12,7 +12,7 @@ COMMON_CFLAGS := $(COMMON_CFLAGS) C_Files := crypto/shamir_secret_sharing/verifiable_secret_sharing.c crypto/paillier/paillier.c crypto/paillier/paillier_zkp.c crypto/GFp_curve_algebra/GFp_curve_algebra.c \ crypto/commitments/commitments.c crypto/zero_knowledge_proof/schnorr.c crypto/zero_knowledge_proof/range_proofs.c crypto/zero_knowledge_proof/diffie_hellman_log.c \ - crypto/commitments/ring_pedersen.c crypto/ed25519_algebra/ed25519_algebra.c crypto/drng/drng.c crypto/keccak1600/keccak1600.c logging/logging.c + crypto/commitments/ring_pedersen.c crypto/ed25519_algebra/ed25519_algebra.c crypto/drng/drng.c crypto/keccak1600/keccak1600.c logging/logging_t.c C_Objects := $(C_Files:.c=.o) diff --git a/src/common/cosigner/asymmetric_eddsa_cosigner.cpp b/src/common/cosigner/asymmetric_eddsa_cosigner.cpp index 09f6203..1a72722 100644 --- a/src/common/cosigner/asymmetric_eddsa_cosigner.cpp +++ b/src/common/cosigner/asymmetric_eddsa_cosigner.cpp @@ -2,7 +2,7 @@ #include "cosigner/cmp_key_persistency.h" #include "cosigner/cosigner_exception.h" #include "cosigner/platform_service.h" -#include "logging/logging.h" +#include "logging/logging_t.h" #include diff --git a/src/common/cosigner/asymmetric_eddsa_cosigner_client.cpp b/src/common/cosigner/asymmetric_eddsa_cosigner_client.cpp index d824ad4..ea01267 100644 --- a/src/common/cosigner/asymmetric_eddsa_cosigner_client.cpp +++ b/src/common/cosigner/asymmetric_eddsa_cosigner_client.cpp @@ -3,7 +3,7 @@ #include "cosigner/cosigner_exception.h" #include "cosigner/platform_service.h" #include "cosigner/mpc_globals.h" -#include "logging/logging.h" +#include "logging/logging_t.h" #include "utils.h" #include diff --git a/src/common/cosigner/asymmetric_eddsa_cosigner_server.cpp b/src/common/cosigner/asymmetric_eddsa_cosigner_server.cpp index dc30d6e..362cad9 100644 --- a/src/common/cosigner/asymmetric_eddsa_cosigner_server.cpp +++ b/src/common/cosigner/asymmetric_eddsa_cosigner_server.cpp @@ -4,7 +4,7 @@ #include "cosigner/platform_service.h" #include "cosigner/mpc_globals.h" #include "utils.h" -#include "logging/logging.h" +#include "logging/logging_t.h" #include diff --git a/src/common/cosigner/cmp_ecdsa_offline_signing_service.cpp b/src/common/cosigner/cmp_ecdsa_offline_signing_service.cpp index 0bedf6e..0109a86 100644 --- a/src/common/cosigner/cmp_ecdsa_offline_signing_service.cpp +++ b/src/common/cosigner/cmp_ecdsa_offline_signing_service.cpp @@ -6,7 +6,7 @@ #include "utils.h" #include "crypto/GFp_curve_algebra/GFp_curve_algebra.h" #include "crypto/zero_knowledge_proof/range_proofs.h" -#include "logging/logging.h" +#include "logging/logging_t.h" namespace fireblocks { diff --git a/src/common/cosigner/cmp_ecdsa_online_signing_service.cpp b/src/common/cosigner/cmp_ecdsa_online_signing_service.cpp index 899ab52..21bb43a 100644 --- a/src/common/cosigner/cmp_ecdsa_online_signing_service.cpp +++ b/src/common/cosigner/cmp_ecdsa_online_signing_service.cpp @@ -6,7 +6,7 @@ #include "crypto/GFp_curve_algebra/GFp_curve_algebra.h" #include "crypto/zero_knowledge_proof/range_proofs.h" #include "utils.h" -#include "logging/logging.h" +#include "logging/logging_t.h" namespace fireblocks { diff --git a/src/common/cosigner/cmp_ecdsa_signing_service.cpp b/src/common/cosigner/cmp_ecdsa_signing_service.cpp index 1a9d158..7278a82 100644 --- a/src/common/cosigner/cmp_ecdsa_signing_service.cpp +++ b/src/common/cosigner/cmp_ecdsa_signing_service.cpp @@ -4,7 +4,7 @@ #include "crypto/GFp_curve_algebra/GFp_curve_algebra.h" #include "crypto/zero_knowledge_proof/diffie_hellman_log.h" #include "crypto/zero_knowledge_proof/range_proofs.h" -#include "logging/logging.h" +#include "logging/logging_t.h" #include diff --git a/src/common/cosigner/cmp_offline_refresh_service.cpp b/src/common/cosigner/cmp_offline_refresh_service.cpp index b752e67..7e5c5b9 100644 --- a/src/common/cosigner/cmp_offline_refresh_service.cpp +++ b/src/common/cosigner/cmp_offline_refresh_service.cpp @@ -6,7 +6,7 @@ #include "cosigner/platform_service.h" #include "cosigner/prf.h" #include "crypto/elliptic_curve_algebra/elliptic_curve256_algebra.h" -#include "logging/logging.h" +#include "logging/logging_t.h" namespace fireblocks { diff --git a/src/common/cosigner/cmp_setup_service.cpp b/src/common/cosigner/cmp_setup_service.cpp index 0594b17..8bf373d 100644 --- a/src/common/cosigner/cmp_setup_service.cpp +++ b/src/common/cosigner/cmp_setup_service.cpp @@ -2,7 +2,7 @@ #include "cosigner/cosigner_exception.h" #include "utils.h" #include "crypto/zero_knowledge_proof/schnorr.h" -#include "logging/logging.h" +#include "logging/logging_t.h" #include diff --git a/src/common/cosigner/cosigner_exception.cpp b/src/common/cosigner/cosigner_exception.cpp index 6fc99f2..32b9f15 100644 --- a/src/common/cosigner/cosigner_exception.cpp +++ b/src/common/cosigner/cosigner_exception.cpp @@ -1,6 +1,6 @@ #include "cosigner/cosigner_exception.h" #include "crypto/paillier/paillier.h" -#include "logging/logging.h" +#include "logging/logging_t.h" namespace fireblocks { diff --git a/src/common/cosigner/eddsa_online_signing_service.cpp b/src/common/cosigner/eddsa_online_signing_service.cpp index 4aaa8aa..8bb4f91 100644 --- a/src/common/cosigner/eddsa_online_signing_service.cpp +++ b/src/common/cosigner/eddsa_online_signing_service.cpp @@ -4,7 +4,7 @@ #include "cosigner/mpc_globals.h" #include "cosigner/platform_service.h" #include "utils.h" -#include "logging/logging.h" +#include "logging/logging_t.h" extern "C" int gettimeofday(struct timeval *tv, struct timezone *tz); diff --git a/src/common/cosigner/mta.cpp b/src/common/cosigner/mta.cpp index 0b078c0..3d3a088 100644 --- a/src/common/cosigner/mta.cpp +++ b/src/common/cosigner/mta.cpp @@ -6,7 +6,7 @@ #include "../crypto/paillier/paillier_internal.h" #ifndef TEST_ONLY -#include "logging/logging.h" +#include "logging/logging_t.h" #else #define LOG_ERROR(message, ...) printf((message), ##__VA_ARGS__);putchar('\n') #endif diff --git a/src/common/cosigner/utils.cpp b/src/common/cosigner/utils.cpp index 50d735b..e9b220b 100644 --- a/src/common/cosigner/utils.cpp +++ b/src/common/cosigner/utils.cpp @@ -2,7 +2,7 @@ #include "cosigner/cmp_key_persistency.h" #include "cosigner/cosigner_exception.h" #include "cosigner/platform_service.h" -#include "logging/logging.h" +#include "logging/logging_t.h" namespace fireblocks { diff --git a/src/common/logging/logging.c b/src/common/logging/logging_t.c similarity index 97% rename from src/common/logging/logging.c rename to src/common/logging/logging_t.c index 0c08ca0..ec1da77 100644 --- a/src/common/logging/logging.c +++ b/src/common/logging/logging_t.c @@ -1,4 +1,4 @@ -#include "logging/logging.h" +#include "logging/logging_t.h" #include #include