- while (strlen(inbuf) > 0) {
- pos = (-1);
- for (i=strlen(inbuf); i>=0; --i) {
- if ((inbuf[i]=='<')&&(inbuf[i+1]=='?')) pos = i;
- }
- if (pos < 0) {
- wprintf("%s", inbuf);
- strcpy(inbuf, "");
- }
- else {
- strncpy(outbuf, inbuf, pos);
- outbuf[pos] = 0;
- wprintf("%s", outbuf);
- strcpy(inbuf, &inbuf[pos]);
- pos = 1;
- for (i=strlen(inbuf); i>=0; --i) {
- if (inbuf[i]=='>') pos = i;
- }
- strncpy(key, &inbuf[2], pos-2);
- key[pos-2] = 0;
- print_value_of(key);
- strcpy(inbuf, &inbuf[pos+1]);
- }
- }
+void InitTemplateCache(void)
+{
+ LoadTemplateDir(static_dirs[0],
+ WirelessTemplateCache,
+ TemplateCache);
+ LoadTemplateDir(static_dirs[1],
+ WirelessLocalTemplateCache,
+ LocalTemplateCache);
+}
+
+void tmplput_serv_ip(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context)
+{
+ StrBufAppendPrintf(Target, "%d", WC->ctdl_pid);
+}
+
+void tmplput_serv_nodename(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context)
+{
+ escputs(serv_info.serv_nodename); ////TODO: respcect Target
+}
+
+void tmplput_serv_humannode(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context)
+{
+ escputs(serv_info.serv_humannode);////TODO: respcect Target
+}
+
+void tmplput_serv_fqdn(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context)
+{
+ escputs(serv_info.serv_fqdn);////TODO: respcect Target
+}
+
+void tmmplput_serv_software(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context)
+{
+ escputs(serv_info.serv_software);////TODO: respcect Target
+}
+
+void tmplput_serv_rev_level(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context)
+{
+ StrBufAppendPrintf(Target, "%d.%02d",
+ serv_info.serv_rev_level / 100,
+ serv_info.serv_rev_level % 100);
+}
+
+void tmmplput_serv_bbs_city(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context)
+{
+ escputs(serv_info.serv_bbs_city);////TODO: respcect Target
+}
+
+void tmplput_current_user(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context)
+{
+ escputs(WC->wc_fullname);////TODO: respcect Target
+}
+
+void tmplput_current_room(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context)
+{
+ escputs(WC->wc_roomname);////TODO: respcect Target
+}
+
+
+typedef struct _HashIterator {
+ HashList *StaticList;
+ RetrieveHashlistFunc GetHash;
+ HashDestructorFunc Destructor;
+ SubTemplFunc DoSubTemplate;
+} HashIterator;
+
+void tmpl_iterate_subtmpl(StrBuf *Target, int nArgs, WCTemplateToken *Tokens, void *Context)
+{
+ void *vIt;
+ HashIterator *It;
+ HashList *List;
+ HashPos *it;
+ long len;
+ const char *Key;
+ void *vContext;
+ StrBuf *SubBuf;
+
+ if (!GetHash(Iterators,
+ Tokens->Params[0]->Start,
+ Tokens->Params[0]->len,
+ &vIt))
+ return;
+ It = (HashIterator*) vIt;
+ if (It->StaticList == NULL)
+ List = It->GetHash();
+ else
+ List = It->StaticList;
+
+ SubBuf = NewStrBuf();
+ it = GetNewHashPos();
+ while (GetNextHashPos(List, it, &len, &Key, &vContext)) {
+ It->DoSubTemplate(SubBuf, vContext);
+ DoTemplate(Tokens->Params[0]->Start,
+ Tokens->Params[0]->len,
+ vContext, SubBuf);
+
+ StrBufAppendBuf(Target, SubBuf, 0);
+ FlushStrBuf(SubBuf);