[gnome-autoar/wip/razvan/general-improvements: 1/20] AutoarExtract: remove support for memory files



commit c740e6d446126f71c37fe3f9cfcedddb77819a4f
Author: Razvan Chitu <razvan ch95 gmail com>
Date:   Sun Aug 7 15:45:51 2016 +0300

    AutoarExtract: remove support for memory files
    
    While libarchive offers support for archives read from memory, there is no use
    case for this feature in gnome-autoar.
    
    https://bugzilla.gnome.org/show_bug.cgi?id=768645

 gnome-autoar/autoar-extract.c |  199 +++++------------------------------------
 gnome-autoar/autoar-extract.h |   13 ---
 tests/test-extract.c          |   26 +-----
 3 files changed, 25 insertions(+), 213 deletions(-)
---
diff --git a/gnome-autoar/autoar-extract.c b/gnome-autoar/autoar-extract.c
index c5886e6..80eb92f 100644
--- a/gnome-autoar/autoar-extract.c
+++ b/gnome-autoar/autoar-extract.c
@@ -109,14 +109,10 @@ struct _AutoarExtractPrivate
   GFile *source_file;
   GFile *output_file;
 
-  int source_is_mem  : 1;
   int output_is_dest : 1;
 
   AutoarPref *arpref;
 
-  const void *source_buffer;
-  gsize source_buffer_size;
-
   GCancellable *cancellable;
 
   gint64 notify_interval;
@@ -174,14 +170,13 @@ enum
 {
   PROP_0,
   PROP_SOURCE,           /* Only used to display messages */
-  PROP_SOURCE_FILE,      /* It may be invalid if source-is-mem is TRUE */
+  PROP_SOURCE_FILE,
   PROP_OUTPUT,           /* Only used to display messages */
   PROP_OUTPUT_FILE,
   PROP_SIZE,
   PROP_COMPLETED_SIZE,
   PROP_FILES,
   PROP_COMPLETED_FILES,
-  PROP_SOURCE_IS_MEM,    /* Must be set when constructing object */
   PROP_OUTPUT_IS_DEST,
   PROP_NOTIFY_INTERVAL
 };
