opm-common
GTNode.hpp
1 /*
2  Copyright 2019 Equinor ASA.
3 
4  This file is part of the Open Porous Media project (OPM).
5 
6  OPM is free software: you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation, either version 3 of the License, or
9  (at your option) any later version.
10 
11  OPM is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with OPM. If not, see <http://www.gnu.org/licenses/>.
18 */
19 
20 #ifndef GROUPTREE2
21 #define GROUPTREE2
22 
23 #include <opm/input/eclipse/Schedule/Group/Group.hpp>
24 #include <opm/input/eclipse/Schedule/Well/Well.hpp>
25 
26 #include <cstddef>
27 #include <optional>
28 #include <string>
29 #include <vector>
30 
31 namespace Opm {
32 
33 class GTNode
34 {
35 public:
36  GTNode(const Group& group, std::size_t level, const std::optional<std::string>& parent_name);
37 
38  void add_group(const GTNode& child_group);
39  void add_well(const Well& well);
40 
41  const std::vector<Well>& wells() const;
42  const std::vector<GTNode>& groups() const;
43  const std::string& name() const;
44  const std::string& parent_name() const;
45 
46  const Group& group() const;
47  std::size_t level() const;
48  std::vector<const GTNode*> all_nodes() const;
49 
50 private:
51  Group m_group;
52  std::size_t m_level{};
53  std::optional<std::string> m_parent_name {std::nullopt};
54 
55  // Class T with a stl container <T> - supposedly undefined behavior
56  // before C++17 - but it compiles without warnings.
57  std::vector<GTNode> m_child_groups{};
58  std::vector<Well> m_wells{};
59 };
60 
61 } // namespace Opm
62 
63 #endif // GROUPTREE2
Definition: Group.hpp:49
Definition: Well.hpp:78
This class implements a small container which holds the transmissibility mulitpliers for all the face...
Definition: Exceptions.hpp:30
Definition: GTNode.hpp:33