2025-12-27 12:07:41 +08:00
# Mango Wayland Compositor
<div>
<img src="https://github.com/DreamMaoMao/mangowc/blob/main/assets/mango-transparency-256.png" alt="MangoWC Logo" width="120"/>
</div>
2025-07-30 21:01:09 +08:00
2025-06-22 03:53:43 -07:00
This project's development is based on [dwl ](https://codeberg.org/dwl/dwl/ ).
2025-05-07 11:12:20 +08:00
2025-05-08 19:25:23 +08:00
2025-06-25 18:17:44 +03:00
1. **Lightweight & Fast Build **
2025-05-07 11:12:20 +08:00
2025-07-30 14:54:59 +08:00
- _Mango_ is as lightweight as _ dwl _ , and can be built completely within a few seconds. Despite this, _ Mango _ does not compromise on functionality.
2025-06-25 18:17:44 +03:00
2. **Feature Highlights **
2025-07-30 14:54:59 +08:00
- In addition to basic WM functionality, Mango provides:
2025-06-29 16:09:48 +08:00
- Excellent xwayland support.
2025-07-01 04:05:36 -04:00
- Base tags not workspaces (supports separate window layouts for each tag)
2025-06-29 16:09:48 +08:00
- Smooth and customizable complete animations (window open/move/close, tag enter/leave,layer open/close/move)
2025-06-22 03:53:43 -07:00
- Excellent input method support (text input v2/v3)
2025-10-09 13:09:40 +08:00
- Flexible window layouts with easy switching (scroller, master-stack, monocle,center-master, etc.)
2025-06-22 03:53:43 -07:00
- Rich window states (swallow, minimize, maximize, unglobal, global, fakefullscreen, overlay, etc.)
2025-09-22 22:12:55 +08:00
- Simple yet powerful external configuration(support shortcuts hot-reload)
2025-06-22 03:53:43 -07:00
- Sway-like scratchpad and named scratchpad
2025-09-06 18:49:00 +08:00
- Ipc support(get/send message from/to compositor by external program)
2025-06-22 03:53:43 -07:00
- Hycov-like overview
2025-07-01 04:05:36 -04:00
- Window effects from scenefx (blur, shadow, corner radius, opacity)
2026-02-15 16:43:02 +08:00
- Zero flickering - every frame is perfect.
2025-05-07 11:12:20 +08:00
2026-02-08 18:17:55 +08:00
https://github.com/user-attachments/assets/bb83004a-0563-4b48-ad89-6461a9b78b1f
2025-07-12 21:01:29 +08:00
2026-02-22 11:11:07 +08:00
# Mango's Vision
**Mango's primary goal is stability ** : After months of testing and development—and aside from a few lingering GPU compatibility issues—it should now be stable enough. I don't plan on making many breaking changes.
**Mango's preference is practicality ** : I tend to add features that genuinely help with daily workflows—things that make our work more convenient.
**Mango won't cater to every user preference ** : For niche feature requests, I'll take a wait-and-see approach. I'll only consider adding them if they get a significant number of upvotes.
2025-10-26 18:10:48 +08:00
# Our discord
[mangowc ](https://discord.gg/CPjbDxesh5 )
2025-06-20 10:52:41 +08:00
# Supported layouts
2025-08-15 13:26:21 +08:00
- tile
- scroller
- monocle
- grid
- deck
2025-09-26 21:30:45 +08:00
- center_tile
2025-08-15 13:26:21 +08:00
- vertical_tile
2025-10-11 16:27:54 +08:00
- vertical_grid
2025-08-15 13:26:21 +08:00
- vertical_scroller
2026-02-22 11:11:07 +08:00
- tgmix
2025-06-22 03:53:43 -07:00
# Installation
2025-03-24 12:34:17 +08:00
2026-02-19 15:02:03 +01:00
[](https://repology.org/project/mangowc/versions)
2025-06-22 03:53:43 -07:00
## Dependencies
2025-03-15 10:26:11 +08:00
2025-06-25 18:17:44 +03:00
- wayland
- wayland-protocols
- libinput
- libdrm
- libxkbcommon
- pixman
- libdisplay-info
- libliftoff
- hwdata
- seatd
- pcre2
2025-12-03 23:19:58 +08:00
- xorg-xwayland
- libxcb
2025-03-24 12:34:17 +08:00
2025-06-22 03:53:43 -07:00
## Arch Linux
2026-02-06 15:18:31 +05:45
The package is in the Arch User Repository and is available for manual download [here ](https://aur.archlinux.org/packages/mangowc-git ) or through a AUR helper like yay:
2025-04-13 09:05:09 +08:00
``` bash
2025-08-01 10:56:39 +08:00
yay -S mangowc-git
2025-03-24 12:34:17 +08:00
2025-02-03 23:18:47 +08:00
```
2025-07-08 07:49:50 +03:00
## Gentoo Linux
The package is in the community-maintained repository called GURU.
First, add GURU repository:
``` bash
emerge --ask --verbose eselect-repository
eselect repository enable guru
emerge --sync guru
```
2025-08-10 14:12:16 +03:00
Then, add `gui-libs/scenefx` and `gui-wm/mangowc` to the `package.accept_keywords` .
2025-07-08 07:49:50 +03:00
Finally, install the package:
``` bash
2025-08-10 14:12:16 +03:00
emerge --ask --verbose gui-wm/mangowc
2025-07-08 07:49:50 +03:00
```
2025-12-06 14:50:54 -06:00
## Fedora Linux
The package is in the third-party Terra repository.
First, add the [Terra Repository ](https://terra.fyralabs.com/ ).
Then, install the package:
``` bash
dnf install mangowc
```
2026-02-20 19:56:26 +01:00
## Guix System
2026-02-15 16:50:07 +03:00
The package definition is described in the source repository.
First, add `mangowc` channel to `channels.scm` file:
``` scheme
;; In $HOME/.config/guix/channels.scm
( cons ( channel
( name 'mangowc )
2026-02-20 19:56:26 +01:00
( url "https://github.com/DreamMaoMao/mangowc.git" )
( branch "main" ) )
2026-02-15 16:50:07 +03:00
. . . ;; Your other channels
%default-channels )
```
Then, run `guix pull` and after update you can either run
`guix install mangowc` or add it to your configuration via:
``` scheme
( use-modules ( mangowc ) ) ;; Add mangowc module
;; Add mangowc to packages list
2026-02-20 19:56:26 +01:00
( packages ( cons*
mangowc-git
2026-02-15 16:50:07 +03:00
. . . ;; Other packages you specified
%base-packages ) )
```
And then rebuild your system.
2025-06-22 03:53:43 -07:00
## Other
2025-06-25 18:17:44 +03:00
2025-04-13 09:05:09 +08:00
``` bash
2025-11-10 14:30:20 +08:00
git clone -b 0.19.2 https://gitlab.freedesktop.org/wlroots/wlroots.git
2025-06-08 10:38:51 +08:00
cd wlroots
meson build -Dprefix= /usr
sudo ninja -C build install
2025-11-19 12:45:04 +08:00
git clone -b 0.4.1 https://github.com/wlrfx/scenefx.git
2025-06-24 14:55:18 +08:00
cd scenefx
meson build -Dprefix= /usr
sudo ninja -C build install
2025-08-01 10:56:39 +08:00
git clone https://github.com/DreamMaoMao/mangowc.git
cd mangowc
2025-02-03 23:18:47 +08:00
meson build -Dprefix= /usr
sudo ninja -C build install
2025-03-03 08:33:19 +08:00
```
2025-02-20 08:47:56 +08:00
2025-06-22 03:53:43 -07:00
## Suggested Tools
2025-03-24 12:34:17 +08:00
2025-11-10 14:30:20 +08:00
### Hybrid component
2025-10-31 10:42:38 +08:00
- [dms-shell ](https://github.com/AvengeMedia/DankMaterialShell )
### Independent component
2025-09-08 10:20:30 +08:00
- Application launcher (rofi, bemenu, wmenu, fuzzel)
2025-06-25 18:17:44 +03:00
- Terminal emulator (foot, wezterm, alacritty, kitty, ghostty)
- Status bar (waybar, eww, quickshell, ags), waybar is preferred
- Wallpaper setup (swww, swaybg)
2025-07-12 21:01:29 +08:00
- Notification daemon (swaync, dunst,mako)
2025-06-25 18:17:44 +03:00
- Desktop portal (xdg-desktop-portal, xdg-desktop-portal-wlr, xdg-desktop-portal-gtk)
- Clipboard (wl-clipboard, wl-clip-persist, cliphist)
- Gamma control/night light (wlsunset, gammastep)
- Miscellaneous (xfce-polkit, wlogout)
2025-03-11 09:44:00 +08:00
2025-06-22 03:53:43 -07:00
## Some Common Default Keybindings
2025-06-25 18:17:44 +03:00
2025-04-28 22:58:00 +08:00
- alt+return: open foot terminal
2025-08-18 19:42:52 +08:00
- alt+space: open rofi launcher
2025-04-28 22:58:00 +08:00
- alt+q: kill client
- alt+left/right/up/down: focus direction
2025-07-30 14:54:59 +08:00
- super+m: quit mango
2025-03-24 12:34:17 +08:00
2025-06-22 03:53:43 -07:00
## My Dotfiles
2025-06-25 18:17:44 +03:00
2025-10-31 10:42:38 +08:00
### Daily
2025-06-22 03:53:43 -07:00
- Dependencies
2025-06-25 18:17:44 +03:00
2025-06-24 16:22:25 +08:00
``` bash
2025-09-08 10:20:30 +08:00
yay -S rofi foot xdg-desktop-portal-wlr swaybg waybar wl-clip-persist cliphist wl-clipboard wlsunset xfce-polkit swaync pamixer wlr-dpms sway-audio-idle-inhibit-git swayidle dimland-git brightnessctl swayosd wlr-randr grim slurp satty swaylock-effects-git wlogout sox
2025-04-29 21:20:37 +08:00
```
2025-06-25 18:17:44 +03:00
2025-10-31 10:42:38 +08:00
### Dms
- Dependencies
``` bash
2025-11-02 08:51:06 +08:00
yay -S foot xdg-desktop-portal-wlr swaybg wl-clip-persist cliphist wl-clipboard sway-audio-idle-inhibit-git brightnessctl grim slurp satty matugen-bin dms-shell-git
2025-10-31 10:42:38 +08:00
```
- use my dms config
``` bash
git clone -b dms https://github.com/DreamMaoMao/mango-config.git ~/.config/mango
```
- use my daily config
2025-06-25 18:17:44 +03:00
2025-06-24 16:22:25 +08:00
``` bash
2025-07-30 14:54:59 +08:00
git clone https://github.com/DreamMaoMao/mango-config.git ~/.config/mango
2025-04-29 21:20:37 +08:00
```
2025-06-25 18:17:44 +03:00
2025-02-23 19:55:42 +08:00
2025-07-01 04:05:36 -04:00
## Config Documentation
2025-02-23 19:55:42 +08:00
2025-12-08 09:42:18 +08:00
Refer to the repo wiki [wiki ](https://github.com/DreamMaoMao/mango/wiki/ )
or the website docs [docs ](https://mangowc.vercel.app/docs )
2025-03-07 20:57:34 +08:00
2025-06-22 03:53:43 -07:00
# NixOS + Home-manager
2025-03-24 12:34:17 +08:00
2025-07-30 14:54:59 +08:00
The repo contains a flake that provides a NixOS module and a home-manager module for mango.
Use the NixOS module to install mango with other necessary components of a working Wayland environment.
Use the home-manager module to declare configuration and autostart for mango.
2025-03-24 12:50:27 +08:00
Here's an example of using the modules in a flake:
2025-02-25 22:05:29 +08:00
``` nix
{
inputs = {
nixpkgs . url = " g i t h u b : N i x O S / n i x p k g s / n i x o s - u n s t a b l e " ;
home-manager = {
url = " g i t h u b : n i x - c o m m u n i t y / h o m e - m a n a g e r " ;
inputs . nixpkgs . follows = " n i x p k g s " ;
} ;
flake-parts . url = " g i t h u b : h e r c u l e s - c i / f l a k e - p a r t s " ;
2025-11-11 17:03:43 +01:00
mango = {
url = " g i t h u b : D r e a m M a o M a o / m a n g o " ;
inputs . nixpkgs . follows = " n i x p k g s " ;
} ;
2025-02-25 22:05:29 +08:00
} ;
outputs =
inputs @ { self , flake-parts , . . . }:
flake-parts . lib . mkFlake { inherit inputs ; } {
debug = true ;
systems = [ " x 8 6 _ 6 4 - l i n u x " ] ;
flake = {
nixosConfigurations = {
hostname = inputs . nixpkgs . lib . nixosSystem {
system = " x 8 6 _ 6 4 - l i n u x " ;
modules = [
inputs . home-manager . nixosModules . home-manager
2025-03-24 12:50:27 +08:00
2025-07-30 14:54:59 +08:00
# Add mango nixos module
inputs . mango . nixosModules . mango
2025-03-24 12:50:27 +08:00
{
2025-07-30 14:54:59 +08:00
programs . mango . enable = true ;
2025-03-24 12:50:27 +08:00
}
2025-02-25 22:05:29 +08:00
{
home-manager = {
useGlobalPkgs = true ;
useUserPackages = true ;
backupFileExtension = " b a c k u p " ;
users . " u s e r n a m e " . imports =
[
(
{ . . . }:
{
2025-07-30 14:54:59 +08:00
wayland . windowManager . mango = {
2025-02-25 22:05:29 +08:00
enable = true ;
settings = ''
# s e e c o n f i g . c o n f
'' ;
autostart_sh = ''
# s e e a u t o s t a r t . s h
2025-02-25 22:37:34 +08:00
# N o t e : h e r e n o n e e d t o a d d s h e b a n g
2025-02-25 22:05:29 +08:00
'' ;
} ;
}
)
]
++ [
2025-07-30 14:54:59 +08:00
# Add mango hm module
inputs . mango . hmModules . mango
2025-02-25 22:05:29 +08:00
] ;
} ;
}
] ;
} ;
} ;
} ;
} ;
}
```
2025-07-30 14:54:59 +08:00
# Packaging mango
2025-06-25 18:17:44 +03:00
2025-07-30 14:54:59 +08:00
To package mango for other distributions, you can check the reference setup for:
2025-06-25 18:17:44 +03:00
2025-09-26 12:15:08 +08:00
- [nix ](https://github.com/DreamMaoMao/mangowc/blob/main/nix/default.nix )
- [arch ](https://aur.archlinux.org/cgit/aur.git/tree/PKGBUILD?h=mangowc-git ).
2025-08-10 14:12:16 +03:00
- [gentoo ](https://data.gpo.zugaina.org/guru/gui-wm/mangowc )
2025-06-25 18:17:44 +03:00
2025-09-26 12:00:26 +08:00
You might need to package `scenefx` for your distribution, check availability [here ](https://github.com/wlrfx/scenefx.git ).
2025-06-25 18:17:44 +03:00
2025-07-30 14:54:59 +08:00
If you encounter build errors when packaging `mango` , feel free to create an issue and ask a question, but
2025-06-25 18:17:44 +03:00
Read The Friendly Manual on packaging software in your distribution first.
2025-06-22 03:53:43 -07:00
# Thanks to These Reference Repositories
2025-02-14 14:32:20 +08:00
2025-06-22 03:53:43 -07:00
- https://gitlab.freedesktop.org/wlroots/wlroots - Implementation of Wayland protocol
2025-02-14 14:32:20 +08:00
2025-06-22 03:53:43 -07:00
- https://github.com/dqrk0jeste/owl - Basal window animation
2025-02-14 14:32:20 +08:00
2025-06-22 03:53:43 -07:00
- https://codeberg.org/dwl/dwl - Basal dwl feature
2025-03-01 21:34:05 +08:00
2025-06-22 03:53:43 -07:00
- https://github.com/swaywm/sway - Sample of Wayland protocol
2025-06-24 14:55:18 +08:00
2025-06-24 16:22:25 +08:00
- https://github.com/wlrfx/scenefx - Make it simple to add window effect.
2026-01-13 20:25:19 +08:00
# Sponsor
At present, I can only accept sponsorship through an encrypted connection.
If you find this project helpful to you, you can offer sponsorship in the following ways.
<img width="650" height="870" alt="image" src="https://github.com/user-attachments/assets/8c860317-90d2-4071-971d-f1a92b674469" />
Thanks to the following friends for their sponsorship of this project
[@tonybanters ](https://github.com/tonybanters )