#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
#include "filefilter.h"
#include "cache.h"
-#include "rcfile.h"
-#include "secure_save.h"
#include "thumb_standard.h"
#include "ui_fileops.h"
#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
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("\"\"");
+}
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 */
#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)
{
#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);