libpappsomspp
Library for mass spectrometry
Loading...
Searching...
No Matches
cborstreamwriter.h
Go to the documentation of this file.
1/**
2 * \file pappsomspp/processing/cbor/cborstreamwriter.h
3 * \date 05/07/2025
4 * \author Olivier Langella
5 * \brief PAPPSO CBOR stream writer
6 */
7
8/*******************************************************************************
9 * Copyright (c) 2025 Olivier Langella <Olivier.Langella@universite-paris-saclay.fr>.
10 *
11 * This file is part of PAPPSOms-tools.
12 *
13 * PAPPSOms-tools is free software: you can redistribute it and/or modify
14 * it under the terms of the GNU General Public License as published by
15 * the Free Software Foundation, either version 3 of the License, or
16 * (at your option) any later version.
17 *
18 * PAPPSOms-tools is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU General Public License for more details.
22 *
23 * You should have received a copy of the GNU General Public License
24 * along with PAPPSOms-tools. If not, see <http://www.gnu.org/licenses/>.
25 *
26 ******************************************************************************/
27#pragma once
28
29#include <QCborStreamWriter>
30#include <QCborMap>
31
32
33namespace pappso
34{
35namespace cbor
36{
37/**
38 * @todo write docs
39 */
40class CborStreamWriter : public QCborStreamWriter
41{
42 public:
43 /**
44 * Default constructor
45 */
46 CborStreamWriter(QByteArray *data);
47 CborStreamWriter(QIODevice *device);
48
49 /**
50 * Destructor
51 */
52 virtual ~CborStreamWriter();
53
54
55 void writeInformations(const QString &software_name,
56 const QString &software_version,
57 const QString &type,
58 const QString &operation);
59
60
61 void writeCborMap(const QCborMap &cbor_map);
62 void writeCborArray(const QCborArray &cbor_array);
63 void writeArray(const std::vector<std::size_t> &int_list);
64 void writeArray(const std::vector<double> &double_list);
65 void writeArray(const std::vector<int> &positions);
66 void writeArray(QStringList &str_list);
67};
68} // namespace cbor
69} // namespace pappso
void writeInformations(const QString &software_name, const QString &software_version, const QString &type, const QString &operation)
void writeArray(const std::vector< std::size_t > &int_list)
void writeCborMap(const QCborMap &cbor_map)
void writeCborArray(const QCborArray &cbor_array)
tries to keep as much as possible monoisotopes, removing any possible C13 peaks and changes multichar...
Definition aa.cpp:39