Go to file
Sergio Gómez a1c3c09959 kiosk-shell: Introduce surface tree lists to the kiosk shell
The following patchset implements proper z-order for xdg surfaces in the kiosk
shell. For this it introduces to the kiosk shell the concept of a "surface
tree": a list of kiosk shell surface structures having a common ancestor (in
the xdg protocol sense).

The design is based on the following assumptions that the kiosk shell currently
makes:

- A kiosk surface with no parent must be fullscreen.
- If a parent is set on a kiosk surface, that surface is assigned the output of
  the root kiosk surface. This means that all kiosk surfaces in a surface tree
  will always have the same output.
- There is no possibility to minimize a kiosk surface.

With these in mind, the following design decisions were deemed convenient:

- For every output, at most one surface tree list will be active. This means
  that, for a given output, only views belonging to surfaces of the same
  surface tree will be in the normal layer. Moreover, all such views will be in
  the normal layer if the surface tree list is active.
- The z-order of surface trees (the weston views' relative placement in the
  normal layer) is determined by the placement of their corresponding kiosk
  surface in the surface tree list.

Each kiosk shell surface begins its life as root of its own surface tree list.
Whenever a parent is set on a surface, that surface is linked to the surface
tree list of the root surface of the parent. If a parent kiosk shell surface is
destroyed, its children will keep the link to the root surface's surface tree
list. If the destroyed parent is also the root surface of the surface tree,
each child is unlinked from this root and they become the root of a new surface
tree.

This commit introduces to the kiosk_shell_surface structure the fields
'surface_tree_list', representing the surface tree list to which the surface is
linked at creation as its root, and 'surface_tree_link', the link to the
surface tree list.

Signed-off-by: Sergio Gómez <sergio.g.delreal@gmail.com>
2023-07-27 10:13:48 +03:00
.gitlab-ci CI: Remove per-test-asan wrapper 2023-06-22 14:31:57 +01:00
clients Revert "clients/window: Update min_allocation for smaller widths/heights" 2023-07-19 14:40:03 +03:00
compositor frontend: Fix build error when Xwayland disabled 2023-07-18 11:44:11 +01:00
data build: Switch join_paths(foo, bar) to foo / bar 2023-06-22 14:31:57 +01:00
desktop-shell desktop-shell: Remove unnecessary repaint schedules 2023-07-24 12:35:47 +03:00
doc doc: add workaround for doxygen 1.9.6 bug with cairo >= 1.17.6 2023-07-17 14:12:20 +00:00
fullscreen-shell view: Add weston_view_add_transform and weston_view_remove_transform 2023-07-04 15:52:21 +01:00
include libweston: Remove plane clip 2023-07-20 14:42:55 -05:00
ivi-shell ivi-layout: Remove weston_view_schedule_repaint() 2023-07-25 10:46:59 +03:00
kiosk-shell kiosk-shell: Introduce surface tree lists to the kiosk shell 2023-07-27 10:13:48 +03:00
libweston input: Don't schedule repaints for drag-and-drop 2023-07-24 12:35:47 +03:00
man man: Document tls-cert and tls-key config options 2023-07-14 10:45:25 +00:00
pam libweston: Add user authentication support via PAM 2022-11-23 16:58:48 +01:00
pipewire pipewire-[backend|plugin]: Add timestamps to buffers 2023-04-20 12:32:49 +00:00
protocol tests: Add client<->compositor breakpoint support 2023-06-30 11:42:00 +00:00
remoting remoting-plugin: Check virtual outputs/remoting instance 2023-02-20 12:41:03 +02:00
shared libweston,shared/meson:build Add xkbcommon missing depends 2023-05-18 19:23:12 +03:00
subprojects backend-drm: use libdisplay-info 2023-04-28 16:18:22 +03:00
tests tests: Check that test-surface unmaps on NULL 2023-07-11 15:27:28 +00:00
tools zuc: Delete support for forking tests 2022-07-05 10:15:49 +01:00
wcap build: simplify include_directories 2019-10-04 17:14:22 +03:00
xwayland xwayland: Use weston_coord 2023-07-19 07:41:33 -05:00
.editorconfig Fix .editorconfig: use tabs for Meson files 2019-02-18 11:21:07 +01:00
.gitignore gitignore: Ignore the build/ directory. 2021-07-06 18:46:09 +00:00
.gitlab-ci.yml CI: Remove per-test-asan wrapper 2023-06-22 14:31:57 +01:00
.mailmap Add a .mailmap file 2023-03-25 11:18:10 -05:00
CONTRIBUTING.md CONTRIBUTING.md: Fix link for patchwork 2023-04-20 09:46:51 +03:00
COPYING COPYING: Specify origin of the library 2015-06-15 13:04:19 -07:00
DCO-1.1.txt contributing: add copy of DCO 2019-07-16 11:43:57 +00:00
meson_options.txt libweston: Split dbus support into seperate build option 2023-07-14 10:55:24 +00:00
meson.build build: Run tests with leak-sanitizer suppressions 2023-06-22 14:31:57 +01:00
notes.txt notes: fix a typo 2017-01-03 11:59:01 +00:00
README.md frontend: Use short-form names for shell argument 2023-01-10 10:53:02 +02:00
releasing.md releasing: use the Wayland release script 2022-11-10 11:22:54 +02:00
weston.ini.in frontend: Use short-form names for shell argument 2023-01-10 10:53:02 +02:00

