blob: 8dabc4fb285507571319e120f7a2d8674715159b (
plain)
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
|
{bionix, nixpkgs}:
with nixpkgs;
with lib;
let
nix-adt-src = fetchFromGitHub {
owner = "shlevy";
repo = "nix-adt";
rev = "dd04b5d08eed65ecd73aafde56a78078e09f1c74";
sha256 = "0vhk1y7gilgn2pgvj4813bh2ljpw4pvrph8k8b0fsg56dbm8mqxa";
};
nix-adt = import "${nix-adt-src}";
inherit (nix-adt.checked) make-type match any std none;
inherit (std) option;
idft = sym: ft: _: abort "unhandled filetype (${ft}) for ${sym}";
idst = sym: st: _: abort "unhandled sorting (${st}) for ${sym}";
defError = errF: y: x: listToAttrs (map (n: nameValuePair n (errF n)) (filter (x: builtins.substring 0 1 x != "_") (attrNames x))) // y;
in
rec {
option-sort = option sorting;
matchFiletype = sym: y: x: if x ? filetype then match x.filetype (defError (idft sym) y filetype) else abort "unknown filetype for ${sym}";
filetype = make-type "filetype" {
fa = {};
fq = {};
bam = {ref = any; sorting = option-sort;};
sam = {ref = any; sorting = option-sort;};
cram = {ref = any; sorting = option-sort;};
vcf = {ref = any;};
bed = {ref = any;};
gz = filetype;
bz2 = filetype;
};
toCram = matchFiletype "bam2cram" { bam = filetype.cram; sam = filetype.cram; cram = filetype.cram; };
toBam = matchFiletype "bam2cram" { bam = filetype.bam; sam = filetype.bam; cram = filetype.bam; };
toSam = matchFiletype "bam2cram" { bam = filetype.sam; sam = filetype.sam; cram = filetype.sam; };
matchSorting = sym: y: let f = x: match x.sorting { some = z: match z (defError (idst sym) y sorting); none = abort "unknown sort for ${sym}"; }; in matchFiletype sym { bam = f; sam = f; cram = f; };
sorting = make-type "sorting" {
coord = {};
name = {};
};
coordSort = f: matchFiletype "coordSort" { bam = x: filetype.bam (x // {sorting = option-sort.some (sorting.coord {});}); } {filetype = f;};
nameSort = f: matchFiletype "nameSort" { bam = x: filetype.bam (x // {sorting = option-sort.some (sorting.name {});}); } {filetype = f;};
gunzip = matchFiletype "gunzip" { gz = x: x; };
bunzip2 = matchFiletype "bunzip2" { bz2 = x: x; };
tag = attrs: x: if x ? type && x.type == "derivation" then x // attrs else tagPassthru attrs x;
tagPassthru = attrs: x: if x ? passthru then x // { passthru = x.passthru // attrs; } else x // { passthru = attrs; };
tagFiletype = ft: tag { filetype = ft; };
}
|