#include <zlib.h>
#endif
-
-/* Work around PACKAGE/VERSION defs that are (not supposed to be?) in ical.h */
-#ifdef PACKAGE
-# define CTDL_PACKAGE PACKAGE
-# undef PACKAGE
-#endif
-
-#ifdef PACKAGE_STRING
-# define CTDL_PACKAGE_STRING PACKAGE_STRING
-//# undef PACKAGE_STRING
-#endif
-
-#ifdef VERSION
-# define CTDL_VERSION VERSION
-# undef VERSION
-#endif
-
-#include <ical.h>
+#include <libical/ical.h>
#undef PACKAGE
#undef VERSION
* \brief Dynamic content for variable substitution in templates
*/
typedef struct _wcsubst {
- int wcs_type; /**< which type of ??? */
- char wcs_key[32]; /**< ??? what?*/
- void *wcs_value; /**< ???? what?*/
+ int wcs_type; /**< which type of Substitution are we */
+ char wcs_key[32]; /**< copy of our hashkey for debugging */
+ StrBuf *wcs_value; /**< if we're a string, keep it here */
+ long lvalue; /**< type long? keep data here */
void (*wcs_function)(void); /**< funcion hook ???*/
} wcsubst;
#define TYPE_STR 1
#define TYPE_LONG 2
-#define MAXPARAM 10
+#define MAXPARAM 20
typedef struct _TemplateParam {
const char *Start;
int Type;
} TemplateParam;
typedef struct _TemplateToken {
+ StrBuf *FlatToken;
+ long Line;
const char *pTokenStart;
size_t TokenStart;
size_t TokenEnd;
const char *pTokenEnd;
- int IsGettext;
+ int Flags;
const char *pName;
size_t NameEnd;
TemplateParam *Params[MAXPARAM];
} WCTemplateToken;
+
typedef void (*WCHandlerFunc)(StrBuf *Target, int nArgs, WCTemplateToken *Token, void *Context);
void RegisterNS(const char *NSName, long len,
int nMinArgs,
#define RegisterNamespace(a, b, c, d) RegisterNS(a, sizeof(a)-1, b, c, d)
+
+typedef int (*WCConditionalFunc)(WCTemplateToken *Token, void *Context);
+typedef struct _ConditionalStruct {
+ int nParams;
+ WCConditionalFunc CondF;
+} ConditionalStruct;
+void RegisterConditional(const char *Name, long len,
+ int nParams,
+ WCConditionalFunc CondF);
+
+
+
typedef void (*SubTemplFunc)(StrBuf *TemplBuffer, void *Context);
typedef HashList *(*RetrieveHashlistFunc)(void);
typedef void (*HashDestructorFunc) (HashList *KillMe);
WCS_FUNCTION, /**< its a function callback */
WCS_SERVCMD, /**< its a command to send to the citadel server */
WCS_STRBUF, /**< its a strbuf we own */
- WCS_STRBUF_REF /**< its a strbuf we mustn't free */
+ WCS_STRBUF_REF, /**< its a strbuf we mustn't free */
+ WCS_LONG /**< its an integer */
};
/**
char content_type[SIZ]; /**< the content itself ???*/
char filename[SIZ]; /**< the filename hooked to this content ??? */
char *data; /**< the data pool; aka this content */
+ long lvalue; /**< if we put a long... */
};
/**
time_t cache_timestamp; /**< ??? todo */
HashList *IconBarSetttings; /**< which icons should be shown / not shown? */
long current_iconbar; /**< What is currently in the iconbar? */
- StrBuf *floordiv_expanded; /**< which floordiv currently expanded */
+ const StrBuf *floordiv_expanded; /**< which floordiv currently expanded */
int selected_language; /**< Language selected by user */
time_t last_pager_check; /**< last time we polled for instant msgs */
int nonce; /**< session nonce (to prevent session riding) */
StrBuf *UrlFragment2; /**< second urlfragment, if NEED_URL is specified by the handler*/
StrBuf *WBuf; /**< Our output buffer */
StrBuf *HBuf; /**< Our HeaderBuffer */
+
+ HashList *ServCfg; /**< cache our server config for editing */
};
/** values for WC->current_iconbar */
extern HashList *GlobalNS;
extern HashList *Iterators;
extern HashList *ZoneHash;
-
+extern HashList *Contitionals;
void InitialiseSemaphores(void);
void pullquote_fmout(void);
void wDumpContent(int);
-
/* These may return NULL if not foud */
#define sbstr(a) SBstr(a, sizeof(a) - 1)
const StrBuf *SBSTR(const char *key);
const StrBuf *SBstr(const char *key, size_t keylen);
#define xbstr(a, b) (char*) XBstr(a, sizeof(a) - 1, b)
-const char *XBstr(char *key, size_t keylen, size_t *len);
-const char *XBSTR(char *key, size_t *len);
+const char *XBstr(const char *key, size_t keylen, size_t *len);
+const char *XBSTR(const char *key, size_t *len);
#define lbstr(a) LBstr(a, sizeof(a) - 1)
-long LBstr(char *key, size_t keylen);
-long LBSTR(char *key);
+long LBstr(const char *key, size_t keylen);
+long LBSTR(const char *key);
#define ibstr(a) IBstr(a, sizeof(a) - 1)
-int IBstr(char *key, size_t keylen);
-int IBSTR(char *key);
+int IBstr(const char *key, size_t keylen);
+int IBSTR(const char *key);
#define havebstr(a) HaveBstr(a, sizeof(a) - 1)
-int HaveBstr(char *key, size_t keylen);
-int HAVEBSTR(char *key);
+int HaveBstr(const char *key, size_t keylen);
+int HAVEBSTR(const char *key);
#define yesbstr(a) YesBstr(a, sizeof(a) - 1)
-int YesBstr(char *key, size_t keylen);
-int YESBSTR(char *key);
+int YesBstr(const char *key, size_t keylen);
+int YESBSTR(const char *key);
/* TODO: get rid of the non-const-typecast */
#define bstr(a) (char*) Bstr(a, sizeof(a) - 1)
-const char *BSTR(char *key);
-const char *Bstr(char *key, size_t keylen);
+const char *BSTR(const char *key);
+const char *Bstr(const char *key, size_t keylen);
void serv_gets(char *strbuf);
void serv_write(const char *buf, int nbytes);
void serv_puts(const char *string);
+void serv_putbuf(const StrBuf *string);
void serv_printf(const char *format,...)__attribute__((__format__(__printf__,1,2)));
void load_floorlist(void);
void shutdown_sessions(void);
void SVPut(char *keyname, size_t keylen, int keytype, char *Data);
#define svput(a, b, c) SVPut(a, sizeof(a) - 1, b, c)
+void SVPutLong(char *keyname, size_t keylen, long Data);
+#define svputlong(a, b) SVPutLong(a, sizeof(a) - 1, b)
void svprintf(char *keyname, size_t keylen, int keytype, const char *format,...) __attribute__((__format__(__printf__,4,5)));
void SVPRINTF(char *keyname, int keytype, const char *format,...) __attribute__((__format__(__printf__,3,4)));
void SVCALLBACK(char *keyname, var_callback_fptr fcn_ptr);
void DoTemplate(const char *templatename, long len, void *Context, StrBuf *Target);
#define do_template(a, b) DoTemplate(a, sizeof(a) -1, b, NULL);
+void url_do_template(void);
int lingering_close(int fd);
void stop_selected_language(void);
void preset_locale(void);
void httplang_to_locale(char *LocaleString);
+void StrEndTab(StrBuf *Target, int tabnum, int num_tabs);
+void StrBeginTab(StrBuf *Target, int tabnum, int num_tabs);
+void StrTabbedDialog(StrBuf *Target, int num_tabs, StrBuf *tabnames[]);
void tabbed_dialog(int num_tabs, char *tabnames[]);
void begin_tab(int tabnum, int num_tabs);
void end_tab(int tabnum, int num_tabs);