File: fastq.pyx

package info (click to toggle)
obitools 3.0.1~b26%2Bdfsg-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 26,788 kB
  • sloc: ansic: 24,299; python: 657; sh: 27; makefile: 20
file content (41 lines) | stat: -rwxr-xr-x 986 bytes parent folder | download | duplicates (2)
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
#cython: language_level=3

'''
Created on oct 14th 2018

@author: celine.mercier.bioinfo@gmail.com
'''

    
cdef class FastqWriter:
    
    def __init__(self, 
                 object formatter, 
                 object output_object, 
                 int skip=0,
                 only=None):
        
        self.formatter = formatter
        self.output = output_object
    
        if only is None:
            self.only = -1
        else:
            self.only = int(only)

        self.formatter = formatter
        self.output = output_object
        self.skip = skip
        self.skipped = 0
        self.read = 0
    
    
    def __call__(self, object seq):
        if self.only > -1 and self.read == self.only:
            raise StopIteration
        if self.skip > 0 and self.skipped < self.skip:
            self.skipped += 1
            return
        self.output.write(self.formatter(seq))
        self.output.write(b"\n")  # TODO is that clean?
        self.read += 1