SeqAn3 3.3.0-rc.1
The Modern C++ library for sequence analysis.
 
Loading...
Searching...
No Matches
sequence_file/input_format_concept.hpp
Go to the documentation of this file.
1// -----------------------------------------------------------------------------------------------------
2// Copyright (c) 2006-2022, Knut Reinert & Freie Universität Berlin
3// Copyright (c) 2016-2022, Knut Reinert & MPI für molekulare Genetik
4// This file may be used, modified and/or redistributed under the terms of the 3-clause BSD-License
5// shipped with this file and also available at: https://github.com/seqan/seqan3/blob/master/LICENSE.md
6// -----------------------------------------------------------------------------------------------------
7
14#pragma once
15
16#include <fstream>
17#include <string>
18#include <vector>
19
25
26namespace seqan3::detail
27{
28
39template <typename format_type>
40struct sequence_file_input_format_exposer : public format_type
41{
42public:
43 // Can't use `using format_type::read_sequence_record` as it produces a hard failure in the format concept check
44 // for types that do not model the format concept, i.e. don't offer the proper read_sequence_record interface.
46 template <typename... ts>
47 void read_sequence_record(ts &&... args)
48 {
49 format_type::read_sequence_record(std::forward<ts>(args)...);
50 }
51};
52
53} // namespace seqan3::detail
54
55namespace seqan3
56{
57
71template <typename t>
72concept sequence_file_input_format =
73 requires (detail::sequence_file_input_format_exposer<t> & v,
74 std::ifstream & f,
75 sequence_file_input_options<dna5> & options,
76 std::streampos & position_buffer,
81 t::file_extensions;
82
83 {
84 v.read_sequence_record(f, options, position_buffer, seq, id, qual)
85 } -> std::same_as<void>;
86 {
87 v.read_sequence_record(f, options, position_buffer, seq_qual, id, seq_qual)
88 } -> std::same_as<void>;
89 {
90 v.read_sequence_record(f, options, position_buffer, std::ignore, std::ignore, std::ignore)
91 } -> std::same_as<void>;
92 };
94
95// Workaround for https://github.com/doxygen/doxygen/issues/9379
96#if SEQAN3_DOXYGEN_ONLY(1) 0
97template <typename t>
99{};
100#endif
101
142
143} // namespace seqan3
144
145namespace seqan3::detail
146{
147
153template <typename t>
155
161template <typename... ts>
164
170template <typename t>
171concept type_list_of_sequence_file_input_formats = is_type_list_of_sequence_file_input_formats_v<t>;
172} // namespace seqan3::detail
The generic concept for sequence file in formats.
Definition: sequence_file/input_format_concept.hpp:99
Auxiliary concept that checks whether a type is a seqan3::type_list and all types meet seqan3::sequen...
Definition: sequence_file/input_format_concept.hpp:171
Provides seqan3::dna5, container aliases and string literals.
constexpr bool is_type_list_of_sequence_file_input_formats_v
Auxiliary value metafuncton that checks whether a type is a seqan3::type_list and all types meet seqa...
Definition: sequence_file/input_format_concept.hpp:154
@ id
The identifier, usually a string.
@ seq
The "sequence", usually a range of nucleotides or amino acids.
@ qual
The qualities, usually in Phred score notation.
The internal SeqAn3 namespace.
Definition: aligned_sequence_concept.hpp:29
The main SeqAn3 namespace.
Definition: aligned_sequence_concept.hpp:29
Provides seqan3::phred42 quality scores.
Provides quality alphabet composites.
Provides seqan3::sequence_file_input_options.
Internal class used to expose the actual format interface to read sequence records from the file.
Definition: sequence_file/input_format_concept.hpp:41
void read_sequence_record(ts &&... args)
Forwards to the seqan3::sequence_file_input_format::read_sequence_record interface.
Definition: sequence_file/input_format_concept.hpp:47
Type that contains multiple types.
Definition: type_list.hpp:29
Provides seqan3::type_list.