From bfe42327cab38b3e47a3b2afec53ea8edd4b1531 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Tue, 4 Aug 2020 16:22:16 +0200 Subject: Remove lilv_dir_path() This function was weird. Instead, to make a directory path with trailing separator, join nothing as in Python. --- src/filesystem.c | 21 +-------------------- src/filesystem.h | 4 ---- src/state.c | 6 +++--- 3 files changed, 4 insertions(+), 27 deletions(-) diff --git a/src/filesystem.c b/src/filesystem.c index 45ece12..a12dcba 100644 --- a/src/filesystem.c +++ b/src/filesystem.c @@ -170,7 +170,7 @@ char* lilv_path_join(const char* a, const char* b) { if (!a) { - return lilv_strdup(b); + return (b && b[0]) ? lilv_strdup(b) : NULL; } const size_t a_len = strlen(a); @@ -187,25 +187,6 @@ lilv_path_join(const char* a, const char* b) return path; } -char* -lilv_dir_path(const char* path) -{ - if (!path) { - return NULL; - } - - const size_t len = strlen(path); - - if (lilv_is_dir_sep(path[len - 1])) { - return lilv_strdup(path); - } - - char* dir_path = (char*)calloc(len + 2, 1); - memcpy(dir_path, path, len); - dir_path[len] = LILV_DIR_SEP[0]; - return dir_path; -} - char* lilv_path_canonical(const char* path) { diff --git a/src/filesystem.h b/src/filesystem.h index eb00e60..1b29d42 100644 --- a/src/filesystem.h +++ b/src/filesystem.h @@ -56,10 +56,6 @@ lilv_path_parent(const char* path); char* lilv_path_join(const char* a, const char* b); -/// Return `path` normalized to have a trailing directory separator -char* -lilv_dir_path(const char* path); - /** Return `path` as a canonicalized absolute path. diff --git a/src/state.c b/src/state.c index 85e8d0f..2b7cde9 100644 --- a/src/state.c +++ b/src/state.c @@ -539,7 +539,7 @@ set_state_dir_from_model(LilvState* state, const SordNode* graph) const char* uri = (const char*)sord_node_get_string(graph); char* path = lilv_file_uri_parse(uri, NULL); - state->dir = lilv_dir_path(path); + state->dir = lilv_path_join(path, NULL); free(path); } assert(!state->dir || lilv_path_is_absolute(state->dir)); @@ -559,7 +559,7 @@ new_state_from_model(LilvWorld* world, // Allocate state LilvState* const state = (LilvState*)calloc(1, sizeof(LilvState)); - state->dir = lilv_dir_path(dir); + state->dir = lilv_path_join(dir, NULL); state->atom_Path = map->map(map->handle, LV2_ATOM__Path); state->uri = lilv_node_new_from_node(world, node); @@ -727,7 +727,7 @@ lilv_state_new_from_file(LilvWorld* world, char* dirname = lilv_path_parent(path); char* real_path = lilv_path_canonical(dirname); - char* dir_path = lilv_dir_path(real_path); + char* dir_path = lilv_path_join(real_path, NULL); LilvState* state = new_state_from_model(world, map, model, subject_node, dir_path); free(dir_path); -- cgit v1.2.1