Mir
set_terminator.h
Go to the documentation of this file.
1/*
2 * Copyright © Canonical Ltd.
3 *
4 * This program is free software: you can redistribute it and/or modify it
5 * under the terms of the GNU General Public License version 2 or 3 as
6 * published by the Free Software Foundation.
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program. If not, see <http://www.gnu.org/licenses/>.
15 */
16
17#ifndef MIRAL_SET_TERMINATOR_H
18#define MIRAL_SET_TERMINATOR_H
19
20#include <functional>
21
22namespace mir { class Server; }
23
24namespace miral
25{
26/// Set handler for termination requests.
27/// terminator will be called following receipt of SIGTERM or SIGINT.
28/// The default terminator stop()s the server, replacements should probably
29/// do the same in addition to any additional shutdown logic.
31{
32public:
33 using Terminator = std::function<void(int signal)>;
34
35 explicit SetTerminator(Terminator const& terminator);
37
38 void operator()(mir::Server& server) const;
39
40private:
41 Terminator terminator;
42};
43}
44
45#endif //MIRAL_SET_TERMINATOR_H
Set handler for termination requests. terminator will be called following receipt of SIGTERM or SIGIN...
Definition: set_terminator.h:31
SetTerminator(Terminator const &terminator)
void operator()(mir::Server &server) const
Definition: runner.h:27
Mir Abstraction Layer.
Definition: runner.h:35

Copyright © 2012-2023 Canonical Ltd.
Generated on Tue 2 May 10:01:24 UTC 2023
This documentation is licensed under the GPL version 2 or 3.