X-Git-Url: http://git.dolda2000.com/gitweb/?a=blobdiff_plain;f=daemon%2Fui.c;h=44e4605975021b63dcf701a2271980f0d9ab1dfb;hb=5ec60e4217863b0e2d6a86ba3f60f60c68608227;hp=51528086dc6ec6d18bfe6558cf2f3645e2291722;hpb=5c851d430732bd833615350cca963f9482b1af24;p=doldaconnect.git diff --git a/daemon/ui.c b/daemon/ui.c index 5152808..44e4605 100644 --- a/daemon/ui.c +++ b/daemon/ui.c @@ -159,6 +159,8 @@ struct uidata size_t cwsize, cwdata; }; +static int uiread(struct socket *sk, struct uidata *data); +static int uierror(struct socket *sk, int err, struct uidata *data); static int srcheta(struct search *srch, void *uudata); static int srchcommit(struct search *srch, void *uudata); static int srchres(struct search *srch, struct srchres *sr, void *uudata); @@ -1054,18 +1056,19 @@ static void cmd_cansrch(struct socket *sk, struct uidata *data, int argc, wchar_ sq(sk, 0, L"200", L"Search cancelled", NULL); } -static void fcmdread(struct socket *sk, struct uidata *data) +static int fcmdread(struct socket *sk, struct uidata *data) { char *buf; size_t bufsize; if((buf = sockgetinbuf(sk, &bufsize)) == NULL) - return; + return(0); bufcat(data->fcmdbuf, buf, bufsize); free(buf); + return(0); } -static void fcmderr(struct socket *sk, int err, struct uidata *data) +static int fcmderr(struct socket *sk, int err, struct uidata *data) { wchar_t *wbuf, *p, *p2; @@ -1082,7 +1085,7 @@ static void fcmderr(struct socket *sk, int err, struct uidata *data) } data->fcmdbufsize = data->fcmdbufdata = 0; sq(data->sk, 0, L"505", L"An error occurred on the pipe to the filtercmd", L"%%s", strerror(err), NULL); - return; + return(0); } putsock(data->fcmdsk); data->fcmdsk = NULL; @@ -1100,7 +1103,7 @@ static void fcmderr(struct socket *sk, int err, struct uidata *data) if(wbuf == NULL) { sq(data->sk, 0, L"504", L"Filtercmd sent data which could not be converted from the local charset", NULL); - return; + return(0); } p = wbuf; for(p2 = wcschr(p, L'\n'); p2 != NULL; p2 = wcschr(p, L'\n')) @@ -1117,6 +1120,7 @@ static void fcmderr(struct socket *sk, int err, struct uidata *data) sq(data->sk, 0, L"200", L"%%ls", p, NULL); } free(wbuf); + return(0); } static void cmd_filtercmd(struct socket *sk, struct uidata *data, int argc, wchar_t **argv) @@ -1182,9 +1186,8 @@ static void cmd_filtercmd(struct socket *sk, struct uidata *data, int argc, wcha data->fcmdbuf = NULL; } data->fcmdbufsize = data->fcmdbufdata = 0; - data->fcmdsk->data = data; - data->fcmdsk->readcb = (void (*)(struct socket *, void *))fcmdread; - data->fcmdsk->errcb = (void (*)(struct socket *, int, void *))fcmderr; + CBREG(data->fcmdsk, socket_read, (int (*)(struct socket *, void *))fcmdread, NULL, NULL); + CBREG(data->fcmdsk, socket_err, (int (*)(struct socket *, int, void *))fcmderr, NULL, NULL); } static void cmd_lstrarg(struct socket *sk, struct uidata *data, int argc, wchar_t **argv) @@ -1511,8 +1514,8 @@ static void freeuidata(struct uidata *data) data->prev->next = data->next; if(data == actives) actives = data->next; - data->sk->readcb = NULL; - data->sk->errcb = NULL; + CBUNREG(data->sk, socket_read, uiread, data); + CBUNREG(data->sk, socket_err, uierror, data); putsock(data->sk); while((qcmd = unlinkqcmd(data)) != NULL) freequeuecmd(qcmd); @@ -1590,7 +1593,7 @@ static struct uidata *newuidata(struct socket *sk) return(data); } -static void uiread(struct socket *sk, struct uidata *data) +static int uiread(struct socket *sk, struct uidata *data) { int ret, done; char *newbuf; @@ -1602,7 +1605,7 @@ static void uiread(struct socket *sk, struct uidata *data) if(data->indata > 1024) data->indata = 0; if((newbuf = sockgetinbuf(sk, &datalen)) == NULL) - return; + return(0); sizebuf(&data->inbuf, &data->inbufsize, data->indata + datalen, 1, 1); memcpy(data->inbuf + data->indata, newbuf, datalen); free(newbuf); @@ -1755,26 +1758,29 @@ static void uiread(struct socket *sk, struct uidata *data) break; } } + return(0); } -static void uierror(struct socket *sk, int err, struct uidata *data) +static int uierror(struct socket *sk, int err, struct uidata *data) { if(err) flog(LOG_WARNING, "error occurred on UI socket: %s", strerror(err)); freeuidata(data); + return(0); } -static void uiaccept(struct socket *sk, struct socket *newsk, void *data) +static int uiaccept(struct socket *sk, struct socket *newsk, void *data) { struct uidata *uidata; - newsk->data = uidata = newuidata(newsk); + uidata = newuidata(newsk); socksettos(newsk, confgetint("ui", "uitos")); if(uidata == NULL) - return; - newsk->errcb = (void (*)(struct socket *, int, void *))uierror; - newsk->readcb = (void (*)(struct socket *, void *))uiread; + return(0); + CBREG(newsk, socket_err, (int (*)(struct socket *, int, void *))uierror, NULL, data); + CBREG(newsk, socket_read, (int (*)(struct socket *, void *))uiread, NULL, data); queuecmd(uidata, &commands[0], 0, NULL); + return(0); } static int srcheta(struct search *srch, void *uudata)