ngs_server 0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (284) hide show
  1. data/.gitignore +4 -0
  2. data/Gemfile +4 -0
  3. data/Rakefile +2 -0
  4. data/bin/ngs_server +58 -0
  5. data/data/holder.txt +0 -0
  6. data/ext/bamtools/CMakeLists.txt +49 -0
  7. data/ext/bamtools/LICENSE +22 -0
  8. data/ext/bamtools/README +60 -0
  9. data/ext/bamtools/Tutorial_Toolkit_BamTools-1.0.pdf +0 -0
  10. data/ext/bamtools/docs/Doxyfile +1601 -0
  11. data/ext/bamtools/extconf.rb +9 -0
  12. data/ext/bamtools/src/CMakeFiles/CMakeDirectoryInformation.cmake +22 -0
  13. data/ext/bamtools/src/CMakeFiles/SharedHeaders.dir/DependInfo.cmake +13 -0
  14. data/ext/bamtools/src/CMakeFiles/SharedHeaders.dir/build.make +65 -0
  15. data/ext/bamtools/src/CMakeFiles/SharedHeaders.dir/cmake_clean.cmake +8 -0
  16. data/ext/bamtools/src/CMakeFiles/SharedHeaders.dir/depend.internal +3 -0
  17. data/ext/bamtools/src/CMakeFiles/SharedHeaders.dir/depend.make +3 -0
  18. data/ext/bamtools/src/CMakeFiles/SharedHeaders.dir/progress.make +2 -0
  19. data/ext/bamtools/src/CMakeFiles/progress.marks +1 -0
  20. data/ext/bamtools/src/CMakeLists.txt +18 -0
  21. data/ext/bamtools/src/ExportHeader.cmake +31 -0
  22. data/ext/bamtools/src/Makefile +182 -0
  23. data/ext/bamtools/src/api/BamAlignment.cpp +2432 -0
  24. data/ext/bamtools/src/api/BamAlignment.h +206 -0
  25. data/ext/bamtools/src/api/BamAux.h +456 -0
  26. data/ext/bamtools/src/api/BamConstants.h +127 -0
  27. data/ext/bamtools/src/api/BamIndex.h +79 -0
  28. data/ext/bamtools/src/api/BamMultiReader.cpp +395 -0
  29. data/ext/bamtools/src/api/BamMultiReader.h +126 -0
  30. data/ext/bamtools/src/api/BamReader.cpp +369 -0
  31. data/ext/bamtools/src/api/BamReader.h +117 -0
  32. data/ext/bamtools/src/api/BamWriter.cpp +142 -0
  33. data/ext/bamtools/src/api/BamWriter.h +63 -0
  34. data/ext/bamtools/src/api/CMakeFiles/APIHeaders.dir/DependInfo.cmake +14 -0
  35. data/ext/bamtools/src/api/CMakeFiles/APIHeaders.dir/build.make +80 -0
  36. data/ext/bamtools/src/api/CMakeFiles/APIHeaders.dir/cmake_clean.cmake +8 -0
  37. data/ext/bamtools/src/api/CMakeFiles/APIHeaders.dir/depend.internal +3 -0
  38. data/ext/bamtools/src/api/CMakeFiles/APIHeaders.dir/depend.make +3 -0
  39. data/ext/bamtools/src/api/CMakeFiles/APIHeaders.dir/progress.make +2 -0
  40. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/BamAlignment.cpp.o +0 -0
  41. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/BamMultiReader.cpp.o +0 -0
  42. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/BamReader.cpp.o +0 -0
  43. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/BamWriter.cpp.o +0 -0
  44. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/CXX.includecache +596 -0
  45. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/DependInfo.cmake +41 -0
  46. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/SamHeader.cpp.o +0 -0
  47. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/SamProgram.cpp.o +0 -0
  48. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/SamProgramChain.cpp.o +0 -0
  49. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/SamReadGroup.cpp.o +0 -0
  50. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/SamReadGroupDictionary.cpp.o +0 -0
  51. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/SamSequence.cpp.o +0 -0
  52. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/SamSequenceDictionary.cpp.o +0 -0
  53. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/build.make +675 -0
  54. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/cmake_clean.cmake +32 -0
  55. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/cmake_clean_target.cmake +3 -0
  56. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/depend.internal +295 -0
  57. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/depend.make +295 -0
  58. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/flags.make +8 -0
  59. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/internal/BamHeader_p.cpp.o +0 -0
  60. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/internal/BamIndexFactory_p.cpp.o +0 -0
  61. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/internal/BamMultiReader_p.cpp.o +0 -0
  62. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/internal/BamRandomAccessController_p.cpp.o +0 -0
  63. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/internal/BamReader_p.cpp.o +0 -0
  64. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/internal/BamStandardIndex_p.cpp.o +0 -0
  65. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/internal/BamToolsIndex_p.cpp.o +0 -0
  66. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/internal/BamWriter_p.cpp.o +0 -0
  67. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/internal/BgzfStream_p.cpp.o +0 -0
  68. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/internal/SamFormatParser_p.cpp.o +0 -0
  69. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/internal/SamFormatPrinter_p.cpp.o +0 -0
  70. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/internal/SamHeaderValidator_p.cpp.o +0 -0
  71. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/link.txt +2 -0
  72. data/ext/bamtools/src/api/CMakeFiles/BamTools-static.dir/progress.make +24 -0
  73. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/BamAlignment.cpp.o +0 -0
  74. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/BamMultiReader.cpp.o +0 -0
  75. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/BamReader.cpp.o +0 -0
  76. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/BamWriter.cpp.o +0 -0
  77. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/CXX.includecache +596 -0
  78. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/DependInfo.cmake +47 -0
  79. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/SamHeader.cpp.o +0 -0
  80. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/SamProgram.cpp.o +0 -0
  81. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/SamProgramChain.cpp.o +0 -0
  82. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/SamReadGroup.cpp.o +0 -0
  83. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/SamReadGroupDictionary.cpp.o +0 -0
  84. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/SamSequence.cpp.o +0 -0
  85. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/SamSequenceDictionary.cpp.o +0 -0
  86. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/build.make +677 -0
  87. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/cmake_clean.cmake +33 -0
  88. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/depend.internal +295 -0
  89. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/depend.make +295 -0
  90. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/flags.make +8 -0
  91. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/internal/BamHeader_p.cpp.o +0 -0
  92. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/internal/BamIndexFactory_p.cpp.o +0 -0
  93. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/internal/BamMultiReader_p.cpp.o +0 -0
  94. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/internal/BamRandomAccessController_p.cpp.o +0 -0
  95. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/internal/BamReader_p.cpp.o +0 -0
  96. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/internal/BamStandardIndex_p.cpp.o +0 -0
  97. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/internal/BamToolsIndex_p.cpp.o +0 -0
  98. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/internal/BamWriter_p.cpp.o +0 -0
  99. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/internal/BgzfStream_p.cpp.o +0 -0
  100. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/internal/SamFormatParser_p.cpp.o +0 -0
  101. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/internal/SamFormatPrinter_p.cpp.o +0 -0
  102. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/internal/SamHeaderValidator_p.cpp.o +0 -0
  103. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/link.txt +1 -0
  104. data/ext/bamtools/src/api/CMakeFiles/BamTools.dir/progress.make +24 -0
  105. data/ext/bamtools/src/api/CMakeFiles/CMakeDirectoryInformation.cmake +22 -0
  106. data/ext/bamtools/src/api/CMakeFiles/progress.marks +1 -0
  107. data/ext/bamtools/src/api/CMakeLists.txt +78 -0
  108. data/ext/bamtools/src/api/Makefile +902 -0
  109. data/ext/bamtools/src/api/SamConstants.h +95 -0
  110. data/ext/bamtools/src/api/SamHeader.cpp +184 -0
  111. data/ext/bamtools/src/api/SamHeader.h +68 -0
  112. data/ext/bamtools/src/api/SamProgram.cpp +139 -0
  113. data/ext/bamtools/src/api/SamProgram.h +61 -0
  114. data/ext/bamtools/src/api/SamProgramChain.cpp +351 -0
  115. data/ext/bamtools/src/api/SamProgramChain.h +85 -0
  116. data/ext/bamtools/src/api/SamReadGroup.cpp +221 -0
  117. data/ext/bamtools/src/api/SamReadGroup.h +68 -0
  118. data/ext/bamtools/src/api/SamReadGroupDictionary.cpp +289 -0
  119. data/ext/bamtools/src/api/SamReadGroupDictionary.h +86 -0
  120. data/ext/bamtools/src/api/SamSequence.cpp +161 -0
  121. data/ext/bamtools/src/api/SamSequence.h +60 -0
  122. data/ext/bamtools/src/api/SamSequenceDictionary.cpp +292 -0
  123. data/ext/bamtools/src/api/SamSequenceDictionary.h +88 -0
  124. data/ext/bamtools/src/api/api_global.h +21 -0
  125. data/ext/bamtools/src/api/cmake_install.cmake +122 -0
  126. data/ext/bamtools/src/api/internal/BamHeader_p.cpp +132 -0
  127. data/ext/bamtools/src/api/internal/BamHeader_p.h +71 -0
  128. data/ext/bamtools/src/api/internal/BamIndexFactory_p.cpp +112 -0
  129. data/ext/bamtools/src/api/internal/BamIndexFactory_p.h +49 -0
  130. data/ext/bamtools/src/api/internal/BamMultiMerger_p.h +297 -0
  131. data/ext/bamtools/src/api/internal/BamMultiReader_p.cpp +805 -0
  132. data/ext/bamtools/src/api/internal/BamMultiReader_p.h +103 -0
  133. data/ext/bamtools/src/api/internal/BamRandomAccessController_p.cpp +272 -0
  134. data/ext/bamtools/src/api/internal/BamRandomAccessController_p.h +93 -0
  135. data/ext/bamtools/src/api/internal/BamReader_p.cpp +380 -0
  136. data/ext/bamtools/src/api/internal/BamReader_p.h +112 -0
  137. data/ext/bamtools/src/api/internal/BamStandardIndex_p.cpp +986 -0
  138. data/ext/bamtools/src/api/internal/BamStandardIndex_p.h +236 -0
  139. data/ext/bamtools/src/api/internal/BamToolsIndex_p.cpp +641 -0
  140. data/ext/bamtools/src/api/internal/BamToolsIndex_p.h +187 -0
  141. data/ext/bamtools/src/api/internal/BamWriter_p.cpp +424 -0
  142. data/ext/bamtools/src/api/internal/BamWriter_p.h +66 -0
  143. data/ext/bamtools/src/api/internal/BgzfStream_p.cpp +438 -0
  144. data/ext/bamtools/src/api/internal/BgzfStream_p.h +108 -0
  145. data/ext/bamtools/src/api/internal/SamFormatParser_p.cpp +230 -0
  146. data/ext/bamtools/src/api/internal/SamFormatParser_p.h +61 -0
  147. data/ext/bamtools/src/api/internal/SamFormatPrinter_p.cpp +210 -0
  148. data/ext/bamtools/src/api/internal/SamFormatPrinter_p.h +60 -0
  149. data/ext/bamtools/src/api/internal/SamHeaderValidator_p.cpp +510 -0
  150. data/ext/bamtools/src/api/internal/SamHeaderValidator_p.h +101 -0
  151. data/ext/bamtools/src/api/internal/SamHeaderVersion_p.h +134 -0
  152. data/ext/bamtools/src/cmake_install.cmake +42 -0
  153. data/ext/bamtools/src/shared/bamtools_global.h +78 -0
  154. data/ext/bamtools/src/third_party/CMakeFiles/CMakeDirectoryInformation.cmake +22 -0
  155. data/ext/bamtools/src/third_party/CMakeFiles/progress.marks +1 -0
  156. data/ext/bamtools/src/third_party/CMakeLists.txt +10 -0
  157. data/ext/bamtools/src/third_party/Makefile +167 -0
  158. data/ext/bamtools/src/third_party/cmake_install.cmake +35 -0
  159. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/CMakeDirectoryInformation.cmake +22 -0
  160. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/jsoncpp.dir/CXX.includecache +144 -0
  161. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/jsoncpp.dir/DependInfo.cmake +27 -0
  162. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/jsoncpp.dir/build.make +157 -0
  163. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/jsoncpp.dir/cmake_clean.cmake +13 -0
  164. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/jsoncpp.dir/depend.internal +31 -0
  165. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/jsoncpp.dir/depend.make +31 -0
  166. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/jsoncpp.dir/flags.make +8 -0
  167. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/jsoncpp.dir/json_reader.cpp.o +0 -0
  168. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/jsoncpp.dir/json_value.cpp.o +0 -0
  169. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/jsoncpp.dir/json_writer.cpp.o +0 -0
  170. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/jsoncpp.dir/link.txt +1 -0
  171. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/jsoncpp.dir/progress.make +4 -0
  172. data/ext/bamtools/src/third_party/jsoncpp/CMakeFiles/progress.marks +1 -0
  173. data/ext/bamtools/src/third_party/jsoncpp/CMakeLists.txt +23 -0
  174. data/ext/bamtools/src/third_party/jsoncpp/LICENSE +55 -0
  175. data/ext/bamtools/src/third_party/jsoncpp/Makefile +263 -0
  176. data/ext/bamtools/src/third_party/jsoncpp/cmake_install.cmake +29 -0
  177. data/ext/bamtools/src/third_party/jsoncpp/json.h +15 -0
  178. data/ext/bamtools/src/third_party/jsoncpp/json_batchallocator.h +130 -0
  179. data/ext/bamtools/src/third_party/jsoncpp/json_config.h +42 -0
  180. data/ext/bamtools/src/third_party/jsoncpp/json_features.h +47 -0
  181. data/ext/bamtools/src/third_party/jsoncpp/json_forwards.h +42 -0
  182. data/ext/bamtools/src/third_party/jsoncpp/json_internalarray.inl +453 -0
  183. data/ext/bamtools/src/third_party/jsoncpp/json_internalmap.inl +612 -0
  184. data/ext/bamtools/src/third_party/jsoncpp/json_reader.cpp +870 -0
  185. data/ext/bamtools/src/third_party/jsoncpp/json_reader.h +201 -0
  186. data/ext/bamtools/src/third_party/jsoncpp/json_tool.h +93 -0
  187. data/ext/bamtools/src/third_party/jsoncpp/json_value.cpp +1701 -0
  188. data/ext/bamtools/src/third_party/jsoncpp/json_value.h +1059 -0
  189. data/ext/bamtools/src/third_party/jsoncpp/json_valueiterator.inl +297 -0
  190. data/ext/bamtools/src/third_party/jsoncpp/json_writer.cpp +819 -0
  191. data/ext/bamtools/src/third_party/jsoncpp/json_writer.h +179 -0
  192. data/ext/bamtools/src/toolkit/CMakeFiles/CMakeDirectoryInformation.cmake +25 -0
  193. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/CXX.includecache +698 -0
  194. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/DependInfo.cmake +34 -0
  195. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools.cpp.o +0 -0
  196. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_convert.cpp.o +0 -0
  197. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_count.cpp.o +0 -0
  198. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_coverage.cpp.o +0 -0
  199. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_filter.cpp.o +0 -0
  200. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_header.cpp.o +0 -0
  201. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_index.cpp.o +0 -0
  202. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_merge.cpp.o +0 -0
  203. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_random.cpp.o +0 -0
  204. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_resolve.cpp.o +0 -0
  205. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_revert.cpp.o +0 -0
  206. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_sort.cpp.o +0 -0
  207. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_split.cpp.o +0 -0
  208. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/bamtools_stats.cpp.o +0 -0
  209. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/build.make +447 -0
  210. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/cmake_clean.cmake +24 -0
  211. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/depend.internal +319 -0
  212. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/depend.make +319 -0
  213. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/flags.make +8 -0
  214. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/link.txt +1 -0
  215. data/ext/bamtools/src/toolkit/CMakeFiles/bamtools_cmd.dir/progress.make +15 -0
  216. data/ext/bamtools/src/toolkit/CMakeFiles/progress.marks +1 -0
  217. data/ext/bamtools/src/toolkit/CMakeLists.txt +44 -0
  218. data/ext/bamtools/src/toolkit/Makefile +560 -0
  219. data/ext/bamtools/src/toolkit/bamtools.cpp +163 -0
  220. data/ext/bamtools/src/toolkit/bamtools_convert.cpp +888 -0
  221. data/ext/bamtools/src/toolkit/bamtools_convert.h +37 -0
  222. data/ext/bamtools/src/toolkit/bamtools_count.cpp +187 -0
  223. data/ext/bamtools/src/toolkit/bamtools_count.h +37 -0
  224. data/ext/bamtools/src/toolkit/bamtools_coverage.cpp +196 -0
  225. data/ext/bamtools/src/toolkit/bamtools_coverage.h +37 -0
  226. data/ext/bamtools/src/toolkit/bamtools_filter.cpp +911 -0
  227. data/ext/bamtools/src/toolkit/bamtools_filter.h +37 -0
  228. data/ext/bamtools/src/toolkit/bamtools_header.cpp +122 -0
  229. data/ext/bamtools/src/toolkit/bamtools_header.h +38 -0
  230. data/ext/bamtools/src/toolkit/bamtools_index.cpp +126 -0
  231. data/ext/bamtools/src/toolkit/bamtools_index.h +37 -0
  232. data/ext/bamtools/src/toolkit/bamtools_merge.cpp +221 -0
  233. data/ext/bamtools/src/toolkit/bamtools_merge.h +37 -0
  234. data/ext/bamtools/src/toolkit/bamtools_random.cpp +255 -0
  235. data/ext/bamtools/src/toolkit/bamtools_random.h +37 -0
  236. data/ext/bamtools/src/toolkit/bamtools_resolve.cpp +1396 -0
  237. data/ext/bamtools/src/toolkit/bamtools_resolve.h +42 -0
  238. data/ext/bamtools/src/toolkit/bamtools_revert.cpp +194 -0
  239. data/ext/bamtools/src/toolkit/bamtools_revert.h +37 -0
  240. data/ext/bamtools/src/toolkit/bamtools_sort.cpp +410 -0
  241. data/ext/bamtools/src/toolkit/bamtools_sort.h +37 -0
  242. data/ext/bamtools/src/toolkit/bamtools_split.cpp +551 -0
  243. data/ext/bamtools/src/toolkit/bamtools_split.h +38 -0
  244. data/ext/bamtools/src/toolkit/bamtools_stats.cpp +286 -0
  245. data/ext/bamtools/src/toolkit/bamtools_stats.h +37 -0
  246. data/ext/bamtools/src/toolkit/bamtools_tool.h +35 -0
  247. data/ext/bamtools/src/toolkit/bamtools_version.h +20 -0
  248. data/ext/bamtools/src/toolkit/bamtools_version.h.in +20 -0
  249. data/ext/bamtools/src/toolkit/cmake_install.cmake +52 -0
  250. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/CXX.includecache +250 -0
  251. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/DependInfo.cmake +29 -0
  252. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/bamtools_fasta.cpp.o +0 -0
  253. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/bamtools_options.cpp.o +0 -0
  254. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/bamtools_pileup_engine.cpp.o +0 -0
  255. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/bamtools_utilities.cpp.o +0 -0
  256. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/build.make +184 -0
  257. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/cmake_clean.cmake +14 -0
  258. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/depend.internal +40 -0
  259. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/depend.make +40 -0
  260. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/flags.make +8 -0
  261. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/link.txt +1 -0
  262. data/ext/bamtools/src/utils/CMakeFiles/BamTools-utils.dir/progress.make +5 -0
  263. data/ext/bamtools/src/utils/CMakeFiles/CMakeDirectoryInformation.cmake +23 -0
  264. data/ext/bamtools/src/utils/CMakeFiles/progress.marks +1 -0
  265. data/ext/bamtools/src/utils/CMakeLists.txt +30 -0
  266. data/ext/bamtools/src/utils/Makefile +290 -0
  267. data/ext/bamtools/src/utils/bamtools_fasta.cpp +632 -0
  268. data/ext/bamtools/src/utils/bamtools_fasta.h +47 -0
  269. data/ext/bamtools/src/utils/bamtools_filter_engine.h +552 -0
  270. data/ext/bamtools/src/utils/bamtools_filter_properties.h +195 -0
  271. data/ext/bamtools/src/utils/bamtools_filter_ruleparser.h +319 -0
  272. data/ext/bamtools/src/utils/bamtools_options.cpp +287 -0
  273. data/ext/bamtools/src/utils/bamtools_options.h +213 -0
  274. data/ext/bamtools/src/utils/bamtools_pileup_engine.cpp +327 -0
  275. data/ext/bamtools/src/utils/bamtools_pileup_engine.h +94 -0
  276. data/ext/bamtools/src/utils/bamtools_utilities.cpp +333 -0
  277. data/ext/bamtools/src/utils/bamtools_utilities.h +67 -0
  278. data/ext/bamtools/src/utils/bamtools_variant.h +128 -0
  279. data/ext/bamtools/src/utils/cmake_install.cmake +29 -0
  280. data/ext/bamtools/src/utils/utils_global.h +21 -0
  281. data/lib/ngs_server/version.rb +3 -0
  282. data/lib/ngs_server.rb +3 -0
  283. data/ngs_server.gemspec +23 -0
  284. metadata +339 -0
