]> code.citadel.org Git - citadel.git/blobdiff - webcit/preferences.h
* realize types in preferences like thought at the start
[citadel.git] / webcit / preferences.h
index d02ae73bc3790c1056b026deb7f3b2eea2609332..779ad3c2a9dec6773b678bef78d90712ea3fa694 100644 (file)
@@ -1,10 +1,26 @@
+
+
+#define PRF_STRING 1
+#define PRF_INT 2
+#define PRF_QP_STRING 3
+#define PRF_YESNO 4
+
+
+
+typedef void (*PrefEvalFunc)(StrBuf *Preference, long lvalue); 
+void RegisterPreference(const char *Setting, long SettingLen, 
+                       const char *PrefStr, 
+                       long Type, 
+                       PrefEvalFunc OnLoad);
+
+
 void load_preferences(void);
 void save_preferences(void);
 #define get_preference(a, b) get_PREFERENCE(a, sizeof(a) - 1, b)
-#define get_pref(a, b)       get_PREFERENCE(ChrPtr(a), StrLength(a), b)
+#define get_pref(a, b)       get_PREFERENCE(SKEY(a), b)
 int get_PREFERENCE(const char *key, size_t keylen, StrBuf **value);
 #define set_preference(a, b, c) set_PREFERENCE(a, sizeof(a) - 1, b, c)
-#define set_pref(a, b, c)       set_PREFERENCE(ChrPtr(a), StrLength(a), b, c)
+#define set_pref(a, b, c)       set_PREFERENCE(SKEY(a), b, c)
 void set_PREFERENCE(const char *key, size_t keylen, StrBuf *value, int save_to_server);
 
 #define get_pref_long(a, b, c) get_PREF_LONG(a, sizeof(a) - 1, b, c)
@@ -15,7 +31,7 @@ void set_PREF_LONG(const char *key, size_t keylen, long value, int save_to_serve
 #define get_pref_yesno(a, b, c) get_PREF_YESNO(a, sizeof(a) - 1, b, c)
 int get_PREF_YESNO(const char *key, size_t keylen, int *value, int Default);
 #define set_pref_yesno(a, b, c) set_PREF_YESNO(a, sizeof(a) - 1, b, c)
-void set_PREF_YESNO(const char *key, size_t keylen, int value, int save_to_server);
+void set_PREF_YESNO(const char *key, size_t keylen, long value, int save_to_server);
 
 #define get_room_pref(a) get_ROOM_PREFS(a, sizeof(a) - 1)
 StrBuf *get_ROOM_PREFS(const char *key, size_t keylen);