forked from neherlab/ncov-europe
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSnakefile
62 lines (50 loc) · 2.05 KB
/
Snakefile
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
from os import environ
from socket import getfqdn
from getpass import getuser
from snakemake.utils import validate
configfile: "defaults/parameters.yaml"
validate(config, schema="workflow/schemas/config.schema.yaml")
# In our shell rules, we try to use the same Python executable running
# Snakemake, if known, by interpolating {python:q}. The aim is to prevent
# issues with multiple Python versions or symlinks for python vs. python3.
python = sys.executable or "python3"
# default build if none specified in config
if "builds" not in config:
config["builds"] = {
"global": {
"subsampling_scheme": "region_global",
}
}
BUILD_NAMES = list(config["builds"].keys())
# Define patterns we expect for wildcards.
wildcard_constraints:
# Allow build names to contain alpha characters, underscores, and hyphens
# but not special strings used for Nextstrain builds.
build_name = r'(?:[_a-zA-Z-](?!(tip-frequencies|gisaid|zh)))+',
date = r"[0-9][0-9][0-9][0-9]-[0-9][0-9]-[0-9][0-9]"
localrules: download
# Create a standard ncov build for auspice, by default.
rule all:
input:
auspice_json = expand("auspice/ncov_{build_name}.json", build_name=BUILD_NAMES),
tip_frequency_json = expand("auspice/ncov_{build_name}_tip-frequencies.json", build_name=BUILD_NAMES)
rule clean:
message: "Removing directories: {params}"
params:
"results ",
"auspice"
shell:
"rm -rfv {params}"
# Include small, shared functions that help build inputs and parameters.
include: "workflow/snakemake_rules/common.smk"
# Include rules to handle primary build logic from multiple sequence alignment
# to output of auspice JSONs for a default build.
include: "workflow/snakemake_rules/main_workflow.smk"
# Include a custom Snakefile that specifies `localrules` required by the user's
# workflow environment.
if "localrules" in config:
include: config["localrules"]
# Include custom rules defined in the config.
if "custom_rules" in config:
for rule_file in config["custom_rules"]:
include: rule_file