[asterisk-commits] russell: branch group/bindings r204011 - in /team/group/bindings: ./ apps/ bu...

SVN commits to the Asterisk project asterisk-commits at lists.digium.com
Mon Jun 29 10:03:16 CDT 2009


Author: russell
Date: Mon Jun 29 10:03:10 2009
New Revision: 204011

URL: http://svn.asterisk.org/svn-view/asterisk?view=rev&rev=204011
Log:
resolve, reset

Added:
    team/group/bindings/cdr/cdr_syslog.c
      - copied unchanged from r203985, trunk/cdr/cdr_syslog.c
    team/group/bindings/configs/cdr_syslog.conf.sample
      - copied unchanged from r203985, trunk/configs/cdr_syslog.conf.sample
Modified:
    team/group/bindings/   (props changed)
    team/group/bindings/CHANGES
    team/group/bindings/UPGRADE.txt
    team/group/bindings/apps/app_chanspy.c
    team/group/bindings/build_tools/menuselect-deps.in
    team/group/bindings/channels/chan_dahdi.c
    team/group/bindings/channels/sig_pri.c
    team/group/bindings/configure
    team/group/bindings/configure.ac
    team/group/bindings/main/app.c
    team/group/bindings/main/file.c

Propchange: team/group/bindings/
------------------------------------------------------------------------------
    automerge = *

Propchange: team/group/bindings/
------------------------------------------------------------------------------
Binary property 'branch-1.4-merged' - no diff available.

Propchange: team/group/bindings/
------------------------------------------------------------------------------
--- svnmerge-integrated (original)
+++ svnmerge-integrated Mon Jun 29 10:03:10 2009
@@ -1,1 +1,1 @@
-/trunk:1-203794
+/trunk:1-204010

Modified: team/group/bindings/CHANGES
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/bindings/CHANGES?view=diff&rev=204011&r1=204010&r2=204011
==============================================================================
--- team/group/bindings/CHANGES (original)
+++ team/group/bindings/CHANGES Mon Jun 29 10:03:10 2009
@@ -50,16 +50,19 @@
 Applications
 ------------
  * Added progress option to the app_dial D() option.  When progress DTMF is
-   present, those values are sent immediatly upon receiving a PROGRESS message
+   present, those values are sent immediately upon receiving a PROGRESS message
    regardless if the call has been answered or not.
  * Added functionality to the app_dial F() option to continue with execution
    at the current location when no parameters are provided.
  * Added c() option to app_chanspy. This option allows custom DTMF to be set
-   to cycle through the next avaliable channel.  By default this is still '*'.
+   to cycle through the next available channel.  By default this is still '*'.
  * Added x() option to app_chanspy.  This option allows DTMF to be set to
    exit the application.
  * The Voicemail application has been improved to automatically ignore messages
    that only contain silence.
+ * The ChanSpy application now has the 's' option, which makes the application
+   automatically exit once it hits a point where no more channels are available
+   to spy on.
 
 Dialplan Functions
 ------------------
@@ -84,7 +87,7 @@
 
    The possible values are:
 
-     on - normal mode (the echo canceller is actually reinitalized)
+     on - normal mode (the echo canceller is actually reinitialized)
      off - disabled
      fax - FAX/data mode (NLP disabled if possible, otherwise completely
            disabled)
@@ -163,12 +166,6 @@
    reflect this change.  Previous options such as 'sslenable' still work,
    but options with the 'tls' prefix are preferred.
 
-Logger
-------
- * The rarely used 'event_log' and LOG_EVENT channel have been removed; the few
-   users of this channel in the tree have been converted to LOG_NOTICE or removed
-   (in cases where the same message was already generated to another channel).
-
 Channel Event Logging
 ---------------------
  * A new interface, CEL, is introduced here. CEL logs single events, much like
@@ -185,6 +182,8 @@
    linkedid is based on uniqueID, but spreads to other channels as transfers, dials,
    etc are performed. Thus the peices of CDR can be grouped into multilegged sets.
  * Multiple files and formats can now be specified in cdr_custom.conf.
