summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2024-01-09 17:21:28 -0500
committerDavid Robillard <d@drobilla.net>2024-01-09 17:28:24 -0500
commite30c50d87ac7c2bc663074839ce12a9ac5796de7 (patch)
tree342e39bc6f20ba79d67c16907a03d0a414caf674
parent81bd78db915bc0d11f23386e49ffe29968ded486 (diff)
downloadlilv-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--NEWS3
-rw-r--r--meson/suppressions/meson.build1
-rw-r--r--src/state.c32
-rw-r--r--test/test_state.c9
4 files changed, 29 insertions, 16 deletions
diff --git a/NEWS b/NEWS
index aa297ee..f799662 100644
--- a/NEWS
+++ b/NEWS
@@ -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);