mirror of
https://gitlab.xiph.org/xiph/ezstream.git
synced 2024-12-04 14:46:31 -05:00
Add new wrapper/convenience script ezstream-file.sh -- generates ezstreams on-
the-fly. git-svn-id: https://svn.xiph.org/trunk/ezstream@16529 0101bb08-14d6-0310-b084-bc0e0c8e3800
This commit is contained in:
parent
f8c39fa992
commit
d3151cd65a
6
NEWS
6
NEWS
@ -1,5 +1,11 @@
|
|||||||
Changes in 0.5.6, released on XXXX-XX-XX:
|
Changes in 0.5.6, released on XXXX-XX-XX:
|
||||||
|
|
||||||
|
* ezstream-file.sh:
|
||||||
|
- [NEW] Add and install ezstream-file.sh, a new convenience shell script
|
||||||
|
that generates configuration and playlist from a template and
|
||||||
|
command line, respectively. (Bourne shell and POSIX utilities
|
||||||
|
required.)
|
||||||
|
See ezstream-file.sh(1) for details.
|
||||||
* src/ezstream.c:
|
* src/ezstream.c:
|
||||||
- [MISC] Be more tolerant towards faulty playlists and similar issues.
|
- [MISC] Be more tolerant towards faulty playlists and similar issues.
|
||||||
Failure to open a resource (e.g. a media file) is no longer fatal
|
Failure to open a resource (e.g. a media file) is no longer fatal
|
||||||
|
@ -281,9 +281,12 @@ AC_CONFIG_FILES([
|
|||||||
compat/Makefile
|
compat/Makefile
|
||||||
compat/sys/Makefile
|
compat/sys/Makefile
|
||||||
doc/Makefile
|
doc/Makefile
|
||||||
|
doc/ezstream-file.sh.1.in
|
||||||
|
doc/ezstream.1.in
|
||||||
examples/Makefile
|
examples/Makefile
|
||||||
m4/Makefile
|
m4/Makefile
|
||||||
src/Makefile
|
src/Makefile
|
||||||
|
src/ezstream-file.sh
|
||||||
win32/Makefile
|
win32/Makefile
|
||||||
win32/shout/Makefile
|
win32/shout/Makefile
|
||||||
])
|
])
|
||||||
|
@ -1,14 +1,16 @@
|
|||||||
AUTOMAKE_OPTIONS = 1.9 foreign
|
AUTOMAKE_OPTIONS = 1.9 foreign
|
||||||
|
|
||||||
man_MANS = ezstream.1
|
man_MANS = ezstream.1 ezstream-file.sh.1
|
||||||
|
|
||||||
EXTRA_DIST = ezstream.1.in
|
|
||||||
|
|
||||||
do_subst = sed \
|
do_subst = sed \
|
||||||
-e 's|!!EXAMPLES_DIR!!|@EXAMPLES_DIR@|g' \
|
-e 's|!!EXAMPLES_DIR!!|@EXAMPLES_DIR@|g'
|
||||||
-e 's|!!BUILD_DATE!!|@BUILD_DATE@|g'
|
|
||||||
|
.PHONY: $(man_MANS)
|
||||||
|
|
||||||
ezstream.1: ezstream.1.in Makefile
|
ezstream.1: ezstream.1.in Makefile
|
||||||
$(do_subst) < $(srcdir)/ezstream.1.in > ezstream.1
|
$(do_subst) < $(builddir)/ezstream.1.in > ezstream.1
|
||||||
|
|
||||||
|
ezstream-file.sh.1: ezstream-file.sh.1.in Makefile
|
||||||
|
$(do_subst) < $(builddir)/ezstream-file.sh.1.in > ezstream-file.sh.1
|
||||||
|
|
||||||
CLEANFILES = *~ *.core core $(man_MANS)
|
CLEANFILES = *~ *.core core $(man_MANS)
|
||||||
|
110
doc/ezstream-file.sh.1.in.in
Normal file
110
doc/ezstream-file.sh.1.in.in
Normal file
@ -0,0 +1,110 @@
|
|||||||
|
.\" $Id$
|
||||||
|
.\"
|
||||||
|
.\" Copyright (c) 2009 Moritz Grimm <mdgrimm@gmx.net>
|
||||||
|
.\"
|
||||||
|
.\" Permission to use, copy, modify, and distribute this software for any
|
||||||
|
.\" purpose with or without fee is hereby granted, provided that the above
|
||||||
|
.\" copyright notice and this permission notice appear in all copies.
|
||||||
|
.\"
|
||||||
|
.\" THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||||
|
.\" WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||||
|
.\" MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||||
|
.\" ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||||
|
.\" WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||||
|
.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||||
|
.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
.\"
|
||||||
|
.Dd @BUILD_DATE@
|
||||||
|
.Dt EZSTREAM-FILE.SH 1
|
||||||
|
.Os @PACKAGE_NAME@ @PACKAGE_VERSION@
|
||||||
|
.Sh NAME
|
||||||
|
.Nm ezstream-file.sh
|
||||||
|
.Nd convenience script to stream files from the command line
|
||||||
|
.Sh SYNOPSIS
|
||||||
|
.Nm
|
||||||
|
.Bk -words
|
||||||
|
.Op Fl hnqVv
|
||||||
|
.Op Fl T Ar cfg_template
|
||||||
|
.Op Ar
|
||||||
|
.Ek
|
||||||
|
.Sh DESCRIPTION
|
||||||
|
The
|
||||||
|
.Nm
|
||||||
|
script uses an
|
||||||
|
.Nm ezstream
|
||||||
|
configuration file template to stream a list of files given on the command
|
||||||
|
line, or via standard input.
|
||||||
|
In other words, filenames are written to a temporary playlist, and a
|
||||||
|
template-based configuration is generated to stream them.
|
||||||
|
.Pp
|
||||||
|
The path to a configuration template must be provided, either by using the
|
||||||
|
.Fl T
|
||||||
|
command line argument, or the
|
||||||
|
.Dv EZSTREAM_TEMPLATE
|
||||||
|
environment variable.
|
||||||
|
.Pp
|
||||||
|
The configuration template must be a valid playlist configuration, and contain
|
||||||
|
the follwing configuration statement:
|
||||||
|
.Bd -literal -offset indent
|
||||||
|
\&<filename\&>%FILENAME%\&</filename\&>
|
||||||
|
.Ed
|
||||||
|
.Pp
|
||||||
|
If no input files are specified, the list of files to be streamed are read
|
||||||
|
from standard input.
|
||||||
|
.Pp
|
||||||
|
Lastly, the
|
||||||
|
.Dv EZSTREAM
|
||||||
|
environment variable allows to specify an alternate
|
||||||
|
.Nm ezstream
|
||||||
|
binary.
|
||||||
|
.Ss Command line parameters
|
||||||
|
.Bl -tag -width Ds
|
||||||
|
.It Fl h
|
||||||
|
Print a summary of available command line parameters with short descriptions
|
||||||
|
and exit.
|
||||||
|
.It Fl n
|
||||||
|
.Po
|
||||||
|
Passed to
|
||||||
|
.Nm ezstream .
|
||||||
|
.Pc
|
||||||
|
Normalize metadata strings by removing excess whitespaces.
|
||||||
|
.It Fl q
|
||||||
|
.Po
|
||||||
|
Passed to
|
||||||
|
.Nm ezstream .
|
||||||
|
.Pc
|
||||||
|
Be more quiet.
|
||||||
|
Suppress the output that external programs send to standard error.
|
||||||
|
.It Fl T Ar cfg_template
|
||||||
|
Use the configuration in
|
||||||
|
.Ar cfg_template ,
|
||||||
|
overriding the default set in the
|
||||||
|
.Dv EZSTREAM_TEMPLATE
|
||||||
|
environment variable.
|
||||||
|
.It Fl V
|
||||||
|
Print the
|
||||||
|
.Nm
|
||||||
|
version number and exit.
|
||||||
|
.It Fl v
|
||||||
|
.Po
|
||||||
|
Passed to
|
||||||
|
.Nm ezstream .
|
||||||
|
.Pc
|
||||||
|
Produce more verbose output from
|
||||||
|
.Nm ezstream .
|
||||||
|
Use twice for even more verbose output.
|
||||||
|
.El
|
||||||
|
.Sh FILES
|
||||||
|
.Bl -tag -width "!!EXAMPLES_DIR!!" -compact
|
||||||
|
.It Pa !!EXAMPLES_DIR!!
|
||||||
|
Directory containing example configuration files for various uses of
|
||||||
|
.Nm ezstream ,
|
||||||
|
as well as example playlist and metadata scripts.
|
||||||
|
.El
|
||||||
|
.Sh SEE ALSO
|
||||||
|
.Xr ezstream 1
|
||||||
|
.Sh AUTHORS
|
||||||
|
.An -nosplit
|
||||||
|
.Nm
|
||||||
|
and this manual were written by
|
||||||
|
.An Moritz Grimm Aq mdgrimm@gmx.net .
|
@ -3,9 +3,9 @@
|
|||||||
.\" This document may be be used and/or modified under the licensing terms
|
.\" This document may be be used and/or modified under the licensing terms
|
||||||
.\" of the Ezstream software.
|
.\" of the Ezstream software.
|
||||||
.\"
|
.\"
|
||||||
.Dd !!BUILD_DATE!!
|
.Dd @BUILD_DATE@
|
||||||
.Dt EZSTREAM 1
|
.Dt EZSTREAM 1
|
||||||
.Os
|
.Os @PACKAGE_NAME@ @PACKAGE_VERSION@
|
||||||
.Sh NAME
|
.Sh NAME
|
||||||
.Nm ezstream
|
.Nm ezstream
|
||||||
.Nd source client for Icecast with external de-/encoder support
|
.Nd source client for Icecast with external de-/encoder support
|
||||||
@ -598,6 +598,8 @@ Directory containing example configuration files for various uses of
|
|||||||
.Nm ,
|
.Nm ,
|
||||||
as well as example playlist and metadata scripts.
|
as well as example playlist and metadata scripts.
|
||||||
.El
|
.El
|
||||||
|
.Sh SEE ALSO
|
||||||
|
.Xr ezstream-file.sh 1
|
||||||
.Sh AUTHORS
|
.Sh AUTHORS
|
||||||
.Nm
|
.Nm
|
||||||
was written by:
|
was written by:
|
@ -1,6 +1,7 @@
|
|||||||
AUTOMAKE_OPTIONS = 1.9 foreign
|
AUTOMAKE_OPTIONS = 1.9 foreign
|
||||||
|
|
||||||
bin_PROGRAMS = ezstream
|
bin_PROGRAMS = ezstream
|
||||||
|
bin_SCRIPTS = ezstream-file.sh
|
||||||
|
|
||||||
ezstream_SOURCES = \
|
ezstream_SOURCES = \
|
||||||
compat.c \
|
compat.c \
|
||||||
|
145
src/ezstream-file.sh.in
Normal file
145
src/ezstream-file.sh.in
Normal file
@ -0,0 +1,145 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# ezstream-file.sh
|
||||||
|
# Convenience/wrapper script that uses ezstream to stream one or more files
|
||||||
|
# given on the command line.
|
||||||
|
|
||||||
|
# Copyright (c) 2009 Moritz Grimm <mdgrimm@gmx.net>
|
||||||
|
#
|
||||||
|
# Permission to use, copy, modify, and distribute this software for any
|
||||||
|
# purpose with or without fee is hereby granted, provided that the above
|
||||||
|
# copyright notice and this permission notice appear in all copies.
|
||||||
|
#
|
||||||
|
# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||||
|
# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||||
|
# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||||
|
# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||||
|
# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||||
|
# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||||
|
# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
|
||||||
|
_myname="$(basename $0)"
|
||||||
|
_filename_placeholder="%FILENAME%"
|
||||||
|
|
||||||
|
_opt_string="hnqT:Vv"
|
||||||
|
print_usage()
|
||||||
|
{
|
||||||
|
echo "usage: ${_myname} [-hnqVv] [-T cfg_template] [file ...]" >&2
|
||||||
|
}
|
||||||
|
|
||||||
|
print_usage_help()
|
||||||
|
{
|
||||||
|
cat << __EOT >&2
|
||||||
|
|
||||||
|
-h print this help and exit
|
||||||
|
-n [ezstream] normalize metadata strings
|
||||||
|
-q [ezstream] suppress STDERR output from external en-/decoders
|
||||||
|
-T template run ezstream using template for configuration
|
||||||
|
-V print the version number and exit
|
||||||
|
-v [ezstream] verbose output (use twice for more effect)
|
||||||
|
|
||||||
|
The configuration template must contain the configuration statement
|
||||||
|
<filename>${_filename_placeholder}</filename>
|
||||||
|
|
||||||
|
See the ezstream-file.sh(1) manual for detailed information.
|
||||||
|
__EOT
|
||||||
|
}
|
||||||
|
|
||||||
|
_normalize=""
|
||||||
|
_quiet=""
|
||||||
|
_verbose=""
|
||||||
|
_cfg_template="${EZSTREAM_TEMPLATE}"
|
||||||
|
|
||||||
|
_args=`getopt ${_opt_string} $*`
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
print_usage
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
set -- ${_args}
|
||||||
|
while [ $# -ge 0 ]
|
||||||
|
do
|
||||||
|
case "$1" in
|
||||||
|
-h)
|
||||||
|
print_usage
|
||||||
|
print_usage_help
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
-n)
|
||||||
|
_normalize="-n"; shift ;;
|
||||||
|
-q)
|
||||||
|
_quiet="-q"; shift ;;
|
||||||
|
-T)
|
||||||
|
_cfg_template="$2"; shift; shift ;;
|
||||||
|
-V)
|
||||||
|
echo "${_myname} @PACKAGE_VERSION@"
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
-v)
|
||||||
|
if [ -z "${_verbose}" ]; then
|
||||||
|
_verbose="-v"
|
||||||
|
else
|
||||||
|
_verbose="${_verbose}v"
|
||||||
|
fi
|
||||||
|
shift ;;
|
||||||
|
--)
|
||||||
|
shift; break ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ -z "${_cfg_template}" ]; then
|
||||||
|
echo "${_myname}: No configuration template supplied." >&2
|
||||||
|
echo "Use -T or the EZSTREAM_TEMPLATE environment variable." >&2
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
if [ ! -e "${_cfg_template}" ]; then
|
||||||
|
echo "${_myname}: Configuration template ${_cfg_template} does not exist." >&2
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
if [ -z "$(grep ${_filename_placeholder} ${_cfg_template})" ]; then
|
||||||
|
echo "${_myname}: ${_cfg_template} lacks the ${_filename_placeholder} placeholder." >&2
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
|
||||||
|
test -n "${EZSTREAM}" || EZSTREAM="$(which ezstream)"
|
||||||
|
if [ -z "${EZSTREAM}" ]; then
|
||||||
|
echo "${_myname}: Cannot find ezstream." >&2
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
|
||||||
|
_temp_dir="`mktemp -t -d _ezstream.XXXXXXXXXX`"
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "${_myname}: Unable to create temporary directory." >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
trap 'rm -rf ${_temp_dir}' 0
|
||||||
|
trap 'rm -rf ${_temp_dir}; exit 1' 2 15
|
||||||
|
|
||||||
|
_cfg="${_temp_dir}/config.xml"
|
||||||
|
_playlist="${_temp_dir}/playlist.txt"
|
||||||
|
|
||||||
|
touch "${_cfg}"
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "${_myname}: Unable to create configuration." >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
chmod 0600 "${_cfg}"
|
||||||
|
|
||||||
|
sed -e "s,${_filename_placeholder},${_playlist},g" \
|
||||||
|
< "${_cfg_template}" \
|
||||||
|
> "${_cfg}"
|
||||||
|
|
||||||
|
if [ -n "$1" ]; then
|
||||||
|
for _file in $*
|
||||||
|
do
|
||||||
|
echo "${_file}" >> "${_playlist}"
|
||||||
|
done
|
||||||
|
else
|
||||||
|
while read _file
|
||||||
|
do
|
||||||
|
echo "${_file}" >> "${_playlist}"
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
"${EZSTREAM}" ${_normalize} ${_quiet} ${_verbose} -c "${_cfg}"
|
||||||
|
|
||||||
|
exit $?
|
Loading…
Reference in New Issue
Block a user