+ * cdr_syslog has been added which allows CDRs to be written directly to syslog.
+   See configs/cdr_syslog.conf.sample for more information.
 
 Calendaring for Asterisk
 ------------------------
@@ -500,12 +499,8 @@
    as well as periodically updating the IP address. These properties allow for
    better performance as well as recovery in the event of an IP change.
  * Performance improvements via using hash tables (astobj2) and doubly-linked lists to improve 
-   load/reload of large numbers of peers/users by ~40x (for large lists of peers.
-   Initially, we saw 4x improvement in call setup/destruction, but at the time
-   of merging, this gain has disappeared; further research will be done to try
-   and restore this performance improvement. Astobj2 refcounting is now used
-   for users, peers, and dialogs.  Users are encouraged to assist in regression
-   testing and problem reporting!
+   load/reload of large numbers of peers/users by ~40x (for large lists of peers).
+   These changes also provide performance improvements for call setup and tear down.
  * Added ability to specify registration expiry time on a per registration basis in
    the register line.
  * Added support for T140 RED - redundancy in T.140 to prevent text loss due to
@@ -1141,11 +1136,11 @@
 --------------
   * Added rotatestrategy option to logger.conf, along with two new options:
      "timestamp" which will use the time to name the logger files instead of
-     sequence number; and "rotate", which rotates the names of the logfiles,
+     sequence number; and "rotate", which rotates the names of the log files,
      similar to the way syslog rotates files.
   * Added exec_after_rotate option to logger.conf, which allows a system
      command to be run after rotation.  This is primarily useful with
-     rotatestrategry=rotate, to allow a limit on the number of logfiles kept
+     rotatestrategy=rotate, to allow a limit on the number of log files kept
      and to ensure that the oldest log file gets deleted.
   * Added realtime support for the queue log
 

Modified: team/group/bindings/UPGRADE.txt
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/bindings/UPGRADE.txt?view=diff&rev=204011&r1=204010&r2=204011
==============================================================================
--- team/group/bindings/UPGRADE.txt (original)
+++ team/group/bindings/UPGRADE.txt Mon Jun 29 10:03:10 2009
@@ -20,11 +20,16 @@
 
 From 1.6.2 to 1.6.3:
 
+* The rarely used 'event_log' and LOG_EVENT channel have been removed; the few
+  users of this channel in the tree have been converted to LOG_NOTICE or removed
+  (in cases where the same message was already generated to another channel).
+
 * The usage of RTP inside of Asterisk has now become modularized. This means
   the Asterisk RTP stack now exists as a loadable module, res_rtp_asterisk.
   If you are not using autoload=yes in modules.conf you will need to ensure
   it is set to load. If not, then any module which uses RTP (such as chan_sip)
   will not be able to send or receive calls.
+
 * The app_dahdiscan.c file has been removed, but the dialplan app DAHDIScan still 
   remains. It now exists within app_chanspy.c and retains the exact same 
   functionality as before. 

Modified: team/group/bindings/apps/app_chanspy.c
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/bindings/apps/app_chanspy.c?view=diff&rev=204011&r1=204010&r2=204011
==============================================================================
--- team/group/bindings/apps/app_chanspy.c (original)
+++ team/group/bindings/apps/app_chanspy.c Mon Jun 29 10:03:10 2009
@@ -134,6 +134,9 @@
 					</option>
 					<option name="o">
 						<para>Only listen to audio coming from this channel.</para>
+					</option>
+					<option name="s">
+						<para>Stop when no more channels are left to spy on.</para>
 					</option>
 					<option name="X">
 						<para>Allow the user to exit ChanSpy to a valid single digit
@@ -266,6 +269,9 @@
 					<option name="o">
 						<para>Only listen to audio coming from this channel.</para>
 					</option>
+					<option name="s">
+						<para>Stop when there are no more extensions left to spy on.</para>
+					</option>
 					<option name="X">
 						<para>Allow the user to exit ChanSpy to a valid single digit
 						numeric extension in the current context or the context
@@ -349,6 +355,7 @@
 	OPTION_DTMF_EXIT         = (1 << 14),	/* Set DTMF to exit, added for DAHDIScan integration */
 	OPTION_DTMF_CYCLE        = (1 << 15),	/* Custom DTMF for cycling next avaliable channel, (default is '*') */
 	OPTION_DAHDI_SCAN        = (1 << 16),	/* Scan groups in DAHDIScan mode */
+	OPTION_STOP              = (1 << 17),
 };
 
 enum {
@@ -373,6 +380,7 @@
 	AST_APP_OPTION_ARG('r', OPTION_RECORD, OPT_ARG_RECORD),
 	AST_APP_OPTION_ARG('e', OPTION_ENFORCED, OPT_ARG_ENFORCED),
 	AST_APP_OPTION('o', OPTION_READONLY),
+	AST_APP_OPTION('s', OPTION_STOP),
 	AST_APP_OPTION('X', OPTION_EXIT),
 	AST_APP_OPTION('s', OPTION_NOTECH),
 	AST_APP_OPTION_ARG('n', OPTION_NAME, OPT_ARG_NAME),
@@ -956,6 +964,9 @@
 
 		if (res == -1 || ast_check_hangup(chan))
 			break;
+		if (ast_test_flag(flags, OPTION_STOP) && !next_autochan) {
+			break;
+		}
 	}
 exit:
 

