2018-07-30 20:55:31 +02:00
|
|
|
# Mutter
|
|
|
|
|
|
|
|
Mutter is a Wayland display server and X11 window manager and compositor library.
|
|
|
|
|
|
|
|
When used as a Wayland display server, it runs on top of KMS and libinput. It
|
|
|
|
implements the compositor side of the Wayland core protocol as well as various
|
|
|
|
protocol extensions. It also has functionality related to running X11
|
|
|
|
applications using Xwayland.
|
|
|
|
|
|
|
|
When used on top of Xorg it acts as a X11 window manager and compositing manager.
|
|
|
|
|
|
|
|
It contains functionality related to, among other things, window management,
|
|
|
|
window compositing, focus tracking, workspace management, keybindings and
|
|
|
|
monitor configuration.
|
|
|
|
|
|
|
|
Internally it uses a fork of Cogl, a hardware acceleration abstraction library
|
2022-07-29 19:18:13 +00:00
|
|
|
used to simplify usage of OpenGL pipelines, as well as a fork of Clutter, a
|
2018-07-30 20:55:31 +02:00
|
|
|
scene graph and user interface toolkit.
|
|
|
|
|
2018-11-08 15:03:35 +00:00
|
|
|
Mutter is used by, for example, GNOME Shell, the GNOME core user interface, and
|
|
|
|
by Gala, elementary OS's window manager. It can also be run standalone, using
|
|
|
|
the command "mutter", but just running plain mutter is only intended for
|
|
|
|
debugging purposes.
|
2018-07-30 20:55:31 +02:00
|
|
|
|
2019-02-06 11:41:43 +01:00
|
|
|
## Contributing
|
|
|
|
|
|
|
|
To contribute, open merge requests at https://gitlab.gnome.org/GNOME/mutter.
|
|
|
|
|
2020-10-23 20:43:40 +02:00
|
|
|
It can be useful to look at the documentation available at the
|
|
|
|
[Wiki](https://gitlab.gnome.org/GNOME/mutter/-/wikis/home).
|
|
|
|
|
2022-06-03 17:38:57 +00:00
|
|
|
The API documentation is available at:
|
|
|
|
- Meta: <https://gnome.pages.gitlab.gnome.org/mutter/meta/>
|
|
|
|
- Clutter: <https://gnome.pages.gitlab.gnome.org/mutter/clutter/>
|
|
|
|
- Cally: <https://gnome.pages.gitlab.gnome.org/mutter/cally/>
|
|
|
|
- Cogl: <https://gnome.pages.gitlab.gnome.org/mutter/cogl/>
|
|
|
|
- CoglPango: <https://gnome.pages.gitlab.gnome.org/mutter/cogl-pango/>
|
|
|
|
|
2020-10-23 20:47:01 +02:00
|
|
|
## Coding style and conventions
|
|
|
|
|
2021-06-17 12:18:38 -03:00
|
|
|
See [HACKING.md](./HACKING.md).
|
2020-10-23 20:47:01 +02:00
|
|
|
|
|
|
|
## Git messages
|
2019-02-06 11:41:43 +01:00
|
|
|
|
|
|
|
Commit messages should follow the [GNOME commit message
|
|
|
|
guidelines](https://wiki.gnome.org/Git/CommitMessages). We require an URL
|
2020-10-23 20:47:01 +02:00
|
|
|
to either an issue or a merge request in each commit. Try to always prefix
|
|
|
|
commit subjects with a relevant topic, such as `compositor:` or
|
|
|
|
`clutter/actor:`, and it's always better to write too much in the commit
|
|
|
|
message body than too little.
|
2019-02-06 11:41:43 +01:00
|
|
|
|
2023-02-16 09:45:08 +01:00
|
|
|
If a commit fixes an issue and that issue should be closed, add URL to it in
|
|
|
|
the bottom of the commit message and prefix with `Closes:`.
|
|
|
|
|
|
|
|
Do not add any `Part-of:` line, as that will be handled automatically when
|
|
|
|
merging.
|
|
|
|
|
|
|
|
### The Fixes tag
|
|
|
|
|
|
|
|
If a commit fixes a regression caused by a particular commit, it can be marked
|
|
|
|
with the `Fixes:` tag. To produce such a tag, use
|
|
|
|
|
|
|
|
```
|
|
|
|
git show -s --pretty='format:Fixes: %h (\"%s\")' <COMMIT>
|
|
|
|
```
|
|
|
|
|
|
|
|
or create an alias
|
|
|
|
|
|
|
|
```
|
|
|
|
git config --global alias.fixes "show -s --pretty='format:Fixes: %h (\"%s\")'"
|
|
|
|
```
|
|
|
|
|
|
|
|
and then use
|
|
|
|
|
|
|
|
```
|
|
|
|
git fixes <COMMIT>
|
|
|
|
```
|
|
|
|
|
|
|
|
### Example
|
|
|
|
|
|
|
|
```
|
|
|
|
compositor: Also consider dark matter when calculating paint volume
|
|
|
|
|
|
|
|
Ignoring dark matter when calculating the paint volume missed the case where
|
|
|
|
compositing happens in complete vacuum.
|
|
|
|
|
|
|
|
Fixes: 123abc123ab ("compositor: Calculate paint volume ourselves")
|
|
|
|
Closes: https://gitlab.gnome.org/GNOME/mutter/-/issues/1234
|
|
|
|
```
|
|
|
|
|
2021-07-14 21:14:32 +02:00
|
|
|
## Default branch
|
|
|
|
|
|
|
|
The default development branch is `main`. If you still have a local
|
|
|
|
checkout under the old name, use:
|
|
|
|
```sh
|
|
|
|
git checkout master
|
|
|
|
git branch -m master main
|
|
|
|
git fetch
|
|
|
|
git branch --unset-upstream
|
|
|
|
git branch -u origin/main
|
|
|
|
git symbolic-ref refs/remotes/origin/HEAD refs/remotes/origin/main
|
|
|
|
```
|
|
|
|
|
2018-07-30 20:55:31 +02:00
|
|
|
## License
|
|
|
|
|
|
|
|
Mutter is distributed under the terms of the GNU General Public License,
|
|
|
|
version 2 or later. See the [COPYING][license] file for detalis.
|
|
|
|
|
|
|
|
[bug-tracker]: https://gitlab.gnome.org/GNOME/mutter/issues
|
|
|
|
[license]: COPYING
|