-
Notifications
You must be signed in to change notification settings - Fork 66
/
FileFormat.h
97 lines (68 loc) · 2.83 KB
/
FileFormat.h
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/*++
Module Name:
FileFormat.h
Abstract:
Headers for the FileFormat class for the SNAP sequencer
Authors:
Ravi Pandya, February 2013
Environment:
User mode service.
Revision History:
--*/
#pragma once
#include "Compat.h"
#include "Tables.h"
#include "Read.h"
#include "Genome.h"
#include "LandauVishkin.h"
#include "AlignerOptions.h"
#include "Genome.h"
//
// abstract class defining format-specific operations
// for reading and writing files of reads
//
class FileFormat
{
public:
//
// files
//
// reading
//
virtual void getSortInfo(const Genome* genome, char* buffer, _int64 bytes, GenomeLocation* o_location, GenomeDistance* o_readBytes, int* o_refID = NULL, int* o_pos = NULL) const = 0;
/*
virtual ReadReader* createReader(const DataSupplier* supplier, const char *fileName,
const Genome *genome, _int64 startingOffset, _int64 amountOfFileToProcess,
ReadClippingType clipping = ClipBack) = 0;
virtual PairedReadReader* createPairedReader(const DataSupplier* supplier, const char *fileName,
const Genome *genome, _int64 startingOffset, _int64 amountOfFileToProcess,
ReadClippingType clipping = ClipBack) = 0;
virtual ReadSupplierGenerator *createReadSupplierGenerator(const char *fileName, int numThreads,
const Genome *genome, ReadClippingType clipping = ClipBack) = 0;
virtual PairedReadSupplierGenerator *createPairedReadSupplierGenerator(const char *fileName,
int numThreads, const Genome *genome, ReadClippingType clipping = ClipBack) = 0;
// parse header and match against genome
virtual bool parseHeader(const char *fileName, char *firstLine, char *endOfBuffer,
const Genome *genome, _int64 *o_headerSize) = 0;
*/
//
// writing
//
virtual ReadWriterSupplier* getWriterSupplier(AlignerOptions* options, const Genome* genome) const = 0;
virtual bool writeHeader(
const ReaderContext& context, char *header, size_t headerBufferSize, size_t *headerActualSize,
bool sorted, int argc, const char **argv, const char *version, const char *rgLine) const = 0;
virtual bool writeRead(
const Genome * genome, LandauVishkinWithCigar * lv, char * buffer, size_t bufferSpace,
size_t * spaceUsed, size_t qnameLen, Read * read, AlignmentResult result,
int mapQuality, GenomeLocation genomeLocation, Direction direction, bool secondaryAlignment,
bool hasMate = false, bool firstInPair = false, Read * mate = NULL,
AlignmentResult mateResult = NotFound, GenomeLocation mateLocation = 0, Direction mateDirection = FORWARD) const = 0;
//
// formats
//
static const FileFormat* SAM[2]; // 0 for =, 1 for M (useM flag)
static const FileFormat* BAM[2];
static const FileFormat* FASTQ;
static const FileFormat* FASTQZ;
};