Mercurial > pidgin
view src/protocols/zephyr/ZhmStat.c @ 10810:9a1ced2bc585
[gaim-migrate @ 12463]
This makes conversations contact aware, or is a start to it anyway.
All messages from the same contact will appear in the same IM tab.
Whoever messaged you last is who your messages go to.
Don't forget to run make install in the top level src directory, or some
plugin will likely crash gaim, as I changed a struct they use.
Known bugs include a crash if you close the convo window (clicking the X
on the tab doesn't crash however [actually it used to, but i fixed that one
already]), and the history plugin inserting history when it shouldn't.
There's probably many more tiny bugs. If you're wondering "how does it
handle X?" the answer is probably it doesn't. However, I think this is
all stuff our CPWs can handle, if I don't have time to fix it first (and
I probably won't til friday).
committer: Tailor Script <tailor@pidgin.im>
author | Tim Ringenbach <marv@pidgin.im> |
---|---|
date | Mon, 11 Apr 2005 02:20:34 +0000 |
parents | 43d6c08d7e96 |
children | 5727afad0fb8 |
line wrap: on
line source
/* This file is part of the Project Athena Zephyr Notification System. * It contains the ZhmStat() function. * * Created by: Marc Horowitz * * $Id: ZhmStat.c 9554 2004-04-24 09:02:28Z chipx86 $ * * Copyright (c) 1996 by the Massachusetts Institute of Technology. * For copying and distribution information, see the file * "mit-copyright.h". */ #include "internal.h" #include <sys/socket.h> #ifndef INADDR_LOOPBACK #define INADDR_LOOPBACK 0x7f000001 #endif Code_t ZhmStat(hostaddr, notice) struct in_addr *hostaddr; ZNotice_t *notice; { struct servent *sp; struct sockaddr_in sin; ZNotice_t req; Code_t code; struct timeval tv; fd_set readers; (void) memset((char *)&sin, 0, sizeof(struct sockaddr_in)); sp = getservbyname(HM_SVCNAME, "udp"); sin.sin_port = (sp) ? sp->s_port : HM_SVC_FALLBACK; sin.sin_family = AF_INET; if (hostaddr) sin.sin_addr = *hostaddr; else sin.sin_addr.s_addr = htonl(INADDR_LOOPBACK); (void) memset((char *)&req, 0, sizeof(req)); req.z_kind = STAT; req.z_port = 0; req.z_class = HM_STAT_CLASS; req.z_class_inst = HM_STAT_CLIENT; req.z_opcode = HM_GIMMESTATS; req.z_sender = ""; req.z_recipient = ""; req.z_default_format = ""; req.z_message_len = 0; if ((code = ZSetDestAddr(&sin)) != ZERR_NONE) return(code); if ((code = ZSendNotice(&req, ZNOAUTH)) != ZERR_NONE) return(code); /* Wait up to ten seconds for a response. */ FD_ZERO(&readers); FD_SET(ZGetFD(), &readers); tv.tv_sec = 10; tv.tv_usec = 0; code = select(ZGetFD() + 1, &readers, NULL, NULL, &tv); if (code < 0 && errno != EINTR) return(errno); if (code == 0 || (code < 0 && errno == EINTR) || ZPending() == 0) return(ZERR_HMDEAD); return(ZReceiveNotice(notice, (struct sockaddr_in *) 0)); }