Mir
display_configuration.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 3,
6 * as 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_DISPLAY_CONFIGURATION_H
18#define MIRAL_DISPLAY_CONFIGURATION_H
19
20#include <memory>
21#include <string>
22#include <vector>
23
24namespace mir { class Server; }
25
26namespace miral
27{
28class MirRunner;
30
31/// Enable display configuration.
32/// The config file (miral::MirRunner::display_config_file()) is located via
33/// the XDG Base Directory Specification. Vis:
34///($XDG_CONFIG_HOME or $HOME/.config followed by $XDG_CONFIG_DIRS)
35/// \remark Since MirAL 2.4
36/// \note From MirAL 3.8 will monitor the configuration file or, if none found,
37/// for the creation of a file in $XDG_CONFIG_HOME or $HOME/.config. Changes
38/// to this file will be reloaded. In addition, the selected layout may be
39/// overridden using a corresponding file: display_config_file() + "-layout"
40/// which will also be monitored and changes reloaded
42{
43public:
44 explicit DisplayConfiguration(MirRunner const& mir_runner);
45
46 /// Provide the default 'display-layout' configuration option
48
49 /// Select a layout from the configuration
50 void select_layout(std::string const& layout);
51
52 /// List all layouts found in the config file
53 auto list_layouts() -> std::vector<std::string>;
54
55 /// Enable a custom output attribute in the .display YAML
56 /// \remark Since MirAL 3.8
57 void add_output_attribute(std::string const& key);
58
59 void operator()(mir::Server& server) const;
60
64
65private:
66 struct Self;
67 std::shared_ptr<Self> self;
68};
69}
70
71#endif //MIRAL_DISPLAY_CONFIGURATION_H
Add a user configuration option to Mir's option handling. By default the callback will be invoked fol...
Definition: configuration_option.h:40
Enable display configuration. The config file (miral::MirRunner::display_config_file()) is located vi...
Definition: display_configuration.h:42
void add_output_attribute(std::string const &key)
Enable a custom output attribute in the .display YAML.
auto layout_option() -> ConfigurationOption
Provide the default 'display-layout' configuration option.
DisplayConfiguration(MirRunner const &mir_runner)
void operator()(mir::Server &server) const
auto operator=(DisplayConfiguration const &) -> DisplayConfiguration &
void select_layout(std::string const &layout)
Select a layout from the configuration.
DisplayConfiguration(DisplayConfiguration const &)
auto list_layouts() -> std::vector< std::string >
List all layouts found in the config file.
Runner for applying initialization options to Mir.
Definition: runner.h:41
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.