複数行のコマンド全体を省略しますduplicity
。しかし、次のスクリプトで一連のパラメータを設定することが可能かどうか疑問に思います。
--exclude "$2/${4:-__nosuchfiles__}" --exclude "$2/${5:-__nosuchfiles__}" ...
鍵は$4
、$5
... この名前にスペースが頻繁に含まれるということです。現在の式は機能しますが、__nosuchfiles__
除外基準セットが通過除外数よりも小さい場合は、何も除外しない醜いデフォルト値が犠牲になります。誰かがというフォルダを作成して__nosuchfiles__
処理できる除外項目の数に制限があるため、これは少しハッキングでもあります。
私が欲しいのは正義です。
EXCLUDES='--exclude "Path 1" --exclude "Path 2"'
私の要件を満たす金額は、--exclude
なしから多いまで、$EXCLUDES
次の二重コマンドラインで置き換えられます。
duplicity $STUFF $EXCLUDES $SOURCE $DESTINATION
もちろん、除外項目がスペースを含む名前を指定する場合は機能しません。スクリプト自体でこれらの除外項目のセットを定義して使用するための式を作成することはできません。 (どんな答えでも全く排除しないという意味ならEXCLUDES=""
ボーナスポイントになります。)
はい、duplicity'sを使用できることを知っていますが、--exclude-filelist
コマンドラインではなくファイルから名前のリストを読みやすくするコマンドに依存しない一般的な解決策があるかどうかを知りたいです。また、$2/
除外されたパスのプレフィックスも記録してください。
ベストアンサー1
重複したコマンドラインを作成するには、単純な文字列連結の代わりに配列を使用する必要があります。その後、"${array[@]}"
構文を使用して、二重性の別々の(スペースを含む)引数として配列の内容を提供できます。これにより、スペースやその他の珍しい文字を脱出することを考える必要がなくなります。
実際にDuplicityを呼び出さずにこれがどのように機能するかを確認するには、次のように引数を別の行に印刷する単純なスクリプトを使用できます。
#!/bin/bash
printf "BEGIN\n"
for x in "$@"
do
printf "ARG: $x\n"
done
printf "END\n"
として保存しましたargs.sh
。
次に、次のように配列を使用してコマンドを作成する必要があります。
#!/bin/bash
if test -z "$1"
then
printf "Need at least one argument"
exit 1
fi
prefix=$1
shift
for arg in "$@"
do
args+=("--exclude")
args+=("$prefix/$arg")
done
./args.sh "${args[@]}"
実際の仕組みは次のとおりです。
$ ./801811.sh foo bar "baz quux"
BEGIN
ARG: --exclude
ARG: foo/bar
ARG: --exclude
ARG: foo/baz quux
END
$STUFF
とを考慮する必要があるため、二重性コマンドラインを設定するにはより多くの作業を実行する必要がありますが、追加の前後に$DESTINATION
args配列に要素を追加してすべて同じ方法で処理できます。args+=("whatever")
除外(適切な場合)もちろんです)。そして最後にduplicity "${args[@]}"
。