Go to file
Florian Müllner 1c98a95974 extensionSystem: Include dir and path in data passed to extension
Extensions often need to set up additional resources from their
directory, like settings, translations or image assets.

So far extensions have used getCurrentExtension() to access the
shell's internal extension object which contains path and dir
properties. That's far from ideal, first because it requires
generating a stack to figure out the current extension, and
second because the internal object also contains state that
extensions shouldn't meddle with.

Just include those properties in the metadata we pass to the
extension constructor.

Part-of: <https://gitlab.gnome.org/GNOME/gnome-shell/-/merge_requests/2838>
2023-07-29 15:20:20 +03:00
.gitlab/issue_templates gitlab: Add a comment about disabling extension to the issue template 2022-12-15 19:07:08 +00:00
.gitlab-ci ci: Don't install fake pkexec in toolbox image 2023-07-23 11:42:56 +00:00
.settings
data style: Generalize sharing indicator class 2023-07-29 13:55:15 +03:00
docs/reference docs: Remove invalid XInclude 2023-04-24 10:55:40 +08:00
js extensionSystem: Include dir and path in data passed to extension 2023-07-29 15:20:20 +03:00
lint extensionUtils: Split out extension convenience functions 2023-07-15 13:16:42 +02:00
man
meson theme: Include both dark and light variant in resource 2023-05-25 17:10:53 +02:00
po Update Vietnamese translation 2023-07-29 07:53:03 +00:00
src shell: Add device monitor for cameras 2023-07-29 13:55:15 +03:00
subprojects extensions-app: Stop setting VERSION in config 2023-07-23 15:36:10 +02:00
tests scripting: Convert to ES module and migrate tests 2023-07-15 02:35:56 +00:00
tools tools/create-toolbox: Allow setting up support for GNOME Classic 2023-05-16 18:20:42 +00:00
.eslintrc.yml extensions/internals: Port to ESM 2023-07-15 13:16:42 +02:00
.gitignore Ignore eslint cache files 2023-03-01 15:55:40 +00:00
.gitlab-ci.yml ci: Make meson warnings fatal 2023-07-23 15:36:20 +02:00
.gitmodules
.jscheckignore ci: Don't ignore init.js 2023-04-21 18:28:32 +00:00
config.h.meson shell: Add device monitor for cameras 2023-07-29 13:55:15 +03:00
COPYING
gnome-shell.doap
HACKING.md js: Split gi imports to be on new lines to prepare for ES modules 2023-06-21 04:50:33 -07:00
meson_options.txt shell: Add device monitor for cameras 2023-07-29 13:55:15 +03:00
meson.build shell: Add device monitor for cameras 2023-07-29 13:55:15 +03:00
NEWS Bump version to 45.alpha 2023-07-06 19:23:10 +02:00
README.md

GNOME Shell

GNOME Shell provides core user interface functions for the GNOME desktop, like switching to windows and launching applications. GNOME Shell takes advantage of the capabilities of modern graphics hardware and introduces innovative user interface concepts to provide a visually attractive and easy to use experience.

For more information about GNOME Shell, including instructions on how to build GNOME Shell from source and how to get involved with the project, see the project wiki.

Bugs should be reported to the GNOME bug tracking system. Please refer to the Schedule wiki page to see the supported versions.

Contributing

To contribute, open merge requests at https://gitlab.gnome.org/GNOME/gnome-shell.

Commit messages should follow the GNOME commit message guidelines. If a merge request fixes an existing issue, it is good practice to append the full issue URL to each commit message. Try to always prefix commit subjects with a relevant topic, such as panel: or status/network:, and it's always better to write too much in the commit message body than too little.

Default branch

The default development branch is main. If you still have a local checkout under the old name, use:

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

License

GNOME Shell is distributed under the terms of the GNU General Public License, version 2 or later. See the COPYING file for details.