-
Notifications
You must be signed in to change notification settings - Fork 41
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'bump_v0.2.9' into 'dev'
Version bump See merge request epi2melabs/workflows/wf-single-cell!124
- Loading branch information
Showing
4 changed files
with
69 additions
and
10 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
"""Check (u)BAM files for `@SQ` lines whether they are the same in all headers.""" | ||
|
||
from pathlib import Path | ||
import sys | ||
|
||
import pysam | ||
|
||
from .util import get_named_logger, wf_parser # noqa: ABS101 | ||
|
||
|
||
def get_sq_lines(xam_file): | ||
"""Extract the `@SQ` lines from the header of a XAM file.""" | ||
return pysam.AlignmentFile(xam_file, check_sq=False).header["SQ"] | ||
|
||
|
||
def main(args): | ||
"""Run the entry point.""" | ||
logger = get_named_logger("checkBamHdr") | ||
|
||
if not args.input_path.is_dir(): | ||
raise ValueError(f"Input path '{args.input_path}' must be a directory.") | ||
|
||
target_files = list(args.input_path.glob("*")) | ||
if not target_files: | ||
raise ValueError(f"No files found in input directory '{args.input_path}'.") | ||
# Loop over target files and check if there are `@SQ` lines in all headers or not. | ||
# Set `is_unaligned` accordingly. If there are mixed headers (either with some files | ||
# containing `@SQ` lines and some not or with different files containing different | ||
# `@SQ` lines), set `mixed_headers` to `True`. | ||
first_sq_lines = None | ||
mixed_headers = False | ||
for xam_file in target_files: | ||
sq_lines = get_sq_lines(xam_file) | ||
if first_sq_lines is None: | ||
# this is the first file | ||
first_sq_lines = sq_lines | ||
else: | ||
# this is a subsequent file; check with the first `@SQ` lines | ||
if sq_lines != first_sq_lines: | ||
mixed_headers = True | ||
break | ||
|
||
# we set `is_unaligned` to `True` if there were no mixed headers and the last file | ||
# didn't have `@SQ` lines (as we can then be sure that none of the files did) | ||
is_unaligned = not mixed_headers and not sq_lines | ||
# write `is_unaligned` and `mixed_headers` out so that they can be set as env. | ||
# variables | ||
sys.stdout.write( | ||
f"IS_UNALIGNED={int(is_unaligned)};MIXED_HEADERS={int(mixed_headers)}" | ||
) | ||
logger.info(f"Checked (u)BAM headers in '{args.input_path}'.") | ||
|
||
|
||
def argparser(): | ||
"""Argument parser for entrypoint.""" | ||
parser = wf_parser("check_bam_headers") | ||
parser.add_argument("input_path", type=Path, help="Path to target directory") | ||
return parser |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters