91157642ae40261224f13845885773d1dbeb7664
[asterisk/asterisk.git] / ChangeLog
1 2005-11-21  Josh Roberson <josh@asteriasgi.com>
2
3         * Makefile: Re-fix Darwin poll issues. 
4
5 2005-11-21  Russell Bryant  <russell@digium.com>
6
7         * apps/app_osplookup.c: Properly populate the number of results. (issue #5789)
8
9         * Makefile: Don't hard-code that poll functionality needs to be provided on Darwin.
10         * apps/Makefile: Fix incorrect portion of the patch to fix 'make install' on Solaris.
11
12         * channels/chan_iax2.c (iax2_getpeername): Return non-zero to indicate that a peer was found when using realtime (issue #5815)
13
14 2005-11-20  Russell Bryant  <russell@digium.com>
15
16         * Makefile apps/Makefile: Fix 'make install' for Solaris. (issue #5775)
17
18         * apps/app_record.c: Don't leak a frame if writing it to the file fails. (issue #5787)
19
20         * Makefile: Create the monitor spool directory when the other spool directories are created.
21
22         * pbx.c.c: Remove some useless checks and unnecessary calls to ast_strlen_zero(). (issue #5805)
23
24         * cli.c: Remove some unnecessary calls to ast_strlen_zero(). (issue #5804)
25
26         * channels/chan_oss.c configs/oss.conf.sample: Add the ability to set callerid in oss.conf. 
27
28         * channels/chan_sip.c channels/chan_iax2.c: Change warning messages about the number of scheduled events happening all at once to debug messages. (issue #5794)
29
30 2005-11-20  Josh Roberson <josh@asteriasgi.com>
31
32         * pbx/pbx_spool.c: Fix crash in spooler if set/setvar declared incorrectly. (issue #5806)
33
34         * apps/app_meetme.c: fix 'X' option in MeetMe, with slight modification. (issue #5773)
35
36         * apps/app_voicemail.c: Make sure we're copying the read digits when calling voicemail without a box. (issue #5774)
37
38         * apps/app_md5.c: Fix conditional jump option.
39
40         * apps/app_controlplayback.c: Fix conditional jump option.
41
42         * apps/app_hasnewvoicemail.c: Fix conditional jump option to jump properly, also correct a small typo in the description. (issue #5795)
43
44         * channels/chan_iax2.c: Fix output of iax2 show peer <peer> (issue #5792)
45
46         * UPGRADE.txt: Adjust note for naming conventions of iax2 channels. (issue #5792)
47
48         * res/res_musiconhold.c: Correct typo in ast_copy_string() for class->mode.  (issue #5803)
49
50 2005-11-19  Josh Roberson <josh@asteriasgi.com>
51
52         * channels/Makefile: Put chan_oss back into the default build. (issue #5799)
53
54         * funcs/func_enum.c: Fix long text description causing cosmetic defect on module load. (issue #5791)
55
56 2005-11-19  Russell Bryant  <russell@digium.com>
57
58         * app/app_echo.c: Update application description to be a bit more accurate, and clean up a little bit of code formatting
59
60 2005-11-16  Russell Bryant  <russell@digium.com>
61
62         * Makefile: Fix the output of Makefile generated variables to doxygen
63
64         * channels/chan_sip.c: Add missing carriage return and line feed to the SDP line indicating that we don't support VAD (issue #5780)
65
66 2005-11-16  Kevin P. Fleming  <kpfleming@digium.com>
67
68         * Asterisk 1.2.0 released.
69         
70 2005-11-16  Jeremy McNamara <jj@nufone.net>
71
72         * apps/app_voicemail.c (load_config): do not terminate asterisk if no voicemail config file
73         * channels/chan_skinny:  Don't register channel type until ready, code formatting updates
74
75 2005-11-16  Josh Roberson <josh@asteriasgi.com>
76
77         * Makefile:  Update to fix non-responsive remote console on Darwin (OSX)(issue #5757)
78
79 2005-11-16  Kevin P. Fleming  <kpfleming@digium.com>
80
81         * channels/Makefile: don't build chan_modem and sub-modules by default
82         * configs/modules.conf.sample: explicitly 'noload' chan_modem.so and submodules, in case old versions exist
83         
84         * res/Makefile: issue mpg123 not-installed warning at 'make install' time, not 'make'
85
86         * apps/app_forkcdr.c (forkcdr_exec): issue warning (and don't segfault) if ForkCDR is called on a channel that doesn't have a CDR (issue #5763)
87
88         * channel.c (ast_queue_hangup): ensure that the channel lock is held before changing its fields... (issue #5770)
89
90         * res/res_musiconhold.c: don't spit out incorrect log messages (and leak memory) during reload (issue #5766)
91
92         * channels/chan_sip.c (process_sdp): don't pass video codec number into ast_getformatname(), it is not valid input for that function (issue #5764)
93
94         * pbx/pbx_ael.c (match_assignment): properly parse equal signs surrounded by whitespace (issue #5761)
95
96         * doc/README.realtime: document the limitations of using FreeTDS with Realtime (issue #5767)
97
98 2005-11-15  Kevin P. Fleming  <kpfleming@digium.com>
99
100         * Makefile: use -g3 for compiler to include macro information for debugger
101
102         * astmm.c (__ast_vasprintf): don't re-use the ap list without copying it; that's not safe on some platforms (issue #5035)
103
104         * doc/README.backtrace: add note about properly building Asterisk to be able to produce backtraces; wrap text and remove DOS line endings
105
106         * channels/chan_sip.c (add_codec_to_sdp): add 'annexb=no' to G.729A SDP (issue #5539)
107
108         * channels/chan_alsa.c (alsa_hangup): handle autohangup properly (issue #5672)
109
110         * channels/chan_misdn.c (and other files): various fixes (issue #5739)
111
112         * channels/chan_sip.c (handle_request_info): properly forward 'flash' events received via SIP INFO (issue #5751, different patch)
113
114         * apps/app_disa.c (disa_exec): don't duplicate constant strings when not needed
115
116         * apps/app_playback.c (playback_exec): use correct logic tests for options (issue #5752)
117
118         * apps/app_disa.c (disa_exec): use standard arg parsing routines (issue #5736)
119
120 2005-11-15  Russell Bryant <russell@digium.com>
121
122         * manager.c: Don't crash on a SetVar action if the channel name is not set, or variable's value is not set (issue #5760)
123
124         * doc/README.variables: Add application exit status variables
125
126 2005-11-14  Josh Roberson <josh@asteriasgi.com>
127         
128         * manager.c: Fix crash on variable passing from AMI originate (issue #5737)
129
130 2005-11-14  Russell Bryant  <russell@digium.com>
131
132         * many files: Merge doxygen documentation updates. (issue #5605)
133
134         * apps/app_dial.c: Fix typo in RetryDial description.
135
136 2005-11-12  Russell Bryant  <russell@digium.com>
137
138         * channels/chan_oss.c: Fix a typo in an error message.
139
140 2005-11-11  Kevin P. Fleming  <kpfleming@digium.com>
141
142         * Asterisk 1.2.0-rc2 released.
143         
144 2005-11-11  Kevin P. Fleming  <kpfleming@digium.com>
145
146         * channels/chan_sip.c (thread_safe_rand): ensure that threads don't get the same random number (issue #5712)
147
148         * apps/app_voicemail.c (forward_message): correct bugs in message forwarding (issue #5718)
149         (copy_message): use correct path for locking (issue #5704)
150
151         * apps/app_dial.c (wait_for_answer): correct flag copying for automon feature (issue #5720)
152
153         * channels/chan_iax2.c: correct comment
154
155         * apps/app_voicemail.c (close_mailbox): correct previous commit (issue #5663)
156         (vm_change_password): fix password change writing (issue #5721)
157
158         * channels/chan_sip.c (transmit_invite): remove useless debug message; don't try to add OSP tokens to OPTIONS pings
159
160         * apps/app_voicemail.c (close_mailbox): properly remove deleted messages at mailbox close time (issue #5663)
161
162 2005-11-11  Mark Spencer <markster@digium.com>
163
164         * channels/chan_zap.c (zt_bridge): only enable/disable DTMF detection on SUB_REAL channels
165
166 2005-11-10  Kevin P. Fleming  <kpfleming@digium.com>
167
168         * channels/chan_iax2.c: ensure that system headers that provide basic types are included first (issue #5713)
169
170 2005-11-11  Russell Bryant  <russell@digium.com>
171
172         * many files in apps/: Clean up application descriptions. Clarify some wording and make sure they wrap at 80 characters.
173
174 2005-11-10  Mark Spencer <markster@digium.com>
175
176         * rtp.c (ast_rtp_raw_write): use unsigned int for return value from calc_txstamp() (issue #5595)
177         (calc_txstamp): never return a value that was less than zero before being turned into 'unsigned int' (issue #5595)
178
179 2005-11-10  Kevin P. Fleming  <kpfleming@digium.com>
180
181         * include/asterisk/chanspy.h: move spy-related stuff into separate header so chan_h323 can build (issue #5590)
182
183         * include/asterisk/linkedlists.h (AST_LIST_HEAD_SET_NOLOCK): properly initialize tail pointer when list head is directly set (issue #5669)
184
185         * app.c (ast_app_parse_options): ok, so we aren't all perfect... let's make the while loop actually work properly here (issue #5684)
186
187         * apps/app_disa.c (disa_exec): correct password file parsing (issue #5676)
188
189         * apps/app_meetme.c (conf_run): don't restrict admin users from joining a locked conference (issue #5680)
190
191         * channels/chan_misdn.c: include stdio.h (issue #5671)
192         * channels/chan_misdn_config.c: fix prototype warning (issue #5671)
193
194         * pbx.c: remove apps that were deprecated before 1.0 was released (issue #5673)
195
196         * apps/app_striplsd.c, apps/app_substring.c: remove apps that were deprecated before 1.0 was released (issue #5673)
197
198         * include/asterisk/lock.h (PTHREAD_MUTEX_RECURSIVE_NP): work around header problems on Cygwin (issue #5668)
199
200         * pbx/pbx_ael.c: handle switch default cases inside macros properly (issue #5354)
201
202         * configs/voicemail.conf.sample (format): add strong warning about changing format list when mailboxes contain messages (issue #5689)
203
204         * many files: ensure that system headers are included before Asterisk headers (issue #5693)
205
206         * channels/chan_iax2.c (complete_iax2_show_peer): don't return from function without releasing lock (issue #5685)
207
208         * channels/iax2-provision.c (iax_provision_reload): don't leak memory (issue #5700)
209
210         * pbx/pbx_ael.c (handle_macro): don't leak memory (issue #5701)
211         (handle_context): ditto
212
213         * res/res_features.c (load_config): properly initialize referenced variable (issue #5703)
214
215         * apps/app_queue.c (rqm_exec): correct segfault problem (issue #5705)
216         (aqm_exec): ditto
217
218         * app.c (ast_app_parse_options): don't increment 's' until after checking for NULL (related to issue #5630)
219
220         * apps/app_rpt.c: solve a memory leak (config structure was not freed) (issue #5706)
221
222 2005-11-10  Russell Bryant <russell@digium.com>
223
224         * app.c (ast_app_separate_args): Don't consider the open parenthesis as part of the arguments to an option. (issue #5630)
225
226         * many files: Change all references to ast_separate_app_args to ast_app_separate_args
227
228         * many files in apps/: Clean up some application descriptions. Make sure all descriptions in changed files are wrapped at 80 characters.
229
230 2005-11-09  Russell Bryant <russell@digium.com>
231
232         * pbx.c: Clean up descriptions of built-in dialplan applications. Changes include clearer wording and not referring to return values.
233
234 2005-11-09  Kevin P. Fleming  <kpfleming@digium.com>
235
236         * channels/chan_iax2.c (update_registry): don't complain about unspecifed registration expiration intervals, just use the minimum
237
238 2005-11-08  Kevin P. Fleming  <kpfleming@digium.com>
239
240         * Asterisk 1.2.0-rc1 released.
241
242         * include/asterisk/file.h: add test to ensure that stdio.h is included before this file (issue #5658)
243
244         * res/res_odbc.c (odbc_prepare_and_execute): add new API call for use to properly handle prepared statements across server disconnects (issue #5563)
245
246         * pbx.c (pbx_substitute_variables_helper_full): use already-substituted buffer for parsing variable name (issue #5664)
247
248         * channels/chan_zap.c (zt_request): return AST_CAUSE_CONGESTION when a group-channel is requested and the group exists but all channels are busy (issue #3360, related fix)
249         * channels/chan_iax2.c (create_addr): treat UNREACHABLE as AST_CAUSE_UNREGISTERED so that it will generate CHANUNAVAIL from app_dial (issue #3360)
250
251         * res/res_features.c (ast_bridge_call_thread_launch): set SCHED_RR separately from thread creation, so it won't fail when running as non-root (issue #5601, different fix)
252
253         * pbx.c (pbx_builtin_pushvar_helper): add new API function for setting variables that can exist multiple times (issue #2720)
254         * apps/Makefile (APPS): add app_stack (issue #2720)
255         * apps/app_stack.c: new applications (issue #2720)
256
257         * apps/app_meetme.c: fix two audio delay problems related to using non-Zap channels in conferences (issues #3599 and #4252)
258         * configs/meetme.conf.sample: add documentation of new 'audiobuffers' setting to control buffering on incoming audio from non-Zap channels
259
260         * channels/chan_local.c (local_call): move channel variables from incoming to outgoing instead of inheriting them (issue #5604)
261
262         * many files: add explicit include of stdio.h (issue #5650)
263
264 2005-11-07  Kevin P. Fleming  <kpfleming@digium.com>
265
266         * UPGRADE.txt (Parking): add note about new parking behavior (issue #5532)
267
268         * many files: more Cygwin compatibility, and proper getloadavg() prototype/macro (issue #5569)
269
270         * include/asterisk/lock.h (__ast_pthread_mutex_lock): correct build with DETECT_DEADLOCKS defined (issue #5570)
271
272 2005-11-07  Russell Bryant  <russell@digium.com>
273
274         * apps/app_queue.c: upgrade to new arg/option API and implement priority jumping control (issue #5580)
275         * many files: Add missing include of stdio.h, and remove some duplicate and unused header includes
276
277         * include/asterisk/app.h: Increment the arg_index in the options structure to fix applicaiton options that have arguments to them
278
279 2005-11-07  Kevin P. Fleming  <kpfleming@digium.com>
280
281         * cryptostub.c: include necessary headers
282         * include/asterisk/crypto.h: don't include unnecessary headers
283
284         * manager.c (action_setvar): add support for setting global variables (issue #5571)
285
286         * Makefile: correct cross-compilation issue introduced in Cygwin patches (issue #5572)
287
288         * apps/app_voicemail.c: upgrade to new arg/option API and implement priority jumping control (issue #5649)
289
290         * asterisk.c (main): setpriority() failure is not a reason to stop the process (issue #5581)
291
292         * say.c (ast_say_date_with_format_da): say hours properly (issue #5576)
293
294         * manager.c (astman_get_variables): restore old multiple-variable behavior for "Variable" header (issue #5585)
295
296         * many files: don't check for NULL before calling ast_strlen_zero, it can do it itself (issue #5648)
297
298         * pbx.c (handle_show_hints): use proper state-to-string function for hint state (issue #5583)
299
300         * rtp.c: use unsigned format for debug packet output (issue #5595)
301
302         * asterisk.c (main): force a dnsmgr background refresh after all other modules are initialized (issue #5599)
303         * dnsmgr.c: add ability to start a background refresh on demand (issue #5599)
304
305         * apps/app_dial.c (HANDLE_CAUSE): set CDR disposition to match cause code (issue #5602)
306
307         * asterisk.c: support 'runuser' and 'rungroup' options in asterisk.conf (issue #5621)
308
309         * res/Makefile, apps/Makefile, channels/Makefile, Makefile: support WITHOUT_ZAPTEL define to forcibly avoid building Zaptel support (issue #5634)
310
311         * Makefile: various fixes (issue #5633)
312
313         * apps/app_osplookup.c: upgrade to new arg/option API and implement priority jumping control
314
315         * channels/chan_misdn.c: various fixes (issue #5639)
316         * channels/misdn/isdn_lib.c: various fixes (issue #5639)
317
318         * apps/app_playback.c: upgrade to new arg/option API and implement priority jumping control
319
320         * apps/app_privacy.c: upgrade to new arg/option API and implement priority jumping control
321
322         * apps/app_sendtext.c: upgrade to new arg/option API and implement priority jumping control
323
324         * apps/app_transfer.c: upgrade to new arg/option API and implement priority jumping control
325
326         * apps/app_txtcidname.c: upgrade to new arg/option API and implement priority jumping control
327
328         * Makefile: restore function of 'dont-optimize'
329
330         * config.c (config_text_file_load): don't generate log message when stat() fails
331
332         * many files: clean up application documentation to not refer to return values, since they cannot be used in the dialplan (work done by Neil Lewis)
333
334 2005-11-06  Russell Bryant <russell@digium.com>
335
336         * many files: alphabetize options in applicaiton descriptions
337
338         * channels/chan_iax2.c: Use an enum to define iax peer/user flags as well as the pvt structure state.  Use the ast_flags macros for checking or setting the state.
339
340         * sounds.txt: Add missing words from the description of the vm-opts prompt
341
342         * apps/app_externalivr.c: Add a space that fixes building on older versions of gcc
343
344         * many files: Add doxygen updates to categorize modules into groups. Convert a lot of comments over to doxygen style. Add some text giving a basic overview of channels.
345
346         * many files: Update applications to add an exit status variable, make priority jumping optional, and use new args parsing macros
347
348         * pbx.c cdr.c res/res_features.c apps/app_dial.c include/asterisk/cdr.h: Convert some built-in applications to use new args parsing macros.  Change ast_cdr_reset to take a pointer to an ast_flags structure instead of an integer for flags.
349
350         * channels/chan_agent.c: Don't loop forever on an invalid options string
351
352         * apps/app_disa.c apps/app_forkcdr.c: Fix to use correct arguments to ast_cdr_reset
353
354 2005-11-05  Kevin P. Fleming  <kpfleming@digium.com>
355
356         * Makefile: don't rebuild asterisk/build.h unless the asterisk binary is going to be relinked for some other reason (stops spurious recompile/link every time 'make' is issued); clean up variable substitutions to use consistent syntax
357         * asterisk.c: don't include asterisk/build.h (it's unnecessary)
358         * cli.c: don't include asterisk/build.h, use extern references to buildinfo.c
359         * buildinfo.c: new file to hold version info strings
360
361 2005-11-04  Kevin P. Fleming  <kpfleming@digium.com>
362
363         * apps/app_mixmonitor.c (mixmonitor_exec): correct app name in an error message
364
365 2005-11-04  Russell Bryant  <russell@digium.com>
366
367         * channels/chan_iax2.c: Create a function that stores a peer's status in a given buffer.  Use this function in "iax2 show peers" and "iax2 show peer <peername>".  Also, add the peer's status as an option to the IAXPEER dialplan function.
368
369 2005-11-04  Kevin P. Fleming  <kpfleming@digium.com>
370
371         * include/asterisk/compiler.h: don't try to use always_inline on old compilers
372
373 2005-11-03  Russell Bryant  <russell@digium.com>
374
375         * res/res_agi.c: initialize buffer for result so that the contents are always valid in the response to GET FULL VARIABLE
376
377 2005-11-03  Kevin P. Fleming  <kpfleming@digium.com>
378
379         * doc/README.variables: document DYNAMIC_FEATURES
380
381         * res/res_features.c (ast_bridge_call): remove unused variables
382
383         * apps/app_dial.c (dial_exec_full): simplify options and flag usage
384
385         * include/asterisk/app.h: re-work application arg/option parsing APIs for consistent naming, add doxygen docs for option API
386         * many files: update to new APIs
387
388 2005-11-02  Kevin P. Fleming  <kpfleming@digium.com>
389
390         * apps/app_dial.c (dial_exec_full): convert to use API calls for argument/option parsing
391
392         * include/asterisk/channel.h: add doxygen docs for silence generator APIs
393
394         * channel.c (ast_channel_bridge): simplify native-bridge return logic, remove 'unsuccessful' message since it causes too many questions :-)
395
396 2005-11-01  Kevin P. Fleming  <kpfleming@digium.com>
397
398         * stdtime/localtime.c: fix build failure on uClibc systems (issue #5558)
399         * devicestate.c: same
400
401         * many files: make chan_misdn actually build (issue #5566)
402
403         * many files: more Cygwin build system support (issue #4678)
404
405         * apps/app_parkandannounce.c (parkandannounce_exec): supply parent channel to ast_request_and_dial so channel variables can be inherited (issue #5564)
406         * include/asterisk/channel.h: add parent_channel field
407         * channel.c (__ast_request_and_dial): use parent_channel field to inherit variables into new channel
408
409         * apps/app_cut.c (cut_internal): use ast_app_separate_args() instead of open code (issue #5560)
410
411         * apps/app_mixmonitor.c (launch_monitor_thread): ast_strlen_zero can handle NULL input (issue #5561)
412         (mixmonitor_exec): same
413
414         * res/res_features.c (ast_feature_request_and_dial): ensure that channel variables are inherited from the channel placing the call (issue #5499)
415
416         * utils.c (getloadavg): change to using _BSD_SOURCE as the indicator for whether this function is present or not (issue #5549)
417         
418         * include/asterisk/utils.h (ast_slinear_saturated_add): force to be inlined whenever possible
419         (ast_slinear_saturated_multiply): same
420         (ast_slinear_saturated_divide): same
421         (inaddrcmp): same
422         * include/asterisk/strings.h (ast_strlen_zero): force to be inlined whenever possible
423         * include/asterisk/compiler.h (force_inline): add macro to force inlining of functions
424         
425         * app.c (ast_play_and_record): use ast_silence_generator during recording if requested
426         * asterisk.c: add global option to enable silence-during-record (issue #5135)
427         * channel.c (silence_generator_alloc): new
428         (silence_generator_release): new
429         (silence_generator_generate): new
430         (ast_channel_start_silence_generator): new API call to start generating silence on a channel
431         (ast_channel_stop_silence_generator): parallel call to stop silence generation
432         * apps/app_record.c (record_exec): use ast_silence_generator during recording if requested
433
434 2005-11-01  Kevin P. Fleming  <kpfleming@digium.com>
435
436         * Asterisk 1.2.0-beta2 released.
437