Modified: team/group/bindings/build_tools/menuselect-deps.in
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/bindings/build_tools/menuselect-deps.in?view=diff&rev=204011&r1=204010&r2=204011
==============================================================================
--- team/group/bindings/build_tools/menuselect-deps.in (original)
+++ team/group/bindings/build_tools/menuselect-deps.in Mon Jun 29 10:03:10 2009
@@ -51,6 +51,7 @@
 OPENSSL=@PBX_OPENSSL@
 SUPPSERV=@PBX_SUPPSERV@
 SWIG=@PBX_SWIG@
+SYSLOG=@PBX_SYSLOG@
 TONEZONE=@PBX_TONEZONE@
 UNIXODBC=@PBX_UNIXODBC@
 USB=@PBX_USB@

Modified: team/group/bindings/channels/chan_dahdi.c
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/bindings/channels/chan_dahdi.c?view=diff&rev=204011&r1=204010&r2=204011
==============================================================================
--- team/group/bindings/channels/chan_dahdi.c (original)
+++ team/group/bindings/channels/chan_dahdi.c Mon Jun 29 10:03:10 2009
@@ -15667,7 +15667,7 @@
 	}
 	/*< \todo why check for the pseudo in the per-channel section.
 	 * Any actual use for manual setup of the pseudo channel? */
