The MAUVE Toolchain
WithAbstractShell.hpp
1 /*
2  * Copyright 2017 ONERA
3  *
4  * This file is part of the MAUVE Runtime project.
5  *
6  * MAUVE Runtime is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU Lesser General Public License version 3 as
8  * published by the Free Software Foundation.
9  *
10  * MAUVE Runtime is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  * GNU Lesser General Public License for more details.
14  *
15  * You should have received a copy of the GNU Lesser General Public License
16  * along with MAUVE. If not, see <https://www.gnu.org/licenses/lgpl-3.0>.
17  */
18 #ifndef MAUVE_RUNTIME_WITH_ABSTRACT_SHELL_HPP
19 #define MAUVE_RUNTIME_WITH_ABSTRACT_SHELL_HPP
20 
21 namespace mauve {
22  namespace runtime {
23 
24  class Shell;
25 
29  virtual Shell* get_shell () const = 0;
31  virtual bool is_empty_shell () const = 0;
33  virtual bool configure_shell () = 0;
35  virtual bool cleanup_shell () = 0;
36  };
37  }
38 }
39 
40 #endif
virtual bool is_empty_shell() const =0
Check if the shell is empty.
The MAUVE namespace.
Definition: tracing.hpp:24
virtual bool cleanup_shell()=0
Clean up the shell.
A Shell is the interface of a component.
Definition: Shell.hpp:48
virtual bool configure_shell()=0
Configure th shell.
virtual Shell * get_shell() const =0
Get a pointer to the shell.
Trait for objects with an abstract Shell.
Definition: WithAbstractShell.hpp:27