Mercurial > pidgin
diff src/protocols/zephyr/ZNewLocU.c @ 2086:424a40f12a6c
[gaim-migrate @ 2096]
moving protocols from plugins/ to src/protocols. making it so that you can select which protocols are compiled statically.
committer: Tailor Script <tailor@pidgin.im>
author | Eric Warmenhoven <eric@warmenhoven.org> |
---|---|
date | Tue, 31 Jul 2001 01:00:39 +0000 |
parents | |
children | 43d6c08d7e96 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/protocols/zephyr/ZNewLocU.c Tue Jul 31 01:00:39 2001 +0000 @@ -0,0 +1,51 @@ +/* This file is part of the Project Athena Zephyr Notification System. + * It contains source for the ZNewLocateUser function. + * + * Created by: Robert French + * + * $Source$ + * $Author: warmenhoven $ + * + * Copyright (c) 1987,1988,1991 by the Massachusetts Institute of Technology. + * For copying and distribution information, see the file + * "mit-copyright.h". + */ +/* $Header$ */ + +#include <internal.h> + +#ifndef lint +static const char rcsid_ZNewLocateUser_c[] = + "$Id: ZNewLocU.c 2096 2001-07-31 01:00:39Z warmenhoven $"; +#endif + +Code_t ZLocateUser(user, nlocs, auth) + char *user; + int *nlocs; + Z_AuthProc auth; +{ + Code_t retval; + ZNotice_t notice; + ZAsyncLocateData_t zald; + + (void) ZFlushLocations(); /* ZFlushLocations never fails (the library + is allowed to know this). */ + + if ((retval = ZRequestLocations(user, &zald, UNACKED, auth)) != ZERR_NONE) + return(retval); + + retval = Z_WaitForNotice (¬ice, ZCompareALDPred, &zald, SRV_TIMEOUT); + if (retval == ZERR_NONOTICE) + return ETIMEDOUT; + if (retval != ZERR_NONE) + return retval; + + if ((retval = ZParseLocations(¬ice, &zald, nlocs, NULL)) != ZERR_NONE) { + ZFreeNotice(¬ice); + return(retval); + } + + ZFreeNotice(¬ice); + ZFreeALD(&zald); + return(ZERR_NONE); +}