Move quoted_value() and escquote_value() to misc.[ch].
authorLaurent Monin <geeqie@norz.org>
Sun, 31 Aug 2008 11:27:24 +0000 (11:27 +0000)
committerLaurent Monin <geeqie@norz.org>
Sun, 31 Aug 2008 11:27:24 +0000 (11:27 +0000)
src/collect-io.c
src/filedata.c
src/filefilter.c
src/misc.c
src/misc.h
src/rcfile.c
src/rcfile.h

index fd84f33..941964a 100644 (file)
 #include "collect.h"
 #include "filedata.h"
 #include "layout_util.h"
-#include "rcfile.h"
+#include "misc.h"
 #include "secure_save.h"
 #include "thumb.h"
 #include "ui_fileops.h"
 
-
 #define GQ_COLLECTION_MARKER "#" GQ_APPNAME
 
 #define GQ_COLLECTION_FAIL_MIN     300
index c2b41a6..7ac6601 100644 (file)
@@ -16,8 +16,6 @@
 
 #include "filefilter.h"
 #include "cache.h"
-#include "rcfile.h"
-#include "secure_save.h"
 #include "thumb_standard.h"
 #include "ui_fileops.h"
 
index b1c16f9..481051e 100644 (file)
 #include "filefilter.h"
 
 #include "cache.h"
-#include "rcfile.h"
+#include "misc.h"
 #include "secure_save.h"
 #include "thumb_standard.h"
 #include "ui_fileops.h"
 
-
 /*
  *-----------------------------------------------------------------------------
  * file filtering
index 47bbdc3..d52e1e6 100644 (file)
@@ -108,3 +108,81 @@ gchar *expand_tilde(const gchar *filename)
                return g_build_filename(home, G_DIR_SEPARATOR_S, NULL);
 #endif
 }
+
+/*
+   returns text without quotes or NULL for empty or broken string
+   any text up to first '"' is skipped
+   tail is set to point at the char after the second '"'
+   or at the ending \0
+
+*/
+
+gchar *quoted_value(const gchar *text, const gchar **tail)
+{
+       const gchar *ptr;
+       gint c = 0;
+       gint l = strlen(text);
+       gchar *retval = NULL;
+
+       if (tail) *tail = text;
+
+       if (l == 0) return retval;
+
+       while (c < l && text[c] != '"') c++;
+       if (text[c] == '"')
+               {
+               gint e;
+               c++;
+               ptr = text + c;
+               e = c;
+               while (e < l)
+                       {
+                       if (text[e-1] != '\\' && text[e] == '"') break;
+                       e++;
+                       }
+               if (text[e] == '"')
+                       {
+                       if (e - c > 0)
+                               {
+                               gchar *substring = g_strndup(ptr, e - c);
+
+                               if (substring)
+                                       {
+                                       retval = g_strcompress(substring);
+                                       g_free(substring);
+                                       }
+                               }
+                       }
+               if (tail) *tail = text + e + 1;
+               }
+       else
+               /* for compatibility with older formats (<0.3.7)
+                * read a line without quotes too */
+               {
+               c = 0;
+               while (c < l && text[c] != '\n' && !g_ascii_isspace(text[c])) c++;
+               if (c != 0)
+                       {
+                       retval = g_strndup(text, c);
+                       }
+               if (tail) *tail = text + c;
+               }
+
+       return retval;
+}
+
+gchar *escquote_value(const gchar *text)
+{
+       gchar *e;
+
+       if (!text) return g_strdup("\"\"");
+
+       e = g_strescape(text, "");
+       if (e)
+               {
+               gchar *retval = g_strdup_printf("\"%s\"", e);
+               g_free(e);
+               return retval;
+               }
+       return g_strdup("\"\"");
+}
index 6489ae5..692a3f6 100644 (file)
@@ -17,5 +17,7 @@ gdouble get_zoom_increment(void);
 gchar *utf8_validate_or_convert(const gchar *text);
 gint utf8_compare(const gchar *s1, const gchar *s2, gboolean case_sensitive);
 gchar *expand_tilde(const gchar *filename);
+gchar *quoted_value(const gchar *text, const gchar **tail);
+gchar *escquote_value(const gchar *text);
 
 #endif /* MISC_H */
index 255460e..135b1e9 100644 (file)
 #include "bar_exif.h"
 #include "editors.h"
 #include "filefilter.h"
+#include "misc.h"
 #include "pixbuf-renderer.h"
 #include "secure_save.h"
 #include "slideshow.h"
 #include "ui_fileops.h"
 
-
 /*
  *-----------------------------------------------------------------------------
  * line write/parse routines (private)
  *-----------------------------------------------------------------------------
  */
 
-/*
-   returns text without quotes or NULL for empty or broken string
-   any text up to first '"' is skipped
-   tail is set to point at the char after the second '"'
-   or at the ending \0
-
-*/
-
-gchar *quoted_value(const gchar *text, const gchar **tail)
-{
-       const gchar *ptr;
-       gint c = 0;
-       gint l = strlen(text);
-       gchar *retval = NULL;
-
-       if (tail) *tail = text;
-
-       if (l == 0) return retval;
-
-       while (c < l && text[c] != '"') c++;
-       if (text[c] == '"')
-               {
-               gint e;
-               c++;
-               ptr = text + c;
-               e = c;
-               while (e < l)
-                       {
-                       if (text[e-1] != '\\' && text[e] == '"') break;
-                       e++;
-                       }
-               if (text[e] == '"')
-                       {
-                       if (e - c > 0)
-                               {
-                               gchar *substring = g_strndup(ptr, e - c);
-
-                               if (substring)
-                                       {
-                                       retval = g_strcompress(substring);
-                                       g_free(substring);
-                                       }
-                               }
-                       }
-               if (tail) *tail = text + e + 1;
-               }
-       else
-               /* for compatibility with older formats (<0.3.7)
-                * read a line without quotes too */
-               {
-               c = 0;
-               while (c < l && text[c] != '\n' && !g_ascii_isspace(text[c])) c++;
-               if (c != 0)
-                       {
-                       retval = g_strndup(text, c);
-                       }
-               if (tail) *tail = text + c;
-               }
-
-       return retval;
-}
-
-gchar *escquote_value(const gchar *text)
-{
-       gchar *e;
-
-       if (!text) return g_strdup("\"\"");
-
-       e = g_strescape(text, "");
-       if (e)
-               {
-               gchar *retval = g_strdup_printf("\"%s\"", e);
-               g_free(e);
-               return retval;
-               }
-       return g_strdup("\"\"");
-}
 
 static void write_char_option(SecureSaveInfo *ssi, gchar *label, gchar *text)
 {
index a565dd9..a762838 100644 (file)
@@ -14,9 +14,6 @@
 #ifndef RCFILE_H
 #define RCFILE_H
 
-gchar *quoted_value(const gchar *text, const gchar **tail);
-gchar *escquote_value(const gchar *text);
-
 gboolean save_options_to(const gchar *utf8_path, ConfOptions *options);
 gboolean load_options_from(const gchar *utf8_path, ConfOptions *options);