File: sequence-writer.h

package info (click to toggle)
sra-sdk 2.10.9%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 38,576 kB
  • sloc: ansic: 211,129; cpp: 54,855; perl: 7,788; sh: 6,988; makefile: 5,174; python: 3,840; java: 2,363; yacc: 786; lex: 416; ruby: 329; lisp: 268; xml: 55
file content (89 lines) | stat: -rw-r--r-- 2,929 bytes parent folder | download | duplicates (6)
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
/*===========================================================================
 *
 *                            PUBLIC DOMAIN NOTICE
 *               National Center for Biotechnology Information
 *
 *  This software/database is a "United States Government Work" under the
 *  terms of the United States Copyright Act.  It was written as part of
 *  the author's official duties as a United States Government employee and
 *  thus cannot be copyrighted.  This software/database is freely available
 *  to the public for use. The National Library of Medicine and the U.S.
 *  Government have not placed any restriction on its use or reproduction.
 *
 *  Although all reasonable efforts have been taken to ensure the accuracy
 *  and reliability of the software and data, the NLM and the U.S.
 *  Government do not and cannot warrant the performance or results that
 *  may be obtained by using this software or data. The NLM and the U.S.
 *  Government disclaim all warranties, express or implied, including
 *  warranties of performance, merchantability or fitness for any particular
 *  purpose.
 *
 *  Please cite the author in any work or product based on this material.
 *
 * ===========================================================================
 *
 */

#ifndef BAM_LOAD_SEQUENCE_WRITER_H_
#define BAM_LOAD_SEQUENCE_WRITER_H_ 1

#include <vdb/manager.h>
#include <vdb/database.h>
#include <vdb/table.h>
#include <vdb/cursor.h>

#include <klib/text.h>
#include <klib/data-buffer.h>

struct TableWriterSeq;

typedef struct s_sequence_record {
    char *seq;
    uint8_t *qual;
    uint32_t *readStart;
    uint32_t *readLen;
    uint8_t *orientation;
    uint8_t *is_bad;
    uint8_t *alignmentCount;
    char const *spotGroup;
    char const *linkageGroup;
    bool *aligned;
    char *cskey;
    uint64_t *ti;
    uint64_t keyId;
    unsigned spotGroupLen;
    unsigned linkageGroupLen;
    unsigned numreads;
} SequenceRecord;

typedef struct s_sequence_record_storage {
    uint64_t ti[2];
    uint32_t readStart[2];
    uint32_t readLen[2];
    uint8_t orientation[2];
    uint8_t is_bad[2];
    uint8_t alignmentCount[2];
    bool aligned[2];
    char cskey[2];
} SequenceRecordStorage;

typedef struct s_sequence {
    VDatabase *db;
    struct TableWriterSeq const *tbl;
} Sequence;

Sequence *SequenceInit(Sequence *self, VDatabase *db);

rc_t SequenceWriteRecord(Sequence *self, SequenceRecord const *rec,
                         bool color, bool isDup, INSDC_SRA_platform_id platform);

rc_t SequenceDoneWriting(Sequence *self);
rc_t SequenceReadKey(const Sequence *self, int64_t row, uint64_t *key);
rc_t SequenceUpdateAlignData(Sequence *self, int64_t row, unsigned nreads,
                             const int64_t primeId[/* nreads */],
                             const uint8_t alignCount[/* nreads */]);

void SequenceWhack(Sequence *self, bool commit);


#endif /* ndef BAM_LOAD_SEQUENCE_WRITER_H_ */