-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathstrainify
More file actions
executable file
·85 lines (68 loc) · 1.62 KB
/
strainify
File metadata and controls
executable file
·85 lines (68 loc) · 1.62 KB
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
78
79
80
81
82
83
84
85
#!/usr/bin/env bash
set -euo pipefail
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
SNAKEFILE="$SCRIPT_DIR/Snakefile"
FILTER_SCRIPT="$SCRIPT_DIR/filter_genomes.sh"
usage() {
cat <<EOF
Strainify CLI
Usage:
strainify run [snakemake args...]
strainify filter-run [filter args...]
Commands:
run
Run Snakemake pipeline directly
Example:
strainify run --cores 12 --configfile config.yaml
filter-run
Run genome filtering + pipeline
Example:
strainify filter-run \\
--genomes genomes \\
--fastqs fastqs \\
--out results \\
--config config.yaml \\
--threads 12
help
Show this message
EOF
exit 1
}
# ----------------------------
# Parse command
# ----------------------------
if [[ $# -lt 1 ]]; then
usage
fi
CMD="$1"
shift
case "$CMD" in
run)
if [[ ! -f "$SNAKEFILE" ]]; then
echo "ERROR: Snakefile not found at $SNAKEFILE" >&2
exit 1
fi
snakemake --snakefile "$SNAKEFILE" "$@"
;;
filter-run)
if [[ ! -f "$FILTER_SCRIPT" ]]; then
echo "ERROR: filter script not found: $FILTER_SCRIPT" >&2
exit 1
fi
# auto-fix permissions if needed
if [[ ! -x "$FILTER_SCRIPT" ]]; then
chmod +x "$FILTER_SCRIPT" || {
echo "ERROR: Could not make filter script executable" >&2
exit 1
}
fi
"$FILTER_SCRIPT" "$@"
;;
help|-h|--help)
usage
;;
*)
echo "ERROR: Unknown command: $CMD" >&2
usage
;;
esac