[svn-commits] branch oej/multiparking r16194 - in
/team/oej/multiparking: ./ channels/ func...
svn-commits at lists.digium.com
svn-commits at lists.digium.com
Wed Mar 29 12:33:48 MST 2006
Author: oej
Date: Wed Mar 29 13:33:45 2006
New Revision: 16194
URL: http://svn.digium.com/view/asterisk?rev=16194&view=rev
Log:
- Move to stringfields
- Implement support in the CHANNEL function
Modified:
team/oej/multiparking/Makefile
team/oej/multiparking/channels/chan_iax2.c
team/oej/multiparking/channels/chan_sip.c
team/oej/multiparking/channels/chan_zap.c
team/oej/multiparking/funcs/func_channel.c
team/oej/multiparking/include/asterisk/channel.h
team/oej/multiparking/res/res_features.c
Modified: team/oej/multiparking/Makefile
URL: http://svn.digium.com/view/asterisk/team/oej/multiparking/Makefile?rev=16194&r1=16193&r2=16194&view=diff
==============================================================================
--- team/oej/multiparking/Makefile (original)
+++ team/oej/multiparking/Makefile Wed Mar 29 13:33:45 2006
@@ -46,7 +46,7 @@
#K6OPT = -DK6OPT
#Tell gcc to optimize the code
-OPTIMIZE+=#-O6
+OPTIMIZE+=-O6
else
# Stack backtraces, while useful for debugging, are incompatible with optimizations
ifeq (${OSARCH},Linux)
Modified: team/oej/multiparking/channels/chan_iax2.c
URL: http://svn.digium.com/view/asterisk/team/oej/multiparking/channels/chan_iax2.c?rev=16194&r1=16193&r2=16194&view=diff
==============================================================================
--- team/oej/multiparking/channels/chan_iax2.c (original)
+++ team/oej/multiparking/channels/chan_iax2.c Wed Mar 29 13:33:45 2006
@@ -3585,7 +3585,7 @@
if (!ast_strlen_zero(i->accountcode))
ast_string_field_set(tmp, accountcode, i->accountcode);
if (!ast_strlen_zero(i->parkinglot))
- ast_copy_string(tmp->parkinglot, i->parkinglot, sizeof(tmp->parkinglot));
+ ast_string_field_set(tmp, parkinglot, i->parkinglot);
if (i->amaflags)
tmp->amaflags = i->amaflags;
ast_copy_string(tmp->context, i->context, sizeof(tmp->context));
Modified: team/oej/multiparking/channels/chan_sip.c
URL: http://svn.digium.com/view/asterisk/team/oej/multiparking/channels/chan_sip.c?rev=16194&r1=16193&r2=16194&view=diff
==============================================================================
--- team/oej/multiparking/channels/chan_sip.c (original)
+++ team/oej/multiparking/channels/chan_sip.c Wed Mar 29 13:33:45 2006
@@ -2992,7 +2992,7 @@
if (!ast_strlen_zero(i->musicclass))
ast_string_field_set(tmp, musicclass, i->musicclass);
if (!ast_strlen_zero(i->parkinglot))
- ast_copy_string(tmp->parkinglot, i->parkinglot, sizeof(tmp->parkinglot));
+ ast_string_field_set(tmp, parkinglot, i->parkinglot);
i->owner = tmp;
ast_mutex_lock(&usecnt_lock);
usecnt++;
Modified: team/oej/multiparking/channels/chan_zap.c
URL: http://svn.digium.com/view/asterisk/team/oej/multiparking/channels/chan_zap.c?rev=16194&r1=16193&r2=16194&view=diff
==============================================================================
--- team/oej/multiparking/channels/chan_zap.c (original)
+++ team/oej/multiparking/channels/chan_zap.c Wed Mar 29 13:33:45 2006
@@ -5203,7 +5203,7 @@
if (!ast_strlen_zero(i->musicclass))
ast_string_field_set(tmp, musicclass, i->musicclass);
if (!ast_strlen_zero(i->parkinglot))
- ast_copy_string(tmp->parkinglot, i->parkinglot, sizeof(tmp->parkinglot));
+ ast_string_field_set(tmp, parkinglot, i->parkinglot);
if (!i->owner)
i->owner = tmp;
if (!ast_strlen_zero(i->accountcode))
Modified: team/oej/multiparking/funcs/func_channel.c
URL: http://svn.digium.com/view/asterisk/team/oej/multiparking/funcs/func_channel.c?rev=16194&r1=16193&r2=16194&view=diff
==============================================================================
--- team/oej/multiparking/funcs/func_channel.c (original)
+++ team/oej/multiparking/funcs/func_channel.c Wed Mar 29 13:33:45 2006
@@ -73,6 +73,8 @@
locked_copy_string(chan, buf, chan->language, len);
else if (!strcasecmp(data, "musicclass"))
locked_copy_string(chan, buf, chan->musicclass, len);
+ else if (!strcasecmp(data, "parkinglot"))
+ locked_copy_string(chan, buf, chan->parkinglot, len);
else if (!strcasecmp(data, "state"))
locked_copy_string(chan, buf, ast_state2str(chan->_state), len);
else if (!strcasecmp(data, "channeltype"))
@@ -96,6 +98,8 @@
if (!strcasecmp(data, "language"))
locked_string_field_set(chan, language, value);
+ else if (!strcasecmp(data, "parkinglot"))
+ locked_string_field_set(chan, parkinglot, value);
else if (!strcasecmp(data, "musicclass"))
locked_string_field_set(chan, musicclass, value);
else if (!strcasecmp(data, "callgroup"))
@@ -123,6 +127,7 @@
"R/O channeltype technology used for channel\n"
"R/W language language for sounds played\n"
"R/W musicclass class (from musiconhold.conf) for hold music\n"
+ "R/W parkinglot parkinglot for parking\n"
"R/O state state for channel\n"
"R/O tonezone zone for indications played\n"
"R/O videonativeformat format used natively for video\n"
Modified: team/oej/multiparking/include/asterisk/channel.h
URL: http://svn.digium.com/view/asterisk/team/oej/multiparking/include/asterisk/channel.h?rev=16194&r1=16193&r2=16194&view=diff
==============================================================================
--- team/oej/multiparking/include/asterisk/channel.h (original)
+++ team/oej/multiparking/include/asterisk/channel.h Wed Mar 29 13:33:45 2006
@@ -284,14 +284,11 @@
AST_STRING_FIELD(accountcode); /*! Account code for billing */
AST_STRING_FIELD(call_forward); /*! Where to forward to if asked to dial on this interface */
AST_STRING_FIELD(uniqueid); /*! Unique Channel Identifier */
+ AST_STRING_FIELD(parkinglot); /*! Default parking lot, if empty, default parking lot */
);
/*! File descriptor for channel -- Drivers will poll on these file descriptors, so at least one must be non -1. */
int fds[AST_MAX_FDS];
-
-
- /*! Default parking lot, if empty, default parking lot */
- char parkinglot[AST_MAX_EXTENSION];
/*! Music State*/
void *music_state;
Modified: team/oej/multiparking/res/res_features.c
URL: http://svn.digium.com/view/asterisk/team/oej/multiparking/res/res_features.c?rev=16194&r1=16193&r2=16194&view=diff
==============================================================================
--- team/oej/multiparking/res/res_features.c (original)
+++ team/oej/multiparking/res/res_features.c Wed Mar 29 13:33:45 2006
@@ -14,22 +14,6 @@
* This program is free software, distributed under the terms of
* the GNU General Public License Version 2. See the LICENSE file
* at the top of the source tree.
- */
-
-/*----------------- BRANCH NOTE *------------------------------
- * This code is under development
- *
- * Input is appreciated, e-mail to oej at edvina.net
- *
- * Goal:
- * To implement multiple parking lots, so that if you
- * run a virtual PBX with many customers in the same
- * Asterisk, you can set up multiple parking lots
- * Or one for each group in your company
- * And maybe a special VIP parking lot for the boss :-)
- *
- * Plase add test reviews to the bug tracker
- * http://bugs.digium.com/view.php?id=6113
*/
/*! \file
@@ -325,14 +309,14 @@
if (parkinglotname) {
if (option_debug)
- ast_log(LOG_DEBUG, "---------**--------- Found chanvar Parkinglot: %s\n", parkinglotname);
+ ast_log(LOG_DEBUG, "Found chanvar Parkinglot: %s\n", parkinglotname);
parkinglot = find_parkinglot(parkinglotname);
}
if (!parkinglot)
parkinglot = default_parkinglot;
if (option_debug)
- ast_log(LOG_DEBUG, "---------**--------- Parkinglot: %s\n", parkinglot->name);
+ ast_log(LOG_DEBUG, "Parkinglot: %s\n", parkinglot->name);
if (!(pu = ast_calloc(1, sizeof(*pu)))) {
@@ -1732,7 +1716,7 @@
AST_LIST_TRAVERSE(&parkinglots, parkinglot, list) {
if (!strcasecmp(parkinglot->name, name)) {
if (option_debug)
- ast_log(LOG_DEBUG, "---------**--------- Found Parkinglot: %s\n", parkinglot->name);
+ ast_log(LOG_DEBUG, "Found Parkinglot: %s\n", parkinglot->name);
return(parkinglot);
}
}
@@ -1741,7 +1725,7 @@
return parkinglot;
}
-/*--- park_call_exec: Park a call */
+/*! \brief Park a call */
static int park_call_exec(struct ast_channel *chan, void *data)
{
/* Data is unused at the moment but could contain a parking
@@ -1757,7 +1741,7 @@
parkinglotname = findparkinglotname(chan);
if (parkinglotname) {
- ast_log(LOG_DEBUG, "---------**--------- Found chanvar Parkinglot: %s\n", parkinglotname);
+ ast_log(LOG_DEBUG, "Found chanvar Parkinglot: %s\n", parkinglotname);
parkinglot = find_parkinglot(parkinglotname);
}
/* Setup the exten/priority to be s/1 since we don't know
@@ -1776,7 +1760,7 @@
return res;
}
-/*--- park_exec: Pick up parked call in dial plan */
+/*! \brief Pick up parked call in dial plan */
static int park_exec_full(struct ast_channel *chan, void *data, struct ast_parkinglot *parkinglot)
{
int res=0;
@@ -1800,7 +1784,8 @@
parkinglotname = findparkinglotname(chan);
if (parkinglotname) {
- ast_log(LOG_DEBUG, "---------**--------- Using parking lot: %s\n", parkinglotname);
+ if (option_debug)
+ ast_log(LOG_DEBUG, "Using parking lot: %s\n", parkinglotname);
parkinglot = find_parkinglot(parkinglotname);
}
pu = parkinglot->occupiedlots;
More information about the svn-commits
mailing list