diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/jack.c | 100 | ||||
-rw-r--r-- | src/jack_impl.h | 23 | ||||
-rw-r--r-- | src/jack_internal.c | 109 |
3 files changed, 133 insertions, 99 deletions
@@ -5,6 +5,7 @@ #include "comm.h" #include "frontend.h" +#include "jack_impl.h" #include "jalv.h" #include "jalv_config.h" #include "log.h" @@ -30,7 +31,6 @@ # include <jack/metadata.h> #endif -#include <ctype.h> #include <stdbool.h> #include <stdint.h> #include <stdio.h> @@ -43,22 +43,9 @@ # define REALTIME #endif -struct JalvBackendImpl { - jack_client_t* client; ///< Jack client - bool is_internal_client; ///< Running inside jackd -}; - /// Maximum supported latency in frames (at most 2^24 so all integers work) static const float max_latency = 16777216.0f; -/// Internal Jack client initialization entry point -int -jack_initialize(jack_client_t* client, const char* load_init); - -/// Internal Jack client finalization entry point -void -jack_finish(void* arg); - /// Jack buffer size callback static int jack_buffer_size_cb(jack_nframes_t nframes, void* data) @@ -492,88 +479,3 @@ jalv_backend_recompute_latencies(Jalv* const jalv) { jack_recompute_total_latencies(jalv->backend->client); } - -int -jack_initialize(jack_client_t* const client, const char* const load_init) -{ -#ifndef E2BIG -# define E2BIG 7 -#endif -#ifndef ENOMEM -# define ENOMEM 12 -#endif - - const size_t args_len = strlen(load_init); - if (args_len > JACK_LOAD_INIT_LIMIT) { - jalv_log(JALV_LOG_ERR, "Too many arguments given\n"); - return E2BIG; - } - - Jalv* const jalv = (Jalv*)calloc(1, sizeof(Jalv)); - if (!jalv) { - return ENOMEM; - } - - if (!(jalv->backend = jalv_backend_allocate())) { - free(jalv); - return ENOMEM; - } - - jalv->backend->client = client; - jalv->backend->is_internal_client = true; - - // Build full command line with "program" name for building argv - const size_t cmd_len = strlen("jalv ") + args_len; - char* const cmd = (char*)calloc(cmd_len + 1, 1); - memcpy(cmd, "jalv ", strlen("jalv ") + 1); - memcpy(cmd + 5, load_init, args_len + 1); - - // Build argv - int argc = 0; - char** argv = NULL; - char* tok = cmd; - int err = 0; - for (size_t i = 0; !err && i <= cmd_len; ++i) { - if (isspace(cmd[i]) || !cmd[i]) { - char** const new_argv = (char**)realloc(argv, sizeof(char*) * ++argc); - if (!new_argv) { - err = ENOMEM; - break; - } - - argv = new_argv; - cmd[i] = '\0'; - argv[argc - 1] = tok; - tok = cmd + i + 1; - } - } - - if (err || (err = jalv_open(jalv, &argc, &argv))) { - jalv_close(jalv); - free(jalv); - } else { - jalv_activate(jalv); - } - - free(argv); - free(cmd); - return err; - -#undef ENOMEM -#undef E2BIG -} - -void -jack_finish(void* const arg) -{ - Jalv* const jalv = (Jalv*)arg; - if (jalv) { - jalv_deactivate(jalv); - if (jalv_close(jalv)) { - jalv_log(JALV_LOG_ERR, "Failed to close Jalv\n"); - } - - jalv_backend_free(jalv->backend); - free(jalv); - } -} diff --git a/src/jack_impl.h b/src/jack_impl.h new file mode 100644 index 0000000..0ecd3eb --- /dev/null +++ b/src/jack_impl.h @@ -0,0 +1,23 @@ +// Copyright 2007-2024 David Robillard <d@drobilla.net> +// SPDX-License-Identifier: ISC + +#ifndef JALV_JACK_IMPL_H +#define JALV_JACK_IMPL_H + +#include "attributes.h" + +#include <jack/jack.h> + +#include <stdbool.h> + +// Definition of Jack backend structure (private to implementation) +JALV_BEGIN_DECLS + +struct JalvBackendImpl { + jack_client_t* client; ///< Jack client + bool is_internal_client; ///< Running inside jackd +}; + +JALV_END_DECLS + +#endif // JALV_JACK_IMPL_H diff --git a/src/jack_internal.c b/src/jack_internal.c new file mode 100644 index 0000000..5157e43 --- /dev/null +++ b/src/jack_internal.c @@ -0,0 +1,109 @@ +// Copyright 2007-2024 David Robillard <d@drobilla.net> +// SPDX-License-Identifier: ISC + +#include "backend.h" +#include "jack_impl.h" +#include "jalv.h" +#include "log.h" +#include "types.h" + +#include <jack/types.h> + +#include <ctype.h> +#include <stdbool.h> +#include <stdio.h> +#include <stdlib.h> +#include <string.h> + +/// Internal Jack client initialization entry point +int +jack_initialize(jack_client_t* client, const char* load_init); + +/// Internal Jack client finalization entry point +void +jack_finish(void* arg); + +int +jack_initialize(jack_client_t* const client, const char* const load_init) +{ +#ifndef E2BIG +# define E2BIG 7 +#endif +#ifndef ENOMEM +# define ENOMEM 12 +#endif + + const size_t args_len = strlen(load_init); + if (args_len > JACK_LOAD_INIT_LIMIT) { + jalv_log(JALV_LOG_ERR, "Too many arguments given\n"); + return E2BIG; + } + + Jalv* const jalv = (Jalv*)calloc(1, sizeof(Jalv)); + if (!jalv) { + return ENOMEM; + } + + if (!(jalv->backend = jalv_backend_allocate())) { + free(jalv); + return ENOMEM; + } + + jalv->backend->client = client; + jalv->backend->is_internal_client = true; + + // Build full command line with "program" name for building argv + const size_t cmd_len = strlen("jalv ") + args_len; + char* const cmd = (char*)calloc(cmd_len + 1, 1); + memcpy(cmd, "jalv ", strlen("jalv ") + 1); + memcpy(cmd + 5, load_init, args_len + 1); + + // Build argv + int argc = 0; + char** argv = NULL; + char* tok = cmd; + int err = 0; + for (size_t i = 0; !err && i <= cmd_len; ++i) { + if (isspace(cmd[i]) || !cmd[i]) { + char** const new_argv = (char**)realloc(argv, sizeof(char*) * ++argc); + if (!new_argv) { + err = ENOMEM; + break; + } + + argv = new_argv; + cmd[i] = '\0'; + argv[argc - 1] = tok; + tok = cmd + i + 1; + } + } + + if (err || (err = jalv_open(jalv, &argc, &argv))) { + jalv_close(jalv); + free(jalv); + } else { + jalv_activate(jalv); + } + + free(argv); + free(cmd); + return err; + +#undef ENOMEM +#undef E2BIG +} + +void +jack_finish(void* const arg) +{ + Jalv* const jalv = (Jalv*)arg; + if (jalv) { + jalv_deactivate(jalv); + if (jalv_close(jalv)) { + jalv_log(JALV_LOG_ERR, "Failed to close Jalv\n"); + } + + jalv_backend_free(jalv->backend); + free(jalv); + } +} |