Weston

screenshot of skeletal Weston desktop

Weston is a Wayland compositor designed for correctness, reliability, predictability, and performance.

Out of the box, Weston provides a very basic desktop, or a full-featured environment for non-desktop uses such as automotive, embedded, in-flight, industrial, kiosks, set-top boxes and TVs.

It also provides a library called libweston which allows users to build their own custom full-featured environments on top of Weston's core.

Building Weston

Weston is built using Meson. Weston often depends on the current release versions of Wayland and wayland-protocols.

If necessary, the latest Meson can be installed as a user with:

$ pip3 install --user meson

Weston's Meson build does not do autodetection and it defaults to all features enabled, which means you likely hit missing dependencies on the first try. If a dependency is avoidable through a build option, the error message should tell you what option can be used to avoid it. You may need to disable several features if you want to avoid certain dependencies.

$ git clone https://gitlab.freedesktop.org/wayland/weston.git
$ cd weston
$ meson build/ --prefix=...
$ ninja -C build/ install
$ cd ..

The meson command populates the build directory. This step can fail due to missing dependencies. Any build options you want can be added on that line, e.g. meson build/ --prefix=... -Ddemo-clients=false. All the build options can be found in the file meson_options.txt.

Once the build directory has been successfully populated, you can inspect the configuration with meson configure build/. If you need to change an option, you can do e.g. meson configure build/ -Ddemo-clients=false.

Every push to the Weston master repository and its forks is built using GitLab CI. Reading the configuration may provide a useful example of how to build and install Weston.

More detailed documentation on building Weston is available on the Wayland site. There are also more details on how to run and write tests.

For building the documentation see documentation.

Running Weston

Once Weston is installed, most users can simply run it by typing weston. This will launch Weston inside whatever environment you launch it from: when launched from a text console, it will take over that console. When launched from inside an existing Wayland or X11 session, it will start a 'nested' instance of Weston inside a window in that session.

By default, Weston will start with a skeletal desktop-like environment called desktop-shell. Other shells are available; for example, to load the kiosk shell designed for single-application environments, you can start with:

$ weston --shell=kiosk

Help is available by running weston --help, or man weston, which will list the available configuration options and display backends. It can also be configured through a file on disk; more information on this can be found through man weston.ini.

A small suite of example or demo clients are also provided: though they can be useful in themselves, their main purpose is to be an example or test case for others building compositors or clients.

Using libweston

libweston is designed to allow users to use Weston's core - its client support, backends and renderers - whilst implementing their own user interface, policy, configuration, and lifecycle. If you would like to implement your own window manager or desktop environment, we recommend building your project using the libweston API.

Building and installing Weston will also install libweston's shared library and development headers. libweston is both API-compatible and ABI-compatible within a single stable release. It is parallel-installable, so multiple stable releases can be installed and used side by side.

Documentation for libweston's API can be found within the source (see the documentation section), and also on Weston's online documentation for the current stable release.

Reporting issues and contributing

Weston's development is hosted on freedesktop.org GitLab. Please also see the contributing document, which details how to make code or non-technical contributions to Weston.

Weston and libweston are not suitable for severely memory-constrained environments where the compositor is expected to continue running even in the face of trivial memory allocations failing. If standard functions like malloc() fail for small allocations, you can expect libweston to abort. This is only likely to occur if you have disabled your OS's 'overcommit' functionality, and not in common cases.

Documentation

To read the Weston documentation online, head over to the Weston website.

For documenting weston we use sphinx together with breathe to process and augment code documentation from Doxygen. You should be able to install both sphinx and the breathe extension using pip3 command, or your package manager. Doxygen should be available using your distribution package manager.

Once those are set up, run meson with -Ddoc=true option in order to enable building the documentation. Installation will place the documentation in the prefix's path under datadir (i.e., share/doc).

Adding and improving documentation

For re-generating the documentation a special docs target has been added. Although first time you build (and subsequently install) weston, you'll see the documentation being built, updates to the spinx documentation files or to the source files will only be updated when using docs target!

Example:

$ ninja install # generates and installs the documentation
# time passes, hack hack, add doc in sources or rST files
$ ninja install # not sufficient, docs will not be updated
$ ninja docs && ninja install # run 'docs' then install

Improving/adding documentation can be done by modifying rST files under doc/sphinx/ directory or by modifying the source code using doxygen directives.