nixpkgs/pkgs/desktops/gnome/extensions
2021-10-03 19:54:57 +02:00
..
arcmenu
caffeine
chrome-gnome-shell
clock-override
dash-to-dock
dash-to-panel
drop-down-terminal
EasyScreenCast
emoji-selector
freon
gsconnect
icon-hider
impatience
night-theme-switcher
no-title-bar
paperwm
pidgin-im-integration
sound-output-device-chooser
system-monitor
taskwhisperer
tilingnome gnomeExtensions.tilingGnome: remove unstable in pname 2021-09-11 01:18:08 +02:00
topicons-plus
window-corner-preview
buildGnomeExtension.nix gnomeExtensions: add patch framework 2021-09-08 22:54:31 +02:00
collisions.json gnomeExtensions: Auto-update 2021-10-02 16:50:27 +02:00
default.nix gnomeExtensions: rename extensionPatches.nix to extensionOverrides.nix 2021-09-24 20:59:15 +02:00
extensionOverrides.nix gnomeExtensions.unite: remove manually packaging and use extension overrides 2021-10-03 19:54:57 +02:00
extensionRenames.nix gnomeExtensions: Auto-update 2021-10-02 16:50:27 +02:00
extensions.json gnomeExtensions: Auto-update 2021-10-02 16:50:27 +02:00
manuallyPackaged.nix gnomeExtensions.unite: remove manually packaging and use extension overrides 2021-10-03 19:54:57 +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 buildGnomeExtensions.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 provides 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

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.