diff options
author | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2003-05-22 14:24:06 +0000 |
---|---|---|
committer | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2003-05-22 14:24:06 +0000 |
commit | 858771a1c097f8142bf5bba59d95b518f6000927 (patch) | |
tree | 26ea3a9c71f23e541f75145b9d1b764d042f5441 | |
parent | b31b5067c4b7c7615f984ed83fdb6cbaa879db5c (diff) |
Only send 180 ringing once, fix CTRL+D in main code
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@1052 f38db490-d61c-443f-a65b-d21fe96a405b
-rwxr-xr-x | asterisk.c | 15 | ||||
-rwxr-xr-x | channels/chan_sip.c | 4 |
2 files changed, 12 insertions, 7 deletions
diff --git a/asterisk.c b/asterisk.c index 933ab5594..a00c990d5 100755 --- a/asterisk.c +++ b/asterisk.c @@ -1373,12 +1373,15 @@ int main(int argc, char *argv[]) ast_cli_register(&astexit); consolethread = pthread_self(); - while ( (buf = (char *)el_gets(el, &num) ) != NULL && num != 0) { - - if (buf[strlen(buf)-1] == '\n') - buf[strlen(buf)-1] = '\0'; - - consolehandler((char *)buf); + for (;;) { + buf = (char *)el_gets(el, &num); + if (buf) { + if (buf[strlen(buf)-1] == '\n') + buf[strlen(buf)-1] = '\0'; + + consolehandler((char *)buf); + } else + ast_cli(STDOUT_FILENO, "\nUse EXIT or QUIT to exist, or STOP NOW to shutdown Asterisk\n"); } } else { diff --git a/channels/chan_sip.c b/channels/chan_sip.c index df04adb39..e4bd5af94 100755 --- a/channels/chan_sip.c +++ b/channels/chan_sip.c @@ -179,6 +179,7 @@ static struct sip_pvt { int expiry; /* How long we take to expire */ int branch; /* One random number */ int canreinvite; /* Do we support reinvite */ + int ringing; /* Have sent 180 ringing */ int progress; /* Have sent 183 message progress */ int tag; /* Another random number */ int nat; /* Whether to try to support NAT */ @@ -1011,8 +1012,9 @@ static int sip_indicate(struct ast_channel *ast, int condition) switch(condition) { case AST_CONTROL_RINGING: if (ast->_state == AST_STATE_RING) { - if (!p->progress) { + if (!p->progress && !p->ringing) { transmit_response(p, "180 Ringing", &p->initreq); + p->ringing = 1; break; } else { /* Oops, we've sent progress tones. Let Asterisk do it instead */ |