From f06ad31f282757e6759fc63a5839e28e5dee85fa Mon Sep 17 00:00:00 2001 From: Konstantin Riege Date: Wed, 6 Nov 2024 16:17:03 +0100 Subject: [PATCH] allow for N symbol in barcode if barcodes have been corrected using other tools than 10x cellranger and/or have not been whitelisted, they may contain N symbols. --- dupsifter.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/dupsifter.c b/dupsifter.c index c22e2c4..4a003fe 100644 --- a/dupsifter.c +++ b/dupsifter.c @@ -777,7 +777,7 @@ uint64_t get_packed_barcode(bam1_t *read1, ds_conf_t *conf) { uint8_t *full = s+1; s++; while (*s) { - if (*s != 'A' && *s != 'C' && *s != 'G' && *s != 'T' && *s != '+' && *s != '-') { + if (*s != 'N' && *s != 'A' && *s != 'C' && *s != 'G' && *s != 'T' && *s != '+' && *s != '-') { fprintf(stderr, "[dupsifter] WARNING: Unable to parse barcode from CB tag ('barcode': %s). Using default barcode.\n", full); return 0; @@ -804,7 +804,7 @@ uint64_t get_packed_barcode(bam1_t *read1, ds_conf_t *conf) { uint8_t *full = s+1; s++; while (*s) { - if (*s != 'A' && *s != 'C' && *s != 'G' && *s != 'T' && *s != '+' && *s != '-') { + if (*s != 'N' && *s != 'A' && *s != 'C' && *s != 'G' && *s != 'T' && *s != '+' && *s != '-') { fprintf(stderr, "[dupsifter] WARNING: Unable to parse barcode from CB tag ('barcode': %s). Using default barcode.\n", full); return 0; @@ -834,7 +834,7 @@ uint64_t get_packed_barcode(bam1_t *read1, ds_conf_t *conf) { if (last) { last++; while (*last) { - if (*last != 'A' && *last != 'C' && *last != 'G' && *last != 'T' && *last != '+' && *last != '-') { + if (*last != 'N' && *last != 'A' && *last != 'C' && *last != 'G' && *last != 'T' && *last != '+' && *last != '-') { fprintf(stderr, "[dupsifter] WARNING: Unable to parse barcode from read name ('barcode': %s). Using default barcode.\n", full); return 0;