Add macro %isu_package to generate ISU Package
[platform/upstream/rpm.git] / rpm2cpio.c
index 397303c..8bee3c7 100644 (file)
@@ -2,82 +2,95 @@
 
 #include "system.h"
 
-#include <rpmlib.h>
-#include <rpmpgp.h>
+#include <rpm/rpmlib.h>                /* rpmReadPackageFile .. */
+#include <rpm/rpmtag.h>
+#include <rpm/rpmio.h>
+#include <rpm/rpmpgp.h>
 
-#include "depends.c"
+#include <rpm/rpmts.h>
+#include <unistd.h>
 
 #include "debug.h"
 
-int main(int argc, char **argv)
+int main(int argc, char *argv[])
 {
     FD_t fdi, fdo;
     Header h;
-    char * rpmio_flags;
-    rpmRC rc;
+    char * rpmio_flags = NULL;
+    int rc;
+    off_t payload_size;
     FD_t gzdi;
     
-    setprogname(argv[0]);      /* Retrofit glibc __progname */
+    xsetprogname(argv[0]); /* Portability call -- see system.h */
+
+    rpmReadConfigFiles(NULL, NULL);
     if (argc == 1)
        fdi = fdDup(STDIN_FILENO);
-    else
+    else {
+       if (rstreq(argv[1], "-h") || rstreq(argv[1], "--help")) {
+           fprintf(stderr, "Usage: rpm2cpio file.rpm\n");
+           exit(EXIT_FAILURE);
+       }
        fdi = Fopen(argv[1], "r.ufdio");
+    }
 
     if (Ferror(fdi)) {
        fprintf(stderr, "%s: %s: %s\n", argv[0],
                (argc == 1 ? "<stdin>" : argv[1]), Fstrerror(fdi));
        exit(EXIT_FAILURE);
     }
+    if (isatty(STDOUT_FILENO)) {
+       fprintf(stderr, "Error: refusing to output cpio data to a terminal.\n");
+       exit(EXIT_FAILURE);
+    }
     fdo = fdDup(STDOUT_FILENO);
 
-    {  rpmTransactionSet ts = rpmtransCreateSet(NULL, NULL);
+    {  rpmts ts = rpmtsCreate();
+       rpmVSFlags vsflags = 0;
+
+       /* XXX retain the ageless behavior of rpm2cpio */
+        vsflags |= _RPMVSF_NODIGESTS;
+        vsflags |= _RPMVSF_NOSIGNATURES;
+        vsflags |= RPMVSF_NOHDRCHK;
+       (void) rpmtsSetVSFlags(ts, vsflags);
 
-       /*@-mustmod@*/      /* LCL: segfault */
        rc = rpmReadPackageFile(ts, fdi, "rpm2cpio", &h);
-       /*@=mustmod@*/
 
-       ts = rpmtransFree(ts);
+       ts = rpmtsFree(ts);
     }
 
     switch (rc) {
-    case RPMRC_BADSIZE:
     case RPMRC_OK:
+    case RPMRC_NOKEY:
+    case RPMRC_NOTTRUSTED:
        break;
     case RPMRC_NOTFOUND:
        fprintf(stderr, _("argument is not an RPM package\n"));
        exit(EXIT_FAILURE);
        break;
     case RPMRC_FAIL:
-    case RPMRC_SHORTREAD:
     default:
        fprintf(stderr, _("error reading header from package\n"));
        exit(EXIT_FAILURE);
        break;
     }
 
-    /* Retrieve type of payload compression. */
-    {  const char * payload_compressor = NULL;
-       char * t;
-
-       if (!headerGetEntry(h, RPMTAG_PAYLOADCOMPRESSOR, NULL,
-                           (void **) &payload_compressor, NULL))
-           payload_compressor = "gzip";
-       rpmio_flags = t = alloca(sizeof("r.gzdio"));
-       *t++ = 'r';
-       if (!strcmp(payload_compressor, "gzip"))
-           t = stpcpy(t, ".gzdio");
-       if (!strcmp(payload_compressor, "bzip2"))
-           t = stpcpy(t, ".bzdio");
+    /* Retrieve payload size and compression type. */
+    {  const char *compr = headerGetString(h, RPMTAG_PAYLOADCOMPRESSOR);
+       rpmio_flags = rstrscat(NULL, "r.", compr ? compr : "gzip", NULL);
+       payload_size = headerGetNumber(h, RPMTAG_LONGARCHIVESIZE);
     }
 
     gzdi = Fdopen(fdi, rpmio_flags);   /* XXX gzdi == fdi */
+    free(rpmio_flags);
+
     if (gzdi == NULL) {
        fprintf(stderr, _("cannot re-open payload: %s\n"), Fstrerror(gzdi));
        exit(EXIT_FAILURE);
     }
 
-    rc = ufdCopy(gzdi, fdo);
-    rc = (rc <= 0) ? EXIT_FAILURE : EXIT_SUCCESS;
+    rc = (ufdCopy(gzdi, fdo) == payload_size) ? EXIT_SUCCESS : EXIT_FAILURE;
+
     Fclose(fdo);
 
     Fclose(gzdi);      /* XXX gzdi == fdi */