ソースファイル(* .c)を含む大規模なディレクトリツリーがあり、その一部(すべてではない)は実際に次のものを生成する前処理によって生成されます。どの.cからどの.qc ファイル。
多くの場合、これらのファイルを使用して作業を実行する必要がありますが、最終的なソースファイルのみを使用する必要があります。どの.qc、言うことはできません。どの.c(しかしそうでない場合それは何ですか.qc だとしたら、本当に見てみたいと思いそれは何ですか。氏)。
次のように起動します。
find data-utils -name '*.qc' -o -name '*.c' | xargs grep SMS_GEN
find 出力の一部が次のようになるとします。
data-utils/whatever.c
data-utils/whatsit.c
data-utils/whatever.qc
通過しないように検索結果をフィルタリングするために使用できる既存のツールはありますか?どの.cをxargs(またはルックアップ後のすべて)。つまり、上記のフィルタ結果は次のようになります。
data-utils/whatsit.c
data-utils/whatever.qc
それとも最初から何かを書くべきですか?
ベストアンサー1
ファイル名サフィックスを含むファイルを探します。ただし、そのようなファイルが存在する場合は、.c
そのファイルのパス名を返します。.qc
find server/data-utils -type f -name '*.c' -exec sh -c '
for pathname do
if [ -f "${pathname%.c}.qc" ]; then
printf "%s\n" "${pathname%.c}.qc"
else
printf "%s\n" "$pathname"
fi
done' sh {} +
server/data-utils
検索パス内または下で名前を探します.c
。これらのパス名のバッチに対して短いシェルスクリプトが呼び出されます。シェルスクリプトは与えられた各パス名をテストし、それをに変更し、変更されたパス.c
名.qc
が既存の一般ファイル(またはそのファイルへのシンボリックリンク)を参照している場合はそれを印刷します。それ以外の場合は、元のパス名が印刷されます。
関連:
上記のバリエーションだけです。乾燥原理アプリケーション:
find server/data-utils -type f -name '*.c' -exec sh -c '
for pathname do
qc_pathname=${pathname%.c}.qc
if [ -f "$qc_pathname" ]; then
out=$qc_pathname
else
out=$pathname
fi
printf "%s\n" "$out"
done' sh {} +
...または、ただ
find server/data-utils -type f -name '*.c' -exec sh -c '
for pathname do
qc_pathname=${pathname%.c}.qc
[ -f "$qc_pathname" ] && pathname=$qc_pathname
printf "%s\n" "$pathname"
done' sh {} +