[FFmpeg-devel] [RFC][PATCH] Tool to sort files a bit
Stefano Sabatini
stefano.sabatini-lala
Sat Oct 9 11:23:30 CEST 2010
On date Saturday 2010-10-09 00:12:17 +0200, Michael Niedermayer encoded:
> Hi
>
> The attached script creates directories and symlinks for multimedia files
> based on container and codec in the file. I hope ive not done this work
> redundantly
> it needs to be checked by someone who knows shell escaping to make it
> secure ive made no attempt at making it secure.
>
> Also if people are ok with it id like to commit this so more people can work on
> it, iam not an expert on shell programming ...
>
> yes its intended to help with incoming / samples maybe at some point or even
> to help people sort their personal file collections
>
>
> commit ca9a964c2eba0ba6cda767cfe2d74b80c245dd4c
> Author: Michael Niedermayer <michaelni at gmx.at>
> Date: Fri Oct 8 23:58:51 2010 +0200
>
> Tool to analyze multimedia files and create directories and symlinks for the
> container type and codecs in each file that point back to the file.
>
> diff --git a/tools/jauche_sortierer.sh b/tools/jauche_sortierer.sh
> new file mode 100755
> index 0000000..517353f
> --- /dev/null
> +++ b/tools/jauche_sortierer.sh
> @@ -0,0 +1,19 @@
> +#!/bin/sh
> +#GPL
> +#TODO
> +#add pixelformat/sampleformat into the path of the codecs
> +
> +FFP=../ffprobe
> +TMP=./misthaufen
The name of the script and of $TMP are weird, as already noted...
Also $TMP should contain at least the pid, in order to avoid conflicts
with other concurrent instances of the script, so I suggest:
TMP=$TMPDIR/$(basename $0)-$$
> +TARGET=$1
> +shift
> +
> +for v do
what is v?
> + BASE=`basename $v`
> + echo $v | egrep -i '(public|private)' >/dev/null && echo Warning $v may be private
> + $FFP $v 2> $TMP
> + FORM=`(grep 'Input #0, ' -m1 $TMP || echo 'Input #0, unknown') | sed 's/Input #0, \([a-zA-Z0-9_]*\).*/\1/' `
Since we're using ffprobe the parsing can be simplified a lot (and
made more robust), using ffprobe -show_streams -show_format, also it
should make trivial to add support for other features like pixfmts,
samplefmts, codec tags.
Also I tend to prefer the $(...) syntax over `...`, as it is generally
more readable (and my editor allows to match opening and closing
paren).
> + mkdir -p $TARGET/container/$FORM
> + ln -s $v $TARGET/container/$FORM/$BASE
> + eval `grep 'Stream #0\.[^:]*: [a-zA-Z0-9][^:]*: [a-zA-Z0-9]' $TMP | sed 's#[^:]*: \([a-zA-Z0-9]*\)[^:]*: \([a-zA-Z0-9]*\).*#mkdir -p '$TARGET'/\1/\2 ; ln -s '$v' '$TARGET'/\1/\2/'$BASE' ; #'`
> +done
Missing rm $TMP at the end.
Regards.
--
FFmpeg = Fiendish & Fabulous MultiPurpose Excellent Gymnast
More information about the ffmpeg-devel
mailing list