From ec103b683b1679b09e1d1a54b14a4ba178d67a37 Mon Sep 17 00:00:00 2001 From: Chmouel Boudjnah Date: Thu, 17 Feb 2000 17:58:25 +0000 Subject: Initial revision --- hdlist2files.cc | 46 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 hdlist2files.cc (limited to 'hdlist2files.cc') diff --git a/hdlist2files.cc b/hdlist2files.cc new file mode 100644 index 0000000..1654886 --- /dev/null +++ b/hdlist2files.cc @@ -0,0 +1,46 @@ +#include +#include +#include +#include +#include +#include + + +char *get_name(Header header, int_32 tag) { + int_32 type, count; + char *name; + + headerGetEntry(header, tag, &type, (void **) &name, &count); + return name; +} + +int get_int(Header header, int_32 tag) { + int_32 type, count; + int *i; + + headerGetEntry(header, tag, &type, (void **) &i, &count); + return *i; +} + +int main(int argc, char **argv) +{ + if (argc <= 1) { + cerr << "usage: hdlist2files []\n"; + exit(1); + } + for (int i = 1; i < argc; i++) { + FD_t fd = strcmp(argv[i], "-") == 0 ? fdDup(STDIN_FILENO) : fdOpen(argv[i], O_RDONLY, 0); + if (fdFileno(fd) < 0) cerr << "rpmpackdeps: cannot open file " << argv[i] << "\n"; + else { + Header header; + int_32 type, count; + char **list; + while ((header=headerRead(fd, HEADER_MAGIC_YES))) { + char *name = get_name(header, RPMTAG_NAME); + headerGetEntry(header, RPMTAG_OLDFILENAMES, &type, (void **) &list, &count); + if (list) for (i = 0; i < count; i++) printf("%s:%s\n", name, list[i]); + } + } + fdClose(fd); + } +} -- cgit v1.2.1