#ifdef DBG_PREFS_HASH
dbg_PrintHash(Hash, PrintPref, NULL);
#endif
- HashPos = GetNewHashPos();
+ HashPos = GetNewHashPos(Hash, 0);
while (GetNextHashPos(Hash, HashPos, &len, &Key, &Value)!=0)
{
size_t nchars;
StrBuf *buf, *encBuf;
int *time_format_cache;
- time_format_cache = &(WC->time_format_cache);
-
- if (!havebstr("change_button")) {
- safestrncpy(WC->ImportantMessage,
- _("Cancelled. No settings were changed."),
- sizeof WC->ImportantMessage);
- display_main_menu();
- return;
- }
+ time_format_cache = &(WC->time_format_cache);
+
+ if (!havebstr("change_button")) {
+ safestrncpy(WC->ImportantMessage,
+ _("Cancelled. No settings were changed."),
+ sizeof WC->ImportantMessage);
+ display_main_menu();
+ return;
+ }
+
+ /**
+ * Set the last argument to 1 only for the final setting, so
+ * we don't send the prefs file to the server repeatedly
+ */
+ set_preference("roomlistview", NewStrBufPlain(bstr("roomlistview"), -1), 0);
+ fmt = lbstr("calhourformat");
+ set_pref_long("calhourformat", fmt, 0);
+ if (fmt == 24)
+ *time_format_cache = WC_TIMEFORMAT_24;
+ else
+ *time_format_cache = WC_TIMEFORMAT_AMPM;
+
+ set_pref_long("weekstart", lbstr("weekstart"), 0);
+ set_pref_yesno("use_sig", yesbstr("use_sig"), 0);
+ set_pref_long("daystart", lbstr("daystart"), 0);
+ set_pref_long("dayend", lbstr("dayend"), 0);
+ set_preference("default_header_charset", NewStrBufPlain(bstr("default_header_charset"), -1), 0);
+ set_preference("emptyfloors", NewStrBufPlain(bstr("emptyfloors"), -1), 0);
+ set_preference("defaultfrom", NewStrBufDup(sbstr("defaultfrom")), 0);
+ set_preference("defaultname", NewStrBufDup(sbstr("defaultname")), 0);
+ set_preference("defaulthandle", NewStrBufDup(sbstr("defaulthandle")), 0);
- /**
- * Set the last argument to 1 only for the final setting, so
- * we don't send the prefs file to the server repeatedly
- */
- set_preference("roomlistview", NewStrBufPlain(bstr("roomlistview"), -1), 0);
- fmt = lbstr("calhourformat");
- set_pref_long("calhourformat", fmt, 0);
- if (fmt == 24)
- *time_format_cache = WC_TIMEFORMAT_24;
- else
- *time_format_cache = WC_TIMEFORMAT_AMPM;
-
- set_pref_long("weekstart", lbstr("weekstart"), 0);
- set_pref_yesno("use_sig", yesbstr("use_sig"), 0);
- set_pref_long("daystart", lbstr("daystart"), 0);
- set_pref_long("dayend", lbstr("dayend"), 0);
- set_preference("default_header_charset", NewStrBufPlain(bstr("default_header_charset"), -1), 0);
- set_preference("emptyfloors", NewStrBufPlain(bstr("emptyfloors"), -1), 0);
buf = NewStrBufPlain(bstr("signature"), -1);
encBuf = NewStrBuf();
#define PRF_YESNO 4
-void tmplput_CFG_Value(StrBuf *Target, int nArgs, WCTemplateToken *Token, void *Context)
+void tmplput_CFG_Value(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType)
{
StrBuf *Setting;
- if (get_PREFERENCE(Token->Params[0]->Start,
- Token->Params[0]->len,
+ if (get_PREFERENCE(Tokens->Params[0]->Start,
+ Tokens->Params[0]->len,
&Setting))
- StrBufAppendBuf(Target, Setting, 0);
+ StrBufAppendTemplate(Target, nArgs, Tokens, Context, ContextType, Setting, 1);
}
-void tmplput_CFG_Descr(StrBuf *Target, int nArgs, WCTemplateToken *Token, void *Context)
+void tmplput_CFG_Descr(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType)
{
const char *SettingStr;
- SettingStr = PrefGetLocalStr(Token->Params[0]->Start,
- Token->Params[0]->len);
+ SettingStr = PrefGetLocalStr(Tokens->Params[0]->Start,
+ Tokens->Params[0]->len);
if (SettingStr != NULL)
StrBufAppendBufPlain(Target, SettingStr, -1, 0);
}
-void CfgZoneTempl(StrBuf *TemplBuffer, void *Context)
+void CfgZoneTempl(StrBuf *TemplBuffer, void *vContext, WCTemplateToken *Token)
{
+ StrBuf *Zone = (StrBuf*) vContext;
+ SVPutBuf("ZONENAME", Zone, 1);
}
-int ConditionalPreference(WCTemplateToken *Token, void *Context)
+int ConditionalPreference(WCTemplateToken *Tokens, void *Context, int ContextType)
{
+ StrBuf *Pref;
- void *hash_value;
-
- if (!GetHash(PreferenceHooks,
- Token->Params[2]->Start,
- Token->Params[2]->len,
- &hash_value))
+ if (!get_PREFERENCE(Tokens->Params[2]->Start,
+ Tokens->Params[2]->len,
+ &Pref))
return 0;
+
+ if (Tokens->nParameters == 3) {
+ return 1;
+ }
+ else if (Tokens->Params[3]->Type == TYPE_STR)
+ return ((Tokens->Params[3]->len == StrLength(Pref)) &&
+ (strcmp(Tokens->Params[3]->Start, ChrPtr(Pref)) == 0));
+ else
+ return (StrTol(Pref) == Tokens->Params[3]->lvalue);
+}
+
+HashList *GetGVEAHash(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType)
+{
+ StrBuf *Rcp;
+ HashList *List = NULL;
+ int Done = 0;
+ int i, n = 1;
+ char N[64];
+
+ Rcp = NewStrBuf();
+ serv_puts("GVEA");
+ StrBuf_ServGetln(Rcp);
+ if (ChrPtr(Rcp)[0] == '1') {
+ FlushStrBuf(Rcp);
+ List = NewHash(1, NULL);
+ while (!Done && (StrBuf_ServGetln(Rcp)>=0)) {
+ if ( (StrLength(Rcp)==3) &&
+ !strcmp(ChrPtr(Rcp), "000"))
+ {
+ Done = 1;
+ }
+ else {
+ i = snprintf(N, sizeof(N), "%d", n);
+ StrBufTrim(Rcp);
+ Put(List, N, i, Rcp, HFreeStrBuf);
+ Rcp = NewStrBuf();
+ }
+ n++;
+ }
+ }
+ FreeStrBuf(&Rcp);
+ return List;
+}
+void DeleteGVEAHash(HashList **KillMe)
+{
+ DeleteHash(KillMe);
+}
- Prefs *Newpref = (Prefs*) hash_value;
- return (strcmp(Token->Params[3]->Start, Newpref->PrefStr) == 0);
+HashList *GetGVSNHash(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context, int ContextType)
+{
+ StrBuf *Rcp;
+ HashList *List = NULL;
+ int Done = 0;
+ int i, n = 1;
+ char N[64];
+
+ Rcp = NewStrBuf();
+ serv_puts("GVSN");
+ StrBuf_ServGetln(Rcp);
+ if (ChrPtr(Rcp)[0] == '1') {
+ FlushStrBuf(Rcp);
+ List = NewHash(1, NULL);
+ while (!Done && (StrBuf_ServGetln(Rcp)>=0)) {
+ if ( (StrLength(Rcp)==3) &&
+ !strcmp(ChrPtr(Rcp), "000"))
+ {
+ Done = 1;
+ }
+ else {
+ i = snprintf(N, sizeof(N), "%d", n);
+ StrBufTrim(Rcp);
+ Put(List, N, i, Rcp, HFreeStrBuf);
+ Rcp = NewStrBuf();
+ }
+ n++;
+ }
+ }
+ FreeStrBuf(&Rcp);
+ return List;
+}
+void DeleteGVSNHash(HashList **KillMe)
+{
+ DeleteHash(KillMe);
}
RegisterPreference("signature",_("Use this signature:"),PRF_QP_STRING);
RegisterPreference("default_header_charset", _("Default character set for email headers:") ,PRF_STRING);
RegisterPreference("emptyfloors", _("Show empty floors"), PRF_YESNO);
+ RegisterPreference("defaultfrom", _("Prefered Email Address"), PRF_STRING);
+ RegisterPreference("defaultname", _("Prefered Email Sendername"), PRF_STRING);
+ RegisterPreference("defaulthandle", _("Prefered Name for posting messages"), PRF_STRING);
+
+
+ RegisterNamespace("PREF:VALUE", 1, 2, tmplput_CFG_Value, CTX_NONE);
+ RegisterNamespace("PREF:DESCR", 1, 1, tmplput_CFG_Descr, CTX_NONE);
+ RegisterIterator("PREF:ZONE", 0, ZoneHash, NULL, CfgZoneTempl, NULL, CTX_PREF, CTX_NONE);
+
+ RegisterConditional(HKEY("COND:PREF"), 4, ConditionalPreference, CTX_NONE);
- RegisterNamespace("PREF:VALUE", 1, 1, tmplput_CFG_Value);
- RegisterNamespace("PREF:DESCR", 1, 1, tmplput_CFG_Descr);
- RegisterIterator("PREF:ZONE", ZoneHash, NULL, CfgZoneTempl, NULL);
+ RegisterIterator("PREF:VALID:EMAIL:ADDR", 0, NULL,
+ GetGVEAHash, NULL, DeleteGVEAHash, CTX_STRBUF, CTX_NONE);
+ RegisterIterator("PREF:VALID:EMAIL:NAME", 0, NULL,
+ GetGVSNHash, NULL, DeleteGVSNHash, CTX_STRBUF, CTX_NONE);
- RegisterConditional(HKEY("COND:PREF"), 4, ConditionalPreference);
}
/*@}*/