annotate ezBAMQC/src/htslib/cram/cram_decode.h @ 20:9de3bbec2479 draft default tip

Uploaded
author youngkim
date Thu, 31 Mar 2016 10:10:37 -0400 (2016-03-31)
parents dfa3745e5fd8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
1 /*
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
2 Copyright (c) 2012-2013 Genome Research Ltd.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
3 Author: James Bonfield <jkb@sanger.ac.uk>
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
4
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
5 Redistribution and use in source and binary forms, with or without
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
6 modification, are permitted provided that the following conditions are met:
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
7
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
8 1. Redistributions of source code must retain the above copyright notice,
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
9 this list of conditions and the following disclaimer.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
10
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
11 2. Redistributions in binary form must reproduce the above copyright notice,
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
12 this list of conditions and the following disclaimer in the documentation
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
13 and/or other materials provided with the distribution.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
14
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
15 3. Neither the names Genome Research Ltd and Wellcome Trust Sanger
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
16 Institute nor the names of its contributors may be used to endorse or promote
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
17 products derived from this software without specific prior written permission.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
18
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
19 THIS SOFTWARE IS PROVIDED BY GENOME RESEARCH LTD AND CONTRIBUTORS "AS IS" AND
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
20 ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
21 WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
22 DISCLAIMED. IN NO EVENT SHALL GENOME RESEARCH LTD OR CONTRIBUTORS BE LIABLE
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
23 FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
24 DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
25 SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
26 CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
27 OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
28 OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
29 */
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
30
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
31 /*! \file
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
32 * Include cram.h instead.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
33 *
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
34 * This is an internal part of the CRAM system and is automatically included
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
35 * when you #include cram.h.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
36 *
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
37 * Implements the decoding portion of CRAM I/O. Also see
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
38 * cram_codecs.[ch] for the actual encoding functions themselves.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
39 */
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
40
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
41 #ifndef _CRAM_READ_H_
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
42 #define _CRAM_READ_H_
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
43
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
44 #ifdef __cplusplus
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
45 extern "C" {
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
46 #endif
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
47
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
48 /* ----------------------------------------------------------------------
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
49 * CRAM sequence iterators.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
50 */
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
51
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
52 /*! Read the next cram record and return it as a cram_record.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
53 *
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
54 * Note that to decode cram_record the caller will need to look up some data
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
55 * in the current slice, pointed to by fd->ctr->slice. This is valid until
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
56 * the next call to cram_get_seq (which may invalidate it).
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
57 *
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
58 * @return
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
59 * Returns record pointer on success (do not free);
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
60 * NULL on failure
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
61 */
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
62 cram_record *cram_get_seq(cram_fd *fd);
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
63
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
64 /*! Read the next cram record and convert it to a bam_seq_t struct.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
65 *
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
66 * @return
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
67 * Returns 0 on success;
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
68 * -1 on EOF or failure (check fd->err)
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
69 */
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
70 int cram_get_bam_seq(cram_fd *fd, bam_seq_t **bam);
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
71
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
72
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
73 /* ----------------------------------------------------------------------
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
74 * Internal functions
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
75 */
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
76
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
77 /*! INTERNAL:
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
78 * Decodes a CRAM block compression header.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
79 *
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
80 * @return
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
81 * Returns header ptr on success;
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
82 * NULL on failure
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
83 */
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
84 cram_block_compression_hdr *cram_decode_compression_header(cram_fd *fd,
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
85 cram_block *b);
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
86
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
87 /*! INTERNAL:
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
88 * Decodes a CRAM (un)mapped slice header block.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
89 *
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
90 * @return
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
91 * Returns slice header ptr on success;
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
92 * NULL on failure
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
93 */
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
94 cram_block_slice_hdr *cram_decode_slice_header(cram_fd *fd, cram_block *b);
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
95
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
96
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
97 /*! INTERNAL:
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
98 * Decode an entire slice from container blocks. Fills out s->crecs[] array.
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
99 *
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
100 * @return
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
101 * Returns 0 on success;
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
102 * -1 on failure
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
103 */
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
104 int cram_decode_slice(cram_fd *fd, cram_container *c, cram_slice *s,
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
105 SAM_hdr *hdr);
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
106
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
107
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
108 #ifdef __cplusplus
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
109 }
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
110 #endif
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
111
dfa3745e5fd8 Uploaded
youngkim
parents:
diff changeset
112 #endif