From 9e71c9372d25b699d63a8110ab26a3239ca48cd6 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Fri, 15 Nov 2024 09:23:33 -0500 Subject: Move string utilities to a separate compilation unit These don't really have anything to do with logging. Also replace a call to the non-standard strdup() in the process. --- src/control.c | 4 ++-- src/jack.c | 1 + src/jalv.c | 1 + src/jalv_console.c | 1 + src/log.c | 25 ------------------------- src/log.h | 8 -------- src/state.c | 1 + src/string_utils.c | 30 ++++++++++++++++++++++++++++++ src/string_utils.h | 21 +++++++++++++++++++++ 9 files changed, 57 insertions(+), 35 deletions(-) create mode 100644 src/string_utils.c create mode 100644 src/string_utils.h (limited to 'src') diff --git a/src/control.c b/src/control.c index d663078..451eac5 100644 --- a/src/control.c +++ b/src/control.c @@ -4,6 +4,7 @@ #include "control.h" #include "log.h" +#include "string_utils.h" #include "lilv/lilv.h" #include "lv2/atom/atom.h" @@ -13,7 +14,6 @@ #include #include #include -#include /// Order scale points by value static int @@ -89,7 +89,7 @@ new_port_control(LilvWorld* const world, id->points[np].value = lilv_node_as_float(lilv_scale_point_get_value(p)); id->points[np].label = - strdup(lilv_node_as_string(lilv_scale_point_get_label(p))); + jalv_strdup(lilv_node_as_string(lilv_scale_point_get_label(p))); ++np; } // TODO: Non-float scale points? diff --git a/src/jack.c b/src/jack.c index 0199df5..e6ed812 100644 --- a/src/jack.c +++ b/src/jack.c @@ -9,6 +9,7 @@ #include "log.h" #include "lv2_evbuf.h" #include "port.h" +#include "string_utils.h" #include "types.h" #include "lilv/lilv.h" diff --git a/src/jalv.c b/src/jalv.c index 8f927a2..44536e3 100644 --- a/src/jalv.c +++ b/src/jalv.c @@ -11,6 +11,7 @@ #include "nodes.h" #include "port.h" #include "state.h" +#include "string_utils.h" #include "types.h" #include "urids.h" #include "worker.h" diff --git a/src/jalv_console.c b/src/jalv_console.c index bda894c..2ca69b3 100644 --- a/src/jalv_console.c +++ b/src/jalv_console.c @@ -9,6 +9,7 @@ #include "options.h" #include "port.h" #include "state.h" +#include "string_utils.h" #include "types.h" #include "lilv/lilv.h" diff --git a/src/log.c b/src/log.c index 95f0949..7de6e70 100644 --- a/src/log.c +++ b/src/log.c @@ -18,8 +18,6 @@ #include #include #include -#include -#include void jalv_print_control(const Jalv* const jalv, @@ -30,29 +28,6 @@ jalv_print_control(const Jalv* const jalv, jalv_log(JALV_LOG_INFO, "%s = %f\n", lilv_node_as_string(sym), value); } -char* -jalv_strdup(const char* const str) -{ - const size_t len = strlen(str); - char* copy = (char*)malloc(len + 1); - memcpy(copy, str, len + 1); - return copy; -} - -char* -jalv_strjoin(const char* const a, const char* const b) -{ - const size_t a_len = strlen(a); - const size_t b_len = strlen(b); - char* const out = (char*)malloc(a_len + b_len + 1); - - memcpy(out, a, a_len); - memcpy(out + a_len, b, b_len); - out[a_len + b_len] = '\0'; - - return out; -} - JALV_LOG_FUNC(2, 0) static int jalv_vlog(const JalvLogLevel level, const char* const fmt, va_list ap) diff --git a/src/log.h b/src/log.h index e4dd546..8b67727 100644 --- a/src/log.h +++ b/src/log.h @@ -42,14 +42,6 @@ typedef struct { void jalv_print_control(const Jalv* jalv, const struct Port* port, float value); -/// Return a newly allocated copy of a string -char* -jalv_strdup(const char* str); - -/// Return a newly allocated concatenation of two strings -char* -jalv_strjoin(const char* a, const char* b); - /// Print a log message to stderr with a GCC-like prefix and color JALV_LOG_FUNC(2, 3) int diff --git a/src/state.c b/src/state.c index 26c5c20..5bc781c 100644 --- a/src/state.c +++ b/src/state.c @@ -6,6 +6,7 @@ #include "jalv_internal.h" #include "log.h" #include "port.h" +#include "string_utils.h" #include "lilv/lilv.h" #include "lv2/core/lv2.h" diff --git a/src/string_utils.c b/src/string_utils.c new file mode 100644 index 0000000..a690eb1 --- /dev/null +++ b/src/string_utils.c @@ -0,0 +1,30 @@ +// Copyright 2007-2022 David Robillard +// SPDX-License-Identifier: ISC + +#include "string_utils.h" + +#include +#include + +char* +jalv_strdup(const char* const str) +{ + const size_t len = strlen(str); + char* copy = (char*)malloc(len + 1); + memcpy(copy, str, len + 1); + return copy; +} + +char* +jalv_strjoin(const char* const a, const char* const b) +{ + const size_t a_len = strlen(a); + const size_t b_len = strlen(b); + char* const out = (char*)malloc(a_len + b_len + 1); + + memcpy(out, a, a_len); + memcpy(out + a_len, b, b_len); + out[a_len + b_len] = '\0'; + + return out; +} diff --git a/src/string_utils.h b/src/string_utils.h new file mode 100644 index 0000000..53f09fd --- /dev/null +++ b/src/string_utils.h @@ -0,0 +1,21 @@ +// Copyright 2007-2022 David Robillard +// SPDX-License-Identifier: ISC + +#ifndef JALV_STRING_UTILS_H +#define JALV_STRING_UTILS_H + +#include "attributes.h" + +JALV_BEGIN_DECLS + +/// Return a newly allocated copy of a string +char* +jalv_strdup(const char* str); + +/// Return a newly allocated concatenation of two strings +char* +jalv_strjoin(const char* a, const char* b); + +JALV_END_DECLS + +#endif // JALV_STRING_UTILS_H -- cgit v1.2.1