X-Git-Url: http://git.dolda2000.com/gitweb/?a=blobdiff_plain;f=lib%2Fuimisc.c;h=407e4003925560846efdaa9da3c967041464d25d;hb=c0fe4f459e4c542293aeb1433da2461440a15e36;hp=d989e1ef7aa372e06194e0750e640b5cd9ff0328;hpb=cece2a51a8039efc3d67f37b11b7c8122641cd85;p=doldaconnect.git diff --git a/lib/uimisc.c b/lib/uimisc.c index d989e1e..407e400 100644 --- a/lib/uimisc.c +++ b/lib/uimisc.c @@ -869,6 +869,9 @@ static int getfnlistcallback(struct dc_response *resp) fn->name = swcsdup(ires->argv[2].val.str); fn->numusers = ires->argv[3].val.num; fn->state = ires->argv[4].val.num; + if(fn->pubid != NULL) + free(fn->pubid); + fn->pubid = swcsdup(ires->argv[5].val.str); } else { fn = newfn(); fn->id = ires->argv[0].val.num; @@ -876,6 +879,7 @@ static int getfnlistcallback(struct dc_response *resp) fn->name = swcsdup(ires->argv[2].val.str); fn->numusers = ires->argv[3].val.num; fn->state = ires->argv[4].val.num; + fn->pubid = swcsdup(ires->argv[5].val.str); fn->found = 1; } dc_freeires(ires); @@ -1218,14 +1222,22 @@ void dc_uimisc_handlenotify(struct dc_response *resp) if((fn = dc_findfnetnode(ires->argv[0].val.num)) != NULL) { if((peer = dc_fnetfindpeer(fn, ires->argv[1].val.str)) == NULL) - addpeer(fn, ires->argv[1].val.str, ires->argv[2].val.str); + { + peer = addpeer(fn, ires->argv[1].val.str, ires->argv[2].val.str); + if(fn->newpeercb != NULL) + fn->newpeercb(peer); + } } break; case 631: if((fn = dc_findfnetnode(ires->argv[0].val.num)) != NULL) { if((peer = dc_fnetfindpeer(fn, ires->argv[1].val.str)) != NULL) + { + if(fn->delpeercb != NULL) + fn->delpeercb(peer); delpeer(peer); + } } break; case 632: @@ -1238,7 +1250,7 @@ void dc_uimisc_handlenotify(struct dc_response *resp) free(peer->nick); peer->nick = swcsdup(ires->argv[2].val.str); } - for(i = 3; i < resp->rlines[0].argc; i += 3) + for(i = 4; i < resp->rlines[0].argc; i += 3) { switch(wcstol(resp->rlines[0].argv[i + 1], NULL, 10)) { @@ -1253,6 +1265,8 @@ void dc_uimisc_handlenotify(struct dc_response *resp) break; } } + if(fn->chpeercb != NULL) + fn->chpeercb(peer); } } break;