summaryrefslogtreecommitdiff
path: root/src/database.c
diff options
context:
space:
mode:
authorTimo Teräs <timo.teras@iki.fi>2020-04-01 10:44:28 +0300
committerTimo Teräs <timo.teras@iki.fi>2020-04-01 10:47:54 +0300
commit845b6397ab42ef9bca8d9f38cf2b7b2640917a23 (patch)
tree23d5528bb223dfcfba818b7f6bd7d060765ad6c6 /src/database.c
parenteae92bbacf3c005bf12f8f5f5555bff953ebb5d7 (diff)
downloadapk-tools-845b6397ab42ef9bca8d9f38cf2b7b2640917a23.tar.gz
apk-tools-845b6397ab42ef9bca8d9f38cf2b7b2640917a23.tar.bz2
apk-tools-845b6397ab42ef9bca8d9f38cf2b7b2640917a23.tar.xz
apk-tools-845b6397ab42ef9bca8d9f38cf2b7b2640917a23.zip
db: fix database reading without scripts or triggers
Most notably this happens after blank database is initialized with --initdb, but can happen also in other conditions. The error checking changes modified behaviour if the file does not exist. Explicitly check for ENOENT and ignore it. But the behaviour is improved from earlier as now e.g. EPERM will be detected and reported correctly. Fixes #10679 Fixes: 6da3e8eb15 "istream, archive, db: convert db and tar function to use istream"
Diffstat (limited to 'src/database.c')
-rw-r--r--src/database.c16
1 files changed, 10 insertions, 6 deletions
diff --git a/src/database.c b/src/database.c
index 06d1619..cbc6667 100644
--- a/src/database.c
+++ b/src/database.c
@@ -1118,14 +1118,14 @@ static void apk_db_triggers_write(struct apk_database *db, struct apk_ostream *o
}
}
-static void apk_db_triggers_read(struct apk_database *db, struct apk_istream *is)
+static int apk_db_triggers_read(struct apk_database *db, struct apk_istream *is)
{
struct apk_checksum csum;
struct apk_package *pkg;
struct apk_installed_package *ipkg;
apk_blob_t l;
- if (IS_ERR_OR_NULL(is)) return;
+ if (IS_ERR(is)) return PTR_ERR(is);
while (!APK_BLOB_IS_NULL(l = apk_istream_get_delim(is, APK_BLOB_STR("\n")))) {
apk_blob_pull_csum(&l, &csum);
@@ -1143,6 +1143,8 @@ static void apk_db_triggers_read(struct apk_database *db, struct apk_istream *is
&db->installed.triggers);
}
apk_istream_close(is);
+
+ return 0;
}
static int apk_db_read_state(struct apk_database *db, int flags)
@@ -1166,13 +1168,15 @@ static int apk_db_read_state(struct apk_database *db, int flags)
if (!(flags & APK_OPENF_NO_INSTALLED)) {
r = apk_db_index_read(db, apk_istream_from_file(db->root_fd, apk_installed_file), -1);
- if (r != 0) return -1;
- apk_db_triggers_read(db, apk_istream_from_file(db->root_fd, apk_triggers_file));
+ if (r && r != -ENOENT) return r;
+ r = apk_db_triggers_read(db, apk_istream_from_file(db->root_fd, apk_triggers_file));
+ if (r && r != -ENOENT) return r;
}
if (!(flags & APK_OPENF_NO_SCRIPTS)) {
- apk_tar_parse(apk_istream_from_file(db->root_fd, apk_scripts_file),
- apk_read_script_archive_entry, db, &db->id_cache);
+ r = apk_tar_parse(apk_istream_from_file(db->root_fd, apk_scripts_file),
+ apk_read_script_archive_entry, db, &db->id_cache);
+ if (r && r != -ENOENT) return r;
}
return 0;