[asterisk-commits] irroot: branch irroot/distrotech-customers-1.8 r325802 - /team/irroot/distrot...
SVN commits to the Asterisk project
asterisk-commits at lists.digium.com
Thu Jun 30 07:15:51 CDT 2011
Author: irroot
Date: Thu Jun 30 07:15:46 2011
New Revision: 325802
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=325802
Log:
Check cached entries before counting mailbox
Modified:
team/irroot/distrotech-customers-1.8/channels/chan_sip.c
Modified: team/irroot/distrotech-customers-1.8/channels/chan_sip.c
URL: http://svnview.digium.com/svn/asterisk/team/irroot/distrotech-customers-1.8/channels/chan_sip.c?view=diff&rev=325802&r1=325801&r2=325802
==============================================================================
--- team/irroot/distrotech-customers-1.8/channels/chan_sip.c (original)
+++ team/irroot/distrotech-customers-1.8/channels/chan_sip.c Thu Jun 30 07:15:46 2011
@@ -1325,6 +1325,7 @@
static void *do_monitor(void *data);
static int restart_monitor(void);
static void peer_mailboxes_to_str(struct ast_str **mailbox_str, struct sip_peer *peer);
+static int get_cached_mwi(struct sip_peer *peer, int *new, int *old);
static struct ast_variable *copy_vars(struct ast_variable *src);
static int dialog_find_multiple(void *obj, void *arg, int flags);
/* static int sip_addrcmp(char *name, struct sockaddr_in *sin); Support for peer matching */
@@ -4912,7 +4913,7 @@
}
if (p->type & SIP_TYPE_PEER) {
peer_mailboxes_to_str(&mailbox_str, p);
- if (!ast_strlen_zero(mailbox_str->str)) {
+ if (!ast_strlen_zero(mailbox_str->str) && !get_cached_mwi(p, &newmsgs, &oldmsgs)) {
ast_app_inboxcount(mailbox_str->str, &newmsgs, &oldmsgs);
p->lastmsgssent = ((newmsgs > 0x7fff ? 0x7fff0000 : (newmsgs << 16)) | (oldmsgs > 0xffff ? 0xffff : oldmsgs));
}
More information about the asterisk-commits
mailing list