@@ -225,9 +220,6 @@ autoar_extract_get_property (GObject    *object,
     case PROP_COMPLETED_FILES:
       g_value_set_uint (value, priv->completed_files);
       break;
-    case PROP_SOURCE_IS_MEM:
-      g_value_set_boolean (value, priv->source_is_mem);
-      break;
     case PROP_OUTPUT_IS_DEST:
       g_value_set_boolean (value, priv->output_is_dest);
       break;
@@ -269,9 +261,6 @@ autoar_extract_set_property (GObject      *object,
       g_clear_object (&(priv->output_file));
       priv->output_file = g_object_ref (g_value_get_object (value));
       break;
-    case PROP_SOURCE_IS_MEM:
-      priv->source_is_mem = g_value_get_boolean (value);
-      break;
     case PROP_OUTPUT_IS_DEST:
       autoar_extract_set_output_is_dest (arextract, g_value_get_boolean (value));
       break;
@@ -288,9 +277,8 @@ autoar_extract_set_property (GObject      *object,
  * autoar_extract_get_source:
  * @arextract: an #AutoarExtract
  *
- * If #AutoarExtract:source_is_mem is %TRUE, gets the descriptive string for
- * the source memory buffer. Otherwise, gets the source file will be extracted
- * for this object. It may be a filename or URI.
+ * Gets the source file that will be extracted for this object. It may be a
+ * filename or URI.
  *
  * Returns: (transfer none): a string
  **/
@@ -305,10 +293,8 @@ autoar_extract_get_source (AutoarExtract *arextract)
  * autoar_extract_get_source_file:
  * @arextract: an #AutoarExtract
  *
- * If #AutoarExtract:source_is_mem is %TRUE, gets the #GFile object generated
- * using the value of #AutoarExtract:source. The returned #GFile is not usable
- * at all. Otherwise, gets the #GFile object which represents the source
- * archive will be extracted for this object.
+ * Gets the #GFile object which represents the source archive that will be
+ * extracted for this object.
  *
  * Returns: (transfer none): a #GFile
  **/
@@ -414,21 +400,6 @@ autoar_extract_get_completed_files (AutoarExtract *arextract)
 }
 
 /**
- * autoar_extract_get_source_is_mem:
- * @arextract: an #AutoarExtract
- *
- * Gets whether the source archive is a memory buffer.
- *
- * Returns: %TRUE if the source archive is a memory buffer.
- **/
-gboolean
-autoar_extract_get_source_is_mem (AutoarExtract *arextract)
-{
-  g_return_val_if_fail (AUTOAR_IS_EXTRACT (arextract), FALSE);
-  return arextract->priv->source_is_mem;
-}
-
-/**
  * autoar_extract_get_output_is_dest:
  * @arextract: an #AutoarExtract
  *
@@ -441,7 +412,7 @@ gboolean
 autoar_extract_get_output_is_dest (AutoarExtract *arextract)
 {
   g_return_val_if_fail (AUTOAR_IS_EXTRACT (arextract), FALSE);
-  return arextract->priv->source_is_mem;
+  return arextract->priv->output_is_dest;
 }
 
 /**
@@ -599,6 +570,7 @@ libarchive_read_open_cb (struct archive *ar_read,
 {
   AutoarExtract *arextract;
   AutoarExtractPrivate *priv;
+  GFileInputStream *istream;
 
   g_debug ("libarchive_read_open_cb: called");
 
@@ -608,18 +580,10 @@ libarchive_read_open_cb (struct archive *ar_read,
   if (priv->error != NULL)
     return ARCHIVE_FATAL;
 
-  if (arextract->priv->source_is_mem) {
-    priv->istream =
-      g_memory_input_stream_new_from_data (priv->source_buffer,
-                                           priv->source_buffer_size,
-                                           NULL);
-  } else {
-    GFileInputStream *istream;
-    istream = g_file_read (priv->source_file,
-                           priv->cancellable,
-                           &(arextract->priv->error));
-    priv->istream = G_INPUT_STREAM (istream);
-  }
+  istream = g_file_read (priv->source_file,
+                         priv->cancellable,
+                         &(arextract->priv->error));
+  priv->istream = G_INPUT_STREAM (istream);
 
   if (priv->error != NULL)
     return ARCHIVE_FATAL;
@@ -1327,15 +1291,6 @@ autoar_extract_class_init (AutoarExtractClass *klass)
                                                       G_PARAM_READABLE |
                                                       G_PARAM_STATIC_STRINGS));
 
-  g_object_class_install_property (object_class, PROP_SOURCE_IS_MEM,
-                                   g_param_spec_boolean ("source-is-mem",
-                                                         "Source is memory",
-                                                         "Whether source file is in memory",
-                                                         FALSE,
-                                                         G_PARAM_READWRITE |
-                                                         G_PARAM_CONSTRUCT_ONLY |
-                                                         G_PARAM_STATIC_STRINGS));
-
   g_object_class_install_property (object_class, PROP_OUTPUT_IS_DEST,
                                    g_param_spec_boolean ("output-is-dest",
                                                          "Output is destination",
@@ -1471,9 +1426,6 @@ autoar_extract_init (AutoarExtract *arextract)
   priv = AUTOAR_EXTRACT_GET_PRIVATE (arextract);
   arextract->priv = priv;
 
-  priv->source_buffer = NULL;
-  priv->source_buffer_size = 0;
-
   priv->cancellable = NULL;
 
   priv->size = 0;
@@ -1512,7 +1464,6 @@ autoar_extract_new_full (const char *source,
                          GFile *source_file,
                          const char *output,
                          GFile *output_file,
-                         gboolean source_is_mem,
                          AutoarPref *arpref,
                          const void *buffer,
                          gsize buffer_size,
@@ -1521,21 +1472,17 @@ autoar_extract_new_full (const char *source,
   AutoarExtract *arextract;
   char *gen_source, *gen_output;
   GFile *gen_source_file, *gen_output_file;
+  g_autofree char *source_basename;
 
   gen_source      = NULL;
   gen_source_file = NULL;
   gen_output      = NULL;
   gen_output_file = NULL;
 
-  if (source_is_mem) {
-    gen_source = g_strdup_printf ("(memory %p, size %" G_GSIZE_FORMAT ")", buffer, buffer_size);
-    gen_source_file = g_file_new_for_commandline_arg (gen_source);
-  } else {
-    if (source == NULL)
-      gen_source = autoar_common_g_file_get_name (source_file);
-    if (source_file == NULL)
-      gen_source_file = g_file_new_for_commandline_arg (source);
-  }
+  if (source == NULL)
+    gen_source = autoar_common_g_file_get_name (source_file);
+  if (source_file == NULL)
+    gen_source_file = g_file_new_for_commandline_arg (source);
 
   if (output == NULL)
     gen_output = autoar_common_g_file_get_name (output_file);
@@ -1548,24 +1495,13 @@ autoar_extract_new_full (const char *source,
                   "source-file",    source_file != NULL ? source_file : gen_source_file,
                   "output",         output      != NULL ? output      : gen_output,
                   "output-file",    output_file != NULL ? output_file : gen_output_file,
-                  "source-is-mem",  source_is_mem, NULL);
+                  NULL);
+
   arextract->priv->arpref = g_object_ref (arpref);
 
-  if (source_is_mem) {
-    arextract->priv->source_buffer = buffer;
-    arextract->priv->source_buffer_size = buffer_size;
-    if (suggested_destname != NULL)
-      arextract->priv->suggested_destname =
-        autoar_common_get_basename_remove_extension (suggested_destname);
-    else
-      arextract->priv->suggested_destname =
-        autoar_common_get_basename_remove_extension (gen_source);
-  } else {
-    char *source_basename = g_file_get_basename (arextract->priv->source_file);
-    arextract->priv->suggested_destname =
-      autoar_common_get_basename_remove_extension (source_basename);
-    g_free (source_basename);
-  }
+  source_basename = g_file_get_basename (arextract->priv->source_file);
+  arextract->priv->suggested_destname =
+    autoar_common_get_basename_remove_extension (source_basename);
 
   g_free (gen_source);
   g_free (gen_output);
@@ -1600,7 +1536,7 @@ autoar_extract_new (const char *source,
   g_return_val_if_fail (output != NULL, NULL);
 
   return autoar_extract_new_full (source, NULL, output, NULL,
-                                  FALSE, arpref,
+                                  arpref,
                                   NULL, 0, NULL);
 }
 
@@ -1625,74 +1561,10 @@ autoar_extract_new_file (GFile *source_file,
   g_return_val_if_fail (output_file != NULL, NULL);
 
   return autoar_extract_new_full (NULL, source_file, NULL, output_file,
-                                  FALSE, arpref,
+                                  arpref,
                                   NULL, 0, NULL);
 }
 
-/**
- * autoar_extract_new_memory:
- * @buffer: memory buffer holding the source archive
- * @buffer_size: the size of the source archive memory buffer
- * @source_name: the name of the source archive
- * @output: output directory of extracted file or directory, or the file name
- * of the extracted file or directory itself if you set
- * #AutoarExtract:output-is-dest on the returned object
- * @arpref: an #AutoarPref object
- *
- * Create a new #AutoarExtract object. @source_name does not need to be a full
- * path. The file which it represents does not need to exist, either. This
- * argument is only used to decide the name of the extracted file or directory,
- * and it is useless if you set #AutoarExtract:output-is-dest to %TRUE.
- *
- * Returns: (transfer full): a new #AutoarExtract object
- **/
-AutoarExtract*
-autoar_extract_new_memory (const void *buffer,
-                           gsize buffer_size,
-                           const char *source_name,
-                           const char *output,
-                           AutoarPref *arpref)
-{
-
-  g_return_val_if_fail (output != NULL, NULL);
-  g_return_val_if_fail (buffer != NULL, NULL);
-
-  return autoar_extract_new_full (NULL, NULL, output, NULL,
-                                  TRUE, arpref,
-                                  buffer, buffer_size, source_name);
-}
-
-/**
- * autoar_extract_new_memory_file:
- * @buffer: memory buffer holding the source archive
- * @buffer_size: the size of the source archive memory buffer
- * @source_name: the name of the source archive
- * @output_file: output directory of extracted file or directory, or the file
- * name of the extracted file or directory itself if you set
- * #AutoarExtract:output-is-dest on the returned object
- * @arpref: an #AutoarPref object
- *
- * Create a new #AutoarExtract object. This function is similar to
- * autoar_extract_new_memory() except for the argument for the output
- * directory is #GFile.
- *
- * Returns: (transfer full): a new #AutoarExtract object
- **/
-AutoarExtract*
-autoar_extract_new_memory_file (const void *buffer,
-                                gsize buffer_size,
-                                const char *source_name,
-                                GFile *output_file,
-                                AutoarPref *arpref)
-{
-  g_return_val_if_fail (output_file != NULL, NULL);
-  g_return_val_if_fail (buffer != NULL, NULL);
-
-  return autoar_extract_new_full (NULL, NULL, NULL, output_file,
-                                  TRUE, arpref,
-                                  buffer, buffer_size, source_name);
-}
-
 static void
 autoar_extract_step_initialize_pattern (AutoarExtract *arextract) {
   /* Step 0: Compile the file name pattern. */
@@ -2050,8 +1922,7 @@ autoar_extract_run (AutoarExtract *arextract)
   g_return_if_fail (AUTOAR_IS_EXTRACT (arextract));
   priv = arextract->priv;
 
-  g_return_if_fail (priv->source_file != NULL || (priv->source_is_mem &&
-                                                  priv->source_buffer != NULL));
+  g_return_if_fail (priv->source_file != NULL);
   g_return_if_fail (priv->output_file != NULL);
 
   if (g_cancellable_is_cancelled (priv->cancellable)) {
@@ -2147,25 +2018,3 @@ autoar_extract_start_async (AutoarExtract *arextract,
   g_task_set_task_data (task, NULL, NULL);
   g_task_run_in_thread (task, autoar_extract_start_async_thread);
 }
-
-/**
- * autoar_extract_free_source_buffer:
- * @arextract: an #AutoarExtract object
- * @free_func: a function to free the memory buffer
- *
- * Free the source memory archive provided in autoar_extract_new_memory() or
- * autoar_extract_new_memory_file(). This functions should only be called
- * after the extracting job is completed. That is, you should only call this
- * function after you receives one of #AutoarExtract::cancelled,
- * #AutoarExtract::error, or #AutoarExtract::completed signal.
- **/
-void
-autoar_extract_free_source_buffer (AutoarExtract *arextract,
-                                   GDestroyNotify free_func)
-{
-  if (arextract->priv->source_buffer != NULL)
-    (*free_func)((void*)(arextract->priv->source_buffer));
-
-  arextract->priv->source_buffer = NULL;
-  arextract->priv->source_buffer_size = 0;
-}
diff --git a/gnome-autoar/autoar-extract.h b/gnome-autoar/autoar-extract.h
index be97e83..f649543 100644
--- a/gnome-autoar/autoar-extract.h
+++ b/gnome-autoar/autoar-extract.h
@@ -75,23 +75,11 @@ AutoarExtract  *autoar_extract_new                 (const char *source,
 AutoarExtract  *autoar_extract_new_file            (GFile *source_file,
                                                     GFile *output_file,
                                                     AutoarPref *arpref);
-AutoarExtract  *autoar_extract_new_memory          (const void *buffer,
-                                                    gsize buffer_size,
-                                                    const char *source_name,
-                                                    const char *output,
-                                                    AutoarPref *arpref);
-AutoarExtract  *autoar_extract_new_memory_file     (const void *buffer,
-                                                    gsize buffer_size,
-                                                    const char *source_name,
-                                                    GFile *output_file,
-                                                    AutoarPref *arpref);
 
 void            autoar_extract_start               (AutoarExtract *arextract,
                                                     GCancellable *cancellable);
 void            autoar_extract_start_async         (AutoarExtract *arextract,
                                                     GCancellable *cancellable);
-void            autoar_extract_free_source_buffer  (AutoarExtract *arextract,
-                                                    GDestroyNotify free_func);
 
 char           *autoar_extract_get_source          (AutoarExtract *arextract);
 GFile          *autoar_extract_get_source_file     (AutoarExtract *arextract);
@@ -101,7 +89,6 @@ guint64         autoar_extract_get_size            (AutoarExtract *arextract);
 guint64         autoar_extract_get_completed_size  (AutoarExtract *arextract);
 guint           autoar_extract_get_files           (AutoarExtract *arextract);
 guint           autoar_extract_get_completed_files (AutoarExtract *arextract);
-gboolean        autoar_extract_get_source_is_mem   (AutoarExtract *arextract);
 gboolean        autoar_extract_get_output_is_dest  (AutoarExtract *arextract);
 gint64          autoar_extract_get_notify_interval (AutoarExtract *arextract);
 
diff --git a/tests/test-extract.c b/tests/test-extract.c
index 197eca8..ae6325c 100644
--- a/tests/test-extract.c
+++ b/tests/test-extract.c
@@ -76,31 +76,7 @@ main (int argc,
   autoar_pref_set_delete_if_succeed (arpref, FALSE);
   autoar_pref_set_pattern_to_ignore (arpref, (const char**)argv + 3);
 
-  autoar_pref_forget_changes (arpref);
-  autoar_pref_write_gsettings (arpref, settings);
-
-  if (g_str_has_suffix (argv[0], "test-extract-memory")) {
-    gsize length;
-    GFile *file;
-    GError *error;
-
-    g_print ("Loading whole file into memory ... ");
-
-    error = NULL;
-    file = g_file_new_for_commandline_arg (argv[1]);
-    if (!g_file_load_contents (file, NULL, &content, &length, NULL, &error)) {
-      g_printerr ("\ntest-extract-memory: Error %d: %s\n", error->code, error->message);
-      g_object_unref (file);
-      g_error_free (error);
-      return 1;
-    }
-
-    g_print ("OK\n");
-    g_object_unref (file);
-    arextract = autoar_extract_new_memory (content, length, argv[1], argv[2], arpref);
-  } else {
-    arextract = autoar_extract_new (argv[1], argv[2], arpref);
-  }
+  arextract = autoar_extract_new (argv[1], argv[2], arpref);
 
   g_signal_connect (arextract, "scanned", G_CALLBACK (my_handler_scanned), NULL);
   g_signal_connect (arextract, "decide-dest", G_CALLBACK (my_handler_decide_dest), NULL);


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]