aboutsummaryrefslogtreecommitdiffstats
path: root/recipes/kobodeluxe/files/kobodeluxe-sysconf-support.patch
blob: 1f62b31d71909a4fdd0bbf74d9d8ccec95b155b2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
Index: KoboDeluxe-0.5.1/configure.in
===================================================================
--- KoboDeluxe-0.5.1.orig/configure.in	2008-02-10 20:51:37.000000000 +0100
+++ KoboDeluxe-0.5.1/configure.in	2008-02-10 21:40:09.000000000 +0100
@@ -36,6 +36,7 @@
 SCOREDIR='$(sharedstatedir)/kobo-deluxe/scores'
 CONFIGDIR='HOME>>'
 CONFIGFILE='.kobodlrc'
+USE_SYSCONF=1
 EXEFILE=kobodl
 case "$target_os" in
 	linux*)
@@ -57,6 +58,7 @@
 		SCOREDIR='EXE>>scores'
 		CONFIGDIR='EXE>>'
 		CONFIGFILE='kobodl.cfg'
+    USE_SYSCONF=0
 		EXEFILE=kobodl.exe
 		MATHLIB=""
 		;;
@@ -68,6 +70,7 @@
 		SCOREDIR='EXE>>scores'
 		CONFIGDIR='EXE>>'
 		CONFIGFILE='kobodl.cfg'
+    USE_SYSCONF=0
 		EXEFILE=kobodl.exe
 		MATHLIB=""
 		;;
@@ -105,10 +108,12 @@
 AM_CONDITIONAL(BUILD_MACOSX_BUNDLE, test x$build_macosx_bundle = xyes)
 AM_CONDITIONAL(BUILD_SIMPLE_BUNDLE, test x$build_simple_bundle = xyes)
 AM_CONDITIONAL(UNIX_SCOREDIR, test x$unix_scoredir = xyes)
+AC_DEFINE_UNQUOTED([USE_SYSCONF], [$USE_SYSCONF], [Define to 1 to use Unix-style sysconf dir for default configuration.])
 AC_SUBST(DATADIR)
 AC_SUBST(SCOREDIR)
 AC_SUBST(CONFIGDIR)
 AC_SUBST(CONFIGFILE)
+AC_SUBST(KOBO_SYSCONF)
 AC_SUBST(EXEFILE)
 AC_SUBST(MATHLIB)
 
Index: KoboDeluxe-0.5.1/kobo.cpp
===================================================================
--- KoboDeluxe-0.5.1.orig/kobo.cpp	2008-02-10 20:57:32.000000000 +0100
+++ KoboDeluxe-0.5.1/kobo.cpp	2008-02-10 21:27:22.000000000 +0100
@@ -1293,9 +1293,38 @@
 	FILE *f = fmap->fopen(KOBO_CONFIG_DIR "/" KOBO_CONFIG_FILE, "r");
 	if(f)
 	{
+    log_puts(VLOG, "Loading personal configuration from: "\
+                   KOBO_CONFIG_DIR "/" KOBO_CONFIG_FILE "\n");
 		p->read(f);
 		fclose(f);
 	}
+#if USE_SYSCONF
+  /* On Unixen, where they have SYSCONF_DIR (usually /etc) try to get
+   * the default configuration from a file stored there before
+   * giving up.
+   *
+   * This gives packagers a chance to provide a proper default
+   * (playable) configuration for all those little Linux-based
+   * gadgets that are flying around.
+   */
+  else
+  {
+  	f = fmap->fopen(SYSCONF_DIR "/kobo-deluxe/default-config", "r");
+	  if(f)
+  	{
+      log_puts(VLOG, "Loading configuration defaults from: "\
+                     SYSCONF_DIR "/kobo-deluxe/default-config\n");
+
+  		p->read(f);
+	  	fclose(f);
+  	}
+    else
+      log_puts(VLOG, "Using built-in configuration defaults.\n");
+
+  }
+#else
+  log_puts(VLOG, "Using built-in configuration defaults.\n");
+#endif
 }