forked from dnglab/dnglab
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgentestidx.sh
79 lines (62 loc) · 3.35 KB
/
gentestidx.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
RAWDB="/storage/main/projects/raw/cr3samples/rawdb"
function process_rawfile() {
rawfile=$1
echo $rawfile;
sample=$RAWDB/"$rawfile"
analyze=${rawfile}".analyze.yaml"
digest=${rawfile}".digest.txt"
#dir=`dirname rawler/tests/testdata/"$analyze"`;
#mkdir -p "$dir";
if [ ! -f rawler/data/testdata/"$analyze" ]; then
echo "Processing ${rawfile}";
echo " analyze file: $analyze"
echo " digest file: $digest"
./target/release/dnglab analyze --meta --yaml "$sample" > rawler/data/testdata/"$analyze";
./target/release/dnglab analyze --raw-checksum "$sample" > rawler/data/testdata/"$digest";
fi
MAKE=`echo $rawfile | cut -d/ -f2`;
MODEL=`echo $rawfile | cut -d/ -f3`;
TESTNAME=`basename "${rawfile@L}" | sed -e 's,[[:space:][:punct:]],_,g' -e 's,_+,_,g'`;
echo -e "\tsuper::camera_file_check!(\"$MAKE\", \"$MODEL\", "cam_"$TESTNAME, \"`echo $rawfile | cut -d'/' -f4-`\");" >> "rawler/tests/cameras/mod.rs";
#file "$pixel";
}
cat rawler/tests/supported_rawdb_sets.txt | while read setdir; do mkdir -v -p "rawler/data/testdata/$setdir"; done
#find "$RAWDB" -type f -name RAWLER_SUPPORTED -printf "%h\n" | while read searchdir; do find "$searchdir" -type f -not -name "RAWLER_SUPPORTED" -and -not -name "*.txt" -exec realpath --relative-to $RAWDB '{}' \;; done > rawler/tests/testfiles.idx
#find $RAWDB -type f -name "*.CR3" -exec realpath --relative-to $RAWDB '{}' \; > rawler/tests/testfiles.idx
#while read line; do dirname "$line"; done < rawler/tests/testfiles.idx | sort | uniq | while read setdir; do mkdir -p "rawler/tests/testfiles/$setdir"; done
#exit;
cargo build --release;
#echo "" > "rawler/tests/generated_tests.inc";
echo "use crate::common::camera_file_check;" > "rawler/tests/cameras/mod.rs";
cat rawler/tests/supported_rawdb_sets.txt | grep -v "^$" | while read setdir; do
echo "Processing: $setdir";
modname="camera_"`echo $setdir | cut -d'/' -f3- | sed -e 's,[^[:alnum:]]\+,_,g'`;
echo "mod ${modname@L} {" >> "rawler/tests/cameras/mod.rs";
find "$RAWDB/$setdir" -type f -not -name "*.txt" -exec realpath --relative-to $RAWDB '{}' \; | while read rawfile; do
process_rawfile "$rawfile";
done;
echo "}" >> "rawler/tests/cameras/mod.rs";
done;
echo "" >> "rawler/tests/cameras/mod.rs";
cargo fmt;
exit;
echo "use crate::common::camera_file_check;" > "rawler/tests/cameras/mod.rs";
while read rawfile; do
sample=$RAWDB/"$rawfile"
analyze=${rawfile}".analyze.yaml"
digest=${rawfile}".digest.txt"
dir=`dirname rawler/tests/testdata/"$analyze"`;
mkdir -p "$dir";
if [ ! -f rawler/tests/testdata/"$analyze" ]; then
echo "Processing ${rawfile}";
echo " analyze file: $analyze"
echo " digest file: $digest"
./target/release/dnglab analyze --meta --yaml "$sample" > rawler/tests/testdata/"$analyze";
./target/release/dnglab analyze --checksum "$sample" > rawler/tests/testdata/"$digest";
fi
MAKE=`echo $rawfile | cut -d/ -f2`;
MODEL=`echo $rawfile | cut -d/ -f3`;
TESTNAME=`basename "${rawfile@L}" | sed -e 's,[[:space:][:punct:]],_,g' -e 's,_+,_,g'`;
echo "camera_file_check!(\"$MAKE\", \"$MODEL\", $TESTNAME, \"`echo $rawfile | cut -d'/' -f4-`\");" >> "rawler/tests/cameras/mod.rs";
#file "$pixel";
done < rawler/tests/testfiles.idx;