# Maomaowm This project is developed based on [dwl](https://codeberg.org/dwl/dwl/), "Since many people have asked about the meaning of this compositor's name, 'Maomao' is an online alias I've been using for years - it comes from the first two characters of the Chinese word for 'caterpillar' (毛毛虫). You can basically think of it as meaning 'caterpillar'. 1. **Lightweight & Fast Build** - *Maomao* is as lightweight as *dwl*, and its build can be completed within few seconds. Despite this, *maomao* does not compromise on functionality. 2. **Feature Highlights** - Besides basic WM functionality, maomao provides: - Smooth and customizable animations - Excellent input method support - Flexible window layouts with easy switching - Rich window states: swallow, minimize, maximize, unglobal, global, fakefullscreen, overlay... - Simple yet powerful external configuration 3. **Philosophy** - *Maomao* has no rigid design ideology—you could call it an eclectic hybrid of various compositors. Master-Stack Layout https://github.com/user-attachments/assets/a9d4776e-b50b-48fb-94ce-651d8a749b8a Scroller Layout https://github.com/user-attachments/assets/c9bf9415-fad1-4400-bcdc-3ad2d76de85a # Features - Tag-based instead of workspace-based (supports separate window layouts for each tag) - Supported layouts: - Tile - Scroller - Monocle - Grid - Dwindle - Spiral - Deck # Special Features - Hycov-like overview - Foreign-toplevel protocol support (for dunst, waybar wlr taskbar) - Minimize window to waybar (like hych) - Sway-style scratchpad and Named scratchpad - Text-input-v2/v3 protocol for fcitx5 - Window animations (move/open/close/tag) - Alt-tab window switching - scroller layout # install ## depend ```bash yay -S glibc wayland libinput libdrm pixman libxkbcommon git meson ninja wayland-protocols libdisplay-info libliftoff hwdata seatd pcre2 ``` ## arch ```bash yay -S maomaowm-git ``` ## other ```bash # wlroots 0.19.0 release with a fix-patch to avoid crash git clone -b 0.19.0-fix https://github.com/DreamMaoMao/wlroots.git cd wlroots meson build -Dprefix=/usr sudo ninja -C build install git clone https://github.com/DreamMaoMao/maomaowm.git cd maomaowm meson build -Dprefix=/usr sudo ninja -C build install ``` ## suggest tools ``` yay -S rofi foot xdg-desktop-portal-wlr swaybg waybar wl-clip-persist cliphist wl-clipboard wlsunset xfce-polkit swaync ``` ## Some common default key bindings - alt+return: open foot terminal - alt+q: kill client - alt+left/right/up/down: focus direction - super+m: quit maomao ## My dotfile - depend ``` yay -S pamixer lavalauncher-mao-git wlr-dpms sway-audio-idle-inhibit-git swayidle dimland-git brightnessctl swayosd wlr-randr grim slurp satty swaylock-effects-git wlogout ``` ### maomao config [maomao-config](https://github.com/DreamMaoMao/dotfile/tree/main/maomao) #### other [foot](https://github.com/DreamMaoMao/dotfile/tree/main/foot) [swaylock](https://github.com/DreamMaoMao/dotfile/tree/main/swaylock) [wlogout](https://github.com/DreamMaoMao/dotfile/tree/main/wlogout) [swaync](https://github.com/DreamMaoMao/dotfile/tree/main/swaync) ## Config document refer to [wiki](https://github.com/DreamMaoMao/maomaowm/wiki/) # NixOS+Home-manager The repo contains a flake that provides a NixOS module and a home-manager module for maomaowm. Use the NixOS module to install maomaowm with other necessary components of a working wayland environment. Use the home-manager module to declare configuration and autostart for maomaowm. Here's an example of using the modules in a flake: ```nix { inputs = { nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; home-manager = { url = "github:nix-community/home-manager"; inputs.nixpkgs.follows = "nixpkgs"; }; flake-parts.url = "github:hercules-ci/flake-parts"; maomaowm.url = "github:DreamMaoMao/maomaowm"; }; outputs = inputs@{ self, flake-parts, ... }: flake-parts.lib.mkFlake { inherit inputs; } { debug = true; systems = [ "x86_64-linux" ]; flake = { nixosConfigurations = { hostname = inputs.nixpkgs.lib.nixosSystem { system = "x86_64-linux"; modules = [ inputs.home-manager.nixosModules.home-manager # Add maomaowm nixos module inputs.maomaowm.nixosModules.maomaowm { programs.maomaowm.enable = true; } { home-manager = { useGlobalPkgs = true; useUserPackages = true; backupFileExtension = "backup"; users."username".imports = [ ( { ... }: { wayland.windowManager.maomaowm = { enable = true; settings = '' # see config.conf ''; autostart_sh = '' # see autostart.sh # Note: here no need to add shebang ''; }; } ) ] ++ [ # Add maomaowm hm module inputs.maomaowm.hmModules.maomaowm ]; }; } ]; }; }; }; }; } ``` # thanks for some refer repo - https://gitlab.freedesktop.org/wlroots/wlroots - implementation of wayland protocol - https://github.com/dqrk0jeste/owl - basal window animaition - https://codeberg.org/dwl/dwl - basal dwl feature - https://github.com/labwc/labwc - sample of text-input protocol - https://github.com/swaywm/sway - sample of wayland protocol