X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=kseq.h;h=bbe012552ff3b2ac047ddd10655e80827bbb4008;hb=8cc87acf088966330e253d44e67791696d74f35b;hp=2875c77577152eb9a20b41fc044288f67eb124ab;hpb=42e756837f7acb91bfd1134ef16d423e71c913d7;p=samtools.git diff --git a/kseq.h b/kseq.h index 2875c77..bbe0125 100644 --- a/kseq.h +++ b/kseq.h @@ -25,6 +25,8 @@ /* Contact: Heng Li */ +/* Last Modified: 12APR2009 */ + #ifndef AC_KSEQ_H #define AC_KSEQ_H @@ -32,6 +34,10 @@ #include #include +#define KS_SEP_SPACE 0 // isspace(): \t, \n, \v, \f, \r +#define KS_SEP_TAB 1 // isspace() && !' ' +#define KS_SEP_MAX 1 + #define __KS_TYPE(type_t) \ typedef struct __kstream_t { \ char *buf; \ @@ -99,13 +105,16 @@ typedef struct __kstring_t { if (ks->end == 0) break; \ } else break; \ } \ - if (delimiter) { \ + if (delimiter > KS_SEP_MAX) { \ for (i = ks->begin; i < ks->end; ++i) \ if (ks->buf[i] == delimiter) break; \ - } else { \ + } else if (delimiter == KS_SEP_SPACE) { \ for (i = ks->begin; i < ks->end; ++i) \ if (isspace(ks->buf[i])) break; \ - } \ + } else if (delimiter == KS_SEP_TAB) { \ + for (i = ks->begin; i < ks->end; ++i) \ + if (isspace(ks->buf[i]) && ks->buf[i] != ' ') break; \ + } else i = 0; /* never come to here! */ \ if (str->m - str->l < i - ks->begin + 1) { \ str->m = str->l + (i - ks->begin) + 1; \ kroundup32(str->m); \ @@ -119,6 +128,10 @@ typedef struct __kstring_t { break; \ } \ } \ + if (str->l == 0) { \ + str->m = 1; \ + str->s = (char*)calloc(1, 1); \ + } \ str->s[str->l] = '\0'; \ return str->l; \ }