export_image.c: allow duplicate image names in source WIM
[wimlib] / examples / applywim.c
index 6d34a432f57578c896e69e3307c0939fe9f30ba6..cd6d340967ee4fca79029a3f1ae654884254f86b 100644 (file)
 /*
- * applywim.c - A simple program to extract all images from a WIM file to a
- * directory.
+ * applywim.c - A program to extract the first image from a WIM file.
+ *
+ * The following copying information applies to this specific source code file:
+ *
+ * Written in 2013-2016 by Eric Biggers <ebiggers3@gmail.com>
+ *
+ * To the extent possible under law, the author(s) have dedicated all copyright
+ * and related and neighboring rights to this software to the public domain
+ * worldwide via the Creative Commons Zero 1.0 Universal Public Domain
+ * Dedication (the "CC0").
+ *
+ * This software is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+ * FOR A PARTICULAR PURPOSE. See the CC0 for more details.
+ *
+ * You should have received a copy of the CC0 along with this software; if not
+ * see <http://creativecommons.org/publicdomain/zero/1.0/>.
  */
 
 #include <wimlib.h>
 #include <stdio.h>
 
-int main(int argc, char **argv)
+/*
+ * Windows compatibility defines for string encoding.  Applications using wimlib
+ * that need to run on both UNIX and Windows will need to do something similar
+ * to this, whereas applications that only need to run on one or the other can
+ * just use their platform's convention directly.
+ */
+#ifdef _WIN32
+#  define main         wmain
+   typedef wchar_t     tchar;
+#  define TS           "ls"
+#else
+   typedef char                tchar;
+#  define TS           "s"
+#endif
+
+#define TO_PERCENT(numerator, denominator) \
+       ((float)(((denominator) == 0) ? 0 : ((numerator) * 100 / (float)(denominator))))
+
+static enum wimlib_progress_status
+extract_progress(enum wimlib_progress_msg msg,
+                union wimlib_progress_info *info, void *progctx)
+{
+       switch (msg) {
+       case WIMLIB_PROGRESS_MSG_EXTRACT_STREAMS:
+               printf("Extracting files: %.2f%% complete\n",
+                      TO_PERCENT(info->extract.completed_bytes,
+                                 info->extract.total_bytes));
+               break;
+       default:
+               break;
+       }
+       return WIMLIB_PROGRESS_STATUS_CONTINUE;
+}
+
+int main(int argc, tchar **argv)
 {
        int ret;
-       WIMStruct *wim;
+       WIMStruct *wim = NULL;
+       const tchar *wimpath;
+       const tchar *destdir;
 
+       /* Check for the correct number of arguments.  */
        if (argc != 3) {
                fprintf(stderr, "Usage: applywim WIM DIR\n");
-               ret = 2;
-               goto out;
+               return 2;
        }
 
-       /* Initialize the library. */
-       ret = wimlib_global_init(0);
-       if (ret)
+       wimpath = argv[1];
+       destdir = argv[2];
+
+       /* Open the WIM file as a WIMStruct.  */
+       ret = wimlib_open_wim(wimpath,  /* Path of WIM file to open  */
+                             0,        /* WIMLIB_OPEN_FLAG_* flags (0 means all defaults)  */
+                             &wim);    /* Return the WIMStruct pointer in this location  */
+       if (ret != 0) /* Always should check the error codes.  */
                goto out;
 
-       /* Open the WIM file. */
-       ret = wimlib_open_wim(argv[1], 0, &wim, NULL);
-       if (ret)
-               goto out_wimlib_global_cleanup;
+       /* Register our progress function.  */
+       wimlib_register_progress_function(wim, extract_progress, NULL);
 
-       /* Extract all the images. */
-       ret = wimlib_extract_image(wim, WIMLIB_ALL_IMAGES, argv[2], 0, NULL);
+       /* Extract the first image.  */
+       ret = wimlib_extract_image(wim,     /* WIMStruct from which to extract the image  */
+                                  1,       /* Image to extract  */
+                                  destdir, /* Directory to extract the image to  */
+                                  0);      /* WIMLIB_EXTRACT_FLAG_* flags (0 means all defaults)  */
 
-       /* Free the WIM file */
+out:
+       /* Free the WIMStruct.  Has no effect if the pointer to it is NULL.  */
        wimlib_free(wim);
 
-out_wimlib_global_cleanup:
-       /* Finalize the library */
+       /* Check for error status.  */
+       if (ret != 0) {
+               fprintf(stderr, "wimlib error %d: %" TS"\n",
+                       ret, wimlib_get_error_string((enum wimlib_error_code)ret));
+       }
+
+       /* Free global memory (optional).  */
        wimlib_global_cleanup();
-out:
+
        return ret;
 }