diff options
author | Rafael Garcia-Suarez <rgarciasuarez@mandriva.org> | 2005-11-02 16:08:42 +0000 |
---|---|---|
committer | Rafael Garcia-Suarez <rgarciasuarez@mandriva.org> | 2005-11-02 16:08:42 +0000 |
commit | baabd04d3ba7a4f73bf297d01b7d0820a1f2bde9 (patch) | |
tree | 25d0f49ce35dce3feab4ea207a44f63253e59bc1 /autoirpm.update-all.cc | |
parent | 38033c3f1b3089774c321cead65c6031c650e96c (diff) | |
download | urpmi-baabd04d3ba7a4f73bf297d01b7d0820a1f2bde9.tar urpmi-baabd04d3ba7a4f73bf297d01b7d0820a1f2bde9.tar.gz urpmi-baabd04d3ba7a4f73bf297d01b7d0820a1f2bde9.tar.bz2 urpmi-baabd04d3ba7a4f73bf297d01b7d0820a1f2bde9.tar.xz urpmi-baabd04d3ba7a4f73bf297d01b7d0820a1f2bde9.zip |
Remove old autoirpm attempt
Diffstat (limited to 'autoirpm.update-all.cc')
-rw-r--r-- | autoirpm.update-all.cc | 88 |
1 files changed, 0 insertions, 88 deletions
diff --git a/autoirpm.update-all.cc b/autoirpm.update-all.cc deleted file mode 100644 index de96edd4..00000000 --- a/autoirpm.update-all.cc +++ /dev/null @@ -1,88 +0,0 @@ -#include <stdio.h> -#include <stdlib.h> -#include <string.h> -#include <sys/types.h> -#include <sys/stat.h> -#include <fcntl.h> -#include <unistd.h> -#include <rpmlib.h> -#include <string> -#include <set> -#include <fstream> - - -typedef set<string>::difference_type diff_type; - -set<string> *read_set(const char *file) { - ifstream input(file); - if (input) { - set<string> *myset = new set<string>; - istream_iterator<string,diff_type> input_set(input),eos; - copy(input_set, eos, inserter(*myset, myset->begin())); - return myset; - } - return 0; -} - -int main(int argc, char **argv) { - if (argc <= 3) { - cerr << "usage: " << argv[0] << " <allow progs file> <deny progs file> <hdlist> [<hdlist> ...]\n"; - exit(1); - } - - set<string> *allow = read_set(argv[1]); - set<string> *deny = read_set(argv[2]); - - for (int i = 3; i < argc; i++) { - Header header; - FD_t fd = strcmp(argv[i], "-") == 0 ? fdDup(STDIN_FILENO) : fdOpen(argv[i], O_RDONLY, 0); - if (fdFileno(fd) < 0) { - fprintf(stderr, "%s: cannot open file %s\n", argv[0], argv[i]); - exit(1); - } - - while ((header=headerRead(fd, HEADER_MAGIC_YES))) { - int_32 type, count; - unsigned short *p; - char **f, *name; - int printed = 0; - - headerGetEntry(header, RPMTAG_NAME, &type, (void **) &name, NULL); - headerGetEntry(header, RPMTAG_FILEMODES, &type, (void **) &p, &count); - headerGetEntry(header, RPMTAG_OLDFILENAMES, &type, (void **) &f, NULL); - - char ** baseNames, ** dirNames; - int_32 * dirIndexes; - headerGetEntry(header, RPMTAG_BASENAMES, &type, (void **) &baseNames, NULL); - headerGetEntry(header, RPMTAG_DIRINDEXES, &type, (void **) &dirIndexes, NULL); - headerGetEntry(header, RPMTAG_DIRNAMES, &type, (void **) &dirNames, NULL); - - for (int i = 0; i < count; i++) { - if ((p[i] & 040111) == 0111) { - int ok; - if (f) { - char *s = strrchr(f[i], '/'); - ok = s && s - 3 >= f[i] && strncmp(s - 3, "bin", 3) == 0 && - (!allow || allow->count(s + 1)) && - (!deny || !deny->count(s + 1)); - } else { - char *d = dirNames[dirIndexes[i]]; - ok = strlen(d) >= 4 && strncmp(d + strlen(d) - 4, "bin/", 4) == 0 && - (!allow || allow->count(baseNames[i])) && - (!deny || !deny->count(baseNames[i])); - } - if (ok) { - if (!printed) { - printed = 1; - cout << name; - } - if (f) cout << " " << f[i]; else cout << " " << dirNames[dirIndexes[i]] << baseNames[i]; - } - } - } - if (printed) cout << "\n"; - } - fdClose(fd); - } - return 0; -} |