-	if (!found_pseudo && reload == 0) {
+	if (!found_pseudo && reload != 1) {
 		/* use the default configuration for a channel, so
 		   that any settings from real configured channels
 		   don't "leak" into the pseudo channel config

Modified: team/group/bindings/channels/sig_pri.c
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/bindings/channels/sig_pri.c?view=diff&rev=204011&r1=204010&r2=204011
==============================================================================
--- team/group/bindings/channels/sig_pri.c (original)
+++ team/group/bindings/channels/sig_pri.c Mon Jun 29 10:03:10 2009
@@ -1811,15 +1811,12 @@
 	}
 
 	p->digital = IS_DIGITAL(ast->transfercapability);
-	/* Add support for exclusive override */
-	if (p->priexclusive)
+
+	/* Should the picked channel be used exclusively? */
+	if (p->priexclusive || p->pri->nodetype == PRI_NETWORK) {
 		exclusive = 1;
-	else {
-	/* otherwise, traditional behavior */
-		if (p->pri->nodetype == PRI_NETWORK)
-			exclusive = 0;
-		else
-			exclusive = 1;
+	} else {
+		exclusive = 0;
 	}
 	
 	pri_sr_set_channel(sr, PVT_TO_CHANNEL(p), exclusive, 1);

Modified: team/group/bindings/configure.ac
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/bindings/configure.ac?view=diff&rev=204011&r1=204010&r2=204011
==============================================================================
--- team/group/bindings/configure.ac (original)
+++ team/group/bindings/configure.ac Mon Jun 29 10:03:10 2009
@@ -1877,6 +1877,8 @@
 AC_SUBST([GENERIC_ODBC_INCLUDE])
 AC_SUBST([PBX_GENERIC_ODBC])
 
+PBX_SYSLOG=0
+
 if test "${ac_cv_header_syslog_h}" = "yes"; then
    # syslog facilities
    AST_C_DEFINE_CHECK([SYSLOG_FACILITY_LOG_AUTH],     [LOG_AUTH],     [syslog.h])
@@ -1890,7 +1892,10 @@
    AST_C_DEFINE_CHECK([SYSLOG_FACILITY_LOG_NEWS],     [LOG_NEWS],     [syslog.h])
    AST_C_DEFINE_CHECK([SYSLOG_FACILITY_LOG_SYSLOG],   [LOG_SYSLOG],   [syslog.h])
    AST_C_DEFINE_CHECK([SYSLOG_FACILITY_LOG_UUCP],     [LOG_UUCP],     [syslog.h])
-fi
+   PBX_SYSLOG=1
+fi
+
+AC_SUBST([PBX_SYSLOG])
 
 AC_CONFIG_FILES([build_tools/menuselect-deps makeopts channels/h323/Makefile])
 AST_CHECK_MANDATORY

Modified: team/group/bindings/main/app.c
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/bindings/main/app.c?view=diff&rev=204011&r1=204010&r2=204011
==============================================================================
--- team/group/bindings/main/app.c (original)
+++ team/group/bindings/main/app.c Mon Jun 29 10:03:10 2009
@@ -700,6 +700,7 @@
 	struct ast_dsp *sildet = NULL;   /* silence detector dsp */
 	int totalsilence = 0;
 	int dspsilence = 0;
+	int olddspsilence = 0;
 	int rfmt = 0;
 	struct ast_silence_generator *silgen = NULL;
 	char prependfile[80];
@@ -826,7 +827,10 @@
 				if (maxsilence > 0) {
 					dspsilence = 0;
 					ast_dsp_silence(sildet, f, &dspsilence);
-					totalsilence += dspsilence;
+					if (olddspsilence > dspsilence) {
+						totalsilence += olddspsilence;
+					}
+					olddspsilence = dspsilence;
 
 					if (dspsilence > maxsilence) {
 						/* Ended happily with silence */
@@ -906,6 +910,10 @@
 
 	if (!prepend) {
 		/* Reduce duration by a total silence amount */
+		if (olddspsilence <= dspsilence) {
+			totalsilence += dspsilence;
+		}
+
         	if (totalsilence > 0)
 			*duration -= (totalsilence - 200) / 1000;
 		if (*duration < 0) {

Modified: team/group/bindings/main/file.c
URL: http://svn.asterisk.org/svn-view/asterisk/team/group/bindings/main/file.c?view=diff&rev=204011&r1=204010&r2=204011
==============================================================================
--- team/group/bindings/main/file.c (original)
+++ team/group/bindings/main/file.c Mon Jun 29 10:03:10 2009
@@ -1227,7 +1227,14 @@
 				} else {
 					res = fr->subclass;
 					if (strchr(forward, res)) {
+						int eoftest;
 						ast_stream_fastforward(c->stream, skip_ms);
+						eoftest = fgetc(c->stream->f);
+						if (feof(c->stream->f)) {
+							ast_stream_rewind(c->stream, skip_ms);
+						} else {
+							ungetc(eoftest, c->stream->f);
+						}
 					} else if (strchr(reverse, res)) {
 						ast_stream_rewind(c->stream, skip_ms);
 					} else if (strchr(breakon, res)) {




More information about the asterisk-commits mailing list