SHA256
3
0
forked from pool/rpm

- Rewrite rpmqpack to use rpm's database interface

OBS-URL: https://build.opensuse.org/package/show/Base:System/rpm?expand=0&rev=522
This commit is contained in:
Michael Schröder 2020-01-17 10:30:30 +00:00 committed by Git OBS Bridge
parent 1d70343858
commit 3f017cbc06
2 changed files with 31 additions and 28 deletions

View File

@ -4,6 +4,8 @@ Fri Jan 17 11:27:17 CET 2020 - mls@suse.de
- Use libgcrypt as crypto library instead of beecrypt - Use libgcrypt as crypto library instead of beecrypt
* dropped patch: beecrypt-4.1.2-build.diff * dropped patch: beecrypt-4.1.2-build.diff
* dropped patch: beecrypt-4.1.2.diff * dropped patch: beecrypt-4.1.2.diff
- Rewrite rpmqpack to use rpm's database interface
modified patch: rpmqpack.diff
------------------------------------------------------------------- -------------------------------------------------------------------
Fri Dec 6 15:30:48 CET 2019 - mls@suse.de Fri Dec 6 15:30:48 CET 2019 - mls@suse.de

View File

@ -50,9 +50,9 @@
+ +
+.SH AUTHOR +.SH AUTHOR
+Michael Schroeder <mls@suse.de> +Michael Schroeder <mls@suse.de>
--- ./rpmqpack.c.orig 2017-12-01 15:04:13.398003904 +0000 --- ./rpmqpack.c.orig 2019-12-06 10:14:03.989178873 +0000
+++ ./rpmqpack.c 2017-12-01 15:04:13.398003904 +0000 +++ ./rpmqpack.c 2019-12-06 10:32:16.430275015 +0000
@@ -0,0 +1,59 @@ @@ -0,0 +1,60 @@
+#include <sys/types.h> +#include <sys/types.h>
+#include <limits.h> +#include <limits.h>
+#include <fcntl.h> +#include <fcntl.h>
@ -60,55 +60,56 @@
+#include <stdlib.h> +#include <stdlib.h>
+#include <string.h> +#include <string.h>
+ +
+#include <db.h> +#include <rpm/rpmts.h>
+ +#include <rpm/rpmdb.h>
+DBT key; +#include <rpm/rpmmacro.h>
+DBT data;
+ +
+int +int
+main(int argc, char **argv) +main(int argc, char **argv)
+{ +{
+ DB *db = 0;
+ DBC *dbc = 0;
+ int ret = 0; + int ret = 0;
+ rpmts ts;
+ +
+ if (db_create(&db, 0, 0)) + rpmDefineMacro(NULL, "_dbpath /var/lib/rpm", 0);
+ ts = rpmtsCreate();
+ if (!ts)
+ { + {
+ perror("db_create"); + fprintf(stderr, "rpmtsCreate failed\n");
+ exit(1); + exit(1);
+ } + }
+ if (db->open(db, 0, "/var/lib/rpm/Name", 0, DB_UNKNOWN, DB_RDONLY, 0664)) + if (rpmtsOpenDB(ts, O_RDONLY))
+ { + {
+ perror("db->open"); + perror("rpmtsOpenDB");
+ exit(1); + exit(1);
+ } + }
+ if (argc == 1) + if (argc <= 1)
+ { + {
+ if (db->cursor(db, NULL, &dbc, 0)) + rpmdbIndexIterator ii;
+ ii = rpmdbIndexIteratorInit(rpmtsGetRdb(ts), RPMDBI_NAME);
+ if (ii)
+ { + {
+ perror("db->cursor"); + const void *key = 0;
+ exit(1); + size_t keylen = 0;
+ while ((rpmdbIndexIteratorNext(ii, &key, &keylen)) == 0)
+ printf("%*.*s\n", (int)keylen, (int)keylen, (char *)key);
+ } + }
+ while (dbc->c_get(dbc, &key, &data, DB_NEXT) == 0) + rpmdbIndexIteratorFree(ii);
+ printf("%*.*s\n", (int)key.size, (int)key.size, (char *)key.data);
+ dbc->c_close(dbc);
+ } + }
+ else + else
+ { + {
+ argc--; + argc--;
+ while (argc--) + while (argc--)
+ { + {
+ rpmdbMatchIterator mi;
+ argv++; + argv++;
+ key.data = (void *)*argv; + mi = rpmdbInitIterator(rpmtsGetRdb(ts), RPMDBI_NAME, (void *)*argv, strlen(*argv));
+ key.size = strlen(*argv); + if (mi && rpmdbGetIteratorCount(mi))
+ data.data = NULL;
+ data.size = 0;
+ if (db->get(db, 0, &key, &data, 0) == 0)
+ printf("%s\n", *argv); + printf("%s\n", *argv);
+ else + else
+ ret = 1; + ret = 1;
+ rpmdbFreeIterator(mi);
+ } + }
+ } + }
+ db->close(db, 0); + rpmtsFree(ts);
+ return ret; + return ret;
+} +}