Blame dbrointerruptable.diff

ee825d
--- ./lib/rpmdb.c.orig	2020-05-28 10:04:25.037136686 +0000
ee825d
+++ ./lib/rpmdb.c	2020-09-30 12:23:50.708547165 +0000
Bernhard M. Wiedemann 1250f9
@@ -387,9 +387,11 @@ int rpmdbClose(rpmdb db)
Bernhard M. Wiedemann 1250f9
 {
Bernhard M. Wiedemann 1250f9
     rpmdb * prev, next;
Bernhard M. Wiedemann 1250f9
     int rc = 0;
Bernhard M. Wiedemann 1250f9
+    int dbmode;
Bernhard M. Wiedemann 1250f9
 
Bernhard M. Wiedemann 1250f9
     if (db == NULL)
Bernhard M. Wiedemann 1250f9
 	goto exit;
Bernhard M. Wiedemann 1250f9
+    dbmode = db->db_mode;
Bernhard M. Wiedemann 1250f9
 
Bernhard M. Wiedemann 1250f9
     prev = &rpmdbRock;
Bernhard M. Wiedemann 1250f9
     while ((next = *prev) != NULL && next != db)
ee825d
@@ -423,7 +425,7 @@ int rpmdbClose(rpmdb db)
Bernhard M. Wiedemann 1250f9
 
Bernhard M. Wiedemann 1250f9
     db = _free(db);
Bernhard M. Wiedemann 1250f9
 
Bernhard M. Wiedemann 1250f9
-    if (rpmdbRock == NULL) {
Bernhard M. Wiedemann 1250f9
+    if (rpmdbRock == NULL && (dbmode & (O_RDWR|O_WRONLY)) != 0) {
Bernhard M. Wiedemann 1250f9
 	rpmsqActivate(0);
Bernhard M. Wiedemann 1250f9
     }
Bernhard M. Wiedemann 1250f9
 exit:
ee825d
@@ -510,7 +512,7 @@ static int openDatabase(const char * pre
ee825d
 	int justPkgs = (db->db_flags & RPMDB_FLAG_REBUILD) &&
ee825d
 		       ((db->db_mode & O_ACCMODE) == O_RDONLY);
Bernhard M. Wiedemann 1250f9
 	/* Enable signal queue on the first db open */
Bernhard M. Wiedemann 1250f9
-	if (db->db_next == NULL) {
Bernhard M. Wiedemann 1250f9
+	if (db->db_next == NULL &&  (db->db_mode & (O_RDWR|O_WRONLY)) != 0) {
Bernhard M. Wiedemann 1250f9
 	    rpmsqActivate(1);
Bernhard M. Wiedemann 1250f9
 	}
Bernhard M. Wiedemann 1250f9