Compare commits
	
		
			139 Commits
		
	
	
		
			3.21.3
			...
			wip/ptomat
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | a1e41b6519 | ||
|   | 8c49267658 | ||
|   | d0bab1f7ac | ||
|   | f00826f3fb | ||
|   | 717c0ea19f | ||
|   | 3cd8dd0f32 | ||
|   | aedd616346 | ||
|   | b3de3ff00b | ||
|   | b66dff8aed | ||
|   | ff814df03a | ||
|   | c9a528025c | ||
|   | 5f3ec8a6f1 | ||
|   | becd29c50a | ||
|   | a029a35050 | ||
|   | d6a78d61d1 | ||
|   | 9be46bd212 | ||
|   | 4df3afced0 | ||
|   | 90f8e1df80 | ||
|   | ea2ac89e61 | ||
|   | 695bfb9616 | ||
|   | 5dbdde8c15 | ||
|   | 854bfc17ed | ||
|   | c8b192bcae | ||
|   | f07306897f | ||
|   | 44d731fff5 | ||
|   | 52f939f64c | ||
|   | f1d12c18d8 | ||
|   | 373ebb50eb | ||
|   | b0b5be63b9 | ||
|   | 68f439425b | ||
|   | cae4d92191 | ||
|   | f336295475 | ||
|   | 06d0e7d74a | ||
|   | 5e0e3edc7b | ||
|   | 02a51bfa65 | ||
|   | dbd04df311 | ||
|   | e6adcd99c7 | ||
|   | 3171819c36 | ||
|   | e4976b535d | ||
|   | 06d1602f17 | ||
|   | 603d0dfbc3 | ||
|   | 0b6c5b4620 | ||
|   | d7894dbc44 | ||
|   | d25d8126ea | ||
|   | 2402d3e115 | ||
|   | ac4284d348 | ||
|   | f9ef80749a | ||
|   | 22f0d3076e | ||
|   | 127b6dca1c | ||
|   | 8cfff33291 | ||
|   | 21f534c7f0 | ||
|   | 9faa1db942 | ||
|   | 2fc9bffb23 | ||
|   | f16eae45a2 | ||
|   | 622e73c34c | ||
|   | eb1c3d7045 | ||
|   | fc26895f70 | ||
|   | ca224b379f | ||
|   | 42b609b852 | ||
|   | a24169e2aa | ||
|   | 144d1dca88 | ||
|   | 38ab6ba3ec | ||
|   | bc6a0626c1 | ||
|   | 497f4f4a3c | ||
|   | 8c8c89a5f1 | ||
|   | d658a5148a | ||
|   | 2c3e0dab0f | ||
|   | e2400e35bd | ||
|   | fc4562491b | ||
|   | 6e3bedb888 | ||
|   | 2b8332df5e | ||
|   | 795e7d4b59 | ||
|   | 522d46a525 | ||
|   | dcecf5e350 | ||
|   | a61c929450 | ||
|   | 5992e9f524 | ||
|   | ee4cd05ebd | ||
|   | af5e65fd79 | ||
|   | 284cbf3ea7 | ||
|   | c3e68955e3 | ||
|   | ffa28e7ee7 | ||
|   | 78d81f909c | ||
|   | 34551bf48b | ||
|   | e02cd53ac5 | ||
|   | b7f5154bd3 | ||
|   | d80247918c | ||
|   | bb8c2d3e13 | ||
|   | 6e0e37519d | ||
|   | 5c19ae5878 | ||
|   | 8713473c64 | ||
|   | a4b4f2f6fd | ||
|   | 03f22135b5 | ||
|   | 5b79f657eb | ||
|   | 4fc0c513af | ||
|   | f5c058a036 | ||
|   | 0dac0ad516 | ||
|   | 5d4d1e26fd | ||
|   | 2f0039e7dd | ||
|   | 9202309bed | ||
|   | 7e0e224e0e | ||
|   | 35825cf0c7 | ||
|   | b2d79b6362 | ||
|   | f5e1dc86cd | ||
|   | 8c51f0076f | ||
|   | 8347152730 | ||
|   | 3d77dd8f51 | ||
|   | 82e6935281 | ||
|   | 61070e6ec0 | ||
|   | 128697d6a7 | ||
|   | 424fa01eca | ||
|   | 775187b2e4 | ||
|   | 99b5e10acf | ||
|   | 208ed6e90d | ||
|   | de8d4c4cd8 | ||
|   | 3ae591434d | ||
|   | 61fb62f969 | ||
|   | c4584c20dc | ||
|   | c6eb95ff3a | ||
|   | ab68360d53 | ||
|   | 58a733dc93 | ||
|   | db8f6b4848 | ||
|   | e72d388a67 | ||
|   | b5dd4d1456 | ||
|   | a7562b4148 | ||
|   | 358f64d66b | ||
|   | 2a7f9f70b8 | ||
|   | c91085caf7 | ||
|   | 21ddbf0b8f | ||
|   | 2ad2853278 | ||
|   | e16f63a8e4 | ||
|   | c39ffa111f | ||
|   | 5182129196 | ||
|   | 02bad8e92b | ||
|   | 500ea13155 | ||
|   | ce8e7481e7 | ||
|   | 528f2e3cdc | ||
|   | 408211ba73 | ||
|   | e02467eada | ||
|   | 3e93a1bdd6 | 
							
								
								
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -16,7 +16,6 @@ config.log | ||||
| config.status | ||||
| config | ||||
| configure | ||||
| data/50-gnome-shell-*.xml | ||||
| data/org.gnome.Shell.desktop | ||||
| data/org.gnome.Shell.desktop.in | ||||
| data/gnome-shell-extension-prefs.desktop | ||||
| @@ -26,8 +25,6 @@ data/gschemas.compiled | ||||
| data/perf-background.xml | ||||
| data/org.gnome.shell.gschema.xml | ||||
| data/org.gnome.shell.gschema.valid | ||||
| data/org.gnome.shell.evolution.calendar.gschema.xml | ||||
| data/org.gnome.shell.evolution.calendar.gschema.valid | ||||
| data/org.gnome.Shell.PortalHelper.desktop | ||||
| data/org.gnome.Shell.PortalHelper.service | ||||
| data/theme/.sass-cache | ||||
| @@ -74,7 +71,6 @@ src/*-marshal.[ch] | ||||
| src/Makefile | ||||
| src/Makefile.in | ||||
| src/calendar-server/evolution-calendar.desktop | ||||
| src/calendar-server/evolution-calendar.desktop.in | ||||
| src/calendar-server/org.gnome.Shell.CalendarServer.service | ||||
| src/gnome-shell | ||||
| src/gnome-shell-calendar-server | ||||
|   | ||||
							
								
								
									
										82
									
								
								NEWS
									
									
									
									
									
								
							
							
						
						
									
										82
									
								
								NEWS
									
									
									
									
									
								
							| @@ -1,3 +1,85 @@ | ||||
| 3.22.0 | ||||
| ====== | ||||
| * Misc. bug fixes [Florian, Rui; #771391, #771536] #771656] | ||||
|  | ||||
| Contributors: | ||||
|   Rui Matos, Florian Müllner | ||||
|  | ||||
| Translations: | ||||
|   Ask Hjorth Larsen [da], GNOME Translation Robot [gd], Alexandre Franke [fr], | ||||
|   Daniel Korostil [uk], Jordi Mas [ca], Khaled Hosny [ar], David King [en_GB] | ||||
|  | ||||
| 3.21.92 | ||||
| ======= | ||||
| * Adjust screen capture to work with multiple stage views [Jonas; #770128] | ||||
| * Improve handling of cycle shortcuts [Florian; #771063] | ||||
| * Fix windows not getting undimmed in some cases [Rui; #770163, #752524] | ||||
| * Disable extension version check by default [Florian; #770887] | ||||
| * Misc. bug fixes [Rui, Florian, Michael; #770382, #770888, #770328] | ||||
|  | ||||
| Contributors: | ||||
|   Jonas Ådahl, Michael Catanzaro, Fran Dieguez, Olivier Fourdan, Rui Matos, | ||||
|   Florian Müllner | ||||
|  | ||||
| Translations: | ||||
|   Changwoo Ryu [ko], Baurzhan Muftakhidinov [kk], Aurimas Černius [lt], | ||||
|   Muhammet Kara [tr], Trần Ngọc Quân [vi], A S Alam [pa], Yosef Or Boczko [he], | ||||
|   Anders Jonsson [sv], Tiago Santos [pt], Hannie Dumoleyn [nl], | ||||
|   Rūdolfs Mazurs [lv], Claude Paroz [fr], Arash Mousavi [fa], | ||||
|   Fran Dieguez [gl], Stas Solovey [ru], Tom Tryfonidis [el] | ||||
|  | ||||
| 3.21.91 | ||||
| ======= | ||||
| Translations: | ||||
|   Mario Blättermann [de], Jiri Grönroos [fi], Dušan Kazik [sk], | ||||
|   Andika Triwidada [id], Daniel Mustieles [es], Fabio Tomat [fur], | ||||
|   Enrico Nicoletto [pt_BR], Matej Urbančič [sl], Мирослав Николић [sr, sr@latin] | ||||
|  | ||||
| 3.21.90.1 | ||||
| ========= | ||||
| Contributors: | ||||
|   Piotr Drąg | ||||
|  | ||||
| Translations: | ||||
|   Marek Černocký [cs], Balázs Úr [hu] | ||||
|  | ||||
| 3.21.90 | ||||
| ======= | ||||
| * Improve on-screen keyboard on wayland [Carlos; #765009] | ||||
| * Misc. bug fixes [Florian; #769156, #769216, #769074] | ||||
|  | ||||
| Contributors: | ||||
|   Carlos Garnacho, Florian Müllner | ||||
|  | ||||
| Translations: | ||||
|   Fabio Tomat [fur], Tiago Santos [pt], Daniel Mustieles [es], | ||||
|   Bernd Homuth [de], Aurimas Černius [lt], Balázs Úr [hu], | ||||
|   Yosef Or Boczko [he], Jiri Grönroos [fi], Marek Cernocky [cs], | ||||
|   Muhammet Kara [tr], Enrico Nicoletto [pt_BR], Andika Triwidada [id] | ||||
|  | ||||
| 3.21.4 | ||||
| ====== | ||||
| * overview: Fix switching workspaces when scrolling on non-primary monitors | ||||
|   [Florian; #766883, #768316] | ||||
| * Fix crash when using screen recorder under wayland [Rui; #767001] | ||||
| * Update theme on video memory purge errors [Rui; #739178] | ||||
| * Free old backgrounds immediately [Hyungwon; #766353] | ||||
| * Add support for system upgrades to end session dialog [Kalev; #763611] | ||||
| * Fix maximized windows flickering to the wrong size on restart [Owen; #761566] | ||||
| * Hide ignored events in calendar as well [Florian; #768538] | ||||
| * calendar: Only hide dismissed occurrence of recurring event [Florian; #748226] | ||||
| * Provide org.freedesktop.impl.portal.access implementation [Florian; #768669] | ||||
| * Misc. bug fixes and cleanups [Rui, Florian, Marinus, Jonas; #767954, #768317, | ||||
|   #746867, #762206, #768956, #768979] | ||||
|  | ||||
| Contributors: | ||||
|   Jonas Ådahl, Piotr Drąg, Hyungwon Hwang, Kalev Lember, Rui Matos, | ||||
|   Florian Müllner, Marinus Schraal, Owen W. Taylor | ||||
|  | ||||
| Translations: | ||||
|   Andika Triwidada [id], Daniel Mustieles [es], Bruce Cowan [en_GB], | ||||
|   Dušan Kazik [sk], Piotr Drąg [pl], Chao-Hsiung Liao [zh_HK] | ||||
|  | ||||
| 3.21.3 | ||||
| ====== | ||||
|  * Do not disable suspend action when locked [Florian; #725960] | ||||
|   | ||||
							
								
								
									
										14
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -1,5 +1,5 @@ | ||||
| AC_PREREQ(2.63) | ||||
| AC_INIT([gnome-shell],[3.21.3],[https://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell],[gnome-shell]) | ||||
| AC_INIT([gnome-shell],[3.22.0],[https://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell],[gnome-shell]) | ||||
| AX_IS_RELEASE([git-directory]) | ||||
|  | ||||
| AC_CONFIG_HEADERS([config.h]) | ||||
| @@ -24,13 +24,14 @@ LT_PREREQ([2.2.6]) | ||||
| LT_INIT([disable-static]) | ||||
|  | ||||
| # i18n | ||||
| IT_PROG_INTLTOOL([0.40]) | ||||
|  | ||||
| GETTEXT_PACKAGE=gnome-shell | ||||
| AC_SUBST(GETTEXT_PACKAGE) | ||||
| AC_DEFINE_UNQUOTED(GETTEXT_PACKAGE, "$GETTEXT_PACKAGE", | ||||
|                    [The prefix for our gettext translation domains.]) | ||||
|  | ||||
| AM_GNU_GETTEXT_VERSION([0.19.6]) | ||||
| AM_GNU_GETTEXT([external]) | ||||
|  | ||||
| PKG_PROG_PKG_CONFIG([0.22]) | ||||
|  | ||||
| AC_PATH_PROG([XSLTPROC], [xsltproc]) | ||||
| @@ -75,9 +76,9 @@ AS_IF([test x$enable_systemd != xno], [ | ||||
| AC_MSG_RESULT($enable_systemd) | ||||
|  | ||||
| CLUTTER_MIN_VERSION=1.21.5 | ||||
| GOBJECT_INTROSPECTION_MIN_VERSION=1.45.4 | ||||
| GOBJECT_INTROSPECTION_MIN_VERSION=1.49.1 | ||||
| GJS_MIN_VERSION=1.39.0 | ||||
| MUTTER_MIN_VERSION=3.21.3 | ||||
| MUTTER_MIN_VERSION=3.22.0 | ||||
| GTK_MIN_VERSION=3.15.0 | ||||
| GIO_MIN_VERSION=2.45.3 | ||||
| LIBECAL_MIN_VERSION=3.5.3 | ||||
| @@ -119,7 +120,7 @@ PKG_CHECK_MODULES(SHELL_PERF_HELPER, gtk+-3.0 gio-2.0) | ||||
| PKG_CHECK_MODULES(SHELL_HOTPLUG_SNIFFER, gio-2.0 gdk-pixbuf-2.0) | ||||
| PKG_CHECK_MODULES(TRAY, mutter-clutter-1.0 gtk+-3.0) | ||||
| PKG_CHECK_MODULES(GVC, libpulse >= $PULSE_MIN_VERS libpulse-mainloop-glib gobject-2.0) | ||||
| PKG_CHECK_MODULES(DESKTOP_SCHEMAS, gsettings-desktop-schemas >= 3.21.2) | ||||
| PKG_CHECK_MODULES(DESKTOP_SCHEMAS, gsettings-desktop-schemas >= 3.21.3) | ||||
|  | ||||
| AC_ARG_ENABLE(browser-plugin, | ||||
|               [AS_HELP_STRING([--enable-browser-plugin], | ||||
| @@ -254,7 +255,6 @@ AC_CONFIG_FILES([ | ||||
|   docs/reference/st/Makefile | ||||
|   docs/reference/st/st-docs.sgml | ||||
|   js/Makefile | ||||
|   src/calendar-server/evolution-calendar.desktop.in | ||||
|   src/Makefile | ||||
|   src/gvc/Makefile | ||||
|   browser-plugin/Makefile | ||||
|   | ||||
| @@ -1,24 +1,24 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
| <KeyListEntries schema="org.gnome.shell.keybindings" | ||||
|                 group="system" | ||||
|                 _name="System" | ||||
|                 name="System" | ||||
|                 wm_name="GNOME Shell" | ||||
|                 package="gnome-shell"> | ||||
| 
 | ||||
| 	<KeyListEntry name="toggle-message-tray" | ||||
|                       _description="Show the notification list"/> | ||||
|                       description="Show the notification list"/> | ||||
| 
 | ||||
| 	<KeyListEntry name="focus-active-notification" | ||||
|                       _description="Focus the active notification"/> | ||||
|                       description="Focus the active notification"/> | ||||
| 
 | ||||
| 	<KeyListEntry name="toggle-overview" | ||||
|                       _description="Show the overview"/> | ||||
|                       description="Show the overview"/> | ||||
| 
 | ||||
| 	<KeyListEntry name="toggle-application-view" | ||||
|                       _description="Show all applications"/> | ||||
|                       description="Show all applications"/> | ||||
| 
 | ||||
| 	<KeyListEntry name="open-application-menu" | ||||
|                       _description="Open the application menu"/> | ||||
|                       description="Open the application menu"/> | ||||
| 
 | ||||
| </KeyListEntries> | ||||
| 
 | ||||
| @@ -7,12 +7,16 @@ desktop_DATA = org.gnome.Shell.desktop gnome-shell-extension-prefs.desktop | ||||
| if HAVE_NETWORKMANAGER | ||||
| desktop_DATA += org.gnome.Shell.PortalHelper.desktop | ||||
|  | ||||
| portaldir = $(datadir)/xdg-desktop-portal/portals | ||||
| portal_DATA = gnome-shell.portal | ||||
|  | ||||
| servicedir = $(datadir)/dbus-1/services | ||||
| service_DATA = org.gnome.Shell.PortalHelper.service | ||||
|  | ||||
| CLEANFILES += \ | ||||
| 	org.gnome.Shell.PortalHelper.service \ | ||||
| 	org.gnome.Shell.PortalHelper.desktop \ | ||||
| 	org.gnome.Shell.PortalHelper.service 	\ | ||||
| 	org.gnome.Shell.PortalHelper.desktop 	\ | ||||
| 	org.gnome.Shell.PortalHelper.desktop.in \ | ||||
| 	$(NULL) | ||||
|  | ||||
| endif | ||||
| @@ -28,7 +32,9 @@ endif | ||||
| 	    -e "s|@VERSION[@]|$(VERSION)|" \ | ||||
| 	    $< > $@ || rm $@ | ||||
|  | ||||
| @INTLTOOL_DESKTOP_RULE@ | ||||
| %.desktop:%.desktop.in | ||||
| 	$(AM_V_GEN) $(MSGFMT) --desktop --template $(builddir)/$< \ | ||||
| 	                      -d $(top_srcdir)/po -o $@ | ||||
|  | ||||
| introspectiondir = $(datadir)/dbus-1/interfaces | ||||
| introspection_DATA =				\ | ||||
| @@ -80,14 +86,11 @@ perf-background.xml: perf-background.xml.in | ||||
| 	    $< > $@ || rm $@ | ||||
|  | ||||
| keysdir = @GNOME_KEYBINDINGS_KEYSDIR@ | ||||
| keys_in_files = 50-gnome-shell-system.xml.in | ||||
| keys_DATA = $(keys_in_files:.xml.in=.xml) | ||||
| keys_DATA = 50-gnome-shell-system.xml | ||||
|  | ||||
| gsettings_SCHEMAS = org.gnome.shell.gschema.xml | ||||
|  | ||||
| @INTLTOOL_XML_NOMERGE_RULE@ | ||||
|  | ||||
| %.gschema.xml.in: %.gschema.xml.in.in Makefile | ||||
| %.gschema.xml: %.gschema.xml.in Makefile | ||||
| 	$(AM_V_GEN) sed -e 's|@GETTEXT_PACKAGE[@]|$(GETTEXT_PACKAGE)|g' \ | ||||
| 	$< > $@ || rm $@ | ||||
|  | ||||
| @@ -106,15 +109,16 @@ convert_DATA = gnome-shell-overrides.convert | ||||
| EXTRA_DIST =						\ | ||||
| 	org.gnome.Shell.desktop.in.in			\ | ||||
| 	gnome-shell-extension-prefs.desktop.in.in	\ | ||||
| 	$(portal_DATA)					\ | ||||
| 	$(introspection_DATA)				\ | ||||
| 	$(menu_DATA)					\ | ||||
| 	$(convert_DATA)					\ | ||||
| 	$(keys_in_files)				\ | ||||
| 	$(keys_DATA)					\ | ||||
| 	$(dist_theme_files)				\ | ||||
| 	perf-background.xml.in				\ | ||||
| 	org.gnome.Shell.PortalHelper.desktop.in		\ | ||||
| 	org.gnome.Shell.PortalHelper.desktop.in.in	\ | ||||
| 	org.gnome.Shell.PortalHelper.service.in		\ | ||||
| 	org.gnome.shell.gschema.xml.in.in		\ | ||||
| 	org.gnome.shell.gschema.xml.in			\ | ||||
| 	gnome-shell-theme.gresource.xml 		\ | ||||
| 	$(resource_files)				\ | ||||
| 	$(NULL) | ||||
| @@ -123,11 +127,9 @@ CLEANFILES +=						\ | ||||
| 	org.gnome.Shell.desktop.in			\ | ||||
| 	gnome-shell-extension-prefs.in			\ | ||||
| 	$(desktop_DATA)					\ | ||||
| 	$(keys_DATA)					\ | ||||
| 	$(gsettings_SCHEMAS)				\ | ||||
| 	perf-background.xml				\ | ||||
| 	gschemas.compiled				\ | ||||
| 	org.gnome.shell.gschema.valid			\ | ||||
| 	org.gnome.shell.gschema.xml.in			\ | ||||
| 	gnome-shell-theme.gresource			\ | ||||
| 	$(NULL) | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| [Desktop Entry] | ||||
| Type=Application | ||||
| _Name=GNOME Shell Extension Preferences | ||||
| _Comment=Configure GNOME Shell Extensions | ||||
| Name=GNOME Shell Extension Preferences | ||||
| Comment=Configure GNOME Shell Extensions | ||||
| Exec=@bindir@/gnome-shell-extension-prefs %u | ||||
| X-GNOME-Bugzilla-Bugzilla=GNOME | ||||
| X-GNOME-Bugzilla-Product=gnome-shell | ||||
|   | ||||
							
								
								
									
										4
									
								
								data/gnome-shell.portal
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								data/gnome-shell.portal
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | ||||
| [portal] | ||||
| DBusName=org.freedesktop.impl.portal.desktop.gnome | ||||
| Interfaces=org.freedesktop.impl.portal.Access | ||||
| UseIn=gnome | ||||
| @@ -1,9 +1,10 @@ | ||||
| [Desktop Entry] | ||||
| _Name=Network Login | ||||
| Name=Network Login | ||||
| Type=Application | ||||
| Exec=gapplication launch org.gnome.Shell.PortalHelper | ||||
| DBusActivatable=true | ||||
| NoDisplay=true | ||||
| # Translators: Do NOT translate or transliterate this text (this is an icon file name)! | ||||
| Icon=network-workgroup | ||||
| StartupNotify=true | ||||
| OnlyShowIn=GNOME; | ||||
| @@ -1,7 +1,7 @@ | ||||
| [Desktop Entry] | ||||
| Type=Application | ||||
| _Name=GNOME Shell | ||||
| _Comment=Window management and application launching | ||||
| Name=GNOME Shell | ||||
| Comment=Window management and application launching | ||||
| Exec=@bindir@/gnome-shell | ||||
| X-GNOME-Bugzilla-Bugzilla=GNOME | ||||
| X-GNOME-Bugzilla-Product=gnome-shell | ||||
|   | ||||
| @@ -3,84 +3,84 @@ | ||||
|           gettext-domain="@GETTEXT_PACKAGE@"> | ||||
|     <key name="development-tools" type="b"> | ||||
|       <default>true</default> | ||||
|       <_summary> | ||||
|       <summary> | ||||
|         Enable internal tools useful for developers and testers from Alt-F2 | ||||
|       </_summary> | ||||
|       <_description> | ||||
|       </summary> | ||||
|       <description> | ||||
|         Allows access to internal debugging and monitoring tools | ||||
|         using the Alt-F2 dialog. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key name="enabled-extensions" type="as"> | ||||
|       <default>[]</default> | ||||
|       <_summary>UUIDs of extensions to enable</_summary> | ||||
|       <_description> | ||||
|       <summary>UUIDs of extensions to enable</summary> | ||||
|       <description> | ||||
|         GNOME Shell extensions have a UUID property; this key lists extensions | ||||
|         which should be loaded. Any extension that wants to be loaded needs | ||||
|         to be in this list. You can also manipulate this list with the | ||||
|         EnableExtension and DisableExtension D-Bus methods on org.gnome.Shell. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key name="disable-extension-version-validation" type="b"> | ||||
|       <default>false</default> | ||||
|       <_summary>Disables the validation of extension version compatibility</_summary> | ||||
|       <_description> | ||||
|       <default>true</default> | ||||
|       <summary>Disables the validation of extension version compatibility</summary> | ||||
|       <description> | ||||
|         GNOME Shell will only load extensions that claim to support the current | ||||
|         running version. Enabling this option will disable this check and try to | ||||
|         load all extensions regardless of the versions they claim to support. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key name="favorite-apps" type="as"> | ||||
|       <default>[ 'epiphany.desktop', 'evolution.desktop', 'rhythmbox.desktop', 'shotwell.desktop', 'org.gnome.Nautilus.desktop', 'org.gnome.Software.desktop' ]</default> | ||||
|       <_summary>List of desktop file IDs for favorite applications</_summary> | ||||
|       <_description> | ||||
|       <summary>List of desktop file IDs for favorite applications</summary> | ||||
|       <description> | ||||
|         The applications corresponding to these identifiers | ||||
|         will be displayed in the favorites area. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key name="app-picker-view" type="u"> | ||||
|       <default>0</default> | ||||
|       <_summary>App Picker View</_summary> | ||||
|       <_description> | ||||
|       <summary>App Picker View</summary> | ||||
|       <description> | ||||
|         Index of the currently selected view in the application picker. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key name="command-history" type="as"> | ||||
|       <default>[]</default> | ||||
|       <_summary>History for command (Alt-F2) dialog</_summary> | ||||
|       <summary>History for command (Alt-F2) dialog</summary> | ||||
|     </key> | ||||
|     <key name="looking-glass-history" type="as"> | ||||
|       <default>[]</default> | ||||
|       <!-- Translators: looking glass is a debugger and inspector tool, see https://live.gnome.org/GnomeShell/LookingGlass --> | ||||
|       <_summary>History for the looking glass dialog</_summary> | ||||
|       <!-- Translators: looking glass is a debugger and inspector tool, see https://wiki.gnome.org/Projects/GnomeShell/LookingGlass --> | ||||
|       <summary>History for the looking glass dialog</summary> | ||||
|     </key> | ||||
|     <key name="always-show-log-out" type="b"> | ||||
|       <default>false</default> | ||||
|       <_summary>Always show the 'Log out' menu item in the user menu.</_summary> | ||||
|       <_description> | ||||
|       <summary>Always show the 'Log out' menu item in the user menu.</summary> | ||||
|       <description> | ||||
|         This key overrides the automatic hiding of the 'Log out' | ||||
|         menu item in single-user, single-session situations. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key name="remember-mount-password" type="b"> | ||||
|       <default>false</default> | ||||
|       <_summary>Whether to remember password for mounting encrypted or remote filesystems</_summary> | ||||
|       <_description> | ||||
|       <summary>Whether to remember password for mounting encrypted or remote filesystems</summary> | ||||
|       <description> | ||||
|         The shell will request a password when an encrypted device or a | ||||
|         remote filesystem is mounted.  If the password can be saved for | ||||
|         future use a 'Remember Password' checkbox will be present. | ||||
|         This key sets the default state of the checkbox. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key name="had-bluetooth-devices-setup" type="b"> | ||||
|       <default>false</default> | ||||
|       <_summary>Whether the default Bluetooth adapter had set up devices associated to it</_summary> | ||||
|       <_description> | ||||
|       <summary>Whether the default Bluetooth adapter had set up devices associated to it</summary> | ||||
|       <description> | ||||
|         The shell will only show a Bluetooth menu item if a Bluetooth | ||||
|         adapter is powered, or if there were devices set up associated | ||||
|         with the default adapter. This will be reset if the default | ||||
|         adapter is ever seen not to have devices associated to it. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <child name="keybindings" schema="org.gnome.shell.keybindings"/> | ||||
|     <child name="keyboard" schema="org.gnome.shell.keyboard"/> | ||||
| @@ -90,44 +90,44 @@ | ||||
|           gettext-domain="@GETTEXT_PACKAGE@"> | ||||
|     <key name="open-application-menu" type="as"> | ||||
|       <default>["<Super>F10"]</default> | ||||
|       <_summary>Keybinding to open the application menu</_summary> | ||||
|       <_description> | ||||
|       <summary>Keybinding to open the application menu</summary> | ||||
|       <description> | ||||
|         Keybinding to open the application menu. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key name="toggle-application-view" type="as"> | ||||
|       <default>["<Super>a"]</default> | ||||
|       <_summary>Keybinding to open the "Show Applications" view</_summary> | ||||
|       <_description> | ||||
|       <summary>Keybinding to open the "Show Applications" view</summary> | ||||
|       <description> | ||||
|         Keybinding to open the "Show Applications" view of the Activities | ||||
|         Overview. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key name="toggle-overview" type="as"> | ||||
|       <default>["<Super>s"]</default> | ||||
|       <_summary>Keybinding to open the overview</_summary> | ||||
|       <_description> | ||||
|       <summary>Keybinding to open the overview</summary> | ||||
|       <description> | ||||
|         Keybinding to open the Activities Overview. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key name="toggle-message-tray" type="as"> | ||||
|       <default>["<Super>v","<Super>m"]</default> | ||||
|       <_summary>Keybinding to toggle the visibility of the notification list</_summary> | ||||
|       <_description> | ||||
|       <summary>Keybinding to toggle the visibility of the notification list</summary> | ||||
|       <description> | ||||
|         Keybinding to toggle the visibility of the notification list. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key name="focus-active-notification" type="as"> | ||||
|       <default>["<Super>n"]</default> | ||||
|       <_summary>Keybinding to focus the active notification</_summary> | ||||
|       <_description> | ||||
|       <summary>Keybinding to focus the active notification</summary> | ||||
|       <description> | ||||
|         Keybinding to focus the active notification. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key name="pause-resume-tweens" type="as"> | ||||
|       <default>[]</default> | ||||
|       <_summary>Keybinding that pauses and resumes all running tweens, for debugging purposes</_summary> | ||||
|       <_description></_description> | ||||
|       <summary>Keybinding that pauses and resumes all running tweens, for debugging purposes</summary> | ||||
|       <description></description> | ||||
|     </key> | ||||
|   </schema> | ||||
| 
 | ||||
| @@ -135,10 +135,10 @@ | ||||
|           gettext-domain="@GETTEXT_PACKAGE@"> | ||||
|     <key name="keyboard-type" type="s"> | ||||
|       <default>'touch'</default> | ||||
|       <_summary>Which keyboard to use</_summary> | ||||
|       <_description> | ||||
|       <summary>Which keyboard to use</summary> | ||||
|       <description> | ||||
|         The type of keyboard to use. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|   </schema> | ||||
| 
 | ||||
| @@ -147,11 +147,11 @@ | ||||
|           gettext-domain="@GETTEXT_PACKAGE@"> | ||||
|     <key type="b" name="current-workspace-only"> | ||||
|       <default>false</default> | ||||
|       <_summary>Limit switcher to current workspace.</_summary> | ||||
|       <_description> | ||||
|       <summary>Limit switcher to current workspace.</summary> | ||||
|       <description> | ||||
| 	If true, only applications that have windows on the current workspace are shown in the switcher. | ||||
| 	Otherwise, all applications are included. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|   </schema> | ||||
| 
 | ||||
| @@ -165,20 +165,20 @@ | ||||
|           gettext-domain="@GETTEXT_PACKAGE@"> | ||||
|     <key name="app-icon-mode" enum="org.gnome.shell.window-switcher.AppIconMode"> | ||||
|       <default>'both'</default> | ||||
|       <_summary>The application icon mode.</_summary> | ||||
|       <_description> | ||||
|       <summary>The application icon mode.</summary> | ||||
|       <description> | ||||
| 	Configures how the windows are shown in the switcher. Valid possibilities | ||||
| 	are 'thumbnail-only' (shows a thumbnail of the window), 'app-icon-only' | ||||
| 	(shows only the application icon) or 'both'. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|     <key type="b" name="current-workspace-only"> | ||||
|       <default>true</default> | ||||
|       <_summary>Limit switcher to current workspace.</_summary> | ||||
|       <_description> | ||||
|       <summary>Limit switcher to current workspace.</summary> | ||||
|       <description> | ||||
| 	If true, only windows from the current workspace are shown in the switcher. | ||||
| 	Otherwise, all windows are included. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|   </schema> | ||||
| 
 | ||||
| @@ -186,43 +186,43 @@ | ||||
| 	  gettext-domain="@GETTEXT_PACKAGE@"> | ||||
|     <key name="attach-modal-dialogs" type="b"> | ||||
|       <default>true</default> | ||||
|       <_summary>Attach modal dialog to the parent window</_summary> | ||||
|       <_description> | ||||
|       <summary>Attach modal dialog to the parent window</summary> | ||||
|       <description> | ||||
|         This key overrides the key in org.gnome.mutter when running | ||||
|         GNOME Shell. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
| 
 | ||||
|     <key name="edge-tiling" type="b"> | ||||
|       <default>true</default> | ||||
|       <_summary>Enable edge tiling when dropping windows on screen edges</_summary> | ||||
|       <_description> | ||||
|       <summary>Enable edge tiling when dropping windows on screen edges</summary> | ||||
|       <description> | ||||
|         This key overrides the key in org.gnome.mutter when running GNOME Shell. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
| 
 | ||||
|     <key name="dynamic-workspaces" type="b"> | ||||
|       <default>true</default> | ||||
|       <_summary>Workspaces are managed dynamically</_summary> | ||||
|       <_description> | ||||
|       <summary>Workspaces are managed dynamically</summary> | ||||
|       <description> | ||||
|         This key overrides the key in org.gnome.mutter when running GNOME Shell. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
| 
 | ||||
|     <key name="workspaces-only-on-primary" type="b"> | ||||
|       <default>true</default> | ||||
|       <_summary>Workspaces only on primary monitor</_summary> | ||||
|       <_description> | ||||
|       <summary>Workspaces only on primary monitor</summary> | ||||
|       <description> | ||||
|         This key overrides the key in org.gnome.mutter when running GNOME Shell. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
| 
 | ||||
|     <key name="focus-change-on-pointer-rest" type="b"> | ||||
|       <default>true</default> | ||||
|       <_summary>Delay focus changes in mouse mode until the pointer stops moving</_summary> | ||||
|       <_description> | ||||
|       <summary>Delay focus changes in mouse mode until the pointer stops moving</summary> | ||||
|       <description> | ||||
|         This key overrides the key in org.gnome.mutter when running GNOME Shell. | ||||
|       </_description> | ||||
|       </description> | ||||
|     </key> | ||||
|   </schema> | ||||
| </schemalist> | ||||
| @@ -427,6 +427,29 @@ StScrollBar { | ||||
| .audio-selection-device-icon { | ||||
|   icon-size: 64px; } | ||||
|  | ||||
| /* Access Dialog */ | ||||
| .access-dialog { | ||||
|   spacing: 30px; } | ||||
|  | ||||
| .access-dialog-main-layout { | ||||
|   padding: 12px 20px 0; | ||||
|   spacing: 12px; } | ||||
|  | ||||
| .access-dialog-content { | ||||
|   max-width: 28em; | ||||
|   spacing: 20px; } | ||||
|  | ||||
| .access-dialog-icon { | ||||
|   min-width: 48px; | ||||
|   icon-size: 48px; } | ||||
|  | ||||
| .access-dialog-title { | ||||
|   font-weight: bold; } | ||||
|  | ||||
| .access-dialog-subtitle { | ||||
|   color: #999999; | ||||
|   font-weight: bold; } | ||||
|  | ||||
| /* Geolocation Dialog */ | ||||
| .geolocation-dialog { | ||||
|   spacing: 30px; } | ||||
| @@ -581,6 +604,10 @@ StScrollBar { | ||||
|   width: 96px; | ||||
|   height: 96px; } | ||||
|  | ||||
| /* Window Cycler */ | ||||
| .cycler-highlight { | ||||
|   border: 5px solid #215d9c; } | ||||
|  | ||||
| /* Workspace Switcher */ | ||||
| .workspace-switcher-group { | ||||
|   padding: 12px; } | ||||
| @@ -769,7 +796,7 @@ StScrollBar { | ||||
|   border-radius: 1.4em; } | ||||
|   .calendar-day-base:hover, .calendar-day-base:focus { | ||||
|     background-color: #0d0d0d; } | ||||
|   .calendar-day-base:active { | ||||
|   .calendar-day-base:active, .calendar-day-base:selected { | ||||
|     color: white; | ||||
|     background-color: #215d9c; | ||||
|     border-color: transparent; } | ||||
|   | ||||
 Submodule data/theme/gnome-shell-sass updated: 31aac7f7b5...b2190083c2
									
								
							| @@ -427,6 +427,29 @@ StScrollBar { | ||||
| .audio-selection-device-icon { | ||||
|   icon-size: 64px; } | ||||
|  | ||||
| /* Access Dialog */ | ||||
| .access-dialog { | ||||
|   spacing: 30px; } | ||||
|  | ||||
| .access-dialog-main-layout { | ||||
|   padding: 12px 20px 0; | ||||
|   spacing: 12px; } | ||||
|  | ||||
| .access-dialog-content { | ||||
|   max-width: 28em; | ||||
|   spacing: 20px; } | ||||
|  | ||||
| .access-dialog-icon { | ||||
|   min-width: 48px; | ||||
|   icon-size: 48px; } | ||||
|  | ||||
| .access-dialog-title { | ||||
|   font-weight: bold; } | ||||
|  | ||||
| .access-dialog-subtitle { | ||||
|   color: #8e8e80; | ||||
|   font-weight: bold; } | ||||
|  | ||||
| /* Geolocation Dialog */ | ||||
| .geolocation-dialog { | ||||
|   spacing: 30px; } | ||||
| @@ -581,6 +604,10 @@ StScrollBar { | ||||
|   width: 96px; | ||||
|   height: 96px; } | ||||
|  | ||||
| /* Window Cycler */ | ||||
| .cycler-highlight { | ||||
|   border: 5px solid #215d9c; } | ||||
|  | ||||
| /* Workspace Switcher */ | ||||
| .workspace-switcher-group { | ||||
|   padding: 12px; } | ||||
| @@ -769,7 +796,7 @@ StScrollBar { | ||||
|   border-radius: 1.4em; } | ||||
|   .calendar-day-base:hover, .calendar-day-base:focus { | ||||
|     background-color: #454c4c; } | ||||
|   .calendar-day-base:active { | ||||
|   .calendar-day-base:active, .calendar-day-base:selected { | ||||
|     color: white; | ||||
|     background-color: #215d9c; | ||||
|     border-color: transparent; } | ||||
|   | ||||
| @@ -152,6 +152,7 @@ const Application = new Lang.Class({ | ||||
|         let scroll = new Gtk.ScrolledWindow({ hscrollbar_policy: Gtk.PolicyType.NEVER, | ||||
|                                               shadow_type: Gtk.ShadowType.IN, | ||||
|                                               halign: Gtk.Align.CENTER, | ||||
|                                               propagate_natural_width: true, | ||||
|                                               margin: 18 }); | ||||
|         this._window.add(scroll); | ||||
|  | ||||
|   | ||||
| @@ -804,6 +804,11 @@ const LoginDialog = new Lang.Class({ | ||||
|  | ||||
|         this._user = null; | ||||
|  | ||||
|         if (this._nextSignalId) { | ||||
|             this._authPrompt.disconnect(this._nextSignalId); | ||||
|             this._nextSignalId = 0; | ||||
|         } | ||||
|  | ||||
|         if (beginRequest == AuthPrompt.BeginRequestType.PROVIDE_USERNAME) { | ||||
|             if (!this._disableUserList) | ||||
|                 this._showUserList(); | ||||
|   | ||||
| @@ -31,6 +31,7 @@ | ||||
|  | ||||
|     <file>portalHelper/main.js</file> | ||||
|  | ||||
|     <file>ui/accessDialog.js</file> | ||||
|     <file>ui/altTab.js</file> | ||||
|     <file>ui/animation.js</file> | ||||
|     <file>ui/appDisplay.js</file> | ||||
|   | ||||
| @@ -6,9 +6,7 @@ | ||||
| const Lang = imports.lang; | ||||
| const Signals = imports.signals; | ||||
|  | ||||
| const GLib = imports.gi.GLib; | ||||
| const Gio = imports.gi.Gio; | ||||
| const ShellJS = imports.gi.ShellJS; | ||||
|  | ||||
| const Config = imports.misc.config; | ||||
| const FileUtils = imports.misc.fileUtils; | ||||
| @@ -140,12 +138,11 @@ function createExtensionObject(uuid, dir, type) { | ||||
|     return extension; | ||||
| } | ||||
|  | ||||
| var _extension = null; | ||||
|  | ||||
| function installImporter(extension) { | ||||
|     _extension = extension; | ||||
|     ShellJS.add_extension_importer('imports.misc.extensionUtils._extension', 'imports', extension.path); | ||||
|     _extension = null; | ||||
|     let oldSearchPath = imports.searchPath.slice();  // make a copy | ||||
|     imports.searchPath = [extension.path]; | ||||
|     extension.imports = imports['.'];  // "subdir" creates a new importer object | ||||
|     imports.searchPath = oldSearchPath; | ||||
| } | ||||
|  | ||||
| const ExtensionFinder = new Lang.Class({ | ||||
|   | ||||
							
								
								
									
										202
									
								
								js/ui/accessDialog.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										202
									
								
								js/ui/accessDialog.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,202 @@ | ||||
| const Clutter = imports.gi.Clutter; | ||||
| const Gio = imports.gi.Gio; | ||||
| const GLib = imports.gi.GLib; | ||||
| const Lang = imports.lang; | ||||
| const Pango = imports.gi.Pango; | ||||
| const Shell = imports.gi.Shell; | ||||
| const St = imports.gi.St; | ||||
|  | ||||
| const CheckBox = imports.ui.checkBox; | ||||
| const ModalDialog = imports.ui.modalDialog; | ||||
|  | ||||
| const RequestIface = '<node> \ | ||||
| <interface name="org.freedesktop.impl.portal.Request"> \ | ||||
| <method name="Close"/> \ | ||||
| </interface> \ | ||||
| </node>'; | ||||
|  | ||||
| const AccessIface = '<node> \ | ||||
| <interface name="org.freedesktop.impl.portal.Access"> \ | ||||
| <method name="AccessDialog"> \ | ||||
|   <arg type="o" name="handle" direction="in"/> \ | ||||
|   <arg type="s" name="app_id" direction="in"/> \ | ||||
|   <arg type="s" name="parent_window" direction="in"/> \ | ||||
|   <arg type="s" name="title" direction="in"/> \ | ||||
|   <arg type="s" name="subtitle" direction="in"/> \ | ||||
|   <arg type="s" name="body" direction="in"/> \ | ||||
|   <arg type="a{sv}" name="options" direction="in"/> \ | ||||
|   <arg type="u" name="response" direction="out"/> \ | ||||
|   <arg type="a{sv}" name="results" direction="out"/> \ | ||||
| </method> \ | ||||
| </interface> \ | ||||
| </node>'; | ||||
|  | ||||
| const DialogResponse = { | ||||
|     OK: 0, | ||||
|     CANCEL: 1, | ||||
|     CLOSED: 2 | ||||
| }; | ||||
|  | ||||
| const AccessDialog = new Lang.Class({ | ||||
|     Name: 'AccessDialog', | ||||
|     Extends: ModalDialog.ModalDialog, | ||||
|  | ||||
|     _init: function(invocation, handle, title, subtitle, body, options) { | ||||
|         this.parent({ styleClass: 'access-dialog' }); | ||||
|  | ||||
|         this._invocation = invocation; | ||||
|         this._handle = handle; | ||||
|  | ||||
|         this._requestExported = false; | ||||
|         this._request = Gio.DBusExportedObject.wrapJSObject(RequestIface, this); | ||||
|  | ||||
|         for (let option in options) | ||||
|             options[option] = options[option].deep_unpack(); | ||||
|  | ||||
|         this._buildLayout(title, subtitle, body, options); | ||||
|     }, | ||||
|  | ||||
|     _buildLayout: function(title, subtitle, body, options) { | ||||
|         // No support for non-modal system dialogs, so ignore the option | ||||
|         //let modal = options['modal'] || true; | ||||
|         let denyLabel = options['deny_label'] || _("Deny Access"); | ||||
|         let grantLabel = options['grant_label'] || _("Grant Access"); | ||||
|         let iconName = options['icon'] || null; | ||||
|         let choices = options['choices'] || []; | ||||
|  | ||||
|         let mainContentBox = new St.BoxLayout(); | ||||
|         mainContentBox.style_class = 'access-dialog-main-layout'; | ||||
|         this.contentLayout.add_actor(mainContentBox); | ||||
|  | ||||
|         let icon = new St.Icon({ style_class: 'access-dialog-icon', | ||||
|                                  icon_name: iconName, | ||||
|                                  y_align: Clutter.ActorAlign.START }); | ||||
|         mainContentBox.add_actor(icon); | ||||
|  | ||||
|         let messageBox = new St.BoxLayout({ vertical: true }); | ||||
|         messageBox.style_class = 'access-dialog-content', | ||||
|         mainContentBox.add_actor(messageBox); | ||||
|  | ||||
|         let label; | ||||
|         label = new St.Label({ style_class: 'access-dialog-title headline', | ||||
|                                text: title }); | ||||
|         messageBox.add_actor(label); | ||||
|  | ||||
|         label = new St.Label({ style_class: 'access-dialog-subtitle', | ||||
|                                text: subtitle }); | ||||
|         label.clutter_text.ellipsize = Pango.EllipsizeMode.NONE; | ||||
|         label.clutter_text.line_wrap = true; | ||||
|         messageBox.add_actor(label); | ||||
|  | ||||
|         this._choices = new Map(); | ||||
|  | ||||
|         for (let i = 0; i < choices.length; i++) { | ||||
|             let [id, name, opts, selected] = choices[i]; | ||||
|             if (opts.length > 0) | ||||
|                 continue; // radio buttons, not implemented | ||||
|  | ||||
|             let check = new CheckBox.CheckBox(); | ||||
|             check.getLabelActor().text = name; | ||||
|             check.actor.checked = selected == "true"; | ||||
|             messageBox.add_actor(check.actor); | ||||
|  | ||||
|             this._choices.set(id, check); | ||||
|         } | ||||
|  | ||||
|         label = new St.Label({ text: body }); | ||||
|         label.clutter_text.ellipsize = Pango.EllipsizeMode.NONE; | ||||
|         label.clutter_text.line_wrap = true; | ||||
|         messageBox.add_actor(label); | ||||
|  | ||||
|         this.addButton({ label: denyLabel, | ||||
|                          action: () => { | ||||
|                              this._sendResponse(DialogResponse.CANCEL); | ||||
|                          }, | ||||
|                          key: Clutter.KEY_Escape }); | ||||
|         this.addButton({ label: grantLabel, | ||||
|                          action: () => { | ||||
|                              this._sendResponse(DialogResponse.OK); | ||||
|                          }}); | ||||
|     }, | ||||
|  | ||||
|     open: function() { | ||||
|         this.parent(); | ||||
|  | ||||
|         let connection = this._invocation.get_connection(); | ||||
|         this._requestExported = this._request.export(connection, this._handle); | ||||
|     }, | ||||
|  | ||||
|     CloseAsync: function(invocation, params) { | ||||
|         if (this._invocation.get_sender() != invocation.get_sender()) { | ||||
|             invocation.return_error_literal(Gio.DBusError, | ||||
|                                             Gio.DBusError.ACCESS_DENIED, | ||||
|                                             ''); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         this._sendResponse(DialogResponse.CLOSED); | ||||
|     }, | ||||
|  | ||||
|     _sendResponse: function(response) { | ||||
|         if (this._requestExported) | ||||
|             this._request.unexport(); | ||||
|         this._requestExported = false; | ||||
|  | ||||
|         let results = {}; | ||||
|         if (response == DialogResponse.OK) { | ||||
|             for (let [id, check] of this._choices) { | ||||
|                 let checked = check.actor.checked ? 'true' : 'false'; | ||||
|                 results[id] = new GLib.Variant('s', checked); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         // Delay actual response until the end of the close animation (if any) | ||||
|         this.connect('closed', () => { | ||||
|             this._invocation.return_value(new GLib.Variant('(ua{sv})', | ||||
|                                                            [response, results])); | ||||
|         }); | ||||
|         this.close(); | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const AccessDialogDBus = new Lang.Class({ | ||||
|     Name: 'AccessDialogDBus', | ||||
|  | ||||
|     _init: function() { | ||||
|         this._accessDialog = null; | ||||
|  | ||||
|         this._windowTracker = Shell.WindowTracker.get_default(); | ||||
|  | ||||
|         this._dbusImpl = Gio.DBusExportedObject.wrapJSObject(AccessIface, this); | ||||
|         this._dbusImpl.export(Gio.DBus.session, '/org/freedesktop/portal/desktop'); | ||||
|  | ||||
|         Gio.DBus.session.own_name('org.freedesktop.impl.portal.desktop.gnome', Gio.BusNameOwnerFlags.REPLACE, null, null); | ||||
|     }, | ||||
|  | ||||
|     AccessDialogAsync: function(params, invocation) { | ||||
|         if (this._accessDialog) { | ||||
|             invocation.return_error_literal(Gio.DBusError, | ||||
|                                             Gio.DBusError.LIMITS_EXCEEDED, | ||||
|                                             'Already showing a system access dialog'); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         let [handle, appId, parentWindow, title, subtitle, body, options] = params; | ||||
|         // We probably want to use parentWindow and global.display.focus_window | ||||
|         // for this check in the future | ||||
|         if (appId && appId + '.desktop' != this._windowTracker.focus_app.id) { | ||||
|             invocation.return_error_literal(Gio.DBusError, | ||||
|                                             Gio.DBusError.ACCESS_DENIED, | ||||
|                                             'Only the focused app is allowed to show a system access dialog'); | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         let dialog = new AccessDialog(invocation, handle, title, | ||||
|                                       subtitle, body, options); | ||||
|         dialog.open(); | ||||
|  | ||||
|         dialog.connect('closed', () => { this._accessDialog = null; }); | ||||
|  | ||||
|         this._accessDialog = dialog; | ||||
|     } | ||||
| }); | ||||
| @@ -354,6 +354,67 @@ const AppSwitcherPopup = new Lang.Class({ | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const CyclerHighlight = new Lang.Class({ | ||||
|     Name: 'CyclerHighlight', | ||||
|  | ||||
|     _init: function() { | ||||
|         this._window = null; | ||||
|  | ||||
|         this.actor = new St.Widget({ layout_manager: new Clutter.BinLayout() }); | ||||
|  | ||||
|         this._clone = new Clutter.Clone(); | ||||
|         this.actor.add_actor(this._clone); | ||||
|  | ||||
|         this._highlight = new St.Widget({ style_class: 'cycler-highlight' }); | ||||
|         this.actor.add_actor(this._highlight); | ||||
|  | ||||
|         let coordinate = Clutter.BindCoordinate.ALL; | ||||
|         let constraint = new Clutter.BindConstraint({ coordinate: coordinate }); | ||||
|         this._clone.bind_property('source', constraint, 'source', 0); | ||||
|  | ||||
|         this.actor.add_constraint(constraint); | ||||
|  | ||||
|         this.actor.connect('notify::allocation', | ||||
|                            Lang.bind(this, this._onAllocationChanged)); | ||||
|         this.actor.connect('destroy', Lang.bind(this, this._onDestroy)); | ||||
|     }, | ||||
|  | ||||
|     set window(w) { | ||||
|         if (this._window == w) | ||||
|             return; | ||||
|  | ||||
|         this._window = w; | ||||
|  | ||||
|         if (this._clone.source) | ||||
|             this._clone.source.sync_visibility(); | ||||
|  | ||||
|         let windowActor = this._window ? this._window.get_compositor_private() | ||||
|                                        : null; | ||||
|  | ||||
|         if (windowActor) | ||||
|             windowActor.hide(); | ||||
|  | ||||
|         this._clone.source = windowActor; | ||||
|     }, | ||||
|  | ||||
|     _onAllocationChanged: function() { | ||||
|         if (!this._window) { | ||||
|             this._highlight.set_size(0, 0); | ||||
|             this._highlight.hide(); | ||||
|         } else { | ||||
|             let [x, y] = this.actor.allocation.get_origin(); | ||||
|             let rect = this._window.get_frame_rect(); | ||||
|             this._highlight.set_size(rect.width, rect.height); | ||||
|             this._highlight.set_position(rect.x - x, rect.y - y); | ||||
|             this._highlight.show(); | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     _onDestroy: function() { | ||||
|         this.window = null; | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const CyclerPopup = new Lang.Class({ | ||||
|     Name: 'CyclerPopup', | ||||
|     Extends: SwitcherPopup.SwitcherPopup, | ||||
| @@ -367,6 +428,9 @@ const CyclerPopup = new Lang.Class({ | ||||
|         if (this._items.length == 0) | ||||
|             return; | ||||
|  | ||||
|         this._highlight = new CyclerHighlight(); | ||||
|         global.window_group.add_actor(this._highlight.actor); | ||||
|  | ||||
|         // We don't show an actual popup, so just provide what SwitcherPopup | ||||
|         // expects instead of inheriting from SwitcherList | ||||
|         this._switcherList = { actor: new St.Widget(), | ||||
| @@ -375,11 +439,37 @@ const CyclerPopup = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     _highlightItem: function(index, justOutline) { | ||||
|         Main.activateWindow(this._items[index]); | ||||
|         this._highlight.window = this._items[index]; | ||||
|         global.window_group.set_child_above_sibling(this._highlight.actor, null); | ||||
|     }, | ||||
|  | ||||
|     _finish: function() { | ||||
|         this._highlightItem(this._selectedIndex); | ||||
|         let window = this._items[this._selectedIndex]; | ||||
|         let ws = window.get_workspace(); | ||||
|         let activeWs = global.screen.get_active_workspace(); | ||||
|  | ||||
|         if (window.minimized) { | ||||
|             Main.wm.skipNextEffect(window.get_compositor_private()); | ||||
|             window.unminimize(); | ||||
|         } | ||||
|  | ||||
|         if (activeWs == ws) { | ||||
|             Main.activateWindow(window); | ||||
|         } else { | ||||
|             // If the selected window is on a different workspace, we don't | ||||
|             // want it to disappear, then slide in with the workspace; instead, | ||||
|             // always activate it on the active workspace ... | ||||
|             activeWs.activate_with_focus(window, global.get_current_time()); | ||||
|  | ||||
|             // ... then slide it over to the original workspace if necessary | ||||
|             Main.wm.actionMoveWindow(window, ws); | ||||
|         } | ||||
|  | ||||
|         this.parent(); | ||||
|     }, | ||||
|  | ||||
|     _onDestroy: function() { | ||||
|         this._highlight.actor.destroy(); | ||||
|  | ||||
|         this.parent(); | ||||
|     } | ||||
|   | ||||
| @@ -696,6 +696,7 @@ const BackgroundManager = new Lang.Class({ | ||||
|                            time: FADE_ANIMATION_TIME, | ||||
|                            transition: 'easeOutQuad', | ||||
|                            onComplete: function() { | ||||
|                                oldBackgroundActor.background.run_dispose(); | ||||
|                                oldBackgroundActor.destroy(); | ||||
|                            } | ||||
|                          }); | ||||
|   | ||||
| @@ -120,6 +120,9 @@ const EmptyEventSource = new Lang.Class({ | ||||
|     destroy: function() { | ||||
|     }, | ||||
|  | ||||
|     ignoreEvent: function(event) { | ||||
|     }, | ||||
|  | ||||
|     requestRange: function(begin, end) { | ||||
|     }, | ||||
|  | ||||
| @@ -184,6 +187,15 @@ const DBusEventSource = new Lang.Class({ | ||||
|         this.isLoading = false; | ||||
|         this.isDummy = false; | ||||
|  | ||||
|         this._ignoredEvents = new Map(); | ||||
|  | ||||
|         let savedState = global.get_persistent_state('as', 'ignored_events'); | ||||
|         if (savedState) | ||||
|             savedState.deep_unpack().forEach(Lang.bind(this, | ||||
|                 function(eventId) { | ||||
|                     this._ignoredEvents.set(eventId, true); | ||||
|                 })); | ||||
|  | ||||
|         this._initialized = false; | ||||
|         this._dbusProxy = new CalendarServer(); | ||||
|         this._dbusProxy.init_async(GLib.PRIORITY_DEFAULT, null, Lang.bind(this, function(object, result) { | ||||
| @@ -298,6 +310,16 @@ const DBusEventSource = new Lang.Class({ | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     ignoreEvent: function(event) { | ||||
|         if (this._ignoredEvents.get(event.id)) | ||||
|             return; | ||||
|  | ||||
|         this._ignoredEvents.set(event.id, true); | ||||
|         let savedState = new GLib.Variant('as', [...this._ignoredEvents.keys()]); | ||||
|         global.set_persistent_state('ignored_events', savedState); | ||||
|         this.emit('changed'); | ||||
|     }, | ||||
|  | ||||
|     requestRange: function(begin, end) { | ||||
|         if (!(_datesEqual(begin, this._lastRequestBegin) && _datesEqual(end, this._lastRequestEnd))) { | ||||
|             this.isLoading = true; | ||||
| @@ -313,6 +335,10 @@ const DBusEventSource = new Lang.Class({ | ||||
|         let result = []; | ||||
|         for(let n = 0; n < this._events.length; n++) { | ||||
|             let event = this._events[n]; | ||||
|  | ||||
|             if (this._ignoredEvents.has(event.id)) | ||||
|                 continue; | ||||
|  | ||||
|             if (_dateIntervalsOverlap (event.date, event.end, begin, end)) { | ||||
|                 result.push(event); | ||||
|             } | ||||
| @@ -660,12 +686,12 @@ const Calendar = new Lang.Class({ | ||||
|  | ||||
|         this._buttons.forEach(Lang.bind(this, function(button) { | ||||
|             if (sameDay(button._date, this._selectedDate)) { | ||||
|                 button.add_style_pseudo_class('active'); | ||||
|                 button.add_style_pseudo_class('selected'); | ||||
|                 if (this._shouldDateGrabFocus) | ||||
|                     button.grab_key_focus(); | ||||
|             } | ||||
|             else | ||||
|                 button.remove_style_pseudo_class('active'); | ||||
|                 button.remove_style_pseudo_class('selected'); | ||||
|         })); | ||||
|     } | ||||
| }); | ||||
| @@ -785,15 +811,6 @@ const EventsSection = new Lang.Class({ | ||||
|         this._desktopSettings.connect('changed', Lang.bind(this, this._reloadEvents)); | ||||
|         this._eventSource = new EmptyEventSource(); | ||||
|  | ||||
|         this._ignoredEvents = new Map(); | ||||
|  | ||||
|         let savedState = global.get_persistent_state('as', 'ignored_events'); | ||||
|         if (savedState) | ||||
|             savedState.deep_unpack().forEach(Lang.bind(this, | ||||
|                 function(eventId) { | ||||
|                     this._ignoredEvents.set(eventId, true); | ||||
|                 })); | ||||
|  | ||||
|         this.parent(''); | ||||
|  | ||||
|         Shell.AppSystem.get_default().connect('installed-changed', | ||||
| @@ -802,9 +819,7 @@ const EventsSection = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     _ignoreEvent: function(event) { | ||||
|         this._ignoredEvents.set(event.id, true); | ||||
|         let savedState = new GLib.Variant('as', [...this._ignoredEvents.keys()]); | ||||
|         global.set_persistent_state('ignored_events', savedState); | ||||
|         this._eventSource.ignoreEvent(event); | ||||
|     }, | ||||
|  | ||||
|     setEventSource: function(eventSource) { | ||||
| @@ -850,9 +865,6 @@ const EventsSection = new Lang.Class({ | ||||
|         for (let i = 0; i < events.length; i++) { | ||||
|             let event = events[i]; | ||||
|  | ||||
|             if (this._ignoredEvents.has(event.id)) | ||||
|                 continue; | ||||
|  | ||||
|             let message = new EventMessage(event, this._date); | ||||
|             message.connect('close', Lang.bind(this, function() { | ||||
|                 this._ignoreEvent(event); | ||||
|   | ||||
| @@ -475,6 +475,11 @@ const ChatSource = new Lang.Class({ | ||||
|             this._channel.close_async(function(channel, result) { | ||||
|                 channel.close_finish(result); | ||||
|             }); | ||||
|         } else { | ||||
|             // Don't indicate any unread messages when the notification | ||||
|             // that represents them has been destroyed. | ||||
|             this._pendingMessages = []; | ||||
|             this.countUpdated(); | ||||
|         } | ||||
|  | ||||
|         // Keep source alive while the channel is open | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||
| /* | ||||
|  * Copyright 2010 Red Hat, Inc | ||||
|  * Copyright 2010-2016 Red Hat, Inc | ||||
|  * | ||||
|  * This program is free software; you can redistribute it and/or modify | ||||
|  * it under the terms of the GNU General Public License as published by | ||||
| @@ -114,7 +114,7 @@ const restartDialogContent = { | ||||
|     showOtherSessions: true, | ||||
| }; | ||||
|  | ||||
| const restartInstallDialogContent = { | ||||
| const restartUpdateDialogContent = { | ||||
|  | ||||
|     subject: C_("title", "Restart & Install Updates"), | ||||
|     description: function(seconds) { | ||||
| @@ -132,18 +132,38 @@ const restartInstallDialogContent = { | ||||
|     showOtherSessions: true, | ||||
| }; | ||||
|  | ||||
| const restartUpgradeDialogContent = { | ||||
|  | ||||
|     subject: C_("title", "Restart & Install Upgrade"), | ||||
|     upgradeDescription: function(distroName, distroVersion) { | ||||
|         /* Translators: This is the text displayed for system upgrades in the | ||||
|            shut down dialog. First %s gets replaced with the distro name and | ||||
|            second %s with the distro version to upgrade to */ | ||||
|         return _("%s %s will be installed after restart. Upgrade installation can take a long time: ensure that you have backed up and that the computer is plugged in.").format(distroName, distroVersion); | ||||
|     }, | ||||
|     disableTimer: true, | ||||
|     showBatteryWarning: false, | ||||
|     confirmButtons: [{ signal: 'ConfirmedReboot', | ||||
|                        label:  C_("button", "Restart & Install") }], | ||||
|     iconName: 'view-refresh-symbolic', | ||||
|     iconStyleClass: 'end-session-dialog-shutdown-icon', | ||||
|     showOtherSessions: true, | ||||
| }; | ||||
|  | ||||
| const DialogType = { | ||||
|   LOGOUT: 0 /* GSM_SHELL_END_SESSION_DIALOG_TYPE_LOGOUT */, | ||||
|   SHUTDOWN: 1 /* GSM_SHELL_END_SESSION_DIALOG_TYPE_SHUTDOWN */, | ||||
|   RESTART: 2 /* GSM_SHELL_END_SESSION_DIALOG_TYPE_RESTART */, | ||||
|   UPDATE_RESTART: 3 | ||||
|   UPDATE_RESTART: 3, | ||||
|   UPGRADE_RESTART: 4 | ||||
| }; | ||||
|  | ||||
| const DialogContent = { | ||||
|     0 /* DialogType.LOGOUT */: logoutDialogContent, | ||||
|     1 /* DialogType.SHUTDOWN */: shutdownDialogContent, | ||||
|     2 /* DialogType.RESTART */: restartDialogContent, | ||||
|     3 /* DialogType.UPDATE_RESTART */: restartInstallDialogContent | ||||
|     3 /* DialogType.UPDATE_RESTART */: restartUpdateDialogContent, | ||||
|     4 /* DialogType.UPGRADE_RESTART */: restartUpgradeDialogContent | ||||
| }; | ||||
|  | ||||
| const MAX_USERS_IN_SESSION_DIALOG = 5; | ||||
| @@ -163,7 +183,10 @@ const LogindSession = Gio.DBusProxy.makeProxyWrapper(LogindSessionIface); | ||||
| const PkOfflineIface = '<node> \ | ||||
| <interface name="org.freedesktop.PackageKit.Offline"> \ | ||||
|     <property name="UpdatePrepared" type="b" access="read"/> \ | ||||
|     <property name="TriggerAction" type="s" access="read"/> \ | ||||
|     <property name="UpdateTriggered" type="b" access="read"/> \ | ||||
|     <property name="UpgradePrepared" type="b" access="read"/> \ | ||||
|     <property name="UpgradeTriggered" type="b" access="read"/> \ | ||||
|     <property name="PreparedUpgrade" type="a{sv}" access="read"/> \ | ||||
|     <method name="Trigger"> \ | ||||
|         <arg type="s" name="action" direction="in"/> \ | ||||
|     </method> \ | ||||
| @@ -415,11 +438,19 @@ const EndSessionDialog = new Lang.Class({ | ||||
|  | ||||
|                 if (dialogContent.descriptionWithUser) | ||||
|                     description = dialogContent.descriptionWithUser(realName, displayTime); | ||||
|                 else | ||||
|                     description = dialogContent.description(displayTime); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         // Use a different description when we are installing a system upgrade | ||||
|         if (dialogContent.upgradeDescription) { | ||||
|             let name = this._pkOfflineProxy.PreparedUpgrade['name'].deep_unpack(); | ||||
|             let version = this._pkOfflineProxy.PreparedUpgrade['version'].deep_unpack(); | ||||
|  | ||||
|             if (name != null && version != null) | ||||
|                 description = dialogContent.upgradeDescription(name, version); | ||||
|         } | ||||
|  | ||||
|         // Fall back to regular description | ||||
|         if (!description) | ||||
|             description = dialogContent.description(displayTime); | ||||
|  | ||||
| @@ -698,9 +729,12 @@ const EndSessionDialog = new Lang.Class({ | ||||
|         this._totalSecondsToStayOpen = totalSecondsToStayOpen; | ||||
|         this._type = type; | ||||
|  | ||||
|         if (this._type == DialogType.RESTART && | ||||
|             this._pkOfflineProxy.TriggerAction == 'reboot') | ||||
|             this._type = DialogType.UPDATE_RESTART; | ||||
|         if (this._type == DialogType.RESTART) { | ||||
|             if (this._pkOfflineProxy.UpdateTriggered) | ||||
|                 this._type = DialogType.UPDATE_RESTART; | ||||
|             else if (this._pkOfflineProxy.UpgradeTriggered) | ||||
|                 this._type = DialogType.UPGRADE_RESTART; | ||||
|         } | ||||
|  | ||||
|         this._applications = []; | ||||
|         this._applicationList.destroy_all_children(); | ||||
| @@ -727,19 +761,19 @@ const EndSessionDialog = new Lang.Class({ | ||||
|         if (dialogContent.showOtherSessions) | ||||
|             this._loadSessions(); | ||||
|  | ||||
|         let updateAlreadyTriggered = this._pkOfflineProxy.TriggerAction == 'power-off' || this._pkOfflineProxy.TriggerAction == 'reboot'; | ||||
|         let updateTriggered = this._pkOfflineProxy.UpdateTriggered; | ||||
|         let updatePrepared = this._pkOfflineProxy.UpdatePrepared; | ||||
|         let updatesAllowed = this._updatesPermission && this._updatesPermission.allowed; | ||||
|  | ||||
|         _setCheckBoxLabel(this._checkBox, dialogContent.checkBoxText); | ||||
|         this._checkBox.actor.visible = (dialogContent.checkBoxText && updatePrepared && updatesAllowed); | ||||
|         this._checkBox.actor.checked = (updatePrepared && updateAlreadyTriggered); | ||||
|         this._checkBox.actor.checked = (updatePrepared && updateTriggered); | ||||
|  | ||||
|         // We show the warning either together with the checkbox, or when | ||||
|         // updates have already been triggered, but the user doesn't have | ||||
|         // enough permissions to cancel them. | ||||
|         this._batteryWarning.visible = (dialogContent.showBatteryWarning && | ||||
|                                         (this._checkBox.actor.visible || updatePrepared && updateAlreadyTriggered && !updatesAllowed)); | ||||
|                                         (this._checkBox.actor.visible || updatePrepared && updateTriggered && !updatesAllowed)); | ||||
|  | ||||
|         this._updateButtons(); | ||||
|  | ||||
| @@ -749,7 +783,9 @@ const EndSessionDialog = new Lang.Class({ | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         this._startTimer(); | ||||
|         if (!dialogContent.disableTimer) | ||||
|             this._startTimer(); | ||||
|  | ||||
|         this._sync(); | ||||
|  | ||||
|         let signalId = this.connect('opened', | ||||
|   | ||||
| @@ -10,6 +10,7 @@ const Meta = imports.gi.Meta; | ||||
| const Shell = imports.gi.Shell; | ||||
| const Signals = imports.signals; | ||||
| const St = imports.gi.St; | ||||
| const InputSourceManager = imports.ui.status.keyboard; | ||||
|  | ||||
| const BoxPointer = imports.ui.boxpointer; | ||||
| const Layout = imports.ui.layout; | ||||
| @@ -757,19 +758,48 @@ const ShellWaylandAdapter = new Lang.Class({ | ||||
|     Name: 'ShellWaylandAdapter', | ||||
|     Extends: Caribou.XAdapter, | ||||
|  | ||||
|     _init: function () { | ||||
|         this.parent(); | ||||
|         let deviceManager = Clutter.DeviceManager.get_default(); | ||||
|         this._virtualDevice = deviceManager.create_virtual_device(Clutter.InputDeviceType.KEYBOARD_DEVICE); | ||||
|  | ||||
|         this._inputSourceManager = InputSourceManager.getInputSourceManager(); | ||||
|         this._sourceChangedId = this._inputSourceManager.connect('current-source-changed', | ||||
|                                                                  Lang.bind(this, this._onSourceChanged)); | ||||
|         this._sourcesModifiedId = this._inputSourceManager.connect ('sources-changed', | ||||
|                                                                     Lang.bind(this, this._onSourcesModified)); | ||||
|     }, | ||||
|  | ||||
|     _onSourcesModified: function () { | ||||
|         this.emit('config-changed'); | ||||
|     }, | ||||
|  | ||||
|     _onSourceChanged: function (inputSourceManager, oldSource) { | ||||
|         let source = inputSourceManager.currentSource; | ||||
|         this.emit('group-changed', source.index, source.id, ''); | ||||
|     }, | ||||
|  | ||||
|     vfunc_get_groups: function () { | ||||
|         let inputSources = this._inputSourceManager.inputSources; | ||||
|         let groups = [] | ||||
|         let variants = []; | ||||
|  | ||||
|         for (let i in inputSources) { | ||||
|             let is = inputSources[i]; | ||||
|             groups[is.index] = is.id; | ||||
|             variants[is.index] = ''; | ||||
|         } | ||||
|  | ||||
|         return [groups, groups.length, variants, variants.length]; | ||||
|     }, | ||||
|  | ||||
|     vfunc_keyval_press: function(keyval) { | ||||
|         let focus = global.stage.get_key_focus(); | ||||
|         if (focus instanceof Clutter.Text) | ||||
|             Shell.util_text_insert_keyval(focus, keyval); | ||||
|         else | ||||
|             this.parent(keyval); | ||||
|         this._virtualDevice.notify_keyval(Clutter.get_current_event_time(), | ||||
|                                           keyval, Clutter.KeyState.PRESSED); | ||||
|     }, | ||||
|  | ||||
|     vfunc_keyval_release: function(keyval) { | ||||
|         let focus = global.stage.get_key_focus(); | ||||
|         if (focus instanceof Clutter.Text) | ||||
|             return;             // do nothing | ||||
|         else | ||||
|             this.parent(keyval); | ||||
|         this._virtualDevice.notify_keyval(Clutter.get_current_event_time(), | ||||
|                                           keyval, Clutter.KeyState.RELEASED); | ||||
|     }, | ||||
| }); | ||||
|   | ||||
| @@ -220,7 +220,8 @@ const LayoutManager = new Lang.Class({ | ||||
|         global.stage.add_child(this.uiGroup); | ||||
|  | ||||
|         this.overviewGroup = new St.Widget({ name: 'overviewGroup', | ||||
|                                              visible: false }); | ||||
|                                              visible: false, | ||||
|                                              reactive: true }); | ||||
|         this.addChrome(this.overviewGroup); | ||||
|  | ||||
|         this.screenShieldGroup = new St.Widget({ name: 'screenShieldGroup', | ||||
| @@ -591,7 +592,10 @@ const LayoutManager = new Lang.Class({ | ||||
|         this.addChrome(this._coverPane); | ||||
|  | ||||
|         if (Meta.is_restart()) { | ||||
|             // On restart, we don't do an animation | ||||
|             // On restart, we don't do an animation. Force an update of the | ||||
|             // regions immediately so that maximized windows restore to the | ||||
|             // right size taking struts into account. | ||||
|             this._updateRegions(); | ||||
|         } else if (Main.sessionMode.isGreeter) { | ||||
|             this.panelBox.translation_y = -this.panelBox.height; | ||||
|         } else { | ||||
| @@ -938,6 +942,11 @@ const LayoutManager = new Lang.Class({ | ||||
|         if (Main.modalCount > 0) | ||||
|             return GLib.SOURCE_REMOVE; | ||||
|  | ||||
|         // Bug workaround - get_transformed_position()/get_transformed_size() don't work after | ||||
|         // a change in stage size until the first pick or paint. | ||||
|         // https://bugzilla.gnome.org/show_bug.cgi?id=761565 | ||||
|         global.stage.get_actor_at_pos(Clutter.PickMode.ALL, 0, 0); | ||||
|  | ||||
|         let rects = [], struts = [], i; | ||||
|         let isPopupMenuVisible = global.top_window_group.get_children().some(isPopupMetaWindow); | ||||
|         let wantsInputRegion = !isPopupMenuVisible; | ||||
|   | ||||
| @@ -11,6 +11,7 @@ const Meta = imports.gi.Meta; | ||||
| const Shell = imports.gi.Shell; | ||||
| const St = imports.gi.St; | ||||
|  | ||||
| const AccessDialog = imports.ui.accessDialog; | ||||
| const AudioDeviceSelection = imports.ui.audioDeviceSelection; | ||||
| const Components = imports.ui.components; | ||||
| const CtrlAltTab = imports.ui.ctrlAltTab; | ||||
| @@ -63,6 +64,7 @@ let ctrlAltTabManager = null; | ||||
| let osdWindowManager = null; | ||||
| let osdMonitorLabeler = null; | ||||
| let sessionMode = null; | ||||
| let shellAccessDialogDBusService = null; | ||||
| let shellAudioSelectionDBusService = null; | ||||
| let shellDBusService = null; | ||||
| let shellMountOpDBusService = null; | ||||
| @@ -122,6 +124,7 @@ function start() { | ||||
|                                        _loadDefaultStylesheet); | ||||
|     _initializeUI(); | ||||
|  | ||||
|     shellAccessDialogDBusService = new AccessDialog.AccessDialogDBus(); | ||||
|     shellAudioSelectionDBusService = new AudioDeviceSelection.AudioDeviceSelectionDBus(); | ||||
|     shellDBusService = new ShellDBus.GnomeShell(); | ||||
|     shellMountOpDBusService = new ShellMountOperation.GnomeShellMountOpHandler(); | ||||
| @@ -191,6 +194,8 @@ function _initializeUI() { | ||||
|         return true; | ||||
|     }); | ||||
|  | ||||
|     global.display.connect('gl-video-memory-purged', loadTheme); | ||||
|  | ||||
|     // Provide the bus object for gnome-session to | ||||
|     // initiate logouts. | ||||
|     EndSessionDialog.init(); | ||||
|   | ||||
| @@ -27,6 +27,8 @@ const LevelBar = new Lang.Class({ | ||||
|         this._bar = new St.Widget({ style_class: 'level-bar' }); | ||||
|  | ||||
|         this.actor.set_child(this._bar); | ||||
|  | ||||
|         this.actor.connect('notify::width', () => { this.level = this.level; }); | ||||
|     }, | ||||
|  | ||||
|     get level() { | ||||
| @@ -34,14 +36,44 @@ const LevelBar = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     set level(value) { | ||||
|         let newValue = Math.max(0, Math.min(value, 100)); | ||||
|         if (newValue == this._level) | ||||
|             return; | ||||
|         this._level = newValue; | ||||
|         this._level = Math.max(0, Math.min(value, 100)); | ||||
|  | ||||
|         let width = this.actor.width; | ||||
|         width *= (this._level / 100.); | ||||
|         this._bar.width = width; | ||||
|         let alloc = this.actor.get_allocation_box(); | ||||
|         let newWidth = Math.round((alloc.x2 - alloc.x1) * this._level / 100); | ||||
|         if (newWidth != this._bar.width) | ||||
|             this._bar.width = newWidth; | ||||
|     } | ||||
| }); | ||||
|  | ||||
| const OsdWindowConstraint = new Lang.Class({ | ||||
|     Name: 'OsdWindowConstraint', | ||||
|     Extends: Clutter.Constraint, | ||||
|  | ||||
|     _init: function(props) { | ||||
|         this._minSize = 0; | ||||
|         this.parent(props); | ||||
|     }, | ||||
|  | ||||
|     set minSize(v) { | ||||
|         this._minSize = v; | ||||
|         if (this.actor) | ||||
|             this.actor.queue_relayout(); | ||||
|     }, | ||||
|  | ||||
|     vfunc_update_allocation: function(actor, actorBox) { | ||||
|         // Clutter will adjust the allocation for margins, | ||||
|         // so add it to our minimum size | ||||
|         let minSize = this._minSize + actor.margin_top + actor.margin_bottom; | ||||
|         let [width, height] = actorBox.get_size(); | ||||
|  | ||||
|         // Enforce a ratio of 1 | ||||
|         let size = Math.ceil(Math.max(minSize, height)); | ||||
|         actorBox.set_size(size, size); | ||||
|  | ||||
|         // Recenter | ||||
|         let [x, y] = actorBox.get_origin(); | ||||
|         actorBox.set_origin(Math.floor(x + width / 2 - size / 2), | ||||
|                             Math.floor(y + height / 2 - size / 2)); | ||||
|     } | ||||
| }); | ||||
|  | ||||
| @@ -49,7 +81,6 @@ const OsdWindow = new Lang.Class({ | ||||
|     Name: 'OsdWindow', | ||||
|  | ||||
|     _init: function(monitorIndex) { | ||||
|         this._popupSize = 0; | ||||
|         this.actor = new St.Widget({ x_expand: true, | ||||
|                                      y_expand: true, | ||||
|                                      x_align: Clutter.ActorAlign.CENTER, | ||||
| @@ -59,19 +90,12 @@ const OsdWindow = new Lang.Class({ | ||||
|         let constraint = new Layout.MonitorConstraint({ index: monitorIndex }); | ||||
|         this.actor.add_constraint(constraint); | ||||
|  | ||||
|         this._boxConstraint = new OsdWindowConstraint(); | ||||
|         this._box = new St.BoxLayout({ style_class: 'osd-window', | ||||
|                                        vertical: true }); | ||||
|         this._box.add_constraint(this._boxConstraint); | ||||
|         this.actor.add_actor(this._box); | ||||
|  | ||||
|         this._box.connect('style-changed', Lang.bind(this, this._onStyleChanged)); | ||||
|         this._box.connect('notify::height', Lang.bind(this, | ||||
|             function() { | ||||
|                 Meta.later_add(Meta.LaterType.BEFORE_REDRAW, Lang.bind(this, | ||||
|                     function() { | ||||
|                         this._box.width = this._box.height; | ||||
|                     })); | ||||
|             })); | ||||
|  | ||||
|         this._icon = new St.Icon(); | ||||
|         this._box.add(this._icon, { expand: true }); | ||||
|  | ||||
| @@ -173,30 +197,12 @@ const OsdWindow = new Lang.Class({ | ||||
|         let scalew = monitor.width / 640.0; | ||||
|         let scaleh = monitor.height / 480.0; | ||||
|         let scale = Math.min(scalew, scaleh); | ||||
|         this._popupSize = 110 * Math.max(1, scale); | ||||
|         let popupSize = 110 * Math.max(1, scale); | ||||
|  | ||||
|         let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor; | ||||
|         this._icon.icon_size = this._popupSize / (2 * scaleFactor); | ||||
|         this._icon.icon_size = popupSize / (2 * scaleFactor); | ||||
|         this._box.translation_y = monitor.height / 4; | ||||
|         this._box.style_changed(); | ||||
|     }, | ||||
|  | ||||
|     _onStyleChanged: function() { | ||||
|         let themeNode = this._box.get_theme_node(); | ||||
|         let horizontalPadding = themeNode.get_horizontal_padding(); | ||||
|         let verticalPadding = themeNode.get_vertical_padding(); | ||||
|         let topBorder = themeNode.get_border_width(St.Side.TOP); | ||||
|         let bottomBorder = themeNode.get_border_width(St.Side.BOTTOM); | ||||
|         let leftBorder = themeNode.get_border_width(St.Side.LEFT); | ||||
|         let rightBorder = themeNode.get_border_width(St.Side.RIGHT); | ||||
|  | ||||
|         let minWidth = this._popupSize - verticalPadding - leftBorder - rightBorder; | ||||
|         let minHeight = this._popupSize - horizontalPadding - topBorder - bottomBorder; | ||||
|  | ||||
|         // minWidth/minHeight here are in real pixels, | ||||
|         // but the theme takes measures in unscaled dimensions | ||||
|         let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor; | ||||
|         this._box.style = 'min-height: %dpx;'.format(Math.max(minWidth, minHeight) / scaleFactor); | ||||
|         this._boxConstraint.minSize = popupSize; | ||||
|     } | ||||
| }); | ||||
|  | ||||
|   | ||||
| @@ -107,18 +107,12 @@ const Overview = new Lang.Class({ | ||||
|  | ||||
|         this._overviewCreated = true; | ||||
|  | ||||
|         let layout = new Clutter.BinLayout(); | ||||
|         this._stack = new Clutter.Actor({ layout_manager: layout }); | ||||
|         this._stack.add_constraint(new LayoutManager.MonitorConstraint({ primary: true })); | ||||
|  | ||||
|         /* Translators: This is the main view to select | ||||
|            activities. See also note for "Activities" string. */ | ||||
|         this._overview = new St.BoxLayout({ name: 'overview', | ||||
|                                             accessible_name: _("Overview"), | ||||
|                                             reactive: true, | ||||
|                                             vertical: true, | ||||
|                                             x_expand: true, | ||||
|                                             y_expand: true }); | ||||
|                                             vertical: true }); | ||||
|         this._overview.add_constraint(new LayoutManager.MonitorConstraint({ primary: true })); | ||||
|         this._overview._delegate = this; | ||||
|  | ||||
|         // The main Background actors are inside global.window_group which are | ||||
| @@ -126,7 +120,7 @@ const Overview = new Lang.Class({ | ||||
|         // one. Instances of this class share a single CoglTexture behind the | ||||
|         // scenes which allows us to show the background with different | ||||
|         // rendering options without duplicating the texture data. | ||||
|         this._backgroundGroup = new Meta.BackgroundGroup(); | ||||
|         this._backgroundGroup = new Meta.BackgroundGroup({ reactive: true }); | ||||
|         Main.layoutManager.overviewGroup.add_child(this._backgroundGroup); | ||||
|         this._bgManagers = []; | ||||
|  | ||||
| @@ -149,8 +143,7 @@ const Overview = new Lang.Class({ | ||||
|         Main.layoutManager.overviewGroup.add_child(this._coverPane); | ||||
|         this._coverPane.connect('event', Lang.bind(this, function (actor, event) { return Clutter.EVENT_STOP; })); | ||||
|  | ||||
|         this._stack.add_actor(this._overview); | ||||
|         Main.layoutManager.overviewGroup.add_child(this._stack); | ||||
|         Main.layoutManager.overviewGroup.add_child(this._overview); | ||||
|  | ||||
|         this._coverPane.hide(); | ||||
|  | ||||
| @@ -159,6 +152,9 @@ const Overview = new Lang.Class({ | ||||
|             dragMotion: Lang.bind(this, this._onDragMotion) | ||||
|         }; | ||||
|  | ||||
|  | ||||
|         Main.layoutManager.overviewGroup.connect('scroll-event', | ||||
|                                                  Lang.bind(this, this._onScrollEvent)); | ||||
|         Main.xdndHandler.connect('drag-begin', Lang.bind(this, this._onDragBegin)); | ||||
|         Main.xdndHandler.connect('drag-end', Lang.bind(this, this._onDragEnd)); | ||||
|  | ||||
| @@ -255,7 +251,6 @@ const Overview = new Lang.Class({ | ||||
|  | ||||
|         // Add our same-line elements after the search entry | ||||
|         this._overview.add(this._controls.actor, { y_fill: true, expand: true }); | ||||
|         this._controls.actor.connect('scroll-event', Lang.bind(this, this._onScrollEvent)); | ||||
|  | ||||
|         // TODO - recalculate everything when desktop size changes | ||||
|         this.dashIconSize = this._dash.iconSize; | ||||
| @@ -372,7 +367,7 @@ const Overview = new Lang.Class({ | ||||
|         if (this.isDummy) | ||||
|             return; | ||||
|  | ||||
|         this._overview.add_action(action); | ||||
|         this._backgroundGroup.add_action(action); | ||||
|     }, | ||||
|  | ||||
|     _getDesktopClone: function() { | ||||
| @@ -552,8 +547,8 @@ const Overview = new Lang.Class({ | ||||
|         Meta.disable_unredirect_for_screen(global.screen); | ||||
|         this.viewSelector.show(); | ||||
|  | ||||
|         this._stack.opacity = 0; | ||||
|         Tweener.addTween(this._stack, | ||||
|         this._overview.opacity = 0; | ||||
|         Tweener.addTween(this._overview, | ||||
|                          { opacity: 255, | ||||
|                            transition: 'easeOutQuad', | ||||
|                            time: ANIMATION_TIME, | ||||
| @@ -618,7 +613,7 @@ const Overview = new Lang.Class({ | ||||
|         this.viewSelector.animateFromOverview(); | ||||
|  | ||||
|         // Make other elements fade out. | ||||
|         Tweener.addTween(this._stack, | ||||
|         Tweener.addTween(this._overview, | ||||
|                          { opacity: 0, | ||||
|                            transition: 'easeOutQuad', | ||||
|                            time: ANIMATION_TIME, | ||||
|   | ||||
| @@ -421,7 +421,6 @@ const ControlsManager = new Lang.Class({ | ||||
|  | ||||
|         let layout = new ControlsLayout(); | ||||
|         this.actor = new St.Widget({ layout_manager: layout, | ||||
|                                      reactive: true, | ||||
|                                      x_expand: true, y_expand: true, | ||||
|                                      clip_to_allocation: true }); | ||||
|         this._group = new St.BoxLayout({ name: 'overview-group', | ||||
|   | ||||
| @@ -349,7 +349,6 @@ const Arrow = new Lang.Class({ | ||||
|     _init: function(params) { | ||||
|         this.parent(params); | ||||
|         this.x_fill = this.y_fill = true; | ||||
|         this.set_offscreen_redirect(Clutter.OffscreenRedirect.ALWAYS); | ||||
|  | ||||
|         this._drawingArea = new St.DrawingArea(); | ||||
|         this._drawingArea.connect('repaint', Lang.bind(this, this._drawArrow)); | ||||
| @@ -377,6 +376,22 @@ const Arrow = new Lang.Class({ | ||||
|         cr.$dispose(); | ||||
|     }, | ||||
|  | ||||
|     vfunc_get_paint_volume: function(volume) { | ||||
|         if (!this.parent(volume)) | ||||
|             return false; | ||||
|  | ||||
|         if (!this._shadow) | ||||
|             return true; | ||||
|  | ||||
|         let shadow_box = new Clutter.ActorBox(); | ||||
|         this._shadow.get_box(this._drawingArea.get_allocation_box(), shadow_box); | ||||
|  | ||||
|         volume.set_width(Math.max(shadow_box.x2 - shadow_box.x1, volume.get_width())); | ||||
|         volume.set_height(Math.max(shadow_box.y2 - shadow_box.y1, volume.get_height())); | ||||
|  | ||||
|         return true; | ||||
|     }, | ||||
|  | ||||
|     vfunc_style_changed: function() { | ||||
|         let node = this.get_theme_node(); | ||||
|         this._shadow = node.get_shadow('-arrow-shadow'); | ||||
| @@ -384,6 +399,8 @@ const Arrow = new Lang.Class({ | ||||
|             this._shadowHelper = St.ShadowHelper.new(this._shadow); | ||||
|         else | ||||
|             this._shadowHelper = null; | ||||
|  | ||||
|         this.parent(); | ||||
|     }, | ||||
|  | ||||
|     vfunc_paint: function() { | ||||
| @@ -711,7 +728,7 @@ const ScreenShield = new Lang.Class({ | ||||
|         let unitaryDelay = ARROW_ANIMATION_TIME / (arrows.length + 1); | ||||
|         let maxOpacity = 255 * ARROW_ANIMATION_PEAK_OPACITY; | ||||
|         for (let i = 0; i < arrows.length; i++) { | ||||
|             arrows.opacity = 0; | ||||
|             arrows[i].opacity = 0; | ||||
|             Tweener.addTween(arrows[i], | ||||
|                              { opacity: 0, | ||||
|                                delay: unitaryDelay * (N_ARROWS - (i + 1)), | ||||
|   | ||||
| @@ -1632,6 +1632,8 @@ const NMApplet = new Lang.Class({ | ||||
|         this._readConnections(); | ||||
|         this._readDevices(); | ||||
|         this._syncNMState(); | ||||
|         this._syncMainConnection(); | ||||
|         this._syncVPNConnections(); | ||||
|  | ||||
|         this._client.connect('notify::manager-running', Lang.bind(this, this._syncNMState)); | ||||
|         this._client.connect('notify::networking-enabled', Lang.bind(this, this._syncNMState)); | ||||
|   | ||||
| @@ -683,6 +683,8 @@ const WindowManager = new Lang.Class({ | ||||
|  | ||||
|         this._dimmedWindows = []; | ||||
|  | ||||
|         this._skippedActors = []; | ||||
|  | ||||
|         this._allowedKeybindings = {}; | ||||
|  | ||||
|         this._isWorkspacePrepended = false; | ||||
| @@ -1035,6 +1037,10 @@ const WindowManager = new Lang.Class({ | ||||
|         this._workspaceTracker.keepWorkspaceAlive(workspace, duration); | ||||
|     }, | ||||
|  | ||||
|     skipNextEffect: function(actor) { | ||||
|         this._skippedActors.push(actor); | ||||
|     }, | ||||
|  | ||||
|     setCustomKeybindingHandler: function(name, modes, handler) { | ||||
|         if (Meta.keybindings_set_custom_handler(name, handler)) | ||||
|             this.allowKeybinding(name, modes); | ||||
| @@ -1061,6 +1067,9 @@ const WindowManager = new Lang.Class({ | ||||
|     }, | ||||
|  | ||||
|     _shouldAnimateActor: function(actor, types) { | ||||
|         if (this._removeEffect(this._skippedActors, actor)) | ||||
|             return false; | ||||
|  | ||||
|         if (!this._shouldAnimate()) | ||||
|             return false; | ||||
|  | ||||
| @@ -1349,9 +1358,13 @@ const WindowManager = new Lang.Class({ | ||||
|     _hasAttachedDialogs: function(window, ignoreWindow) { | ||||
|         var count = 0; | ||||
|         window.foreach_transient(function(win) { | ||||
|             if (win != ignoreWindow && win.is_attached_dialog()) | ||||
|             if (win != ignoreWindow && | ||||
|                 win.is_attached_dialog() && | ||||
|                 win.get_transient_for() == window) { | ||||
|                 count++; | ||||
|             return false; | ||||
|                 return false; | ||||
|             } | ||||
|             return true; | ||||
|         }); | ||||
|         return count != 0; | ||||
|     }, | ||||
| @@ -1420,6 +1433,11 @@ const WindowManager = new Lang.Class({ | ||||
|  | ||||
|             actor._windowType = type; | ||||
|         })); | ||||
|         actor.meta_window.connect('unmanaged', Lang.bind(this, function(window) { | ||||
|                 let parent = window.get_transient_for(); | ||||
|                 if (parent) | ||||
|                     this._checkDimming(parent); | ||||
|         })); | ||||
|  | ||||
|         if (actor.meta_window.is_attached_dialog()) | ||||
|             this._checkDimming(actor.get_meta_window().get_transient_for()); | ||||
|   | ||||
| @@ -19,8 +19,7 @@ const WorkspaceSwitcherPopup = new Lang.Class({ | ||||
|     Name: 'WorkspaceSwitcherPopup', | ||||
|  | ||||
|     _init : function() { | ||||
|         this.actor = new St.Widget({ reactive: true, | ||||
|                                      x: 0, | ||||
|         this.actor = new St.Widget({ x: 0, | ||||
|                                      y: 0, | ||||
|                                      width: global.screen_width, | ||||
|                                      height: global.screen_height, | ||||
|   | ||||
| @@ -103,7 +103,7 @@ const WorkspacesView = new Lang.Class({ | ||||
|                                                     page_increment: 1, | ||||
|                                                     page_size: 1, | ||||
|                                                     step_increment: 0, | ||||
|                                                     upper: 0 }); | ||||
|                                                     upper: global.screen.n_workspaces }); | ||||
|         this.scrollAdjustment.connect('notify::value', | ||||
|                                       Lang.bind(this, this._onScroll)); | ||||
|  | ||||
| @@ -374,6 +374,10 @@ const ExtraWorkspaceView = new Lang.Class({ | ||||
|         this._workspace.setActualGeometry(this._actualGeometry); | ||||
|     }, | ||||
|  | ||||
|     getActiveWorkspace: function() { | ||||
|         return this._workspace; | ||||
|     }, | ||||
|  | ||||
|     animateToOverview: function(animationType) { | ||||
|         if (animationType == AnimationType.ZOOM) | ||||
|             this._workspace.zoomToOverview(); | ||||
| @@ -421,8 +425,10 @@ const WorkspacesDisplay = new Lang.Class({ | ||||
|             // Only switch to the workspace when there's no application | ||||
|             // windows open. The problem is that it's too easy to miss | ||||
|             // an app window and get the wrong one focused. | ||||
|             let event = Clutter.get_current_event(); | ||||
|             let index = this._getMonitorIndexForEvent(event); | ||||
|             if ((action.get_button() == 1 || action.get_button() == 0) && | ||||
|                 this._getPrimaryView().getActiveWorkspace().isEmpty()) | ||||
|                 this._workspacesViews[index].getActiveWorkspace().isEmpty()) | ||||
|                 Main.overview.hide(); | ||||
|         })); | ||||
|         Main.overview.addAction(clickAction); | ||||
| @@ -431,11 +437,18 @@ const WorkspacesDisplay = new Lang.Class({ | ||||
|         let panAction = new Clutter.PanAction({ threshold_trigger_edge: Clutter.GestureTriggerEdge.AFTER }); | ||||
|         panAction.connect('pan', Lang.bind(this, this._onPan)); | ||||
|         panAction.connect('gesture-begin', Lang.bind(this, function() { | ||||
|             if (this._workspacesOnlyOnPrimary) { | ||||
|                 let event = Clutter.get_current_event(); | ||||
|                 if (this._getMonitorIndexForEvent(event) != this._primaryIndex) | ||||
|                     return false; | ||||
|             } | ||||
|  | ||||
|             for (let i = 0; i < this._workspacesViews.length; i++) | ||||
|                 this._workspacesViews[i].startSwipeScroll(); | ||||
|             return true; | ||||
|         })); | ||||
|         panAction.connect('gesture-cancel', Lang.bind(this, function() { | ||||
|             clickAction.release(); | ||||
|             for (let i = 0; i < this._workspacesViews.length; i++) | ||||
|                 this._workspacesViews[i].endSwipeScroll(); | ||||
|         })); | ||||
| @@ -581,6 +594,12 @@ const WorkspacesDisplay = new Lang.Class({ | ||||
|         } | ||||
|     }, | ||||
|  | ||||
|     _getMonitorIndexForEvent: function(event) { | ||||
|         let [x, y] = event.get_coords(); | ||||
|         let rect = new Meta.Rectangle({ x: x, y: y, width: 1, height: 1 }); | ||||
|         return global.screen.get_monitor_index_for_rect(rect); | ||||
|     }, | ||||
|  | ||||
|     _getPrimaryView: function() { | ||||
|         if (!this._workspacesViews.length) | ||||
|             return null; | ||||
| @@ -661,6 +680,11 @@ const WorkspacesDisplay = new Lang.Class({ | ||||
|     _onScrollEvent: function(actor, event) { | ||||
|         if (!this.actor.mapped) | ||||
|             return Clutter.EVENT_PROPAGATE; | ||||
|  | ||||
|         if (this._workspacesOnlyOnPrimary && | ||||
|             this._getMonitorIndexForEvent(event) != this._primaryIndex) | ||||
|             return Clutter.EVENT_PROPAGATE; | ||||
|  | ||||
|         let activeWs = global.screen.get_active_workspace(); | ||||
|         let ws; | ||||
|         switch (event.get_scroll_direction()) { | ||||
|   | ||||
							
								
								
									
										68
									
								
								po/Makevars
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								po/Makevars
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | ||||
| # Makefile variables for PO directory in any package using GNU gettext. | ||||
|  | ||||
| # Usually the message domain is the same as the package name. | ||||
| DOMAIN = $(PACKAGE) | ||||
|  | ||||
| # These two variables depend on the location of this directory. | ||||
| subdir = po | ||||
| top_builddir = .. | ||||
|  | ||||
| # These options get passed to xgettext. | ||||
| XGETTEXT_OPTIONS = --from-code=UTF-8 --keyword=_ --keyword=N_ \ | ||||
|         --keyword=C_:1c,2 --keyword=NC_:1c,2 \ | ||||
|         --keyword=g_dngettext:2,3 --add-comments \ | ||||
|         --flag=g_dngettext:2:pass-c-format \ | ||||
|         --flag=g_strdup_printf:1:c-format \ | ||||
|         --flag=g_string_printf:2:c-format \ | ||||
|         --flag=g_string_append_printf:2:c-format \ | ||||
|         --flag=g_error_new:3:c-format \ | ||||
|         --flag=g_set_error:4:c-format \ | ||||
|         --flag=g_markup_printf_escaped:1:c-format \ | ||||
|         --flag=g_log:3:c-format \ | ||||
|         --flag=g_print:1:c-format \ | ||||
|         --flag=g_printerr:1:c-format \ | ||||
|         --flag=g_printf:1:c-format \ | ||||
|         --flag=g_fprintf:2:c-format \ | ||||
|         --flag=g_sprintf:2:c-format \ | ||||
|         --flag=g_snprintf:3:c-format | ||||
|  | ||||
|  | ||||
| # This is the copyright holder that gets inserted into the header of the | ||||
| # $(DOMAIN).pot file.  Set this to the copyright holder of the surrounding | ||||
| # package.  (Note that the msgstr strings, extracted from the package's | ||||
| # sources, belong to the copyright holder of the package.)  Translators are | ||||
| # expected to transfer the copyright for their translations to this person | ||||
| # or entity, or to disclaim their copyright.  The empty string stands for | ||||
| # the public domain; in this case the translators are expected to disclaim | ||||
| # their copyright. | ||||
| COPYRIGHT_HOLDER = Translation copyright holder | ||||
| # This is the email address or URL to which the translators shall report | ||||
| # bugs in the untranslated strings: | ||||
| # - Strings which are not entire sentences, see the maintainer guidelines | ||||
| #   in the GNU gettext documentation, section 'Preparing Strings'. | ||||
| # - Strings which use unclear terms or require additional context to be | ||||
| #   understood. | ||||
| # - Strings which make invalid assumptions about notation of date, time or | ||||
| #   money. | ||||
| # - Pluralisation problems. | ||||
| # - Incorrect English spelling. | ||||
| # - Incorrect formatting. | ||||
| # It can be your email address, or a mailing list address where translators | ||||
| # can write to without being subscribed, or the URL of a web page through | ||||
| # which the translators can contact you. | ||||
| MSGID_BUGS_ADDRESS = http://bugzilla.gnome.org/enter_bug.cgi?product=gnome-shell&keywords=I18N+L10N&component=general | ||||
|  | ||||
| # This is the list of locale categories, beyond LC_MESSAGES, for which the | ||||
| # message catalogs shall be used.  It is usually empty. | ||||
| EXTRA_LOCALE_CATEGORIES = | ||||
|  | ||||
| # Ignore the timestamp of the .pot file, as git clones do not have | ||||
| # deterministic timestamps, and .po files are updated by translators | ||||
| # (only) in GNOME projects. | ||||
| PO_DEPENDS_ON_POT = no | ||||
|  | ||||
| # This tells whether or not to forcibly update $(DOMAIN).pot and | ||||
| # regenerate PO files on "make dist".  Possible values are "yes" and | ||||
| # "no".  Set this to no if the POT file and PO files are maintained | ||||
| # externally. | ||||
| DIST_DEPENDS_ON_UPDATE_PO = no | ||||
| @@ -1,17 +1,17 @@ | ||||
| # List of source files containing translatable strings. | ||||
| # Please keep this file sorted alphabetically. | ||||
| [encoding: UTF-8] | ||||
| data/50-gnome-shell-system.xml.in | ||||
| data/50-gnome-shell-system.xml | ||||
| data/gnome-shell-extension-prefs.desktop.in.in | ||||
| data/org.gnome.Shell.desktop.in.in | ||||
| data/org.gnome.shell.gschema.xml.in.in | ||||
| data/org.gnome.Shell.PortalHelper.desktop.in | ||||
| data/org.gnome.shell.gschema.xml.in | ||||
| data/org.gnome.Shell.PortalHelper.desktop.in.in | ||||
| js/extensionPrefs/main.js | ||||
| js/gdm/authPrompt.js | ||||
| js/gdm/loginDialog.js | ||||
| js/gdm/util.js | ||||
| js/misc/util.js | ||||
| js/portalHelper/main.js | ||||
| js/ui/accessDialog.js | ||||
| js/ui/appDisplay.js | ||||
| js/ui/appFavorites.js | ||||
| js/ui/audioDeviceSelection.js | ||||
| @@ -61,7 +61,7 @@ js/ui/viewSelector.js | ||||
| js/ui/windowAttentionHandler.js | ||||
| js/ui/windowManager.js | ||||
| js/ui/windowMenu.js | ||||
| src/calendar-server/evolution-calendar.desktop.in.in | ||||
| src/calendar-server/evolution-calendar.desktop.in | ||||
| # Please do not remove this file from POTFILES.in. Run "git submodule init && git submodule update" to get it. | ||||
| src/gvc/gvc-mixer-control.c | ||||
| src/main.c | ||||
|   | ||||
| @@ -1,4 +0,0 @@ | ||||
| data/org.gnome.shell.evolution.calendar.gschema.xml.in | ||||
| src/calendar-server/evolution-calendar.desktop.in | ||||
| # Meh, autofools :-( | ||||
| sub/src/calendar-server/evolution-calendar.desktop.in | ||||
							
								
								
									
										2
									
								
								po/as.po
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								po/as.po
									
									
									
									
									
								
							| @@ -13,7 +13,7 @@ msgstr "" | ||||
| "PO-Revision-Date: 2014-09-15 14:59+0530\n" | ||||
| "Last-Translator: Nilamdyuti Goswami <ngoswami@redhat.com>\n" | ||||
| "Language-Team: Assamese <kde-i18n-doc@kde.org>\n" | ||||
| "Language: as_IN\n" | ||||
| "Language: as\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
|   | ||||
							
								
								
									
										1
									
								
								po/bn.po
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								po/bn.po
									
									
									
									
									
								
							| @@ -7,6 +7,7 @@ msgstr "" | ||||
| "PO-Revision-Date: 2011-04-04 11:04+0600\n" | ||||
| "Last-Translator: Israt Jahan <israt@ankur.org.bd>\n" | ||||
| "Language-Team: Bengali <ankur-bd-l10n@googlegroups.com>\n" | ||||
| "Language: bn\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
|   | ||||
| @@ -11,7 +11,7 @@ msgstr "" | ||||
| "PO-Revision-Date: 2014-12-30 16:45+0000\n" | ||||
| "Last-Translator: \n" | ||||
| "Language-Team: American English <kde-i18n-doc@kde.org>\n" | ||||
| "Language: en_US\n" | ||||
| "Language: bn_IN\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
|   | ||||
							
								
								
									
										713
									
								
								po/ca.po
									
									
									
									
									
								
							
							
						
						
									
										713
									
								
								po/ca.po
									
									
									
									
									
								
							| @@ -10,324 +10,16 @@ msgstr "" | ||||
| "Project-Id-Version: HEAD\n" | ||||
| "Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?product=gnome-" | ||||
| "shell&keywords=I18N+L10N&component=general\n" | ||||
| "POT-Creation-Date: 2016-03-13 10:20+0000\n" | ||||
| "PO-Revision-Date: 2016-03-13 14:47+0100\n" | ||||
| "Last-Translator: Gil Forcada <gilforcada@guifi.net>\n" | ||||
| "POT-Creation-Date: 2016-09-16 21:22+0200\n" | ||||
| "PO-Revision-Date: 2016-09-16 21:22+0200\n" | ||||
| "Last-Translator: Jordi Mas <jmas@softcatala.org>\n" | ||||
| "Language-Team: Catalan <tradgnome@softcatala.org>\n" | ||||
| "Language: ca\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bits\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
| "Plural-Forms: nplurals=2; plural=n != 1;\n" | ||||
| "X-Generator: Gtranslator 2.91.6\n" | ||||
|  | ||||
| #: ../data/50-gnome-shell-system.xml.in.h:1 | ||||
| msgid "System" | ||||
| msgstr "Sistema" | ||||
|  | ||||
| #: ../data/50-gnome-shell-system.xml.in.h:2 | ||||
| msgid "Show the notification list" | ||||
| msgstr "Mostra la llista de notificacions" | ||||
|  | ||||
| #: ../data/50-gnome-shell-system.xml.in.h:3 | ||||
| msgid "Focus the active notification" | ||||
| msgstr "Posa el focus en la notificació activa" | ||||
|  | ||||
| #: ../data/50-gnome-shell-system.xml.in.h:4 | ||||
| msgid "Show the overview" | ||||
| msgstr "Mostra la vista general" | ||||
|  | ||||
| #: ../data/50-gnome-shell-system.xml.in.h:5 | ||||
| msgid "Show all applications" | ||||
| msgstr "Mostra totes les aplicacions" | ||||
|  | ||||
| #: ../data/50-gnome-shell-system.xml.in.h:6 | ||||
| msgid "Open the application menu" | ||||
| msgstr "Obre el menú d'aplicació" | ||||
|  | ||||
| #: ../data/gnome-shell-extension-prefs.desktop.in.in.h:1 | ||||
| msgid "GNOME Shell Extension Preferences" | ||||
| msgstr "Preferències de les extensions del GNOME Shell" | ||||
|  | ||||
| #: ../data/gnome-shell-extension-prefs.desktop.in.in.h:2 | ||||
| msgid "Configure GNOME Shell Extensions" | ||||
| msgstr "Configureu les extensions del GNOME Shell" | ||||
|  | ||||
| #: ../data/org.gnome.Shell.desktop.in.in.h:1 | ||||
| msgid "GNOME Shell" | ||||
| msgstr "GNOME Shell" | ||||
|  | ||||
| #: ../data/org.gnome.Shell.desktop.in.in.h:2 | ||||
| msgid "Window management and application launching" | ||||
| msgstr "Gestor de finestres i llançador d'aplicacions" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:1 | ||||
| msgid "Enable internal tools useful for developers and testers from Alt-F2" | ||||
| msgstr "" | ||||
| "Habilita les eines internes en el diàleg de l'Alt+F2 que són útils per als " | ||||
| "desenvolupadors i provadors" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:2 | ||||
| msgid "" | ||||
| "Allows access to internal debugging and monitoring tools using the Alt-F2 " | ||||
| "dialog." | ||||
| msgstr "" | ||||
| "Permet l'accés a les eines de depuració i de seguiment internes a través del " | ||||
| "diàleg de l'Alt+F2." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:3 | ||||
| msgid "UUIDs of extensions to enable" | ||||
| msgstr "" | ||||
| "Identificadors universals únics de les extensions que s'han d'habilitar" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:4 | ||||
| msgid "" | ||||
| "GNOME Shell extensions have a UUID property; this key lists extensions which " | ||||
| "should be loaded. Any extension that wants to be loaded needs to be in this " | ||||
| "list. You can also manipulate this list with the EnableExtension and " | ||||
| "DisableExtension D-Bus methods on org.gnome.Shell." | ||||
| msgstr "" | ||||
| "Les extensions del GNOME Shell tenen un identificador universal. Aquesta " | ||||
| "clau conté una llista de les extensions que s'han de carregar. Qualsevol " | ||||
| "extensió que s'hagi de carregar ha de ser a la llista. Podeu modificar " | ||||
| "aquesta llista amb els mètodes de D-Bus «EnableExtension» (activa una " | ||||
| "extensió) i «DisableExtension» (desactiva una extensió) a org.gnome.Shell." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:5 | ||||
| msgid "Disables the validation of extension version compatibility" | ||||
| msgstr "Desactiva la validació de la compatibilitat de versió d'extensions" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:6 | ||||
| msgid "" | ||||
| "GNOME Shell will only load extensions that claim to support the current " | ||||
| "running version. Enabling this option will disable this check and try to " | ||||
| "load all extensions regardless of the versions they claim to support." | ||||
| msgstr "" | ||||
| "El GNOME Shell només carregarà extensions que afirmin ser compatibles amb la " | ||||
| "versió en execució. Si s'activa aquesta opció, es desactivarà la comprovació " | ||||
| "i es provarà de carregar totes les extensions sense tenir en compte les " | ||||
| "versions amb què afirmin ser compatibles." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:7 | ||||
| msgid "List of desktop file IDs for favorite applications" | ||||
| msgstr "" | ||||
| "Llista d'identificadors de fitxers d'escriptori de les aplicacions preferides" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:8 | ||||
| msgid "" | ||||
| "The applications corresponding to these identifiers will be displayed in the " | ||||
| "favorites area." | ||||
| msgstr "" | ||||
| "Es mostraran, a l'àrea de preferits, les aplicacions que corresponguin a " | ||||
| "aquests identificadors." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:9 | ||||
| msgid "App Picker View" | ||||
| msgstr "Vista del seleccionador d'aplicacions" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:10 | ||||
| msgid "Index of the currently selected view in the application picker." | ||||
| msgstr "" | ||||
| "Índex de la vista seleccionada actualment en el seleccionador d'aplicacions." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:11 | ||||
| msgid "History for command (Alt-F2) dialog" | ||||
| msgstr "Historial de les ordres utilitzades en el diàleg de l'Alt+F2" | ||||
|  | ||||
| #. Translators: looking glass is a debugger and inspector tool, see https://live.gnome.org/GnomeShell/LookingGlass | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:13 | ||||
| msgid "History for the looking glass dialog" | ||||
| msgstr "Historial del depurador del GNOME Shell" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:14 | ||||
| msgid "Always show the 'Log out' menu item in the user menu." | ||||
| msgstr "Mostra sempre l'element de menú «Surt» al menú d'usuari." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:15 | ||||
| msgid "" | ||||
| "This key overrides the automatic hiding of the 'Log out' menu item in single-" | ||||
| "user, single-session situations." | ||||
| msgstr "" | ||||
| "Aquesta clau sobreescriu l'ocultació automàtica de l'element de menú «Surt» " | ||||
| "quan només hi ha un usuari i un sol tipus de sessió." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:16 | ||||
| msgid "" | ||||
| "Whether to remember password for mounting encrypted or remote filesystems" | ||||
| msgstr "" | ||||
| "Si s'han de recordar les contrasenyes dels punts de muntatge encriptats o " | ||||
| "els sistemes de fitxers remots" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:17 | ||||
| msgid "" | ||||
| "The shell will request a password when an encrypted device or a remote " | ||||
| "filesystem is mounted. If the password can be saved for future use a " | ||||
| "'Remember Password' checkbox will be present. This key sets the default " | ||||
| "state of the checkbox." | ||||
| msgstr "" | ||||
| "El GNOME Shell us demanarà la contrasenya quan es munti un dispositiu " | ||||
| "encriptat o un sistema de fitxers remot. Si es pot desar la contrasenya per " | ||||
| "utilitzar-lo en el futur, es mostrarà la casella de verificació «Recorda la " | ||||
| "contrasenya». Aquesta clau estableix el valor per defecte d'aquesta casella " | ||||
| "de verificació." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:18 | ||||
| msgid "" | ||||
| "Whether the default Bluetooth adapter had set up devices associated to it" | ||||
| msgstr "" | ||||
| "Si l'adaptador de Bluetooth predeterminat té dispositius configurats " | ||||
| "associats" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:19 | ||||
| msgid "" | ||||
| "The shell will only show a Bluetooth menu item if a Bluetooth adapter is " | ||||
| "powered, or if there were devices set up associated with the default " | ||||
| "adapter. This will be reset if the default adapter is ever seen not to have " | ||||
| "devices associated to it." | ||||
| msgstr "" | ||||
| "El Shell només mostrà una entrada de menú Bluetooth si un adaptador Bluetooh " | ||||
| "està engegat, o si hi ha dispositius configurats associats a l'adaptador " | ||||
| "predeterminat. Això es reiniciarà si l'adaptador predeterminat té " | ||||
| "dispositius associats." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:20 | ||||
| msgid "Show the week date in the calendar" | ||||
| msgstr "Mostra el número de la setmana al calendari" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:21 | ||||
| msgid "If true, display the ISO week date in the calendar." | ||||
| msgstr "Si és «true» (cert) es mostra el número de la setmana al calendari." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:22 | ||||
| msgid "Keybinding to open the application menu" | ||||
| msgstr "Vinculació per obrir el menú d'aplicació" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:23 | ||||
| msgid "Keybinding to open the application menu." | ||||
| msgstr "La vinculació per obrir el menú d'aplicació." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:24 | ||||
| msgid "Keybinding to open the \"Show Applications\" view" | ||||
| msgstr "Vinculació per obrir la vista «Mostra les aplicacions»" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:25 | ||||
| msgid "" | ||||
| "Keybinding to open the \"Show Applications\" view of the Activities Overview." | ||||
| msgstr "" | ||||
| "Vinculació per obrir la vista «Mostra les aplicacions» de les activitats de " | ||||
| "la vista general." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:26 | ||||
| msgid "Keybinding to open the overview" | ||||
| msgstr "Vinculació per obrir la vista general" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:27 | ||||
| msgid "Keybinding to open the Activities Overview." | ||||
| msgstr "Vinculació per obrir la vista general d'activitats." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:28 | ||||
| msgid "Keybinding to toggle the visibility of the notification list" | ||||
| msgstr "" | ||||
| "La vinculació per commutar la visibilitat de la llista de notificacions" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:29 | ||||
| msgid "Keybinding to toggle the visibility of the notification list." | ||||
| msgstr "" | ||||
| "La vinculació per commutar la visibilitat de la llista de notificacions." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:30 | ||||
| msgid "Keybinding to focus the active notification" | ||||
| msgstr "Vinculació per posar el focus a la notificació activa" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:31 | ||||
| msgid "Keybinding to focus the active notification." | ||||
| msgstr "Vinculació per posar el focus a la notificació activa." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:32 | ||||
| msgid "" | ||||
| "Keybinding that pauses and resumes all running tweens, for debugging purposes" | ||||
| msgstr "" | ||||
| "Vinculació que fa una pausa i continua tots els «tweens» en execució, per " | ||||
| "motius de depuració" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:33 | ||||
| msgid "Which keyboard to use" | ||||
| msgstr "Quin tipus de teclat s'ha d'utilitzar" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:34 | ||||
| msgid "The type of keyboard to use." | ||||
| msgstr "El tipus de teclat que s'utilitzarà." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:35 | ||||
| msgid "Limit switcher to current workspace." | ||||
| msgstr "Limita el canviador a l'espai de treball actual." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:36 | ||||
| msgid "" | ||||
| "If true, only applications that have windows on the current workspace are " | ||||
| "shown in the switcher. Otherwise, all applications are included." | ||||
| msgstr "" | ||||
| "Si és «true» (cert), només les aplicacions que tinguin finestres en l'espai " | ||||
| "de treball actual es mostren en el canviador. En cas contrari es mostren " | ||||
| "totes les aplicacions." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:37 | ||||
| msgid "The application icon mode." | ||||
| msgstr "El mode d'icona de les aplicacions." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:38 | ||||
| msgid "" | ||||
| "Configures how the windows are shown in the switcher. Valid possibilities " | ||||
| "are 'thumbnail-only' (shows a thumbnail of the window), 'app-icon-" | ||||
| "only' (shows only the application icon) or 'both'." | ||||
| msgstr "" | ||||
| "Configureu com es mostren les finestres en l'intercanviador. Els valors " | ||||
| "possibles són: «thumbnail-only» (mostra una miniatura de la finestra), «app-" | ||||
| "icon-only» (mostra la icona de l'aplicació) o «both» (ambdues coses: mostra " | ||||
| "la miniatura de la finestra i la icona de l'aplicació)." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:39 | ||||
| msgid "" | ||||
| "If true, only windows from the current workspace are shown in the switcher. " | ||||
| "Otherwise, all windows are included." | ||||
| msgstr "" | ||||
| "Si és «true» (cert), només les finestres de l'espai de treball actual es " | ||||
| "mostren en el canviador. En cas contrari, es mostren totes les finestres." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:40 | ||||
| msgid "Attach modal dialog to the parent window" | ||||
| msgstr "Adjunta el diàleg modal a la finestra pare" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:41 | ||||
| msgid "" | ||||
| "This key overrides the key in org.gnome.mutter when running GNOME Shell." | ||||
| msgstr "" | ||||
| "Si s'executa el GNOME Shell, aquesta clau sobreescriu la clau «org.gnome." | ||||
| "mutter»." | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:42 | ||||
| msgid "Enable edge tiling when dropping windows on screen edges" | ||||
| msgstr "" | ||||
| "Habilita la tesselització a les vores en deixar anar les finestres a les " | ||||
| "vores de la pantalla" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:43 | ||||
| msgid "Workspaces are managed dynamically" | ||||
| msgstr "Els espais de treball es gestionen dinàmicament" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:44 | ||||
| msgid "Workspaces only on primary monitor" | ||||
| msgstr "Només en el monitor principal hi ha espais de treball" | ||||
|  | ||||
| #: ../data/org.gnome.shell.gschema.xml.in.in.h:45 | ||||
| msgid "Delay focus changes in mouse mode until the pointer stops moving" | ||||
| msgstr "" | ||||
| "Retarda el canvi del focus, quan s'està en mode ratolí, fins que el punter " | ||||
| "no estigui quiet" | ||||
|  | ||||
| #: ../data/org.gnome.Shell.PortalHelper.desktop.in.h:1 | ||||
| msgid "Network Login" | ||||
| msgstr "Inici de sessió de la xarxa" | ||||
| "X-Generator: Poedit 1.8.7.1\n" | ||||
|  | ||||
| #: ../js/extensionPrefs/main.js:117 | ||||
| #, javascript-format | ||||
| @@ -340,7 +32,7 @@ msgstr "Extensions del GNOME Shell" | ||||
|  | ||||
| #: ../js/gdm/authPrompt.js:147 ../js/ui/audioDeviceSelection.js:71 | ||||
| #: ../js/ui/components/networkAgent.js:145 | ||||
| #: ../js/ui/components/polkitAgent.js:179 ../js/ui/endSessionDialog.js:452 | ||||
| #: ../js/ui/components/polkitAgent.js:179 ../js/ui/endSessionDialog.js:483 | ||||
| #: ../js/ui/extensionDownloader.js:195 ../js/ui/shellMountOperation.js:399 | ||||
| #: ../js/ui/status/network.js:916 | ||||
| msgid "Cancel" | ||||
| @@ -374,7 +66,7 @@ msgstr "No esteu llistat?" | ||||
|  | ||||
| #. Translators: this message is shown below the username entry field | ||||
| #. to clue the user in on how to login to the local network realm | ||||
| #: ../js/gdm/loginDialog.js:854 | ||||
| #: ../js/gdm/loginDialog.js:859 | ||||
| #, javascript-format | ||||
| msgid "(e.g., user or %s)" | ||||
| msgstr "(p. ex. l'usuari o %s)" | ||||
| @@ -382,12 +74,12 @@ msgstr "(p. ex. l'usuari o %s)" | ||||
| #. TTLS and PEAP are actually much more complicated, but this complication | ||||
| #. is not visible here since we only care about phase2 authentication | ||||
| #. (and don't even care of which one) | ||||
| #: ../js/gdm/loginDialog.js:859 ../js/ui/components/networkAgent.js:271 | ||||
| #: ../js/gdm/loginDialog.js:864 ../js/ui/components/networkAgent.js:271 | ||||
| #: ../js/ui/components/networkAgent.js:289 | ||||
| msgid "Username: " | ||||
| msgstr "Nom d'usuari:" | ||||
|  | ||||
| #: ../js/gdm/loginDialog.js:1196 | ||||
| #: ../js/gdm/loginDialog.js:1201 | ||||
| msgid "Login Window" | ||||
| msgstr "Finestra d'entrada" | ||||
|  | ||||
| @@ -495,6 +187,16 @@ msgstr "%d de %B de %Y, a les %l∶%M %p" | ||||
| msgid "Web Authentication Redirect" | ||||
| msgstr "Redirecció per l'autenticació web" | ||||
|  | ||||
| #. No support for non-modal system dialogs, so ignore the option | ||||
| #. let modal = options['modal'] || true; | ||||
| #: ../js/ui/accessDialog.js:62 ../js/ui/status/location.js:426 | ||||
| msgid "Deny Access" | ||||
| msgstr "Denega l'accés" | ||||
|  | ||||
| #: ../js/ui/accessDialog.js:63 ../js/ui/status/location.js:429 | ||||
| msgid "Grant Access" | ||||
| msgstr "Permetre l'accés" | ||||
|  | ||||
| #: ../js/ui/appDisplay.js:794 | ||||
| msgid "Frequently used applications will appear here" | ||||
| msgstr "Les aplicacions utilitzades freqüentment apareixeran aquí" | ||||
| @@ -561,7 +263,7 @@ msgstr "Canvia el fons de l'escriptori…" | ||||
| msgid "Display Settings" | ||||
| msgstr "Paràmetres de la pantalla" | ||||
|  | ||||
| #: ../js/ui/backgroundMenu.js:22 ../js/ui/status/system.js:366 | ||||
| #: ../js/ui/backgroundMenu.js:22 ../js/ui/status/system.js:374 | ||||
| msgid "Settings" | ||||
| msgstr "Paràmetres" | ||||
|  | ||||
| @@ -617,55 +319,55 @@ msgctxt "grid saturday" | ||||
| msgid "S" | ||||
| msgstr "Ds" | ||||
|  | ||||
| #: ../js/ui/calendar.js:416 | ||||
| #: ../js/ui/calendar.js:442 | ||||
| msgid "Previous month" | ||||
| msgstr "Mes anterior" | ||||
|  | ||||
| #: ../js/ui/calendar.js:426 | ||||
| #: ../js/ui/calendar.js:452 | ||||
| msgid "Next month" | ||||
| msgstr "Mes següent" | ||||
|  | ||||
| #: ../js/ui/calendar.js:579 | ||||
| #: ../js/ui/calendar.js:605 | ||||
| #, no-javascript-format | ||||
| msgctxt "date day number format" | ||||
| msgid "%d" | ||||
| msgstr "%d" | ||||
|  | ||||
| #: ../js/ui/calendar.js:634 | ||||
| #: ../js/ui/calendar.js:660 | ||||
| msgid "Week %V" | ||||
| msgstr "Setmana %V" | ||||
|  | ||||
| #. Translators: Shown in calendar event list for all day events | ||||
| #. * Keep it short, best if you can use less then 10 characters | ||||
| #. | ||||
| #: ../js/ui/calendar.js:695 | ||||
| #: ../js/ui/calendar.js:721 | ||||
| msgctxt "event list time" | ||||
| msgid "All Day" | ||||
| msgstr "Tot el dia" | ||||
|  | ||||
| #: ../js/ui/calendar.js:821 | ||||
| #: ../js/ui/calendar.js:836 | ||||
| msgid "Events" | ||||
| msgstr "Cites" | ||||
|  | ||||
| #: ../js/ui/calendar.js:830 | ||||
| #: ../js/ui/calendar.js:845 | ||||
| msgctxt "calendar heading" | ||||
| msgid "%A, %B %d" | ||||
| msgstr "%A %d de %B" | ||||
|  | ||||
| #: ../js/ui/calendar.js:834 | ||||
| #: ../js/ui/calendar.js:849 | ||||
| msgctxt "calendar heading" | ||||
| msgid "%A, %B %d, %Y" | ||||
| msgstr "%A %d de %B de %Y" | ||||
|  | ||||
| #: ../js/ui/calendar.js:919 | ||||
| #: ../js/ui/calendar.js:931 | ||||
| msgid "Notifications" | ||||
| msgstr "Notificacions" | ||||
|  | ||||
| #: ../js/ui/calendar.js:1070 | ||||
| #: ../js/ui/calendar.js:1082 | ||||
| msgid "No Notifications" | ||||
| msgstr "Cap notificació" | ||||
|  | ||||
| #: ../js/ui/calendar.js:1073 | ||||
| #: ../js/ui/calendar.js:1085 | ||||
| msgid "No Events" | ||||
| msgstr "Cap cita" | ||||
|  | ||||
| @@ -803,7 +505,7 @@ msgstr "No ha funcionat. Torneu-ho a provar." | ||||
|  | ||||
| #. Translators: this is the other person changing their old IM name to their new | ||||
| #. IM name. | ||||
| #: ../js/ui/components/telepathyClient.js:759 | ||||
| #: ../js/ui/components/telepathyClient.js:765 | ||||
| #, javascript-format | ||||
| msgid "%s is now known as %s" | ||||
| msgstr "En/na %s ara es diu %s" | ||||
| @@ -936,7 +638,7 @@ msgstr[1] "" | ||||
| "Es reiniciarà l'ordinador automàticament i s'instal·laran les " | ||||
| "actualitzacions d'aquí %d segons." | ||||
|  | ||||
| #: ../js/ui/endSessionDialog.js:127 | ||||
| #: ../js/ui/endSessionDialog.js:127 ../js/ui/endSessionDialog.js:147 | ||||
| msgctxt "button" | ||||
| msgid "Restart & Install" | ||||
| msgstr "Reinicia i instal·la" | ||||
| @@ -951,30 +653,45 @@ msgctxt "checkbox" | ||||
| msgid "Power off after updates are installed" | ||||
| msgstr "Apaga després d'instal·lar les actualitzacions" | ||||
|  | ||||
| #: ../js/ui/endSessionDialog.js:338 | ||||
| #: ../js/ui/endSessionDialog.js:137 | ||||
| msgctxt "title" | ||||
| msgid "Restart & Install Upgrade" | ||||
| msgstr "Reinicia i instal·la l'actualització" | ||||
|  | ||||
| #. Translators: This is the text displayed for system upgrades in the | ||||
| #. shut down dialog. First %s gets replaced with the distro name and | ||||
| #. second %s with the distro version to upgrade to | ||||
| #: ../js/ui/endSessionDialog.js:142 | ||||
| #, javascript-format | ||||
| msgid "" | ||||
| "%s %s will be installed after restart. Upgrade installation can take a long " | ||||
| "time: ensure that you have backed up and that the computer is plugged in." | ||||
| msgstr "" | ||||
|  | ||||
| #: ../js/ui/endSessionDialog.js:361 | ||||
| msgid "Running on battery power: please plug in before installing updates." | ||||
| msgstr "" | ||||
| "S'està utilitzant la bateria: connecteu l'ordinador a la xarxa elèctrica " | ||||
| "abans d'instal·lar les actualitzacions." | ||||
|  | ||||
| #: ../js/ui/endSessionDialog.js:355 | ||||
| #: ../js/ui/endSessionDialog.js:378 | ||||
| msgid "Some applications are busy or have unsaved work." | ||||
| msgstr "" | ||||
| "Hi ha algunes aplicacions que estan ocupades o que tenen documents sense " | ||||
| "desar." | ||||
|  | ||||
| #: ../js/ui/endSessionDialog.js:362 | ||||
| #: ../js/ui/endSessionDialog.js:385 | ||||
| msgid "Other users are logged in." | ||||
| msgstr "Altres usuaris tenen la sessió oberta." | ||||
|  | ||||
| #. Translators: Remote here refers to a remote session, like a ssh login | ||||
| #: ../js/ui/endSessionDialog.js:640 | ||||
| #: ../js/ui/endSessionDialog.js:671 | ||||
| #, javascript-format | ||||
| msgid "%s (remote)" | ||||
| msgstr "%s (remot)" | ||||
|  | ||||
| #. Translators: Console here refers to a tty like a VT console | ||||
| #: ../js/ui/endSessionDialog.js:643 | ||||
| #: ../js/ui/endSessionDialog.js:674 | ||||
| #, javascript-format | ||||
| msgid "%s (console)" | ||||
| msgstr "%s (consola)" | ||||
| @@ -988,7 +705,7 @@ msgstr "Instal·la" | ||||
| msgid "Download and install “%s” from extensions.gnome.org?" | ||||
| msgstr "Voleu baixar i instal·lar «%s» d'extensions.gnome.org?" | ||||
|  | ||||
| #: ../js/ui/keyboard.js:741 ../js/ui/status/keyboard.js:713 | ||||
| #: ../js/ui/keyboard.js:742 ../js/ui/status/keyboard.js:782 | ||||
| msgid "Keyboard" | ||||
| msgstr "Teclat" | ||||
|  | ||||
| @@ -1025,7 +742,7 @@ msgstr "Habilitat" | ||||
|  | ||||
| #. translators: | ||||
| #. * The device has been disabled | ||||
| #: ../js/ui/lookingGlass.js:719 ../src/gvc/gvc-mixer-control.c:1828 | ||||
| #: ../js/ui/lookingGlass.js:719 ../src/gvc/gvc-mixer-control.c:1866 | ||||
| msgid "Disabled" | ||||
| msgstr "Inhabilitat" | ||||
|  | ||||
| @@ -1073,7 +790,7 @@ msgstr "Multimèdia" | ||||
| msgid "Undo" | ||||
| msgstr "Desfés" | ||||
|  | ||||
| #: ../js/ui/overview.js:117 | ||||
| #: ../js/ui/overview.js:113 | ||||
| msgid "Overview" | ||||
| msgstr "Vista general" | ||||
|  | ||||
| @@ -1081,7 +798,7 @@ msgstr "Vista general" | ||||
| #. in the search entry when no search is | ||||
| #. active; it should not exceed ~30 | ||||
| #. characters. | ||||
| #: ../js/ui/overview.js:244 | ||||
| #: ../js/ui/overview.js:240 | ||||
| msgid "Type to search…" | ||||
| msgstr "Teclegeu per cercar…" | ||||
|  | ||||
| @@ -1145,11 +862,11 @@ msgid_plural "%d new notifications" | ||||
| msgstr[0] "%d notificació nova" | ||||
| msgstr[1] "%d notificacions noves" | ||||
|  | ||||
| #: ../js/ui/screenShield.js:432 ../js/ui/status/system.js:374 | ||||
| #: ../js/ui/screenShield.js:449 ../js/ui/status/system.js:382 | ||||
| msgid "Lock" | ||||
| msgstr "Bloqueja" | ||||
|  | ||||
| #: ../js/ui/screenShield.js:684 | ||||
| #: ../js/ui/screenShield.js:704 | ||||
| msgid "GNOME needs to lock the screen" | ||||
| msgstr "El GNOME necessita bloquejar la pantalla" | ||||
|  | ||||
| @@ -1160,11 +877,11 @@ msgstr "El GNOME necessita bloquejar la pantalla" | ||||
| #. | ||||
| #. XXX: another option is to kick the user into the gdm login | ||||
| #. screen, where we're not affected by grabs | ||||
| #: ../js/ui/screenShield.js:805 ../js/ui/screenShield.js:1271 | ||||
| #: ../js/ui/screenShield.js:825 ../js/ui/screenShield.js:1291 | ||||
| msgid "Unable to lock" | ||||
| msgstr "No es pot blocar" | ||||
|  | ||||
| #: ../js/ui/screenShield.js:806 ../js/ui/screenShield.js:1272 | ||||
| #: ../js/ui/screenShield.js:826 ../js/ui/screenShield.js:1292 | ||||
| msgid "Lock was blocked by an application" | ||||
| msgstr "Una aplicació està bloquejant el bloqueig" | ||||
|  | ||||
| @@ -1248,7 +965,7 @@ msgstr "Text gran" | ||||
| msgid "Bluetooth" | ||||
| msgstr "Bluetooth" | ||||
|  | ||||
| #: ../js/ui/status/bluetooth.js:56 | ||||
| #: ../js/ui/status/bluetooth.js:56 ../js/ui/status/network.js:624 | ||||
| msgid "Bluetooth Settings" | ||||
| msgstr "Paràmetres del Bluetooth" | ||||
|  | ||||
| @@ -1283,7 +1000,7 @@ msgstr "Desactiva" | ||||
| msgid "Brightness" | ||||
| msgstr "Brillantor" | ||||
|  | ||||
| #: ../js/ui/status/keyboard.js:736 | ||||
| #: ../js/ui/status/keyboard.js:805 | ||||
| msgid "Show Keyboard Layout" | ||||
| msgstr "Mostra la disposició del teclat" | ||||
|  | ||||
| @@ -1311,14 +1028,6 @@ msgstr "Ubicació inhabilitada" | ||||
| msgid "Enable" | ||||
| msgstr "Habilita" | ||||
|  | ||||
| #: ../js/ui/status/location.js:426 | ||||
| msgid "Deny Access" | ||||
| msgstr "Denega l'accés" | ||||
|  | ||||
| #: ../js/ui/status/location.js:429 | ||||
| msgid "Grant Access" | ||||
| msgstr "Permetre l'accés" | ||||
|  | ||||
| #. Translators: %s is an application name | ||||
| #: ../js/ui/status/location.js:435 | ||||
| #, javascript-format | ||||
| @@ -1329,7 +1038,7 @@ msgstr "Voleu donar a %s accés a la vostra ubicació?" | ||||
| msgid "Location access can be changed at any time from the privacy settings." | ||||
| msgstr "" | ||||
| "Podeu canviar la configuració de l'accés a la ubicació sempre que vulgueu " | ||||
| "des del la configuració de la privacitat." | ||||
| "des de la configuració de la privacitat." | ||||
|  | ||||
| #: ../js/ui/status/network.js:101 | ||||
| msgid "<unknown>" | ||||
| @@ -1397,7 +1106,7 @@ msgstr "%s ha fallat la connexió" | ||||
| msgid "Wired Settings" | ||||
| msgstr "Paràmetres de la xarxa amb fils" | ||||
|  | ||||
| #: ../js/ui/status/network.js:545 ../js/ui/status/network.js:624 | ||||
| #: ../js/ui/status/network.js:545 | ||||
| msgid "Mobile Broadband Settings" | ||||
| msgstr "Configuració de la xarxa de banda ampla mòbil" | ||||
|  | ||||
| @@ -1415,8 +1124,8 @@ msgid "%s Disabled" | ||||
| msgstr "%s Inhabilitat" | ||||
|  | ||||
| #: ../js/ui/status/network.js:632 | ||||
| msgid "Use as Internet connection" | ||||
| msgstr "Utilitza com a connexió a Internet" | ||||
| msgid "Connect to Internet" | ||||
| msgstr "Connecta a l'Internet" | ||||
|  | ||||
| #: ../js/ui/status/network.js:813 | ||||
| msgid "Airplane Mode is On" | ||||
| @@ -1553,27 +1262,27 @@ msgstr "%d %%" | ||||
| msgid "Airplane Mode On" | ||||
| msgstr "El mode d'avió és actiu" | ||||
|  | ||||
| #: ../js/ui/status/system.js:343 | ||||
| #: ../js/ui/status/system.js:351 | ||||
| msgid "Switch User" | ||||
| msgstr "Canvia d'usuari" | ||||
|  | ||||
| #: ../js/ui/status/system.js:348 | ||||
| #: ../js/ui/status/system.js:356 | ||||
| msgid "Log Out" | ||||
| msgstr "Surt" | ||||
|  | ||||
| #: ../js/ui/status/system.js:353 | ||||
| #: ../js/ui/status/system.js:361 | ||||
| msgid "Account Settings" | ||||
| msgstr "Paràmetres del compte" | ||||
|  | ||||
| #: ../js/ui/status/system.js:370 | ||||
| #: ../js/ui/status/system.js:378 | ||||
| msgid "Orientation Lock" | ||||
| msgstr "Bloqueja l'orientació" | ||||
|  | ||||
| #: ../js/ui/status/system.js:378 | ||||
| #: ../js/ui/status/system.js:386 | ||||
| msgid "Suspend" | ||||
| msgstr "Atura temporalment" | ||||
|  | ||||
| #: ../js/ui/status/system.js:381 | ||||
| #: ../js/ui/status/system.js:389 | ||||
| msgid "Power Off" | ||||
| msgstr "Apaga" | ||||
|  | ||||
| @@ -1699,13 +1408,9 @@ msgstr "Mou a la pantalla de l'esquerra" | ||||
| msgid "Move to Monitor Right" | ||||
| msgstr "Mou a la pantalla de la dreta" | ||||
|  | ||||
| #: ../src/calendar-server/evolution-calendar.desktop.in.in.h:1 | ||||
| msgid "Evolution Calendar" | ||||
| msgstr "Calendari de l'Evolution" | ||||
|  | ||||
| #. translators: | ||||
| #. * The number of sound outputs on a particular device | ||||
| #: ../src/gvc/gvc-mixer-control.c:1835 | ||||
| #: ../src/gvc/gvc-mixer-control.c:1873 | ||||
| #, c-format | ||||
| msgid "%u Output" | ||||
| msgid_plural "%u Outputs" | ||||
| @@ -1714,14 +1419,14 @@ msgstr[1] "%u sortides" | ||||
|  | ||||
| #. translators: | ||||
| #. * The number of sound inputs on a particular device | ||||
| #: ../src/gvc/gvc-mixer-control.c:1845 | ||||
| #: ../src/gvc/gvc-mixer-control.c:1883 | ||||
| #, c-format | ||||
| msgid "%u Input" | ||||
| msgid_plural "%u Inputs" | ||||
| msgstr[0] "%u entrada" | ||||
| msgstr[1] "%u entrades" | ||||
|  | ||||
| #: ../src/gvc/gvc-mixer-control.c:2371 | ||||
| #: ../src/gvc/gvc-mixer-control.c:2738 | ||||
| msgid "System Sounds" | ||||
| msgstr "Sons del sistema" | ||||
|  | ||||
| @@ -1741,12 +1446,12 @@ msgstr "Utilitza un mode específic, p. ex. «gdm» per la pantalla d'entrada" | ||||
| msgid "List possible modes" | ||||
| msgstr "Llista els modes possibles" | ||||
|  | ||||
| #: ../src/shell-app.c:246 | ||||
| #: ../src/shell-app.c:270 | ||||
| msgctxt "program" | ||||
| msgid "Unknown" | ||||
| msgstr "Desconegut" | ||||
|  | ||||
| #: ../src/shell-app.c:487 | ||||
| #: ../src/shell-app.c:511 | ||||
| #, c-format | ||||
| msgid "Failed to launch “%s”" | ||||
| msgstr "No s'ha pogut iniciar «%s»" | ||||
| @@ -1763,6 +1468,268 @@ msgstr "La contrasenya no pot ser buida" | ||||
| msgid "Authentication dialog was dismissed by the user" | ||||
| msgstr "L'usuari ha descartat el diàleg d'autenticació" | ||||
|  | ||||
| #~ msgid "System" | ||||
| #~ msgstr "Sistema" | ||||
|  | ||||
| #~ msgid "Show the notification list" | ||||
| #~ msgstr "Mostra la llista de notificacions" | ||||
|  | ||||
| #~ msgid "Focus the active notification" | ||||
| #~ msgstr "Posa el focus en la notificació activa" | ||||
|  | ||||
| #~ msgid "Show the overview" | ||||
| #~ msgstr "Mostra la vista general" | ||||
|  | ||||
| #~ msgid "Show all applications" | ||||
| #~ msgstr "Mostra totes les aplicacions" | ||||
|  | ||||
| #~ msgid "Open the application menu" | ||||
| #~ msgstr "Obre el menú d'aplicació" | ||||
|  | ||||
| #~ msgid "GNOME Shell Extension Preferences" | ||||
| #~ msgstr "Preferències de les extensions del GNOME Shell" | ||||
|  | ||||
| #~ msgid "Configure GNOME Shell Extensions" | ||||
| #~ msgstr "Configureu les extensions del GNOME Shell" | ||||
|  | ||||
| #~ msgid "GNOME Shell" | ||||
| #~ msgstr "GNOME Shell" | ||||
|  | ||||
| #~ msgid "Window management and application launching" | ||||
| #~ msgstr "Gestor de finestres i llançador d'aplicacions" | ||||
|  | ||||
| #~ msgid "Enable internal tools useful for developers and testers from Alt-F2" | ||||
| #~ msgstr "" | ||||
| #~ "Habilita les eines internes en el diàleg de l'Alt+F2 que són útils per " | ||||
| #~ "als desenvolupadors i provadors" | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "Allows access to internal debugging and monitoring tools using the Alt-F2 " | ||||
| #~ "dialog." | ||||
| #~ msgstr "" | ||||
| #~ "Permet l'accés a les eines de depuració i de seguiment internes a través " | ||||
| #~ "del diàleg de l'Alt+F2." | ||||
|  | ||||
| #~ msgid "UUIDs of extensions to enable" | ||||
| #~ msgstr "" | ||||
| #~ "Identificadors universals únics de les extensions que s'han d'habilitar" | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "GNOME Shell extensions have a UUID property; this key lists extensions " | ||||
| #~ "which should be loaded. Any extension that wants to be loaded needs to be " | ||||
| #~ "in this list. You can also manipulate this list with the EnableExtension " | ||||
| #~ "and DisableExtension D-Bus methods on org.gnome.Shell." | ||||
| #~ msgstr "" | ||||
| #~ "Les extensions del GNOME Shell tenen un identificador universal. Aquesta " | ||||
| #~ "clau conté una llista de les extensions que s'han de carregar. Qualsevol " | ||||
| #~ "extensió que s'hagi de carregar ha de ser a la llista. Podeu modificar " | ||||
| #~ "aquesta llista amb els mètodes de D-Bus «EnableExtension» (activa una " | ||||
| #~ "extensió) i «DisableExtension» (desactiva una extensió) a org.gnome.Shell." | ||||
|  | ||||
| #~ msgid "Disables the validation of extension version compatibility" | ||||
| #~ msgstr "Desactiva la validació de la compatibilitat de versió d'extensions" | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "GNOME Shell will only load extensions that claim to support the current " | ||||
| #~ "running version. Enabling this option will disable this check and try to " | ||||
| #~ "load all extensions regardless of the versions they claim to support." | ||||
| #~ msgstr "" | ||||
| #~ "El GNOME Shell només carregarà extensions que afirmin ser compatibles amb " | ||||
| #~ "la versió en execució. Si s'activa aquesta opció, es desactivarà la " | ||||
| #~ "comprovació i es provarà de carregar totes les extensions sense tenir en " | ||||
| #~ "compte les versions amb què afirmin ser compatibles." | ||||
|  | ||||
| #~ msgid "List of desktop file IDs for favorite applications" | ||||
| #~ msgstr "" | ||||
| #~ "Llista d'identificadors de fitxers d'escriptori de les aplicacions " | ||||
| #~ "preferides" | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "The applications corresponding to these identifiers will be displayed in " | ||||
| #~ "the favorites area." | ||||
| #~ msgstr "" | ||||
| #~ "Es mostraran, a l'àrea de preferits, les aplicacions que corresponguin a " | ||||
| #~ "aquests identificadors." | ||||
|  | ||||
| #~ msgid "App Picker View" | ||||
| #~ msgstr "Vista del seleccionador d'aplicacions" | ||||
|  | ||||
| #~ msgid "Index of the currently selected view in the application picker." | ||||
| #~ msgstr "" | ||||
| #~ "Índex de la vista seleccionada actualment en el seleccionador " | ||||
| #~ "d'aplicacions." | ||||
|  | ||||
| #~ msgid "History for command (Alt-F2) dialog" | ||||
| #~ msgstr "Historial de les ordres utilitzades en el diàleg de l'Alt+F2" | ||||
|  | ||||
| #~ msgid "History for the looking glass dialog" | ||||
| #~ msgstr "Historial del depurador del GNOME Shell" | ||||
|  | ||||
| #~ msgid "Always show the 'Log out' menu item in the user menu." | ||||
| #~ msgstr "Mostra sempre l'element de menú «Surt» al menú d'usuari." | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "This key overrides the automatic hiding of the 'Log out' menu item in " | ||||
| #~ "single-user, single-session situations." | ||||
| #~ msgstr "" | ||||
| #~ "Aquesta clau sobreescriu l'ocultació automàtica de l'element de menú " | ||||
| #~ "«Surt» quan només hi ha un usuari i un sol tipus de sessió." | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "Whether to remember password for mounting encrypted or remote filesystems" | ||||
| #~ msgstr "" | ||||
| #~ "Si s'han de recordar les contrasenyes dels punts de muntatge encriptats o " | ||||
| #~ "els sistemes de fitxers remots" | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "The shell will request a password when an encrypted device or a remote " | ||||
| #~ "filesystem is mounted. If the password can be saved for future use a " | ||||
| #~ "'Remember Password' checkbox will be present. This key sets the default " | ||||
| #~ "state of the checkbox." | ||||
| #~ msgstr "" | ||||
| #~ "El GNOME Shell us demanarà la contrasenya quan es munti un dispositiu " | ||||
| #~ "encriptat o un sistema de fitxers remot. Si es pot desar la contrasenya " | ||||
| #~ "per utilitzar-lo en el futur, es mostrarà la casella de verificació " | ||||
| #~ "«Recorda la contrasenya». Aquesta clau estableix el valor per defecte " | ||||
| #~ "d'aquesta casella de verificació." | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "Whether the default Bluetooth adapter had set up devices associated to it" | ||||
| #~ msgstr "" | ||||
| #~ "Si l'adaptador de Bluetooth predeterminat té dispositius configurats " | ||||
| #~ "associats" | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "The shell will only show a Bluetooth menu item if a Bluetooth adapter is " | ||||
| #~ "powered, or if there were devices set up associated with the default " | ||||
| #~ "adapter. This will be reset if the default adapter is ever seen not to " | ||||
| #~ "have devices associated to it." | ||||
| #~ msgstr "" | ||||
| #~ "El Shell només mostrà una entrada de menú Bluetooth si un adaptador " | ||||
| #~ "Bluetooh està engegat, o si hi ha dispositius configurats associats a " | ||||
| #~ "l'adaptador predeterminat. Això es reiniciarà si l'adaptador " | ||||
| #~ "predeterminat té dispositius associats." | ||||
|  | ||||
| #~ msgid "Show the week date in the calendar" | ||||
| #~ msgstr "Mostra el número de la setmana al calendari" | ||||
|  | ||||
| #~ msgid "If true, display the ISO week date in the calendar." | ||||
| #~ msgstr "Si és «true» (cert) es mostra el número de la setmana al calendari." | ||||
|  | ||||
| #~ msgid "Keybinding to open the application menu" | ||||
| #~ msgstr "Vinculació per obrir el menú d'aplicació" | ||||
|  | ||||
| #~ msgid "Keybinding to open the application menu." | ||||
| #~ msgstr "La vinculació per obrir el menú d'aplicació." | ||||
|  | ||||
| #~ msgid "Keybinding to open the \"Show Applications\" view" | ||||
| #~ msgstr "Vinculació per obrir la vista «Mostra les aplicacions»" | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "Keybinding to open the \"Show Applications\" view of the Activities " | ||||
| #~ "Overview." | ||||
| #~ msgstr "" | ||||
| #~ "Vinculació per obrir la vista «Mostra les aplicacions» de les activitats " | ||||
| #~ "de la vista general." | ||||
|  | ||||
| #~ msgid "Keybinding to open the overview" | ||||
| #~ msgstr "Vinculació per obrir la vista general" | ||||
|  | ||||
| #~ msgid "Keybinding to open the Activities Overview." | ||||
| #~ msgstr "Vinculació per obrir la vista general d'activitats." | ||||
|  | ||||
| #~ msgid "Keybinding to toggle the visibility of the notification list" | ||||
| #~ msgstr "" | ||||
| #~ "La vinculació per commutar la visibilitat de la llista de notificacions" | ||||
|  | ||||
| #~ msgid "Keybinding to toggle the visibility of the notification list." | ||||
| #~ msgstr "" | ||||
| #~ "La vinculació per commutar la visibilitat de la llista de notificacions." | ||||
|  | ||||
| #~ msgid "Keybinding to focus the active notification" | ||||
| #~ msgstr "Vinculació per posar el focus a la notificació activa" | ||||
|  | ||||
| #~ msgid "Keybinding to focus the active notification." | ||||
| #~ msgstr "Vinculació per posar el focus a la notificació activa." | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "Keybinding that pauses and resumes all running tweens, for debugging " | ||||
| #~ "purposes" | ||||
| #~ msgstr "" | ||||
| #~ "Vinculació que fa una pausa i continua tots els «tweens» en execució, per " | ||||
| #~ "motius de depuració" | ||||
|  | ||||
| #~ msgid "Which keyboard to use" | ||||
| #~ msgstr "Quin tipus de teclat s'ha d'utilitzar" | ||||
|  | ||||
| #~ msgid "The type of keyboard to use." | ||||
| #~ msgstr "El tipus de teclat que s'utilitzarà." | ||||
|  | ||||
| #~ msgid "Limit switcher to current workspace." | ||||
| #~ msgstr "Limita el canviador a l'espai de treball actual." | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "If true, only applications that have windows on the current workspace are " | ||||
| #~ "shown in the switcher. Otherwise, all applications are included." | ||||
| #~ msgstr "" | ||||
| #~ "Si és «true» (cert), només les aplicacions que tinguin finestres en " | ||||
| #~ "l'espai de treball actual es mostren en el canviador. En cas contrari es " | ||||
| #~ "mostren totes les aplicacions." | ||||
|  | ||||
| #~ msgid "The application icon mode." | ||||
| #~ msgstr "El mode d'icona de les aplicacions." | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "Configures how the windows are shown in the switcher. Valid possibilities " | ||||
| #~ "are 'thumbnail-only' (shows a thumbnail of the window), 'app-icon-" | ||||
| #~ "only' (shows only the application icon) or 'both'." | ||||
| #~ msgstr "" | ||||
| #~ "Configureu com es mostren les finestres en l'intercanviador. Els valors " | ||||
| #~ "possibles són: «thumbnail-only» (mostra una miniatura de la finestra), " | ||||
| #~ "«app-icon-only» (mostra la icona de l'aplicació) o «both» (ambdues coses: " | ||||
| #~ "mostra la miniatura de la finestra i la icona de l'aplicació)." | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "If true, only windows from the current workspace are shown in the " | ||||
| #~ "switcher. Otherwise, all windows are included." | ||||
| #~ msgstr "" | ||||
| #~ "Si és «true» (cert), només les finestres de l'espai de treball actual es " | ||||
| #~ "mostren en el canviador. En cas contrari, es mostren totes les finestres." | ||||
|  | ||||
| #~ msgid "Attach modal dialog to the parent window" | ||||
| #~ msgstr "Adjunta el diàleg modal a la finestra pare" | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "This key overrides the key in org.gnome.mutter when running GNOME Shell." | ||||
| #~ msgstr "" | ||||
| #~ "Si s'executa el GNOME Shell, aquesta clau sobreescriu la clau «org.gnome." | ||||
| #~ "mutter»." | ||||
|  | ||||
| #~ msgid "Enable edge tiling when dropping windows on screen edges" | ||||
| #~ msgstr "" | ||||
| #~ "Habilita la tesselització a les vores en deixar anar les finestres a les " | ||||
| #~ "vores de la pantalla" | ||||
|  | ||||
| #~ msgid "Workspaces are managed dynamically" | ||||
| #~ msgstr "Els espais de treball es gestionen dinàmicament" | ||||
|  | ||||
| #~ msgid "Workspaces only on primary monitor" | ||||
| #~ msgstr "Només en el monitor principal hi ha espais de treball" | ||||
|  | ||||
| #~ msgid "Delay focus changes in mouse mode until the pointer stops moving" | ||||
| #~ msgstr "" | ||||
| #~ "Retarda el canvi del focus, quan s'està en mode ratolí, fins que el " | ||||
| #~ "punter no estigui quiet" | ||||
|  | ||||
| #~ msgid "Network Login" | ||||
| #~ msgstr "Inici de sessió de la xarxa" | ||||
|  | ||||
| #~ msgid "Use as Internet connection" | ||||
| #~ msgstr "Utilitza com a connexió a Internet" | ||||
|  | ||||
| #~ msgid "Evolution Calendar" | ||||
| #~ msgstr "Calendari de l'Evolution" | ||||
|  | ||||
| #~ msgid "%s is requesting access to your location." | ||||
| #~ msgstr "%s està demanant accés a la vostra ubicació." | ||||
|  | ||||
|   | ||||
| @@ -14,7 +14,7 @@ msgstr "" | ||||
| "PO-Revision-Date: 2014-09-14 23:32+0200\n" | ||||
| "Last-Translator: Gil Forcada <gilforcada@guifi.net>\n" | ||||
| "Language-Team: Catalan <tradgnome@softcatala.org>\n" | ||||
| "Language: ca-XV\n" | ||||
| "Language: ca@valencia\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bits\n" | ||||
|   | ||||
							
								
								
									
										2062
									
								
								po/en_GB.po
									
									
									
									
									
								
							
							
						
						
									
										2062
									
								
								po/en_GB.po
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										2
									
								
								po/gu.po
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								po/gu.po
									
									
									
									
									
								
							| @@ -13,7 +13,7 @@ msgstr "" | ||||
| "PO-Revision-Date: 2014-10-01 15:51+0530\n" | ||||
| "Last-Translator: \n" | ||||
| "Language-Team: American English <kde-i18n-doc@kde.org>\n" | ||||
| "Language: \n" | ||||
| "Language: gu\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
|   | ||||
							
								
								
									
										2
									
								
								po/ky.po
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								po/ky.po
									
									
									
									
									
								
							| @@ -14,7 +14,7 @@ msgstr "" | ||||
| "PO-Revision-Date: 2012-09-24 14:29+0600\n" | ||||
| "Last-Translator: Timur Zhamakeev <ztimur@gmail.com>\n" | ||||
| "Language-Team: Kirghiz <gnome-i18n@gnome.org>\n" | ||||
| "Language: ky_KG\n" | ||||
| "Language: ky\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
|   | ||||
							
								
								
									
										1
									
								
								po/mk.po
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								po/mk.po
									
									
									
									
									
								
							| @@ -11,6 +11,7 @@ msgstr "" | ||||
| "PO-Revision-Date: 2011-12-08 22:37+0100\n" | ||||
| "Last-Translator: Jovan N\n" | ||||
| "Language-Team: mk_MK <jovan@lugola.net>\n" | ||||
| "Language: mk\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
|   | ||||
							
								
								
									
										2
									
								
								po/ms.po
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								po/ms.po
									
									
									
									
									
								
							| @@ -11,7 +11,7 @@ msgstr "" | ||||
| "PO-Revision-Date: 2014-09-15 19:21+0730\n" | ||||
| "Last-Translator: Umarzuki Mochlis Moktar <umar@umarzuki.org>\n" | ||||
| "Language-Team: GNOME Malay Team <gnome-ms@googlegroups.com>\n" | ||||
| "Language: \n" | ||||
| "Language: ms\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
|   | ||||
							
								
								
									
										2
									
								
								po/nb.po
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								po/nb.po
									
									
									
									
									
								
							| @@ -13,7 +13,7 @@ msgstr "" | ||||
| "PO-Revision-Date: 2016-05-01 14:21+0200\n" | ||||
| "Last-Translator: Kjartan Maraas <kmaraas@gnome.org>\n" | ||||
| "Language-Team: Norwegian bokmål <i18n-nb@lister.ping.uio.no>\n" | ||||
| "Language: Norwegian bokmål\n" | ||||
| "Language: nb\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
|   | ||||
							
								
								
									
										1017
									
								
								po/pt_BR.po
									
									
									
									
									
								
							
							
						
						
									
										1017
									
								
								po/pt_BR.po
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										836
									
								
								po/sr@latin.po
									
									
									
									
									
								
							
							
						
						
									
										836
									
								
								po/sr@latin.po
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										2
									
								
								po/ug.po
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								po/ug.po
									
									
									
									
									
								
							| @@ -15,7 +15,7 @@ msgstr "" | ||||
| "PO-Revision-Date: 2013-03-07 21:01+0900\n" | ||||
| "Last-Translator: Gheyret Kenji <gheyret@gmail.com>\n" | ||||
| "Language-Team: Uyghur Computer Science Association <UKIJ@yahoogroups.com>\n" | ||||
| "Language: \n" | ||||
| "Language: ug\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
|   | ||||
							
								
								
									
										1981
									
								
								po/uz@cyrillic.po
									
									
									
									
									
								
							
							
						
						
									
										1981
									
								
								po/uz@cyrillic.po
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										1635
									
								
								po/zh_HK.po
									
									
									
									
									
								
							
							
						
						
									
										1635
									
								
								po/zh_HK.po
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -12,7 +12,9 @@ desktopdir=$(datadir)/applications | ||||
| desktop_DATA = $(desktop_in_files:.desktop.in=.desktop) | ||||
| desktop_in_files = calendar-server/evolution-calendar.desktop.in | ||||
|  | ||||
| @INTLTOOL_DESKTOP_RULE@ | ||||
| %.desktop:%.desktop.in | ||||
| 	@$(MKDIR_P) $(builddir)/calendar-server | ||||
| 	$(AM_V_GEN) $(MSGFMT) --desktop --template $< -d $(top_srcdir)/po -o $@ | ||||
|  | ||||
| gnome_shell_calendar_server_CFLAGS =		\ | ||||
| 	-I$(top_srcdir)/src			\ | ||||
| @@ -30,6 +32,7 @@ gnome_shell_calendar_server_LDADD =		\ | ||||
| EXTRA_DIST += 							  \ | ||||
| 	calendar-server/README					  \ | ||||
| 	calendar-server/org.gnome.Shell.CalendarServer.service.in \ | ||||
| 	$(desktop_in_files)					  \ | ||||
| 	$(NULL) | ||||
|  | ||||
| CLEANFILES += \ | ||||
|   | ||||
| @@ -78,7 +78,7 @@ gnome_shell_cflags =				\ | ||||
| 	-DGNOME_SHELL_PKGLIBDIR=\"$(pkglibdir)\" | ||||
|  | ||||
| privlibdir = $(pkglibdir) | ||||
| privlib_LTLIBRARIES = libgnome-shell-js.la libgnome-shell-menu.la libgnome-shell.la | ||||
| privlib_LTLIBRARIES = libgnome-shell-menu.la libgnome-shell.la | ||||
| noinst_LTLIBRARIES += libgnome-shell-base.la | ||||
|  | ||||
| shell_built_sources = \ | ||||
| @@ -200,7 +200,7 @@ gnome_shell_CPPFLAGS = \ | ||||
|  | ||||
| # Here, and after, we repeat mutter and bluetooth libraries just for the rpath | ||||
| # The dependency is already pulled in by libtool | ||||
| gnome_shell_LDADD = libgnome-shell.la libgnome-shell-js.la $(GNOME_SHELL_LIBS) $(MUTTER_LIBS) | ||||
| gnome_shell_LDADD = libgnome-shell.la $(GNOME_SHELL_LIBS) $(MUTTER_LIBS) | ||||
| gnome_shell_LDFLAGS = -rpath $(MUTTER_TYPELIB_DIR) | ||||
| gnome_shell_DEPENDENCIES = libgnome-shell.la | ||||
|  | ||||
| @@ -212,7 +212,7 @@ nodist_gnome_shell_extension_prefs_SOURCES = \ | ||||
| 	$(top_builddir)/js/js-resources.h		\ | ||||
| 	$(NULL) | ||||
| gnome_shell_extension_prefs_CPPFLAGS = $(gnome_shell_cflags) | ||||
| gnome_shell_extension_prefs_LDADD = libgnome-shell-js.la $(GNOME_SHELL_LIBS) | ||||
| gnome_shell_extension_prefs_LDADD = $(GNOME_SHELL_LIBS) | ||||
| gnome_shell_extension_prefs_LDFLAGS = -rpath $(MUTTER_TYPELIB_DIR) | ||||
|  | ||||
| if HAVE_NETWORKMANAGER | ||||
| @@ -226,30 +226,13 @@ nodist_gnome_shell_portal_helper_SOURCES = \ | ||||
| 	$(top_builddir)/js/js-resources.h		\ | ||||
| 	$(NULL) | ||||
| gnome_shell_portal_helper_CPPFLAGS = $(gnome_shell_cflags) | ||||
| gnome_shell_portal_helper_LDADD = libgnome-shell-js.la $(GNOME_SHELL_LIBS) | ||||
| gnome_shell_portal_helper_LDADD = $(GNOME_SHELL_LIBS) | ||||
| gnome_shell_portal_helper_LDFLAGS = -rpath $(MUTTER_TYPELIB_DIR) | ||||
|  | ||||
| endif | ||||
|  | ||||
| ######################################## | ||||
|  | ||||
| libgnome_shell_js_la_SOURCES =		\ | ||||
| 	shell-js.h			\ | ||||
| 	shell-js.cpp			\ | ||||
| 	$(NULL) | ||||
|  | ||||
| libgnome_shell_js_la_LIBADD =		\ | ||||
| 	$(GNOME_SHELL_JS_LIBS)		\ | ||||
| 	$(NULL) | ||||
|  | ||||
| libgnome_shell_js_la_LDFLAGS =		\ | ||||
| 	-avoid-version | ||||
|  | ||||
| libgnome_shell_js_la_CPPFLAGS =		\ | ||||
| 	$(GNOME_SHELL_JS_CFLAGS) | ||||
|  | ||||
| ######################################## | ||||
|  | ||||
| shell_recorder_sources =        \ | ||||
| 	shell-recorder.c	\ | ||||
| 	shell-recorder.h | ||||
| @@ -366,13 +349,6 @@ Shell_0_1_gir_SCANNERFLAGS =	\ | ||||
| INTROSPECTION_GIRS += Shell-0.1.gir | ||||
| CLEANFILES += Shell-0.1.gir | ||||
|  | ||||
| ShellJS-0.1.gir: libgnome-shell-js.la | ||||
| ShellJS_0_1_gir_CFLAGS = $(libgnome_shell_la_CPPFLAGS) -I $(srcdir) | ||||
| ShellJS_0_1_gir_LIBS = libgnome-shell-js.la | ||||
| ShellJS_0_1_gir_FILES = $(libgnome_shell_js_la_SOURCES) | ||||
| INTROSPECTION_GIRS += ShellJS-0.1.gir | ||||
| CLEANFILES += ShellJS-0.1.gir | ||||
|  | ||||
| St-1.0.gir: libst-1.0.la | ||||
| St_1_0_gir_INCLUDES = Clutter-1.0 Gtk-3.0 | ||||
| St_1_0_gir_CFLAGS = $(st_cflags) -DST_COMPILATION | ||||
|   | ||||
							
								
								
									
										8
									
								
								src/calendar-server/evolution-calendar.desktop.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								src/calendar-server/evolution-calendar.desktop.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| [Desktop Entry] | ||||
| Name=Evolution Calendar | ||||
| Exec=evolution -c calendar | ||||
| # Translators: Do NOT translate or transliterate this text (this is an icon file name)! | ||||
| Icon=evolution | ||||
| NoDisplay=true | ||||
| Type=Application | ||||
| StartupNotify=true | ||||
| @@ -1,7 +0,0 @@ | ||||
| [Desktop Entry] | ||||
| _Name=Evolution Calendar | ||||
| Exec=evolution -c calendar | ||||
| Icon=evolution | ||||
| NoDisplay=true | ||||
| Type=Application | ||||
| StartupNotify=true | ||||
| @@ -74,15 +74,15 @@ static App *_global_app = NULL; | ||||
|  | ||||
| typedef struct | ||||
| { | ||||
|   char *rid; | ||||
|   time_t start_time; | ||||
|   time_t end_time; | ||||
| } CalendarOccurrence; | ||||
|  | ||||
| typedef struct | ||||
| { | ||||
|   char   *id; | ||||
|   char   *uid; | ||||
|   char   *rid; | ||||
|   char   *source_id; | ||||
|   char   *backend_name; | ||||
|   char   *summary; | ||||
|   char   *description; | ||||
| @@ -95,6 +95,12 @@ typedef struct | ||||
|   GSList *occurrences; | ||||
| } CalendarAppointment; | ||||
|  | ||||
| typedef struct | ||||
| { | ||||
|   ECalClient *client; | ||||
|   GHashTable *appointments; | ||||
| } CollectAppointmentsData; | ||||
|  | ||||
| static time_t | ||||
| get_time_from_property (icalcomponent         *ical, | ||||
|                         icalproperty_kind      prop_kind, | ||||
| @@ -129,22 +135,6 @@ get_ical_uid (icalcomponent *ical) | ||||
|   return g_strdup (icalcomponent_get_uid (ical)); | ||||
| } | ||||
|  | ||||
| static char * | ||||
| get_ical_rid (icalcomponent *ical) | ||||
| { | ||||
|   icalproperty        *prop; | ||||
|   struct icaltimetype  ical_time; | ||||
|  | ||||
|   prop = icalcomponent_get_first_property (ical, ICAL_RECURRENCEID_PROPERTY); | ||||
|   if (!prop) | ||||
|     return NULL; | ||||
|  | ||||
|   ical_time = icalproperty_get_recurrenceid (prop); | ||||
|  | ||||
|   return icaltime_is_valid_time (ical_time) && !icaltime_is_null_time (ical_time) ? | ||||
|     g_strdup (icaltime_as_ical_string (ical_time)) : NULL; | ||||
| } | ||||
|  | ||||
| static char * | ||||
| get_ical_summary (icalcomponent *ical) | ||||
| { | ||||
| @@ -324,12 +314,14 @@ calendar_appointment_equal (CalendarAppointment *a, | ||||
|       CalendarOccurrence *ob = lb->data; | ||||
|  | ||||
|       if (oa->start_time != ob->start_time || | ||||
|           oa->end_time   != ob->end_time) | ||||
|           oa->end_time   != ob->end_time || | ||||
|           null_safe_strcmp (oa->rid, ob->rid) != 0) | ||||
|         return FALSE; | ||||
|     } | ||||
|  | ||||
|   return | ||||
|     null_safe_strcmp (a->uid,          b->uid)          == 0 && | ||||
|     null_safe_strcmp (a->source_id,    b->source_id)    == 0 && | ||||
|     null_safe_strcmp (a->backend_name, b->backend_name) == 0 && | ||||
|     null_safe_strcmp (a->summary,      b->summary)      == 0 && | ||||
|     null_safe_strcmp (a->description,  b->description)  == 0 && | ||||
| @@ -345,18 +337,15 @@ calendar_appointment_free (CalendarAppointment *appointment) | ||||
|   GSList *l; | ||||
|  | ||||
|   for (l = appointment->occurrences; l; l = l->next) | ||||
|     g_free (l->data); | ||||
|   g_slist_free (appointment->occurrences); | ||||
|     g_free (((CalendarOccurrence *)l->data)->rid); | ||||
|   g_slist_free_full (appointment->occurrences, g_free); | ||||
|   appointment->occurrences = NULL; | ||||
|  | ||||
|   g_free (appointment->id); | ||||
|   appointment->id = NULL; | ||||
|  | ||||
|   g_free (appointment->uid); | ||||
|   appointment->uid = NULL; | ||||
|  | ||||
|   g_free (appointment->rid); | ||||
|   appointment->rid = NULL; | ||||
|   g_free (appointment->source_id); | ||||
|   appointment->source_id = NULL; | ||||
|  | ||||
|   g_free (appointment->backend_name); | ||||
|   appointment->backend_name = NULL; | ||||
| @@ -377,13 +366,16 @@ calendar_appointment_free (CalendarAppointment *appointment) | ||||
| static void | ||||
| calendar_appointment_init (CalendarAppointment  *appointment, | ||||
|                            icalcomponent        *ical, | ||||
|                            ECalClient           *cal, | ||||
|                            icaltimezone         *default_zone) | ||||
|                            ECalClient           *cal) | ||||
| { | ||||
|   const char *source_uid; | ||||
|   icaltimezone *default_zone; | ||||
|   const char *source_id; | ||||
|  | ||||
|   source_id = e_source_get_uid (e_client_get_source (E_CLIENT (cal))); | ||||
|   default_zone = e_cal_client_get_default_timezone (cal); | ||||
|  | ||||
|   appointment->uid          = get_ical_uid (ical); | ||||
|   appointment->rid          = get_ical_rid (ical); | ||||
|   appointment->source_id    = g_strdup (source_id); | ||||
|   appointment->backend_name = get_source_backend_name (cal); | ||||
|   appointment->summary      = get_ical_summary (ical); | ||||
|   appointment->description  = get_ical_description (ical); | ||||
| @@ -393,16 +385,6 @@ calendar_appointment_init (CalendarAppointment  *appointment, | ||||
|   appointment->is_all_day   = get_ical_is_all_day (ical, | ||||
|                                                    appointment->start_time, | ||||
|                                                    default_zone); | ||||
|  | ||||
|   /* While the UID is usually enough to identify an event, only the triple | ||||
|    * of (source,UID,RID) is fully unambiguous; neither may contain '\n', | ||||
|    * so we can safely use it to create a unique ID from the triple | ||||
|    */ | ||||
|   source_uid = e_source_get_uid (e_client_get_source (E_CLIENT (cal))); | ||||
|   appointment->id = g_strdup_printf ("%s\n%s\n%s", | ||||
|                                      source_uid, | ||||
|                                      appointment->uid, | ||||
|                                      appointment->rid ? appointment->rid : ""); | ||||
| } | ||||
|  | ||||
| static icaltimezone * | ||||
| @@ -420,70 +402,52 @@ resolve_timezone_id (const char *tzid, | ||||
|   return retval; | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| calendar_appointment_collect_occurrence (ECalComponent  *component, | ||||
|                                          time_t          occurrence_start, | ||||
|                                          time_t          occurrence_end, | ||||
|                                          gpointer        data) | ||||
| { | ||||
|   CalendarOccurrence *occurrence; | ||||
|   GSList **collect_loc = data; | ||||
|  | ||||
|   occurrence             = g_new0 (CalendarOccurrence, 1); | ||||
|   occurrence->start_time = occurrence_start; | ||||
|   occurrence->end_time   = occurrence_end; | ||||
|  | ||||
|   *collect_loc = g_slist_prepend (*collect_loc, occurrence); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| static void | ||||
| calendar_appointment_generate_occurrences (CalendarAppointment *appointment, | ||||
|                                            icalcomponent       *ical, | ||||
|                                            ECalClient          *cal, | ||||
|                                            time_t               start, | ||||
|                                            time_t               end, | ||||
|                                            icaltimezone        *default_zone) | ||||
| { | ||||
|   ECalComponent *ecal; | ||||
|  | ||||
|   g_assert (appointment->occurrences == NULL); | ||||
|  | ||||
|   ecal = e_cal_component_new (); | ||||
|   e_cal_component_set_icalcomponent (ecal, | ||||
|                                      icalcomponent_new_clone (ical)); | ||||
|  | ||||
|   e_cal_recur_generate_instances (ecal, | ||||
|                                   start, | ||||
|                                   end, | ||||
|                                   calendar_appointment_collect_occurrence, | ||||
|                                   &appointment->occurrences, | ||||
|                                   (ECalRecurResolveTimezoneFn) resolve_timezone_id, | ||||
|                                   cal, | ||||
|                                   default_zone); | ||||
|  | ||||
|   g_object_unref (ecal); | ||||
|  | ||||
|   appointment->occurrences = g_slist_reverse (appointment->occurrences); | ||||
| } | ||||
|  | ||||
| static CalendarAppointment * | ||||
| calendar_appointment_new (icalcomponent        *ical, | ||||
|                           ECalClient           *cal, | ||||
|                           icaltimezone         *default_zone) | ||||
|                           ECalClient           *cal) | ||||
| { | ||||
|   CalendarAppointment *appointment; | ||||
|  | ||||
|   appointment = g_new0 (CalendarAppointment, 1); | ||||
|  | ||||
|   calendar_appointment_init (appointment, | ||||
|                              ical, | ||||
|                              cal, | ||||
|                              default_zone); | ||||
|   calendar_appointment_init (appointment, ical, cal); | ||||
|   return appointment; | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| generate_instances_cb (ECalComponent *comp, | ||||
|                        time_t         start, | ||||
|                        time_t         end, | ||||
|                        gpointer       data) | ||||
| { | ||||
|   ECalClient *cal = ((CollectAppointmentsData *)data)->client; | ||||
|   GHashTable *appointments = ((CollectAppointmentsData *)data)->appointments; | ||||
|   CalendarAppointment *appointment; | ||||
|   CalendarOccurrence *occurrence; | ||||
|   const char *uid; | ||||
|  | ||||
|   e_cal_component_get_uid (comp, &uid); | ||||
|   appointment = g_hash_table_lookup (appointments, uid); | ||||
|  | ||||
|   if (appointment == NULL) | ||||
|     { | ||||
|       icalcomponent *ical = e_cal_component_get_icalcomponent (comp); | ||||
|  | ||||
|       appointment = calendar_appointment_new (ical, cal); | ||||
|       g_hash_table_insert (appointments, g_strdup (uid), appointment); | ||||
|     } | ||||
|  | ||||
|   occurrence             = g_new0 (CalendarOccurrence, 1); | ||||
|   occurrence->start_time = start; | ||||
|   occurrence->end_time   = end; | ||||
|   occurrence->rid        = e_cal_component_get_recurid_as_string (comp); | ||||
|  | ||||
|   appointment->occurrences = g_slist_append (appointment->occurrences, occurrence); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* ---------------------------------------------------------------------------------------------------- */ | ||||
|  | ||||
| struct _App | ||||
| @@ -526,6 +490,10 @@ app_update_timezone (App *app) | ||||
|       app->timezone_location = location; | ||||
|       print_debug ("Using timezone %s", app->timezone_location); | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       g_free (location); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| @@ -619,6 +587,7 @@ app_load_events (App *app) | ||||
|   GList *ll; | ||||
|   gchar *since_iso8601; | ||||
|   gchar *until_iso8601; | ||||
|   gchar *query; | ||||
|  | ||||
|   /* out with the old */ | ||||
|   g_hash_table_remove_all (app->appointments); | ||||
| @@ -645,14 +614,19 @@ app_load_events (App *app) | ||||
|                since_iso8601, | ||||
|                until_iso8601); | ||||
|  | ||||
|   query = g_strdup_printf ("occur-in-time-range? (make-time \"%s\") " | ||||
|                            "(make-time \"%s\")", | ||||
|                            since_iso8601, | ||||
|                            until_iso8601); | ||||
|  | ||||
|   clients = calendar_sources_get_appointment_clients (app->sources); | ||||
|   for (l = clients; l != NULL; l = l->next) | ||||
|     { | ||||
|       ECalClient *cal = E_CAL_CLIENT (l->data); | ||||
|       GError *error; | ||||
|       gchar *query; | ||||
|       GSList *objects, *j; | ||||
|       ECalClientView *view; | ||||
|       CollectAppointmentsData data; | ||||
|  | ||||
|       e_cal_client_set_default_timezone (cal, app->zone); | ||||
|  | ||||
| @@ -666,45 +640,13 @@ app_load_events (App *app) | ||||
|           continue; | ||||
|         } | ||||
|  | ||||
|       query = g_strdup_printf ("occur-in-time-range? (make-time \"%s\") " | ||||
|                                "(make-time \"%s\")", | ||||
|                                since_iso8601, | ||||
|                                until_iso8601); | ||||
|       error = NULL; | ||||
|       objects = NULL; | ||||
|       if (!e_cal_client_get_object_list_sync (cal, | ||||
| 					      query, | ||||
| 					      &objects, | ||||
| 					      NULL, /* cancellable */ | ||||
| 					      &error)) | ||||
|         { | ||||
|           ESource *source = e_client_get_source (E_CLIENT (cal)); | ||||
|           g_warning ("Error querying calendar %s: %s\n", | ||||
| 		     e_source_get_uid (source), error->message); | ||||
|           g_error_free (error); | ||||
|           g_free (query); | ||||
|           continue; | ||||
|         } | ||||
|  | ||||
|       for (j = objects; j != NULL; j = j->next) | ||||
|         { | ||||
|           icalcomponent *ical = j->data; | ||||
|           CalendarAppointment *appointment; | ||||
|  | ||||
|           appointment = calendar_appointment_new (ical, cal, app->zone); | ||||
|           if (appointment == NULL) | ||||
|             continue; | ||||
|  | ||||
|           calendar_appointment_generate_occurrences (appointment, | ||||
|                                                      ical, | ||||
|                                                      cal, | ||||
|                                                      app->since, | ||||
|                                                      app->until, | ||||
|                                                      app->zone); | ||||
|           g_hash_table_insert (app->appointments, g_strdup (appointment->uid), appointment); | ||||
|         } | ||||
|  | ||||
|       e_cal_client_free_icalcomp_slist (objects); | ||||
|       data.client = cal; | ||||
|       data.appointments = app->appointments; | ||||
|       e_cal_client_generate_instances_sync (cal, | ||||
|                                             app->since, | ||||
|                                             app->until, | ||||
|                                             generate_instances_cb, | ||||
|                                             &data); | ||||
|  | ||||
|       error = NULL; | ||||
|       if (!e_cal_client_get_view_sync (cal, | ||||
| @@ -733,12 +675,11 @@ app_load_events (App *app) | ||||
|           e_cal_client_view_start (view, NULL); | ||||
|           app->live_views = g_list_prepend (app->live_views, view); | ||||
|         } | ||||
|  | ||||
|       g_free (query); | ||||
|     } | ||||
|   g_list_free (clients); | ||||
|   g_free (since_iso8601); | ||||
|   g_free (until_iso8601); | ||||
|   g_free (query); | ||||
|   app->cache_invalid = FALSE; | ||||
| } | ||||
|  | ||||
| @@ -929,16 +870,27 @@ handle_method_call (GDBusConnection       *connection, | ||||
|                   (start_time <= app->since && | ||||
|                   (end_time - 1) > app->since)) | ||||
|                 { | ||||
|                   /* While the UID is usually enough to identify an event, | ||||
|                    * only the triple of (source,UID,RID) is fully unambiguous; | ||||
|                    * neither may contain '\n', so we can safely use it to | ||||
|                    * create a unique ID from the triple | ||||
|                    */ | ||||
|                   char *id = g_strdup_printf ("%s\n%s\n%s", | ||||
|                                               a->source_id, | ||||
|                                               a->uid, | ||||
|                                               o->rid ? o->rid : ""); | ||||
|  | ||||
|                   g_variant_builder_init (&extras_builder, G_VARIANT_TYPE ("a{sv}")); | ||||
|                   g_variant_builder_add (&builder, | ||||
|                                          "(sssbxxa{sv})", | ||||
|                                          a->id, | ||||
|                                          id, | ||||
|                                          a->summary != NULL ? a->summary : "", | ||||
|                                          a->description != NULL ? a->description : "", | ||||
|                                          (gboolean) a->is_all_day, | ||||
|                                          (gint64) start_time, | ||||
|                                          (gint64) end_time, | ||||
|                                          extras_builder); | ||||
|                   g_free (id); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|   | ||||
| @@ -6,8 +6,6 @@ | ||||
| #include <gjs/gjs.h> | ||||
| #include <glib/gi18n.h> | ||||
|  | ||||
| #include "shell-js.h" | ||||
|  | ||||
| int | ||||
| main (int argc, char *argv[]) | ||||
| { | ||||
| @@ -51,18 +49,3 @@ main (int argc, char *argv[]) | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* HACK: | ||||
|    Add a dummy function that calls into libgnome-shell-js.so to ensure it's | ||||
|    linked to /usr/bin/gnome-shell-extension-prefs even when linking with | ||||
|    --as-needed. This function is never actually called. | ||||
|    https://bugzilla.gnome.org/show_bug.cgi?id=670477 | ||||
| */ | ||||
| void _shell_link_to_shell_js (void); | ||||
|  | ||||
| void | ||||
| _shell_link_to_shell_js (void) | ||||
| { | ||||
|   shell_js_add_extension_importer (NULL, NULL, NULL, NULL); | ||||
| } | ||||
|   | ||||
							
								
								
									
										15
									
								
								src/main.c
									
									
									
									
									
								
							
							
						
						
									
										15
									
								
								src/main.c
									
									
									
									
									
								
							| @@ -25,7 +25,6 @@ | ||||
|  | ||||
| #include "shell-global.h" | ||||
| #include "shell-global-private.h" | ||||
| #include "shell-js.h" | ||||
| #include "shell-perf-log.h" | ||||
| #include "st.h" | ||||
|  | ||||
| @@ -480,17 +479,3 @@ main (int argc, char **argv) | ||||
|  | ||||
|   return ecode; | ||||
| } | ||||
|  | ||||
| /* HACK: | ||||
|    Add a dummy function that calls into libgnome-shell-js.so to ensure it's | ||||
|    linked to /usr/bin/gnome-shell even when linking with --as-needed. | ||||
|    This function is never actually called. | ||||
|    https://bugzilla.gnome.org/show_bug.cgi?id=670477 | ||||
| */ | ||||
| void _shell_link_to_shell_js (void); | ||||
|  | ||||
| void | ||||
| _shell_link_to_shell_js (void) | ||||
| { | ||||
|   shell_js_add_extension_importer (NULL, NULL, NULL, NULL); | ||||
| } | ||||
|   | ||||
| @@ -59,6 +59,8 @@ main(int argc, char **argv) | ||||
|   gsize len; | ||||
|   int code; | ||||
|  | ||||
|   gdk_set_allowed_backends("x11"); | ||||
|  | ||||
|   gtk_init (&argc, &argv); | ||||
|  | ||||
|   clutter_x11_set_display (GDK_DISPLAY_XDISPLAY (gdk_display_get_default ())); | ||||
| @@ -66,6 +68,9 @@ main(int argc, char **argv) | ||||
|   if (clutter_init (&argc, &argv) != CLUTTER_INIT_SUCCESS) | ||||
|     return 1; | ||||
|  | ||||
|   g_object_set (clutter_settings_get_default (), "window-scaling-factor", 1, NULL); | ||||
|   gdk_x11_display_set_window_scale (gdk_display_get_default (), 1); | ||||
|  | ||||
|   context = g_option_context_new (NULL); | ||||
|  | ||||
|   /* pass unknown through to the JS script */ | ||||
|   | ||||
| @@ -96,7 +96,8 @@ enum { | ||||
|   PROP_ID, | ||||
|   PROP_DBUS_ID, | ||||
|   PROP_ACTION_GROUP, | ||||
|   PROP_MENU | ||||
|   PROP_MENU, | ||||
|   PROP_APP_INFO | ||||
| }; | ||||
|  | ||||
| enum { | ||||
| @@ -138,6 +139,29 @@ shell_app_get_property (GObject    *gobject, | ||||
|       if (app->running_state) | ||||
|         g_value_set_object (value, app->running_state->remote_menu); | ||||
|       break; | ||||
|     case PROP_APP_INFO: | ||||
|       if (app->info) | ||||
|         g_value_set_object (value, app->info); | ||||
|       break; | ||||
|     default: | ||||
|       G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec); | ||||
|       break; | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void | ||||
| shell_app_set_property (GObject      *gobject, | ||||
|                         guint         prop_id, | ||||
|                         const GValue *value, | ||||
|                         GParamSpec   *pspec) | ||||
| { | ||||
|   ShellApp *app = SHELL_APP (gobject); | ||||
|  | ||||
|   switch (prop_id) | ||||
|     { | ||||
|     case PROP_APP_INFO: | ||||
|       _shell_app_set_app_info (app, g_value_get_object (value)); | ||||
|       break; | ||||
|     default: | ||||
|       G_OBJECT_WARN_INVALID_PROPERTY_ID (gobject, prop_id, pspec); | ||||
|       break; | ||||
| @@ -806,9 +830,9 @@ _shell_app_new (GDesktopAppInfo *info) | ||||
| { | ||||
|   ShellApp *app; | ||||
|  | ||||
|   app = g_object_new (SHELL_TYPE_APP, NULL); | ||||
|  | ||||
|   _shell_app_set_app_info (app, info); | ||||
|   app = g_object_new (SHELL_TYPE_APP, | ||||
|                       "app-info", info, | ||||
|                       NULL); | ||||
|  | ||||
|   return app; | ||||
| } | ||||
| @@ -817,12 +841,11 @@ void | ||||
| _shell_app_set_app_info (ShellApp        *app, | ||||
|                          GDesktopAppInfo *info) | ||||
| { | ||||
|   g_clear_object (&app->info); | ||||
|   app->info = g_object_ref (info); | ||||
|   g_set_object (&app->info, info); | ||||
|  | ||||
|   if (app->name_collation_key != NULL) | ||||
|     g_free (app->name_collation_key); | ||||
|   app->name_collation_key = g_utf8_collate_key (shell_app_get_name (app), -1); | ||||
|   g_clear_pointer (&app->name_collation_key, g_free); | ||||
|   if (app->info) | ||||
|     app->name_collation_key = g_utf8_collate_key (shell_app_get_name (app), -1); | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -1405,6 +1428,7 @@ shell_app_class_init(ShellAppClass *klass) | ||||
|   GObjectClass *gobject_class = G_OBJECT_CLASS (klass); | ||||
|  | ||||
|   gobject_class->get_property = shell_app_get_property; | ||||
|   gobject_class->set_property = shell_app_set_property; | ||||
|   gobject_class->dispose = shell_app_dispose; | ||||
|   gobject_class->finalize = shell_app_finalize; | ||||
|  | ||||
| @@ -1483,5 +1507,17 @@ shell_app_class_init(ShellAppClass *klass) | ||||
|                                                         "The primary menu exported by the remote application", | ||||
|                                                         G_TYPE_MENU_MODEL, | ||||
|                                                         G_PARAM_READABLE | G_PARAM_STATIC_STRINGS)); | ||||
|   /** | ||||
|    * ShellApp:app-info: | ||||
|    * | ||||
|    * The #GDesktopAppInfo associated with this ShellApp, if any. | ||||
|    */ | ||||
|   g_object_class_install_property (gobject_class, | ||||
|                                    PROP_APP_INFO, | ||||
|                                    g_param_spec_object ("app-info", | ||||
|                                                         "DesktopAppInfo", | ||||
|                                                         "The DesktopAppInfo associated with this app", | ||||
|                                                         G_TYPE_DESKTOP_APP_INFO, | ||||
|                                                         G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY | G_PARAM_STATIC_STRINGS)); | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -277,6 +277,7 @@ shell_global_init (ShellGlobal *global) | ||||
|                           XDisplayName (NULL)); | ||||
|   (void) g_mkdir_with_parents (path, 0700); | ||||
|   global->runtime_state_path = g_file_new_for_path (path); | ||||
|   g_free (path); | ||||
|  | ||||
|   global->settings = g_settings_new ("org.gnome.shell"); | ||||
|  | ||||
| @@ -1583,7 +1584,7 @@ shell_global_get_current_time (ShellGlobal *global) | ||||
|  */ | ||||
| GAppLaunchContext * | ||||
| shell_global_create_app_launch_context (ShellGlobal *global, | ||||
|                                         int          timestamp, | ||||
|                                         guint32      timestamp, | ||||
|                                         int          workspace) | ||||
| { | ||||
|   GdkAppLaunchContext *context; | ||||
|   | ||||
| @@ -71,7 +71,7 @@ void     shell_global_sync_pointer              (ShellGlobal  *global); | ||||
|  | ||||
| GAppLaunchContext * | ||||
|          shell_global_create_app_launch_context (ShellGlobal  *global, | ||||
|                                                  int           timestamp, | ||||
|                                                  guint32       timestamp, | ||||
|                                                  int           workspace); | ||||
|  | ||||
| void     shell_global_play_theme_sound          (ShellGlobal *global, | ||||
|   | ||||
| @@ -1,77 +0,0 @@ | ||||
| /* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */ | ||||
|  | ||||
| #include "config.h" | ||||
|  | ||||
| #include "shell-js.h" | ||||
|  | ||||
| #include <gio/gio.h> | ||||
| #include <gjs/gjs.h> | ||||
| #include <gjs/gjs-module.h> | ||||
|  | ||||
| /** | ||||
|  * shell_js_add_extension_importer: | ||||
|  * @target_object_script: JavaScript code evaluating to a target object | ||||
|  * @target_property: Name of property to use for importer | ||||
|  * @directory: Source directory: | ||||
|  * @error: A #GError | ||||
|  * | ||||
|  * This function sets a property named @target_property on the object | ||||
|  * resulting from the evaluation of @target_object_script code, which | ||||
|  * acts as a GJS importer for directory @directory. | ||||
|  * | ||||
|  * Returns: %TRUE on success | ||||
|  */ | ||||
| gboolean | ||||
| shell_js_add_extension_importer (const char  *target_object_script, | ||||
|                                  const char  *target_property, | ||||
|                                  const char  *directory, | ||||
|                                  GError     **error) | ||||
| { | ||||
|   jsval target_object; | ||||
|   GList *contexts; | ||||
|   JSContext *context; | ||||
|   char *search_path[2] = { 0, 0 }; | ||||
|   gboolean ret = FALSE; | ||||
|  | ||||
|   /* Take the first GjsContext from all of them -- | ||||
|    * we should only ever have one context, so this | ||||
|    * should be alright. */ | ||||
|   contexts = gjs_context_get_all (); | ||||
|   context = (JSContext*) gjs_context_get_native_context ((GjsContext*)contexts->data); | ||||
|   g_list_free_full (contexts, g_object_unref); | ||||
|  | ||||
|   JS_BeginRequest (context); | ||||
|  | ||||
|   /* This is a bit of a hack; ideally we'd be able to pass our target | ||||
|    * object directly into this function, but introspection doesn't | ||||
|    * support that at the moment.  Instead evaluate a string to get it. */ | ||||
|   if (!JS_EvaluateScript(context, | ||||
|                          JS_GetGlobalObject(context), | ||||
|                          target_object_script, | ||||
|                          strlen (target_object_script), | ||||
|                          "<target_object_script>", | ||||
|                          0, | ||||
|                          &target_object)) | ||||
|     { | ||||
|       gjs_log_exception(context); | ||||
|       g_set_error(error, | ||||
|                   G_IO_ERROR, | ||||
|                   G_IO_ERROR_FAILED, | ||||
|                   "Unable to import %s", target_object_script); | ||||
|       goto out; | ||||
|     } | ||||
|  | ||||
|   if (!JSVAL_IS_OBJECT (target_object)) | ||||
|     { | ||||
|       g_error ("shell_js_add_extension_importer: invalid target object"); | ||||
|       goto out; | ||||
|     } | ||||
|  | ||||
|   search_path[0] = (char*)directory; | ||||
|   gjs_define_importer (context, JSVAL_TO_OBJECT (target_object), target_property, (const char **)search_path, FALSE); | ||||
|   ret = TRUE; | ||||
|  | ||||
|  out: | ||||
|   JS_EndRequest (context); | ||||
|   return ret; | ||||
| } | ||||
| @@ -1,16 +0,0 @@ | ||||
| /* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */ | ||||
| #ifndef __SHELL_JS_H__ | ||||
| #define __SHELL_JS_H__ | ||||
|  | ||||
| #include <glib.h> | ||||
|  | ||||
| G_BEGIN_DECLS | ||||
|  | ||||
| gboolean shell_js_add_extension_importer (const char   *target_object_script, | ||||
|                                           const char   *target_property, | ||||
|                                           const char   *directory, | ||||
|                                           GError      **error); | ||||
|  | ||||
| G_END_DECLS | ||||
|  | ||||
| #endif /* __SHELL_JS_H__ */ | ||||
| @@ -22,6 +22,7 @@ | ||||
| #include "shell-global.h" | ||||
| #include "shell-recorder-src.h" | ||||
| #include "shell-recorder.h" | ||||
| #include "shell-util.h" | ||||
|  | ||||
| #define A11Y_APPS_SCHEMA "org.gnome.desktop.a11y.applications" | ||||
| #define MAGNIFIER_ACTIVE_KEY "screen-magnifier-enabled" | ||||
| @@ -107,6 +108,8 @@ static void recorder_set_draw_cursor (ShellRecorder *recorder, | ||||
| static void recorder_pipeline_set_caps (RecorderPipeline *pipeline); | ||||
| static void recorder_pipeline_closed   (RecorderPipeline *pipeline); | ||||
|  | ||||
| static void recorder_remove_redraw_timeout (ShellRecorder *recorder); | ||||
|  | ||||
| enum { | ||||
|   PROP_0, | ||||
|   PROP_SCREEN, | ||||
| @@ -235,6 +238,8 @@ shell_recorder_finalize (GObject  *object) | ||||
|   recorder_set_pipeline (recorder, NULL); | ||||
|   recorder_set_file_template (recorder, NULL); | ||||
|  | ||||
|   recorder_remove_redraw_timeout (recorder); | ||||
|  | ||||
|   g_clear_object (&recorder->a11y_settings); | ||||
|  | ||||
|   G_OBJECT_CLASS (shell_recorder_parent_class)->finalize (object); | ||||
| @@ -317,6 +322,9 @@ recorder_fetch_cursor_image (ShellRecorder *recorder) | ||||
|   guint8 *data; | ||||
|  | ||||
|   texture = meta_cursor_tracker_get_sprite (recorder->cursor_tracker); | ||||
|   if (!texture) | ||||
|     return; | ||||
|  | ||||
|   width = cogl_texture_get_width (texture); | ||||
|   height = cogl_texture_get_height (texture); | ||||
|   stride = 4 * width; | ||||
| @@ -382,11 +390,17 @@ recorder_draw_cursor (ShellRecorder *recorder, | ||||
| /* Retrieve a frame and feed it into the pipeline | ||||
|  */ | ||||
| static void | ||||
| recorder_record_frame (ShellRecorder *recorder) | ||||
| recorder_record_frame (ShellRecorder *recorder, | ||||
|                        gboolean       paint) | ||||
| { | ||||
|   GstBuffer *buffer; | ||||
|   guint8 *data; | ||||
|   ClutterCapture *captures; | ||||
|   int n_captures; | ||||
|   cairo_surface_t *image; | ||||
|   guint size; | ||||
|   uint8_t *data; | ||||
|   GstMemory *memory; | ||||
|   int i; | ||||
|   GstClock *clock; | ||||
|   GstClockTime now, base_time; | ||||
|  | ||||
| @@ -418,21 +432,35 @@ recorder_record_frame (ShellRecorder *recorder) | ||||
|     return; | ||||
|   recorder->last_frame_time = now; | ||||
|  | ||||
|   size = recorder->area.width * recorder->area.height * 4; | ||||
|   clutter_stage_capture (recorder->stage, paint, &recorder->area, | ||||
|                          &captures, &n_captures); | ||||
|  | ||||
|   data = g_malloc (size); | ||||
|   cogl_framebuffer_read_pixels (cogl_get_draw_framebuffer (), | ||||
|                                 recorder->area.x, | ||||
|                                 recorder->area.y, | ||||
|                                 recorder->area.width, | ||||
|                                 recorder->area.height, | ||||
|                                 CLUTTER_CAIRO_FORMAT_ARGB32, | ||||
|                                 data); | ||||
|   if (n_captures == 0) | ||||
|     return; | ||||
|  | ||||
|   if (n_captures == 1) | ||||
|     image = cairo_surface_reference (captures[0].image); | ||||
|   else | ||||
|     image = shell_util_composite_capture_images (captures, | ||||
|                                                  n_captures, | ||||
|                                                  recorder->area.x, | ||||
|                                                  recorder->area.y, | ||||
|                                                  recorder->area.width, | ||||
|                                                  recorder->area.height); | ||||
|  | ||||
|   data = cairo_image_surface_get_data (image); | ||||
|   size = (cairo_image_surface_get_height (image) * | ||||
|           cairo_image_surface_get_stride (image)); | ||||
|  | ||||
|   for (i = 0; i < n_captures; i++) | ||||
|     cairo_surface_destroy (captures[i].image); | ||||
|   g_free (captures); | ||||
|  | ||||
|   buffer = gst_buffer_new(); | ||||
|   gst_buffer_insert_memory (buffer, -1, | ||||
|                             gst_memory_new_wrapped (0, data, size, 0, | ||||
|                                                     size, data, g_free)); | ||||
|   memory = gst_memory_new_wrapped (0, data, size, 0, size, | ||||
|                                    image, | ||||
|                                    (GDestroyNotify) cairo_surface_destroy); | ||||
|   gst_buffer_insert_memory (buffer, -1, memory); | ||||
|  | ||||
|   GST_BUFFER_PTS(buffer) = now; | ||||
|  | ||||
| @@ -456,7 +484,7 @@ recorder_on_stage_paint (ClutterActor  *actor, | ||||
|                          ShellRecorder *recorder) | ||||
| { | ||||
|   if (recorder->state == RECORDER_STATE_RECORDING) | ||||
|     recorder_record_frame (recorder); | ||||
|     recorder_record_frame (recorder, FALSE); | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -1052,7 +1080,7 @@ recorder_open_outfile (ShellRecorder  *recorder, | ||||
|  | ||||
|       if (outfile == -1 && errno != EEXIST) | ||||
|         { | ||||
|           g_warning ("Cannot open output file '%s': %s", filename->str, g_strerror (errno)); | ||||
|           g_warning ("Cannot open output file '%s': %s", path, g_strerror (errno)); | ||||
|           g_string_free (filename, TRUE); | ||||
|           g_free (path); | ||||
|           goto out; | ||||
| @@ -1554,7 +1582,7 @@ shell_recorder_close (ShellRecorder *recorder) | ||||
|   /* We want to record one more frame since some time may have | ||||
|    * elapsed since the last frame | ||||
|    */ | ||||
|   clutter_actor_paint (CLUTTER_ACTOR (recorder->stage)); | ||||
|   recorder_record_frame (recorder, TRUE); | ||||
|  | ||||
|   recorder_remove_update_pointer_timeout (recorder); | ||||
|   recorder_close_pipeline (recorder); | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user