Generic File Format Support. Should be included by clients of the file handling routines. File service providers should instead include mod_format.h. More...
#include <fcntl.h>#include <sys/mman.h>
Go to the source code of this file.
Defines | |
| #define | AST_DIGIT_ANY "0123456789#*ABCD" |
| #define | AST_DIGIT_ANYNUM "0123456789" |
| #define | AST_MAX_FORMATS 10 |
| #define | AST_RESERVED_POINTERS 20 |
| #define | SEEK_FORCECUR 10 |
Functions | |
| int | ast_applystream (struct ast_channel *chan, struct ast_filestream *s) |
| Applys a open stream to a channel. | |
| int | ast_closestream (struct ast_filestream *f) |
| Closes a stream. | |
| int | ast_file_init (void) |
| int | ast_filecopy (const char *oldname, const char *newname, const char *fmt) |
| Copies a file. | |
| int | ast_filedelete (const char *filename, const char *fmt) |
| Deletes a file. | |
| int | ast_fileexists (const char *filename, const char *fmt, const char *preflang) |
| Checks for the existence of a given file. | |
| int | ast_filerename (const char *oldname, const char *newname, const char *fmt) |
| Renames a file. | |
| char * | ast_format_str_reduce (char *fmts) |
| struct ast_filestream * | ast_openstream (struct ast_channel *chan, const char *filename, const char *preflang) |
| Opens stream for use in seeking, playing. | |
| struct ast_filestream * | ast_openstream_full (struct ast_channel *chan, const char *filename, const char *preflang, int asis) |
| Opens stream for use in seeking, playing. | |
| struct ast_filestream * | ast_openvstream (struct ast_channel *chan, const char *filename, const char *preflang) |
| Opens stream for use in seeking, playing. | |
| int | ast_playstream (struct ast_filestream *s) |
| Play a open stream on a channel. | |
| struct ast_filestream * | ast_readfile (const char *filename, const char *type, const char *comment, int flags, int check, mode_t mode) |
| Starts reading from a file. | |
| struct ast_frame * | ast_readframe (struct ast_filestream *s) |
| Read a frame from a filestream. | |
| int | ast_seekstream (struct ast_filestream *fs, off_t sample_offset, int whence) |
| Seeks into stream. | |
| int | ast_stopstream (struct ast_channel *c) |
| Stops a stream. | |
| int | ast_stream_and_wait (struct ast_channel *chan, const char *file, const char *digits) |
| stream file until digit If the file name is non-empty, try to play it. | |
| int | ast_stream_fastforward (struct ast_filestream *fs, off_t ms) |
| Fast forward stream ms. | |
| int | ast_stream_rewind (struct ast_filestream *fs, off_t ms) |
| Rewind stream ms. | |
| int | ast_streamfile (struct ast_channel *c, const char *filename, const char *preflang) |
| Streams a file. | |
| off_t | ast_tellstream (struct ast_filestream *fs) |
| Tell where we are in a stream. | |
| int | ast_truncstream (struct ast_filestream *fs) |
| Trunc stream at current location. | |
| int | ast_waitstream (struct ast_channel *c, const char *breakon) |
| Waits for a stream to stop or digit to be pressed. | |
| int | ast_waitstream_exten (struct ast_channel *c, const char *context) |
| Waits for a stream to stop or digit matching a valid one digit exten to be pressed. | |
| int | ast_waitstream_fr (struct ast_channel *c, const char *breakon, const char *forward, const char *rewind, int ms) |
| Same as waitstream but allows stream to be forwarded or rewound. | |
| int | ast_waitstream_full (struct ast_channel *c, const char *breakon, int audiofd, int monfd) |
| struct ast_filestream * | ast_writefile (const char *filename, const char *type, const char *comment, int flags, int check, mode_t mode) |
| Starts writing a file. | |
| int | ast_writestream (struct ast_filestream *fs, struct ast_frame *f) |
| Writes a frame to a stream. | |
Generic File Format Support. Should be included by clients of the file handling routines. File service providers should instead include mod_format.h.
Definition in file file.h.
| #define AST_DIGIT_ANY "0123456789#*ABCD" |
Convenient for waiting
Definition at line 47 of file file.h.
Referenced by ast_play_and_wait(), ast_record_review(), ivr_dispatch(), ast_ivr_menu_run_internal(), menu_callback(), dial_exec_full(), retrydial_exec(), dictate_exec(), play_mailbox_owner(), select_item_seq(), select_item_menu(), directory_exec(), festival_exec(), conf_run(), conf_exec(), play_record_review(), play_file(), say_position(), try_calling(), sayunixtime_exec(), say_and_wait(), get_folder(), wait_file2(), play_message_datetime(), play_message_callerid(), play_message_duration(), play_message(), vm_intro_gr(), vm_intro_multilang(), vm_intro_he(), vm_intro_pt_BR(), vm_intro_pt(), sayname(), vmsayname_exec(), grab_transfer(), feature_blind_transfer(), feature_attended_transfer(), ast_readstring_full(), bridge_playfile(), builtin_blindtransfer(), builtin_atxfer(), and pbx_builtin_background().
| #define AST_DIGIT_ANYNUM "0123456789" |
Definition at line 48 of file file.h.
Referenced by initreqprep().
| #define AST_MAX_FORMATS 10 |
The maximum number of formats we expect to see in a format string
Definition at line 44 of file file.h.
Referenced by ast_format_str_reduce().
| #define SEEK_FORCECUR 10 |
Definition at line 50 of file file.h.
Referenced by __ast_read(), ast_write(), g719seek(), g729_seek(), gsm_seek(), ilbc_seek(), pcm_seek(), au_seek(), siren14seek(), siren7seek(), slinear_seek(), vox_seek(), and wav_seek().
| int ast_applystream | ( | struct ast_channel * | chan, |
| struct ast_filestream * | s | ||
| ) |
Applys a open stream to a channel.
| chan | channel to work |
| s | ast_filestream to apply |
| 0 | on success. |
| -1 | on failure. |
Definition at line 850 of file file.c.
References ast_filestream::owner.
Referenced by speech_streamfile(), ast_streamfile(), handle_streamfile(), handle_getoption(), and handle_recordfile().
{
s->owner = chan;
return 0;
}
| int ast_closestream | ( | struct ast_filestream * | f | ) |
Closes a stream.
| f | filestream to close Close a playback or recording stream |
| 0 | on success. |
| -1 | on failure. |
Definition at line 893 of file file.c.
References ast_filestream::owner, ast_filestream::fmt, ast_format::format, AST_FORMAT_AUDIO_MASK, ast_channel::stream, AST_SCHED_DEL, ast_channel::sched, ast_channel::streamid, ast_settimeout(), ast_channel::vstream, ast_channel::vstreamid, and ao2_ref.
Referenced by __ast_play_and_record(), dictate_exec(), gen_closestream(), recordthread(), mixmonitor_ds_close_fs(), record_exec(), rpt(), ast_hangup(), ast_stopstream(), filestream_destructor(), ast_filehelper(), ast_readfile(), ast_writefile(), handle_recordfile(), handle_cli_file_convert(), ast_monitor_start(), ast_monitor_stop(), moh_files_release(), ast_moh_files_next(), and local_ast_moh_stop().
{
/* This used to destroy the filestream, but it now just decrements a refcount.
* We need to force the stream to quit queuing frames now, because we might
* change the writeformat, which could result in a subsequent write error, if
* the format is different. */
/* Stop a running stream if there is one */
if (f->owner) {
if (f->fmt->format < AST_FORMAT_AUDIO_MASK) {
f->owner->stream = NULL;
AST_SCHED_DEL(f->owner->sched, f->owner->streamid);
ast_settimeout(f->owner, 0, NULL, NULL);
} else {
f->owner->vstream = NULL;
AST_SCHED_DEL(f->owner->sched, f->owner->vstreamid);
}
}
ao2_ref(f, -1);
return 0;
}
| int ast_file_init | ( | void | ) |
Initialize file stuff
Initializes all the various file stuff. Basically just registers the cli stuff Returns 0 all the time
Provided by file.c
Definition at line 1484 of file file.c.
References ast_cli_register_multiple(), and ARRAY_LEN.
{
ast_cli_register_multiple(cli_file, ARRAY_LEN(cli_file));
return 0;
}
| int ast_filecopy | ( | const char * | oldname, |
| const char * | newname, | ||
| const char * | fmt | ||
| ) |
Copies a file.
| oldname | name of the file you wish to copy (minus extension) |
| newname | name you wish the file to be copied to (minus extension) |
| fmt | the format of the file Copy a given file in a given format, or if fmt is NULL, then do so for all |
Definition at line 944 of file file.c.
References ast_filehelper(), and ACTION_COPY.
Referenced by copy_plain_file(), and vm_forwardoptions().
{
return ast_filehelper(filename, filename2, fmt, ACTION_COPY);
}
| int ast_filedelete | ( | const char * | filename, |
| const char * | fmt | ||
| ) |
Deletes a file.
| filename | name of the file you wish to delete (minus the extension) |
| fmt | of the file Delete a given file in a given format, or if fmt is NULL, then do so for all |
Definition at line 934 of file file.c.
References ast_filehelper(), and ACTION_DELETE.
Referenced by __ast_play_and_record(), setup_privacy_args(), dial_exec_full(), conf_free(), announce_thread(), conf_run(), vm_delete(), leave_voicemail(), record_exec(), play_record_review(), handle_cli_file_convert(), ast_monitor_start(), and ast_monitor_stop().
{
return ast_filehelper(filename, NULL, fmt, ACTION_DELETE);
}
| int ast_fileexists | ( | const char * | filename, |
| const char * | fmt, | ||
| const char * | preflang | ||
| ) |
Checks for the existence of a given file.
| filename | name of the file you wish to check, minus the extension |
| fmt | the format you wish to check (the extension) |
| preflang | (the preferred language you wisht to find the file in) See if a given file exists in a given format. If fmt is NULL, any format is accepted. |
Definition at line 920 of file file.c.
References ast_filestream::buf, and fileexists_core().
Referenced by common_exec(), setup_privacy_args(), dial_exec_full(), retrydial_exec(), eivr_comm(), app_exec(), announce_thread(), conf_run(), invent_message(), leave_voicemail(), minivm_delete_exec(), play_file(), readexten_exec(), record_exec(), saynode(), rpt_tele_thread(), function_playback(), get_folder(), forward_message(), play_message_callerid(), play_message(), vm_intro(), vm_newuser(), vm_options(), vm_tempgreeting(), sayname(), ast_monitor_start(), ast_monitor_stop(), ast_moh_files_next(), say_character_str_full(), say_phonetic_str_full(), and say_digit_str_full().
{
char *buf;
int buflen;
if (preflang == NULL)
preflang = "";
buflen = strlen(preflang) + strlen(filename) + 4; /* room for everything */
buf = alloca(buflen);
if (buf == NULL)
return 0;
return fileexists_core(filename, fmt, preflang, buf, buflen);
}
| int ast_filerename | ( | const char * | oldname, |
| const char * | newname, | ||
| const char * | fmt | ||
| ) |
Renames a file.
| oldname | the name of the file you wish to act upon (minus the extension) |
| newname | the name you wish to rename the file to (minus the extension) |
| fmt | the format of the file Rename a given file in a given format, or if fmt is NULL, then do so for all |
Definition at line 939 of file file.c.
References ast_filehelper(), and ACTION_RENAME.
Referenced by __ast_play_and_record(), rename_file(), leave_voicemail(), vm_forwardoptions(), forward_message(), play_record_review(), and ast_monitor_stop().
{
return ast_filehelper(filename, filename2, fmt, ACTION_RENAME);
}
| char* ast_format_str_reduce | ( | char * | fmts | ) |
Remove duplicate formats from a format string.
| fmts | a format string, this string will be modified |
| NULL | error |
Definition at line 1368 of file file.c.
References f, AST_MAX_FORMATS, type, first, len(), AST_RWLIST_RDLOCK, ast_log(), LOG_WARNING, ast_strdupa, strsep(), AST_RWLIST_TRAVERSE, ast_format::list, exts_compare(), ast_format::exts, and AST_RWLIST_UNLOCK.
Referenced by load_config().
{
struct ast_format *f;
struct ast_format *fmts_ptr[AST_MAX_FORMATS];
char *fmts_str[AST_MAX_FORMATS];
char *stringp, *type;
char *orig = fmts;
int i, j, x, first, found = 0;
int len = strlen(fmts) + 1;
int res;
if (AST_RWLIST_RDLOCK(&formats)) {
ast_log(LOG_WARNING, "Unable to lock format list\n");
return NULL;
}
stringp = ast_strdupa(fmts);
for (x = 0; (type = strsep(&stringp, "|")) && x < AST_MAX_FORMATS; x++) {
AST_RWLIST_TRAVERSE(&formats, f, list) {
if (exts_compare(f->exts, type)) {
found = 1;
break;
}
}
fmts_str[x] = type;
if (found) {
fmts_ptr[x] = f;
} else {
fmts_ptr[x] = NULL;
}
}
AST_RWLIST_UNLOCK(&formats);
first = 1;
for (i = 0; i < x; i++) {
/* ignore invalid entries */
if (!fmts_ptr[i]) {
ast_log(LOG_WARNING, "ignoring unknown format '%s'\n", fmts_str[i]);
continue;
}
/* special handling for the first entry */
if (first) {
res = snprintf(fmts, len, "%s", fmts_str[i]);
fmts += res;
len -= res;
first = 0;
continue;
}
found = 0;
for (j = 0; j < i; j++) {
/* this is a duplicate */
if (fmts_ptr[j] == fmts_ptr[i]) {
found = 1;
break;
}
}
if (!found) {
res = snprintf(fmts, len, "|%s", fmts_str[i]);
fmts += res;
len -= res;
}
}
if (first) {
ast_log(LOG_WARNING, "no known formats found in format list (%s)\n", orig);
return NULL;
}
return orig;
}
| struct ast_filestream* ast_openstream | ( | struct ast_channel * | chan, |
| const char * | filename, | ||
| const char * | preflang | ||
| ) | [read] |
Opens stream for use in seeking, playing.
| chan | channel to work with |
| filename | to use |
| preflang | prefered language to use |
| a | ast_filestream pointer if it opens the file. |
| NULL | on error. |
Definition at line 621 of file file.c.
References ast_openstream_full().
Referenced by dictate_exec(), speech_streamfile(), ast_streamfile(), handle_streamfile(), and handle_getoption().
{
return ast_openstream_full(chan, filename, preflang, 0);
}
| struct ast_filestream* ast_openstream_full | ( | struct ast_channel * | chan, |
| const char * | filename, | ||
| const char * | preflang, | ||
| int | asis | ||
| ) | [read] |
Opens stream for use in seeking, playing.
| chan | channel to work with |
| filename | to use |
| preflang | prefered language to use |
| asis | if set, don't clear generators |
| a | ast_filestream pointer if it opens the file. |
| NULL | on error. |
Definition at line 626 of file file.c.
References ast_filestream::buf, ast_stopstream(), ast_channel::generator, ast_deactivate_generator(), fileexists_core(), AST_FORMAT_AUDIO_MASK, ast_log(), LOG_WARNING, ast_channel::oldwriteformat, ast_channel::writeformat, ast_set_write_format(), ast_filehelper(), ACTION_OPEN, and ast_channel::stream.
Referenced by gen_nextfile(), ast_openstream(), and ast_moh_files_next().
{
/*
* Use fileexists_core() to find a file in a compatible
* language and format, set up a suitable translator,
* and open the stream.
*/
format_t fmts, res;
int buflen;
char *buf;
if (!asis) {
/* do this first, otherwise we detect the wrong writeformat */
ast_stopstream(chan);
if (chan->generator)
ast_deactivate_generator(chan);
}
if (preflang == NULL)
preflang = "";
buflen = strlen(preflang) + strlen(filename) + 4;
buf = alloca(buflen);
if (buf == NULL)
return NULL;
fmts = fileexists_core(filename, NULL, preflang, buf, buflen);
if (fmts > 0)
fmts &= AST_FORMAT_AUDIO_MASK;
if (fmts < 1) {
ast_log(LOG_WARNING, "File %s does not exist in any format\n", filename);
return NULL;
}
chan->oldwriteformat = chan->writeformat;
/* Set the channel to a format we can work with */
res = ast_set_write_format(chan, fmts);
if (res == -1) { /* No format available that works with this channel */
return NULL;
}
res = ast_filehelper(buf, chan, NULL, ACTION_OPEN);
if (res >= 0)
return chan->stream;
return NULL;
}
| struct ast_filestream* ast_openvstream | ( | struct ast_channel * | chan, |
| const char * | filename, | ||
| const char * | preflang | ||
| ) | [read] |
Opens stream for use in seeking, playing.
| chan | channel to work with |
| filename | to use |
| preflang | prefered language to use |
| a | ast_filestream pointer if it opens the file. |
| NULL | on error. |
Definition at line 668 of file file.c.
References format, ast_filestream::buf, AST_FORMAT_FIRST_VIDEO_BIT, AST_FORMAT_VIDEO_MASK, ast_filestream::fmt, ast_channel::nativeformats, ast_getformatname(), fileexists_core(), ast_filehelper(), ACTION_OPEN, ast_channel::vstream, ast_log(), and LOG_WARNING.
Referenced by ast_streamfile(), handle_streamfile(), and handle_getoption().
{
/* As above, but for video. But here we don't have translators
* so we must enforce a format.
*/
format_t format;
char *buf;
int buflen;
if (preflang == NULL)
preflang = "";
buflen = strlen(preflang) + strlen(filename) + 4;
buf = alloca(buflen);
if (buf == NULL)
return NULL;
for (format = AST_FORMAT_FIRST_VIDEO_BIT; format <= AST_FORMAT_VIDEO_MASK; format = format << 1) {
int fd;
const char *fmt;
if (!(chan->nativeformats & format))
continue;
fmt = ast_getformatname(format);
if ( fileexists_core(filename, fmt, preflang, buf, buflen) < 1) /* no valid format */
continue;
fd = ast_filehelper(buf, chan, fmt, ACTION_OPEN);
if (fd >= 0)
return chan->vstream;
ast_log(LOG_WARNING, "File %s has video but couldn't be opened\n", filename);
}
return NULL;
}
| int ast_playstream | ( | struct ast_filestream * | s | ) |
Play a open stream on a channel.
| s | filestream to play |
| 0 | on success. |
| -1 | on failure. |
Definition at line 856 of file file.c.
References ast_filestream::fmt, ast_format::format, AST_FORMAT_AUDIO_MASK, ast_readaudio_callback(), ast_readvideo_callback(), and FSREAD_FAILURE.
Referenced by speech_streamfile(), ast_streamfile(), handle_streamfile(), and handle_getoption().
{
enum fsread_res res;
if (s->fmt->format & AST_FORMAT_AUDIO_MASK)
res = ast_readaudio_callback(s);
else
res = ast_readvideo_callback(s);
return (res == FSREAD_FAILURE) ? -1 : 0;
}
| struct ast_filestream* ast_readfile | ( | const char * | filename, |
| const char * | type, | ||
| const char * | comment, | ||
| int | flags, | ||
| int | check, | ||
| mode_t | mode | ||
| ) | [read] |
Starts reading from a file.
| filename | the name of the file to read from |
| type | format of file you wish to read from |
| comment | comment to go with |
| flags | file flags |
| check | (unimplemented, hence negligible) |
| mode | Open mode Open an incoming file stream. flags are flags for the open() command, and if check is non-zero, then it will not read a file if there are any files that start with that name and have an extension Please note, this is a blocking function. Program execution will not return until ast_waitstream completes it's execution. |
| a | struct ast_filestream on success. |
| NULL | on failure. |
Definition at line 993 of file file.c.
References f, AST_RWLIST_RDLOCK, AST_RWLIST_TRAVERSE, exts_compare(), ast_format::exts, build_filename(), errno, get_filestream(), open_wrapper(), ast_log(), LOG_WARNING, ast_closestream(), ast_free, ast_filestream::trans, ast_filestream::fmt, ast_filestream::flags, ast_filestream::mode, ast_filestream::filename, ast_strdup, ast_filestream::vfs, and AST_RWLIST_UNLOCK.
Referenced by __ast_play_and_record(), and handle_cli_file_convert().
{
FILE *bfile;
struct ast_format *f;
struct ast_filestream *fs = NULL;
char *fn;
int format_found = 0;
AST_RWLIST_RDLOCK(&formats);
AST_RWLIST_TRAVERSE(&formats, f, list) {
fs = NULL;
if (!exts_compare(f->exts, type))
continue;
else
format_found = 1;
fn = build_filename(filename, type);
errno = 0;
bfile = fopen(fn, "r");
if (!bfile || (fs = get_filestream(f, bfile)) == NULL || open_wrapper(fs) ) {
ast_log(LOG_WARNING, "Unable to open %s\n", fn);
if (fs) {
ast_closestream(fs);
}
fs = NULL;
bfile = NULL;
ast_free(fn);
break;
}
/* found it */
fs->trans = NULL;
fs->fmt = f;
fs->flags = flags;
fs->mode = mode;
fs->filename = ast_strdup(filename);
fs->vfs = NULL;
break;
}
AST_RWLIST_UNLOCK(&formats);
if (!format_found)
ast_log(LOG_WARNING, "No such format '%s'\n", type);
return fs;
}
| struct ast_frame* ast_readframe | ( | struct ast_filestream * | s | ) | [read] |
Read a frame from a filestream.
| s | ast_filestream to act on |
| NULL | if read failed. |
Definition at line 726 of file file.c.
References read_frame().
Referenced by __ast_play_and_record(), dictate_exec(), gen_readframe(), handle_cli_file_convert(), and moh_files_readframe().
{
int whennext = 0;
return read_frame(s, &whennext);
}
| int ast_seekstream | ( | struct ast_filestream * | fs, |
| off_t | sample_offset, | ||
| int | whence | ||
| ) |
Seeks into stream.
| fs | ast_filestream to perform seek on |
| sample_offset | numbers of samples to seek |
| whence | SEEK_SET, SEEK_CUR, SEEK_END |
| 0 | on success. |
| -1 | on failure. |
Definition at line 868 of file file.c.
References ast_filestream::fmt, and ast_format::seek.
Referenced by ast_control_streamfile(), dictate_exec(), __ast_read(), ast_write(), ast_stream_fastforward(), ast_stream_rewind(), ast_streamfile(), handle_streamfile(), handle_getoption(), handle_recordfile(), speech_streamfile(), and ast_moh_files_next().
| int ast_stopstream | ( | struct ast_channel * | c | ) |
Stops a stream.
| c | The channel you wish to stop playback on |
Stop playback of a stream
| 0 | always |
Definition at line 124 of file file.c.
References ast_channel_lock, ast_channel::stream, ast_closestream(), ast_channel::oldwriteformat, ast_set_write_format(), ast_log(), LOG_WARNING, ast_getformatname(), ast_channel::vstream, and ast_channel_unlock.
Referenced by ast_control_streamfile(), ast_play_and_wait(), ivr_dispatch(), menu_callback(), dial_exec_full(), play_mailbox_owner(), select_item_seq(), directory_exec(), send_waveform_to_channel(), wait_for_winner(), ices_exec(), conf_run(), conf_exec(), recordthread(), minivm_greet_exec(), mp3_exec(), NBScat_exec(), parkandannounce_exec(), s_streamwait3(), playback_exec(), play_file(), queue_exec(), read_exec(), readexten_exec(), record_exec(), send_morse(), send_tone_telemetry(), sayfile(), saycharstr(), saynum(), rpt_tele_thread(), speech_background(), background_detect_exec(), leave_voicemail(), vm_authenticate(), vm_execmain(), zapateller_exec(), grab_transfer(), ast_readstring_full(), ast_openstream_full(), waitstream_core(), pbx_builtin_background(), ast_adsi_transmit_message_full(), handle_streamfile(), handle_getoption(), handle_speechrecognize(), say_character_str_full(), say_phonetic_str_full(), say_digit_str_full(), ast_say_number_full_en(), ast_say_number_full_cs(), ast_say_number_full_da(), ast_say_number_full_de(), ast_say_number_full_en_GB(), ast_say_number_full_es(), ast_say_number_full_fr(), ast_say_number_full_he(), ast_say_number_full_hu(), ast_say_number_full_it(), ast_say_number_full_nl(), ast_say_number_full_no(), pl_odtworz_plik(), ast_say_number_full_pt(), ast_say_number_full_se(), ast_say_number_full_zh(), ast_say_number_full_ur(), ast_say_number_full_ru(), ast_say_number_full_th(), ast_say_number_full_vi(), ast_say_enumeration_full_en(), ast_say_enumeration_full_vi(), ast_say_enumeration_full_da(), ast_say_enumeration_full_de(), ast_say_enumeration_full_he(), ast_say_number_full_gr(), and ast_say_number_full_ka().
{
ast_channel_lock(tmp);
/* Stop a running stream if there is one */
if (tmp->stream) {
ast_closestream(tmp->stream);
tmp->stream = NULL;
if (tmp->oldwriteformat && ast_set_write_format(tmp, tmp->oldwriteformat))
ast_log(LOG_WARNING, "Unable to restore format back to %s\n", ast_getformatname(tmp->oldwriteformat));
}
/* Stop the video stream too */
if (tmp->vstream != NULL) {
ast_closestream(tmp->vstream);
tmp->vstream = NULL;
}
ast_channel_unlock(tmp);
return 0;
}
| int ast_stream_and_wait | ( | struct ast_channel * | chan, |
| const char * | file, | ||
| const char * | digits | ||
| ) |
stream file until digit If the file name is non-empty, try to play it.
| -1 | if error. |
| digit | if interrupted by a digit. |
Definition at line 1355 of file file.c.
References ast_strlen_zero(), ast_test_suite_event_notify, ast_streamfile(), ast_channel::language, and ast_waitstream().
Referenced by __ast_play_and_record(), ast_record_review(), ivr_dispatch(), announce_user_count(), play_prompt_to_channel(), join_conference_bridge(), play_sound_file(), menu_callback(), confbridge_exec(), play_mailbox_owner(), select_item_seq(), directory_exec(), app_exec(), play_record_review(), invent_message(), leave_voicemail(), vm_forwardoptions(), forward_message(), wait_file2(), play_message_callerid(), sayname(), vmsayname_exec(), grab_transfer(), feature_blind_transfer(), feature_attended_transfer(), bridge_playfile(), masq_park_call(), xfer_park_call_helper(), play_message_on_chan(), builtin_automixmonitor(), builtin_blindtransfer(), builtin_atxfer(), park_call_exec(), parked_call_exec(), and ast_pickup_call().
{
int res = 0;
if (!ast_strlen_zero(file)) {
ast_test_suite_event_notify("PLAYBACK", "Message: %s", file);
res = ast_streamfile(chan, file, chan->language);
if (!res) {
res = ast_waitstream(chan, digits);
}
}
return res;
}
| int ast_stream_fastforward | ( | struct ast_filestream * | fs, |
| off_t | ms | ||
| ) |
Fast forward stream ms.
| fs | filestream to act on |
| ms | milliseconds to move |
| 0 | on success. |
| -1 | on failure. |
Definition at line 883 of file file.c.
References ast_seekstream(), and DEFAULT_SAMPLES_PER_MS.
Referenced by waitstream_core().
{
return ast_seekstream(fs, ms * DEFAULT_SAMPLES_PER_MS, SEEK_CUR);
}
| int ast_stream_rewind | ( | struct ast_filestream * | fs, |
| off_t | ms | ||
| ) |
Rewind stream ms.
| fs | filestream to act on |
| ms | milliseconds to move |
| 0 | on success. |
| -1 | on failure. |
Definition at line 888 of file file.c.
References ast_seekstream(), and DEFAULT_SAMPLES_PER_MS.
Referenced by __ast_play_and_record(), record_exec(), waitstream_core(), and handle_recordfile().
{
return ast_seekstream(fs, -ms * DEFAULT_SAMPLES_PER_MS, SEEK_CUR);
}
| int ast_streamfile | ( | struct ast_channel * | c, |
| const char * | filename, | ||
| const char * | preflang | ||
| ) |
Streams a file.
| c | channel to stream the file to |
| filename | the name of the file you wish to stream, minus the extension |
| preflang | the preferred language you wish to have the file streamed to you in Prepares a channel for the streaming of a file. To start the stream, afterward do a ast_waitstream() on the channel Also, it will stop any existing streams on the channel. |
| 0 | on success. |
| -1 | on failure. |
Definition at line 949 of file file.c.
References ast_filestream::vfs, ast_filestream::fmt, ast_openstream(), ast_log(), LOG_WARNING, ast_getformatname_multiple(), ast_channel::nativeformats, errno, ast_filestream::f, ast_seekstream(), ast_openvstream(), ast_debug, ast_getformatname(), ast_format::format, ast_test_flag, AST_FLAG_MASQ_NOSTREAM, ast_filestream::orig_chan_name, ast_strdup, ast_channel::name, ast_applystream(), ast_playstream(), ast_verb, and ast_channel::writeformat.
Referenced by ast_app_getdata(), ast_app_getdata_full(), ast_control_streamfile(), ast_play_and_wait(), auth_exec(), common_exec(), menu_callback(), setup_privacy_args(), dial_exec_full(), retrydial_exec(), play_and_wait(), select_item_menu(), do_directory(), wait_for_winner(), app_exec(), announce_thread(), conf_run(), find_conf_realtime(), conf_exec(), invent_message(), play_record_review(), leave_voicemail(), minivm_greet_exec(), page_exec(), parkandannounce_exec(), s_streamwait3(), playback_exec(), privacy_exec(), play_file(), readexten_exec(), record_exec(), sayfile(), rpt_tele_thread(), background_detect_exec(), forward_message(), vm_authenticate(), agent_call(), check_availability(), check_beep(), login_exec(), analog_ss_thread(), local_attended_transfer(), action_bridge(), bridge_exec(), ast_stream_and_wait(), pbx_builtin_background(), handle_recordfile(), say_character_str_full(), say_phonetic_str_full(), say_digit_str_full(), wait_file(), ast_say_number_full_en(), ast_say_number_full_cs(), ast_say_number_full_da(), ast_say_number_full_de(), ast_say_number_full_en_GB(), ast_say_number_full_es(), ast_say_number_full_fr(), ast_say_number_full_he(), ast_say_number_full_hu(), ast_say_number_full_it(), ast_say_number_full_nl(), ast_say_number_full_no(), pl_odtworz_plik(), ast_say_number_full_pt(), ast_say_number_full_se(), ast_say_number_full_zh(), ast_say_number_full_ur(), ast_say_number_full_ru(), ast_say_number_full_th(), ast_say_number_full_vi(), ast_say_enumeration_full_en(), ast_say_enumeration_full_vi(), ast_say_enumeration_full_da(), ast_say_enumeration_full_de(), ast_say_enumeration_full_he(), ast_say_date_en(), ast_say_date_da(), ast_say_date_de(), ast_say_date_hu(), ast_say_date_fr(), ast_say_date_nl(), ast_say_date_th(), ast_say_date_he(), ast_say_time_en(), ast_say_time_de(), ast_say_time_hu(), ast_say_time_fr(), ast_say_time_nl(), ast_say_time_zh(), ast_say_datetime_en(), ast_say_datetime_fr(), ast_say_datetime_nl(), ast_say_datetime_pt(), ast_say_datetime_th(), ast_say_datetime_zh(), ast_say_datetime_he(), ast_say_datetime_from_now_en(), ast_say_datetime_from_now_fr(), ast_say_datetime_from_now_he(), gr_say_number_female(), ast_say_number_full_gr(), ast_say_date_gr(), ast_say_time_gr(), ast_say_datetime_gr(), ast_say_date_with_format_gr(), ast_say_number_full_ka(), ast_say_date_ka(), ast_say_time_ka(), ast_say_datetime_from_now_ka(), and __analog_ss_thread().
{
struct ast_filestream *fs;
struct ast_filestream *vfs=NULL;
char fmt[256];
int seekattempt;
int res;
fs = ast_openstream(chan, filename, preflang);
if (!fs) {
ast_log(LOG_WARNING, "Unable to open %s (format %s): %s\n", filename, ast_getformatname_multiple(fmt, sizeof(fmt), chan->nativeformats), strerror(errno));
return -1;
}
/* check to see if there is any data present (not a zero length file),
* done this way because there is no where for ast_openstream_full to
* return the file had no data. */
seekattempt = fseek(fs->f, -1, SEEK_END);
if (seekattempt && errno == EINVAL) {
/* Zero-length file, as opposed to a pipe */
return 0;
} else {
ast_seekstream(fs, 0, SEEK_SET);
}
vfs = ast_openvstream(chan, filename, preflang);
if (vfs) {
ast_debug(1, "Ooh, found a video stream, too, format %s\n", ast_getformatname(vfs->fmt->format));
}
if (ast_test_flag(chan, AST_FLAG_MASQ_NOSTREAM))
fs->orig_chan_name = ast_strdup(chan->name);
if (ast_applystream(chan, fs))
return -1;
if (vfs && ast_applystream(chan, vfs))
return -1;
res = ast_playstream(fs);
if (!res && vfs)
res = ast_playstream(vfs);
ast_verb(3, "<%s> Playing '%s.%s' (language '%s')\n", chan->name, filename, ast_getformatname(chan->writeformat), preflang ? preflang : "default");
return res;
}
| off_t ast_tellstream | ( | struct ast_filestream * | fs | ) |
Tell where we are in a stream.
| fs | fs to act on |
Definition at line 878 of file file.c.
References ast_filestream::fmt, and ast_format::tell.
Referenced by ast_control_streamfile(), __ast_play_and_record(), handle_streamfile(), handle_getoption(), handle_recordfile(), handle_speechrecognize(), and ast_moh_files_next().
| int ast_truncstream | ( | struct ast_filestream * | fs | ) |
Trunc stream at current location.
| fs | filestream to act on |
| 0 | on success. |
| -1 | on failure. |
Definition at line 873 of file file.c.
References ast_filestream::fmt, and ast_format::trunc.
Referenced by __ast_play_and_record(), record_exec(), and handle_recordfile().
| int ast_waitstream | ( | struct ast_channel * | c, |
| const char * | breakon | ||
| ) |
Waits for a stream to stop or digit to be pressed.
| c | channel to waitstream on |
| breakon | string of DTMF digits to break upon Begins playback of a stream... Wait for a stream to stop or for any one of a given digit to arrive, |
| 0 | if the stream finishes |
| the | character if it was interrupted, |
| -1 | on error |
Definition at line 1328 of file file.c.
References waitstream_core().
Referenced by ast_play_and_wait(), auth_exec(), common_exec(), menu_callback(), setup_privacy_args(), retrydial_exec(), play_and_wait(), select_item_menu(), directory_exec(), app_exec(), announce_thread(), conf_run(), find_conf_realtime(), conf_exec(), invent_message(), play_record_review(), leave_voicemail(), minivm_greet_exec(), page_exec(), parkandannounce_exec(), s_streamwait3(), playback_exec(), privacy_exec(), play_file(), record_exec(), send_morse(), send_tone_telemetry(), sayfile(), saycharstr(), saynum(), rpt_tele_thread(), vm_authenticate(), agent_call(), check_availability(), check_beep(), login_exec(), analog_ss_thread(), local_attended_transfer(), action_bridge(), bridge_exec(), ast_stream_and_wait(), pbx_builtin_background(), handle_recordfile(), say_character_str_full(), say_phonetic_str_full(), say_digit_str_full(), wait_file(), ast_say_number_full_en(), ast_say_number_full_cs(), ast_say_number_full_da(), ast_say_number_full_de(), ast_say_number_full_en_GB(), ast_say_number_full_es(), ast_say_number_full_fr(), ast_say_number_full_he(), ast_say_number_full_hu(), ast_say_number_full_it(), ast_say_number_full_nl(), ast_say_number_full_no(), pl_odtworz_plik(), ast_say_number_full_pt(), ast_say_number_full_se(), ast_say_number_full_zh(), ast_say_number_full_ur(), ast_say_number_full_ru(), ast_say_number_full_th(), ast_say_number_full_vi(), ast_say_enumeration_full_en(), ast_say_enumeration_full_vi(), ast_say_enumeration_full_da(), ast_say_enumeration_full_de(), ast_say_enumeration_full_he(), ast_say_date_en(), ast_say_date_da(), ast_say_date_de(), ast_say_date_hu(), ast_say_date_fr(), ast_say_date_nl(), ast_say_date_th(), ast_say_date_he(), ast_say_time_en(), ast_say_time_de(), ast_say_time_hu(), ast_say_time_nl(), ast_say_time_zh(), ast_say_time_he(), ast_say_datetime_en(), ast_say_datetime_fr(), ast_say_datetime_nl(), ast_say_datetime_pt(), ast_say_datetime_th(), ast_say_datetime_zh(), ast_say_datetime_he(), ast_say_datetime_from_now_en(), ast_say_datetime_from_now_fr(), ast_say_datetime_from_now_he(), gr_say_number_female(), ast_say_number_full_gr(), ast_say_date_gr(), ast_say_time_gr(), ast_say_datetime_gr(), ast_say_date_with_format_gr(), ast_say_number_full_ka(), ast_say_date_ka(), ast_say_time_ka(), ast_say_datetime_from_now_ka(), and __analog_ss_thread().
{
return waitstream_core(c, breakon, NULL, NULL, 0, -1, -1, NULL);
}
| int ast_waitstream_exten | ( | struct ast_channel * | c, |
| const char * | context | ||
| ) |
Waits for a stream to stop or digit matching a valid one digit exten to be pressed.
| c | channel to waitstream on |
| context | string of context to match digits to break upon Begins playback of a stream... Wait for a stream to stop or for any one of a valid extension digit to arrive, |
| 0 | if the stream finishes. |
| the | character if it was interrupted. |
| -1 | on error. |
Definition at line 1339 of file file.c.
References ast_channel::context, and waitstream_core().
Referenced by pbx_builtin_background().
{
/* Waitstream, with return in the case of a valid 1 digit extension */
/* in the current or specified context being pressed */
if (!context)
context = c->context;
return waitstream_core(c, NULL, NULL, NULL, 0,
-1, -1, context);
}
| int ast_waitstream_fr | ( | struct ast_channel * | c, |
| const char * | breakon, | ||
| const char * | forward, | ||
| const char * | rewind, | ||
| int | ms | ||
| ) |
Same as waitstream but allows stream to be forwarded or rewound.
| c | channel to waitstream on |
| breakon | string of DTMF digits to break upon |
| forward | DTMF digit to fast forward upon |
| rewind | DTMF digit to rewind upon |
| ms | How many miliseconds to skip forward/back Begins playback of a stream... Wait for a stream to stop or for any one of a given digit to arrive, |
| 0 | if the stream finishes. |
| the | character if it was interrupted. |
| -1 | on error. |
Definition at line 1322 of file file.c.
References waitstream_core().
Referenced by ast_control_streamfile().
{
return waitstream_core(c, breakon, forward, reverse, ms,
-1 /* no audiofd */, -1 /* no cmdfd */, NULL /* no context */);
}
| int ast_waitstream_full | ( | struct ast_channel * | c, |
| const char * | breakon, | ||
| int | audiofd, | ||
| int | monfd | ||
| ) |
Same as waitstream, but with audio output to fd and monitored fd checking.
Definition at line 1333 of file file.c.
References waitstream_core().
Referenced by s_streamwait3(), ast_readstring_full(), handle_streamfile(), handle_getoption(), say_character_str_full(), say_phonetic_str_full(), say_digit_str_full(), ast_say_number_full_en(), ast_say_number_full_cs(), ast_say_number_full_da(), ast_say_number_full_de(), ast_say_number_full_en_GB(), ast_say_number_full_es(), ast_say_number_full_fr(), ast_say_number_full_he(), ast_say_number_full_hu(), ast_say_number_full_it(), ast_say_number_full_nl(), ast_say_number_full_no(), pl_odtworz_plik(), ast_say_number_full_pt(), ast_say_number_full_se(), ast_say_number_full_zh(), ast_say_number_full_ur(), ast_say_number_full_ru(), ast_say_number_full_th(), ast_say_number_full_vi(), ast_say_enumeration_full_en(), ast_say_enumeration_full_vi(), ast_say_enumeration_full_da(), ast_say_enumeration_full_de(), ast_say_enumeration_full_he(), ast_say_number_full_gr(), and ast_say_number_full_ka().
{
return waitstream_core(c, breakon, NULL, NULL, 0,
audiofd, cmdfd, NULL /* no context */);
}
| struct ast_filestream* ast_writefile | ( | const char * | filename, |
| const char * | type, | ||
| const char * | comment, | ||
| int | flags, | ||
| int | check, | ||
| mode_t | mode | ||
| ) | [read] |
Starts writing a file.
| filename | the name of the file to write to |
| type | format of file you wish to write out to |
| comment | comment to go with |
| flags | output file flags |
| check | (unimplemented, hence negligible) |
| mode | Open mode Create an outgoing file stream. oflags are flags for the open() command, and if check is non-zero, then it will not write a file if there are any files that start with that name and have an extension Please note, this is a blocking function. Program execution will not return until ast_waitstream completes it's execution. |
| a | struct ast_filestream on success. |
| NULL | on failure. |
Definition at line 1041 of file file.c.
References f, ast_filestream::buf, AST_RWLIST_RDLOCK, AST_RWLIST_TRAVERSE, exts_compare(), ast_format::exts, build_filename(), ast_log(), LOG_WARNING, errno, ast_opt_cache_record_files, ast_strdupa, record_cache_dir, ast_free, get_filestream(), ast_filestream::write_buffer, ast_malloc, ast_filestream::f, rewrite_wrapper(), ast_closestream(), ast_filestream::trans, ast_filestream::fmt, ast_filestream::flags, ast_filestream::mode, ast_filestream::realfilename, ast_strdup, ast_filestream::filename, ast_filestream::vfs, ast_format::seek, and AST_RWLIST_UNLOCK.
Referenced by __ast_play_and_record(), dictate_exec(), recordthread(), mixmonitor_thread(), record_exec(), rpt(), ast_writestream(), handle_recordfile(), handle_cli_file_convert(), and ast_monitor_start().
{
int fd, myflags = 0;
/* compiler claims this variable can be used before initialization... */
FILE *bfile = NULL;
struct ast_format *f;
struct ast_filestream *fs = NULL;
char *buf = NULL;
size_t size = 0;
int format_found = 0;
AST_RWLIST_RDLOCK(&formats);
/* set the O_TRUNC flag if and only if there is no O_APPEND specified */
/* We really can't use O_APPEND as it will break WAV header updates */
if (flags & O_APPEND) {
flags &= ~O_APPEND;
} else {
myflags = O_TRUNC;
}
myflags |= O_WRONLY | O_CREAT;
/* XXX need to fix this - we should just do the fopen,
* not open followed by fdopen()
*/
AST_RWLIST_TRAVERSE(&formats, f, list) {
char *fn, *orig_fn = NULL;
if (fs)
break;
if (!exts_compare(f->exts, type))
continue;
else
format_found = 1;
fn = build_filename(filename, type);
fd = open(fn, flags | myflags, mode);
if (fd > -1) {
/* fdopen() the resulting file stream */
bfile = fdopen(fd, ((flags | myflags) & O_RDWR) ? "w+" : "w");
if (!bfile) {
ast_log(LOG_WARNING, "Whoa, fdopen failed: %s!\n", strerror(errno));
close(fd);
fd = -1;
}
}
if (ast_opt_cache_record_files && (fd > -1)) {
char *c;
fclose(bfile); /* this also closes fd */
/*
We touch orig_fn just as a place-holder so other things (like vmail) see the file is there.
What we are really doing is writing to record_cache_dir until we are done then we will mv the file into place.
*/
orig_fn = ast_strdupa(fn);
for (c = fn; *c; c++)
if (*c == '/')
*c = '_';
size = strlen(fn) + strlen(record_cache_dir) + 2;
buf = alloca(size);
strcpy(buf, record_cache_dir);
strcat(buf, "/");
strcat(buf, fn);
ast_free(fn);
fn = buf;
fd = open(fn, flags | myflags, mode);
if (fd > -1) {
/* fdopen() the resulting file stream */
bfile = fdopen(fd, ((flags | myflags) & O_RDWR) ? "w+" : "w");
if (!bfile) {
ast_log(LOG_WARNING, "Whoa, fdopen failed: %s!\n", strerror(errno));
close(fd);
fd = -1;
}
}
}
if (fd > -1) {
errno = 0;
fs = get_filestream(f, bfile);
if (fs) {
if ((fs->write_buffer = ast_malloc(32768))) {
setvbuf(fs->f, fs->write_buffer, _IOFBF, 32768);
}
}
if (!fs || rewrite_wrapper(fs, comment)) {
ast_log(LOG_WARNING, "Unable to rewrite %s\n", fn);
close(fd);
if (orig_fn) {
unlink(fn);
unlink(orig_fn);
}
if (fs) {
ast_closestream(fs);
fs = NULL;
}
continue;
}
fs->trans = NULL;
fs->fmt = f;
fs->flags = flags;
fs->mode = mode;
if (orig_fn) {
fs->realfilename = ast_strdup(orig_fn);
fs->filename = ast_strdup(fn);
} else {
fs->realfilename = NULL;
fs->filename = ast_strdup(filename);
}
fs->vfs = NULL;
/* If truncated, we'll be at the beginning; if not truncated, then append */
f->seek(fs, 0, SEEK_END);
} else if (errno != EEXIST) {
ast_log(LOG_WARNING, "Unable to open file %s: %s\n", fn, strerror(errno));
if (orig_fn)
unlink(orig_fn);
}
/* if buf != NULL then fn is already free and pointing to it */
if (!buf)
ast_free(fn);
}
AST_RWLIST_UNLOCK(&formats);
if (!format_found)
ast_log(LOG_WARNING, "No such format '%s'\n", type);
return fs;
}
| int ast_writestream | ( | struct ast_filestream * | fs, |
| struct ast_frame * | f | ||
| ) |
Writes a frame to a stream.
| fs | filestream to write to |
| f | frame to write to the filestream Send a frame to a filestream -- note: does NOT free the frame, call ast_frfree manually |
| 0 | on success. |
| -1 | on failure. |
Definition at line 146 of file file.c.
References ast_frame::frametype, AST_FRAME_VIDEO, ast_filestream::fmt, ast_format::format, AST_FORMAT_AUDIO_MASK, ast_filestream::vfs, ast_filestream::filename, type, ast_getformatname(), ast_frame::subclass, ast_frame_subclass::codec, ast_writefile(), ast_filestream::flags, ast_filestream::mode, ast_debug, ast_writestream(), AST_FRAME_VOICE, ast_log(), LOG_WARNING, ast_format::write, ast_filestream::trans, ast_filestream::lastwriteformat, ast_translator_free_path(), ast_translator_build_path(), ast_format::name, ast_translate(), AST_LIST_NEXT, and ast_frfree.
Referenced by __ast_play_and_record(), dictate_exec(), recordthread(), mixmonitor_thread(), record_exec(), rpt(), __ast_read(), ast_write(), ast_writestream(), handle_recordfile(), and handle_cli_file_convert().
{
int res = -1;
int alt = 0;
if (f->frametype == AST_FRAME_VIDEO) {
if (fs->fmt->format & AST_FORMAT_AUDIO_MASK) {
/* This is the audio portion. Call the video one... */
if (!fs->vfs && fs->filename) {
const char *type = ast_getformatname(f->subclass.codec & ~0x1);
fs->vfs = ast_writefile(fs->filename, type, NULL, fs->flags, 0, fs->mode);
ast_debug(1, "Opened video output file\n");
}
if (fs->vfs)
return ast_writestream(fs->vfs, f);
/* else ignore */
return 0;
} else {
/* Might / might not have mark set */
alt = 1;
}
} else if (f->frametype != AST_FRAME_VOICE) {
ast_log(LOG_WARNING, "Tried to write non-voice frame\n");
return -1;
}
if (((fs->fmt->format | alt) & f->subclass.codec) == f->subclass.codec) {
res = fs->fmt->write(fs, f);
if (res < 0)
ast_log(LOG_WARNING, "Natural write failed\n");
else if (res > 0)
ast_log(LOG_WARNING, "Huh??\n");
} else {
/* XXX If they try to send us a type of frame that isn't the normal frame, and isn't
the one we've setup a translator for, we do the "wrong thing" XXX */
if (fs->trans && f->subclass.codec != fs->lastwriteformat) {
ast_translator_free_path(fs->trans);
fs->trans = NULL;
}
if (!fs->trans)
fs->trans = ast_translator_build_path(fs->fmt->format, f->subclass.codec);
if (!fs->trans)
ast_log(LOG_WARNING, "Unable to translate to format %s, source format %s\n",
fs->fmt->name, ast_getformatname(f->subclass.codec));
else {
struct ast_frame *trf;
fs->lastwriteformat = f->subclass.codec;
/* Get the translated frame but don't consume the original in case they're using it on another stream */
if ((trf = ast_translate(fs->trans, f, 0))) {
struct ast_frame *cur;
/* the translator may have returned multiple frames, so process them */
for (cur = trf; cur; cur = AST_LIST_NEXT(cur, frame_list)) {
if ((res = fs->fmt->write(fs, trf))) {
ast_log(LOG_WARNING, "Translated frame write failed\n");
break;
}
}
ast_frfree(trf);
} else {
res = 0;
}
}
}
return res;
}