SeqAn3 3.2.0-rc.1
The Modern C++ library for sequence analysis.
input_format_concept.hpp
Go to the documentation of this file.
1// -----------------------------------------------------------------------------------------------------
2// Copyright (c) 2006-2021, Knut Reinert & Freie Universität Berlin
3// Copyright (c) 2016-2021, 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
44 // Can't use `using format_type::read_sequence_record` as it produces a hard failure in the format concept check
45 // for types that do not model the format concept, i.e. don't offer the proper read_sequence_record interface.
47 template <typename ...ts>
48 void read_sequence_record(ts && ...args)
49 {
50 format_type::read_sequence_record(std::forward<ts>(args)...);
51 }
52};
53
54} // namespace seqan3::detail
55
56namespace seqan3
57{
58
72template <typename t>
73concept sequence_file_input_format = 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{
82 t::file_extensions;
83
84 SEQAN3_RETURN_TYPE_CONSTRAINT(v.read_sequence_record(f, options, position_buffer, seq, id, qual),
85 std::same_as, void);
86 SEQAN3_RETURN_TYPE_CONSTRAINT(v.read_sequence_record(f, options, position_buffer, seq_qual, id, seq_qual),
87 std::same_as, void);
88 SEQAN3_RETURN_TYPE_CONSTRAINT(v.read_sequence_record(f,
89 options,
90 position_buffer,
91 std::ignore,
92 std::ignore,
93 std::ignore),
94 std::same_as, void);
95};
97
138
139} // namespace seqan3
140
141namespace seqan3::detail
142{
143
149template <typename t>
150constexpr bool is_type_list_of_sequence_file_input_formats_v = false;
151
157template <typename ...ts>
158constexpr bool is_type_list_of_sequence_file_input_formats_v<type_list<ts...>> =
160
166template <typename t>
167concept type_list_of_sequence_file_input_formats = is_type_list_of_sequence_file_input_formats_v<t>;
168} // namespace seqan3::detail
Provides seqan3::dna5, container aliases and string literals.
@ 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 generic concept for sequence file in formats.
The main SeqAn3 namespace.
Definition: aligned_sequence_concept.hpp:29
Provides seqan3::phred42 quality scores.
#define SEQAN3_RETURN_TYPE_CONSTRAINT(expression, concept_name,...)
Same as writing {expression} -> concept_name<type1[, ...]> in a concept definition.
Definition: platform.hpp:77
Provides quality alphabet composites.
Provides seqan3::sequence_file_input_options.
Provides seqan3::type_list.