nixpkgs/pkgs/desktops/gnome/extensions
2024-09-14 14:23:06 +00:00
..
arcmenu
argos
clock-override gnome-shell: Move from gnome scope to top-level 2024-09-01 14:16:31 +02:00
drop-down-terminal
EasyScreenCast gnomeExtensions.easyScreenCast: 1.9.0 -> 1.10.0 2024-09-14 14:23:06 +00:00
extensionOverridesPatches gnomeExtensions.tophat: update the patch 2024-07-20 00:05:06 +09:00
gnome-browser-connector gnome-shell: Move from gnome scope to top-level 2024-09-01 14:16:31 +02:00
gsconnect gnome-shell: Move from gnome scope to top-level 2024-09-01 14:16:31 +02:00
guillotine gnomeExtensions.guillotine: package manually 2024-07-31 06:47:04 +02:00
icon-hider treewide: remove jonafato from maintainers 2024-09-05 19:42:28 -04:00
impatience
no-title-bar treewide: remove jonafato from maintainers 2024-09-05 19:42:28 -04:00
pidgin-im-integration gnome-shell: Move from gnome scope to top-level 2024-09-01 14:16:31 +02:00
pop-shell
sound-output-device-chooser treewide: remove unused with statements from maintainer lists 2024-07-29 10:06:20 +08:00
systemd-manager gnomeExtensions.systemd-manager: 16 -> 17 2024-07-27 14:29:15 +00:00
taskwhisperer treewide: remove jonafato from maintainers 2024-09-05 19:42:28 -04:00
tilingnome gnome-shell: Move from gnome scope to top-level 2024-09-01 14:16:31 +02:00
topicons-plus
unite gnome-shell: Move from gnome scope to top-level 2024-09-01 14:16:31 +02:00
valent treewide: remove unused with statements from maintainer lists 2024-07-29 10:06:20 +08:00
window-corner-preview gnome-shell: Move from gnome scope to top-level 2024-09-01 14:16:31 +02:00
buildGnomeExtension.nix
collisions.json
default.nix
extensionOverrides.nix
extensionRenames.nix
extensions.json
manuallyPackaged.nix gnomeExtensions.guillotine: package manually 2024-07-31 06:47:04 +02:00
README.md
update-extensions.py

GNOME Shell extensions

All extensions are packaged automatically. They can be found in the pkgs.gnomeXYExtensions for XY being a GNOME version. The package names are the extensions UUID, which can be a bit unwieldy to use. pkgs.gnomeExtensions is a set of manually curated extensions that match the current gnome.gnome-shell versions. Their name is human-friendly, compared to the other extensions sets. Some of its extensions are manually packaged.

Automatically packaged extensions

The actual packages are created by buildGnomeExtension.nix, provided the correct arguments are fed into it. The important extension data is stored in extensions.json, one line/item per extension. That file is generated by running update-extensions.py. Furthermore, the automatic generated names are dumped in collisions.json for manual inspection. extensionRenames.nix contains new names for all extensions that collide.

Extensions updates

For everyday updates,

  1. Run update-extensions.py.
  2. Update extensionRenames.nix according to the comment at the top.

For GNOME updates,

  1. Add a new gnomeXYExtensions set
  2. Remove old ones for GNOME versions we dont want to support any more
  3. Update supported_versions in ./update-extensions.py and re-run it
  4. Change gnomeExtensions to the new version
  5. Update ./extensionsRenames.nix accordingly
  6. Update all-packages.nix accordingly (grep for gnomeExtensions)

Manually packaged extensions

Manually packaged extensions overwrite some of the automatically packaged ones in pkgs.gnomeExtensions. They are listed in manuallyPackaged.nix, every extension has its own sub-folder.