@@ -0,0 +1,438 @@
1
+ // ***************************************************************************
2
+ // BgzfStream_p.cpp (c) 2011 Derek Barnett
3
+ // Marth Lab, Department of Biology, Boston College
4
+ // ---------------------------------------------------------------------------
5
+ // Last modified: 2 September 2011(DB)
6
+ // ---------------------------------------------------------------------------
7
+ // Based on BGZF routines developed at the Broad Institute.
8
+ // Provides the basic functionality for reading & writing BGZF files
9
+ // Replaces the old BGZF.* files to avoid clashing with other toolkits
10
+ // ***************************************************************************
11
+
12
+ #include <api/internal/BgzfStream_p.h>
13
+ using namespace BamTools;
14
+ using namespace BamTools::Internal;
15
+
16
+ #include <cstring>
17
+ #include <algorithm>
18
+ using namespace std;
19
+
20
+ // constructor
21
+ BgzfStream::BgzfStream(void)
22
+ : UncompressedBlockSize(Constants::BGZF_DEFAULT_BLOCK_SIZE)
23
+ , CompressedBlockSize(Constants::BGZF_MAX_BLOCK_SIZE)
24
+ , BlockLength(0)
25
+ , BlockOffset(0)
26
+ , BlockAddress(0)
27
+ , IsOpen(false)
28
+ , IsWriteOnly(false)
29
+ , IsWriteCompressed(true)
30
+ , Stream(NULL)
31
+ , UncompressedBlock(NULL)
32
+ , CompressedBlock(NULL)
33
+ {
34
+ try {
35
+ CompressedBlock = new char[CompressedBlockSize];
36
+ UncompressedBlock = new char[UncompressedBlockSize];
37
+ } catch( std::bad_alloc& ba ) {
38
+ fprintf(stderr, "BgzfStream ERROR: unable to allocate memory\n");
39
+ exit(1);
40
+ }
41
+ }
42
+
43
+ // destructor
44
+ BgzfStream::~BgzfStream(void) {
45
+ if( CompressedBlock ) delete[] CompressedBlock;
46
+ if( UncompressedBlock ) delete[] UncompressedBlock;
47
+ }
48
+
49
+ // closes BGZF file
50
+ void BgzfStream::Close(void) {
51
+
52
+ // skip if file not open
53
+ if ( !IsOpen ) return;
54
+
55
+ // if writing to file, flush the current BGZF block,
56
+ // then write an empty block (as EOF marker)
57
+ if ( IsWriteOnly ) {
58
+ FlushBlock();
59
+ int blockLength = DeflateBlock();
60
+ fwrite(CompressedBlock, 1, blockLength, Stream);
61
+ }
62
+
63
+ // flush and close stream
64
+ fflush(Stream);
65
+ fclose(Stream);
66
+
67
+ // reset flags
68
+ IsWriteCompressed = true;
69
+ IsOpen = false;
70
+ }
71
+
72
+ // compresses the current block
73
+ int BgzfStream::DeflateBlock(void) {
74
+
75
+ // initialize the gzip header
76
+ char* buffer = CompressedBlock;
77
+ memset(buffer, 0, 18);
78
+ buffer[0] = Constants::GZIP_ID1;
79
+ buffer[1] = (char)Constants::GZIP_ID2;
80
+ buffer[2] = Constants::CM_DEFLATE;
81
+ buffer[3] = Constants::FLG_FEXTRA;
82
+ buffer[9] = (char)Constants::OS_UNKNOWN;
83
+ buffer[10] = Constants::BGZF_XLEN;
84
+ buffer[12] = Constants::BGZF_ID1;
85
+ buffer[13] = Constants::BGZF_ID2;
86
+ buffer[14] = Constants::BGZF_LEN;
87
+
88
+ // set compression level
89
+ const int compressionLevel = ( IsWriteCompressed ? Z_DEFAULT_COMPRESSION : 0 );
90
+
91
+ // loop to retry for blocks that do not compress enough
92
+ int inputLength = BlockOffset;
93
+ int compressedLength = 0;
94
+ unsigned int bufferSize = CompressedBlockSize;
95
+
96
+ while ( true ) {
97
+
98
+ // initialize zstream values
99
+ z_stream zs;
100
+ zs.zalloc = NULL;
101
+ zs.zfree = NULL;
102
+ zs.next_in = (Bytef*)UncompressedBlock;
103
+ zs.avail_in = inputLength;
104
+ zs.next_out = (Bytef*)&buffer[Constants::BGZF_BLOCK_HEADER_LENGTH];
105
+ zs.avail_out = bufferSize - Constants::BGZF_BLOCK_HEADER_LENGTH - Constants::BGZF_BLOCK_FOOTER_LENGTH;
106
+
107
+ // initialize the zlib compression algorithm
108
+ if ( deflateInit2(&zs,
109
+ compressionLevel,
110
+ Z_DEFLATED,
111
+ Constants::GZIP_WINDOW_BITS,
112
+ Constants::Z_DEFAULT_MEM_LEVEL,
113
+ Z_DEFAULT_STRATEGY) != Z_OK )
114
+ {
115
+ fprintf(stderr, "BgzfStream ERROR: zlib deflate initialization failed\n");
116
+ exit(1);
117
+ }
118
+
119
+ // compress the data
120
+ int status = deflate(&zs, Z_FINISH);
121
+ if ( status != Z_STREAM_END ) {
122
+
123
+ deflateEnd(&zs);
124
+
125
+ // reduce the input length and try again
126
+ if ( status == Z_OK ) {
127
+ inputLength -= 1024;
128
+ if ( inputLength < 0 ) {
129
+ fprintf(stderr, "BgzfStream ERROR: input reduction failed\n");
130
+ exit(1);
131
+ }
132
+ continue;
133
+ }
134
+
135
+ fprintf(stderr, "BgzfStream ERROR: zlib::deflateEnd() failed\n");
136
+ exit(1);
137
+ }
138
+
139
+ // finalize the compression routine
140
+ if ( deflateEnd(&zs) != Z_OK ) {
141
+ fprintf(stderr, "BgzfStream ERROR: zlib::deflateEnd() failed\n");
142
+ exit(1);
143
+ }
144
+
145
+ compressedLength = zs.total_out;
146
+ compressedLength += Constants::BGZF_BLOCK_HEADER_LENGTH + Constants::BGZF_BLOCK_FOOTER_LENGTH;
147
+ if ( compressedLength > Constants::BGZF_MAX_BLOCK_SIZE ) {
148
+ fprintf(stderr, "BgzfStream ERROR: deflate overflow\n");
149
+ exit(1);
150
+ }
151
+
152
+ break;
153
+ }
154
+
155
+ // store the compressed length
156
+ BamTools::PackUnsignedShort(&buffer[16], (unsigned short)(compressedLength - 1));
157
+
158
+ // store the CRC32 checksum
159
+ unsigned int crc = crc32(0, NULL, 0);
160
+ crc = crc32(crc, (Bytef*)UncompressedBlock, inputLength);
161
+ BamTools::PackUnsignedInt(&buffer[compressedLength - 8], crc);
162
+ BamTools::PackUnsignedInt(&buffer[compressedLength - 4], inputLength);
163
+
164
+ // ensure that we have less than a block of data left
165
+ int remaining = BlockOffset - inputLength;
166
+ if ( remaining > 0 ) {
167
+ if ( remaining > inputLength ) {
168
+ fprintf(stderr, "BgzfStream ERROR: after deflate, remainder too large\n");
169
+ exit(1);
170
+ }
171
+ memcpy(UncompressedBlock, UncompressedBlock + inputLength, remaining);
172
+ }
173
+
174
+ // update block data
175
+ BlockOffset = remaining;
176
+
177
+ // return result
178
+ return compressedLength;
179
+ }
180
+
181
+ // flushes the data in the BGZF block
182
+ void BgzfStream::FlushBlock(void) {
183
+
184
+ // flush all of the remaining blocks
185
+ while ( BlockOffset > 0 ) {
186
+
187
+ // compress the data block
188
+ int blockLength = DeflateBlock();
189
+
190
+ // flush the data to our output stream
191
+ int numBytesWritten = fwrite(CompressedBlock, 1, blockLength, Stream);
192
+ if ( numBytesWritten != blockLength ) {
193
+ fprintf(stderr, "BgzfStream ERROR: expected to write %u bytes during flushing, but wrote %u bytes\n",
194
+ blockLength, numBytesWritten);
195
+ exit(1);
196
+ }
197
+
198
+ // update block data
199
+ BlockAddress += blockLength;
200
+ }
201
+ }
202
+
203
+ // decompresses the current block
204
+ int BgzfStream::InflateBlock(const int& blockLength) {
205
+
206
+ // inflate the data from compressed buffer into uncompressed buffer
207
+ z_stream zs;
208
+ zs.zalloc = NULL;
209
+ zs.zfree = NULL;
210
+ zs.next_in = (Bytef*)CompressedBlock + 18;
211
+ zs.avail_in = blockLength - 16;
212
+ zs.next_out = (Bytef*)UncompressedBlock;
213
+ zs.avail_out = UncompressedBlockSize;
214
+
215
+ int status = inflateInit2(&zs, Constants::GZIP_WINDOW_BITS);
216
+ if ( status != Z_OK ) {
217
+ fprintf(stderr, "BgzfStream ERROR: could not decompress block - zlib::inflateInit() failed\n");
218
+ return -1;
219
+ }
220
+
221
+ status = inflate(&zs, Z_FINISH);
222
+ if ( status != Z_STREAM_END ) {
223
+ inflateEnd(&zs);
224
+ fprintf(stderr, "BgzfStream ERROR: could not decompress block - zlib::inflate() failed\n");
225
+ return -1;
226
+ }
227
+
228
+ status = inflateEnd(&zs);
229
+ if ( status != Z_OK ) {
230
+ fprintf(stderr, "BgzfStream ERROR: could not decompress block - zlib::inflateEnd() failed\n");
231
+ return -1;
232
+ }
233
+
234
+ // return result
235
+ return zs.total_out;
236
+ }
237
+
238
+ // opens the BGZF file for reading (mode is either "rb" for reading, or "wb" for writing)
239
+ bool BgzfStream::Open(const string& filename, const char* mode) {
240
+
241
+ // close current stream, if necessary, before opening next
242
+ if ( IsOpen ) Close();
243
+
244
+ // determine open mode
245
+ if ( strcmp(mode, "rb") == 0 )
246
+ IsWriteOnly = false;
247
+ else if ( strcmp(mode, "wb") == 0)
248
+ IsWriteOnly = true;
249
+ else {
250
+ fprintf(stderr, "BgzfStream ERROR: unknown file mode: %s\n", mode);
251
+ return false;
252
+ }
253
+
254
+ // open BGZF stream on a file
255
+ if ( (filename != "stdin") && (filename != "stdout") && (filename != "-"))
256
+ Stream = fopen(filename.c_str(), mode);
257
+
258
+ // open BGZF stream on stdin
259
+ else if ( (filename == "stdin" || filename == "-") && (strcmp(mode, "rb") == 0 ) )
260
+ Stream = freopen(NULL, mode, stdin);
261
+
262
+ // open BGZF stream on stdout
263
+ else if ( (filename == "stdout" || filename == "-") && (strcmp(mode, "wb") == 0) )
264
+ Stream = freopen(NULL, mode, stdout);
265
+
266
+ if ( !Stream ) {
267
+ fprintf(stderr, "BgzfStream ERROR: unable to open file %s\n", filename.c_str() );
268
+ return false;
269
+ }
270
+
271
+ // set flag & return success
272
+ IsOpen = true;
273
+ return true;
274
+ }
275
+
276
+ // reads BGZF data into a byte buffer
277
+ int BgzfStream::Read(char* data, const unsigned int dataLength) {
278
+
279
+ // if stream not open for reading (or empty request)
280
+ if ( !IsOpen || IsWriteOnly || dataLength == 0 )
281
+ return 0;
282
+
283
+ // read blocks as needed until desired data length is retrieved
284
+ char* output = data;
285
+ unsigned int numBytesRead = 0;
286
+ while ( numBytesRead < dataLength ) {
287
+
288
+ // determine bytes available in current block
289
+ int bytesAvailable = BlockLength - BlockOffset;
290
+
291
+ // read (and decompress) next block if needed
292
+ if ( bytesAvailable <= 0 ) {
293
+ if ( !ReadBlock() ) return -1;
294
+ bytesAvailable = BlockLength - BlockOffset;
295
+ if ( bytesAvailable <= 0 ) break;
296
+ }
297
+
298
+ // copy data from uncompressed source buffer into data destination buffer
299
+ char* buffer = UncompressedBlock;
300
+ int copyLength = min( (int)(dataLength-numBytesRead), bytesAvailable );
301
+ memcpy(output, buffer + BlockOffset, copyLength);
302
+
303
+ // update counters
304
+ BlockOffset += copyLength;
305
+ output += copyLength;
306
+ numBytesRead += copyLength;
307
+ }
308
+
309
+ // update block data
310
+ if ( BlockOffset == BlockLength ) {
311
+ BlockAddress = ftell64(Stream);
312
+ BlockOffset = 0;
313
+ BlockLength = 0;
314
+ }
315
+
316
+ return numBytesRead;
317
+ }
318
+
319
+ // reads a BGZF block
320
+ bool BgzfStream::ReadBlock(void) {
321
+
322
+ char header[Constants::BGZF_BLOCK_HEADER_LENGTH];
323
+ int64_t blockAddress = ftell64(Stream);
324
+
325
+ // read block header from file
326
+ int count = fread(header, 1, sizeof(header), Stream);
327
+
328
+ // if block header empty
329
+ if ( count == 0 ) {
330
+ BlockLength = 0;
331
+ return true;
332
+ }
333
+
334
+ // if block header invalid size
335
+ if ( count != sizeof(header) ) {
336
+ fprintf(stderr, "BgzfStream ERROR: read block failed - could not read block header\n");
337
+ return false;
338
+ }
339
+
340
+ // validate block header contents
341
+ if ( !BgzfStream::CheckBlockHeader(header) ) {
342
+ fprintf(stderr, "BgzfStream ERROR: read block failed - invalid block header\n");
343
+ return false;
344
+ }
345
+
346
+ // copy header contents to compressed buffer
347
+ int blockLength = BamTools::UnpackUnsignedShort(&header[16]) + 1;
348
+ char* compressedBlock = CompressedBlock;
349
+ memcpy(compressedBlock, header, Constants::BGZF_BLOCK_HEADER_LENGTH);
350
+ int remaining = blockLength - Constants::BGZF_BLOCK_HEADER_LENGTH;
351
+
352
+ // read remainder of block
353
+ count = fread(&compressedBlock[Constants::BGZF_BLOCK_HEADER_LENGTH], 1, remaining, Stream);
354
+ if ( count != remaining ) {
355
+ fprintf(stderr, "BgzfStream ERROR: read block failed - could not read data from block\n");
356
+ return false;
357
+ }
358
+
359
+ // decompress block data
360
+ count = InflateBlock(blockLength);
361
+ if ( count < 0 ) {
362
+ fprintf(stderr, "BgzfStream ERROR: read block failed - could not decompress block data\n");
363
+ return false;
364
+ }
365
+
366
+ // update block data
367
+ if ( BlockLength != 0 )
368
+ BlockOffset = 0;
369
+ BlockAddress = blockAddress;
370
+ BlockLength = count;
371
+
372
+ // return success
373
+ return true;
374
+ }
375
+
376
+ // seek to position in BGZF file
377
+ bool BgzfStream::Seek(const int64_t& position) {
378
+
379
+ // skip if not open
380
+ if ( !IsOpen ) return false;
381
+
382
+ // determine adjusted offset & address
383
+ int blockOffset = (position & 0xFFFF);
384
+ int64_t blockAddress = (position >> 16) & 0xFFFFFFFFFFFFLL;
385
+
386
+ // attempt seek in file
387
+ if ( fseek64(Stream, blockAddress, SEEK_SET) != 0 ) {
388
+ fprintf(stderr, "BgzfStream ERROR: unable to seek in file\n");
389
+ return false;
390
+ }
391
+
392
+ // update block data & return success
393
+ BlockLength = 0;
394
+ BlockAddress = blockAddress;
395
+ BlockOffset = blockOffset;
396
+ return true;
397
+ }
398
+
399
+ void BgzfStream::SetWriteCompressed(bool ok) {
400
+ IsWriteCompressed = ok;
401
+ }
402
+
403
+ // get file position in BGZF file
404
+ int64_t BgzfStream::Tell(void) const {
405
+ if ( !IsOpen )
406
+ return 0;
407
+ return ( (BlockAddress << 16) | (BlockOffset & 0xFFFF) );
408
+ }
409
+
410
+ // writes the supplied data into the BGZF buffer
411
+ unsigned int BgzfStream::Write(const char* data, const unsigned int dataLen) {
412
+
413
+ // skip if file not open for writing
414
+ if ( !IsOpen || !IsWriteOnly ) return false;
415
+
416
+ // write blocks as needed til all data is written
417
+ unsigned int numBytesWritten = 0;
418
+ const char* input = data;
419
+ unsigned int blockLength = UncompressedBlockSize;
420
+ while ( numBytesWritten < dataLen ) {
421
+
422
+ // copy data contents to uncompressed output buffer
423
+ unsigned int copyLength = min(blockLength - BlockOffset, dataLen - numBytesWritten);
424
+ char* buffer = UncompressedBlock;
425
+ memcpy(buffer + BlockOffset, input, copyLength);
426
+
427
+ // update counter
428
+ BlockOffset += copyLength;
429
+ input += copyLength;
430
+ numBytesWritten += copyLength;
431
+
432
+ // flush (& compress) output buffer when full
433
+ if ( BlockOffset == blockLength ) FlushBlock();
434
+ }
435
+
436
+ // return result
437
+ return numBytesWritten;
438
+ }
@@ -0,0 +1,108 @@
1
+ // ***************************************************************************
2
+ // BgzfStream_p.h (c) 2011 Derek Barnett
3
+ // Marth Lab, Department of Biology, Boston College
4
+ // ---------------------------------------------------------------------------
5
+ // Last modified: 5 April 2011(DB)
6
+ // ---------------------------------------------------------------------------
7
+ // Based on BGZF routines developed at the Broad Institute.
8
+ // Provides the basic functionality for reading & writing BGZF files
9
+ // Replaces the old BGZF.* files to avoid clashing with other toolkits
10
+ // ***************************************************************************
11
+
12
+ #ifndef BGZFSTREAM_P_H
13
+ #define BGZFSTREAM_P_H
14
+
15
+ // -------------
16
+ // W A R N I N G
17
+ // -------------
18
+ //
19
+ // This file is not part of the BamTools API. It exists purely as an
20
+ // implementation detail. This header file may change from version to version
21
+ // without notice, or even be removed.
22
+ //
23
+ // We mean it.
24
+
25
+ #include <api/BamAux.h>
26
+ #include <api/BamConstants.h>
27
+ #include "zlib.h"
28
+ #include <cstdio>
29
+ #include <string>
30
+
31
+ namespace BamTools {
32
+ namespace Internal {
33
+
34
+ class BgzfStream {
35
+
36
+ // constructor & destructor
37
+ public:
38
+ BgzfStream(void);
39
+ ~BgzfStream(void);
40
+
41
+ // main interface methods
42
+ public:
43
+ // closes BGZF file
44
+ void Close(void);
45
+ // opens the BGZF file (mode is either "rb" for reading, or "wb" for writing)
46
+ bool Open(const std::string& filename, const char* mode);
47
+ // reads BGZF data into a byte buffer
48
+ int Read(char* data, const unsigned int dataLength);
49
+ // seek to position in BGZF file
50
+ bool Seek(const int64_t& position);
51
+ // enable/disable compressed output
52
+ void SetWriteCompressed(bool ok);
53
+ // get file position in BGZF file
54
+ int64_t Tell(void) const;
55
+ // writes the supplied data into the BGZF buffer
56
+ unsigned int Write(const char* data, const unsigned int dataLen);
57
+
58
+ // internal methods
59
+ private:
60
+ // compresses the current block
61
+ int DeflateBlock(void);
62
+ // flushes the data in the BGZF block
63
+ void FlushBlock(void);
64
+ // de-compresses the current block
65
+ int InflateBlock(const int& blockLength);
66
+ // reads a BGZF block
67
+ bool ReadBlock(void);
68
+
69
+ // static 'utility' methods
70
+ public:
71
+ // checks BGZF block header
72
+ static inline bool CheckBlockHeader(char* header);
73
+
74
+ // data members
75
+ public:
76
+ unsigned int UncompressedBlockSize;
77
+ unsigned int CompressedBlockSize;
78
+ unsigned int BlockLength;
79
+ unsigned int BlockOffset;
80
+ uint64_t BlockAddress;
81
+ bool IsOpen;
82
+ bool IsWriteOnly;
83
+ bool IsWriteCompressed;
84
+ FILE* Stream;
85
+ char* UncompressedBlock;
86
+ char* CompressedBlock;
87
+ };
88
+
89
+ // -------------------------------------------------------------
90
+ // static 'utility' method implementations
91
+
92
+ // checks BGZF block header
93
+ inline
94
+ bool BgzfStream::CheckBlockHeader(char* header) {
95
+ return (header[0] == Constants::GZIP_ID1 &&
96
+ header[1] == (char)Constants::GZIP_ID2 &&
97
+ header[2] == Z_DEFLATED &&
98
+ (header[3] & Constants::FLG_FEXTRA) != 0 &&
99
+ BamTools::UnpackUnsignedShort(&header[10]) == Constants::BGZF_XLEN &&
100
+ header[12] == Constants::BGZF_ID1 &&
101
+ header[13] == Constants::BGZF_ID2 &&
102
+ BamTools::UnpackUnsignedShort(&header[14]) == Constants::BGZF_LEN );
103
+ }
104
+
105
+ } // namespace Internal
106
+ } // namespace BamTools
107
+
108
+ #endif // BGZFSTREAM_P_H