mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-02 19:16:15 +00:00
Merged revisions 215270 via svnmerge from
https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r215270 | dhubbard | 2009-09-01 18:04:52 -0500 (Tue, 01 Sep 2009) | 12 lines Use strrchr() so SoftHangup will correctly truncate multi-hyphen channel names In general channel names are in the form Foo/Bar-Z, but the channel name could have multiple hyphens and look like Foo/B-a-r-Z. Use strrchr to truncate the channel name at the last hyphen. (closes issue #15810) Reported by: dhubbard Patches: dw-softhangup-1.4.patch uploaded by dhubbard (license 733) ........ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@215338 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -103,11 +103,13 @@ static int softhangup_exec(struct ast_channel *chan, const char *data)
|
||||
ast_copy_string(name, c->name, sizeof(name));
|
||||
if (ast_test_flag(&flags, OPTION_ALL)) {
|
||||
/* CAPI is set up like CAPI[foo/bar]/clcnt */
|
||||
if (!strcmp(c->tech->type, "CAPI"))
|
||||
if (!strcmp(c->tech->type, "CAPI")) {
|
||||
cut = strrchr(name, '/');
|
||||
/* Basically everything else is Foo/Bar-Z */
|
||||
else
|
||||
cut = strchr(name, '-');
|
||||
} else {
|
||||
/* use strrchr() because Foo/Bar-Z could actually be Foo/B-a-r-Z */
|
||||
cut = strrchr(name,'-');
|
||||
}
|
||||
/* Get rid of what we've cut */
|
||||
if (cut)
|
||||
*cut = 0;
|
||||
|
Reference in New Issue
Block a user