diff options
author | David Robillard <d@drobilla.net> | 2024-01-09 17:21:28 -0500 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2024-01-09 17:28:24 -0500 |
commit | e30c50d87ac7c2bc663074839ce12a9ac5796de7 (patch) | |
tree | 342e39bc6f20ba79d67c16907a03d0a414caf674 | |
parent | 81bd78db915bc0d11f23386e49ffe29968ded486 (diff) | |
download | lilv-e30c50d87ac7c2bc663074839ce12a9ac5796de7.tar.gz lilv-e30c50d87ac7c2bc663074839ce12a9ac5796de7.tar.bz2 lilv-e30c50d87ac7c2bc663074839ce12a9ac5796de7.zip |
Fix potential null dereferences and conversion warnings
A few of these can't actually happen, but that's opaque to static analysis, so
appease clang-tidy with casts since the checks are too valuable to suppress.
-rw-r--r-- | NEWS | 3 | ||||
-rw-r--r-- | meson/suppressions/meson.build | 1 | ||||
-rw-r--r-- | src/state.c | 32 | ||||
-rw-r--r-- | test/test_state.c | 9 |
4 files changed, 29 insertions, 16 deletions
@@ -1,8 +1,9 @@ lilv (0.24.23) unstable; urgency=medium * Fix null dereference when trying to load state from a missing file + * Fix potential null dereferences and conversion warnings - -- David Robillard <d@drobilla.net> Tue, 09 Jan 2024 22:24:29 +0000 + -- David Robillard <d@drobilla.net> Tue, 09 Jan 2024 22:28:10 +0000 lilv (0.24.22) stable; urgency=medium diff --git a/meson/suppressions/meson.build b/meson/suppressions/meson.build index 52cb15d..d05af9e 100644 --- a/meson/suppressions/meson.build +++ b/meson/suppressions/meson.build @@ -24,7 +24,6 @@ if cc.get_id() in ['clang', 'emscripten'] '-Wno-format-nonliteral', '-Wno-implicit-float-conversion', '-Wno-implicit-int-conversion', - '-Wno-nullable-to-nonnull-conversion', '-Wno-padded', '-Wno-reserved-id-macro', '-Wno-shorten-64-to-32', diff --git a/src/state.c b/src/state.c index cc4d950..91f65ad 100644 --- a/src/state.c +++ b/src/state.c @@ -766,7 +766,7 @@ lilv_state_new_from_file(LilvWorld* world, SordModel* model = sord_new(world->world, SORD_SPO, false); SerdReader* reader = sord_new_reader(model, env, SERD_TURTLE, NULL); - serd_reader_read_file(reader, node.buf); + serd_reader_read_file(reader, (const uint8_t*)node.buf); SordNode* subject_node = (subject) ? subject->node @@ -837,7 +837,7 @@ ttl_writer(SerdSink sink, void* stream, const SerdNode* base, SerdEnv** new_env) { SerdURI base_uri = SERD_URI_NULL; if (base && base->buf) { - serd_uri_parse(base->buf, &base_uri); + serd_uri_parse((const uint8_t*)base->buf, &base_uri); } SerdEnv* env = *new_env ? *new_env : serd_env_new(base); @@ -914,11 +914,12 @@ write_manifest(LilvWorld* world, { (void)world; - char* const path = (char*)serd_file_uri_parse(file_uri->buf, NULL); - FILE* const wfd = fopen(path, "w"); + char* const path = + (char*)serd_file_uri_parse((const uint8_t*)file_uri->buf, NULL); + + FILE* const wfd = path ? fopen(path, "w") : NULL; if (!wfd) { LILV_ERRORF("Failed to open %s for writing (%s)\n", path, strerror(errno)); - serd_free(path); return 1; } @@ -944,10 +945,11 @@ add_state_to_manifest(LilvWorld* lworld, SerdEnv* env = serd_env_new(&manifest); SordModel* model = sord_new(world, SORD_SPO, false); - if (zix_file_type(manifest_path) == ZIX_FILE_TYPE_REGULAR) { + const uint8_t* const manifest_uri = manifest.buf; + if (manifest_uri && zix_file_type(manifest_path) == ZIX_FILE_TYPE_REGULAR) { // Read manifest into model SerdReader* reader = sord_new_reader(model, env, SERD_TURTLE, NULL); - SerdStatus st = serd_reader_read_file(reader, manifest.buf); + SerdStatus st = serd_reader_read_file(reader, manifest_uri); if (st) { LILV_WARNF("Failed to read manifest (%s)\n", serd_strerror(st)); } @@ -1032,8 +1034,8 @@ link_exists(const char* path, const void* data) return false; } - char* real_path = zix_canonical_path(NULL, path); - bool matches = !strcmp(real_path, target); + char* const real_path = zix_canonical_path(NULL, path); + const bool matches = real_path && !strcmp(real_path, target); zix_free(NULL, real_path); return !matches; } @@ -1213,7 +1215,7 @@ lilv_state_make_links(const LilvState* state, const char* dir) const PathMap* const pm = (const PathMap*)zix_tree_get(i); char* const path = zix_path_join(NULL, dir, pm->rel); - if (path_is_child(pm->abs, state->copy_dir) && + if (state->copy_dir && path_is_child(pm->abs, state->copy_dir) && !!strcmp(state->copy_dir, dir)) { // Link directly to snapshot in the copy directory maybe_symlink(pm->abs, path); @@ -1263,9 +1265,13 @@ lilv_state_save(LilvWorld* world, return 1; } - char* abs_dir = zix_canonical_path(NULL, dir); - char* const path = zix_path_join(NULL, abs_dir, filename); - FILE* fd = fopen(path, "w"); + char* const abs_dir = zix_canonical_path(NULL, dir); + if (!abs_dir) { + return 2; + } + + char* const path = zix_path_join(NULL, abs_dir, filename); + FILE* fd = path ? fopen(path, "w") : NULL; if (!fd) { LILV_ERRORF("Failed to open %s (%s)\n", path, strerror(errno)); zix_free(NULL, abs_dir); diff --git a/test/test_state.c b/test/test_state.c index 3ab2148..67325d2 100644 --- a/test/test_state.c +++ b/test/test_state.c @@ -122,6 +122,12 @@ create_test_directories(void) dirs.copy = zix_path_join(NULL, dirs.shared, "copy"); dirs.link = zix_path_join(NULL, dirs.shared, "link"); + assert(dirs.top); + assert(dirs.shared); + assert(dirs.scratch); + assert(dirs.copy); + assert(dirs.link); + assert(!mkdir(dirs.shared, 0700)); assert(!mkdir(dirs.scratch, 0700)); assert(!mkdir(dirs.copy, 0700)); @@ -553,7 +559,8 @@ count_statements(const char* path) SerdNode uri = serd_node_new_file_uri((const uint8_t*)path, NULL, NULL, true); - assert(!serd_reader_read_file(reader, uri.buf)); + assert(uri.buf); + assert(!serd_reader_read_file(reader, (const uint8_t*)uri.buf)); serd_node_free(&uri); serd_reader_free(reader); |