aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2003-05-22 14:24:06 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2003-05-22 14:24:06 +0000
commit858771a1c097f8142bf5bba59d95b518f6000927 (patch)
tree26ea3a9c71f23e541f75145b9d1b764d042f5441
parentb31b5067c4b7c7615f984ed83fdb6cbaa879db5c (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-xasterisk.c15
-rwxr-xr-xchannels/chan_sip.c4
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 */