Antares Simulator
Power System Simulator
datafile.h
1 /*
2 ** Copyright 2007-2025, RTE (https://www.rte-france.com)
3 ** See AUTHORS.txt
4 ** SPDX-License-Identifier: MPL-2.0
5 ** This file is part of Antares-Simulator,
6 ** Adequacy and Performance assessment for interconnected energy networks.
7 **
8 ** Antares_Simulator is free software: you can redistribute it and/or modify
9 ** it under the terms of the Mozilla Public Licence 2.0 as published by
10 ** the Mozilla Foundation, either version 2 of the License, or
11 ** (at your option) any later version.
12 **
13 ** Antares_Simulator is distributed in the hope that it will be useful,
14 ** but WITHOUT ANY WARRANTY; without even the implied warranty of
15 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 ** Mozilla Public Licence 2.0 for more details.
17 **
18 ** You should have received a copy of the Mozilla Public Licence 2.0
19 ** along with Antares_Simulator. If not, see <https://opensource.org/license/mpl-2-0/>.
20 */
21 #ifndef __STUDY_DATA_FILE_AGGREGATOR_DATA_FILE_H__
22 #define __STUDY_DATA_FILE_AGGREGATOR_DATA_FILE_H__
23 
24 #include <memory>
25 #include <set>
26 
27 #include <yuni/yuni.h>
28 #include <yuni/core/string.h>
29 
30 class DataFile final
31 {
32 public:
34  using Ptr = std::shared_ptr<DataFile>;
36  using Vector = std::vector<Ptr>;
38  using ShortString = Yuni::CString<10, false>;
39 
40 public:
41  template<class StringT, class StringT2>
42  DataFile(const StringT& data, const StringT2& time, uint i):
43  index(i),
44  dataLevel(data),
45  timeLevel(time)
46  {
47  }
48 
49  template<class StringT>
50  void append(StringT& out) const
51  {
52  out << dataLevel << '-' << timeLevel << ".txt";
53  }
54 
55 public:
57  const uint index;
62 
63 }; // class DataFile
64 
65 #endif // __STUDY_DATA_FILE_AGGREGATOR_DATA_FILE_H__
Definition: datafile.h:31
Yuni::CString< 10, false > ShortString
Short string.
Definition: datafile.h:38
const ShortString timeLevel
File level (hourly, daily...)
Definition: datafile.h:61
std::vector< Ptr > Vector
Vector.
Definition: datafile.h:36
const uint index
Data target index.
Definition: datafile.h:57
const ShortString dataLevel
Data level (values, details, id...)
Definition: datafile.h:59
std::shared_ptr< DataFile > Ptr
The most suitable smart pointer.
Definition: datafile.h:34