Compare commits
	
		
			204 Commits
		
	
	
		
			3.10.1.1
			...
			wip/waylan
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 531a7b2812 | ||
|   | 580669cdea | ||
|   | e50a578ad3 | ||
|   | 06b3d36e97 | ||
|   | 715fa91599 | ||
|   | 997188e914 | ||
|   | c6dd56f9ce | ||
|   | 466af03ed3 | ||
|   | 9c2d806556 | ||
|   | 13a7c8da85 | ||
|   | d69d566087 | ||
|   | b722274886 | ||
|   | 164cdabb21 | ||
|   | 0b025f0e9c | ||
|   | 87354bdac6 | ||
|   | 02e163882a | ||
|   | 9db02a7379 | ||
|   | 78fcfec5c1 | ||
|   | 1bd3a162f8 | ||
|   | 918cfdcbda | ||
|   | cd76313297 | ||
|   | dc8231c2cf | ||
|   | 4d01eb3a23 | ||
|   | 35f47b211d | ||
|   | 77046edf21 | ||
|   | 488df061c7 | ||
|   | 21d511e50f | ||
|   | 15e83f0c2f | ||
|   | a23830fd13 | ||
|   | c8bf8c17be | ||
|   | d82e24981b | ||
|   | 01b8ffac5d | ||
|   | 1fa56bd7e0 | ||
|   | c3f28b9cdb | ||
|   | dc4e1d4cd1 | ||
|   | d69553e8f5 | ||
|   | 0ead0d945a | ||
|   | c24d9bf142 | ||
|   | a6bf340ff8 | ||
|   | 35ef7c95b2 | ||
|   | 348f3007d9 | ||
|   | 52e2a1226e | ||
|   | 58622c0515 | ||
|   | cb5e1e2776 | ||
|   | e965cf32d4 | ||
|   | ce5e0b20b5 | ||
|   | 90854a0f80 | ||
|   | 2d9dc143fc | ||
|   | 1e52d2aa9c | ||
|   | 2734c8547f | ||
|   | cc0b093f7a | ||
|   | d25275fa8d | ||
|   | 389e04c715 | ||
|   | 24074a81d0 | ||
|   | c0e7f6d9bf | ||
|   | 9a13b857f4 | ||
|   | 776a86a65f | ||
|   | 76e2455d1b | ||
|   | 81d9797544 | ||
|   | 12d6c70000 | ||
|   | a7eaf43e18 | ||
|   | 514fec7275 | ||
|   | 42a5f4f479 | ||
|   | 6c1feedbdf | ||
|   | 2d21fbbd35 | ||
|   | 7baf687499 | ||
|   | a3e44d13d1 | ||
|   | 65db8efbe8 | ||
|   | e48a5cd5f2 | ||
|   | 698bb24848 | ||
|   | 67fff237e6 | ||
|   | b9247b4b2f | ||
|   | 0394b4a82b | ||
|   | ff7c85c599 | ||
|   | c316ad17a4 | ||
|   | fc108d5052 | ||
|   | 8c0d38a1a1 | ||
|   | 2f9c6c4146 | ||
|   | 72ca2b218d | ||
|   | 7360aece74 | ||
|   | b5f3238f6f | ||
|   | 227fb56103 | ||
|   | 5ae52473c9 | ||
|   | 7b537d6b8f | ||
|   | 4494888b82 | ||
|   | 004ee2d3b5 | ||
|   | 168ea64a45 | ||
|   | 73ee491281 | ||
|   | 95a9655412 | ||
|   | 72b6699efb | ||
|   | 3e341e83d9 | ||
|   | 5b3340e585 | ||
|   | 6f4f611ba8 | ||
|   | 450afbaf51 | ||
|   | 28708e4317 | ||
|   | 9f64f2cf4f | ||
|   | 2b1eb206d3 | ||
|   | a6dc454c49 | ||
|   | c2bf44fa19 | ||
|   | 2d67b01c3a | ||
|   | 6014d31dea | ||
|   | bf78f067a2 | ||
|   | ddb9929dad | ||
|   | 2098ec2d16 | ||
|   | 97eece6607 | ||
|   | 7ac9a6e241 | ||
|   | b53bf0e8c2 | ||
|   | a26ded47d9 | ||
|   | cad9e14463 | ||
|   | 806d5939e3 | ||
|   | 0f0c23fbab | ||
|   | 5d1fcc26c0 | ||
|   | cbe5b6b3bc | ||
|   | 590cf4e832 | ||
|   | 22ca820c44 | ||
|   | b1206ceb66 | ||
|   | ad4053ab84 | ||
|   | 7bd4e6ecb0 | ||
|   | deeb1db1ac | ||
|   | 7eb4bfbea3 | ||
|   | 59b274f12f | ||
|   | e311cef013 | ||
|   | e72f81c24f | ||
|   | 96fa518576 | ||
|   | e263b3624c | ||
|   | 1c34f0b342 | ||
|   | 2d27873f98 | ||
|   | fd40a12213 | ||
|   | 57406e0a9e | ||
|   | 1987cbb764 | ||
|   | 705978405b | ||
|   | daba05f6a7 | ||
|   | 1a7984be43 | ||
|   | 1b3c77d53a | ||
|   | 5b0f0d9e5b | ||
|   | 9816659fa9 | ||
|   | 3b1b611634 | ||
|   | f08921bd0c | ||
|   | 0089b5769c | ||
|   | 452be05ea0 | ||
|   | 69f038f7c7 | ||
|   | 2d35e07fae | ||
|   | 95e2d26d03 | ||
|   | f506e090ea | ||
|   | 0697b53826 | ||
|   | 7d9141c56f | ||
|   | 519a06b93d | ||
|   | 0cceddab75 | ||
|   | c9830c13b4 | ||
|   | 9a4783e364 | ||
|   | aa15c09d54 | ||
|   | 62d908be42 | ||
|   | 6526e9882b | ||
|   | ab72352c47 | ||
|   | f09b9573f0 | ||
|   | 3d3ae40f79 | ||
|   | ea3d2b4759 | ||
|   | 542a0886cf | ||
|   | bd3d5df9ce | ||
|   | 91cdfab495 | ||
|   | 1617323dca | ||
|   | bbf9358eba | ||
|   | 9682a2aea4 | ||
|   | c9fbb51775 | ||
|   | aa6d887214 | ||
|   | 13312527de | ||
|   | 9bd366f2a6 | ||
|   | 5de346bfef | ||
|   | 2af20b77b6 | ||
|   | 9affbf10a6 | ||
|   | c0acf3ae6d | ||
|   | 2c1b20e15f | ||
|   | 77290b6736 | ||
|   | 876f81db12 | ||
|   | 75f3ae14b5 | ||
|   | d26f248b0f | ||
|   | eeb3dfc991 | ||
|   | e66db2eab3 | ||
|   | 2ae7454f36 | ||
|   | 4fd3c63da9 | ||
|   | bfc87d13cb | ||
|   | 24564c77d6 | ||
|   | 18a21b67c2 | ||
|   | 3803fd9511 | ||
|   | 152d896f75 | ||
|   | 2f3a5f2001 | ||
|   | 0e098249b1 | ||
|   | 9a5f243f73 | ||
|   | 03f55b9485 | ||
|   | ef9ef87d91 | ||
|   | 0ee2c21da7 | ||
|   | 9b966561c4 | ||
|   | 8c0779a9db | ||
|   | 2c901cc015 | ||
|   | 85e66f69fa | ||
|   | a5585327dc | ||
|   | 268ebb1b18 | ||
|   | 40e820f551 | ||
|   | f9a11b3b18 | ||
|   | bd3c357212 | ||
|   | b4d108dac6 | ||
|   | 6585a5760b | ||
|   | 531be6c413 | ||
|   | f0c503b5a9 | 
							
								
								
									
										18
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -23,7 +23,7 @@ src/50-mutter-navigation.xml | ||||
| src/50-mutter-system.xml | ||||
| src/50-mutter-windows.xml | ||||
| src/mutter-wm.desktop | ||||
| src/mutter.desktop | ||||
| src/mutter-wayland.desktop | ||||
| *.o | ||||
| *.a | ||||
| *.lo | ||||
| @@ -46,16 +46,16 @@ POTFILES | ||||
| po/*.pot | ||||
| 50-metacity-desktop-key.xml | ||||
| 50-metacity-key.xml | ||||
| libmutter.pc | ||||
| mutter | ||||
| mutter-theme-viewer | ||||
| mutter.desktop | ||||
| libmutter-wayland.pc | ||||
| mutter-wayland | ||||
| mutter-launch | ||||
| org.gnome.mutter.gschema.valid | ||||
| org.gnome.mutter.gschema.xml | ||||
| org.gnome.mutter.wayland.gschema.valid | ||||
| org.gnome.mutter.wayland.gschema.xml | ||||
| testasyncgetprop | ||||
| testboxes | ||||
| testgradient | ||||
| m4/* | ||||
| mutter-grayscale | ||||
| mutter-mag | ||||
| mutter-message | ||||
| @@ -78,6 +78,12 @@ src/stamp-mutter-marshal.h | ||||
| src/meta-dbus-xrandr.[ch] | ||||
| src/meta-dbus-idle-monitor.[ch] | ||||
| src/mutter-plugins.pc | ||||
| src/wayland/gtk-shell-protocol.c | ||||
| src/wayland/gtk-shell-client-protocol.h | ||||
| src/wayland/gtk-shell-server-protocol.h | ||||
| src/wayland/xserver-protocol.c | ||||
| src/wayland/xserver-client-protocol.h | ||||
| src/wayland/xserver-server-protocol.h | ||||
| doc/reference/*.args | ||||
| doc/reference/*.bak | ||||
| doc/reference/*.hierarchy | ||||
|   | ||||
| @@ -1,10 +1,10 @@ | ||||
|  | ||||
| SUBDIRS=src po doc | ||||
|  | ||||
| ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS} | ||||
| SUBDIRS=src protocol po doc | ||||
|  | ||||
| EXTRA_DIST = HACKING MAINTAINERS rationales.txt | ||||
|  | ||||
| DISTCLEANFILES = intltool-extract intltool-merge intltool-update po/stamp-it po/.intltool-merge-cache | ||||
|  | ||||
| DISTCHECK_CONFIGURE_FLAGS = --enable-gtk-doc | ||||
|  | ||||
| ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS} | ||||
|   | ||||
							
								
								
									
										75
									
								
								NEWS
									
									
									
									
									
								
							
							
						
						
									
										75
									
								
								NEWS
									
									
									
									
									
								
							| @@ -1,25 +1,25 @@ | ||||
| 3.10.1.1 | ||||
| ======== | ||||
| * Don't assert that at least one output is connected [Giovanni; #709009] | ||||
| 3.11.1 | ||||
| ====== | ||||
| * Fix tile previews getting stuck on right click during drags [Lionel; #704759] | ||||
| * Use new UPower API [Bastien] | ||||
| * Set hot spot when cursor set from wl_buffer [Jonas; #709593] | ||||
| * Expose min-backlight-step [Asad; #710380] | ||||
| * Misc. bug fixes and cleanups [Jasper, Olav, Magdalen; #709776] | ||||
|  | ||||
| Contributors: | ||||
|   Giovanni Campagna | ||||
|   Magdalen Berns, Lionel Landwerlin, Asad Mehmood, Bastien Nocera, | ||||
|   Jasper St. Pierre, Olav Vitters, Jonas Ådahl | ||||
|  | ||||
| 3.10.1 | ||||
| ====== | ||||
| * Don't apply fullscreen workarounds to CSD windows [Giovanni; #708718] | ||||
| * Fix hangs during DND operations [Adel; #709340] | ||||
| * Use nearest-pixel interpolation when possible [Hans; #708389] | ||||
| * Fix tile previews getting stuck on right click during drags [Lionel; #704759] | ||||
| * Misc bug fixes [Giovanni, Jasper; #708420] | ||||
| * Misc bug fixes [Dan, Giovanni, Jasper; #708813, #708420] | ||||
|  | ||||
| Contributors: | ||||
|   Giovanni Campagna, Adel Gadllah, Lionel Landwerlin, Hans Petter Jansson, | ||||
|   Giovanni Campagna, Adel Gadllah, Dan Horák, Hans Petter Jansson, | ||||
|   Jasper St. Pierre | ||||
|  | ||||
| Translations: | ||||
|   Khaled Hosny [ar], Reinout van Schouwen [nl], Carles Ferrando [ca@valencia] | ||||
|  | ||||
| 3.10.0.1 | ||||
| ======== | ||||
| * Fix bug when a window changed size twice in a single frame - this | ||||
| @@ -30,24 +30,32 @@ Contributors: | ||||
|  | ||||
| 3.10.0 | ||||
| ====== | ||||
|  | ||||
| Translations: | ||||
|   Ask H. Larsen [da], Gabor Kelemen [hu], Duarte Loreto [pt], | ||||
|   Yosef Or Boczko [he] | ||||
| * Update dependencies [Giovanni; #708210] | ||||
|  | ||||
| 3.9.92 | ||||
| ====== | ||||
| * Don't create a dummy texture for the texture pipeline template [Neil; #707458] | ||||
| * Remove holes generated by disabling the laptop lid [Giovanni; #707473] | ||||
| * https://bugzilla.gnome.org/show_bug.cgi?id=707474 [Giovanni; #707474] | ||||
| * Constrain the pointer position onto visible monitors [Giovanni; #706655] | ||||
| * Fix keyboard state handling in face of event compression [Giovanni; #706963] | ||||
| * Extend the MetaCursorTracker API with query pointer and cursor visibility [Giovanni; #707474] | ||||
| * Be stricter in checking and exposing the wayland protocol version [#707851] | ||||
| * Don't require plugins to pass event to Clutter [Giovanni; #707482] | ||||
| * Move the --wayland option from the binary to the library [Giovanni; #707897] | ||||
| * Implement running from gnome-session (environment variable setting, process group | ||||
|   handling, Clutter backend variables) [Giovanni; #706421] | ||||
| * Add support for more cursor types [Giovanni; #707919] | ||||
| * Drop man pages for removed utilities [Kalev; #706579] | ||||
| * Implement monitor configuration on KMS [Giovanni; #706308] | ||||
| * Implement HW cursors [Giovanni; #707573] | ||||
| * Implement minimal support for resizing and maximizing wayland clients [Giovanni; #707401] | ||||
| * Implement transient hints for wayland clients [Giovanni; #707401] | ||||
| * Implement popup menu surfaces and grabs [Giovanni; #707863] | ||||
| * Immediately fire idle watches that are already expired [Giovanni; #707302] | ||||
| * Misc bug fixes [Giovanni, Colin, Pavel; #707649, #707563, #708070] | ||||
| * Remove holes generated by disabling the laptop lid [Giovanni; #707473] | ||||
| * Misc bug fixes [Giovanni, Pavel, Adel; #707649, #706124, #707584, #707851, #707929, | ||||
|   #708070] | ||||
|  | ||||
| Contributors: | ||||
|   Giovanni Campagna, Adel Gadllah, Colin Guthrie, Neil Roberts, | ||||
|   Jasper St. Pierre, Ray Strode, Pavel Vasin | ||||
|   Adel Gadllah, Giovanni Campagna, Kalev Lember, Pavel Vasin | ||||
|  | ||||
| Translations: | ||||
|   Мирослав Николић po/sr, sr@latin.po, Мирослав Николић [sr, sr@latin], | ||||
| @@ -60,19 +68,30 @@ Translations: | ||||
| 3.9.91 | ||||
| ====== | ||||
| * Drop man pages for removed utilities [Kalev; #706579] | ||||
| * Add support for idle tracking [Giovanni; #706005] | ||||
| * Add support for idle tracking [Giovanni, Cosimo; #706005, #707250] | ||||
| * Skip CRTC reconfigurations that have no effect [Giovanni; #706672] | ||||
| * Ignore skip-taskbar hints on parentless dialogs [Giovanni; #673399] | ||||
| * Don't save pixbuf data in user data [Tim; #706777] | ||||
| * Don't queue redraws for obscured regions [Adel; #703332] | ||||
| * Turn blending off when drawing entirely opaque regions [Jasper; #706930] | ||||
| * Suppor the opaque region hints for wayland clients [Jasper; #707019] | ||||
| * Turn blending off when drawing entirely opaque regions [Jasper; #707019] | ||||
| * Check event timestamps before reconfiguring [Giovanni; #706735] | ||||
| * Merge the DBus API for display configuration in the wayland branch [Giovanni] | ||||
| * Install an X IO error handler for XWayland [Giovanni; #706962] | ||||
| * Use the clutter xkbcommon integration for the wayland keyboard [Giovanni; #705862] | ||||
| * Add a setuid helper for running on KMS+evdev [Giovanni, Colin; #705861] | ||||
| * Add keybindings for switching VT [Giovanni; #705861] | ||||
| * Implement plugin modality when running as a wayland compositor [Giovanni; #705917] | ||||
| * Add support for the application menu for wayland clients [Giovanni; #707128] | ||||
| * Several Coverity spotted fixes [Jasper] | ||||
| * Don't create a dummy texture for the texture template [Neil; #707458] | ||||
| * Use a more conservative paint volume for obscured windows [Adel] | ||||
| * Misc bug fixes [Giovanni, Colin, Seán, Jasper, Cosimo; #706582, #706598, | ||||
|   #706787, #706729, #706825, #707081, #707090, #707250, #707267] | ||||
|   #706787, #706729, #706825, #707081, #707090, #707267, #706982, #706289] | ||||
|  | ||||
| Contributors: | ||||
|   Giovanni Campagna, Cosimo Cecchi, Adel Gadllah, Colin Guthrie, Kalev Lember, | ||||
|   Tim Lunn, Jasper St. Pierre, Rico Tzschichholz, Seán de Búrca | ||||
|   Tim Lunn, Jasper St. Pierre, Neil Roberts, Rico Tzschichholz, Seán de Búrca | ||||
|  | ||||
| Translations: | ||||
|   Piotr Drąg [pl], Alexandre Franke [fr], Kjartan Maraas [nb], | ||||
| @@ -81,6 +100,8 @@ Translations: | ||||
|  | ||||
| 3.9.90 | ||||
| ====== | ||||
| * First release from the wayland branch, includes basic support for running | ||||
|   as a wayland compositor [Robert, Neil, Giovanni] | ||||
| * Add support for _GTK_FRAME_EXTENTS [Jasper; #705766] | ||||
| * Fix quick consecutive <super> presses breaking keyboard input [Alban; #666101] | ||||
| * Work towards running as wayland compositor [Giovanni] | ||||
| @@ -95,8 +116,8 @@ Translations: | ||||
|  | ||||
| Contributors: | ||||
|   Robert Bragg, Giovanni Campagna, Alban Crequy, Adel Gadllah, | ||||
|   Alexander Larsson, Florian Müllner, Jasper St. Pierre, Rico Tzschichholz, | ||||
|   Colin Walters | ||||
|   Alexander Larsson, Florian Müllner, Jasper St. Pierre, Neil Roberts, | ||||
|   Rico Tzschichholz, Colin Walters | ||||
|  | ||||
| Translations: | ||||
|   Jiro Matsuzawa [ja], Kjartan Maraas [nb], Matej Urbančič [sl], | ||||
|   | ||||
| @@ -5,7 +5,7 @@ srcdir=`dirname $0` | ||||
| test -z "$srcdir" && srcdir=. | ||||
|  | ||||
| PKG_NAME="mutter" | ||||
| REQUIRED_AUTOMAKE_VERSION=1.10 | ||||
| REQUIRED_AUTOMAKE_VERSION=1.13 | ||||
|  | ||||
| (test -f $srcdir/configure.ac \ | ||||
|   && test -d $srcdir/src) || { | ||||
|   | ||||
							
								
								
									
										71
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										71
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -1,8 +1,9 @@ | ||||
| AC_PREREQ(2.50) | ||||
| AC_CONFIG_MACRO_DIR([m4]) | ||||
|  | ||||
| m4_define([mutter_major_version], [3]) | ||||
| m4_define([mutter_minor_version], [10]) | ||||
| m4_define([mutter_micro_version], [1.1]) | ||||
| m4_define([mutter_minor_version], [11]) | ||||
| m4_define([mutter_micro_version], [1]) | ||||
|  | ||||
| m4_define([mutter_version], | ||||
|           [mutter_major_version.mutter_minor_version.mutter_micro_version]) | ||||
| @@ -12,14 +13,17 @@ m4_define([mutter_plugin_api_version], [3]) | ||||
| AC_INIT([mutter], [mutter_version], | ||||
|         [http://bugzilla.gnome.org/enter_bug.cgi?product=mutter]) | ||||
|  | ||||
| AC_CONFIG_MACRO_DIR([m4]) | ||||
| AC_CONFIG_SRCDIR(src/core/display.c) | ||||
| AC_CONFIG_HEADERS(config.h) | ||||
|  | ||||
| AM_INIT_AUTOMAKE([1.11 no-dist-gzip dist-xz tar-ustar]) | ||||
| AM_INIT_AUTOMAKE([1.11 foreign no-dist-gzip dist-xz tar-ustar]) | ||||
| m4_ifdef([AM_SILENT_RULES],[AM_SILENT_RULES([yes])],) | ||||
| AM_MAINTAINER_MODE([enable]) | ||||
|  | ||||
| # Change pkglibdir and pkgdatadir to mutter-wayland instead of mutter | ||||
| PACKAGE="mutter-wayland" | ||||
| AC_SUBST([PACKAGE], [$PACKAGE]) | ||||
|  | ||||
| MUTTER_MAJOR_VERSION=mutter_major_version | ||||
| MUTTER_MINOR_VERSION=mutter_minor_version | ||||
| MUTTER_MICRO_VERSION=mutter_micro_version | ||||
| @@ -35,7 +39,7 @@ AC_SUBST(MUTTER_PLUGIN_DIR) | ||||
| # Honor aclocal flags | ||||
| AC_SUBST(ACLOCAL_AMFLAGS, "\${ACLOCAL_FLAGS}") | ||||
|  | ||||
| GETTEXT_PACKAGE=mutter | ||||
| GETTEXT_PACKAGE=mutter-wayland | ||||
| AC_SUBST(GETTEXT_PACKAGE) | ||||
| AC_DEFINE_UNQUOTED(GETTEXT_PACKAGE,"$GETTEXT_PACKAGE",[Name of default gettext domain]) | ||||
|  | ||||
| @@ -68,15 +72,15 @@ CANBERRA_GTK_VERSION=0.26 | ||||
| CLUTTER_PACKAGE=clutter-1.0 | ||||
|  | ||||
| MUTTER_PC_MODULES=" | ||||
|    gtk+-3.0 >= 3.9.11 | ||||
|    gtk+-3.0 >= 3.3.7 | ||||
|    gio-2.0 >= 2.25.10 | ||||
|    pango >= 1.2.0 | ||||
|    cairo >= 1.10.0 | ||||
|    gsettings-desktop-schemas >= 3.7.3 | ||||
|    xcomposite >= 0.2 xfixes xrender xdamage xi >= 1.6.0 | ||||
|    $CLUTTER_PACKAGE >= 1.15.90 | ||||
|    cogl-1.0 >= 1.15.6 | ||||
|    upower-glib > 0.9.11 | ||||
|    $CLUTTER_PACKAGE >= 1.15.94 | ||||
|    cogl-1.0 >= 1.13.3 | ||||
|    upower-glib >= 0.99.0 | ||||
|    gnome-desktop-3.0 | ||||
| " | ||||
|  | ||||
| @@ -116,11 +120,32 @@ AC_ARG_ENABLE(shape, | ||||
|                  [disable mutter's use of the shaped window extension]),, | ||||
|   enable_shape=auto) | ||||
|  | ||||
| ## Wayland support requires the xserver.xml protocol extension found in the weston | ||||
| ## repository but since there aren't currently established conventions for | ||||
| ## installing and discovering these we simply require a location to be given | ||||
| ## explicitly... | ||||
| AC_ARG_WITH([wayland-protocols], | ||||
|             [AS_HELP_STRING([--with-wayland-protocols], [Location for wayland extension protocol specs])], | ||||
|             [ | ||||
|             ], | ||||
|             []) | ||||
|  | ||||
| AC_ARG_WITH([xwayland-path], | ||||
|             [AS_HELP_STRING([--with-xwayland-path], [Absolute path for an X Wayland server])], | ||||
|             [XWAYLAND_PATH="$withval"], | ||||
|             [XWAYLAND_PATH="$bindir/Xorg"]) | ||||
|  | ||||
| AM_GLIB_GNU_GETTEXT | ||||
|  | ||||
| ## here we get the flags we'll actually use | ||||
| # GRegex requires Glib-2.14.0 | ||||
| PKG_CHECK_MODULES(ALL, glib-2.0 >= 2.14.0) | ||||
| PKG_CHECK_MODULES(MUTTER_LAUNCH, libdrm libsystemd-login) | ||||
|  | ||||
| saved_LIBS="$LIBS" | ||||
| LIBS="$LIBS $MUTTER_LAUNCH" | ||||
| AC_CHECK_FUNCS([sd_session_get_vt]) | ||||
| LIBS="$saved_LIBS" | ||||
|  | ||||
| # Unconditionally use this dir to avoid a circular dep with gnomecc | ||||
| GNOME_KEYBINDINGS_KEYSDIR="${datadir}/gnome-control-center/keybindings" | ||||
| @@ -185,20 +210,18 @@ if test x$found_introspection != xno; then | ||||
|   AC_SUBST(META_GIR) | ||||
| fi | ||||
|  | ||||
| AC_MSG_CHECKING([Xcursor]) | ||||
| if $PKG_CONFIG xcursor; then | ||||
|      have_xcursor=yes | ||||
|   else | ||||
|      have_xcursor=no | ||||
|   fi | ||||
|   AC_MSG_RESULT($have_xcursor) | ||||
| MUTTER_PC_MODULES="$MUTTER_PC_MODULES xcursor" | ||||
|  | ||||
| if test x$have_xcursor = xyes; then | ||||
|   echo "Building with Xcursor" | ||||
|   MUTTER_PC_MODULES="$MUTTER_PC_MODULES xcursor" | ||||
|   AC_DEFINE(HAVE_XCURSOR, , [Building with Xcursor support]) | ||||
| fi | ||||
| # We always build with wayland enabled | ||||
| AC_DEFINE(HAVE_WAYLAND, , [Building with Wayland support]) | ||||
|  | ||||
| AC_PATH_PROG([WAYLAND_SCANNER],[wayland-scanner],[no]) | ||||
| AS_IF([test "x$WAYLAND_SCANNER" = "xno"], | ||||
|   AC_MSG_ERROR([Could not find wayland-scanner in your PATH, required for parsing wayland extension protocols])) | ||||
| AC_SUBST([WAYLAND_SCANNER]) | ||||
| AC_SUBST(XWAYLAND_PATH) | ||||
|  | ||||
| MUTTER_PC_MODULES="$MUTTER_PC_MODULES clutter-wayland-1.0 clutter-wayland-compositor-1.0 clutter-egl-1.0 wayland-server libdrm" | ||||
| PKG_CHECK_MODULES(MUTTER, $MUTTER_PC_MODULES) | ||||
|  | ||||
| PKG_CHECK_EXISTS([xi >= 1.6.99.1], | ||||
| @@ -436,9 +459,9 @@ doc/man/Makefile | ||||
| doc/reference/Makefile | ||||
| doc/reference/meta-docs.sgml | ||||
| src/Makefile | ||||
| src/libmutter.pc | ||||
| src/mutter-plugins.pc | ||||
| src/libmutter-wayland.pc | ||||
| src/compositor/plugins/Makefile | ||||
| protocol/Makefile | ||||
| po/Makefile.in | ||||
| ]) | ||||
|  | ||||
| @@ -454,7 +477,7 @@ fi | ||||
|  | ||||
| dnl ========================================================================== | ||||
| echo " | ||||
| mutter-$VERSION | ||||
| mutter-wayland-$VERSION | ||||
|  | ||||
| 	prefix:                   ${prefix} | ||||
| 	source code location:	  ${srcdir} | ||||
|   | ||||
| @@ -140,7 +140,7 @@ expand_content_files= \ | ||||
| # e.g. GTKDOC_CFLAGS=-I$(top_srcdir) -I$(top_builddir) $(GTK_DEBUG_FLAGS) | ||||
| # e.g. GTKDOC_LIBS=$(top_builddir)/gtk/$(gtktargetlib) | ||||
| GTKDOC_CFLAGS=$(MUTTER_CFLAGS) | ||||
| GTKDOC_LIBS=$(MUTTER_LIBS) $(top_builddir)/src/libmutter.la | ||||
| GTKDOC_LIBS=$(MUTTER_LIBS) $(top_builddir)/src/libmutter-wayland.la | ||||
|  | ||||
| # This includes the standard gtk-doc make rules, copied by gtkdocize. | ||||
| include $(top_srcdir)/gtk-doc.make | ||||
|   | ||||
| @@ -207,7 +207,6 @@ meta_key_binding_get_modifiers | ||||
| meta_key_binding_get_mask | ||||
| meta_key_binding_is_builtin | ||||
| meta_keybindings_set_custom_handler | ||||
| meta_keybindings_switch_window | ||||
| meta_screen_ungrab_all_keys | ||||
| meta_screen_grab_all_keys | ||||
| </SECTION> | ||||
|   | ||||
| @@ -21,6 +21,7 @@ environment.</description> | ||||
|   --> | ||||
|   <mailing-list rdf:resource="http://mail.gnome.org/mailman/listinfo/gnome-shell-list" /> | ||||
|   <download-page rdf:resource="http://download.gnome.org/sources/mutter/" /> | ||||
|   <download-page rdf:resource="http://download.gnome.org/sources/mutter-wayland/" /> | ||||
|   <bug-database rdf:resource="http://bugzilla.gnome.org/browse.cgi?product=mutter" /> | ||||
|  | ||||
|   <category rdf:resource="http://api.gnome.org/doap-extensions#desktop" /> | ||||
|   | ||||
| @@ -21,9 +21,9 @@ src/core/util.c | ||||
| src/core/window.c | ||||
| src/core/window-props.c | ||||
| src/core/xprops.c | ||||
| src/mutter.desktop.in | ||||
| src/mutter-wm.desktop.in | ||||
| src/mutter-wayland.desktop.in | ||||
| src/org.gnome.mutter.gschema.xml.in | ||||
| src/org.gnome.mutter.wayland.gschema.xml.in | ||||
| src/ui/frames.c | ||||
| src/ui/menu.c | ||||
| src/ui/metaaccellabel.c | ||||
|   | ||||
							
								
								
									
										2834
									
								
								po/ca@valencia.po
									
									
									
									
									
								
							
							
						
						
									
										2834
									
								
								po/ca@valencia.po
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										353
									
								
								po/cs.po
									
									
									
									
									
								
							
							
						
						
									
										353
									
								
								po/cs.po
									
									
									
									
									
								
							| @@ -6,23 +6,22 @@ | ||||
| # Petr Tomeš <ptomes@gmail.com>, 2006. | ||||
| # Jakub Friedl <jfriedl@suse.cz>, 2006, 2007. | ||||
| # Petr Kovar <pknbe@volny.cz>, 2007, 2008, 2009, 2010, 2011, 2012, 2013. | ||||
| # Marek Černocký <marek@manet.cz>, 2012, 2013. | ||||
| # | ||||
| # Marek Černocký <marek@manet.cz>, 2012. | ||||
| msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: mutter\n" | ||||
| "Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?" | ||||
| "product=mutter&keywords=I18N+L10N&component=general\n" | ||||
| "POT-Creation-Date: 2013-08-18 20:03+0000\n" | ||||
| "PO-Revision-Date: 2013-08-20 08:50+0200\n" | ||||
| "Last-Translator: Marek Černocký <marek@manet.cz>\n" | ||||
| "Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?product=mutter" | ||||
| "&keywords=I18N+L10N&component=general\n" | ||||
| "POT-Creation-Date: 2013-03-22 10:02+0000\n" | ||||
| "PO-Revision-Date: 2013-03-24 20:55+0200\n" | ||||
| "Last-Translator: Petr Kovar <pknbe@volny.cz>\n" | ||||
| "Language-Team: Czech <gnome-cs-list@gnome.org>\n" | ||||
| "Language: cs\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
| "Plural-Forms: nplurals=3; plural=(n==1) ? 0 : (n>=2 && n<=4) ? 1 : 2;\n" | ||||
| "X-Generator: Gtranslator 2.91.6\n" | ||||
| "X-Generator: Virtaal 0.7.1\n" | ||||
| "X-Project-Style: gnome\n" | ||||
|  | ||||
| #: ../src/50-mutter-navigation.xml.in.h:1 | ||||
| @@ -187,8 +186,7 @@ msgstr "Přepnout výskyt okna na všech plochách nebo jen na jedné" | ||||
|  | ||||
| #: ../src/50-mutter-windows.xml.in.h:13 | ||||
| msgid "Raise window if covered, otherwise lower it" | ||||
| msgstr "" | ||||
| "Přenést okno do popředí, pokud je zakryté, jinak jej odsunout do pozadí" | ||||
| msgstr "Přenést okno do popředí, pokud je zakryté, jinak jej odsunout do pozadí" | ||||
|  | ||||
| #: ../src/50-mutter-windows.xml.in.h:14 | ||||
| msgid "Raise window above other windows" | ||||
| @@ -216,14 +214,14 @@ msgstr "Zobrazit rozdělení napravo" | ||||
|  | ||||
| #. This probably means that a non-WM compositor like xcompmgr is running; | ||||
| #. * we have no way to get it to exit | ||||
| #: ../src/compositor/compositor.c:589 | ||||
| #: ../src/compositor/compositor.c:568 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Another compositing manager is already running on screen %i on display \"%s" | ||||
| "\"." | ||||
| msgstr "Jiný kompozitní správce již běží na obrazovce %i displeje „%s“." | ||||
|  | ||||
| #: ../src/compositor/meta-background.c:1076 | ||||
| #: ../src/compositor/meta-background.c:1191 | ||||
| msgid "background texture could not be created from file" | ||||
| msgstr "textura pozadí nemohla být ze souboru vytvořena" | ||||
|  | ||||
| @@ -261,17 +259,17 @@ msgstr "_Počkat" | ||||
| msgid "_Force Quit" | ||||
| msgstr "_Vynutit ukončení" | ||||
|  | ||||
| #: ../src/core/display.c:421 | ||||
| #: ../src/core/display.c:401 | ||||
| #, c-format | ||||
| msgid "Missing %s extension required for compositing" | ||||
| msgstr "Schází rozšíření %s vyžadované funkcemi kompozitoru" | ||||
|  | ||||
| #: ../src/core/display.c:513 | ||||
| #: ../src/core/display.c:493 | ||||
| #, c-format | ||||
| msgid "Failed to open X Window System display '%s'\n" | ||||
| msgstr "Nelze otevřít displej X Window System „%s“\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1136 | ||||
| #: ../src/core/keybindings.c:935 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Some other program is already using the key %s with modifiers %x as a " | ||||
| @@ -279,8 +277,9 @@ msgid "" | ||||
| msgstr "" | ||||
| "Klávesu %s s modifikátory %x již jako zkratku používá nějaký jiný program\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1333 | ||||
| #: ../src/core/keybindings.c:1135 | ||||
| #, c-format | ||||
| #| msgid "\"%s\" is not a valid value for focus attribute" | ||||
| msgid "\"%s\" is not a valid accelerator\n" | ||||
| msgstr "„%s“ není platný akcelerátor\n" | ||||
|  | ||||
| @@ -321,19 +320,6 @@ msgstr "" | ||||
| "Nelze najít motiv! Ujistěte se prosím, že existuje %s a obsahuje obvyklé " | ||||
| "motivy.\n" | ||||
|  | ||||
| #: ../src/core/monitor.c:711 | ||||
| msgid "Built-in display" | ||||
| msgstr "Vestavěný displej" | ||||
|  | ||||
| #. TRANSLATORS: this is a monitor name (in case we don't know | ||||
| #. the vendor), it's Unknown followed by a size in inches, | ||||
| #. like 'Unknown 15"' | ||||
| #. | ||||
| #: ../src/core/monitor.c:739 | ||||
| #, c-format | ||||
| msgid "Unknown %s" | ||||
| msgstr "Neznámý %s" | ||||
|  | ||||
| #: ../src/core/mutter.c:40 | ||||
| #, c-format | ||||
| msgid "" | ||||
| @@ -358,7 +344,7 @@ msgstr "Vypíše verzi" | ||||
| msgid "Mutter plugin to use" | ||||
| msgstr "Zásuvný modul Mutter, který se má použít" | ||||
|  | ||||
| #: ../src/core/prefs.c:1202 | ||||
| #: ../src/core/prefs.c:1095 | ||||
| msgid "" | ||||
| "Workarounds for broken applications disabled. Some applications may not " | ||||
| "behave properly.\n" | ||||
| @@ -366,12 +352,12 @@ msgstr "" | ||||
| "Bylo zakázáno obcházení chyb aplikací. Některé aplikace se možná nebudou " | ||||
| "chovat správně.\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1277 | ||||
| #: ../src/core/prefs.c:1170 | ||||
| #, c-format | ||||
| msgid "Could not parse font description \"%s\" from GSettings key %s\n" | ||||
| msgstr "Nelze zpracovat popis písma „%s“ v klíči GSettings %s\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1343 | ||||
| #: ../src/core/prefs.c:1236 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for mouse button " | ||||
| @@ -380,7 +366,7 @@ msgstr "" | ||||
| "„%s“ nalezené v databázi nastavení není platnou hodnotou modifikátoru " | ||||
| "tlačítka myši\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1909 | ||||
| #: ../src/core/prefs.c:1788 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for keybinding " | ||||
| @@ -389,17 +375,17 @@ msgstr "" | ||||
| "„%s“ nalezené v databázi nastavení není platnou hodnotou klávesové zkratky " | ||||
| "„%s“\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1999 | ||||
| #: ../src/core/prefs.c:1887 | ||||
| #, c-format | ||||
| msgid "Workspace %d" | ||||
| msgstr "Plocha %d" | ||||
|  | ||||
| #: ../src/core/screen.c:534 | ||||
| #: ../src/core/screen.c:691 | ||||
| #, c-format | ||||
| msgid "Screen %d on display '%s' is invalid\n" | ||||
| msgstr "Obrazovka %d na displeji „%s“ je neplatná\n" | ||||
|  | ||||
| #: ../src/core/screen.c:550 | ||||
| #: ../src/core/screen.c:707 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Screen %d on display \"%s\" already has a window manager; try using the --" | ||||
| @@ -408,18 +394,18 @@ msgstr "" | ||||
| "Obrazovka %d na displeji „%s“ již správce oken má; zkuste prosím nahradit " | ||||
| "aktuálního správce oken pomocí přepínače --replace.\n" | ||||
|  | ||||
| #: ../src/core/screen.c:577 | ||||
| #: ../src/core/screen.c:734 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not acquire window manager selection on screen %d display \"%s\"\n" | ||||
| msgstr "Nelze získat výběr správce oken na obrazovce %d displeje „%s“\n" | ||||
|  | ||||
| #: ../src/core/screen.c:655 | ||||
| #: ../src/core/screen.c:812 | ||||
| #, c-format | ||||
| msgid "Screen %d on display \"%s\" already has a window manager\n" | ||||
| msgstr "Obrazovka %d na displeji „%s“ již má správce oken\n" | ||||
|  | ||||
| #: ../src/core/screen.c:846 | ||||
| #: ../src/core/screen.c:998 | ||||
| #, c-format | ||||
| msgid "Could not release screen %d on display \"%s\"\n" | ||||
| msgstr "Nelze uvolnit obrazovku %d na displeji „%s“\n" | ||||
| @@ -494,7 +480,8 @@ msgstr "Nelze provést fdopen() soubor záznamu %s: %s\n" | ||||
| msgid "Opened log file %s\n" | ||||
| msgstr "Otevřen soubor záznamu %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:119 | ||||
| #: ../src/core/util.c:119 ../src/tools/mutter-message.c:149 | ||||
| #, c-format | ||||
| msgid "Mutter was compiled without support for verbose mode\n" | ||||
| msgstr "Mutter bylo přeloženo bez podpory podrobného režimu\n" | ||||
|  | ||||
| @@ -502,20 +489,20 @@ msgstr "Mutter bylo přeloženo bez podpory podrobného režimu\n" | ||||
| msgid "Window manager: " | ||||
| msgstr "Správce oken: " | ||||
|  | ||||
| #: ../src/core/util.c:414 | ||||
| #: ../src/core/util.c:412 | ||||
| msgid "Bug in window manager: " | ||||
| msgstr "Chyba ve správci oken: " | ||||
|  | ||||
| #: ../src/core/util.c:445 | ||||
| #: ../src/core/util.c:443 | ||||
| msgid "Window manager warning: " | ||||
| msgstr "Varování správce oken: " | ||||
|  | ||||
| #: ../src/core/util.c:473 | ||||
| #: ../src/core/util.c:471 | ||||
| msgid "Window manager error: " | ||||
| msgstr "Chyba správce oken: " | ||||
|  | ||||
| #. first time through | ||||
| #: ../src/core/window.c:7533 | ||||
| #: ../src/core/window.c:7596 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER " | ||||
| @@ -531,7 +518,7 @@ msgstr "" | ||||
| #. * MWM but not WM_NORMAL_HINTS are basically broken. We complain | ||||
| #. * about these apps but make them work. | ||||
| #. | ||||
| #: ../src/core/window.c:8257 | ||||
| #: ../src/core/window.c:8320 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets an MWM hint indicating it isn't resizable, but sets min size " | ||||
| @@ -541,22 +528,22 @@ msgstr "" | ||||
| "velikost, ale nastavuje min. velikost %d × %d a max. velikost %d × %d; to " | ||||
| "nedává smysl.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:347 | ||||
| #: ../src/core/window-props.c:318 | ||||
| #, c-format | ||||
| msgid "Application set a bogus _NET_WM_PID %lu\n" | ||||
| msgstr "Aplikace nastavila neplatný _NET_WM_PID %lu\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:463 | ||||
| #: ../src/core/window-props.c:434 | ||||
| #, c-format | ||||
| msgid "%s (on %s)" | ||||
| msgstr "%s (na %s)" | ||||
|  | ||||
| #: ../src/core/window-props.c:1546 | ||||
| #: ../src/core/window-props.c:1517 | ||||
| #, c-format | ||||
| msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n" | ||||
| msgstr "Neplatné okno WM_TRANSIENT_FOR 0x%lx specifikováno pro %s.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:1557 | ||||
| #: ../src/core/window-props.c:1528 | ||||
| #, c-format | ||||
| msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n" | ||||
| msgstr "Okno WM_TRANSIENT_FOR 0x%lx by vytvořilo smyčku pro %s.\n" | ||||
| @@ -720,104 +707,109 @@ msgstr "Vybrat okno z překryvné nabídky tabulátoru" | ||||
| msgid "Cancel tab popup" | ||||
| msgstr "Zrušit překryvné okno tabulátoru" | ||||
|  | ||||
| #: ../src/tools/mutter-message.c:123 | ||||
| #, c-format | ||||
| msgid "Usage: %s\n" | ||||
| msgstr "Použití: %s\n" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:67 | ||||
| #: ../src/ui/menu.c:69 | ||||
| msgid "Mi_nimize" | ||||
| msgstr "Mi_nimalizovat" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:69 | ||||
| #: ../src/ui/menu.c:71 | ||||
| msgid "Ma_ximize" | ||||
| msgstr "Ma_ximalizovat" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:71 | ||||
| #: ../src/ui/menu.c:73 | ||||
| msgid "Unma_ximize" | ||||
| msgstr "Zrušit ma_ximalizaci" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:73 | ||||
| #: ../src/ui/menu.c:75 | ||||
| msgid "Roll _Up" | ||||
| msgstr "Sv_inout" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:75 | ||||
| #: ../src/ui/menu.c:77 | ||||
| msgid "_Unroll" | ||||
| msgstr "Rozv_inout" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:77 | ||||
| #: ../src/ui/menu.c:79 | ||||
| msgid "_Move" | ||||
| msgstr "_Přesunout" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:79 | ||||
| #: ../src/ui/menu.c:81 | ||||
| msgid "_Resize" | ||||
| msgstr "Z_měnit velikost" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:81 | ||||
| #: ../src/ui/menu.c:83 | ||||
| msgid "Move Titlebar On_screen" | ||||
| msgstr "Přesunout záhlaví okna na _obrazovku" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:84 ../src/ui/menu.c:86 | ||||
| #: ../src/ui/menu.c:86 ../src/ui/menu.c:88 | ||||
| msgid "Always on _Top" | ||||
| msgstr "_Vždy navrchu" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:88 | ||||
| #: ../src/ui/menu.c:90 | ||||
| msgid "_Always on Visible Workspace" | ||||
| msgstr "Vžd_y na viditelné ploše" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:90 | ||||
| #: ../src/ui/menu.c:92 | ||||
| msgid "_Only on This Workspace" | ||||
| msgstr "_Jen na této ploše" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:92 | ||||
| #: ../src/ui/menu.c:94 | ||||
| msgid "Move to Workspace _Left" | ||||
| msgstr "Přesunout na plochu v_levo" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:94 | ||||
| #: ../src/ui/menu.c:96 | ||||
| msgid "Move to Workspace R_ight" | ||||
| msgstr "Přesunout na plochu vp_ravo" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:96 | ||||
| #: ../src/ui/menu.c:98 | ||||
| msgid "Move to Workspace _Up" | ||||
| msgstr "Přesunout na plochu na_hoře" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:98 | ||||
| #: ../src/ui/menu.c:100 | ||||
| msgid "Move to Workspace _Down" | ||||
| msgstr "Přesunout na plochu _dole" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:102 | ||||
| #: ../src/ui/menu.c:104 | ||||
| msgid "_Close" | ||||
| msgstr "_Zavřít" | ||||
|  | ||||
| #: ../src/ui/menu.c:202 | ||||
| #: ../src/ui/menu.c:204 | ||||
| #, c-format | ||||
| msgid "Workspace %d%n" | ||||
| msgstr "Plocha %d%n" | ||||
|  | ||||
| #: ../src/ui/menu.c:212 | ||||
| #: ../src/ui/menu.c:214 | ||||
| #, c-format | ||||
| msgid "Workspace 1_0" | ||||
| msgstr "Plocha 1_0" | ||||
|  | ||||
| #: ../src/ui/menu.c:214 | ||||
| #: ../src/ui/menu.c:216 | ||||
| #, c-format | ||||
| msgid "Workspace %s%d" | ||||
| msgstr "Plocha %s%d" | ||||
|  | ||||
| #: ../src/ui/menu.c:384 | ||||
| #: ../src/ui/menu.c:397 | ||||
| msgid "Move to Another _Workspace" | ||||
| msgstr "Přes_unout na jinou plochu" | ||||
|  | ||||
| @@ -993,8 +985,8 @@ msgid "" | ||||
| "GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] " | ||||
| "where NORMAL is the state; could not parse \"%s\"" | ||||
| msgstr "" | ||||
| "Specifikace GTK barvy musí mít stav v hranatých závorkách, např. gtk:" | ||||
| "fg[NORMAL], kde NORMAL je stav; nelze analyzovat „%s“" | ||||
| "Specifikace GTK barvy musí mít stav v hranatých závorkách, např. gtk:fg" | ||||
| "[NORMAL], kde NORMAL je stav; nelze analyzovat „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1292 | ||||
| #, c-format | ||||
| @@ -1002,8 +994,8 @@ msgid "" | ||||
| "GTK color specification must have a close bracket after the state, e.g. gtk:" | ||||
| "fg[NORMAL] where NORMAL is the state; could not parse \"%s\"" | ||||
| msgstr "" | ||||
| "Specifikace GTK barvy musí mít za stavem hranatou závorku, např. gtk:" | ||||
| "fg[NORMAL], kde NORMAL je stav; nelze analyzovat „%s“" | ||||
| "Specifikace GTK barvy musí mít za stavem hranatou závorku, např. gtk:fg" | ||||
| "[NORMAL], kde NORMAL je stav; nelze analyzovat „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1303 | ||||
| #, c-format | ||||
| @@ -1173,18 +1165,18 @@ msgid "" | ||||
| msgstr "" | ||||
| "Chybí <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"cokoliv\"/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5082 | ||||
| #: ../src/ui/theme.c:5084 | ||||
| #, c-format | ||||
| msgid "Failed to load theme \"%s\": %s\n" | ||||
| msgstr "Nelze načíst motiv „%s“: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232 | ||||
| #: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246 | ||||
| #: ../src/ui/theme.c:5220 ../src/ui/theme.c:5227 ../src/ui/theme.c:5234 | ||||
| #: ../src/ui/theme.c:5241 ../src/ui/theme.c:5248 | ||||
| #, c-format | ||||
| msgid "No <%s> set for theme \"%s\"" | ||||
| msgstr "Není nastaveno <%s> motivu „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:5254 | ||||
| #: ../src/ui/theme.c:5256 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "No frame style set for window type \"%s\" in theme \"%s\", add a <window " | ||||
| @@ -1193,7 +1185,7 @@ msgstr "" | ||||
| "U typu okna „%s“ motivu „%s“ není nastaven typ rámu, přidejte prosím prvek " | ||||
| "<window type=\"%s\" style_set=\"cokoliv\"/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786 | ||||
| #: ../src/ui/theme.c:5663 ../src/ui/theme.c:5725 ../src/ui/theme.c:5788 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "User-defined constants must begin with a capital letter; \"%s\" does not" | ||||
| @@ -1201,7 +1193,7 @@ msgstr "" | ||||
| "Uživatelem definované konstanty musí začínat velkým písmenem; „%s“ toto " | ||||
| "nesplňuje" | ||||
|  | ||||
| #: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794 | ||||
| #: ../src/ui/theme.c:5671 ../src/ui/theme.c:5733 ../src/ui/theme.c:5796 | ||||
| #, c-format | ||||
| msgid "Constant \"%s\" has already been defined" | ||||
| msgstr "Konstanta „%s“ již byla definována" | ||||
| @@ -1580,4 +1572,205 @@ msgstr "<%s> u tohoto motivu definováno dvakrát" | ||||
| #: ../src/ui/theme-parser.c:4336 | ||||
| #, c-format | ||||
| msgid "Failed to find a valid file for theme %s\n" | ||||
| msgstr "Nelze nalézt platný soubor motivu %s\n" | ||||
| msgstr "Nelze nalézt platný soubor motivu %s\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:99 | ||||
| msgid "_Windows" | ||||
| msgstr "_Okna" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:100 | ||||
| msgid "_Dialog" | ||||
| msgstr "_Dialogové okno" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:101 | ||||
| msgid "_Modal dialog" | ||||
| msgstr "_Modální dialogové okno" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:102 | ||||
| msgid "_Utility" | ||||
| msgstr "_Nástroje" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:103 | ||||
| msgid "_Splashscreen" | ||||
| msgstr "_Spouštěcí obrazovka" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:104 | ||||
| msgid "_Top dock" | ||||
| msgstr "_Horní dok" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:105 | ||||
| msgid "_Bottom dock" | ||||
| msgstr "Dolní do_k" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:106 | ||||
| msgid "_Left dock" | ||||
| msgstr "_Levý dok" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:107 | ||||
| msgid "_Right dock" | ||||
| msgstr "P_ravý dok" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:108 | ||||
| msgid "_All docks" | ||||
| msgstr "_Všechny doky" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:109 | ||||
| msgid "Des_ktop" | ||||
| msgstr "Pra_covní prostředí" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:115 | ||||
| msgid "Open another one of these windows" | ||||
| msgstr "Otevřít další takové okno" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:117 | ||||
| msgid "This is a demo button with an 'open' icon" | ||||
| msgstr "Toto je demonstrační tlačítko s ikonou „otevřít“" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:119 | ||||
| msgid "This is a demo button with a 'quit' icon" | ||||
| msgstr "Toto je demonstrační tlačítko s ikonou „ukončit“" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:248 | ||||
| msgid "This is a sample message in a sample dialog" | ||||
| msgstr "Toto je ukázková zpráva v ukázkovém dialogu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:328 | ||||
| #, c-format | ||||
| msgid "Fake menu item %d\n" | ||||
| msgstr "Falešná položka nabídky %d\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:363 | ||||
| msgid "Border-only window" | ||||
| msgstr "Okno jen s okrajem" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:365 | ||||
| msgid "Bar" | ||||
| msgstr "Lišta" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:382 | ||||
| msgid "Normal Application Window" | ||||
| msgstr "Normální okno aplikace" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:386 | ||||
| msgid "Dialog Box" | ||||
| msgstr "Dialogové okno" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:390 | ||||
| msgid "Modal Dialog Box" | ||||
| msgstr "Modální dialogové okno" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:394 | ||||
| msgid "Utility Palette" | ||||
| msgstr "Paleta nástrojů" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:398 | ||||
| msgid "Torn-off Menu" | ||||
| msgstr "Odtržení nabídky" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:402 | ||||
| msgid "Border" | ||||
| msgstr "Okraj" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:406 | ||||
| msgid "Attached Modal Dialog" | ||||
| msgstr "Připojené modální dialogové okno" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:737 | ||||
| #, c-format | ||||
| msgid "Button layout test %d" | ||||
| msgstr "Test rozložení tlačítek %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:766 | ||||
| #, c-format | ||||
| msgid "%g milliseconds to draw one window frame" | ||||
| msgstr "%g milisekund na nakreslení jednoho rámu okna" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:811 | ||||
| #, c-format | ||||
| msgid "Usage: metacity-theme-viewer [THEMENAME]\n" | ||||
| msgstr "Použití: metacity-theme-viewer [NÁZEVMOTIVU]\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:818 | ||||
| #, c-format | ||||
| msgid "Error loading theme: %s\n" | ||||
| msgstr "Chyba při načítání motivu: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:824 | ||||
| #, c-format | ||||
| msgid "Loaded theme \"%s\" in %g seconds\n" | ||||
| msgstr "Načten motiv „%s“ za %g sekund\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:869 | ||||
| msgid "Normal Title Font" | ||||
| msgstr "Normální písmo nadpisu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:875 | ||||
| msgid "Small Title Font" | ||||
| msgstr "Malé písmo nadpisu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:881 | ||||
| msgid "Large Title Font" | ||||
| msgstr "Velké písmo nadpisu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:886 | ||||
| msgid "Button Layouts" | ||||
| msgstr "Rozložení tlačítek" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:891 | ||||
| msgid "Benchmark" | ||||
| msgstr "Test výkonnosti" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:947 | ||||
| msgid "Window Title Goes Here" | ||||
| msgstr "Sem patří nadpis okna" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1053 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g " | ||||
| "seconds wall clock time including X server resources (%g milliseconds per " | ||||
| "frame)\n" | ||||
| msgstr "" | ||||
| "Nakresleno %d rámů za %g sekund na straně klienta (%g milisekund na rám) a " | ||||
| "%g sekund reálného času včetně zdrojů serveru X (%g milisekund na rám)\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1273 | ||||
| msgid "position expression test returned TRUE but set error" | ||||
| msgstr "test výrazu umístění vrátil TRUE, ale nastavil chybu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1275 | ||||
| msgid "position expression test returned FALSE but didn't set error" | ||||
| msgstr "test výrazu umístění vrátil FALSE, ale nenastavil chybu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1279 | ||||
| msgid "Error was expected but none given" | ||||
| msgstr "Byla očekávána chyba, ale nebyla přijata" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1281 | ||||
| #, c-format | ||||
| msgid "Error %d was expected but %d given" | ||||
| msgstr "Byla očekávána chyba %d, ale bylo přijato %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1287 | ||||
| #, c-format | ||||
| msgid "Error not expected but one was returned: %s" | ||||
| msgstr "Chyba nebyla očekávána, ale byla vrácena: %s" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1291 | ||||
| #, c-format | ||||
| msgid "x value was %d, %d was expected" | ||||
| msgstr "Hodnota x byla %d, bylo očekáváno %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1294 | ||||
| #, c-format | ||||
| msgid "y value was %d, %d was expected" | ||||
| msgstr "Hodnota y byla %d, bylo očekáváno %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1359 | ||||
| #, c-format | ||||
| msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n" | ||||
| msgstr "Zpracováno %d výrazů souřadnic za %g sekund (průměr %g sekund)\n" | ||||
|  | ||||
| #, fuzzy | ||||
| #~ msgid "Minimize window" | ||||
| #~ msgstr "Minimalizovat okno" | ||||
|   | ||||
							
								
								
									
										398
									
								
								po/hu.po
									
									
									
									
									
								
							
							
						
						
									
										398
									
								
								po/hu.po
									
									
									
									
									
								
							| @@ -6,21 +6,19 @@ | ||||
| # Gabor Sari <saga at externet dot hu>, 2003. | ||||
| # Laszlo Dvornik <dvornik at gnome dot hu>, 2004. | ||||
| # Gabor Kelemen <kelemeng at gnome dot hu>, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013. | ||||
| # Balázs Úr <urbalazs at gmail dot com>, 2013. | ||||
| msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: mutter master\n" | ||||
| "Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?" | ||||
| "product=mutter&keywords=I18N+L10N&component=general\n" | ||||
| "POT-Creation-Date: 2013-08-18 20:03+0000\n" | ||||
| "PO-Revision-Date: 2013-08-25 10:26+0200\n" | ||||
| "Last-Translator: Balázs Úr <urbalazs at gmail dot com>\n" | ||||
| "Report-Msgid-Bugs-To: \n" | ||||
| "POT-Creation-Date: 2013-03-21 00:15+0100\n" | ||||
| "PO-Revision-Date: 2013-03-21 00:14+0100\n" | ||||
| "Last-Translator: Gabor Kelemen <kelemeng at gnome dot hu>\n" | ||||
| "Language-Team: Hungarian <gnome-hu-list at gnome dot org>\n" | ||||
| "Language: hu\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8bit\n" | ||||
| "X-Generator: Lokalize 1.2\n" | ||||
| "X-Generator: Lokalize 1.4\n" | ||||
| "Plural-Forms:  nplurals=2; plural=(n != 1);\n" | ||||
|  | ||||
| #: ../src/50-mutter-navigation.xml.in.h:1 | ||||
| @@ -213,7 +211,7 @@ msgstr "Jobb oldali felosztás megjelenítése" | ||||
|  | ||||
| #. This probably means that a non-WM compositor like xcompmgr is running; | ||||
| #. * we have no way to get it to exit | ||||
| #: ../src/compositor/compositor.c:589 | ||||
| #: ../src/compositor/compositor.c:568 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Another compositing manager is already running on screen %i on display \"%s" | ||||
| @@ -222,7 +220,7 @@ msgstr "" | ||||
| "Már fut egy másik kompozitáláskezelő a(z) %i képernyőn a(z) „%s” " | ||||
| "megjelenítőn." | ||||
|  | ||||
| #: ../src/compositor/meta-background.c:1076 | ||||
| #: ../src/compositor/meta-background.c:1191 | ||||
| msgid "background texture could not be created from file" | ||||
| msgstr "nem hozható létre a háttér textúrája fájlból" | ||||
|  | ||||
| @@ -260,17 +258,17 @@ msgstr "Vá_rakozás" | ||||
| msgid "_Force Quit" | ||||
| msgstr "_Erőltetett kilépés" | ||||
|  | ||||
| #: ../src/core/display.c:421 | ||||
| #: ../src/core/display.c:401 | ||||
| #, c-format | ||||
| msgid "Missing %s extension required for compositing" | ||||
| msgstr "Hiányzik a kompozit ablakkezeléshez szükséges %s kiterjesztés" | ||||
|  | ||||
| #: ../src/core/display.c:513 | ||||
| #: ../src/core/display.c:493 | ||||
| #, c-format | ||||
| msgid "Failed to open X Window System display '%s'\n" | ||||
| msgstr "Nem sikerült megnyitni a(z) „%s” X Window rendszer képernyőt\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1136 | ||||
| #: ../src/core/keybindings.c:935 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Some other program is already using the key %s with modifiers %x as a " | ||||
| @@ -279,7 +277,7 @@ msgstr "" | ||||
| "Valamely másik program már használja a(z) %s billentyűt %x módosítókkal " | ||||
| "összekötve\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1333 | ||||
| #: ../src/core/keybindings.c:1135 | ||||
| #, c-format | ||||
| msgid "\"%s\" is not a valid accelerator\n" | ||||
| msgstr "„%s” érvénytelen hívóbetű\n" | ||||
| @@ -321,20 +319,6 @@ msgstr "" | ||||
| "Nem található téma! Bizonyosodjon meg róla hogy a(z) %s létezik és " | ||||
| "tartalmazza a szokásos témákat.\n" | ||||
|  | ||||
| #: ../src/core/monitor.c:711 | ||||
| msgid "Built-in display" | ||||
| msgstr "Beépített kijelző" | ||||
|  | ||||
| #. TRANSLATORS: this is a monitor name (in case we don't know | ||||
| #. the vendor), it's Unknown followed by a size in inches, | ||||
| #. like 'Unknown 15"' | ||||
| #. | ||||
| #: ../src/core/monitor.c:739 | ||||
| #, c-format | ||||
| #| msgid "Unknown element %s" | ||||
| msgid "Unknown %s" | ||||
| msgstr "Ismeretlen %s" | ||||
|  | ||||
| #: ../src/core/mutter.c:40 | ||||
| #, c-format | ||||
| msgid "" | ||||
| @@ -358,7 +342,7 @@ msgstr "Verzió kinyomtatása" | ||||
| msgid "Mutter plugin to use" | ||||
| msgstr "Használandó Mutter bővítmény" | ||||
|  | ||||
| #: ../src/core/prefs.c:1202 | ||||
| #: ../src/core/prefs.c:1095 | ||||
| msgid "" | ||||
| "Workarounds for broken applications disabled. Some applications may not " | ||||
| "behave properly.\n" | ||||
| @@ -366,14 +350,14 @@ msgstr "" | ||||
| "A hibás alkalmazások hibáinak megkerülése nincs engedélyezve. Néhány " | ||||
| "alkalmazás lehet, hogy nem fog helyesen működni.\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1277 | ||||
| #: ../src/core/prefs.c:1170 | ||||
| #, c-format | ||||
| msgid "Could not parse font description \"%s\" from GSettings key %s\n" | ||||
| msgstr "" | ||||
| "Nem sikerült feldolgozni a(z) „%s” betűkészlet leírását a(z) „%s” GSettings " | ||||
| "kulcsból\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1343 | ||||
| #: ../src/core/prefs.c:1236 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for mouse button " | ||||
| @@ -382,7 +366,7 @@ msgstr "" | ||||
| "A konfigurációs adatbázisban talált „%s” érvénytelen érték az egérgomb " | ||||
| "módosítóhoz\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1909 | ||||
| #: ../src/core/prefs.c:1788 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for keybinding " | ||||
| @@ -391,17 +375,17 @@ msgstr "" | ||||
| "A konfigurációs adatbázisban talált „%s” nem érvényes érték a következő " | ||||
| "billentyűkombinációhoz: „%s”\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1999 | ||||
| #: ../src/core/prefs.c:1887 | ||||
| #, c-format | ||||
| msgid "Workspace %d" | ||||
| msgstr "%d. munkaterület" | ||||
|  | ||||
| #: ../src/core/screen.c:534 | ||||
| #: ../src/core/screen.c:691 | ||||
| #, c-format | ||||
| msgid "Screen %d on display '%s' is invalid\n" | ||||
| msgstr "A(z) %d képernyő a(z) „%s” megjelenítőn érvénytelen\n" | ||||
|  | ||||
| #: ../src/core/screen.c:550 | ||||
| #: ../src/core/screen.c:707 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Screen %d on display \"%s\" already has a window manager; try using the --" | ||||
| @@ -410,7 +394,7 @@ msgstr "" | ||||
| "A(z) %d képernyő a(z) „%s” megjelenítőn már rendelkezik egy ablakkezelővel; " | ||||
| "próbálja a --replace opcióval helyettesíteni a jelenlegi ablakkezelőt.\n" | ||||
|  | ||||
| #: ../src/core/screen.c:577 | ||||
| #: ../src/core/screen.c:734 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not acquire window manager selection on screen %d display \"%s\"\n" | ||||
| @@ -418,12 +402,12 @@ msgstr "" | ||||
| "Nem sikerült beolvasni az ablakkezelő kiválasztását a(z) %d képernyőn a(z) " | ||||
| "„%s” megjelenítőn\n" | ||||
|  | ||||
| #: ../src/core/screen.c:655 | ||||
| #: ../src/core/screen.c:812 | ||||
| #, c-format | ||||
| msgid "Screen %d on display \"%s\" already has a window manager\n" | ||||
| msgstr "A(z) %d képernyőnek a(z) „%s” megjelenítőn már van ablakkezelője\n" | ||||
|  | ||||
| #: ../src/core/screen.c:846 | ||||
| #: ../src/core/screen.c:998 | ||||
| #, c-format | ||||
| msgid "Could not release screen %d on display \"%s\"\n" | ||||
| msgstr "Nem sikerült elengedni a(z) %d képernyőt a(z) „%s” kijelzőn\n" | ||||
| @@ -500,7 +484,8 @@ msgstr "Nem sikerült megnyitni az fdopen()-nel a(z) „%s” naplófájlt: %s\n | ||||
| msgid "Opened log file %s\n" | ||||
| msgstr "%s naplófájl megnyitva\n" | ||||
|  | ||||
| #: ../src/core/util.c:119 | ||||
| #: ../src/core/util.c:119 ../src/tools/mutter-message.c:149 | ||||
| #, c-format | ||||
| msgid "Mutter was compiled without support for verbose mode\n" | ||||
| msgstr "A Mutter ablakkezelőt a részletes mód támogatása nélkül fordították\n" | ||||
|  | ||||
| @@ -508,20 +493,20 @@ msgstr "A Mutter ablakkezelőt a részletes mód támogatása nélkül fordítot | ||||
| msgid "Window manager: " | ||||
| msgstr "Ablakkezelő: " | ||||
|  | ||||
| #: ../src/core/util.c:414 | ||||
| #: ../src/core/util.c:412 | ||||
| msgid "Bug in window manager: " | ||||
| msgstr "Hiba az ablakkezelőben: " | ||||
|  | ||||
| #: ../src/core/util.c:445 | ||||
| #: ../src/core/util.c:443 | ||||
| msgid "Window manager warning: " | ||||
| msgstr "Figyelmeztetés az ablakkezelőtől: " | ||||
|  | ||||
| #: ../src/core/util.c:473 | ||||
| #: ../src/core/util.c:471 | ||||
| msgid "Window manager error: " | ||||
| msgstr "Hibaüzenet az ablakkezelőtől: " | ||||
|  | ||||
| #. first time through | ||||
| #: ../src/core/window.c:7533 | ||||
| #: ../src/core/window.c:7596 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER " | ||||
| @@ -537,7 +522,7 @@ msgstr "" | ||||
| #. * MWM but not WM_NORMAL_HINTS are basically broken. We complain | ||||
| #. * about these apps but make them work. | ||||
| #. | ||||
| #: ../src/core/window.c:8257 | ||||
| #: ../src/core/window.c:8320 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets an MWM hint indicating it isn't resizable, but sets min size " | ||||
| @@ -547,24 +532,24 @@ msgstr "" | ||||
| "de mégis %d x %d minimális és %d x %d maximális értéket ad meg, amelynek így " | ||||
| "nincs értelme.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:347 | ||||
| #: ../src/core/window-props.c:318 | ||||
| #, c-format | ||||
| msgid "Application set a bogus _NET_WM_PID %lu\n" | ||||
| msgstr "Az alkalmazás hibás _NET_WM_PID-értéket állított be: %lu\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:463 | ||||
| #: ../src/core/window-props.c:434 | ||||
| #, c-format | ||||
| msgid "%s (on %s)" | ||||
| msgstr "%s (ezen: %s)" | ||||
|  | ||||
| #: ../src/core/window-props.c:1546 | ||||
| #: ../src/core/window-props.c:1517 | ||||
| #, c-format | ||||
| msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n" | ||||
| msgstr "" | ||||
| "Érvénytelen WM_TRANSIENT_FOR ablak (0x%lx) került megadásra a következőhöz: " | ||||
| "%s.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:1557 | ||||
| #: ../src/core/window-props.c:1528 | ||||
| #, c-format | ||||
| msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n" | ||||
| msgstr "" | ||||
| @@ -662,7 +647,7 @@ msgstr "" | ||||
|  | ||||
| #: ../src/org.gnome.mutter.gschema.xml.in.h:9 | ||||
| msgid "Workspaces only on primary" | ||||
| msgstr "Munkaterületek csak az elsődlegesen" | ||||
| msgstr "Munkaterületek csak az elsődlegese" | ||||
|  | ||||
| #: ../src/org.gnome.mutter.gschema.xml.in.h:10 | ||||
| msgid "" | ||||
| @@ -731,104 +716,109 @@ msgstr "Ablakok kiválasztása tab billentyűre felugró ablakból" | ||||
| msgid "Cancel tab popup" | ||||
| msgstr "Tab felugró kikapcsolása" | ||||
|  | ||||
| #: ../src/tools/mutter-message.c:123 | ||||
| #, c-format | ||||
| msgid "Usage: %s\n" | ||||
| msgstr "Használat: %s\n" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:67 | ||||
| #: ../src/ui/menu.c:69 | ||||
| msgid "Mi_nimize" | ||||
| msgstr "Mi_nimalizálás" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:69 | ||||
| #: ../src/ui/menu.c:71 | ||||
| msgid "Ma_ximize" | ||||
| msgstr "Ma_ximalizálás" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:71 | ||||
| #: ../src/ui/menu.c:73 | ||||
| msgid "Unma_ximize" | ||||
| msgstr "_Eredeti méret" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:73 | ||||
| #: ../src/ui/menu.c:75 | ||||
| msgid "Roll _Up" | ||||
| msgstr "_Felgördítés" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:75 | ||||
| #: ../src/ui/menu.c:77 | ||||
| msgid "_Unroll" | ||||
| msgstr "_Legördítés" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:77 | ||||
| #: ../src/ui/menu.c:79 | ||||
| msgid "_Move" | ||||
| msgstr "Át_helyezés" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:79 | ||||
| #: ../src/ui/menu.c:81 | ||||
| msgid "_Resize" | ||||
| msgstr "Át_méretezés" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:81 | ||||
| #: ../src/ui/menu.c:83 | ||||
| msgid "Move Titlebar On_screen" | ||||
| msgstr "_Címsor mozgatása a képernyőn" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:84 ../src/ui/menu.c:86 | ||||
| #: ../src/ui/menu.c:86 ../src/ui/menu.c:88 | ||||
| msgid "Always on _Top" | ||||
| msgstr "Mindig _felül" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:88 | ||||
| #: ../src/ui/menu.c:90 | ||||
| msgid "_Always on Visible Workspace" | ||||
| msgstr "Mindig a látható m_unkaterületen" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:90 | ||||
| #: ../src/ui/menu.c:92 | ||||
| msgid "_Only on This Workspace" | ||||
| msgstr "_Csak ezen a munkaterületen" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:92 | ||||
| #: ../src/ui/menu.c:94 | ||||
| msgid "Move to Workspace _Left" | ||||
| msgstr "Áthelyezés a bal ol_dali munkaterületre" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:94 | ||||
| #: ../src/ui/menu.c:96 | ||||
| msgid "Move to Workspace R_ight" | ||||
| msgstr "Áthelyezés a j_obb oldali munkaterületre" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:96 | ||||
| #: ../src/ui/menu.c:98 | ||||
| msgid "Move to Workspace _Up" | ||||
| msgstr "Áthelyezés a fel_ső munkaterületre" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:98 | ||||
| #: ../src/ui/menu.c:100 | ||||
| msgid "Move to Workspace _Down" | ||||
| msgstr "Áthelyezés az _alsó munkaterületre" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:102 | ||||
| #: ../src/ui/menu.c:104 | ||||
| msgid "_Close" | ||||
| msgstr "_Bezárás" | ||||
|  | ||||
| #: ../src/ui/menu.c:202 | ||||
| #: ../src/ui/menu.c:204 | ||||
| #, c-format | ||||
| msgid "Workspace %d%n" | ||||
| msgstr "%d%n. munkaterület" | ||||
|  | ||||
| #: ../src/ui/menu.c:212 | ||||
| #: ../src/ui/menu.c:214 | ||||
| #, c-format | ||||
| msgid "Workspace 1_0" | ||||
| msgstr "1_0. munkaterület" | ||||
|  | ||||
| #: ../src/ui/menu.c:214 | ||||
| #: ../src/ui/menu.c:216 | ||||
| #, c-format | ||||
| msgid "Workspace %s%d" | ||||
| msgstr "%s%d. munkaterület" | ||||
|  | ||||
| #: ../src/ui/menu.c:384 | ||||
| #: ../src/ui/menu.c:397 | ||||
| msgid "Move to Another _Workspace" | ||||
| msgstr "Áthelyezés mási_k munkaterületre" | ||||
|  | ||||
| @@ -1189,18 +1179,18 @@ msgid "" | ||||
| msgstr "" | ||||
| "Hiányzó <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"bármi\"/> elem" | ||||
|  | ||||
| #: ../src/ui/theme.c:5082 | ||||
| #: ../src/ui/theme.c:5084 | ||||
| #, c-format | ||||
| msgid "Failed to load theme \"%s\": %s\n" | ||||
| msgstr "Hiba a(z) „%s” téma betöltése közben: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232 | ||||
| #: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246 | ||||
| #: ../src/ui/theme.c:5220 ../src/ui/theme.c:5227 ../src/ui/theme.c:5234 | ||||
| #: ../src/ui/theme.c:5241 ../src/ui/theme.c:5248 | ||||
| #, c-format | ||||
| msgid "No <%s> set for theme \"%s\"" | ||||
| msgstr "Nincs <%s> beállítva a(z) „%s” témához" | ||||
|  | ||||
| #: ../src/ui/theme.c:5254 | ||||
| #: ../src/ui/theme.c:5256 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "No frame style set for window type \"%s\" in theme \"%s\", add a <window " | ||||
| @@ -1209,7 +1199,7 @@ msgstr "" | ||||
| "Nincs keretstílus beállítva a(z) „%s” ablaktípushoz a(z) „%s” témában, adjon " | ||||
| "hozzá egy <window type=\"%s\" style_set=\"bármi\"/> elemet" | ||||
|  | ||||
| #: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786 | ||||
| #: ../src/ui/theme.c:5663 ../src/ui/theme.c:5725 ../src/ui/theme.c:5788 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "User-defined constants must begin with a capital letter; \"%s\" does not" | ||||
| @@ -1217,7 +1207,7 @@ msgstr "" | ||||
| "A felhasználó által meghatározott konstansoknak nagybetűvel kell kezdődniük, " | ||||
| "a(z) „%s” nem ilyen" | ||||
|  | ||||
| #: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794 | ||||
| #: ../src/ui/theme.c:5671 ../src/ui/theme.c:5733 ../src/ui/theme.c:5796 | ||||
| #, c-format | ||||
| msgid "Constant \"%s\" has already been defined" | ||||
| msgstr "A(z) „%s” konstans már definiálva van" | ||||
| @@ -1610,154 +1600,206 @@ msgstr "<%s> kétszer lett megadva ehhez a témához" | ||||
| msgid "Failed to find a valid file for theme %s\n" | ||||
| msgstr "Nem található érvényes fájl a következő témához: %s\n" | ||||
|  | ||||
| #~ msgid "Usage: %s\n" | ||||
| #~ msgstr "Használat: %s\n" | ||||
| #: ../src/ui/theme-viewer.c:99 | ||||
| msgid "_Windows" | ||||
| msgstr "_Ablakok" | ||||
|  | ||||
| #~ msgid "_Windows" | ||||
| #~ msgstr "_Ablakok" | ||||
| #: ../src/ui/theme-viewer.c:100 | ||||
| msgid "_Dialog" | ||||
| msgstr "_Párbeszédablak" | ||||
|  | ||||
| #~ msgid "_Dialog" | ||||
| #~ msgstr "_Párbeszédablak" | ||||
| #: ../src/ui/theme-viewer.c:101 | ||||
| msgid "_Modal dialog" | ||||
| msgstr "_Kizárólagos párbeszédablak" | ||||
|  | ||||
| #~ msgid "_Modal dialog" | ||||
| #~ msgstr "_Kizárólagos párbeszédablak" | ||||
| #: ../src/ui/theme-viewer.c:102 | ||||
| msgid "_Utility" | ||||
| msgstr "_Segédprogram" | ||||
|  | ||||
| #~ msgid "_Utility" | ||||
| #~ msgstr "_Segédprogram" | ||||
| #: ../src/ui/theme-viewer.c:103 | ||||
| msgid "_Splashscreen" | ||||
| msgstr "_Indítóképernyő" | ||||
|  | ||||
| #~ msgid "_Splashscreen" | ||||
| #~ msgstr "_Indítóképernyő" | ||||
| #: ../src/ui/theme-viewer.c:104 | ||||
| msgid "_Top dock" | ||||
| msgstr "_Felső dokk" | ||||
|  | ||||
| #~ msgid "_Top dock" | ||||
| #~ msgstr "_Felső dokk" | ||||
| #: ../src/ui/theme-viewer.c:105 | ||||
| msgid "_Bottom dock" | ||||
| msgstr "_Alsó dokk" | ||||
|  | ||||
| #~ msgid "_Bottom dock" | ||||
| #~ msgstr "_Alsó dokk" | ||||
| #: ../src/ui/theme-viewer.c:106 | ||||
| msgid "_Left dock" | ||||
| msgstr "_Bal dokk" | ||||
|  | ||||
| #~ msgid "_Left dock" | ||||
| #~ msgstr "_Bal dokk" | ||||
| #: ../src/ui/theme-viewer.c:107 | ||||
| msgid "_Right dock" | ||||
| msgstr "_Jobb dokk" | ||||
|  | ||||
| #~ msgid "_Right dock" | ||||
| #~ msgstr "_Jobb dokk" | ||||
| #: ../src/ui/theme-viewer.c:108 | ||||
| msgid "_All docks" | ||||
| msgstr "Össz_es dokk" | ||||
|  | ||||
| #~ msgid "_All docks" | ||||
| #~ msgstr "Össz_es dokk" | ||||
| #: ../src/ui/theme-viewer.c:109 | ||||
| msgid "Des_ktop" | ||||
| msgstr "_Asztal" | ||||
|  | ||||
| #~ msgid "Des_ktop" | ||||
| #~ msgstr "_Asztal" | ||||
| #: ../src/ui/theme-viewer.c:115 | ||||
| msgid "Open another one of these windows" | ||||
| msgstr "Egy újabb példány megnyitása ezekből az ablakokból" | ||||
|  | ||||
| #~ msgid "Open another one of these windows" | ||||
| #~ msgstr "Egy újabb példány megnyitása ezekből az ablakokból" | ||||
| #: ../src/ui/theme-viewer.c:117 | ||||
| msgid "This is a demo button with an 'open' icon" | ||||
| msgstr "Ez egy mintagomb a „Megnyitás” ikonnal" | ||||
|  | ||||
| #~ msgid "This is a demo button with an 'open' icon" | ||||
| #~ msgstr "Ez egy mintagomb a „Megnyitás” ikonnal" | ||||
| #: ../src/ui/theme-viewer.c:119 | ||||
| msgid "This is a demo button with a 'quit' icon" | ||||
| msgstr "Ez egy mintagomb a „Kilépés” ikonnal" | ||||
|  | ||||
| #~ msgid "This is a demo button with a 'quit' icon" | ||||
| #~ msgstr "Ez egy mintagomb a „Kilépés” ikonnal" | ||||
| #: ../src/ui/theme-viewer.c:248 | ||||
| msgid "This is a sample message in a sample dialog" | ||||
| msgstr "Ez egy mintaüzenet egy minta párbeszédben" | ||||
|  | ||||
| #~ msgid "This is a sample message in a sample dialog" | ||||
| #~ msgstr "Ez egy mintaüzenet egy minta párbeszédben" | ||||
| #: ../src/ui/theme-viewer.c:328 | ||||
| #, c-format | ||||
| msgid "Fake menu item %d\n" | ||||
| msgstr "%d. hamis menüelem\n" | ||||
|  | ||||
| #~ msgid "Fake menu item %d\n" | ||||
| #~ msgstr "%d. hamis menüelem\n" | ||||
| #: ../src/ui/theme-viewer.c:363 | ||||
| msgid "Border-only window" | ||||
| msgstr "Csak keretes ablak" | ||||
|  | ||||
| #~ msgid "Border-only window" | ||||
| #~ msgstr "Csak keretes ablak" | ||||
| #: ../src/ui/theme-viewer.c:365 | ||||
| msgid "Bar" | ||||
| msgstr "Sáv" | ||||
|  | ||||
| #~ msgid "Bar" | ||||
| #~ msgstr "Sáv" | ||||
| #: ../src/ui/theme-viewer.c:382 | ||||
| msgid "Normal Application Window" | ||||
| msgstr "Normál alkalmazásablak" | ||||
|  | ||||
| #~ msgid "Normal Application Window" | ||||
| #~ msgstr "Normál alkalmazásablak" | ||||
| #: ../src/ui/theme-viewer.c:386 | ||||
| msgid "Dialog Box" | ||||
| msgstr "Párbeszédablak" | ||||
|  | ||||
| #~ msgid "Dialog Box" | ||||
| #~ msgstr "Párbeszédablak" | ||||
| #: ../src/ui/theme-viewer.c:390 | ||||
| msgid "Modal Dialog Box" | ||||
| msgstr "Kizárólagos párbeszéd doboz" | ||||
|  | ||||
| #~ msgid "Modal Dialog Box" | ||||
| #~ msgstr "Kizárólagos párbeszéd doboz" | ||||
| #: ../src/ui/theme-viewer.c:394 | ||||
| msgid "Utility Palette" | ||||
| msgstr "Eszközpaletta" | ||||
|  | ||||
| #~ msgid "Utility Palette" | ||||
| #~ msgstr "Eszközpaletta" | ||||
| #: ../src/ui/theme-viewer.c:398 | ||||
| msgid "Torn-off Menu" | ||||
| msgstr "Leválasztott menü" | ||||
|  | ||||
| #~ msgid "Torn-off Menu" | ||||
| #~ msgstr "Leválasztott menü" | ||||
| #: ../src/ui/theme-viewer.c:402 | ||||
| msgid "Border" | ||||
| msgstr "Szegély" | ||||
|  | ||||
| #~ msgid "Border" | ||||
| #~ msgstr "Szegély" | ||||
| #: ../src/ui/theme-viewer.c:406 | ||||
| msgid "Attached Modal Dialog" | ||||
| msgstr "Csatolt kizárólagos párbeszédablak" | ||||
|  | ||||
| #~ msgid "Attached Modal Dialog" | ||||
| #~ msgstr "Csatolt kizárólagos párbeszédablak" | ||||
| #: ../src/ui/theme-viewer.c:737 | ||||
| #, c-format | ||||
| msgid "Button layout test %d" | ||||
| msgstr "Gombelrendezés teszt %d" | ||||
|  | ||||
| #~ msgid "Button layout test %d" | ||||
| #~ msgstr "Gombelrendezés teszt %d" | ||||
| #: ../src/ui/theme-viewer.c:766 | ||||
| #, c-format | ||||
| msgid "%g milliseconds to draw one window frame" | ||||
| msgstr "%g ezredmásodpercig tartott egy ablakkeret kirajzolása" | ||||
|  | ||||
| #~ msgid "%g milliseconds to draw one window frame" | ||||
| #~ msgstr "%g ezredmásodpercig tartott egy ablakkeret kirajzolása" | ||||
| #: ../src/ui/theme-viewer.c:811 | ||||
| #, c-format | ||||
| msgid "Usage: metacity-theme-viewer [THEMENAME]\n" | ||||
| msgstr "Használat: metacity-theme-viewer [TÉMANÉV]\n" | ||||
|  | ||||
| #~ msgid "Usage: metacity-theme-viewer [THEMENAME]\n" | ||||
| #~ msgstr "Használat: metacity-theme-viewer [TÉMANÉV]\n" | ||||
| #: ../src/ui/theme-viewer.c:818 | ||||
| #, c-format | ||||
| msgid "Error loading theme: %s\n" | ||||
| msgstr "Hiba történt a téma betöltése közben: %s\n" | ||||
|  | ||||
| #~ msgid "Error loading theme: %s\n" | ||||
| #~ msgstr "Hiba történt a téma betöltése közben: %s\n" | ||||
| #: ../src/ui/theme-viewer.c:824 | ||||
| #, c-format | ||||
| msgid "Loaded theme \"%s\" in %g seconds\n" | ||||
| msgstr "A(z) „%s” téma %g másodperc alatt betöltve\n" | ||||
|  | ||||
| #~ msgid "Loaded theme \"%s\" in %g seconds\n" | ||||
| #~ msgstr "A(z) „%s” téma %g másodperc alatt betöltve\n" | ||||
| #: ../src/ui/theme-viewer.c:869 | ||||
| msgid "Normal Title Font" | ||||
| msgstr "Normál cím betűtípus" | ||||
|  | ||||
| #~ msgid "Normal Title Font" | ||||
| #~ msgstr "Normál cím betűtípus" | ||||
| #: ../src/ui/theme-viewer.c:875 | ||||
| msgid "Small Title Font" | ||||
| msgstr "Kicsi cím betűtípus" | ||||
|  | ||||
| #~ msgid "Small Title Font" | ||||
| #~ msgstr "Kicsi cím betűtípus" | ||||
| #: ../src/ui/theme-viewer.c:881 | ||||
| msgid "Large Title Font" | ||||
| msgstr "Nagy cím betűtípus" | ||||
|  | ||||
| #~ msgid "Large Title Font" | ||||
| #~ msgstr "Nagy cím betűtípus" | ||||
| #: ../src/ui/theme-viewer.c:886 | ||||
| msgid "Button Layouts" | ||||
| msgstr "Gombelrendezések" | ||||
|  | ||||
| #~ msgid "Button Layouts" | ||||
| #~ msgstr "Gombelrendezések" | ||||
| #: ../src/ui/theme-viewer.c:891 | ||||
| msgid "Benchmark" | ||||
| msgstr "Teljesítményteszt" | ||||
|  | ||||
| #~ msgid "Benchmark" | ||||
| #~ msgstr "Teljesítményteszt" | ||||
| #: ../src/ui/theme-viewer.c:947 | ||||
| msgid "Window Title Goes Here" | ||||
| msgstr "Ide kerül az ablak címe" | ||||
|  | ||||
| #~ msgid "Window Title Goes Here" | ||||
| #~ msgstr "Ide kerül az ablak címe" | ||||
| #: ../src/ui/theme-viewer.c:1053 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g " | ||||
| "seconds wall clock time including X server resources (%g milliseconds per " | ||||
| "frame)\n" | ||||
| msgstr "" | ||||
| "%d keret kirajzolása %g kliens-oldali másodperc alatt (%g ezredmásodperc " | ||||
| "képkeretenként) és %g összes idő beleértve az X szerver erőforrásokat (%g " | ||||
| "ezredmásodperc képkeretenként)\n" | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and " | ||||
| #~ "%g seconds wall clock time including X server resources (%g milliseconds " | ||||
| #~ "per frame)\n" | ||||
| #~ msgstr "" | ||||
| #~ "%d keret kirajzolása %g kliens-oldali másodperc alatt (%g ezredmásodperc " | ||||
| #~ "képkeretenként) és %g összes idő beleértve az X szerver erőforrásokat (%g " | ||||
| #~ "ezredmásodperc képkeretenként)\n" | ||||
| #: ../src/ui/theme-viewer.c:1273 | ||||
| msgid "position expression test returned TRUE but set error" | ||||
| msgstr "a pozíció kifejezés teszt IGAZ értéket adott vissza, de hiba történt" | ||||
|  | ||||
| #~ msgid "position expression test returned TRUE but set error" | ||||
| #~ msgstr "" | ||||
| #~ "a pozíció kifejezés teszt IGAZ értéket adott vissza, de hiba történt" | ||||
| #: ../src/ui/theme-viewer.c:1275 | ||||
| msgid "position expression test returned FALSE but didn't set error" | ||||
| msgstr "" | ||||
| "a pozíció kifejezés teszt HAMIS értéket adott vissza, de nem történt hiba" | ||||
|  | ||||
| #~ msgid "position expression test returned FALSE but didn't set error" | ||||
| #~ msgstr "" | ||||
| #~ "a pozíció kifejezés teszt HAMIS értéket adott vissza, de nem történt hiba" | ||||
| #: ../src/ui/theme-viewer.c:1279 | ||||
| msgid "Error was expected but none given" | ||||
| msgstr "Hibát vártunk, de nem történt egy sem" | ||||
|  | ||||
| #~ msgid "Error was expected but none given" | ||||
| #~ msgstr "Hibát vártunk, de nem történt egy sem" | ||||
| #: ../src/ui/theme-viewer.c:1281 | ||||
| #, c-format | ||||
| msgid "Error %d was expected but %d given" | ||||
| msgstr "A(z) %d hibát vártuk, de a(z) %d hiba következett be" | ||||
|  | ||||
| #~ msgid "Error %d was expected but %d given" | ||||
| #~ msgstr "A(z) %d hibát vártuk, de a(z) %d hiba következett be" | ||||
| #: ../src/ui/theme-viewer.c:1287 | ||||
| #, c-format | ||||
| msgid "Error not expected but one was returned: %s" | ||||
| msgstr "Nem várt hiba következett be: %s" | ||||
|  | ||||
| #~ msgid "Error not expected but one was returned: %s" | ||||
| #~ msgstr "Nem várt hiba következett be: %s" | ||||
| #: ../src/ui/theme-viewer.c:1291 | ||||
| #, c-format | ||||
| msgid "x value was %d, %d was expected" | ||||
| msgstr "x értéke %d volt, de a várt érték %d volt" | ||||
|  | ||||
| #~ msgid "x value was %d, %d was expected" | ||||
| #~ msgstr "x értéke %d volt, de a várt érték %d volt" | ||||
| #: ../src/ui/theme-viewer.c:1294 | ||||
| #, c-format | ||||
| msgid "y value was %d, %d was expected" | ||||
| msgstr "y értéke %d volt, de a várt érték %d volt" | ||||
|  | ||||
| #~ msgid "y value was %d, %d was expected" | ||||
| #~ msgstr "y értéke %d volt, de a várt érték %d volt" | ||||
|  | ||||
| #~ msgid "" | ||||
| #~ "%d coordinate expressions parsed in %g seconds (%g seconds average)\n" | ||||
| #~ msgstr "" | ||||
| #~ "A %d koordináta kifejezések %g másodperc alatt lettek feldolgozva " | ||||
| #~ "(átlagosan %g másodperc)\n" | ||||
| #: ../src/ui/theme-viewer.c:1359 | ||||
| #, c-format | ||||
| msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n" | ||||
| msgstr "" | ||||
| "A %d koordináta kifejezések %g másodperc alatt lettek feldolgozva (átlagosan " | ||||
| "%g másodperc)\n" | ||||
|  | ||||
| #, fuzzy | ||||
| #~ msgid "Minimize window" | ||||
|   | ||||
							
								
								
									
										440
									
								
								po/it.po
									
									
									
									
									
								
							
							
						
						
									
										440
									
								
								po/it.po
									
									
									
									
									
								
							| @@ -12,8 +12,8 @@ msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: mutter\n" | ||||
| "Report-Msgid-Bugs-To: \n" | ||||
| "POT-Creation-Date: 2013-08-24 19:11+0200\n" | ||||
| "PO-Revision-Date: 2013-08-24 19:11+0200\n" | ||||
| "POT-Creation-Date: 2013-03-12 18:34+0100\n" | ||||
| "PO-Revision-Date: 2013-03-12 18:35+0100\n" | ||||
| "Last-Translator: Milo Casagrande <milo@ubuntu.com>\n" | ||||
| "Language-Team: Italian <tp@lists.linux.it>\n" | ||||
| "Language: it\n" | ||||
| @@ -21,7 +21,6 @@ msgstr "" | ||||
| "Content-Type: text/plain; charset=UTF-8\n" | ||||
| "Content-Transfer-Encoding: 8-bit\n" | ||||
| "Plural-Forms: nplurals=2; plural=(n!=1);\n" | ||||
| "X-Generator: Gtranslator 2.91.6\n" | ||||
|  | ||||
| #: ../src/50-mutter-navigation.xml.in.h:1 | ||||
| msgid "Navigation" | ||||
| @@ -217,7 +216,7 @@ msgstr "Massimizza a destra" | ||||
|  | ||||
| #. This probably means that a non-WM compositor like xcompmgr is running; | ||||
| #. * we have no way to get it to exit | ||||
| #: ../src/compositor/compositor.c:596 | ||||
| #: ../src/compositor/compositor.c:502 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Another compositing manager is already running on screen %i on display \"%s" | ||||
| @@ -226,11 +225,11 @@ msgstr "" | ||||
| "Un altro compositing manager è già in esecuzione sullo schermo %i sul " | ||||
| "display «%s»." | ||||
|  | ||||
| #: ../src/compositor/meta-background.c:1076 | ||||
| #: ../src/compositor/meta-background.c:1180 | ||||
| msgid "background texture could not be created from file" | ||||
| msgstr "La texture dello sfondo non può essere creata dal file" | ||||
|  | ||||
| #: ../src/core/bell.c:322 | ||||
| #: ../src/core/bell.c:320 | ||||
| msgid "Bell event" | ||||
| msgstr "Evento campanella" | ||||
|  | ||||
| @@ -266,17 +265,17 @@ msgstr "_Attendi" | ||||
| msgid "_Force Quit" | ||||
| msgstr "_Forza uscita" | ||||
|  | ||||
| #: ../src/core/display.c:422 | ||||
| #: ../src/core/display.c:402 | ||||
| #, c-format | ||||
| msgid "Missing %s extension required for compositing" | ||||
| msgstr "Estensione %s richiesta per il compositing mancante" | ||||
|  | ||||
| #: ../src/core/display.c:514 | ||||
| #: ../src/core/display.c:494 | ||||
| #, c-format | ||||
| msgid "Failed to open X Window System display '%s'\n" | ||||
| msgstr "Apertura del display «%s» di X Window System non riuscita\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1136 | ||||
| #: ../src/core/keybindings.c:929 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Some other program is already using the key %s with modifiers %x as a " | ||||
| @@ -285,41 +284,41 @@ msgstr "" | ||||
| "Qualche altro programma sta già usando il tasto %s con i modificatori %x " | ||||
| "come una associazione di tasti\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1333 | ||||
| #: ../src/core/keybindings.c:1129 | ||||
| #, c-format | ||||
| msgid "\"%s\" is not a valid accelerator\n" | ||||
| msgstr "«%s» non è una scorciatoia valida\n" | ||||
|  | ||||
| #: ../src/core/main.c:197 | ||||
| #: ../src/core/main.c:196 | ||||
| msgid "Disable connection to session manager" | ||||
| msgstr "Disabilita la connessione al gestore di sessione" | ||||
|  | ||||
| #: ../src/core/main.c:203 | ||||
| #: ../src/core/main.c:202 | ||||
| msgid "Replace the running window manager" | ||||
| msgstr "Sostituisce il window manager in esecuzione" | ||||
|  | ||||
| #: ../src/core/main.c:209 | ||||
| #: ../src/core/main.c:208 | ||||
| msgid "Specify session management ID" | ||||
| msgstr "Specifica l'ID di gestione sessione" | ||||
|  | ||||
| #: ../src/core/main.c:214 | ||||
| #: ../src/core/main.c:213 | ||||
| msgid "X Display to use" | ||||
| msgstr "Display X da usare" | ||||
|  | ||||
| #: ../src/core/main.c:220 | ||||
| #: ../src/core/main.c:219 | ||||
| msgid "Initialize session from savefile" | ||||
| msgstr "Inizializza la sessione da file salvato" | ||||
|  | ||||
| #: ../src/core/main.c:226 | ||||
| #: ../src/core/main.c:225 | ||||
| msgid "Make X calls synchronous" | ||||
| msgstr "Rende le chiamate X sincrone" | ||||
|  | ||||
| #: ../src/core/main.c:534 | ||||
| #: ../src/core/main.c:533 | ||||
| #, c-format | ||||
| msgid "Failed to scan themes directory: %s\n" | ||||
| msgstr "Scansione della directory dei temi non riuscita: %s\n" | ||||
|  | ||||
| #: ../src/core/main.c:550 | ||||
| #: ../src/core/main.c:549 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not find a theme! Be sure %s exists and contains the usual themes.\n" | ||||
| @@ -327,19 +326,6 @@ msgstr "" | ||||
| "Non è stato trovato alcun tema. Assicurarsi che %s esista e contenga i temi " | ||||
| "standard.\n" | ||||
|  | ||||
| #: ../src/core/monitor.c:702 | ||||
| msgid "Built-in display" | ||||
| msgstr "Display integrato" | ||||
|  | ||||
| #. TRANSLATORS: this is a monitor name (in case we don't know | ||||
| #. the vendor), it's Unknown followed by a size in inches, | ||||
| #. like 'Unknown 15"' | ||||
| #. | ||||
| #: ../src/core/monitor.c:730 | ||||
| #, c-format | ||||
| msgid "Unknown %s" | ||||
| msgstr "Sconosciuto %s" | ||||
|  | ||||
| #: ../src/core/mutter.c:40 | ||||
| #, c-format | ||||
| msgid "" | ||||
| @@ -363,7 +349,7 @@ msgstr "Stampa la versione" | ||||
| msgid "Mutter plugin to use" | ||||
| msgstr "Plugin Mutter da usare" | ||||
|  | ||||
| #: ../src/core/prefs.c:1202 | ||||
| #: ../src/core/prefs.c:1087 | ||||
| msgid "" | ||||
| "Workarounds for broken applications disabled. Some applications may not " | ||||
| "behave properly.\n" | ||||
| @@ -371,14 +357,14 @@ msgstr "" | ||||
| "Disabilitate le funzionalità palliative per la applicazioni difettose. " | ||||
| "Alcune applicazioni potrebbero avere comportamenti errati.\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1277 | ||||
| #: ../src/core/prefs.c:1162 | ||||
| #, c-format | ||||
| msgid "Could not parse font description \"%s\" from GSettings key %s\n" | ||||
| msgstr "" | ||||
| "Impossibile analizzare la descrizione del tipo di carattere «%s» dalla " | ||||
| "chiave GSettings %s\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1343 | ||||
| #: ../src/core/prefs.c:1228 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for mouse button " | ||||
| @@ -387,7 +373,7 @@ msgstr "" | ||||
| "Il valore «%s» trovato nel database di configurazione non è valido per il " | ||||
| "modificatore del tasto del mouse\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1909 | ||||
| #: ../src/core/prefs.c:1780 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for keybinding " | ||||
| @@ -396,17 +382,17 @@ msgstr "" | ||||
| "Il valore «%s» nel database di configurazione non è valido per " | ||||
| "l'associazione di tasti «%s»\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1999 | ||||
| #: ../src/core/prefs.c:1879 | ||||
| #, c-format | ||||
| msgid "Workspace %d" | ||||
| msgstr "Spazio di lavoro %d" | ||||
|  | ||||
| #: ../src/core/screen.c:537 | ||||
| #: ../src/core/screen.c:674 | ||||
| #, c-format | ||||
| msgid "Screen %d on display '%s' is invalid\n" | ||||
| msgstr "Lo schermo %d nel display «%s» non è valido\n" | ||||
|  | ||||
| #: ../src/core/screen.c:553 | ||||
| #: ../src/core/screen.c:690 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Screen %d on display \"%s\" already has a window manager; try using the --" | ||||
| @@ -415,7 +401,7 @@ msgstr "" | ||||
| "Lo schermo %d sul display «%s» ha già un window manager; provare a " | ||||
| "utilizzare l'opzione --replace per sostituirlo.\n" | ||||
|  | ||||
| #: ../src/core/screen.c:580 | ||||
| #: ../src/core/screen.c:717 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not acquire window manager selection on screen %d display \"%s\"\n" | ||||
| @@ -423,12 +409,12 @@ msgstr "" | ||||
| "Impossibile acquisire la selezione del window manager per lo schermo %d nel " | ||||
| "display «%s»\n" | ||||
|  | ||||
| #: ../src/core/screen.c:658 | ||||
| #: ../src/core/screen.c:795 | ||||
| #, c-format | ||||
| msgid "Screen %d on display \"%s\" already has a window manager\n" | ||||
| msgstr "Lo schermo %d sul display «%s» ha già un window manager\n" | ||||
|  | ||||
| #: ../src/core/screen.c:850 | ||||
| #: ../src/core/screen.c:980 | ||||
| #, c-format | ||||
| msgid "Could not release screen %d on display \"%s\"\n" | ||||
| msgstr "Impossibile rilasciare lo schermo %d sul display «%s»\n" | ||||
| @@ -490,44 +476,45 @@ msgstr "" | ||||
| "Queste finestre non supportano la funzione "salva impostazioni " | ||||
| "attuali" e dovranno essere riavviate manualmente al prossimo accesso." | ||||
|  | ||||
| #: ../src/core/util.c:84 | ||||
| #: ../src/core/util.c:80 | ||||
| #, c-format | ||||
| msgid "Failed to open debug log: %s\n" | ||||
| msgstr "Apertura nel file di registro di debug non riuscita: %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:94 | ||||
| #: ../src/core/util.c:90 | ||||
| #, c-format | ||||
| msgid "Failed to fdopen() log file %s: %s\n" | ||||
| msgstr "Esecuzione di fdopen() sul file di registro %s non riuscita: %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:100 | ||||
| #: ../src/core/util.c:96 | ||||
| #, c-format | ||||
| msgid "Opened log file %s\n" | ||||
| msgstr "File di registro %s aperto\n" | ||||
|  | ||||
| #: ../src/core/util.c:119 | ||||
| #: ../src/core/util.c:115 ../src/tools/mutter-message.c:149 | ||||
| #, c-format | ||||
| msgid "Mutter was compiled without support for verbose mode\n" | ||||
| msgstr "" | ||||
| "Mutter è stato compilato escludendo il supporto per la modalità prolissa\n" | ||||
|  | ||||
| #: ../src/core/util.c:264 | ||||
| #: ../src/core/util.c:259 | ||||
| msgid "Window manager: " | ||||
| msgstr "Window manager: " | ||||
|  | ||||
| #: ../src/core/util.c:414 | ||||
| #: ../src/core/util.c:407 | ||||
| msgid "Bug in window manager: " | ||||
| msgstr "Bug nel window manager: " | ||||
|  | ||||
| #: ../src/core/util.c:445 | ||||
| #: ../src/core/util.c:438 | ||||
| msgid "Window manager warning: " | ||||
| msgstr "Avviso del window manager: " | ||||
|  | ||||
| #: ../src/core/util.c:473 | ||||
| #: ../src/core/util.c:466 | ||||
| msgid "Window manager error: " | ||||
| msgstr "Errore del window manager: " | ||||
|  | ||||
| #. first time through | ||||
| #: ../src/core/window.c:7533 | ||||
| #: ../src/core/window.c:7538 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER " | ||||
| @@ -543,7 +530,7 @@ msgstr "" | ||||
| #. * MWM but not WM_NORMAL_HINTS are basically broken. We complain | ||||
| #. * about these apps but make them work. | ||||
| #. | ||||
| #: ../src/core/window.c:8257 | ||||
| #: ../src/core/window.c:8262 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets an MWM hint indicating it isn't resizable, but sets min size " | ||||
| @@ -553,26 +540,26 @@ msgstr "" | ||||
| "ridimensionabile, ma ha impostato la dimensione minima %d x %d e la " | ||||
| "dimensione massima %d x %d; ciò non ha senso.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:347 | ||||
| #: ../src/core/window-props.c:318 | ||||
| #, c-format | ||||
| msgid "Application set a bogus _NET_WM_PID %lu\n" | ||||
| msgstr "L'applicazione ha impostato un _NET_WM_PID errato %lu\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:463 | ||||
| #: ../src/core/window-props.c:434 | ||||
| #, c-format | ||||
| msgid "%s (on %s)" | ||||
| msgstr "%s (su %s)" | ||||
|  | ||||
| # Sì, direi che è oscuro  -Luca | ||||
| # | ||||
| #: ../src/core/window-props.c:1546 | ||||
| #: ../src/core/window-props.c:1517 | ||||
| #, c-format | ||||
| msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n" | ||||
| msgstr "Specificato un WM_TRANSIENT_FOR finestra 0x%lx non valido per %s.\n" | ||||
|  | ||||
| # Sì, direi che è oscuro  -Luca | ||||
| # | ||||
| #: ../src/core/window-props.c:1557 | ||||
| #: ../src/core/window-props.c:1528 | ||||
| #, c-format | ||||
| msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n" | ||||
| msgstr "WM_TRANSIENT_FOR finestra 0x%lx per %s potrebbe creare un loop.\n" | ||||
| @@ -744,120 +731,125 @@ msgstr "Seleziona finestra dal tab popup" | ||||
| msgid "Cancel tab popup" | ||||
| msgstr "Annulla tab popup" | ||||
|  | ||||
| #: ../src/tools/mutter-message.c:123 | ||||
| #, c-format | ||||
| msgid "Usage: %s\n" | ||||
| msgstr "Uso: %s\n" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:67 | ||||
| #: ../src/ui/menu.c:69 | ||||
| msgid "Mi_nimize" | ||||
| msgstr "_Minimizza" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:69 | ||||
| #: ../src/ui/menu.c:71 | ||||
| msgid "Ma_ximize" | ||||
| msgstr "Ma_ssimizza" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:71 | ||||
| #: ../src/ui/menu.c:73 | ||||
| msgid "Unma_ximize" | ||||
| msgstr "Dema_ssimizza" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:73 | ||||
| #: ../src/ui/menu.c:75 | ||||
| msgid "Roll _Up" | ||||
| msgstr "Arr_otola" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:75 | ||||
| #: ../src/ui/menu.c:77 | ||||
| msgid "_Unroll" | ||||
| msgstr "Sr_otola" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:77 | ||||
| #: ../src/ui/menu.c:79 | ||||
| msgid "_Move" | ||||
| msgstr "M_uovi" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:79 | ||||
| #: ../src/ui/menu.c:81 | ||||
| msgid "_Resize" | ||||
| msgstr "_Ridimensiona" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:81 | ||||
| #: ../src/ui/menu.c:83 | ||||
| msgid "Move Titlebar On_screen" | ||||
| msgstr "Muovi barra del titolo su _schermo" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:84 ../src/ui/menu.c:86 | ||||
| #: ../src/ui/menu.c:86 ../src/ui/menu.c:88 | ||||
| msgid "Always on _Top" | ||||
| msgstr "Sempre in _primo piano" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:88 | ||||
| #: ../src/ui/menu.c:90 | ||||
| msgid "_Always on Visible Workspace" | ||||
| msgstr "Sempre su spazio di lavoro _visibile" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:90 | ||||
| #: ../src/ui/menu.c:92 | ||||
| msgid "_Only on This Workspace" | ||||
| msgstr "Solo su _questo spazio di lavoro" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:92 | ||||
| #: ../src/ui/menu.c:94 | ||||
| msgid "Move to Workspace _Left" | ||||
| msgstr "Sposta su spazio di lavoro a s_inistra" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:94 | ||||
| #: ../src/ui/menu.c:96 | ||||
| msgid "Move to Workspace R_ight" | ||||
| msgstr "Sposta su spazio di lavoro a d_estra" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:96 | ||||
| #: ../src/ui/menu.c:98 | ||||
| msgid "Move to Workspace _Up" | ||||
| msgstr "Sposta su spazio di lavoro in alt_o" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:98 | ||||
| #: ../src/ui/menu.c:100 | ||||
| msgid "Move to Workspace _Down" | ||||
| msgstr "Sposta su spazio di lavoro in _basso" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:102 | ||||
| #: ../src/ui/menu.c:104 | ||||
| msgid "_Close" | ||||
| msgstr "_Chiudi" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #: ../src/ui/menu.c:202 | ||||
| #: ../src/ui/menu.c:204 | ||||
| #, c-format | ||||
| msgid "Workspace %d%n" | ||||
| msgstr "Spazio di lavoro %d%n" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #: ../src/ui/menu.c:212 | ||||
| #: ../src/ui/menu.c:214 | ||||
| #, c-format | ||||
| msgid "Workspace 1_0" | ||||
| msgstr "Spazio di lavoro 1_0" | ||||
|  | ||||
| # mantenere in sync con libwnck | ||||
| #: ../src/ui/menu.c:214 | ||||
| #: ../src/ui/menu.c:216 | ||||
| #, c-format | ||||
| msgid "Workspace %s%d" | ||||
| msgstr "Spazio di lavoro %s%d" | ||||
|  | ||||
| #: ../src/ui/menu.c:384 | ||||
| #: ../src/ui/menu.c:397 | ||||
| msgid "Move to Another _Workspace" | ||||
| msgstr "Sposta su _altro spazio di lavoro" | ||||
|  | ||||
| @@ -959,49 +951,49 @@ msgstr "Mod5" | ||||
| msgid "%d x %d" | ||||
| msgstr "%d × %d" | ||||
|  | ||||
| #: ../src/ui/theme.c:236 | ||||
| #: ../src/ui/theme.c:235 | ||||
| msgid "top" | ||||
| msgstr "alto" | ||||
|  | ||||
| #: ../src/ui/theme.c:238 | ||||
| #: ../src/ui/theme.c:237 | ||||
| msgid "bottom" | ||||
| msgstr "basso" | ||||
|  | ||||
| #: ../src/ui/theme.c:240 | ||||
| #: ../src/ui/theme.c:239 | ||||
| msgid "left" | ||||
| msgstr "sinistra" | ||||
|  | ||||
| #: ../src/ui/theme.c:242 | ||||
| #: ../src/ui/theme.c:241 | ||||
| msgid "right" | ||||
| msgstr "destra" | ||||
|  | ||||
| #: ../src/ui/theme.c:270 | ||||
| #: ../src/ui/theme.c:269 | ||||
| #, c-format | ||||
| msgid "frame geometry does not specify \"%s\" dimension" | ||||
| msgstr "la geometria della cornice non specifica la dimensione «%s»" | ||||
|  | ||||
| #: ../src/ui/theme.c:289 | ||||
| #: ../src/ui/theme.c:288 | ||||
| #, c-format | ||||
| msgid "frame geometry does not specify dimension \"%s\" for border \"%s\"" | ||||
| msgstr "" | ||||
| "la geometria della cornice non specifica la dimensione «%s» per il bordo «%s»" | ||||
|  | ||||
| #: ../src/ui/theme.c:326 | ||||
| #: ../src/ui/theme.c:325 | ||||
| #, c-format | ||||
| msgid "Button aspect ratio %g is not reasonable" | ||||
| msgstr "Le proporzioni %g del pulsante non sono ragionevoli" | ||||
|  | ||||
| #: ../src/ui/theme.c:338 | ||||
| #: ../src/ui/theme.c:337 | ||||
| #, c-format | ||||
| msgid "Frame geometry does not specify size of buttons" | ||||
| msgstr "La geometria della cornice non specifica la dimensione dei pulsanti" | ||||
|  | ||||
| #: ../src/ui/theme.c:1051 | ||||
| #: ../src/ui/theme.c:1050 | ||||
| #, c-format | ||||
| msgid "Gradients should have at least two colors" | ||||
| msgstr "I gradienti dovrebbero avere almeno due colori" | ||||
|  | ||||
| #: ../src/ui/theme.c:1203 | ||||
| #: ../src/ui/theme.c:1202 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK custom color specification must have color name and fallback in " | ||||
| @@ -1011,7 +1003,7 @@ msgstr "" | ||||
| "colore e un ripiego tra parentesi, per es. gtk:custom(foo,bar); impossibile " | ||||
| "analizzare \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1219 | ||||
| #: ../src/ui/theme.c:1218 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-" | ||||
| @@ -1020,7 +1012,7 @@ msgstr "" | ||||
| "Carattere \"%c\" non valido nel parametro color_name di gtk:custom, sono " | ||||
| "validi solo A-Za-z0-9-_" | ||||
|  | ||||
| #: ../src/ui/theme.c:1233 | ||||
| #: ../src/ui/theme.c:1232 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not " | ||||
| @@ -1029,7 +1021,7 @@ msgstr "" | ||||
| "Il formato per Gtk:custom è \"gtk:custom(color_name,fallback)\", «%s» non è " | ||||
| "adatto a tale formato" | ||||
|  | ||||
| #: ../src/ui/theme.c:1278 | ||||
| #: ../src/ui/theme.c:1277 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] " | ||||
| @@ -1038,7 +1030,7 @@ msgstr "" | ||||
| "La specificazione del colore GTK deve avere lo stato fra parentesi, per es. " | ||||
| "gtk:fg[NORMAL] dove NORMAL è lo stato; impossibile analizzare \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1292 | ||||
| #: ../src/ui/theme.c:1291 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK color specification must have a close bracket after the state, e.g. gtk:" | ||||
| @@ -1048,18 +1040,18 @@ msgstr "" | ||||
| "lo stato, per es. gtk:fg[NORMAL] dove NORMAL è lo stato; impossibile " | ||||
| "analizzare \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1303 | ||||
| #: ../src/ui/theme.c:1302 | ||||
| #, c-format | ||||
| msgid "Did not understand state \"%s\" in color specification" | ||||
| msgstr "Stato «%s» incomprensibile nella specificazione del colore" | ||||
|  | ||||
| #: ../src/ui/theme.c:1316 | ||||
| #: ../src/ui/theme.c:1315 | ||||
| #, c-format | ||||
| msgid "Did not understand color component \"%s\" in color specification" | ||||
| msgstr "" | ||||
| "Componente di colore «%s» incomprensibile nella specificazione del colore" | ||||
|  | ||||
| #: ../src/ui/theme.c:1345 | ||||
| #: ../src/ui/theme.c:1344 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the " | ||||
| @@ -1068,17 +1060,17 @@ msgstr "" | ||||
| "Il formato della sfumature è «blend/bg_color/fg_color/alpha», «%s» non è " | ||||
| "adatto a tale formato" | ||||
|  | ||||
| #: ../src/ui/theme.c:1356 | ||||
| #: ../src/ui/theme.c:1355 | ||||
| #, c-format | ||||
| msgid "Could not parse alpha value \"%s\" in blended color" | ||||
| msgstr "Impossibile analizzare il valore alpha «%s» nel colore sfumato" | ||||
|  | ||||
| #: ../src/ui/theme.c:1366 | ||||
| #: ../src/ui/theme.c:1365 | ||||
| #, c-format | ||||
| msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0" | ||||
| msgstr "Il valore alpha «%s» nel colore sfumato non è compreso tra 0.0 e 1.0" | ||||
|  | ||||
| #: ../src/ui/theme.c:1413 | ||||
| #: ../src/ui/theme.c:1412 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format" | ||||
| @@ -1086,31 +1078,31 @@ msgstr "" | ||||
| "Il formato dell'ombreggiatura è «shade/base_color/factor», «%s» non è adatto " | ||||
| "a tale formato" | ||||
|  | ||||
| #: ../src/ui/theme.c:1424 | ||||
| #: ../src/ui/theme.c:1423 | ||||
| #, c-format | ||||
| msgid "Could not parse shade factor \"%s\" in shaded color" | ||||
| msgstr "" | ||||
| "Impossibile analizzare il fattore di ombreggiatura «%s» nel colore " | ||||
| "ombreggiato" | ||||
|  | ||||
| #: ../src/ui/theme.c:1434 | ||||
| #: ../src/ui/theme.c:1433 | ||||
| #, c-format | ||||
| msgid "Shade factor \"%s\" in shaded color is negative" | ||||
| msgstr "Il fattore di ombreggiatura «%s» nel colore ombreggiato è negativo" | ||||
|  | ||||
| #: ../src/ui/theme.c:1463 | ||||
| #: ../src/ui/theme.c:1462 | ||||
| #, c-format | ||||
| msgid "Could not parse color \"%s\"" | ||||
| msgstr "Impossibile analizzare il colore «%s»" | ||||
|  | ||||
| #: ../src/ui/theme.c:1780 | ||||
| #: ../src/ui/theme.c:1779 | ||||
| #, c-format | ||||
| msgid "Coordinate expression contains character '%s' which is not allowed" | ||||
| msgstr "" | ||||
| "L'espressione delle coordinate contiene il carattere «%s» che non è " | ||||
| "consentito" | ||||
|  | ||||
| #: ../src/ui/theme.c:1807 | ||||
| #: ../src/ui/theme.c:1806 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression contains floating point number '%s' which could not be " | ||||
| @@ -1119,14 +1111,14 @@ msgstr "" | ||||
| "L'espressione delle coordinate contiene il numero in virgola mobile «%s» che " | ||||
| "non può essere analizzato" | ||||
|  | ||||
| #: ../src/ui/theme.c:1821 | ||||
| #: ../src/ui/theme.c:1820 | ||||
| #, c-format | ||||
| msgid "Coordinate expression contains integer '%s' which could not be parsed" | ||||
| msgstr "" | ||||
| "L'espressione delle coordinate contiene l'intero «%s» che non può essere " | ||||
| "analizzato" | ||||
|  | ||||
| #: ../src/ui/theme.c:1942 | ||||
| #: ../src/ui/theme.c:1941 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression contained unknown operator at the start of this text: " | ||||
| @@ -1135,18 +1127,18 @@ msgstr "" | ||||
| "L'espressione delle coordinate contiene un operatore sconosciuto all'inizio " | ||||
| "di questo testo: \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1999 | ||||
| #: ../src/ui/theme.c:1998 | ||||
| #, c-format | ||||
| msgid "Coordinate expression was empty or not understood" | ||||
| msgstr "L'espressione delle coordinate è vuota o incomprensibile" | ||||
|  | ||||
| #: ../src/ui/theme.c:2112 ../src/ui/theme.c:2122 ../src/ui/theme.c:2156 | ||||
| #: ../src/ui/theme.c:2111 ../src/ui/theme.c:2121 ../src/ui/theme.c:2155 | ||||
| #, c-format | ||||
| msgid "Coordinate expression results in division by zero" | ||||
| msgstr "" | ||||
| "L'espressione delle coordinate ha come risultato una divisione per zero" | ||||
|  | ||||
| #: ../src/ui/theme.c:2164 | ||||
| #: ../src/ui/theme.c:2163 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression tries to use mod operator on a floating-point number" | ||||
| @@ -1154,27 +1146,27 @@ msgstr "" | ||||
| "L'espressione delle coordinate tenta di usare un operatore mod su un numero " | ||||
| "in virgola mobile" | ||||
|  | ||||
| #: ../src/ui/theme.c:2220 | ||||
| #: ../src/ui/theme.c:2219 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression has an operator \"%s\" where an operand was expected" | ||||
| msgstr "" | ||||
| "L'espressione delle coordinate ha un operatore «%s» dove è atteso un operando" | ||||
|  | ||||
| #: ../src/ui/theme.c:2229 | ||||
| #: ../src/ui/theme.c:2228 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had an operand where an operator was expected" | ||||
| msgstr "" | ||||
| "L'espressione delle coordinate ha un operando dove è atteso un operatore" | ||||
|  | ||||
| #: ../src/ui/theme.c:2237 | ||||
| #: ../src/ui/theme.c:2236 | ||||
| #, c-format | ||||
| msgid "Coordinate expression ended with an operator instead of an operand" | ||||
| msgstr "" | ||||
| "L'espressione delle coordinate finisce con un operatore invece che un " | ||||
| "operando" | ||||
|  | ||||
| #: ../src/ui/theme.c:2247 | ||||
| #: ../src/ui/theme.c:2246 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression has operator \"%c\" following operator \"%c\" with no " | ||||
| @@ -1183,45 +1175,45 @@ msgstr "" | ||||
| "L'espressione delle coordinate ha l'operatore «%c» seguito dall'operatore " | ||||
| "«%c» senza un operando fra i due" | ||||
|  | ||||
| #: ../src/ui/theme.c:2398 ../src/ui/theme.c:2443 | ||||
| #: ../src/ui/theme.c:2397 ../src/ui/theme.c:2442 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had unknown variable or constant \"%s\"" | ||||
| msgstr "" | ||||
| "L'espressione delle coordinate ha la variabile o la costante «%s» sconosciuta" | ||||
|  | ||||
| #: ../src/ui/theme.c:2497 | ||||
| #: ../src/ui/theme.c:2496 | ||||
| #, c-format | ||||
| msgid "Coordinate expression parser overflowed its buffer." | ||||
| msgstr "" | ||||
| "L'analizzatore dell'espressione delle coordinate ha superato il proprio " | ||||
| "buffer." | ||||
|  | ||||
| #: ../src/ui/theme.c:2526 | ||||
| #: ../src/ui/theme.c:2525 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had a close parenthesis with no open parenthesis" | ||||
| msgstr "" | ||||
| "L'espressione delle coordinate ha una parentesi di chiusura senza la " | ||||
| "relativa di apertura" | ||||
|  | ||||
| #: ../src/ui/theme.c:2590 | ||||
| #: ../src/ui/theme.c:2589 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had an open parenthesis with no close parenthesis" | ||||
| msgstr "" | ||||
| "L'espressione delle coordinate ha una parentesi di apertura senza la " | ||||
| "relativa di chiusura" | ||||
|  | ||||
| #: ../src/ui/theme.c:2601 | ||||
| #: ../src/ui/theme.c:2600 | ||||
| #, c-format | ||||
| msgid "Coordinate expression doesn't seem to have any operators or operands" | ||||
| msgstr "" | ||||
| "L'espressione delle coordinate non sembra avere né operatori né operandi" | ||||
|  | ||||
| #: ../src/ui/theme.c:2814 ../src/ui/theme.c:2834 ../src/ui/theme.c:2854 | ||||
| #: ../src/ui/theme.c:2813 ../src/ui/theme.c:2833 ../src/ui/theme.c:2853 | ||||
| #, c-format | ||||
| msgid "Theme contained an expression that resulted in an error: %s\n" | ||||
| msgstr "Il tema contiene un'espressione che ha come risultato un errore: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:4500 | ||||
| #: ../src/ui/theme.c:4499 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be " | ||||
| @@ -1230,7 +1222,7 @@ msgstr "" | ||||
| "È necessario specificare <button function=\"%s\" state=\"%s\" draw_ops=" | ||||
| "\"whatever\"/> per questo stile di cornice" | ||||
|  | ||||
| #: ../src/ui/theme.c:5011 ../src/ui/theme.c:5036 | ||||
| #: ../src/ui/theme.c:5010 ../src/ui/theme.c:5035 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>" | ||||
| @@ -1238,18 +1230,18 @@ msgstr "" | ||||
| "Risulta mancante <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=" | ||||
| "\"whatever\"/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5082 | ||||
| #: ../src/ui/theme.c:5083 | ||||
| #, c-format | ||||
| msgid "Failed to load theme \"%s\": %s\n" | ||||
| msgstr "Caricamento del tema «%s» non riuscito: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232 | ||||
| #: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246 | ||||
| #: ../src/ui/theme.c:5219 ../src/ui/theme.c:5226 ../src/ui/theme.c:5233 | ||||
| #: ../src/ui/theme.c:5240 ../src/ui/theme.c:5247 | ||||
| #, c-format | ||||
| msgid "No <%s> set for theme \"%s\"" | ||||
| msgstr "Nessun <%s> impostato per il tema «%s»" | ||||
|  | ||||
| #: ../src/ui/theme.c:5254 | ||||
| #: ../src/ui/theme.c:5255 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "No frame style set for window type \"%s\" in theme \"%s\", add a <window " | ||||
| @@ -1258,7 +1250,7 @@ msgstr "" | ||||
| "Nessuno stile di cornice impostato per il tipo di finestra «%s» nel tema " | ||||
| "«%s», aggiungere un elemento <window type=\"%s\" style_set=\"whatever\"/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786 | ||||
| #: ../src/ui/theme.c:5662 ../src/ui/theme.c:5724 ../src/ui/theme.c:5787 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "User-defined constants must begin with a capital letter; \"%s\" does not" | ||||
| @@ -1266,7 +1258,7 @@ msgstr "" | ||||
| "Le costanti definite dall'utente devono iniziare con una lettera maiuscola, " | ||||
| "«%s» non lo fa" | ||||
|  | ||||
| #: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794 | ||||
| #: ../src/ui/theme.c:5670 ../src/ui/theme.c:5732 ../src/ui/theme.c:5795 | ||||
| #, c-format | ||||
| msgid "Constant \"%s\" has already been defined" | ||||
| msgstr "La costante «%s» è già definita" | ||||
| @@ -1669,7 +1661,207 @@ msgstr "Il testo non è consentito all'interno dell'elemento <%s>" | ||||
| msgid "<%s> specified twice for this theme" | ||||
| msgstr "<%s> specificato due volte per questo tema" | ||||
|  | ||||
| #: ../src/ui/theme-parser.c:4336 | ||||
| #: ../src/ui/theme-parser.c:4334 | ||||
| #, c-format | ||||
| msgid "Failed to find a valid file for theme %s\n" | ||||
| msgstr "Ricerca di un file valido per il tema «%s» non riuscita\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:99 | ||||
| msgid "_Windows" | ||||
| msgstr "_Finestre" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:100 | ||||
| msgid "_Dialog" | ||||
| msgstr "_Dialogo" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:101 | ||||
| msgid "_Modal dialog" | ||||
| msgstr "Dialogo _modale" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:102 | ||||
| msgid "_Utility" | ||||
| msgstr "_Utilità" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:103 | ||||
| msgid "_Splashscreen" | ||||
| msgstr "_Schermata d'avvio" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:104 | ||||
| msgid "_Top dock" | ||||
| msgstr "Dock superi_ore" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:105 | ||||
| msgid "_Bottom dock" | ||||
| msgstr "Dock in_feriore" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:106 | ||||
| msgid "_Left dock" | ||||
| msgstr "Dock _sinistro" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:107 | ||||
| msgid "_Right dock" | ||||
| msgstr "Dock _destro" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:108 | ||||
| msgid "_All docks" | ||||
| msgstr "Tutti i doc_k" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:109 | ||||
| msgid "Des_ktop" | ||||
| msgstr "Scri_vania" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:115 | ||||
| msgid "Open another one of these windows" | ||||
| msgstr "Apre un'altra di queste finestre" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:117 | ||||
| msgid "This is a demo button with an 'open' icon" | ||||
| msgstr "Questo è un pulsante di prova con un'icona «Apri»" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:119 | ||||
| msgid "This is a demo button with a 'quit' icon" | ||||
| msgstr "Questo è un pulsante di prova con un'icona «Esci»" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:248 | ||||
| msgid "This is a sample message in a sample dialog" | ||||
| msgstr "Questo è un messaggio d'esempio in una finestra di dialogo d'esempio" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:328 | ||||
| #, c-format | ||||
| msgid "Fake menu item %d\n" | ||||
| msgstr "Voce di menu finta n.%d\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:363 | ||||
| msgid "Border-only window" | ||||
| msgstr "Finestra solo-bordo" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:365 | ||||
| msgid "Bar" | ||||
| msgstr "Barra" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:382 | ||||
| msgid "Normal Application Window" | ||||
| msgstr "Finestra applicazione normale" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:386 | ||||
| msgid "Dialog Box" | ||||
| msgstr "Casella di dialogo" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:390 | ||||
| msgid "Modal Dialog Box" | ||||
| msgstr "Casella di dialogo modale" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:394 | ||||
| msgid "Utility Palette" | ||||
| msgstr "Tavolozza di utilità" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:398 | ||||
| msgid "Torn-off Menu" | ||||
| msgstr "Menù staccato" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:402 | ||||
| msgid "Border" | ||||
| msgstr "Bordo" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:406 | ||||
| msgid "Attached Modal Dialog" | ||||
| msgstr "Dialogo modale attaccato" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:737 | ||||
| #, c-format | ||||
| msgid "Button layout test %d" | ||||
| msgstr "Test n.%d disposizione pulsanti" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:766 | ||||
| #, c-format | ||||
| msgid "%g milliseconds to draw one window frame" | ||||
| msgstr "%g millisecondi per disegnare una cornice di finestra" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:811 | ||||
| #, c-format | ||||
| msgid "Usage: metacity-theme-viewer [THEMENAME]\n" | ||||
| msgstr "Uso: metacity-theme-viewer [NOME_TEMA]\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:818 | ||||
| #, c-format | ||||
| msgid "Error loading theme: %s\n" | ||||
| msgstr "Errore nel caricare il tema: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:824 | ||||
| #, c-format | ||||
| msgid "Loaded theme \"%s\" in %g seconds\n" | ||||
| msgstr "Tema «%s» caricato in %g secondi\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:869 | ||||
| msgid "Normal Title Font" | ||||
| msgstr "Carattere titolo normale" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:875 | ||||
| msgid "Small Title Font" | ||||
| msgstr "Carattere titolo piccolo" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:881 | ||||
| msgid "Large Title Font" | ||||
| msgstr "Carattere titolo grande" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:886 | ||||
| msgid "Button Layouts" | ||||
| msgstr "Disposizione pulsanti" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:891 | ||||
| msgid "Benchmark" | ||||
| msgstr "Prestazioni" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:947 | ||||
| msgid "Window Title Goes Here" | ||||
| msgstr "Qui va il titolo della finestra" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1053 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g " | ||||
| "seconds wall clock time including X server resources (%g milliseconds per " | ||||
| "frame)\n" | ||||
| msgstr "" | ||||
| "Disegnate %d cornici in %g secondi lato client (%g millisecondi per cornice) " | ||||
| "e %g secondi di wall clock time, incluse le risorse del server X (%g " | ||||
| "millisecondi per cornice)\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1273 | ||||
| msgid "position expression test returned TRUE but set error" | ||||
| msgstr "test espressione posizione ha restituito TRUE, ma impostato errore" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1275 | ||||
| msgid "position expression test returned FALSE but didn't set error" | ||||
| msgstr "" | ||||
| "test espressione posizione ha restituito FALSE, ma non ha impostato errore" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1279 | ||||
| msgid "Error was expected but none given" | ||||
| msgstr "Errore atteso, ma non fornito" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1281 | ||||
| #, c-format | ||||
| msgid "Error %d was expected but %d given" | ||||
| msgstr "Atteso errore %d, ma fornito %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1287 | ||||
| #, c-format | ||||
| msgid "Error not expected but one was returned: %s" | ||||
| msgstr "Errore non atteso, ma è stato restituito: %s" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1291 | ||||
| #, c-format | ||||
| msgid "x value was %d, %d was expected" | ||||
| msgstr "valore x era %d, era atteso %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1294 | ||||
| #, c-format | ||||
| msgid "y value was %d, %d was expected" | ||||
| msgstr "valore y era %d, era atteso %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1359 | ||||
| #, c-format | ||||
| msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n" | ||||
| msgstr "" | ||||
| "%d espressioni di coordinate analizzate in %g secondi (%g secondi in media)\n" | ||||
|   | ||||
							
								
								
									
										443
									
								
								po/lt.po
									
									
									
									
									
								
							
							
						
						
									
										443
									
								
								po/lt.po
									
									
									
									
									
								
							| @@ -13,8 +13,8 @@ msgstr "" | ||||
| "Project-Id-Version: lt\n" | ||||
| "Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?" | ||||
| "product=mutter&keywords=I18N+L10N&component=general\n" | ||||
| "POT-Creation-Date: 2013-08-18 20:03+0000\n" | ||||
| "PO-Revision-Date: 2013-08-28 23:06+0300\n" | ||||
| "POT-Creation-Date: 2013-03-01 15:50+0000\n" | ||||
| "PO-Revision-Date: 2013-03-02 22:57+0200\n" | ||||
| "Last-Translator: Aurimas Černius <aurisc4@gmail.com>\n" | ||||
| "Language-Team: Lietuvių <gnome-lt@lists.akl.lt>\n" | ||||
| "Language: lt\n" | ||||
| @@ -216,18 +216,18 @@ msgstr "Rodyti skyrimą dešinėje" | ||||
|  | ||||
| #. This probably means that a non-WM compositor like xcompmgr is running; | ||||
| #. * we have no way to get it to exit | ||||
| #: ../src/compositor/compositor.c:589 | ||||
| #: ../src/compositor/compositor.c:507 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Another compositing manager is already running on screen %i on display \"%s" | ||||
| "\"." | ||||
| msgstr "Kita kompozicijos valdyklė jau veikia ekrane %i vaizduoklyje „%s“." | ||||
|  | ||||
| #: ../src/compositor/meta-background.c:1076 | ||||
| #: ../src/compositor/meta-background.c:1111 | ||||
| msgid "background texture could not be created from file" | ||||
| msgstr "nepavyko sukurti fono tekstūros iš failo" | ||||
|  | ||||
| #: ../src/core/bell.c:322 | ||||
| #: ../src/core/bell.c:320 | ||||
| msgid "Bell event" | ||||
| msgstr "Skambučio įvykis" | ||||
|  | ||||
| @@ -259,17 +259,17 @@ msgstr "_Laukti" | ||||
| msgid "_Force Quit" | ||||
| msgstr "_Priverstinai išeiti" | ||||
|  | ||||
| #: ../src/core/display.c:421 | ||||
| #: ../src/core/display.c:401 | ||||
| #, c-format | ||||
| msgid "Missing %s extension required for compositing" | ||||
| msgstr "Trūksta %s priedo, reikalingo komponavimui" | ||||
|  | ||||
| #: ../src/core/display.c:513 | ||||
| #: ../src/core/display.c:493 | ||||
| #, c-format | ||||
| msgid "Failed to open X Window System display '%s'\n" | ||||
| msgstr "Nepavyko atverti X Window sistemos ekrano „%s“\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1136 | ||||
| #: ../src/core/keybindings.c:929 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Some other program is already using the key %s with modifiers %x as a " | ||||
| @@ -278,41 +278,42 @@ msgstr "" | ||||
| "Kažkokia kita programa jau naudoja %s klavišą su modifikatoriais %x kaip " | ||||
| "susiejimą\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1333 | ||||
| #: ../src/core/keybindings.c:1129 | ||||
| #, c-format | ||||
| #| msgid "\"%s\" is not a valid value for focus attribute" | ||||
| msgid "\"%s\" is not a valid accelerator\n" | ||||
| msgstr "„%s“ yra nepriimtinas spartusis klavišas\n" | ||||
|  | ||||
| #: ../src/core/main.c:197 | ||||
| #: ../src/core/main.c:196 | ||||
| msgid "Disable connection to session manager" | ||||
| msgstr "Išjungti susijungimą su sesijos valdykle" | ||||
|  | ||||
| #: ../src/core/main.c:203 | ||||
| #: ../src/core/main.c:202 | ||||
| msgid "Replace the running window manager" | ||||
| msgstr "Pakeisti veikiančią langų valdyklę" | ||||
|  | ||||
| #: ../src/core/main.c:209 | ||||
| #: ../src/core/main.c:208 | ||||
| msgid "Specify session management ID" | ||||
| msgstr "Nurodyti sesijos valdymo ID" | ||||
|  | ||||
| #: ../src/core/main.c:214 | ||||
| #: ../src/core/main.c:213 | ||||
| msgid "X Display to use" | ||||
| msgstr "Naudotinas X ekranas" | ||||
|  | ||||
| #: ../src/core/main.c:220 | ||||
| #: ../src/core/main.c:219 | ||||
| msgid "Initialize session from savefile" | ||||
| msgstr "Inicializuoti sesiją iš išsaugojimo failo" | ||||
|  | ||||
| #: ../src/core/main.c:226 | ||||
| #: ../src/core/main.c:225 | ||||
| msgid "Make X calls synchronous" | ||||
| msgstr "Sinchronizuoti X iškvietimus" | ||||
|  | ||||
| #: ../src/core/main.c:534 | ||||
| #: ../src/core/main.c:494 | ||||
| #, c-format | ||||
| msgid "Failed to scan themes directory: %s\n" | ||||
| msgstr "Nepavyko nuskanuoti temų aplanko: %s\n" | ||||
|  | ||||
| #: ../src/core/main.c:550 | ||||
| #: ../src/core/main.c:510 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not find a theme! Be sure %s exists and contains the usual themes.\n" | ||||
| @@ -320,20 +321,6 @@ msgstr "" | ||||
| "Nepavyko rasti temos! Įsitikinkite, kad %s egzistuoja ir kad ten yra " | ||||
| "įprastos temos.\n" | ||||
|  | ||||
| #: ../src/core/monitor.c:711 | ||||
| msgid "Built-in display" | ||||
| msgstr "Integruotas vaizduoklis" | ||||
|  | ||||
| #. TRANSLATORS: this is a monitor name (in case we don't know | ||||
| #. the vendor), it's Unknown followed by a size in inches, | ||||
| #. like 'Unknown 15"' | ||||
| #. | ||||
| #: ../src/core/monitor.c:739 | ||||
| #, c-format | ||||
| #| msgid "Unknown element %s" | ||||
| msgid "Unknown %s" | ||||
| msgstr "Nežinomas %s" | ||||
|  | ||||
| #: ../src/core/mutter.c:40 | ||||
| #, c-format | ||||
| msgid "" | ||||
| @@ -359,7 +346,7 @@ msgstr "Parodyti versiją" | ||||
| msgid "Mutter plugin to use" | ||||
| msgstr "Naudojamas Mutter įskiepis" | ||||
|  | ||||
| #: ../src/core/prefs.c:1202 | ||||
| #: ../src/core/prefs.c:1087 | ||||
| msgid "" | ||||
| "Workarounds for broken applications disabled. Some applications may not " | ||||
| "behave properly.\n" | ||||
| @@ -367,12 +354,12 @@ msgstr "" | ||||
| "Apsauga nuo sugadintų programų atjungta. Kai kurios programos gali pradėti " | ||||
| "keistai elgtis.\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1277 | ||||
| #: ../src/core/prefs.c:1162 | ||||
| #, c-format | ||||
| msgid "Could not parse font description \"%s\" from GSettings key %s\n" | ||||
| msgstr "Nepavyko perskaityti šrifto aprašymo „%s“ saugomo GSettings rakte %s\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1343 | ||||
| #: ../src/core/prefs.c:1228 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for mouse button " | ||||
| @@ -381,7 +368,7 @@ msgstr "" | ||||
| "„%s“ reikšmė rasta nustatymų duomenų bazėje yra netinkama pelės mygtuko " | ||||
| "keitiklio aprašymui\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1909 | ||||
| #: ../src/core/prefs.c:1780 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for keybinding " | ||||
| @@ -390,17 +377,17 @@ msgstr "" | ||||
| "„%s“ reikšmė rasta konfiguracijos duomenų bazė yra netinkama klavišų " | ||||
| "kombinacijai „%s“\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1999 | ||||
| #: ../src/core/prefs.c:1879 | ||||
| #, c-format | ||||
| msgid "Workspace %d" | ||||
| msgstr "Darbalaukis %d" | ||||
|  | ||||
| #: ../src/core/screen.c:534 | ||||
| #: ../src/core/screen.c:673 | ||||
| #, c-format | ||||
| msgid "Screen %d on display '%s' is invalid\n" | ||||
| msgstr "Ekranas %d vaizduoklyje „%s“ netinkamas\n" | ||||
|  | ||||
| #: ../src/core/screen.c:550 | ||||
| #: ../src/core/screen.c:689 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Screen %d on display \"%s\" already has a window manager; try using the --" | ||||
| @@ -409,19 +396,19 @@ msgstr "" | ||||
| "Ekranas %d vaizduoklyje „%s“ jau turi langų valdyklę; pabandykite " | ||||
| "pasinaudoti parinktimi --replace, jei norite pakeisti esamą langų valdyklę.\n" | ||||
|  | ||||
| #: ../src/core/screen.c:577 | ||||
| #: ../src/core/screen.c:716 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not acquire window manager selection on screen %d display \"%s\"\n" | ||||
| msgstr "" | ||||
| "Nepavyko aptikti langų valdyklės pasirinkimo ekrano %d vaizduoklyje „%s“\n" | ||||
|  | ||||
| #: ../src/core/screen.c:655 | ||||
| #: ../src/core/screen.c:794 | ||||
| #, c-format | ||||
| msgid "Screen %d on display \"%s\" already has a window manager\n" | ||||
| msgstr "Ekranas %d vaizduoklyje „%s“ jau turi langų valdyklę\n" | ||||
|  | ||||
| #: ../src/core/screen.c:846 | ||||
| #: ../src/core/screen.c:979 | ||||
| #, c-format | ||||
| msgid "Could not release screen %d on display \"%s\"\n" | ||||
| msgstr "Nepavyko pasitraukti iš ekrano %d vaizduoklyje „%s“\n" | ||||
| @@ -481,43 +468,44 @@ msgstr "" | ||||
| "Šie langai nepalaiko "išsaugoti esamus nustatymus" komandos ir " | ||||
| "turi būti paleisti rankiniu būdu, kai prisijungsite kitą kartą." | ||||
|  | ||||
| #: ../src/core/util.c:84 | ||||
| #: ../src/core/util.c:80 | ||||
| #, c-format | ||||
| msgid "Failed to open debug log: %s\n" | ||||
| msgstr "Nepavyko atverti derinimo žurnalo: %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:94 | ||||
| #: ../src/core/util.c:90 | ||||
| #, c-format | ||||
| msgid "Failed to fdopen() log file %s: %s\n" | ||||
| msgstr "Funkcija fdopen() su žurnalo failu %s nesėkminga: %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:100 | ||||
| #: ../src/core/util.c:96 | ||||
| #, c-format | ||||
| msgid "Opened log file %s\n" | ||||
| msgstr "Atvertas žurnalo failas %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:119 | ||||
| #: ../src/core/util.c:115 ../src/tools/mutter-message.c:149 | ||||
| #, c-format | ||||
| msgid "Mutter was compiled without support for verbose mode\n" | ||||
| msgstr "Mutter buvo sukompiliuota be išsamaus veikimo veiksenos\n" | ||||
|  | ||||
| #: ../src/core/util.c:264 | ||||
| #: ../src/core/util.c:259 | ||||
| msgid "Window manager: " | ||||
| msgstr "Langų valdyklė:" | ||||
|  | ||||
| #: ../src/core/util.c:414 | ||||
| #: ../src/core/util.c:407 | ||||
| msgid "Bug in window manager: " | ||||
| msgstr "Klaida langų valdyklėje:" | ||||
|  | ||||
| #: ../src/core/util.c:445 | ||||
| #: ../src/core/util.c:438 | ||||
| msgid "Window manager warning: " | ||||
| msgstr "Langų valdyklės perspėjimas:" | ||||
|  | ||||
| #: ../src/core/util.c:473 | ||||
| #: ../src/core/util.c:466 | ||||
| msgid "Window manager error: " | ||||
| msgstr "Langų valdyklės klaida:" | ||||
|  | ||||
| #. first time through | ||||
| #: ../src/core/window.c:7533 | ||||
| #: ../src/core/window.c:7539 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER " | ||||
| @@ -533,7 +521,7 @@ msgstr "" | ||||
| #. * MWM but not WM_NORMAL_HINTS are basically broken. We complain | ||||
| #. * about these apps but make them work. | ||||
| #. | ||||
| #: ../src/core/window.c:8257 | ||||
| #: ../src/core/window.c:8263 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets an MWM hint indicating it isn't resizable, but sets min size " | ||||
| @@ -543,22 +531,22 @@ msgstr "" | ||||
| "tuo pat metu nustatė ir leistinas mažiausio dydžio %d x %d bei didžiausio " | ||||
| "dydžio %d x %d reikšmes; tai yra beprasmiška.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:347 | ||||
| #: ../src/core/window-props.c:318 | ||||
| #, c-format | ||||
| msgid "Application set a bogus _NET_WM_PID %lu\n" | ||||
| msgstr "Programa nustatė netinkamą _NET_WM_PID %lu\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:463 | ||||
| #: ../src/core/window-props.c:434 | ||||
| #, c-format | ||||
| msgid "%s (on %s)" | ||||
| msgstr "%s (kompiuteryje %s)" | ||||
|  | ||||
| #: ../src/core/window-props.c:1546 | ||||
| #: ../src/core/window-props.c:1517 | ||||
| #, c-format | ||||
| msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n" | ||||
| msgstr "Nekorektiškas WM_TRANSIENT_FOR langas 0x%lx nurodytas %s.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:1557 | ||||
| #: ../src/core/window-props.c:1528 | ||||
| #, c-format | ||||
| msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n" | ||||
| msgstr "WM_TRANSIENT_FOR langas 0x%lx nurodytas %s sukurtų ciklą.\n" | ||||
| @@ -722,104 +710,109 @@ msgstr "Pasirinkti langą iš tab iššokimo" | ||||
| msgid "Cancel tab popup" | ||||
| msgstr "Atšaukti tab iššokimą" | ||||
|  | ||||
| #: ../src/tools/mutter-message.c:123 | ||||
| #, c-format | ||||
| msgid "Usage: %s\n" | ||||
| msgstr "Naudojimas: %s\n" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:67 | ||||
| #: ../src/ui/menu.c:69 | ||||
| msgid "Mi_nimize" | ||||
| msgstr "Sumaži_nti" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:69 | ||||
| #: ../src/ui/menu.c:71 | ||||
| msgid "Ma_ximize" | ||||
| msgstr "Iš_didinti" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:71 | ||||
| #: ../src/ui/menu.c:73 | ||||
| msgid "Unma_ximize" | ||||
| msgstr "_Grąžinti iš išdidinimo" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:73 | ||||
| #: ../src/ui/menu.c:75 | ||||
| msgid "Roll _Up" | ||||
| msgstr "Su_vynioti" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:75 | ||||
| #: ../src/ui/menu.c:77 | ||||
| msgid "_Unroll" | ||||
| msgstr "_Išvynioti" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:77 | ||||
| #: ../src/ui/menu.c:79 | ||||
| msgid "_Move" | ||||
| msgstr "Pe_rkelti" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:79 | ||||
| #: ../src/ui/menu.c:81 | ||||
| msgid "_Resize" | ||||
| msgstr "_Keisti dydį" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:81 | ||||
| #: ../src/ui/menu.c:83 | ||||
| msgid "Move Titlebar On_screen" | ||||
| msgstr "Perkelti lango juostą ant _ekrano" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:84 ../src/ui/menu.c:86 | ||||
| #: ../src/ui/menu.c:86 ../src/ui/menu.c:88 | ||||
| msgid "Always on _Top" | ||||
| msgstr "Visada _viršuje" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:88 | ||||
| #: ../src/ui/menu.c:90 | ||||
| msgid "_Always on Visible Workspace" | ||||
| msgstr "_Visada matomame darbalaukyje" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:90 | ||||
| #: ../src/ui/menu.c:92 | ||||
| msgid "_Only on This Workspace" | ||||
| msgstr "_Tik šiame darbalaukyje" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:92 | ||||
| #: ../src/ui/menu.c:94 | ||||
| msgid "Move to Workspace _Left" | ||||
| msgstr "Perkelti _langą į kairįjį darbalaukį" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:94 | ||||
| #: ../src/ui/menu.c:96 | ||||
| msgid "Move to Workspace R_ight" | ||||
| msgstr "Pe_rkelti langą į dešinįjį darbalaukį" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:96 | ||||
| #: ../src/ui/menu.c:98 | ||||
| msgid "Move to Workspace _Up" | ||||
| msgstr "Perkelti langą į a_ukštesnįjį darbalaukį" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:98 | ||||
| #: ../src/ui/menu.c:100 | ||||
| msgid "Move to Workspace _Down" | ||||
| msgstr "Perkelti langą į ž_emesnįjį darbalaukį" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:102 | ||||
| #: ../src/ui/menu.c:104 | ||||
| msgid "_Close" | ||||
| msgstr "_Užverti" | ||||
|  | ||||
| #: ../src/ui/menu.c:202 | ||||
| #: ../src/ui/menu.c:204 | ||||
| #, c-format | ||||
| msgid "Workspace %d%n" | ||||
| msgstr "Darbalaukis %d%n" | ||||
|  | ||||
| #: ../src/ui/menu.c:212 | ||||
| #: ../src/ui/menu.c:214 | ||||
| #, c-format | ||||
| msgid "Workspace 1_0" | ||||
| msgstr "1_0-tas darbalaukis" | ||||
|  | ||||
| #: ../src/ui/menu.c:214 | ||||
| #: ../src/ui/menu.c:216 | ||||
| #, c-format | ||||
| msgid "Workspace %s%d" | ||||
| msgstr "Darbalaukis %s%d" | ||||
|  | ||||
| #: ../src/ui/menu.c:384 | ||||
| #: ../src/ui/menu.c:397 | ||||
| msgid "Move to Another _Workspace" | ||||
| msgstr "Perkelti langą į kitą _darbalaukį" | ||||
|  | ||||
| @@ -921,48 +914,48 @@ msgstr "Mod5" | ||||
| msgid "%d x %d" | ||||
| msgstr "%d x %d" | ||||
|  | ||||
| #: ../src/ui/theme.c:236 | ||||
| #: ../src/ui/theme.c:235 | ||||
| msgid "top" | ||||
| msgstr "viršus" | ||||
|  | ||||
| #: ../src/ui/theme.c:238 | ||||
| #: ../src/ui/theme.c:237 | ||||
| msgid "bottom" | ||||
| msgstr "apačia" | ||||
|  | ||||
| #: ../src/ui/theme.c:240 | ||||
| #: ../src/ui/theme.c:239 | ||||
| msgid "left" | ||||
| msgstr "kairė" | ||||
|  | ||||
| #: ../src/ui/theme.c:242 | ||||
| #: ../src/ui/theme.c:241 | ||||
| msgid "right" | ||||
| msgstr "dešinė" | ||||
|  | ||||
| #: ../src/ui/theme.c:270 | ||||
| #: ../src/ui/theme.c:269 | ||||
| #, c-format | ||||
| msgid "frame geometry does not specify \"%s\" dimension" | ||||
| msgstr "rėmelio aprašyme nenurodytas „%s“ matmuo" | ||||
|  | ||||
| #: ../src/ui/theme.c:289 | ||||
| #: ../src/ui/theme.c:288 | ||||
| #, c-format | ||||
| msgid "frame geometry does not specify dimension \"%s\" for border \"%s\"" | ||||
| msgstr "rėmelio aprašyme nenurodytas paraštės „%2$s“ „%1$s“ matmuo" | ||||
|  | ||||
| #: ../src/ui/theme.c:326 | ||||
| #: ../src/ui/theme.c:325 | ||||
| #, c-format | ||||
| msgid "Button aspect ratio %g is not reasonable" | ||||
| msgstr "Mygtuko dydžio santykis %g yra nenuosaikus" | ||||
|  | ||||
| #: ../src/ui/theme.c:338 | ||||
| #: ../src/ui/theme.c:337 | ||||
| #, c-format | ||||
| msgid "Frame geometry does not specify size of buttons" | ||||
| msgstr "Rėmelio aprašyme nenurodytas mygtukų dydis" | ||||
|  | ||||
| #: ../src/ui/theme.c:1051 | ||||
| #: ../src/ui/theme.c:1050 | ||||
| #, c-format | ||||
| msgid "Gradients should have at least two colors" | ||||
| msgstr "Aprašant persiliejančias spalvas reikia nurodyti bent dvi spalvas" | ||||
|  | ||||
| #: ../src/ui/theme.c:1203 | ||||
| #: ../src/ui/theme.c:1202 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK custom color specification must have color name and fallback in " | ||||
| @@ -972,7 +965,7 @@ msgstr "" | ||||
| "uždarančius laužtinius skliaustus, pvz.: gtk:custom(foo,bar); nepavyko " | ||||
| "perskaityti „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1219 | ||||
| #: ../src/ui/theme.c:1218 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-" | ||||
| @@ -981,7 +974,7 @@ msgstr "" | ||||
| "Netinkamas simbolis „%c“ gtk:custom parametre color_name, leidžiama tik A-Za-" | ||||
| "z0-9_" | ||||
|  | ||||
| #: ../src/ui/theme.c:1233 | ||||
| #: ../src/ui/theme.c:1232 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not " | ||||
| @@ -990,7 +983,7 @@ msgstr "" | ||||
| "Gtk:custom formatas yra „gtk:custom(color_name,fallback)“, „%s“ neatitinka " | ||||
| "šio formato" | ||||
|  | ||||
| #: ../src/ui/theme.c:1278 | ||||
| #: ../src/ui/theme.c:1277 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] " | ||||
| @@ -1000,7 +993,7 @@ msgstr "" | ||||
| "skliaustų, pvz.: gtk:fg[NORMAL], kur NORMAL yra būsena; nepavyko apdoroti " | ||||
| "\"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1292 | ||||
| #: ../src/ui/theme.c:1291 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK color specification must have a close bracket after the state, e.g. gtk:" | ||||
| @@ -1010,17 +1003,17 @@ msgstr "" | ||||
| "skliaustus, pvz.: gtk:fg[NORMAL], kur NORMAL yra būsena; nepavyko apdoroti " | ||||
| "\"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1303 | ||||
| #: ../src/ui/theme.c:1302 | ||||
| #, c-format | ||||
| msgid "Did not understand state \"%s\" in color specification" | ||||
| msgstr "Nesuprantama spalvų aprašymo būsena \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1316 | ||||
| #: ../src/ui/theme.c:1315 | ||||
| #, c-format | ||||
| msgid "Did not understand color component \"%s\" in color specification" | ||||
| msgstr "Spalvų aprašyme nurodytas nesuprantamas spalvos komponentas \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1345 | ||||
| #: ../src/ui/theme.c:1344 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the " | ||||
| @@ -1029,19 +1022,19 @@ msgstr "" | ||||
| "Išplaukimo formatas yra \"blend/bg_color/fg_color/alpha\", \"%s\" neatitinka " | ||||
| "šio formato" | ||||
|  | ||||
| #: ../src/ui/theme.c:1356 | ||||
| #: ../src/ui/theme.c:1355 | ||||
| #, c-format | ||||
| msgid "Could not parse alpha value \"%s\" in blended color" | ||||
| msgstr "" | ||||
| "Nepavyko aprodoti skaidrumo reikšmės \"%s\" priskirtos išplaukiančiai spalva" | ||||
|  | ||||
| #: ../src/ui/theme.c:1366 | ||||
| #: ../src/ui/theme.c:1365 | ||||
| #, c-format | ||||
| msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0" | ||||
| msgstr "" | ||||
| "Skaidrumo reikšmė \"%s\" tarp išplaukiančios spalvos yra ne tarp 0.0 ir 1.0" | ||||
|  | ||||
| #: ../src/ui/theme.c:1413 | ||||
| #: ../src/ui/theme.c:1412 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format" | ||||
| @@ -1049,27 +1042,27 @@ msgstr "" | ||||
| "Šešėlio formatas yra \"shade/base_color/factor\", \"%s\" neatitinka šio " | ||||
| "formato" | ||||
|  | ||||
| #: ../src/ui/theme.c:1424 | ||||
| #: ../src/ui/theme.c:1423 | ||||
| #, c-format | ||||
| msgid "Could not parse shade factor \"%s\" in shaded color" | ||||
| msgstr "Nepavyko apdoroti šešėlinės spalvos šešėlių rodiklio \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1434 | ||||
| #: ../src/ui/theme.c:1433 | ||||
| #, c-format | ||||
| msgid "Shade factor \"%s\" in shaded color is negative" | ||||
| msgstr "Šešėlio rodiklis \"%s\" tarp šešėlinės spalvos yra neigiamas" | ||||
|  | ||||
| #: ../src/ui/theme.c:1463 | ||||
| #: ../src/ui/theme.c:1462 | ||||
| #, c-format | ||||
| msgid "Could not parse color \"%s\"" | ||||
| msgstr "Nepavyko apdoroti spalvos \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1780 | ||||
| #: ../src/ui/theme.c:1779 | ||||
| #, c-format | ||||
| msgid "Coordinate expression contains character '%s' which is not allowed" | ||||
| msgstr "Koordinačių išraiška turi neleistiną simbolį '%s'" | ||||
|  | ||||
| #: ../src/ui/theme.c:1807 | ||||
| #: ../src/ui/theme.c:1806 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression contains floating point number '%s' which could not be " | ||||
| @@ -1078,13 +1071,13 @@ msgstr "" | ||||
| "Koordinačių išraiška turi skaičių su slankiu kableliu '%s', kuris negali " | ||||
| "būti apdorotas" | ||||
|  | ||||
| #: ../src/ui/theme.c:1821 | ||||
| #: ../src/ui/theme.c:1820 | ||||
| #, c-format | ||||
| msgid "Coordinate expression contains integer '%s' which could not be parsed" | ||||
| msgstr "" | ||||
| "Koordinačių išraiška turi sveiką skaičių '%s', kuris negali būti apdorotas" | ||||
|  | ||||
| #: ../src/ui/theme.c:1942 | ||||
| #: ../src/ui/theme.c:1941 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression contained unknown operator at the start of this text: " | ||||
| @@ -1093,17 +1086,17 @@ msgstr "" | ||||
| "Koordinačių išraiškoje nurodytas nežinomas operatorius šio teksto pradžioje: " | ||||
| "\"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1999 | ||||
| #: ../src/ui/theme.c:1998 | ||||
| #, c-format | ||||
| msgid "Coordinate expression was empty or not understood" | ||||
| msgstr "Koordinačių išraiška tuščia arba nesuprantama" | ||||
|  | ||||
| #: ../src/ui/theme.c:2112 ../src/ui/theme.c:2122 ../src/ui/theme.c:2156 | ||||
| #: ../src/ui/theme.c:2111 ../src/ui/theme.c:2121 ../src/ui/theme.c:2155 | ||||
| #, c-format | ||||
| msgid "Coordinate expression results in division by zero" | ||||
| msgstr "Koordinačių išraiška sukelia dalybą iš nulio" | ||||
|  | ||||
| #: ../src/ui/theme.c:2164 | ||||
| #: ../src/ui/theme.c:2163 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression tries to use mod operator on a floating-point number" | ||||
| @@ -1111,7 +1104,7 @@ msgstr "" | ||||
| "Koordinačių išraiška bando panaudoti liekanos operatorių (mod) slankaus " | ||||
| "kablelio skaičiui" | ||||
|  | ||||
| #: ../src/ui/theme.c:2220 | ||||
| #: ../src/ui/theme.c:2219 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression has an operator \"%s\" where an operand was expected" | ||||
| @@ -1119,17 +1112,17 @@ msgstr "" | ||||
| "Koordinačių išraiškoje įvestas operatorius \"%s\" ten, kur turi būti vedamas " | ||||
| "operandas" | ||||
|  | ||||
| #: ../src/ui/theme.c:2229 | ||||
| #: ../src/ui/theme.c:2228 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had an operand where an operator was expected" | ||||
| msgstr "Koordinačių išraiškoje operandas įrašytas operatoriaus vietoje" | ||||
|  | ||||
| #: ../src/ui/theme.c:2237 | ||||
| #: ../src/ui/theme.c:2236 | ||||
| #, c-format | ||||
| msgid "Coordinate expression ended with an operator instead of an operand" | ||||
| msgstr "Koordinačių išraiška pasibaigė operatoriumi, o ne operandu" | ||||
|  | ||||
| #: ../src/ui/theme.c:2247 | ||||
| #: ../src/ui/theme.c:2246 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression has operator \"%c\" following operator \"%c\" with no " | ||||
| @@ -1138,41 +1131,41 @@ msgstr "" | ||||
| "Koordinačių išraiškoje operatorius \"%c\" eina po operatoriaus \"%c\" be " | ||||
| "tarpinio operando" | ||||
|  | ||||
| #: ../src/ui/theme.c:2398 ../src/ui/theme.c:2443 | ||||
| #: ../src/ui/theme.c:2397 ../src/ui/theme.c:2442 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had unknown variable or constant \"%s\"" | ||||
| msgstr "Koordinačių išraiška saugo nežinomą kintamąjį arba konstantą \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:2497 | ||||
| #: ../src/ui/theme.c:2496 | ||||
| #, c-format | ||||
| msgid "Coordinate expression parser overflowed its buffer." | ||||
| msgstr "Koordinačių išraiškų skaitytuvas perpildė buferį." | ||||
|  | ||||
| #: ../src/ui/theme.c:2526 | ||||
| #: ../src/ui/theme.c:2525 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had a close parenthesis with no open parenthesis" | ||||
| msgstr "" | ||||
| "Koordinačių išraiškoje įvesti uždarantys skliaustai, nors atidarančių " | ||||
| "skliaustų nerasta" | ||||
|  | ||||
| #: ../src/ui/theme.c:2590 | ||||
| #: ../src/ui/theme.c:2589 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had an open parenthesis with no close parenthesis" | ||||
| msgstr "" | ||||
| "Koordinačių išraiškoje po atidarančių skliaustų neįvesti uždarantys " | ||||
| "skliaustai" | ||||
|  | ||||
| #: ../src/ui/theme.c:2601 | ||||
| #: ../src/ui/theme.c:2600 | ||||
| #, c-format | ||||
| msgid "Coordinate expression doesn't seem to have any operators or operands" | ||||
| msgstr "Koordinačių išraiška neturi jokių operatorių ar operandų" | ||||
|  | ||||
| #: ../src/ui/theme.c:2814 ../src/ui/theme.c:2834 ../src/ui/theme.c:2854 | ||||
| #: ../src/ui/theme.c:2813 ../src/ui/theme.c:2833 ../src/ui/theme.c:2853 | ||||
| #, c-format | ||||
| msgid "Theme contained an expression that resulted in an error: %s\n" | ||||
| msgstr "Temoje esanti išraiška sukėlė klaidą: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:4500 | ||||
| #: ../src/ui/theme.c:4499 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be " | ||||
| @@ -1181,25 +1174,25 @@ msgstr "" | ||||
| "Šiam rėmelio stiliui turi būti nurodytas <button function=\"%s\" state=\"%s" | ||||
| "\" draw_ops=\"kažkokswhatever\"/> požymis" | ||||
|  | ||||
| #: ../src/ui/theme.c:5011 ../src/ui/theme.c:5036 | ||||
| #: ../src/ui/theme.c:5010 ../src/ui/theme.c:5035 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>" | ||||
| msgstr "" | ||||
| "Trūksta <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"kažkoks\"/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5082 | ||||
| #: ../src/ui/theme.c:5083 | ||||
| #, c-format | ||||
| msgid "Failed to load theme \"%s\": %s\n" | ||||
| msgstr "Nepavyko paleisti temos \"%s\": %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232 | ||||
| #: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246 | ||||
| #: ../src/ui/theme.c:5219 ../src/ui/theme.c:5226 ../src/ui/theme.c:5233 | ||||
| #: ../src/ui/theme.c:5240 ../src/ui/theme.c:5247 | ||||
| #, c-format | ||||
| msgid "No <%s> set for theme \"%s\"" | ||||
| msgstr "Temoje \"%2$s\" trūksta <%1$s> nustatymų" | ||||
|  | ||||
| #: ../src/ui/theme.c:5254 | ||||
| #: ../src/ui/theme.c:5255 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "No frame style set for window type \"%s\" in theme \"%s\", add a <window " | ||||
| @@ -1208,7 +1201,7 @@ msgstr "" | ||||
| "Rėmelio stilius nenurodytas lango tipui \"%s\" temoje \"%s\", pridėkite " | ||||
| "<window type=\"%s\" style_set=\"kažkoks\"/> elementą" | ||||
|  | ||||
| #: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786 | ||||
| #: ../src/ui/theme.c:5662 ../src/ui/theme.c:5724 ../src/ui/theme.c:5787 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "User-defined constants must begin with a capital letter; \"%s\" does not" | ||||
| @@ -1216,7 +1209,7 @@ msgstr "" | ||||
| "Naudotojo nustatytos konstantos turi prasidėti didžiąja raide; „%s“ nėra " | ||||
| "didžioji" | ||||
|  | ||||
| #: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794 | ||||
| #: ../src/ui/theme.c:5670 ../src/ui/theme.c:5732 ../src/ui/theme.c:5795 | ||||
| #, c-format | ||||
| msgid "Constant \"%s\" has already been defined" | ||||
| msgstr "Konstanta „%s“ jau aprašyta" | ||||
| @@ -1600,8 +1593,210 @@ msgstr "Elemente <%s> tekstas negalimas" | ||||
| msgid "<%s> specified twice for this theme" | ||||
| msgstr "<%s> elementas temos aprašyme nurodytas du kartus" | ||||
|  | ||||
| #: ../src/ui/theme-parser.c:4336 | ||||
| #: ../src/ui/theme-parser.c:4334 | ||||
| #, c-format | ||||
| msgid "Failed to find a valid file for theme %s\n" | ||||
| msgstr "Nepavyko rasti tinkamo temos %s failo\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:99 | ||||
| msgid "_Windows" | ||||
| msgstr "_Langai" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:100 | ||||
| msgid "_Dialog" | ||||
| msgstr "_Dialogas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:101 | ||||
| msgid "_Modal dialog" | ||||
| msgstr "_Modalinis dialogas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:102 | ||||
| msgid "_Utility" | ||||
| msgstr "_Įrankis" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:103 | ||||
| msgid "_Splashscreen" | ||||
| msgstr "_Pristatymo langas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:104 | ||||
| msgid "_Top dock" | ||||
| msgstr "_Viršutinis dokas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:105 | ||||
| msgid "_Bottom dock" | ||||
| msgstr "_Apatinis dokas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:106 | ||||
| msgid "_Left dock" | ||||
| msgstr "_Kairysis dokas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:107 | ||||
| msgid "_Right dock" | ||||
| msgstr "_Kairysis dokas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:108 | ||||
| msgid "_All docks" | ||||
| msgstr "Visi dok_ai" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:109 | ||||
| msgid "Des_ktop" | ||||
| msgstr "Dar_bastalis" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:115 | ||||
| msgid "Open another one of these windows" | ||||
| msgstr "Atverti dar vieną tokį langą" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:117 | ||||
| msgid "This is a demo button with an 'open' icon" | ||||
| msgstr "Tai yra bandomasis mygtukas su „atverti“ piktograma" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:119 | ||||
| msgid "This is a demo button with a 'quit' icon" | ||||
| msgstr "Tai yra bandomasis mygtukas su „uždaryti“ piktograma" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:248 | ||||
| msgid "This is a sample message in a sample dialog" | ||||
| msgstr "Tai yra pavydžio pranešimas pavyzdžio dialoge" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:328 | ||||
| #, c-format | ||||
| msgid "Fake menu item %d\n" | ||||
| msgstr "Netikras meniu punktas %d\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:363 | ||||
| msgid "Border-only window" | ||||
| msgstr "Tik rėmelį turintis langas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:365 | ||||
| msgid "Bar" | ||||
| msgstr "Juosta" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:382 | ||||
| msgid "Normal Application Window" | ||||
| msgstr "Normalus programos langas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:386 | ||||
| msgid "Dialog Box" | ||||
| msgstr "Dialogo langas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:390 | ||||
| msgid "Modal Dialog Box" | ||||
| msgstr "Modalinis dialogo langas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:394 | ||||
| msgid "Utility Palette" | ||||
| msgstr "Įrankių paletė" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:398 | ||||
| msgid "Torn-off Menu" | ||||
| msgstr "Atkabinamas meniu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:402 | ||||
| msgid "Border" | ||||
| msgstr "Paraštė" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:406 | ||||
| msgid "Attached Modal Dialog" | ||||
| msgstr "Prikabintas modalinis dialogas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:737 | ||||
| #, c-format | ||||
| msgid "Button layout test %d" | ||||
| msgstr "Mygtukų išdėstymo testas %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:766 | ||||
| #, c-format | ||||
| msgid "%g milliseconds to draw one window frame" | ||||
| msgstr "vienam lango kadrui išvesti yra skirta %g milisekundžių" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:811 | ||||
| #, c-format | ||||
| msgid "Usage: metacity-theme-viewer [THEMENAME]\n" | ||||
| msgstr "Panaudojimas: metacity-theme-viewer [TEMOS PAVADINIMAS]\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:818 | ||||
| #, c-format | ||||
| msgid "Error loading theme: %s\n" | ||||
| msgstr "Klaida įkeliant temą: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:824 | ||||
| #, c-format | ||||
| msgid "Loaded theme \"%s\" in %g seconds\n" | ||||
| msgstr "Tema „%s“ įkelta per %g sekundžių\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:869 | ||||
| msgid "Normal Title Font" | ||||
| msgstr "Normalus antraštės šriftas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:875 | ||||
| msgid "Small Title Font" | ||||
| msgstr "Smulkus antraštės šriftas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:881 | ||||
| msgid "Large Title Font" | ||||
| msgstr "Didelis antraštės šriftas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:886 | ||||
| msgid "Button Layouts" | ||||
| msgstr "Mygtukų išdėstymai" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:891 | ||||
| msgid "Benchmark" | ||||
| msgstr "Greičio testas" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:947 | ||||
| msgid "Window Title Goes Here" | ||||
| msgstr "Čia rodomo lango antraštė" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1053 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g " | ||||
| "seconds wall clock time including X server resources (%g milliseconds per " | ||||
| "frame)\n" | ||||
| msgstr "" | ||||
| "%d kadrai buvo išvesti per %g klientines sekundes (%g milisekunčių kadrui) " | ||||
| "ir per %g bendrinio laiko sekundes įskaitant X serverio resursus (%g " | ||||
| "milisekundžių kadrui)\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1273 | ||||
| msgid "position expression test returned TRUE but set error" | ||||
| msgstr "" | ||||
| "padėties išraiškos testas grąžino teigiamą reikšmę, bet kartu nustatė " | ||||
| "klaidos pranešimą" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1275 | ||||
| msgid "position expression test returned FALSE but didn't set error" | ||||
| msgstr "" | ||||
| "padėties išraiškos testas grąžino neigiamą reikšmę, bet nenustatė klaidos " | ||||
| "pranešimo" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1279 | ||||
| msgid "Error was expected but none given" | ||||
| msgstr "Tikėtasi sulaukti klaidos pranešimo, tačiau nieko nesulaukta" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1281 | ||||
| #, c-format | ||||
| msgid "Error %d was expected but %d given" | ||||
| msgstr "Tikėtasi klaidos %d, tačiau gauta %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1287 | ||||
| #, c-format | ||||
| msgid "Error not expected but one was returned: %s" | ||||
| msgstr "Klaidos nesitikėta, tačiau grąžinta klaida: %s" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1291 | ||||
| #, c-format | ||||
| msgid "x value was %d, %d was expected" | ||||
| msgstr "x reikšmė buvo %d, tikėtasi %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1294 | ||||
| #, c-format | ||||
| msgid "y value was %d, %d was expected" | ||||
| msgstr "y reikšmė buvo %d, tikėtasi %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1359 | ||||
| #, c-format | ||||
| msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n" | ||||
| msgstr "" | ||||
| "Koordinačių %d išraiška apdorota per %g sekundžių (%g sekundžių vidurkis)\n" | ||||
|   | ||||
							
								
								
									
										309
									
								
								po/nb.po
									
									
									
									
									
								
							
							
						
						
									
										309
									
								
								po/nb.po
									
									
									
									
									
								
							| @@ -6,8 +6,8 @@ msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: mutter 3.9.x\n" | ||||
| "Report-Msgid-Bugs-To: \n" | ||||
| "POT-Creation-Date: 2013-08-22 16:11+0200\n" | ||||
| "PO-Revision-Date: 2013-08-22 16:12+0200\n" | ||||
| "POT-Creation-Date: 2013-08-08 22:14+0200\n" | ||||
| "PO-Revision-Date: 2013-05-28 09:48+0200\n" | ||||
| "Last-Translator: Kjartan Maraas <kmaraas@gnome.org>\n" | ||||
| "Language-Team: Norwegian bokmål <i18n-no@lister.ping.uio.no>\n" | ||||
| "Language: \n" | ||||
| @@ -205,7 +205,7 @@ msgstr "Visning delt til høyre" | ||||
|  | ||||
| #. This probably means that a non-WM compositor like xcompmgr is running; | ||||
| #. * we have no way to get it to exit | ||||
| #: ../src/compositor/compositor.c:596 | ||||
| #: ../src/compositor/compositor.c:589 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Another compositing manager is already running on screen %i on display \"%s" | ||||
| @@ -260,7 +260,7 @@ msgstr "Mangler utvidelsen %s som kreves for komposittfunksjon" | ||||
| msgid "Failed to open X Window System display '%s'\n" | ||||
| msgstr "Feil under åpning av X Window System skjerm «%s»\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1136 | ||||
| #: ../src/core/keybindings.c:1138 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Some other program is already using the key %s with modifiers %x as a " | ||||
| @@ -269,7 +269,7 @@ msgstr "" | ||||
| "Et annet program bruker allerede nøkkelen %s med modifikatorer %x som " | ||||
| "binding\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1333 | ||||
| #: ../src/core/keybindings.c:1335 | ||||
| #, c-format | ||||
| msgid "\"%s\" is not a valid accelerator\n" | ||||
| msgstr "«%s» er ikke en gyldig aksellerator\n" | ||||
| @@ -311,19 +311,6 @@ msgstr "" | ||||
| "Kunne ikke finne et tema! Sjekk at %s eksisterer og inneholder de vanlige " | ||||
| "temaene.\n" | ||||
|  | ||||
| #: ../src/core/monitor.c:702 | ||||
| msgid "Built-in display" | ||||
| msgstr "Innebygget skjerm" | ||||
|  | ||||
| #. TRANSLATORS: this is a monitor name (in case we don't know | ||||
| #. the vendor), it's Unknown followed by a size in inches, | ||||
| #. like 'Unknown 15"' | ||||
| #. | ||||
| #: ../src/core/monitor.c:730 | ||||
| #, c-format | ||||
| msgid "Unknown %s" | ||||
| msgstr "Ukjent %s" | ||||
|  | ||||
| #: ../src/core/mutter.c:40 | ||||
| #, c-format | ||||
| msgid "" | ||||
| @@ -382,12 +369,12 @@ msgstr "" | ||||
| msgid "Workspace %d" | ||||
| msgstr "Arbeidsområde %d" | ||||
|  | ||||
| #: ../src/core/screen.c:537 | ||||
| #: ../src/core/screen.c:691 | ||||
| #, c-format | ||||
| msgid "Screen %d on display '%s' is invalid\n" | ||||
| msgstr "Skjerm %d på display «%s» er ugyldig\n" | ||||
|  | ||||
| #: ../src/core/screen.c:553 | ||||
| #: ../src/core/screen.c:707 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Screen %d on display \"%s\" already has a window manager; try using the --" | ||||
| @@ -396,19 +383,19 @@ msgstr "" | ||||
| "Skjerm %d på display «%s» har allerede en vindushåndterer; prøv å bruke " | ||||
| "flagget --replace for å erstatte aktiv vindushåndterer.\n" | ||||
|  | ||||
| #: ../src/core/screen.c:580 | ||||
| #: ../src/core/screen.c:734 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not acquire window manager selection on screen %d display \"%s\"\n" | ||||
| msgstr "" | ||||
| "Kunne ikke hente utvalg fra vinduhåndterer på skjerm %d, display «%s»\n" | ||||
|  | ||||
| #: ../src/core/screen.c:658 | ||||
| #: ../src/core/screen.c:812 | ||||
| #, c-format | ||||
| msgid "Screen %d on display \"%s\" already has a window manager\n" | ||||
| msgstr "Skjerm %d på display «%s» har allerede en vinduhåndterer\n" | ||||
|  | ||||
| #: ../src/core/screen.c:850 | ||||
| #: ../src/core/screen.c:998 | ||||
| #, c-format | ||||
| msgid "Could not release screen %d on display \"%s\"\n" | ||||
| msgstr "Kunne ikke slippe skjerm %d på display «%s»\n" | ||||
| @@ -483,7 +470,8 @@ msgstr "Feil under fdopen() av loggfil %s: %s\n" | ||||
| msgid "Opened log file %s\n" | ||||
| msgstr "Åpnet loggfil %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:119 | ||||
| #: ../src/core/util.c:119 ../src/tools/mutter-message.c:149 | ||||
| #, c-format | ||||
| msgid "Mutter was compiled without support for verbose mode\n" | ||||
| msgstr "Mutter er kompilert uten støtte for «verbose» modus\n" | ||||
|  | ||||
| @@ -491,20 +479,20 @@ msgstr "Mutter er kompilert uten støtte for «verbose» modus\n" | ||||
| msgid "Window manager: " | ||||
| msgstr "Vindushåndterer: " | ||||
|  | ||||
| #: ../src/core/util.c:414 | ||||
| #: ../src/core/util.c:412 | ||||
| msgid "Bug in window manager: " | ||||
| msgstr "Feil i vindushåndterer: " | ||||
|  | ||||
| #: ../src/core/util.c:445 | ||||
| #: ../src/core/util.c:443 | ||||
| msgid "Window manager warning: " | ||||
| msgstr "Advarsel fra vindushåndterer: " | ||||
|  | ||||
| #: ../src/core/util.c:473 | ||||
| #: ../src/core/util.c:471 | ||||
| msgid "Window manager error: " | ||||
| msgstr "Feil i vindushåndterer: " | ||||
|  | ||||
| #. first time through | ||||
| #: ../src/core/window.c:7533 | ||||
| #: ../src/core/window.c:7513 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER " | ||||
| @@ -520,7 +508,7 @@ msgstr "" | ||||
| #. * MWM but not WM_NORMAL_HINTS are basically broken. We complain | ||||
| #. * about these apps but make them work. | ||||
| #. | ||||
| #: ../src/core/window.c:8257 | ||||
| #: ../src/core/window.c:8237 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets an MWM hint indicating it isn't resizable, but sets min size " | ||||
| @@ -530,22 +518,22 @@ msgstr "" | ||||
| "men setter minste størrelse %d x %d og maks størrelse %d x %d; dette virker " | ||||
| "ikke fornuftig.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:347 | ||||
| #: ../src/core/window-props.c:318 | ||||
| #, c-format | ||||
| msgid "Application set a bogus _NET_WM_PID %lu\n" | ||||
| msgstr "Programmet satte en feil _NET_WM_PID %lu\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:463 | ||||
| #: ../src/core/window-props.c:434 | ||||
| #, c-format | ||||
| msgid "%s (on %s)" | ||||
| msgstr "%s (på %s)" | ||||
|  | ||||
| #: ../src/core/window-props.c:1546 | ||||
| #: ../src/core/window-props.c:1517 | ||||
| #, c-format | ||||
| msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n" | ||||
| msgstr "Ugyldig WM_TRANSIENT_FOR vindu 0x%lx oppgitt for %s.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:1557 | ||||
| #: ../src/core/window-props.c:1528 | ||||
| #, c-format | ||||
| msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n" | ||||
| msgstr "WM_TRANSIENT_FOR vindu 0x%lx for %s ville skapt en løkke.\n" | ||||
| @@ -708,104 +696,109 @@ msgstr "Fjern vindu fra tabulatordialog" | ||||
| msgid "Cancel tab popup" | ||||
| msgstr "Avbryt tabulatordialog" | ||||
|  | ||||
| #: ../src/tools/mutter-message.c:123 | ||||
| #, c-format | ||||
| msgid "Usage: %s\n" | ||||
| msgstr " Bruk: %s\n" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:67 | ||||
| #: ../src/ui/menu.c:69 | ||||
| msgid "Mi_nimize" | ||||
| msgstr "Mi_nimer" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:69 | ||||
| #: ../src/ui/menu.c:71 | ||||
| msgid "Ma_ximize" | ||||
| msgstr "Ma_ksimer" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:71 | ||||
| #: ../src/ui/menu.c:73 | ||||
| msgid "Unma_ximize" | ||||
| msgstr "G_jenopprett" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:73 | ||||
| #: ../src/ui/menu.c:75 | ||||
| msgid "Roll _Up" | ||||
| msgstr "Rull _opp" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:75 | ||||
| #: ../src/ui/menu.c:77 | ||||
| msgid "_Unroll" | ||||
| msgstr "R_ull ned" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:77 | ||||
| #: ../src/ui/menu.c:79 | ||||
| msgid "_Move" | ||||
| msgstr "_Flytt" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:79 | ||||
| #: ../src/ui/menu.c:81 | ||||
| msgid "_Resize" | ||||
| msgstr "End_re størrelse" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:81 | ||||
| #: ../src/ui/menu.c:83 | ||||
| msgid "Move Titlebar On_screen" | ||||
| msgstr "Flytt tittellinje på _skjermen" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:84 ../src/ui/menu.c:86 | ||||
| #: ../src/ui/menu.c:86 ../src/ui/menu.c:88 | ||||
| msgid "Always on _Top" | ||||
| msgstr "All_tid øverst" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:88 | ||||
| #: ../src/ui/menu.c:90 | ||||
| msgid "_Always on Visible Workspace" | ||||
| msgstr "_Alltid på synlig arbeidsområde" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:90 | ||||
| #: ../src/ui/menu.c:92 | ||||
| msgid "_Only on This Workspace" | ||||
| msgstr "K_un på dette arbeidsområdet" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:92 | ||||
| #: ../src/ui/menu.c:94 | ||||
| msgid "Move to Workspace _Left" | ||||
| msgstr "Flytt til arbeidsområdet ti_l venstre" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:94 | ||||
| #: ../src/ui/menu.c:96 | ||||
| msgid "Move to Workspace R_ight" | ||||
| msgstr "Flytt til a_rbeidsområdet til høyre" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:96 | ||||
| #: ../src/ui/menu.c:98 | ||||
| msgid "Move to Workspace _Up" | ||||
| msgstr "Flytt til arbeidsområdet _over" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:98 | ||||
| #: ../src/ui/menu.c:100 | ||||
| msgid "Move to Workspace _Down" | ||||
| msgstr "Flytt til arbeidsområdet ne_denfor" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:102 | ||||
| #: ../src/ui/menu.c:104 | ||||
| msgid "_Close" | ||||
| msgstr "_Lukk" | ||||
|  | ||||
| #: ../src/ui/menu.c:202 | ||||
| #: ../src/ui/menu.c:204 | ||||
| #, c-format | ||||
| msgid "Workspace %d%n" | ||||
| msgstr "Arbeidsområde %d%n" | ||||
|  | ||||
| #: ../src/ui/menu.c:212 | ||||
| #: ../src/ui/menu.c:214 | ||||
| #, c-format | ||||
| msgid "Workspace 1_0" | ||||
| msgstr "Arbeidsområde 1_0" | ||||
|  | ||||
| #: ../src/ui/menu.c:214 | ||||
| #: ../src/ui/menu.c:216 | ||||
| #, c-format | ||||
| msgid "Workspace %s%d" | ||||
| msgstr "Arbeidsområde %s%d" | ||||
|  | ||||
| #: ../src/ui/menu.c:384 | ||||
| #: ../src/ui/menu.c:397 | ||||
| msgid "Move to Another _Workspace" | ||||
| msgstr "Flytt til et annet ar_beidsområde" | ||||
|  | ||||
| @@ -1158,18 +1151,18 @@ msgid "" | ||||
| msgstr "" | ||||
| "Mangler <frame state=«%s» resize=«%s» focus=«%s» stil=«ett-eller-annet»/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5082 | ||||
| #: ../src/ui/theme.c:5084 | ||||
| #, c-format | ||||
| msgid "Failed to load theme \"%s\": %s\n" | ||||
| msgstr "Klarte ikke å laste tema «%s»: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232 | ||||
| #: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246 | ||||
| #: ../src/ui/theme.c:5220 ../src/ui/theme.c:5227 ../src/ui/theme.c:5234 | ||||
| #: ../src/ui/theme.c:5241 ../src/ui/theme.c:5248 | ||||
| #, c-format | ||||
| msgid "No <%s> set for theme \"%s\"" | ||||
| msgstr "<%s> er ikke satt for tema «%s»" | ||||
|  | ||||
| #: ../src/ui/theme.c:5254 | ||||
| #: ../src/ui/theme.c:5256 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "No frame style set for window type \"%s\" in theme \"%s\", add a <window " | ||||
| @@ -1178,14 +1171,14 @@ msgstr "" | ||||
| "Ingen rammestil satt for vindutype «%s» i tema «%s», legg til et <window " | ||||
| "type=«%s» style_set=«ett-eller-annet»/>-element" | ||||
|  | ||||
| #: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786 | ||||
| #: ../src/ui/theme.c:5663 ../src/ui/theme.c:5725 ../src/ui/theme.c:5788 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "User-defined constants must begin with a capital letter; \"%s\" does not" | ||||
| msgstr "" | ||||
| "Brukerdefinerte konstanter må begynne med stor bokstav; «%s» gjør ikke det" | ||||
|  | ||||
| #: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794 | ||||
| #: ../src/ui/theme.c:5671 ../src/ui/theme.c:5733 ../src/ui/theme.c:5796 | ||||
| #, c-format | ||||
| msgid "Constant \"%s\" has already been defined" | ||||
| msgstr "Konstant «%s» er allerede definert" | ||||
| @@ -1570,3 +1563,201 @@ msgstr "<%s> spesifisert to ganger for dette temaet" | ||||
| #, c-format | ||||
| msgid "Failed to find a valid file for theme %s\n" | ||||
| msgstr "Fant ikke en gyldig fil for tema %s\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:99 | ||||
| msgid "_Windows" | ||||
| msgstr "_Vinduer" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:100 | ||||
| msgid "_Dialog" | ||||
| msgstr "_Dialog" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:101 | ||||
| msgid "_Modal dialog" | ||||
| msgstr "_Modal dialog" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:102 | ||||
| msgid "_Utility" | ||||
| msgstr "_Verktøy" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:103 | ||||
| msgid "_Splashscreen" | ||||
| msgstr "Opp_startskjerm" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:104 | ||||
| msgid "_Top dock" | ||||
| msgstr "_Toppdokk" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:105 | ||||
| msgid "_Bottom dock" | ||||
| msgstr "_Bunndokk" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:106 | ||||
| msgid "_Left dock" | ||||
| msgstr "_Venstre dokk" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:107 | ||||
| msgid "_Right dock" | ||||
| msgstr "Høy_re dokk" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:108 | ||||
| msgid "_All docks" | ||||
| msgstr "_Alle dokker" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:109 | ||||
| msgid "Des_ktop" | ||||
| msgstr "S_krivebord" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:115 | ||||
| msgid "Open another one of these windows" | ||||
| msgstr "Åpne et til av disse vinduene" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:117 | ||||
| msgid "This is a demo button with an 'open' icon" | ||||
| msgstr "Dette er en demoknapp med et «åpne»-ikon" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:119 | ||||
| msgid "This is a demo button with a 'quit' icon" | ||||
| msgstr "Dette er en demoknapp med et «avslutt»-ikon" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:248 | ||||
| msgid "This is a sample message in a sample dialog" | ||||
| msgstr "Dette er en eksempelbeskjed i en eksempeldialog" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:328 | ||||
| #, c-format | ||||
| msgid "Fake menu item %d\n" | ||||
| msgstr "Falsk menyoppføring %d\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:363 | ||||
| msgid "Border-only window" | ||||
| msgstr "Vindu uten innhold" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:365 | ||||
| msgid "Bar" | ||||
| msgstr "Linje" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:382 | ||||
| msgid "Normal Application Window" | ||||
| msgstr "Normalt programvindu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:386 | ||||
| msgid "Dialog Box" | ||||
| msgstr "Dialogboks" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:390 | ||||
| msgid "Modal Dialog Box" | ||||
| msgstr "Modal dialogboks" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:394 | ||||
| msgid "Utility Palette" | ||||
| msgstr "Verktøypalett" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:398 | ||||
| msgid "Torn-off Menu" | ||||
| msgstr "Avrevet meny" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:402 | ||||
| msgid "Border" | ||||
| msgstr "Kant" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:406 | ||||
| msgid "Attached Modal Dialog" | ||||
| msgstr "Festet modal dialog" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:737 | ||||
| #, c-format | ||||
| msgid "Button layout test %d" | ||||
| msgstr "Test av knappeplassering %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:766 | ||||
| #, c-format | ||||
| msgid "%g milliseconds to draw one window frame" | ||||
| msgstr "%g millisekunder for å tegne en vindusramme" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:811 | ||||
| #, c-format | ||||
| msgid "Usage: metacity-theme-viewer [THEMENAME]\n" | ||||
| msgstr "Bruk: metacity-theme-viewer [TEMANAVN]\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:818 | ||||
| #, c-format | ||||
| msgid "Error loading theme: %s\n" | ||||
| msgstr "Feil under lasting av tema: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:824 | ||||
| #, c-format | ||||
| msgid "Loaded theme \"%s\" in %g seconds\n" | ||||
| msgstr "Lastet tema «%s» på %g sekunder\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:869 | ||||
| msgid "Normal Title Font" | ||||
| msgstr "Normal tittelskrift" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:875 | ||||
| msgid "Small Title Font" | ||||
| msgstr "Liten tittelskrift" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:881 | ||||
| msgid "Large Title Font" | ||||
| msgstr "Stor tittelskrift" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:886 | ||||
| msgid "Button Layouts" | ||||
| msgstr "Knappeplasseringer" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:891 | ||||
| msgid "Benchmark" | ||||
| msgstr "Ytelsestest" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:947 | ||||
| msgid "Window Title Goes Here" | ||||
| msgstr "Vindutittel skal her" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1053 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g " | ||||
| "seconds wall clock time including X server resources (%g milliseconds per " | ||||
| "frame)\n" | ||||
| msgstr "" | ||||
| "Tegnet %d rammer på %g sekunder hos klienten (%g millisekunder per ramme) og " | ||||
| "%g sekunder på klokken inklusive ressurser på X-tjener (%g millisekunder per " | ||||
| "ramme)\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1273 | ||||
| msgid "position expression test returned TRUE but set error" | ||||
| msgstr "test av posisjonsuttrykk returnerte TRUE, men satte en feilkode" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1275 | ||||
| msgid "position expression test returned FALSE but didn't set error" | ||||
| msgstr "test av posisjonsuttrykk returnerte FALSE, men satte ikke en feilkode" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1279 | ||||
| msgid "Error was expected but none given" | ||||
| msgstr "Feil var ventet men ingen ble gitt" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1281 | ||||
| #, c-format | ||||
| msgid "Error %d was expected but %d given" | ||||
| msgstr "Feil %d var ventet men %d ble gitt" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1287 | ||||
| #, c-format | ||||
| msgid "Error not expected but one was returned: %s" | ||||
| msgstr "Feil ikke ventet men en ble returnert: %s" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1291 | ||||
| #, c-format | ||||
| msgid "x value was %d, %d was expected" | ||||
| msgstr "x-verdi var %d, %d var ventet" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1294 | ||||
| #, c-format | ||||
| msgid "y value was %d, %d was expected" | ||||
| msgstr "y-verdi var %d, %d var ventet" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1359 | ||||
| #, c-format | ||||
| msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n" | ||||
| msgstr "%d koordinatuttrykk lest på %g sekunder (%g sekunder i snitt)\n" | ||||
|   | ||||
							
								
								
									
										440
									
								
								po/pl.po
									
									
									
									
									
								
							
							
						
						
									
										440
									
								
								po/pl.po
									
									
									
									
									
								
							| @@ -15,8 +15,8 @@ msgid "" | ||||
| msgstr "" | ||||
| "Project-Id-Version: mutter\n" | ||||
| "Report-Msgid-Bugs-To: \n" | ||||
| "POT-Creation-Date: 2013-08-22 01:49+0200\n" | ||||
| "PO-Revision-Date: 2013-08-22 01:50+0200\n" | ||||
| "POT-Creation-Date: 2013-03-02 01:52+0100\n" | ||||
| "PO-Revision-Date: 2013-03-02 01:53+0100\n" | ||||
| "Last-Translator: Piotr Drąg <piotrdrag@gmail.com>\n" | ||||
| "Language-Team: Polish <gnomepl@aviary.pl>\n" | ||||
| "Language: pl\n" | ||||
| @@ -220,7 +220,7 @@ msgstr "Podział widoku po prawej" | ||||
|  | ||||
| #. This probably means that a non-WM compositor like xcompmgr is running; | ||||
| #. * we have no way to get it to exit | ||||
| #: ../src/compositor/compositor.c:596 | ||||
| #: ../src/compositor/compositor.c:507 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Another compositing manager is already running on screen %i on display \"%s" | ||||
| @@ -228,11 +228,11 @@ msgid "" | ||||
| msgstr "" | ||||
| "Inny menedżer składania jest już uruchomiony na podekranie %i ekranu \"%s\"." | ||||
|  | ||||
| #: ../src/compositor/meta-background.c:1076 | ||||
| #: ../src/compositor/meta-background.c:1111 | ||||
| msgid "background texture could not be created from file" | ||||
| msgstr "nie można utworzyć tekstury tła z pliku" | ||||
|  | ||||
| #: ../src/core/bell.c:322 | ||||
| #: ../src/core/bell.c:320 | ||||
| msgid "Bell event" | ||||
| msgstr "Zdarzenie sygnału dźwiękowego" | ||||
|  | ||||
| @@ -264,18 +264,18 @@ msgstr "_Czekaj" | ||||
| msgid "_Force Quit" | ||||
| msgstr "_Zakończ" | ||||
|  | ||||
| #: ../src/core/display.c:421 | ||||
| #: ../src/core/display.c:401 | ||||
| #, c-format | ||||
| msgid "Missing %s extension required for compositing" | ||||
| msgstr "Brak rozszerzenia %s, wymaganego przez składanie" | ||||
|  | ||||
| #: ../src/core/display.c:513 | ||||
| #: ../src/core/display.c:493 | ||||
| #, c-format | ||||
| msgid "Failed to open X Window System display '%s'\n" | ||||
| msgstr "" | ||||
| "Otwarcie połączenia z ekranem \"%s\" systemu X Window się nie powiodło\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1136 | ||||
| #: ../src/core/keybindings.c:929 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Some other program is already using the key %s with modifiers %x as a " | ||||
| @@ -284,41 +284,41 @@ msgstr "" | ||||
| "Skrótu klawiszowego z klawiszem %s i modyfikatorami %x używa już inny " | ||||
| "program\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1333 | ||||
| #: ../src/core/keybindings.c:1129 | ||||
| #, c-format | ||||
| msgid "\"%s\" is not a valid accelerator\n" | ||||
| msgstr "\"%s\" nie jest prawidłowym skrótem\n" | ||||
|  | ||||
| #: ../src/core/main.c:197 | ||||
| #: ../src/core/main.c:196 | ||||
| msgid "Disable connection to session manager" | ||||
| msgstr "Rozłącza połączenie z menedżerem sesji" | ||||
|  | ||||
| #: ../src/core/main.c:203 | ||||
| #: ../src/core/main.c:202 | ||||
| msgid "Replace the running window manager" | ||||
| msgstr "Zastępuje uruchomionego menedżera okien" | ||||
|  | ||||
| #: ../src/core/main.c:209 | ||||
| #: ../src/core/main.c:208 | ||||
| msgid "Specify session management ID" | ||||
| msgstr "Podaje identyfikator zarządzania sesją" | ||||
|  | ||||
| #: ../src/core/main.c:214 | ||||
| #: ../src/core/main.c:213 | ||||
| msgid "X Display to use" | ||||
| msgstr "Używany ekran X" | ||||
|  | ||||
| #: ../src/core/main.c:220 | ||||
| #: ../src/core/main.c:219 | ||||
| msgid "Initialize session from savefile" | ||||
| msgstr "Inicjuje sesję z zapisanego pliku" | ||||
|  | ||||
| #: ../src/core/main.c:226 | ||||
| #: ../src/core/main.c:225 | ||||
| msgid "Make X calls synchronous" | ||||
| msgstr "Synchroniczne wywołania X" | ||||
|  | ||||
| #: ../src/core/main.c:534 | ||||
| #: ../src/core/main.c:533 | ||||
| #, c-format | ||||
| msgid "Failed to scan themes directory: %s\n" | ||||
| msgstr "Przejrzenie katalogu z motywami się nie powiodło: %s\n" | ||||
|  | ||||
| #: ../src/core/main.c:550 | ||||
| #: ../src/core/main.c:549 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not find a theme! Be sure %s exists and contains the usual themes.\n" | ||||
| @@ -326,19 +326,6 @@ msgstr "" | ||||
| "Nie można odnaleźć żadnego motywu. Proszę sprawdzić, czy katalog %s istnieje " | ||||
| "i zawiera standardowe motywy.\n" | ||||
|  | ||||
| #: ../src/core/monitor.c:702 | ||||
| msgid "Built-in display" | ||||
| msgstr "Wbudowany ekran" | ||||
|  | ||||
| #. TRANSLATORS: this is a monitor name (in case we don't know | ||||
| #. the vendor), it's Unknown followed by a size in inches, | ||||
| #. like 'Unknown 15"' | ||||
| #. | ||||
| #: ../src/core/monitor.c:730 | ||||
| #, c-format | ||||
| msgid "Unknown %s" | ||||
| msgstr "Nieznany %s" | ||||
|  | ||||
| #: ../src/core/mutter.c:40 | ||||
| #, c-format | ||||
| msgid "" | ||||
| @@ -363,7 +350,7 @@ msgstr "Wyświetla wersję" | ||||
| msgid "Mutter plugin to use" | ||||
| msgstr "Używana wtyczka programu Mutter" | ||||
|  | ||||
| #: ../src/core/prefs.c:1202 | ||||
| #: ../src/core/prefs.c:1087 | ||||
| msgid "" | ||||
| "Workarounds for broken applications disabled. Some applications may not " | ||||
| "behave properly.\n" | ||||
| @@ -371,14 +358,14 @@ msgstr "" | ||||
| "Obejścia dla błędnie działających programów są wyłączone. Niektóre z nich " | ||||
| "mogą się zachowywać w sposób nieprzewidywalny.\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1277 | ||||
| #: ../src/core/prefs.c:1162 | ||||
| #, c-format | ||||
| msgid "Could not parse font description \"%s\" from GSettings key %s\n" | ||||
| msgstr "" | ||||
| "Nie można przetworzyć opisu czcionki \"%s\", powiązanego z kluczem GSettings " | ||||
| "%s\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1343 | ||||
| #: ../src/core/prefs.c:1228 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for mouse button " | ||||
| @@ -387,7 +374,7 @@ msgstr "" | ||||
| "Wartość \"%s\", odnaleziona w bazie danych konfiguracji nie opisuje " | ||||
| "prawidłowo modyfikatora przycisku myszy\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1909 | ||||
| #: ../src/core/prefs.c:1780 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for keybinding " | ||||
| @@ -396,17 +383,17 @@ msgstr "" | ||||
| "Wartość \"%s\", odnaleziona w bazie danych konfiguracji nie opisuje " | ||||
| "prawidłowo skrótu klawiszowego \"%s\"\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1999 | ||||
| #: ../src/core/prefs.c:1879 | ||||
| #, c-format | ||||
| msgid "Workspace %d" | ||||
| msgstr "Obszar roboczy %d" | ||||
|  | ||||
| #: ../src/core/screen.c:537 | ||||
| #: ../src/core/screen.c:673 | ||||
| #, c-format | ||||
| msgid "Screen %d on display '%s' is invalid\n" | ||||
| msgstr "Podekran %d ekranu \"%s\" jest nieprawidłowy\n" | ||||
|  | ||||
| #: ../src/core/screen.c:553 | ||||
| #: ../src/core/screen.c:689 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Screen %d on display \"%s\" already has a window manager; try using the --" | ||||
| @@ -415,7 +402,7 @@ msgstr "" | ||||
| "Na podekranie %d ekranu \"%s\" działa już menedżer okien. Aby zastąpić " | ||||
| "działającego menedżera okien, proszę spróbować użyć opcji --replace.\n" | ||||
|  | ||||
| #: ../src/core/screen.c:580 | ||||
| #: ../src/core/screen.c:716 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not acquire window manager selection on screen %d display \"%s\"\n" | ||||
| @@ -423,12 +410,12 @@ msgstr "" | ||||
| "Nie można uzyskać zaznaczenia menedżera okien na podekranie %d ekranu \"%s" | ||||
| "\"\n" | ||||
|  | ||||
| #: ../src/core/screen.c:658 | ||||
| #: ../src/core/screen.c:794 | ||||
| #, c-format | ||||
| msgid "Screen %d on display \"%s\" already has a window manager\n" | ||||
| msgstr "Na podekranie %d ekranu \"%s\" działa już menedżer okien\n" | ||||
|  | ||||
| #: ../src/core/screen.c:850 | ||||
| #: ../src/core/screen.c:979 | ||||
| #, c-format | ||||
| msgid "Could not release screen %d on display \"%s\"\n" | ||||
| msgstr "Nie można zwolnić podekranu %d ekranu \"%s\"\n" | ||||
| @@ -490,44 +477,45 @@ msgstr "" | ||||
| "Te okna nie obsługują opcji zapisu aktualnego stanu (\"save current setup" | ||||
| "\"), więc przy następnym zalogowaniu będą musiały zostać uruchomione ręcznie." | ||||
|  | ||||
| #: ../src/core/util.c:84 | ||||
| #: ../src/core/util.c:80 | ||||
| #, c-format | ||||
| msgid "Failed to open debug log: %s\n" | ||||
| msgstr "Otwarcie dziennika z zapisem wykonania się nie powiodło: %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:94 | ||||
| #: ../src/core/util.c:90 | ||||
| #, c-format | ||||
| msgid "Failed to fdopen() log file %s: %s\n" | ||||
| msgstr "Wykonać fdopen() na pliku dziennika %s się nie powiodło: %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:100 | ||||
| #: ../src/core/util.c:96 | ||||
| #, c-format | ||||
| msgid "Opened log file %s\n" | ||||
| msgstr "Otwarty plik dziennika %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:119 | ||||
| #: ../src/core/util.c:115 ../src/tools/mutter-message.c:149 | ||||
| #, c-format | ||||
| msgid "Mutter was compiled without support for verbose mode\n" | ||||
| msgstr "" | ||||
| "Program Mutter został skompilowany bez obsługi trybu z obszerną informacją\n" | ||||
|  | ||||
| #: ../src/core/util.c:264 | ||||
| #: ../src/core/util.c:259 | ||||
| msgid "Window manager: " | ||||
| msgstr "Menedżer okien: " | ||||
|  | ||||
| #: ../src/core/util.c:414 | ||||
| #: ../src/core/util.c:407 | ||||
| msgid "Bug in window manager: " | ||||
| msgstr "Błąd w programie menedżera okien: " | ||||
|  | ||||
| #: ../src/core/util.c:445 | ||||
| #: ../src/core/util.c:438 | ||||
| msgid "Window manager warning: " | ||||
| msgstr "Ostrzeżenie menedżera okien: " | ||||
|  | ||||
| #: ../src/core/util.c:473 | ||||
| #: ../src/core/util.c:466 | ||||
| msgid "Window manager error: " | ||||
| msgstr "Błąd menedżera okien: " | ||||
|  | ||||
| #. first time through | ||||
| #: ../src/core/window.c:7533 | ||||
| #: ../src/core/window.c:7539 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER " | ||||
| @@ -543,7 +531,7 @@ msgstr "" | ||||
| #. * MWM but not WM_NORMAL_HINTS are basically broken. We complain | ||||
| #. * about these apps but make them work. | ||||
| #. | ||||
| #: ../src/core/window.c:8257 | ||||
| #: ../src/core/window.c:8263 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets an MWM hint indicating it isn't resizable, but sets min size " | ||||
| @@ -553,23 +541,23 @@ msgstr "" | ||||
| "niezmienny, lecz jednocześnie ustawia minimalny rozmiar na %d x %d, a " | ||||
| "maksymalny rozmiar na %d x %d. To nie ma żadnego sensu.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:347 | ||||
| #: ../src/core/window-props.c:318 | ||||
| #, c-format | ||||
| msgid "Application set a bogus _NET_WM_PID %lu\n" | ||||
| msgstr "Program ustawił błędną wartość _NET_WM_PID %lu\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:463 | ||||
| #: ../src/core/window-props.c:434 | ||||
| #, c-format | ||||
| msgid "%s (on %s)" | ||||
| msgstr "%s (na %s)" | ||||
|  | ||||
| #: ../src/core/window-props.c:1546 | ||||
| #: ../src/core/window-props.c:1517 | ||||
| #, c-format | ||||
| msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n" | ||||
| msgstr "" | ||||
| "Nieprawidłowa wartość WM_TRANSIENT_FOR dla okna 0x%lx określona w %s.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:1557 | ||||
| #: ../src/core/window-props.c:1528 | ||||
| #, c-format | ||||
| msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n" | ||||
| msgstr "WM_TRANSIENT_FOR okna 0x%lx dla %s utworzyłoby pętlę.\n" | ||||
| @@ -742,104 +730,109 @@ msgstr "Wybór okna z wyskakującego okna dla tabulacji" | ||||
| msgid "Cancel tab popup" | ||||
| msgstr "Anulowanie wyskakującego okna dla tabulacji" | ||||
|  | ||||
| #: ../src/tools/mutter-message.c:123 | ||||
| #, c-format | ||||
| msgid "Usage: %s\n" | ||||
| msgstr "Użycie: %s\n" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:67 | ||||
| #: ../src/ui/menu.c:69 | ||||
| msgid "Mi_nimize" | ||||
| msgstr "Zm_inimalizuj" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:69 | ||||
| #: ../src/ui/menu.c:71 | ||||
| msgid "Ma_ximize" | ||||
| msgstr "Zm_aksymalizuj" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:71 | ||||
| #: ../src/ui/menu.c:73 | ||||
| msgid "Unma_ximize" | ||||
| msgstr "Cofnij m_aksymalizację" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:73 | ||||
| #: ../src/ui/menu.c:75 | ||||
| msgid "Roll _Up" | ||||
| msgstr "_Zwiń" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:75 | ||||
| #: ../src/ui/menu.c:77 | ||||
| msgid "_Unroll" | ||||
| msgstr "Ro_zwiń" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:77 | ||||
| #: ../src/ui/menu.c:79 | ||||
| msgid "_Move" | ||||
| msgstr "Prz_esuń" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:79 | ||||
| #: ../src/ui/menu.c:81 | ||||
| msgid "_Resize" | ||||
| msgstr "Zmień _rozmiar" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:81 | ||||
| #: ../src/ui/menu.c:83 | ||||
| msgid "Move Titlebar On_screen" | ||||
| msgstr "Przeno_szenie paska tytułowego na ekranie" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:84 ../src/ui/menu.c:86 | ||||
| #: ../src/ui/menu.c:86 ../src/ui/menu.c:88 | ||||
| msgid "Always on _Top" | ||||
| msgstr "Zawsze na _wierzchu" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:88 | ||||
| #: ../src/ui/menu.c:90 | ||||
| msgid "_Always on Visible Workspace" | ||||
| msgstr "_Zawsze na widocznym obszarze roboczym" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:90 | ||||
| #: ../src/ui/menu.c:92 | ||||
| msgid "_Only on This Workspace" | ||||
| msgstr "_Tylko na tym obszarze roboczym" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:92 | ||||
| #: ../src/ui/menu.c:94 | ||||
| msgid "Move to Workspace _Left" | ||||
| msgstr "Przenieś na _lewy obszar roboczy" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:94 | ||||
| #: ../src/ui/menu.c:96 | ||||
| msgid "Move to Workspace R_ight" | ||||
| msgstr "Przen_ieś na prawy obszar roboczy" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:96 | ||||
| #: ../src/ui/menu.c:98 | ||||
| msgid "Move to Workspace _Up" | ||||
| msgstr "_Przenieś na górny obszar roboczy" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:98 | ||||
| #: ../src/ui/menu.c:100 | ||||
| msgid "Move to Workspace _Down" | ||||
| msgstr "Przenieś na _dolny obszar roboczy" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:102 | ||||
| #: ../src/ui/menu.c:104 | ||||
| msgid "_Close" | ||||
| msgstr "Za_mknij" | ||||
|  | ||||
| #: ../src/ui/menu.c:202 | ||||
| #: ../src/ui/menu.c:204 | ||||
| #, c-format | ||||
| msgid "Workspace %d%n" | ||||
| msgstr "Obszar roboczy %d%n" | ||||
|  | ||||
| #: ../src/ui/menu.c:212 | ||||
| #: ../src/ui/menu.c:214 | ||||
| #, c-format | ||||
| msgid "Workspace 1_0" | ||||
| msgstr "Obszar roboczy 1_0" | ||||
|  | ||||
| #: ../src/ui/menu.c:214 | ||||
| #: ../src/ui/menu.c:216 | ||||
| #, c-format | ||||
| msgid "Workspace %s%d" | ||||
| msgstr "Obszar roboczy %s%d" | ||||
|  | ||||
| #: ../src/ui/menu.c:384 | ||||
| #: ../src/ui/menu.c:397 | ||||
| msgid "Move to Another _Workspace" | ||||
| msgstr "Przeniesienie na inny _obszar roboczy" | ||||
|  | ||||
| @@ -941,49 +934,49 @@ msgstr "Mod5" | ||||
| msgid "%d x %d" | ||||
| msgstr "%d x %d" | ||||
|  | ||||
| #: ../src/ui/theme.c:236 | ||||
| #: ../src/ui/theme.c:235 | ||||
| msgid "top" | ||||
| msgstr "góra" | ||||
|  | ||||
| #: ../src/ui/theme.c:238 | ||||
| #: ../src/ui/theme.c:237 | ||||
| msgid "bottom" | ||||
| msgstr "dół" | ||||
|  | ||||
| #: ../src/ui/theme.c:240 | ||||
| #: ../src/ui/theme.c:239 | ||||
| msgid "left" | ||||
| msgstr "lewa" | ||||
|  | ||||
| #: ../src/ui/theme.c:242 | ||||
| #: ../src/ui/theme.c:241 | ||||
| msgid "right" | ||||
| msgstr "prawa" | ||||
|  | ||||
| #: ../src/ui/theme.c:270 | ||||
| #: ../src/ui/theme.c:269 | ||||
| #, c-format | ||||
| msgid "frame geometry does not specify \"%s\" dimension" | ||||
| msgstr "Rozmiar ramki nie określa wymiaru \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:289 | ||||
| #: ../src/ui/theme.c:288 | ||||
| #, c-format | ||||
| msgid "frame geometry does not specify dimension \"%s\" for border \"%s\"" | ||||
| msgstr "Rozmiar ramki nie określa wymiaru \"%s\" dla krawędzi \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:326 | ||||
| #: ../src/ui/theme.c:325 | ||||
| #, c-format | ||||
| msgid "Button aspect ratio %g is not reasonable" | ||||
| msgstr "" | ||||
| "Współczynnik proporcji przycisku %g nie mieści się w rozsądnych granicach" | ||||
|  | ||||
| #: ../src/ui/theme.c:338 | ||||
| #: ../src/ui/theme.c:337 | ||||
| #, c-format | ||||
| msgid "Frame geometry does not specify size of buttons" | ||||
| msgstr "Rozmiar ramki nie określa liczby przycisków" | ||||
|  | ||||
| #: ../src/ui/theme.c:1051 | ||||
| #: ../src/ui/theme.c:1050 | ||||
| #, c-format | ||||
| msgid "Gradients should have at least two colors" | ||||
| msgstr "Gradienty powinny się składać co najmniej z dwóch kolorów" | ||||
|  | ||||
| #: ../src/ui/theme.c:1203 | ||||
| #: ../src/ui/theme.c:1202 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK custom color specification must have color name and fallback in " | ||||
| @@ -993,7 +986,7 @@ msgstr "" | ||||
| "kolor zastępczy w nawiasach, np. gtk:custom(foo,bar); nie można przetworzyć " | ||||
| "\"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1219 | ||||
| #: ../src/ui/theme.c:1218 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-" | ||||
| @@ -1002,7 +995,7 @@ msgstr "" | ||||
| "Nieprawidłowy znak \"%c\" w parametrze nazwa_koloru opcji gtk:custom, tylko " | ||||
| "znaki A-Za-z0-9-_ są prawidłowe" | ||||
|  | ||||
| #: ../src/ui/theme.c:1233 | ||||
| #: ../src/ui/theme.c:1232 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not " | ||||
| @@ -1011,7 +1004,7 @@ msgstr "" | ||||
| "Formatem Gtk:custom jest \"gtk:custom(nazwa_koloru,kolor_zastępczy)\", \"%s" | ||||
| "\" nie pasuje do formatu" | ||||
|  | ||||
| #: ../src/ui/theme.c:1278 | ||||
| #: ../src/ui/theme.c:1277 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] " | ||||
| @@ -1021,7 +1014,7 @@ msgstr "" | ||||
| "kwadratowych, np. gtk:fg[NORMAL], gdzie NORMAL jest nazwą stanu; nie można " | ||||
| "przetworzyć \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1292 | ||||
| #: ../src/ui/theme.c:1291 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK color specification must have a close bracket after the state, e.g. gtk:" | ||||
| @@ -1031,17 +1024,17 @@ msgstr "" | ||||
| "nawias kwadratowy, np. gtk:fg[NORMAL], gdzie NORMAL jest nazwą stanu; nie " | ||||
| "można przetworzyć \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1303 | ||||
| #: ../src/ui/theme.c:1302 | ||||
| #, c-format | ||||
| msgid "Did not understand state \"%s\" in color specification" | ||||
| msgstr "Niezrozumiały stan \"%s\" w specyfikacji koloru" | ||||
|  | ||||
| #: ../src/ui/theme.c:1316 | ||||
| #: ../src/ui/theme.c:1315 | ||||
| #, c-format | ||||
| msgid "Did not understand color component \"%s\" in color specification" | ||||
| msgstr "Niezrozumiała definicja koloru \"%s\" w specyfikacji koloru" | ||||
|  | ||||
| #: ../src/ui/theme.c:1345 | ||||
| #: ../src/ui/theme.c:1344 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the " | ||||
| @@ -1050,19 +1043,19 @@ msgstr "" | ||||
| "Formatem przenikania jest \"blend/bg_color/fg_color/alpha\", \"%s\" nie " | ||||
| "pasuje do formatu" | ||||
|  | ||||
| #: ../src/ui/theme.c:1356 | ||||
| #: ../src/ui/theme.c:1355 | ||||
| #, c-format | ||||
| msgid "Could not parse alpha value \"%s\" in blended color" | ||||
| msgstr "Nie można przetworzyć wartości alfa \"%s\" w przenikającym kolorze" | ||||
|  | ||||
| #: ../src/ui/theme.c:1366 | ||||
| #: ../src/ui/theme.c:1365 | ||||
| #, c-format | ||||
| msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0" | ||||
| msgstr "" | ||||
| "Wartość alfa \"%s\" w przenikającym kolorze nie zawiera się pomiędzy 0,0 i " | ||||
| "1,0" | ||||
|  | ||||
| #: ../src/ui/theme.c:1413 | ||||
| #: ../src/ui/theme.c:1412 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format" | ||||
| @@ -1070,29 +1063,29 @@ msgstr "" | ||||
| "Formatem przenikania jest \"shade/base_color/factor\", \"%s\" nie pasuje do " | ||||
| "formatu" | ||||
|  | ||||
| #: ../src/ui/theme.c:1424 | ||||
| #: ../src/ui/theme.c:1423 | ||||
| #, c-format | ||||
| msgid "Could not parse shade factor \"%s\" in shaded color" | ||||
| msgstr "" | ||||
| "Nie można przetworzyć współczynnika przenikania \"%s\" w przenikającym " | ||||
| "kolorze" | ||||
|  | ||||
| #: ../src/ui/theme.c:1434 | ||||
| #: ../src/ui/theme.c:1433 | ||||
| #, c-format | ||||
| msgid "Shade factor \"%s\" in shaded color is negative" | ||||
| msgstr "Współczynnik przenikania \"%s\" w przenikającym kolorze jest ujemny" | ||||
|  | ||||
| #: ../src/ui/theme.c:1463 | ||||
| #: ../src/ui/theme.c:1462 | ||||
| #, c-format | ||||
| msgid "Could not parse color \"%s\"" | ||||
| msgstr "Nie można przetworzyć koloru \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1780 | ||||
| #: ../src/ui/theme.c:1779 | ||||
| #, c-format | ||||
| msgid "Coordinate expression contains character '%s' which is not allowed" | ||||
| msgstr "Wyrażenie określające współrzędne zawiera niedozwolony znak \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1807 | ||||
| #: ../src/ui/theme.c:1806 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression contains floating point number '%s' which could not be " | ||||
| @@ -1101,14 +1094,14 @@ msgstr "" | ||||
| "Wyrażenie określające współrzędne zawiera liczbę zmiennoprzecinkową \"%s\", " | ||||
| "której nie można przetworzyć" | ||||
|  | ||||
| #: ../src/ui/theme.c:1821 | ||||
| #: ../src/ui/theme.c:1820 | ||||
| #, c-format | ||||
| msgid "Coordinate expression contains integer '%s' which could not be parsed" | ||||
| msgstr "" | ||||
| "Wyrażenie określające współrzędne zawiera liczbę całkowitą \"%s\", której " | ||||
| "nie można przetworzyć" | ||||
|  | ||||
| #: ../src/ui/theme.c:1942 | ||||
| #: ../src/ui/theme.c:1941 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression contained unknown operator at the start of this text: " | ||||
| @@ -1117,18 +1110,18 @@ msgstr "" | ||||
| "Wyrażenie określające współrzędne zawiera nieznany operator na początku " | ||||
| "tekstu: \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:1999 | ||||
| #: ../src/ui/theme.c:1998 | ||||
| #, c-format | ||||
| msgid "Coordinate expression was empty or not understood" | ||||
| msgstr "" | ||||
| "Wyrażenie określające współrzędne jest puste lub nie można go rozpoznać" | ||||
|  | ||||
| #: ../src/ui/theme.c:2112 ../src/ui/theme.c:2122 ../src/ui/theme.c:2156 | ||||
| #: ../src/ui/theme.c:2111 ../src/ui/theme.c:2121 ../src/ui/theme.c:2155 | ||||
| #, c-format | ||||
| msgid "Coordinate expression results in division by zero" | ||||
| msgstr "Wyrażenie opisujące położenie zawiera dzielenie przez zero" | ||||
|  | ||||
| #: ../src/ui/theme.c:2164 | ||||
| #: ../src/ui/theme.c:2163 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression tries to use mod operator on a floating-point number" | ||||
| @@ -1136,7 +1129,7 @@ msgstr "" | ||||
| "Wyrażenie opisujące położenie używa operatora dzielenia modulo z liczbą " | ||||
| "zmiennoprzecinkową" | ||||
|  | ||||
| #: ../src/ui/theme.c:2220 | ||||
| #: ../src/ui/theme.c:2219 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression has an operator \"%s\" where an operand was expected" | ||||
| @@ -1144,19 +1137,19 @@ msgstr "" | ||||
| "Wyrażenie opisujące położenie zawiera operator \"%s\" w miejscu, w którym " | ||||
| "oczekiwano operandu" | ||||
|  | ||||
| #: ../src/ui/theme.c:2229 | ||||
| #: ../src/ui/theme.c:2228 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had an operand where an operator was expected" | ||||
| msgstr "" | ||||
| "Wyrażenie opisujące położenie zawiera operand w miejscu, w którym oczekiwano " | ||||
| "operatora" | ||||
|  | ||||
| #: ../src/ui/theme.c:2237 | ||||
| #: ../src/ui/theme.c:2236 | ||||
| #, c-format | ||||
| msgid "Coordinate expression ended with an operator instead of an operand" | ||||
| msgstr "Wyrażenie opisujące położenie kończy się operatorem zamiast operandem" | ||||
|  | ||||
| #: ../src/ui/theme.c:2247 | ||||
| #: ../src/ui/theme.c:2246 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression has operator \"%c\" following operator \"%c\" with no " | ||||
| @@ -1165,43 +1158,43 @@ msgstr "" | ||||
| "Wyrażenie opisujące położenie zawiera operator \"%c\" bezpośrednio po " | ||||
| "operatorze \"%c\" bez rozdzielającego ich operandu" | ||||
|  | ||||
| #: ../src/ui/theme.c:2398 ../src/ui/theme.c:2443 | ||||
| #: ../src/ui/theme.c:2397 ../src/ui/theme.c:2442 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had unknown variable or constant \"%s\"" | ||||
| msgstr "" | ||||
| "Wyrażenie opisujące położenie zawiera nieznaną zmienną lub stałą \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:2497 | ||||
| #: ../src/ui/theme.c:2496 | ||||
| #, c-format | ||||
| msgid "Coordinate expression parser overflowed its buffer." | ||||
| msgstr "Parser wyrażeń określających współrzędne przepełnił swój bufor." | ||||
|  | ||||
| #: ../src/ui/theme.c:2526 | ||||
| #: ../src/ui/theme.c:2525 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had a close parenthesis with no open parenthesis" | ||||
| msgstr "" | ||||
| "Wyrażenie opisujące położenie zawiera nawias zamykający bez odpowiadającego " | ||||
| "mu nawiasu otwierającego" | ||||
|  | ||||
| #: ../src/ui/theme.c:2590 | ||||
| #: ../src/ui/theme.c:2589 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had an open parenthesis with no close parenthesis" | ||||
| msgstr "" | ||||
| "Wyrażenie opisujące położenie zawiera nawias otwierający bez odpowiadającego " | ||||
| "mu nawiasu zamykającego" | ||||
|  | ||||
| #: ../src/ui/theme.c:2601 | ||||
| #: ../src/ui/theme.c:2600 | ||||
| #, c-format | ||||
| msgid "Coordinate expression doesn't seem to have any operators or operands" | ||||
| msgstr "" | ||||
| "Wyrażenie opisujące położenie nie zawiera żadnych operatorów ani operandów" | ||||
|  | ||||
| #: ../src/ui/theme.c:2814 ../src/ui/theme.c:2834 ../src/ui/theme.c:2854 | ||||
| #: ../src/ui/theme.c:2813 ../src/ui/theme.c:2833 ../src/ui/theme.c:2853 | ||||
| #, c-format | ||||
| msgid "Theme contained an expression that resulted in an error: %s\n" | ||||
| msgstr "Motyw zawiera wyrażenie, przy którego obliczaniu wystąpił błąd: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:4500 | ||||
| #: ../src/ui/theme.c:4499 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be " | ||||
| @@ -1210,25 +1203,25 @@ msgstr "" | ||||
| "Przy tym stylu ramki należy podać <button function=\"%s\" state=\"%s\" " | ||||
| "draw_ops=\"cokolwiek\"/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5011 ../src/ui/theme.c:5036 | ||||
| #: ../src/ui/theme.c:5010 ../src/ui/theme.c:5035 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>" | ||||
| msgstr "" | ||||
| "Brak <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"cokolwiek\"/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5082 | ||||
| #: ../src/ui/theme.c:5083 | ||||
| #, c-format | ||||
| msgid "Failed to load theme \"%s\": %s\n" | ||||
| msgstr "Wczytanie motywu \"%s\" się nie powiodło: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232 | ||||
| #: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246 | ||||
| #: ../src/ui/theme.c:5219 ../src/ui/theme.c:5226 ../src/ui/theme.c:5233 | ||||
| #: ../src/ui/theme.c:5240 ../src/ui/theme.c:5247 | ||||
| #, c-format | ||||
| msgid "No <%s> set for theme \"%s\"" | ||||
| msgstr "Nie określono elementu <%s> dla motywu \"%s\"" | ||||
|  | ||||
| #: ../src/ui/theme.c:5254 | ||||
| #: ../src/ui/theme.c:5255 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "No frame style set for window type \"%s\" in theme \"%s\", add a <window " | ||||
| @@ -1237,7 +1230,7 @@ msgstr "" | ||||
| "Przy typie okna \"%s\" w motywie \"%s\" nie ustawiono stylu ramki. Należy " | ||||
| "dodać element <window type=\"%s\" style_set=\"cokolwiek\"/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786 | ||||
| #: ../src/ui/theme.c:5662 ../src/ui/theme.c:5724 ../src/ui/theme.c:5787 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "User-defined constants must begin with a capital letter; \"%s\" does not" | ||||
| @@ -1245,7 +1238,7 @@ msgstr "" | ||||
| "Stałe definiowane przez użytkownika powinny rozpoczynać się wielką literą, " | ||||
| "natomiast \"%s\" nie spełnia tego warunku" | ||||
|  | ||||
| #: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794 | ||||
| #: ../src/ui/theme.c:5670 ../src/ui/theme.c:5732 ../src/ui/theme.c:5795 | ||||
| #, c-format | ||||
| msgid "Constant \"%s\" has already been defined" | ||||
| msgstr "Stała \"%s\" została już określona" | ||||
| @@ -1633,7 +1626,208 @@ msgstr "Wewnątrz elementu <%s> nie jest dopuszczalny tekst" | ||||
| msgid "<%s> specified twice for this theme" | ||||
| msgstr "<%s> określono dwukrotnie dla tego motywu" | ||||
|  | ||||
| #: ../src/ui/theme-parser.c:4336 | ||||
| #: ../src/ui/theme-parser.c:4334 | ||||
| #, c-format | ||||
| msgid "Failed to find a valid file for theme %s\n" | ||||
| msgstr "Odnalezienie prawidłowego pliku dla motywu %s się nie powiodło\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:99 | ||||
| msgid "_Windows" | ||||
| msgstr "_Okna" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:100 | ||||
| msgid "_Dialog" | ||||
| msgstr "Okno _dialogowe" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:101 | ||||
| msgid "_Modal dialog" | ||||
| msgstr "_Modalne okno dialogowe" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:102 | ||||
| msgid "_Utility" | ||||
| msgstr "_Narzędzie" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:103 | ||||
| msgid "_Splashscreen" | ||||
| msgstr "_Ekran powitalny" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:104 | ||||
| msgid "_Top dock" | ||||
| msgstr "_Górny dok" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:105 | ||||
| msgid "_Bottom dock" | ||||
| msgstr "_Dolny dok" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:106 | ||||
| msgid "_Left dock" | ||||
| msgstr "_Lewy dok" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:107 | ||||
| msgid "_Right dock" | ||||
| msgstr "_Prawy dok" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:108 | ||||
| msgid "_All docks" | ||||
| msgstr "_Wszystkie doki" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:109 | ||||
| msgid "Des_ktop" | ||||
| msgstr "Pu_lpit" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:115 | ||||
| msgid "Open another one of these windows" | ||||
| msgstr "Otwiera kolejne okno tego typu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:117 | ||||
| msgid "This is a demo button with an 'open' icon" | ||||
| msgstr "To jest przycisk demonstracyjny z ikoną \"otwórz\"" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:119 | ||||
| msgid "This is a demo button with a 'quit' icon" | ||||
| msgstr "To jest przycisk demonstracyjny z ikoną \"zakończ\"" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:248 | ||||
| msgid "This is a sample message in a sample dialog" | ||||
| msgstr "To jest przykładowy komunikat w prostym oknie dialogowym" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:328 | ||||
| #, c-format | ||||
| msgid "Fake menu item %d\n" | ||||
| msgstr "Imitacja elementu menu %d\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:363 | ||||
| msgid "Border-only window" | ||||
| msgstr "Okno zawierające tylko krawędzie" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:365 | ||||
| msgid "Bar" | ||||
| msgstr "Pasek" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:382 | ||||
| msgid "Normal Application Window" | ||||
| msgstr "Zwykłe okno programu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:386 | ||||
| msgid "Dialog Box" | ||||
| msgstr "Okno dialogowe" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:390 | ||||
| msgid "Modal Dialog Box" | ||||
| msgstr "Modalne okno dialogowe" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:394 | ||||
| msgid "Utility Palette" | ||||
| msgstr "Paleta narzędziowa" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:398 | ||||
| msgid "Torn-off Menu" | ||||
| msgstr "Menu oderwane" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:402 | ||||
| msgid "Border" | ||||
| msgstr "Krawędź" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:406 | ||||
| msgid "Attached Modal Dialog" | ||||
| msgstr "Dołączone modalne okno dialogowe" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:737 | ||||
| #, c-format | ||||
| msgid "Button layout test %d" | ||||
| msgstr "Test układu przycisków %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:766 | ||||
| #, c-format | ||||
| msgid "%g milliseconds to draw one window frame" | ||||
| msgstr "%g milisekundy do narysowania jednej ramki okna" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:811 | ||||
| #, c-format | ||||
| msgid "Usage: metacity-theme-viewer [THEMENAME]\n" | ||||
| msgstr "Użycie: metacity-theme-viewer [NAZWA_MOTYWU]\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:818 | ||||
| #, c-format | ||||
| msgid "Error loading theme: %s\n" | ||||
| msgstr "Błąd podczas wczytywania motywu: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:824 | ||||
| #, c-format | ||||
| msgid "Loaded theme \"%s\" in %g seconds\n" | ||||
| msgstr "Wczytano motyw \"%s\" w ciągu %g sekund\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:869 | ||||
| msgid "Normal Title Font" | ||||
| msgstr "Zwykła czcionka tytułu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:875 | ||||
| msgid "Small Title Font" | ||||
| msgstr "Mała czcionka tytułu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:881 | ||||
| msgid "Large Title Font" | ||||
| msgstr "Duża czcionka tytułu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:886 | ||||
| msgid "Button Layouts" | ||||
| msgstr "Układy przycisków" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:891 | ||||
| msgid "Benchmark" | ||||
| msgstr "Test wydajności" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:947 | ||||
| msgid "Window Title Goes Here" | ||||
| msgstr "Tutaj znajduje się tytuł okna" | ||||
|  | ||||
| # FIXME - bełkot | ||||
| #: ../src/ui/theme-viewer.c:1053 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g " | ||||
| "seconds wall clock time including X server resources (%g milliseconds per " | ||||
| "frame)\n" | ||||
| msgstr "" | ||||
| "Narysowano %d ramek w ciągu %g sekund klienta (%g milisekund na ramkę) oraz " | ||||
| "%g sekund rzeczywistych, włączając w to zasoby serwera X (%g milisekund na " | ||||
| "ramkę)\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1273 | ||||
| msgid "position expression test returned TRUE but set error" | ||||
| msgstr "Test wyrażenia pozycji zwrócił wartość PRAWDA, lecz ustawił błąd" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1275 | ||||
| msgid "position expression test returned FALSE but didn't set error" | ||||
| msgstr "Test wyrażenia pozycji zwrócił wartość FAŁSZ, lecz nie ustawił błędu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1279 | ||||
| msgid "Error was expected but none given" | ||||
| msgstr "Oczekiwano błędu, lecz nie otrzymano żadnego" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1281 | ||||
| #, c-format | ||||
| msgid "Error %d was expected but %d given" | ||||
| msgstr "Oczekiwano błędu %d, lecz otrzymano %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1287 | ||||
| #, c-format | ||||
| msgid "Error not expected but one was returned: %s" | ||||
| msgstr "Nie oczekiwano błędu, lecz został on zwrócony: %s" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1291 | ||||
| #, c-format | ||||
| msgid "x value was %d, %d was expected" | ||||
| msgstr "Wartością X było %d, oczekiwano wartości %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1294 | ||||
| #, c-format | ||||
| msgid "y value was %d, %d was expected" | ||||
| msgstr "Wartością Y było %d, oczekiwano wartości %d" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1359 | ||||
| #, c-format | ||||
| msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n" | ||||
| msgstr "" | ||||
| "Wyrażenia współrzędnych %d zostało przetworzone w %g sekund (średnio %g " | ||||
| "sekund)\n" | ||||
|   | ||||
							
								
								
									
										498
									
								
								po/pt_BR.po
									
									
									
									
									
								
							
							
						
						
									
										498
									
								
								po/pt_BR.po
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										417
									
								
								po/sk.po
									
									
									
									
									
								
							
							
						
						
									
										417
									
								
								po/sk.po
									
									
									
									
									
								
							| @@ -13,9 +13,9 @@ msgstr "" | ||||
| "Project-Id-Version: mutter\n" | ||||
| "Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?" | ||||
| "product=mutter&keywords=I18N+L10N&component=general\n" | ||||
| "POT-Creation-Date: 2013-08-21 17:41+0000\n" | ||||
| "PO-Revision-Date: 2013-08-02 14:46+0200\n" | ||||
| "Last-Translator: Ján Kyselica <kyselica.jan@gmail.com>\n" | ||||
| "POT-Creation-Date: 2013-05-24 21:44+0000\n" | ||||
| "PO-Revision-Date: 2013-05-18 16:53+0100\n" | ||||
| "Last-Translator: Jan Kyselica <kyselica.jan@gmail.com>\n" | ||||
| "Language-Team: Slovak <gnome-sk-list@gnome.org>\n" | ||||
| "Language: sk\n" | ||||
| "MIME-Version: 1.0\n" | ||||
| @@ -87,8 +87,9 @@ msgstr "Prepnúť okná aplikácie" | ||||
| # PK: zisti co to robi | ||||
| # description | ||||
| #: ../src/50-mutter-navigation.xml.in.h:13 | ||||
| #, fuzzy | ||||
| msgid "Switch system controls" | ||||
| msgstr "Prepnúť medzi ovládacími prvkami systému" | ||||
| msgstr "Prepnúť medzi systémovými ovládacími prvkami" | ||||
|  | ||||
| # description | ||||
| #: ../src/50-mutter-navigation.xml.in.h:14 | ||||
| @@ -103,8 +104,9 @@ msgstr "Prepnúť okná aplikácie priamo" | ||||
| # MČ: podobne ako vyššie: „cycle-panels“ | ||||
| # description | ||||
| #: ../src/50-mutter-navigation.xml.in.h:16 | ||||
| #, fuzzy | ||||
| msgid "Switch system controls directly" | ||||
| msgstr "Prepnúť medzi ovládacími prvkami systému priamo" | ||||
| msgstr "Prepnúť medzi systémovými ovládacími prvkami priamo" | ||||
|  | ||||
| # description | ||||
| #: ../src/50-mutter-navigation.xml.in.h:17 | ||||
| @@ -265,13 +267,13 @@ msgstr "Zobraziť rozdelenie napravo" | ||||
| # PK: je %i cislo obrazovky? ak ano tak "č. %i" | ||||
| #. This probably means that a non-WM compositor like xcompmgr is running; | ||||
| #. * we have no way to get it to exit | ||||
| #: ../src/compositor/compositor.c:596 | ||||
| #, c-format | ||||
| #: ../src/compositor/compositor.c:571 | ||||
| #, fuzzy, c-format | ||||
| msgid "" | ||||
| "Another compositing manager is already running on screen %i on display \"%s" | ||||
| "\"." | ||||
| msgstr "" | ||||
| "Pre obrazovku č. %i na displeji „%s“ je spustený už iný správca rozloženia." | ||||
| "Pre obrazovku %i na displeji „%s“ je spustený už iný správca rozloženia." | ||||
|  | ||||
| #: ../src/compositor/meta-background.c:1076 | ||||
| msgid "background texture could not be created from file" | ||||
| @@ -311,18 +313,18 @@ msgstr "_Počkať" | ||||
| msgid "_Force Quit" | ||||
| msgstr "_Vynútiť ukončenie" | ||||
|  | ||||
| #: ../src/core/display.c:421 | ||||
| #: ../src/core/display.c:401 | ||||
| #, c-format | ||||
| msgid "Missing %s extension required for compositing" | ||||
| msgstr "Rozšírenie %s, potrebné pre kompozitné prostredie, chýba" | ||||
|  | ||||
| # X window system preloz, napr. system na spravu okien X | ||||
| #: ../src/core/display.c:513 | ||||
| #: ../src/core/display.c:493 | ||||
| #, c-format | ||||
| msgid "Failed to open X Window System display '%s'\n" | ||||
| msgstr "Zlyhalo otvorenie displeja systému na správu okien X „%s“\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1136 | ||||
| #: ../src/core/keybindings.c:970 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Some other program is already using the key %s with modifiers %x as a " | ||||
| @@ -330,7 +332,7 @@ msgid "" | ||||
| msgstr "" | ||||
| "Iný program už používa kláves %s s modifikátormi %x ako klávesovú skratku\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1333 | ||||
| #: ../src/core/keybindings.c:1151 | ||||
| #, c-format | ||||
| msgid "\"%s\" is not a valid accelerator\n" | ||||
| msgstr "„%s“ nie je platný akcelerátor\n" | ||||
| @@ -376,20 +378,6 @@ msgid "" | ||||
| msgstr "" | ||||
| "Nepodarilo sa nájsť tému! Overte, že %s existuje a obsahuje obvyklé témy.\n" | ||||
|  | ||||
| #: ../src/core/monitor.c:702 | ||||
| msgid "Built-in display" | ||||
| msgstr "Vstavaný displej" | ||||
|  | ||||
| #. TRANSLATORS: this is a monitor name (in case we don't know | ||||
| #. the vendor), it's Unknown followed by a size in inches, | ||||
| #. like 'Unknown 15"' | ||||
| #. | ||||
| #: ../src/core/monitor.c:730 | ||||
| #, c-format | ||||
| #| msgid "Unknown element %s" | ||||
| msgid "Unknown %s" | ||||
| msgstr "Neznámy %s" | ||||
|  | ||||
| #: ../src/core/mutter.c:40 | ||||
| #, c-format | ||||
| msgid "" | ||||
| @@ -415,7 +403,7 @@ msgstr "Zobrazí verziu" | ||||
| msgid "Mutter plugin to use" | ||||
| msgstr "Použije zásuvný modul Mutter" | ||||
|  | ||||
| #: ../src/core/prefs.c:1202 | ||||
| #: ../src/core/prefs.c:1193 | ||||
| msgid "" | ||||
| "Workarounds for broken applications disabled. Some applications may not " | ||||
| "behave properly.\n" | ||||
| @@ -423,12 +411,12 @@ msgstr "" | ||||
| "Náhradné riešenia pre chybné aplikácie nie sú povolené. Niektoré aplikácie " | ||||
| "sa nemusia správať správne.\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1277 | ||||
| #: ../src/core/prefs.c:1268 | ||||
| #, c-format | ||||
| msgid "Could not parse font description \"%s\" from GSettings key %s\n" | ||||
| msgstr "Nepodarilo sa spracovať popis písma „%s“ z kľúča GSettings %s\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1343 | ||||
| #: ../src/core/prefs.c:1334 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for mouse button " | ||||
| @@ -437,7 +425,7 @@ msgstr "" | ||||
| "V konfiguračnej databáze sa našlo „%s“, čo nie je platná hodnota pre " | ||||
| "modifikátor tlačidla myši\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1909 | ||||
| #: ../src/core/prefs.c:1881 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for keybinding " | ||||
| @@ -446,17 +434,17 @@ msgstr "" | ||||
| "V konfiguračnej databáze sa našlo „%s“, čo nie je platná hodnota pre " | ||||
| "klávesovú skratku „%s“\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1999 | ||||
| #: ../src/core/prefs.c:1945 | ||||
| #, c-format | ||||
| msgid "Workspace %d" | ||||
| msgstr "Pracovný priestor č. %d" | ||||
|  | ||||
| #: ../src/core/screen.c:537 | ||||
| #: ../src/core/screen.c:691 | ||||
| #, c-format | ||||
| msgid "Screen %d on display '%s' is invalid\n" | ||||
| msgstr "Obrazovka č. %d na displeji „%s“ nie je platná\n" | ||||
|  | ||||
| #: ../src/core/screen.c:553 | ||||
| #: ../src/core/screen.c:707 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Screen %d on display \"%s\" already has a window manager; try using the --" | ||||
| @@ -465,7 +453,7 @@ msgstr "" | ||||
| "Obrazovka č. %d na displeji „%s“ už má správcu okien. Skúste použiť prepínač " | ||||
| "--replace, aby sa aktuálny správca nahradil.\n" | ||||
|  | ||||
| #: ../src/core/screen.c:580 | ||||
| #: ../src/core/screen.c:734 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not acquire window manager selection on screen %d display \"%s\"\n" | ||||
| @@ -473,12 +461,12 @@ msgstr "" | ||||
| "Nepodarilo sa získať výber správcu okien pre obrazovku č. %d na displeji " | ||||
| "„%s“\n" | ||||
|  | ||||
| #: ../src/core/screen.c:658 | ||||
| #: ../src/core/screen.c:812 | ||||
| #, c-format | ||||
| msgid "Screen %d on display \"%s\" already has a window manager\n" | ||||
| msgstr "Obrazovka č. %d na displeji „%s“ už má správcu okien\n" | ||||
|  | ||||
| #: ../src/core/screen.c:850 | ||||
| #: ../src/core/screen.c:998 | ||||
| #, c-format | ||||
| msgid "Could not release screen %d on display \"%s\"\n" | ||||
| msgstr "Nepodarilo sa uvoľniť obrazovku č. %d na displeji „%s“\n" | ||||
| @@ -554,7 +542,8 @@ msgstr "Zlyhalo otvorenie súboru so záznamom pomocou fdopen() %s: %s\n" | ||||
| msgid "Opened log file %s\n" | ||||
| msgstr "Otvorený súbor so záznamom %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:119 | ||||
| #: ../src/core/util.c:119 ../src/tools/mutter-message.c:149 | ||||
| #, c-format | ||||
| msgid "Mutter was compiled without support for verbose mode\n" | ||||
| msgstr "Mutter bol skompilovaný bez výpisu podrobností pri behu\n" | ||||
|  | ||||
| @@ -562,20 +551,20 @@ msgstr "Mutter bol skompilovaný bez výpisu podrobností pri behu\n" | ||||
| msgid "Window manager: " | ||||
| msgstr "Správca okien: " | ||||
|  | ||||
| #: ../src/core/util.c:414 | ||||
| #: ../src/core/util.c:412 | ||||
| msgid "Bug in window manager: " | ||||
| msgstr "Chyba v správcovi okien: " | ||||
|  | ||||
| #: ../src/core/util.c:445 | ||||
| #: ../src/core/util.c:443 | ||||
| msgid "Window manager warning: " | ||||
| msgstr "Varovanie správcu okien: " | ||||
|  | ||||
| #: ../src/core/util.c:473 | ||||
| #: ../src/core/util.c:471 | ||||
| msgid "Window manager error: " | ||||
| msgstr "Chyba správcu okien: " | ||||
|  | ||||
| #. first time through | ||||
| #: ../src/core/window.c:7533 | ||||
| #: ../src/core/window.c:7505 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER " | ||||
| @@ -591,7 +580,7 @@ msgstr "" | ||||
| #. * MWM but not WM_NORMAL_HINTS are basically broken. We complain | ||||
| #. * about these apps but make them work. | ||||
| #. | ||||
| #: ../src/core/window.c:8257 | ||||
| #: ../src/core/window.c:8229 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets an MWM hint indicating it isn't resizable, but sets min size " | ||||
| @@ -601,7 +590,7 @@ msgstr "" | ||||
| "nastavuje minimálnu veľkosť %d x %d a maximálnu veľkosť %d x %d. To nedáva " | ||||
| "zmysel.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:347 | ||||
| #: ../src/core/window-props.c:318 | ||||
| #, c-format | ||||
| msgid "Application set a bogus _NET_WM_PID %lu\n" | ||||
| msgstr "Aplikácia nastavila neplatné _NET_WM_PID %lu\n" | ||||
| @@ -609,18 +598,18 @@ msgstr "Aplikácia nastavila neplatné _NET_WM_PID %lu\n" | ||||
| # PK: co je toto? | ||||
| # JK: nedokazem zistit | ||||
| # PM: vyžiadaj komentár od vývojárov, pomožeme aj ostatným prekladateľom | ||||
| #: ../src/core/window-props.c:463 | ||||
| #: ../src/core/window-props.c:434 | ||||
| #, fuzzy, c-format | ||||
| msgid "%s (on %s)" | ||||
| msgstr "%s (na %s)" | ||||
|  | ||||
| #: ../src/core/window-props.c:1546 | ||||
| #: ../src/core/window-props.c:1517 | ||||
| #, c-format | ||||
| msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n" | ||||
| msgstr "Neplatné WM_TRANSIENT_FOR okno 0x%lx nastavené pre %s.\n" | ||||
|  | ||||
| # MČ: zacykliť sa, alebo vytvoriť slučku. | ||||
| #: ../src/core/window-props.c:1557 | ||||
| #: ../src/core/window-props.c:1528 | ||||
| #, c-format | ||||
| msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n" | ||||
| msgstr "WM_TRANSIENT_FOR okno 0x%lx  pre %s môže vytvoriť slučku.\n" | ||||
| @@ -708,9 +697,9 @@ msgid "" | ||||
| "vertically and resizes them horizontally to cover half of the available " | ||||
| "area. Dropping windows on the top screen edge maximizes them completely." | ||||
| msgstr "" | ||||
| "Ak je povolené, upustenie okien pri zvislých okrajoch obrazovky ich zvislo " | ||||
| "maximalizuje a vodorovná veľkosť sa zmení na polovicu dostupnej plochy. " | ||||
| "Upustenie okien pri vrchnom okraji obrazovky ich maximalizuje úplne." | ||||
| "Ak je povolené, upustenie okien pri zvislých okrajoch obrazovky ich " | ||||
| "zvislo maximalizuje a vodorovná veľkosť sa zmení na polovicu dostupnej " | ||||
| "plochy. Upustenie okien pri vrchnom okraji obrazovky ich maximalizuje úplne." | ||||
|  | ||||
| # summary | ||||
| #: ../src/org.gnome.mutter.gschema.xml.in.h:7 | ||||
| @@ -746,8 +735,9 @@ msgstr "" | ||||
| # PM: ja by som dal Bez vyvovlávania tabulátorom | ||||
| # summary | ||||
| #: ../src/org.gnome.mutter.gschema.xml.in.h:11 | ||||
| #, fuzzy | ||||
| msgid "No tab popup" | ||||
| msgstr "Bez vyvolávania tabulátorom" | ||||
| msgstr "Nepoužívať prekryvnú ponuku tabulátora" | ||||
|  | ||||
| # MČ: Neviem, čo to presne má robiť, ale popis som pochopil inak. „…či sa má používať rozbaľovacia ponuka a zvýraznenie rámikom sa má vypnúť…“ | ||||
| # description | ||||
| @@ -816,104 +806,109 @@ msgstr "Vybrať okno z rozbaľovacej ponuky tabulátoru" | ||||
| msgid "Cancel tab popup" | ||||
| msgstr "Zrušit rozbaľovaciu ponuku tabulátoru" | ||||
|  | ||||
| #: ../src/tools/mutter-message.c:123 | ||||
| #, c-format | ||||
| msgid "Usage: %s\n" | ||||
| msgstr "Použitie: %s\n" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:67 | ||||
| #: ../src/ui/menu.c:69 | ||||
| msgid "Mi_nimize" | ||||
| msgstr "Mi_nimalizovať" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:69 | ||||
| #: ../src/ui/menu.c:71 | ||||
| msgid "Ma_ximize" | ||||
| msgstr "Ma_ximalizovať" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:71 | ||||
| #: ../src/ui/menu.c:73 | ||||
| msgid "Unma_ximize" | ||||
| msgstr "Zrušiť ma_ximalizáciu" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:73 | ||||
| #: ../src/ui/menu.c:75 | ||||
| msgid "Roll _Up" | ||||
| msgstr "_Zabaliť" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:75 | ||||
| #: ../src/ui/menu.c:77 | ||||
| msgid "_Unroll" | ||||
| msgstr "_Rozbaliť" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:77 | ||||
| #: ../src/ui/menu.c:79 | ||||
| msgid "_Move" | ||||
| msgstr "Pre_miestniť" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:79 | ||||
| #: ../src/ui/menu.c:81 | ||||
| msgid "_Resize" | ||||
| msgstr "Zmeniť veľko_sť" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:81 | ||||
| #: ../src/ui/menu.c:83 | ||||
| msgid "Move Titlebar On_screen" | ||||
| msgstr "Presunúť titulok na _obrazovku" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:84 ../src/ui/menu.c:86 | ||||
| #: ../src/ui/menu.c:86 ../src/ui/menu.c:88 | ||||
| msgid "Always on _Top" | ||||
| msgstr "Vždy na_vrchu" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:88 | ||||
| #: ../src/ui/menu.c:90 | ||||
| msgid "_Always on Visible Workspace" | ||||
| msgstr "Vž_dy na viditeľnom pracovnom priestore" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:90 | ||||
| #: ../src/ui/menu.c:92 | ||||
| msgid "_Only on This Workspace" | ||||
| msgstr "_Len na tomto pracovnom priestore" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:92 | ||||
| #: ../src/ui/menu.c:94 | ||||
| msgid "Move to Workspace _Left" | ||||
| msgstr "Presunúť na pracovný priestor vľav_o" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:94 | ||||
| #: ../src/ui/menu.c:96 | ||||
| msgid "Move to Workspace R_ight" | ||||
| msgstr "Presunúť na pracovný priestor v_pravo" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:96 | ||||
| #: ../src/ui/menu.c:98 | ||||
| msgid "Move to Workspace _Up" | ||||
| msgstr "Presunúť na pracovný priestor _hore" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:98 | ||||
| #: ../src/ui/menu.c:100 | ||||
| msgid "Move to Workspace _Down" | ||||
| msgstr "Presunúť na pracovný priestor _dole" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:102 | ||||
| #: ../src/ui/menu.c:104 | ||||
| msgid "_Close" | ||||
| msgstr "_Zavrieť" | ||||
|  | ||||
| #: ../src/ui/menu.c:202 | ||||
| #: ../src/ui/menu.c:204 | ||||
| #, c-format | ||||
| msgid "Workspace %d%n" | ||||
| msgstr "Pracovná priestor %d%n" | ||||
|  | ||||
| #: ../src/ui/menu.c:212 | ||||
| #: ../src/ui/menu.c:214 | ||||
| #, c-format | ||||
| msgid "Workspace 1_0" | ||||
| msgstr "Pracovný priestor 1_0" | ||||
|  | ||||
| #: ../src/ui/menu.c:214 | ||||
| #: ../src/ui/menu.c:216 | ||||
| #, c-format | ||||
| msgid "Workspace %s%d" | ||||
| msgstr "Pracovný priestor %s%d" | ||||
|  | ||||
| #: ../src/ui/menu.c:384 | ||||
| #: ../src/ui/menu.c:397 | ||||
| msgid "Move to Another _Workspace" | ||||
| msgstr "P_resunúť na iný pracovný priestor" | ||||
|  | ||||
| @@ -1071,21 +1066,21 @@ msgstr "" | ||||
| # MČ: Preformuloval by som koniec: „platné sú len znaky A-Za-z0-9-_“ | ||||
| # PK: color_name je asi nejaky atribut, to sa nepreklada, ked tak do zatvorky | ||||
| #: ../src/ui/theme.c:1219 | ||||
| #, c-format | ||||
| #, fuzzy, c-format | ||||
| msgid "" | ||||
| "Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-" | ||||
| "_ are valid" | ||||
| msgstr "" | ||||
| "V parametri color_name (názov farby) pre gtk:custom je neplatný znak „%c“, platné sú len " | ||||
| "V parametri názov_farby pre gtk:custom je neplatný znak „%c“, platné sú len " | ||||
| "znaky A-Za-z0-9-_" | ||||
|  | ||||
| #: ../src/ui/theme.c:1233 | ||||
| #, c-format | ||||
| #, fuzzy, c-format | ||||
| msgid "" | ||||
| "Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not " | ||||
| "fit the format" | ||||
| msgstr "" | ||||
| "Formát Gtk:custom je  „gtk:custom(color_name,fallback)“, „%s“ tomu " | ||||
| "Formát Gtk:custom je  „gtk:custom(názov_farby,fallback)“, „%s“ tomu " | ||||
| "nezodpovedá" | ||||
|  | ||||
| #: ../src/ui/theme.c:1278 | ||||
| @@ -1271,20 +1266,20 @@ msgid "" | ||||
| "Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>" | ||||
| msgstr "Chýbajúce <frame state=„%s“ resize=„%s“ focus=„%s“ style=„whatever“/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5082 | ||||
| #: ../src/ui/theme.c:5084 | ||||
| #, c-format | ||||
| msgid "Failed to load theme \"%s\": %s\n" | ||||
| msgstr "Zlyhalo načítanie témy „%s“: %s\n" | ||||
|  | ||||
| # PK: prvok? | ||||
| # JK: XML značka (XML tag) | ||||
| #: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232 | ||||
| #: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246 | ||||
| #: ../src/ui/theme.c:5220 ../src/ui/theme.c:5227 ../src/ui/theme.c:5234 | ||||
| #: ../src/ui/theme.c:5241 ../src/ui/theme.c:5248 | ||||
| #, c-format | ||||
| msgid "No <%s> set for theme \"%s\"" | ||||
| msgstr "Pre tému „%s“ nie je nastavená <%s>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5254 | ||||
| #: ../src/ui/theme.c:5256 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "No frame style set for window type \"%s\" in theme \"%s\", add a <window " | ||||
| @@ -1293,13 +1288,13 @@ msgstr "" | ||||
| "Pre typ okna „%s“ nie je sada štýlov v téme „%s“, pridajte prvok <window " | ||||
| "type=„%s“ style_set=„whatever“/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786 | ||||
| #: ../src/ui/theme.c:5663 ../src/ui/theme.c:5725 ../src/ui/theme.c:5788 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "User-defined constants must begin with a capital letter; \"%s\" does not" | ||||
| msgstr "Používateľské konštanty musia začínať veľkým písmenom, „%s“ nezačína" | ||||
|  | ||||
| #: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794 | ||||
| #: ../src/ui/theme.c:5671 ../src/ui/theme.c:5733 ../src/ui/theme.c:5796 | ||||
| #, c-format | ||||
| msgid "Constant \"%s\" has already been defined" | ||||
| msgstr "Konštanta „%s“ už je definovaná" | ||||
| @@ -1402,7 +1397,7 @@ msgstr "<%s> musí uvádzať buď geometriu alebo rodiča, ktorý má geometriu" | ||||
| msgid "You must specify a background for an alpha value to be meaningful" | ||||
| msgstr "Ak má byť hodnota alpha zmysluplná, tak musíte vybrať nejaké pozadie" | ||||
|  | ||||
| #  PM: asi atribút type | ||||
| # PM: asi atribút type | ||||
| # JK: https://bugzilla.gnome.org/show_bug.cgi?id=698123 | ||||
| #: ../src/ui/theme-parser.c:1264 | ||||
| #, fuzzy, c-format | ||||
| @@ -1564,7 +1559,6 @@ msgid "\"%s\" is not a valid value for resize attribute" | ||||
| msgstr "„%s“ nie je platná hodnota pre atribút zmeny veľkosti" | ||||
|  | ||||
| # PK: shaded states? to zatvorky daj popis co je resize | ||||
| # PM: skôr "pre stavy maximized (maximalizovaný)/shaded (zatienený)" | ||||
| #: ../src/ui/theme-parser.c:3147 | ||||
| #, fuzzy, c-format | ||||
| msgid "" | ||||
| @@ -1706,172 +1700,221 @@ msgstr "<%s> uvedený dvakrát pre túto tému" | ||||
| msgid "Failed to find a valid file for theme %s\n" | ||||
| msgstr "Zlyhalo nájdenie platného súboru pre tému%s\n" | ||||
|  | ||||
| #~ msgid "Usage: %s\n" | ||||
| #~ msgstr "Použitie: %s\n" | ||||
| #: ../src/ui/theme-viewer.c:99 | ||||
| msgid "_Windows" | ||||
| msgstr "_Okná" | ||||
|  | ||||
| #~ msgid "_Windows" | ||||
| #~ msgstr "_Okná" | ||||
| #: ../src/ui/theme-viewer.c:100 | ||||
| msgid "_Dialog" | ||||
| msgstr "_Dialógové okno" | ||||
|  | ||||
| #~ msgid "_Dialog" | ||||
| #~ msgstr "_Dialógové okno" | ||||
| #: ../src/ui/theme-viewer.c:101 | ||||
| msgid "_Modal dialog" | ||||
| msgstr "_Modálne dialógové okno" | ||||
|  | ||||
| #~ msgid "_Modal dialog" | ||||
| #~ msgstr "_Modálne dialógové okno" | ||||
| #: ../src/ui/theme-viewer.c:102 | ||||
| msgid "_Utility" | ||||
| msgstr "_Nástroje" | ||||
|  | ||||
| #~ msgid "_Utility" | ||||
| #~ msgstr "_Nástroje" | ||||
|  | ||||
| #~ msgid "_Splashscreen" | ||||
| #~ msgstr "Ú_vodná obrazovka" | ||||
| #: ../src/ui/theme-viewer.c:103 | ||||
| msgid "_Splashscreen" | ||||
| msgstr "Ú_vodná obrazovka" | ||||
|  | ||||
| # MČ: nie som si istý prekladom „dok“, nemal by to byť „panel“? | ||||
| #~ msgid "_Top dock" | ||||
| #~ msgstr "_Horný panel" | ||||
| #: ../src/ui/theme-viewer.c:104 | ||||
| msgid "_Top dock" | ||||
| msgstr "_Horný panel" | ||||
|  | ||||
| #~ msgid "_Bottom dock" | ||||
| #~ msgstr "_Spodný panel" | ||||
| #: ../src/ui/theme-viewer.c:105 | ||||
| msgid "_Bottom dock" | ||||
| msgstr "_Spodný panel" | ||||
|  | ||||
| #~ msgid "_Left dock" | ||||
| #~ msgstr "Ľ_avý panel" | ||||
| #: ../src/ui/theme-viewer.c:106 | ||||
| msgid "_Left dock" | ||||
| msgstr "Ľ_avý panel" | ||||
|  | ||||
| #~ msgid "_Right dock" | ||||
| #~ msgstr "_Pravý panel" | ||||
| #: ../src/ui/theme-viewer.c:107 | ||||
| msgid "_Right dock" | ||||
| msgstr "_Pravý panel" | ||||
|  | ||||
| #~ msgid "_All docks" | ||||
| #~ msgstr "_Všetky panely" | ||||
| #: ../src/ui/theme-viewer.c:108 | ||||
| msgid "_All docks" | ||||
| msgstr "_Všetky panely" | ||||
|  | ||||
| #~ msgid "Des_ktop" | ||||
| #~ msgstr "P_racovná plocha" | ||||
| #: ../src/ui/theme-viewer.c:109 | ||||
| msgid "Des_ktop" | ||||
| msgstr "P_racovná plocha" | ||||
|  | ||||
| # tooltip | ||||
| #~ msgid "Open another one of these windows" | ||||
| #~ msgstr "Otvorí ďalšie z týchto okien" | ||||
| #: ../src/ui/theme-viewer.c:115 | ||||
| msgid "Open another one of these windows" | ||||
| msgstr "Otvorí ďalšie z týchto okien" | ||||
|  | ||||
| # PK: prekladat to v uvodzovkach? nahlas bug | ||||
| # tooltip | ||||
| # JK: https://bugzilla.gnome.org/show_bug.cgi?id=698123 | ||||
| #: ../src/ui/theme-viewer.c:117 | ||||
| #, fuzzy | ||||
| #~ msgid "This is a demo button with an 'open' icon" | ||||
| #~ msgstr "Toto je ukážkové tlačidlo s ikonou „open“" | ||||
| msgid "This is a demo button with an 'open' icon" | ||||
| msgstr "Toto je ukážkové tlačidlo s ikonou „open“" | ||||
|  | ||||
| # tooltip | ||||
| # JK: https://bugzilla.gnome.org/show_bug.cgi?id=698123 | ||||
| #: ../src/ui/theme-viewer.c:119 | ||||
| #, fuzzy | ||||
| #~ msgid "This is a demo button with a 'quit' icon" | ||||
| #~ msgstr "Toto je ukážkové tlačidlo s ikonou „quit“" | ||||
| msgid "This is a demo button with a 'quit' icon" | ||||
| msgstr "Toto je ukážkové tlačidlo s ikonou „quit“" | ||||
|  | ||||
| # label | ||||
| #~ msgid "This is a sample message in a sample dialog" | ||||
| #~ msgstr "Toto je ukážková správa v ukážkovom dialógovom okne" | ||||
| #: ../src/ui/theme-viewer.c:248 | ||||
| msgid "This is a sample message in a sample dialog" | ||||
| msgstr "Toto je ukážková správa v ukážkovom dialógovom okne" | ||||
|  | ||||
| # PK: falosna | ||||
| #~ msgid "Fake menu item %d\n" | ||||
| #~ msgstr "Falošná položka ponuky č. %d\n" | ||||
| #: ../src/ui/theme-viewer.c:328 | ||||
| #, c-format | ||||
| msgid "Fake menu item %d\n" | ||||
| msgstr "Falošná položka ponuky č. %d\n" | ||||
|  | ||||
| #~ msgid "Border-only window" | ||||
| #~ msgstr "Okno len s okrajom" | ||||
| #: ../src/ui/theme-viewer.c:363 | ||||
| msgid "Border-only window" | ||||
| msgstr "Okno len s okrajom" | ||||
|  | ||||
| #~ msgid "Bar" | ||||
| #~ msgstr "Lišta" | ||||
| #: ../src/ui/theme-viewer.c:365 | ||||
| msgid "Bar" | ||||
| msgstr "Lišta" | ||||
|  | ||||
| #~ msgid "Normal Application Window" | ||||
| #~ msgstr "Normálne aplikačné okno" | ||||
| #: ../src/ui/theme-viewer.c:382 | ||||
| msgid "Normal Application Window" | ||||
| msgstr "Normálne aplikačné okno" | ||||
|  | ||||
| #~ msgid "Dialog Box" | ||||
| #~ msgstr "Dialógové okno" | ||||
| #: ../src/ui/theme-viewer.c:386 | ||||
| msgid "Dialog Box" | ||||
| msgstr "Dialógové okno" | ||||
|  | ||||
| #~ msgid "Modal Dialog Box" | ||||
| #~ msgstr "Modálne dialógové okno" | ||||
| #: ../src/ui/theme-viewer.c:390 | ||||
| msgid "Modal Dialog Box" | ||||
| msgstr "Modálne dialógové okno" | ||||
|  | ||||
| #~ msgid "Utility Palette" | ||||
| #~ msgstr "Paleta nástrojov" | ||||
| #: ../src/ui/theme-viewer.c:394 | ||||
| msgid "Utility Palette" | ||||
| msgstr "Paleta nástrojov" | ||||
|  | ||||
| #~ msgid "Torn-off Menu" | ||||
| #~ msgstr "Vypnúť ponuku" | ||||
| #: ../src/ui/theme-viewer.c:398 | ||||
| msgid "Torn-off Menu" | ||||
| msgstr "Vypnúť ponuku" | ||||
|  | ||||
| #~ msgid "Border" | ||||
| #~ msgstr "Okraj" | ||||
| #: ../src/ui/theme-viewer.c:402 | ||||
| msgid "Border" | ||||
| msgstr "Okraj" | ||||
|  | ||||
| #~ msgid "Attached Modal Dialog" | ||||
| #~ msgstr "Pričlenené modálne okno" | ||||
| #: ../src/ui/theme-viewer.c:406 | ||||
| msgid "Attached Modal Dialog" | ||||
| msgstr "Pričlenené modálne okno" | ||||
|  | ||||
| #~ msgid "Button layout test %d" | ||||
| #~ msgstr "Test rozloženia tlačidiel č. %d" | ||||
| #: ../src/ui/theme-viewer.c:737 | ||||
| #, c-format | ||||
| msgid "Button layout test %d" | ||||
| msgstr "Test rozloženia tlačidiel č. %d" | ||||
|  | ||||
| # PK: plural forms | ||||
| # JK: https://bugzilla.gnome.org/show_bug.cgi?id=697987 | ||||
| #, fuzzy | ||||
| #~ msgid "%g milliseconds to draw one window frame" | ||||
| #~ msgstr "%g milisekúnd pre vykreslenie jedného rámca okna" | ||||
| #: ../src/ui/theme-viewer.c:766 | ||||
| #, fuzzy, c-format | ||||
| msgid "%g milliseconds to draw one window frame" | ||||
| msgstr "%g milisekúnd pre vykreslenie jedného rámca okna" | ||||
|  | ||||
| #~ msgid "Usage: metacity-theme-viewer [THEMENAME]\n" | ||||
| #~ msgstr "Použitie: metacity-theme-viewer [NÁZOVTÉMY]\n" | ||||
| #: ../src/ui/theme-viewer.c:811 | ||||
| #, c-format | ||||
| msgid "Usage: metacity-theme-viewer [THEMENAME]\n" | ||||
| msgstr "Použitie: metacity-theme-viewer [NÁZOVTÉMY]\n" | ||||
|  | ||||
| #~ msgid "Error loading theme: %s\n" | ||||
| #~ msgstr "Chyba pri načítavaní témy: %s\n" | ||||
| #: ../src/ui/theme-viewer.c:818 | ||||
| #, c-format | ||||
| msgid "Error loading theme: %s\n" | ||||
| msgstr "Chyba pri načítavaní témy: %s\n" | ||||
|  | ||||
| # PK: plural forms | ||||
| # JK: https://bugzilla.gnome.org/show_bug.cgi?id=697987 | ||||
| #, fuzzy | ||||
| #~ msgid "Loaded theme \"%s\" in %g seconds\n" | ||||
| #~ msgstr "Téma „%s“ načítaná za %g sekúnd\n" | ||||
| #: ../src/ui/theme-viewer.c:824 | ||||
| #, fuzzy, c-format | ||||
| msgid "Loaded theme \"%s\" in %g seconds\n" | ||||
| msgstr "Téma „%s“ načítaná za %g sekúnd\n" | ||||
|  | ||||
| # PK: inde titulku, aky je rozdiel | ||||
| #~ msgid "Normal Title Font" | ||||
| #~ msgstr "Obyčajné písmo titulku" | ||||
| #: ../src/ui/theme-viewer.c:869 | ||||
| msgid "Normal Title Font" | ||||
| msgstr "Obyčajné písmo titulku" | ||||
|  | ||||
| #~ msgid "Small Title Font" | ||||
| #~ msgstr "Malé písmo titulku" | ||||
| #: ../src/ui/theme-viewer.c:875 | ||||
| msgid "Small Title Font" | ||||
| msgstr "Malé písmo titulku" | ||||
|  | ||||
| #~ msgid "Large Title Font" | ||||
| #~ msgstr "Veľké písmo titulku" | ||||
| #: ../src/ui/theme-viewer.c:881 | ||||
| msgid "Large Title Font" | ||||
| msgstr "Veľké písmo titulku" | ||||
|  | ||||
| #~ msgid "Button Layouts" | ||||
| #~ msgstr "Rozloženia tlačidiel" | ||||
| #: ../src/ui/theme-viewer.c:886 | ||||
| msgid "Button Layouts" | ||||
| msgstr "Rozloženia tlačidiel" | ||||
|  | ||||
| #~ msgid "Benchmark" | ||||
| #~ msgstr "Test rýchlosti" | ||||
| #: ../src/ui/theme-viewer.c:891 | ||||
| msgid "Benchmark" | ||||
| msgstr "Test rýchlosti" | ||||
|  | ||||
| #~ msgid "Window Title Goes Here" | ||||
| #~ msgstr "Sem príde názov okna" | ||||
| #: ../src/ui/theme-viewer.c:947 | ||||
| msgid "Window Title Goes Here" | ||||
| msgstr "Sem príde názov okna" | ||||
|  | ||||
| # PK: plural forms | ||||
| # JK: https://bugzilla.gnome.org/show_bug.cgi?id=697987 | ||||
| #, fuzzy | ||||
| #~ msgid "" | ||||
| #~ "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and " | ||||
| #~ "%g seconds wall clock time including X server resources (%g milliseconds " | ||||
| #~ "per frame)\n" | ||||
| #~ msgstr "" | ||||
| #~ "Vykreslených %d rámcov za %g sekúnd na strane klienta (%g milisekúnd na " | ||||
| #~ "rámec) a %g sekúnd celkového času vrátane zdrojov servera X (%g " | ||||
| #~ "milisekúnd na rámec)\n" | ||||
| #: ../src/ui/theme-viewer.c:1053 | ||||
| #, fuzzy, c-format | ||||
| msgid "" | ||||
| "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g " | ||||
| "seconds wall clock time including X server resources (%g milliseconds per " | ||||
| "frame)\n" | ||||
| msgstr "" | ||||
| "Vykreslených %d rámcov za %g sekúnd na strane klienta (%g milisekúnd na " | ||||
| "rámec) a %g sekúnd celkového času vrátane zdrojov servera X (%g milisekúnd " | ||||
| "na rámec)\n" | ||||
|  | ||||
| #~ msgid "position expression test returned TRUE but set error" | ||||
| #~ msgstr "test výrazu polohy vrátil TRUE, ale nastavil chybu" | ||||
| #: ../src/ui/theme-viewer.c:1273 | ||||
| msgid "position expression test returned TRUE but set error" | ||||
| msgstr "test výrazu polohy vrátil TRUE, ale nastavil chybu" | ||||
|  | ||||
| #~ msgid "position expression test returned FALSE but didn't set error" | ||||
| #~ msgstr "test výrazu polohy vrátil FALSE, ale nenastavil chybu" | ||||
| #: ../src/ui/theme-viewer.c:1275 | ||||
| msgid "position expression test returned FALSE but didn't set error" | ||||
| msgstr "test výrazu polohy vrátil FALSE, ale nenastavil chybu" | ||||
|  | ||||
| #~ msgid "Error was expected but none given" | ||||
| #~ msgstr "Bola očakávaná chyba, ale žiadna nenastala" | ||||
| #: ../src/ui/theme-viewer.c:1279 | ||||
| msgid "Error was expected but none given" | ||||
| msgstr "Bola očakávaná chyba, ale žiadna nenastala" | ||||
|  | ||||
| #~ msgid "Error %d was expected but %d given" | ||||
| #~ msgstr "Bola očakávaná chyba %d, ale nastala %d" | ||||
| #: ../src/ui/theme-viewer.c:1281 | ||||
| #, c-format | ||||
| msgid "Error %d was expected but %d given" | ||||
| msgstr "Bola očakávaná chyba %d, ale nastala %d" | ||||
|  | ||||
| #~ msgid "Error not expected but one was returned: %s" | ||||
| #~ msgstr "Chyba nebola očakávaná, ale bola vrátená: %s" | ||||
| #: ../src/ui/theme-viewer.c:1287 | ||||
| #, c-format | ||||
| msgid "Error not expected but one was returned: %s" | ||||
| msgstr "Chyba nebola očakávaná, ale bola vrátená: %s" | ||||
|  | ||||
| #~ msgid "x value was %d, %d was expected" | ||||
| #~ msgstr "hodnota x bola %d, očakávaná bola %d" | ||||
| #: ../src/ui/theme-viewer.c:1291 | ||||
| #, c-format | ||||
| msgid "x value was %d, %d was expected" | ||||
| msgstr "hodnota x bola %d, očakávaná bola %d" | ||||
|  | ||||
| #~ msgid "y value was %d, %d was expected" | ||||
| #~ msgstr "hodnota y bola %d, očakávaná bola %d" | ||||
| #: ../src/ui/theme-viewer.c:1294 | ||||
| #, c-format | ||||
| msgid "y value was %d, %d was expected" | ||||
| msgstr "hodnota y bola %d, očakávaná bola %d" | ||||
|  | ||||
| # PK: plural forms | ||||
| # JK: https://bugzilla.gnome.org/show_bug.cgi?id=697987 | ||||
| #, fuzzy | ||||
| #~ msgid "" | ||||
| #~ "%d coordinate expressions parsed in %g seconds (%g seconds average)\n" | ||||
| #~ msgstr "" | ||||
| #~ "%d výrazov pre súradnice analyzovaných za %g sekúnd (priemer %g sekúnd)\n" | ||||
| #: ../src/ui/theme-viewer.c:1359 | ||||
| #, fuzzy, c-format | ||||
| msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n" | ||||
| msgstr "" | ||||
| "%d výrazov pre súradnice analyzovaných za %g sekúnd (priemer %g sekúnd)\n" | ||||
|   | ||||
							
								
								
									
										425
									
								
								po/sr.po
									
									
									
									
									
								
							
							
						
						
									
										425
									
								
								po/sr.po
									
									
									
									
									
								
							| @@ -212,7 +212,7 @@ msgstr "Прикажите поделу на десно" | ||||
|  | ||||
| #. This probably means that a non-WM compositor like xcompmgr is running; | ||||
| #. * we have no way to get it to exit | ||||
| #: ../src/compositor/compositor.c:589 | ||||
| #: ../src/compositor/compositor.c:507 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Another compositing manager is already running on screen %i on display \"%s" | ||||
| @@ -220,11 +220,11 @@ msgid "" | ||||
| msgstr "" | ||||
| "Неки други композитни управник је већ покренут на приказу %i еркана „%s“." | ||||
|  | ||||
| #: ../src/compositor/meta-background.c:1076 | ||||
| #: ../src/compositor/meta-background.c:1111 | ||||
| msgid "background texture could not be created from file" | ||||
| msgstr "склоп позадине не може бити створен из датотеке" | ||||
|  | ||||
| #: ../src/core/bell.c:322 | ||||
| #: ../src/core/bell.c:320 | ||||
| msgid "Bell event" | ||||
| msgstr "Звонца" | ||||
|  | ||||
| @@ -258,17 +258,17 @@ msgstr "_Сачекај" | ||||
| msgid "_Force Quit" | ||||
| msgstr "_Приморај излаз" | ||||
|  | ||||
| #: ../src/core/display.c:421 | ||||
| #: ../src/core/display.c:401 | ||||
| #, c-format | ||||
| msgid "Missing %s extension required for compositing" | ||||
| msgstr "Недостаје потребан композитни додатак %s" | ||||
|  | ||||
| #: ../src/core/display.c:513 | ||||
| #: ../src/core/display.c:493 | ||||
| #, c-format | ||||
| msgid "Failed to open X Window System display '%s'\n" | ||||
| msgstr "Нисам успео да отворим екран „%s“ Икс система прозора\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1136 | ||||
| #: ../src/core/keybindings.c:929 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Some other program is already using the key %s with modifiers %x as a " | ||||
| @@ -277,41 +277,42 @@ msgstr "" | ||||
| "Неки други програм већ користи тастер %s са измењивачима %x за неку " | ||||
| "функцију\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1333 | ||||
| #: ../src/core/keybindings.c:1129 | ||||
| #, c-format | ||||
| #| msgid "\"%s\" is not a valid value for focus attribute" | ||||
| msgid "\"%s\" is not a valid accelerator\n" | ||||
| msgstr "„%s“ није исправна пречица\n" | ||||
|  | ||||
| #: ../src/core/main.c:197 | ||||
| #: ../src/core/main.c:196 | ||||
| msgid "Disable connection to session manager" | ||||
| msgstr "Искључује везу са управником сесије" | ||||
|  | ||||
| #: ../src/core/main.c:203 | ||||
| #: ../src/core/main.c:202 | ||||
| msgid "Replace the running window manager" | ||||
| msgstr "Мења текућег управника прозорима" | ||||
|  | ||||
| #: ../src/core/main.c:209 | ||||
| #: ../src/core/main.c:208 | ||||
| msgid "Specify session management ID" | ||||
| msgstr "Наводи ИБ управника сесије" | ||||
|  | ||||
| #: ../src/core/main.c:214 | ||||
| #: ../src/core/main.c:213 | ||||
| msgid "X Display to use" | ||||
| msgstr "Икс екран који ће бити коришћен" | ||||
|  | ||||
| #: ../src/core/main.c:220 | ||||
| #: ../src/core/main.c:219 | ||||
| msgid "Initialize session from savefile" | ||||
| msgstr "Покреће сесију из датотеке чувања" | ||||
|  | ||||
| #: ../src/core/main.c:226 | ||||
| #: ../src/core/main.c:225 | ||||
| msgid "Make X calls synchronous" | ||||
| msgstr "Чини Икс позиве усклађеним" | ||||
|  | ||||
| #: ../src/core/main.c:534 | ||||
| #: ../src/core/main.c:494 | ||||
| #, c-format | ||||
| msgid "Failed to scan themes directory: %s\n" | ||||
| msgstr "Нисам успео да прочитам директоријум тема: %s\n" | ||||
|  | ||||
| #: ../src/core/main.c:550 | ||||
| #: ../src/core/main.c:510 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not find a theme! Be sure %s exists and contains the usual themes.\n" | ||||
| @@ -356,7 +357,7 @@ msgstr "Исписује издање" | ||||
| msgid "Mutter plugin to use" | ||||
| msgstr "Прикључци Матера за коришћење" | ||||
|  | ||||
| #: ../src/core/prefs.c:1202 | ||||
| #: ../src/core/prefs.c:1087 | ||||
| msgid "" | ||||
| "Workarounds for broken applications disabled. Some applications may not " | ||||
| "behave properly.\n" | ||||
| @@ -364,12 +365,12 @@ msgstr "" | ||||
| "Решења за оштећене програме су искључена. Неке апликације се могу понашати " | ||||
| "чудно.\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1277 | ||||
| #: ../src/core/prefs.c:1162 | ||||
| #, c-format | ||||
| msgid "Could not parse font description \"%s\" from GSettings key %s\n" | ||||
| msgstr "Не могу да обрадим опис „%s“ из кључа „%s“ у Гномовим подешавањима\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1343 | ||||
| #: ../src/core/prefs.c:1228 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for mouse button " | ||||
| @@ -378,24 +379,24 @@ msgstr "" | ||||
| "„%s“ је пронађен у бази подешавања што није исправна вредност која мења " | ||||
| "понашање тастера миша\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1909 | ||||
| #: ../src/core/prefs.c:1780 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for keybinding " | ||||
| "\"%s\"\n" | ||||
| msgstr "„%s“ из базе са подешавањима није исправна комбинација тастера „%s“\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1999 | ||||
| #: ../src/core/prefs.c:1879 | ||||
| #, c-format | ||||
| msgid "Workspace %d" | ||||
| msgstr "%d. радни простор" | ||||
|  | ||||
| #: ../src/core/screen.c:534 | ||||
| #: ../src/core/screen.c:673 | ||||
| #, c-format | ||||
| msgid "Screen %d on display '%s' is invalid\n" | ||||
| msgstr "Приказ „%d“ на екрану „%s“ није исправан\n" | ||||
|  | ||||
| #: ../src/core/screen.c:550 | ||||
| #: ../src/core/screen.c:689 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Screen %d on display \"%s\" already has a window manager; try using the --" | ||||
| @@ -404,18 +405,18 @@ msgstr "" | ||||
| "Приказ „%d“ на екрану „%s“ већ има управника прозора; покушајте да користите " | ||||
| "опцију „--replace“ да замените тренутног управника прозора.\n" | ||||
|  | ||||
| #: ../src/core/screen.c:577 | ||||
| #: ../src/core/screen.c:716 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not acquire window manager selection on screen %d display \"%s\"\n" | ||||
| msgstr "Не могу да добијем избор управника прозора на приказу %d еркана „%s“\n" | ||||
|  | ||||
| #: ../src/core/screen.c:655 | ||||
| #: ../src/core/screen.c:794 | ||||
| #, c-format | ||||
| msgid "Screen %d on display \"%s\" already has a window manager\n" | ||||
| msgstr "Приказ %d на екрану „%s“ већ има управника прозора\n" | ||||
|  | ||||
| #: ../src/core/screen.c:846 | ||||
| #: ../src/core/screen.c:979 | ||||
| #, c-format | ||||
| msgid "Could not release screen %d on display \"%s\"\n" | ||||
| msgstr "Не могу да отпустим приказ %d на екрану „%s“\n" | ||||
| @@ -475,43 +476,44 @@ msgstr "" | ||||
| "Ови прозори не подржавају могућност „сачувај тренутна подешавања“ па ћете " | ||||
| "морати ручно да их поново покренете када се следећи пут пријавите." | ||||
|  | ||||
| #: ../src/core/util.c:84 | ||||
| #: ../src/core/util.c:80 | ||||
| #, c-format | ||||
| msgid "Failed to open debug log: %s\n" | ||||
| msgstr "Нисам успео да отворим дневник грешака: %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:94 | ||||
| #: ../src/core/util.c:90 | ||||
| #, c-format | ||||
| msgid "Failed to fdopen() log file %s: %s\n" | ||||
| msgstr "Нисам успео да „fdopen()“ датотеку дневника „%s“: %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:100 | ||||
| #: ../src/core/util.c:96 | ||||
| #, c-format | ||||
| msgid "Opened log file %s\n" | ||||
| msgstr "Отворена је датотека дневника „%s“\n" | ||||
|  | ||||
| #: ../src/core/util.c:119 | ||||
| #: ../src/core/util.c:115 ../src/tools/mutter-message.c:149 | ||||
| #, c-format | ||||
| msgid "Mutter was compiled without support for verbose mode\n" | ||||
| msgstr "Матер је преведен без подршке за опширан режим\n" | ||||
|  | ||||
| #: ../src/core/util.c:264 | ||||
| #: ../src/core/util.c:259 | ||||
| msgid "Window manager: " | ||||
| msgstr "Управник прозора: " | ||||
|  | ||||
| #: ../src/core/util.c:414 | ||||
| #: ../src/core/util.c:407 | ||||
| msgid "Bug in window manager: " | ||||
| msgstr "Грешка у управнику прозора: " | ||||
|  | ||||
| #: ../src/core/util.c:445 | ||||
| #: ../src/core/util.c:438 | ||||
| msgid "Window manager warning: " | ||||
| msgstr "Упозорење управника прозора: " | ||||
|  | ||||
| #: ../src/core/util.c:473 | ||||
| #: ../src/core/util.c:466 | ||||
| msgid "Window manager error: " | ||||
| msgstr "Грешка управника прозора: " | ||||
|  | ||||
| #. first time through | ||||
| #: ../src/core/window.c:7533 | ||||
| #: ../src/core/window.c:7539 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER " | ||||
| @@ -527,7 +529,7 @@ msgstr "" | ||||
| #. * MWM but not WM_NORMAL_HINTS are basically broken. We complain | ||||
| #. * about these apps but make them work. | ||||
| #. | ||||
| #: ../src/core/window.c:8257 | ||||
| #: ../src/core/window.c:8263 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets an MWM hint indicating it isn't resizable, but sets min size " | ||||
| @@ -537,22 +539,22 @@ msgstr "" | ||||
| "али је поставио најмању величину %d x %d и највећу величину %d x %d што нема " | ||||
| "много смисла.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:347 | ||||
| #: ../src/core/window-props.c:318 | ||||
| #, c-format | ||||
| msgid "Application set a bogus _NET_WM_PID %lu\n" | ||||
| msgstr "Програм је поставио нетачан _NET_WM_PID %lu\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:463 | ||||
| #: ../src/core/window-props.c:434 | ||||
| #, c-format | ||||
| msgid "%s (on %s)" | ||||
| msgstr "%s (на %s)" | ||||
|  | ||||
| #: ../src/core/window-props.c:1546 | ||||
| #: ../src/core/window-props.c:1517 | ||||
| #, c-format | ||||
| msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n" | ||||
| msgstr "Неисправан прозор 0x%lx наведен као WM_TRANSIENT_FOR за %s.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:1557 | ||||
| #: ../src/core/window-props.c:1528 | ||||
| #, c-format | ||||
| msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n" | ||||
| msgstr "WM_TRANSIENT_FOR прозор 0x%lx за %s ће направити петљу.\n" | ||||
| @@ -717,104 +719,109 @@ msgstr "Бира прозор из језичка искакања" | ||||
| msgid "Cancel tab popup" | ||||
| msgstr "Отказивање језичка искакања" | ||||
|  | ||||
| #: ../src/tools/mutter-message.c:123 | ||||
| #, c-format | ||||
| msgid "Usage: %s\n" | ||||
| msgstr "Употреба: %s\n" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:67 | ||||
| #: ../src/ui/menu.c:69 | ||||
| msgid "Mi_nimize" | ||||
| msgstr "У_мањи" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:69 | ||||
| #: ../src/ui/menu.c:71 | ||||
| msgid "Ma_ximize" | ||||
| msgstr "У_већај" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:71 | ||||
| #: ../src/ui/menu.c:73 | ||||
| msgid "Unma_ximize" | ||||
| msgstr "Поништи у_већање" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:73 | ||||
| #: ../src/ui/menu.c:75 | ||||
| msgid "Roll _Up" | ||||
| msgstr "_Замотај" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:75 | ||||
| #: ../src/ui/menu.c:77 | ||||
| msgid "_Unroll" | ||||
| msgstr "_Одмотај" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:77 | ||||
| #: ../src/ui/menu.c:79 | ||||
| msgid "_Move" | ||||
| msgstr "_Премести" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:79 | ||||
| #: ../src/ui/menu.c:81 | ||||
| msgid "_Resize" | ||||
| msgstr "П_ромени величину" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:81 | ||||
| #: ../src/ui/menu.c:83 | ||||
| msgid "Move Titlebar On_screen" | ||||
| msgstr "Премести траку _наслова на екран" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:84 ../src/ui/menu.c:86 | ||||
| #: ../src/ui/menu.c:86 ../src/ui/menu.c:88 | ||||
| msgid "Always on _Top" | ||||
| msgstr "Увек _изнад осталих" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:88 | ||||
| #: ../src/ui/menu.c:90 | ||||
| msgid "_Always on Visible Workspace" | ||||
| msgstr "_Увек на видљивом радном простору" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:90 | ||||
| #: ../src/ui/menu.c:92 | ||||
| msgid "_Only on This Workspace" | ||||
| msgstr "Само на _овом радном простору" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:92 | ||||
| #: ../src/ui/menu.c:94 | ||||
| msgid "Move to Workspace _Left" | ||||
| msgstr "Премести на радни простор ле_во" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:94 | ||||
| #: ../src/ui/menu.c:96 | ||||
| msgid "Move to Workspace R_ight" | ||||
| msgstr "Премести на радни простор де_сно" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:96 | ||||
| #: ../src/ui/menu.c:98 | ||||
| msgid "Move to Workspace _Up" | ||||
| msgstr "Премести на радни простор го_ре" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:98 | ||||
| #: ../src/ui/menu.c:100 | ||||
| msgid "Move to Workspace _Down" | ||||
| msgstr "Премести на радни простор до_ле" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:102 | ||||
| #: ../src/ui/menu.c:104 | ||||
| msgid "_Close" | ||||
| msgstr "_Затвори" | ||||
|  | ||||
| #: ../src/ui/menu.c:202 | ||||
| #: ../src/ui/menu.c:204 | ||||
| #, c-format | ||||
| msgid "Workspace %d%n" | ||||
| msgstr "Радни простор %d%n" | ||||
|  | ||||
| #: ../src/ui/menu.c:212 | ||||
| #: ../src/ui/menu.c:214 | ||||
| #, c-format | ||||
| msgid "Workspace 1_0" | ||||
| msgstr "1_0. радни простор" | ||||
|  | ||||
| #: ../src/ui/menu.c:214 | ||||
| #: ../src/ui/menu.c:216 | ||||
| #, c-format | ||||
| msgid "Workspace %s%d" | ||||
| msgstr "%s%d. радни простор" | ||||
|  | ||||
| #: ../src/ui/menu.c:384 | ||||
| #: ../src/ui/menu.c:397 | ||||
| msgid "Move to Another _Workspace" | ||||
| msgstr "Премести на други _радни простор" | ||||
|  | ||||
| @@ -916,48 +923,48 @@ msgstr "Мод5" | ||||
| msgid "%d x %d" | ||||
| msgstr "%d x %d" | ||||
|  | ||||
| #: ../src/ui/theme.c:236 | ||||
| #: ../src/ui/theme.c:235 | ||||
| msgid "top" | ||||
| msgstr "горњу" | ||||
|  | ||||
| #: ../src/ui/theme.c:238 | ||||
| #: ../src/ui/theme.c:237 | ||||
| msgid "bottom" | ||||
| msgstr "доњу" | ||||
|  | ||||
| #: ../src/ui/theme.c:240 | ||||
| #: ../src/ui/theme.c:239 | ||||
| msgid "left" | ||||
| msgstr "леву" | ||||
|  | ||||
| #: ../src/ui/theme.c:242 | ||||
| #: ../src/ui/theme.c:241 | ||||
| msgid "right" | ||||
| msgstr "десну" | ||||
|  | ||||
| #: ../src/ui/theme.c:270 | ||||
| #: ../src/ui/theme.c:269 | ||||
| #, c-format | ||||
| msgid "frame geometry does not specify \"%s\" dimension" | ||||
| msgstr "геометрија оквира не подешава „%s“ димензију" | ||||
|  | ||||
| #: ../src/ui/theme.c:289 | ||||
| #: ../src/ui/theme.c:288 | ||||
| #, c-format | ||||
| msgid "frame geometry does not specify dimension \"%s\" for border \"%s\"" | ||||
| msgstr "геометрија оквира не подешава „%s“ димензију за ивицу „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:326 | ||||
| #: ../src/ui/theme.c:325 | ||||
| #, c-format | ||||
| msgid "Button aspect ratio %g is not reasonable" | ||||
| msgstr "Однос размере дугмета %g није разуман" | ||||
|  | ||||
| #: ../src/ui/theme.c:338 | ||||
| #: ../src/ui/theme.c:337 | ||||
| #, c-format | ||||
| msgid "Frame geometry does not specify size of buttons" | ||||
| msgstr "Геометрија оквира не подешава величину дугмића" | ||||
|  | ||||
| #: ../src/ui/theme.c:1051 | ||||
| #: ../src/ui/theme.c:1050 | ||||
| #, c-format | ||||
| msgid "Gradients should have at least two colors" | ||||
| msgstr "Преливи морају имати најмање две боје" | ||||
|  | ||||
| #: ../src/ui/theme.c:1203 | ||||
| #: ../src/ui/theme.c:1202 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK custom color specification must have color name and fallback in " | ||||
| @@ -966,7 +973,7 @@ msgstr "" | ||||
| "Спецификација произвољне ГТК боје мора имати назив боје и пребацивање у " | ||||
| "загради, на пример gtk:custom(foo,bar); не могу да обрадим „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1219 | ||||
| #: ../src/ui/theme.c:1218 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-" | ||||
| @@ -975,7 +982,7 @@ msgstr "" | ||||
| "Неисправан знак „%c“ параметра назив_боје у gtk:custom, иасправни су само A-" | ||||
| "Za-z0-9-_" | ||||
|  | ||||
| #: ../src/ui/theme.c:1233 | ||||
| #: ../src/ui/theme.c:1232 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not " | ||||
| @@ -984,7 +991,7 @@ msgstr "" | ||||
| "Гтк:произвољни формат је „gtk:custom(назив_боје,пребацивање)“, „%s“ се не " | ||||
| "уклапа у формат" | ||||
|  | ||||
| #: ../src/ui/theme.c:1278 | ||||
| #: ../src/ui/theme.c:1277 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] " | ||||
| @@ -993,7 +1000,7 @@ msgstr "" | ||||
| "Спецификација ГТК боје мора имати наведено стање у загради, на пример „gtk:fg" | ||||
| "[NORMAL]“ где је „NORMAL“ стање; не могу да обрадим „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1292 | ||||
| #: ../src/ui/theme.c:1291 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK color specification must have a close bracket after the state, e.g. gtk:" | ||||
| @@ -1002,17 +1009,17 @@ msgstr "" | ||||
| "Спецификација ГТК боје мора имати наведено стање у загради, на пример „gtk:fg" | ||||
| "[NORMAL]“ где је „NORMAL“ стање; не могу да обрадим „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1303 | ||||
| #: ../src/ui/theme.c:1302 | ||||
| #, c-format | ||||
| msgid "Did not understand state \"%s\" in color specification" | ||||
| msgstr "Нисам разумео стање „%s“ у спецификацији боје" | ||||
|  | ||||
| #: ../src/ui/theme.c:1316 | ||||
| #: ../src/ui/theme.c:1315 | ||||
| #, c-format | ||||
| msgid "Did not understand color component \"%s\" in color specification" | ||||
| msgstr "Нисам разумео део боје „%s“ у спецификацији боје" | ||||
|  | ||||
| #: ../src/ui/theme.c:1345 | ||||
| #: ../src/ui/theme.c:1344 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the " | ||||
| @@ -1021,55 +1028,55 @@ msgstr "" | ||||
| "Формат смеше је „blend/bg_color/fg_color/alpha“, „%s“ се не уклапа у тражени " | ||||
| "формат записа" | ||||
|  | ||||
| #: ../src/ui/theme.c:1356 | ||||
| #: ../src/ui/theme.c:1355 | ||||
| #, c-format | ||||
| msgid "Could not parse alpha value \"%s\" in blended color" | ||||
| msgstr "Не могу да обрадим алфа вредност „%s“ у смешаној боји" | ||||
|  | ||||
| #: ../src/ui/theme.c:1366 | ||||
| #: ../src/ui/theme.c:1365 | ||||
| #, c-format | ||||
| msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0" | ||||
| msgstr "Алфа вредност „%s“ у смешаној боји није између 0.0 и 1.0" | ||||
|  | ||||
| #: ../src/ui/theme.c:1413 | ||||
| #: ../src/ui/theme.c:1412 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format" | ||||
| msgstr "Формат сенке је „shade/base_color/factor“, „%s“ се не уклапа у формат" | ||||
|  | ||||
| #: ../src/ui/theme.c:1424 | ||||
| #: ../src/ui/theme.c:1423 | ||||
| #, c-format | ||||
| msgid "Could not parse shade factor \"%s\" in shaded color" | ||||
| msgstr "Не могу да обрадим фактор сенке „%s“ у осенченој боји" | ||||
|  | ||||
| #: ../src/ui/theme.c:1434 | ||||
| #: ../src/ui/theme.c:1433 | ||||
| #, c-format | ||||
| msgid "Shade factor \"%s\" in shaded color is negative" | ||||
| msgstr "Фактор сенке „%s“ у осенченој боји је негативан" | ||||
|  | ||||
| #: ../src/ui/theme.c:1463 | ||||
| #: ../src/ui/theme.c:1462 | ||||
| #, c-format | ||||
| msgid "Could not parse color \"%s\"" | ||||
| msgstr "Не могу да обрадим боју „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1780 | ||||
| #: ../src/ui/theme.c:1779 | ||||
| #, c-format | ||||
| msgid "Coordinate expression contains character '%s' which is not allowed" | ||||
| msgstr "Израз координата садржи знак „%s“ који није дозвољен" | ||||
|  | ||||
| #: ../src/ui/theme.c:1807 | ||||
| #: ../src/ui/theme.c:1806 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression contains floating point number '%s' which could not be " | ||||
| "parsed" | ||||
| msgstr "Израз координата садржи децимални број „%s“ који не може бити обрађен" | ||||
|  | ||||
| #: ../src/ui/theme.c:1821 | ||||
| #: ../src/ui/theme.c:1820 | ||||
| #, c-format | ||||
| msgid "Coordinate expression contains integer '%s' which could not be parsed" | ||||
| msgstr "Израз координата садржи цели број „%s“ који не може бити обрађен" | ||||
|  | ||||
| #: ../src/ui/theme.c:1942 | ||||
| #: ../src/ui/theme.c:1941 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression contained unknown operator at the start of this text: " | ||||
| @@ -1077,17 +1084,17 @@ msgid "" | ||||
| msgstr "" | ||||
| "Израз са координатама садржи непознати оператор на почетку овог текста: „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1999 | ||||
| #: ../src/ui/theme.c:1998 | ||||
| #, c-format | ||||
| msgid "Coordinate expression was empty or not understood" | ||||
| msgstr "Израз са координатама је био празан или неразумљив" | ||||
|  | ||||
| #: ../src/ui/theme.c:2112 ../src/ui/theme.c:2122 ../src/ui/theme.c:2156 | ||||
| #: ../src/ui/theme.c:2111 ../src/ui/theme.c:2121 ../src/ui/theme.c:2155 | ||||
| #, c-format | ||||
| msgid "Coordinate expression results in division by zero" | ||||
| msgstr "Израз са координатама резултира у дељењу нулом" | ||||
|  | ||||
| #: ../src/ui/theme.c:2164 | ||||
| #: ../src/ui/theme.c:2163 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression tries to use mod operator on a floating-point number" | ||||
| @@ -1095,23 +1102,23 @@ msgstr "" | ||||
| "Израз са координатам покушава да користи оператор остатка при дељењу за " | ||||
| "децимални број" | ||||
|  | ||||
| #: ../src/ui/theme.c:2220 | ||||
| #: ../src/ui/theme.c:2219 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression has an operator \"%s\" where an operand was expected" | ||||
| msgstr "Израз са координатама има оператор „%s“ где је очекиван операнд" | ||||
|  | ||||
| #: ../src/ui/theme.c:2229 | ||||
| #: ../src/ui/theme.c:2228 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had an operand where an operator was expected" | ||||
| msgstr "Израз са координатама имаше операнд где је очекиван оператор" | ||||
|  | ||||
| #: ../src/ui/theme.c:2237 | ||||
| #: ../src/ui/theme.c:2236 | ||||
| #, c-format | ||||
| msgid "Coordinate expression ended with an operator instead of an operand" | ||||
| msgstr "Израз са координарама је завршио са оператором уместо са операндом" | ||||
|  | ||||
| #: ../src/ui/theme.c:2247 | ||||
| #: ../src/ui/theme.c:2246 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression has operator \"%c\" following operator \"%c\" with no " | ||||
| @@ -1120,37 +1127,37 @@ msgstr "" | ||||
| "Израз са координатама има оператор „%c“, а затим оператор „%c“ без операнда " | ||||
| "између" | ||||
|  | ||||
| #: ../src/ui/theme.c:2398 ../src/ui/theme.c:2443 | ||||
| #: ../src/ui/theme.c:2397 ../src/ui/theme.c:2442 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had unknown variable or constant \"%s\"" | ||||
| msgstr "Израз са координатама има непознату променљиву или константи „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:2497 | ||||
| #: ../src/ui/theme.c:2496 | ||||
| #, c-format | ||||
| msgid "Coordinate expression parser overflowed its buffer." | ||||
| msgstr "Израз са координатама је био превелики за смештај и обраду." | ||||
|  | ||||
| #: ../src/ui/theme.c:2526 | ||||
| #: ../src/ui/theme.c:2525 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had a close parenthesis with no open parenthesis" | ||||
| msgstr "Израз са координатама има затворене заграде без отворених заграда" | ||||
|  | ||||
| #: ../src/ui/theme.c:2590 | ||||
| #: ../src/ui/theme.c:2589 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had an open parenthesis with no close parenthesis" | ||||
| msgstr "Израз са координатама има отворену заграду без затворене заграде" | ||||
|  | ||||
| #: ../src/ui/theme.c:2601 | ||||
| #: ../src/ui/theme.c:2600 | ||||
| #, c-format | ||||
| msgid "Coordinate expression doesn't seem to have any operators or operands" | ||||
| msgstr "Израз са координатама изгледа да нема ни један оператор или операнд" | ||||
|  | ||||
| #: ../src/ui/theme.c:2814 ../src/ui/theme.c:2834 ../src/ui/theme.c:2854 | ||||
| #: ../src/ui/theme.c:2813 ../src/ui/theme.c:2833 ../src/ui/theme.c:2853 | ||||
| #, c-format | ||||
| msgid "Theme contained an expression that resulted in an error: %s\n" | ||||
| msgstr "Тема садржи израз који резултира грешком: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:4500 | ||||
| #: ../src/ui/theme.c:4499 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be " | ||||
| @@ -1159,25 +1166,25 @@ msgstr "" | ||||
| "<button function=„%s“ state=„%s“ draw_ops=\"whatever\"/> мора бити наведен " | ||||
| "за овај стил оквира" | ||||
|  | ||||
| #: ../src/ui/theme.c:5011 ../src/ui/theme.c:5036 | ||||
| #: ../src/ui/theme.c:5010 ../src/ui/theme.c:5035 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>" | ||||
| msgstr "" | ||||
| "Недостаје <frame state=„%s“ resize=„%s“ focus=„%s“ style=\"whatever\"/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5082 | ||||
| #: ../src/ui/theme.c:5083 | ||||
| #, c-format | ||||
| msgid "Failed to load theme \"%s\": %s\n" | ||||
| msgstr "Нисам успео да учитам тему „%s“: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232 | ||||
| #: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246 | ||||
| #: ../src/ui/theme.c:5219 ../src/ui/theme.c:5226 ../src/ui/theme.c:5233 | ||||
| #: ../src/ui/theme.c:5240 ../src/ui/theme.c:5247 | ||||
| #, c-format | ||||
| msgid "No <%s> set for theme \"%s\"" | ||||
| msgstr "Није дефинисан елемент <%s> за тему „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:5254 | ||||
| #: ../src/ui/theme.c:5255 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "No frame style set for window type \"%s\" in theme \"%s\", add a <window " | ||||
| @@ -1186,14 +1193,14 @@ msgstr "" | ||||
| "Није подешен стил оквира за прозор типа „%s“ у теми „%s“. Додајте <window " | ||||
| "type=„%s“ style_set=\"whatever\"/> елемент" | ||||
|  | ||||
| #: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786 | ||||
| #: ../src/ui/theme.c:5662 ../src/ui/theme.c:5724 ../src/ui/theme.c:5787 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "User-defined constants must begin with a capital letter; \"%s\" does not" | ||||
| msgstr "" | ||||
| "Кориснички дефинисане константе морају почети великим словом; „%s“ не почиње" | ||||
|  | ||||
| #: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794 | ||||
| #: ../src/ui/theme.c:5670 ../src/ui/theme.c:5732 ../src/ui/theme.c:5795 | ||||
| #, c-format | ||||
| msgid "Constant \"%s\" has already been defined" | ||||
| msgstr "Константа „%s“ је већ дефинисана" | ||||
| @@ -1576,7 +1583,209 @@ msgstr "Није дозвољен текст унутар елемента <%s>" | ||||
| msgid "<%s> specified twice for this theme" | ||||
| msgstr "<%s> је наведен два пута у овој теми" | ||||
|  | ||||
| #: ../src/ui/theme-parser.c:4336 | ||||
| #: ../src/ui/theme-parser.c:4334 | ||||
| #, c-format | ||||
| msgid "Failed to find a valid file for theme %s\n" | ||||
| msgstr "Нисам успео да пронађем исправну датотеку за тему „%s“\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:99 | ||||
| msgid "_Windows" | ||||
| msgstr "_Прозори" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:100 | ||||
| msgid "_Dialog" | ||||
| msgstr "_Прозорче" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:101 | ||||
| msgid "_Modal dialog" | ||||
| msgstr "_Важно прозорче" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:102 | ||||
| msgid "_Utility" | ||||
| msgstr "_Алатка" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:103 | ||||
| msgid "_Splashscreen" | ||||
| msgstr "_Уводни екран" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:104 | ||||
| msgid "_Top dock" | ||||
| msgstr "_Горње припајање" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:105 | ||||
| msgid "_Bottom dock" | ||||
| msgstr "_Доње припајање" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:106 | ||||
| msgid "_Left dock" | ||||
| msgstr "_Лево припајање" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:107 | ||||
| msgid "_Right dock" | ||||
| msgstr "Д_есно припајање" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:108 | ||||
| msgid "_All docks" | ||||
| msgstr "_Сва припајања" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:109 | ||||
| msgid "Des_ktop" | ||||
| msgstr "_Радна површ" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:115 | ||||
| msgid "Open another one of these windows" | ||||
| msgstr "Отвори неки други од ових прозора" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:117 | ||||
| msgid "This is a demo button with an 'open' icon" | ||||
| msgstr "Ово је пробно дугме са „отвори“ иконом" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:119 | ||||
| msgid "This is a demo button with a 'quit' icon" | ||||
| msgstr "Ово је пробно дугме са „изађи“ иконицом" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:248 | ||||
| msgid "This is a sample message in a sample dialog" | ||||
| msgstr "Ово је пример поруке у пробном прозорчету" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:328 | ||||
| #, c-format | ||||
| msgid "Fake menu item %d\n" | ||||
| msgstr "Лажна ставка изборника %d\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:363 | ||||
| msgid "Border-only window" | ||||
| msgstr "Прозор само са ивицом" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:365 | ||||
| msgid "Bar" | ||||
| msgstr "Трака" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:382 | ||||
| msgid "Normal Application Window" | ||||
| msgstr "Обичан прозор програма" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:386 | ||||
| msgid "Dialog Box" | ||||
| msgstr "Прозорче" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:390 | ||||
| msgid "Modal Dialog Box" | ||||
| msgstr "Важно прозорче" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:394 | ||||
| msgid "Utility Palette" | ||||
| msgstr "Палета алата" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:398 | ||||
| msgid "Torn-off Menu" | ||||
| msgstr "Откинути изборник" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:402 | ||||
| msgid "Border" | ||||
| msgstr "Ивица" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:406 | ||||
| msgid "Attached Modal Dialog" | ||||
| msgstr "Приложено важно прозорче" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:737 | ||||
| #, c-format | ||||
| msgid "Button layout test %d" | ||||
| msgstr "Проба распореда дугмића %d" | ||||
|  | ||||
| # bug: plural-forms | ||||
| #: ../src/ui/theme-viewer.c:766 | ||||
| #, c-format | ||||
| msgid "%g milliseconds to draw one window frame" | ||||
| msgstr "%g милисекунди за исцртавање оквира једног прозора" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:811 | ||||
| #, c-format | ||||
| msgid "Usage: metacity-theme-viewer [THEMENAME]\n" | ||||
| msgstr "Употреба: metacity-theme-viewer [НАЗИВ_ТЕМЕ]\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:818 | ||||
| #, c-format | ||||
| msgid "Error loading theme: %s\n" | ||||
| msgstr "Грешка приликом учитавања теме: %s\n" | ||||
|  | ||||
| # bug: plural-forms | ||||
| #: ../src/ui/theme-viewer.c:824 | ||||
| #, c-format | ||||
| msgid "Loaded theme \"%s\" in %g seconds\n" | ||||
| msgstr "Учитана је тема „%s“ за %g секунде\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:869 | ||||
| msgid "Normal Title Font" | ||||
| msgstr "Обичан словни лик наслова" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:875 | ||||
| msgid "Small Title Font" | ||||
| msgstr "Мали словни лик наслова" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:881 | ||||
| msgid "Large Title Font" | ||||
| msgstr "Велики словни лик наслова" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:886 | ||||
| msgid "Button Layouts" | ||||
| msgstr "Распоред дугмића" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:891 | ||||
| msgid "Benchmark" | ||||
| msgstr "Провера брзине" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:947 | ||||
| msgid "Window Title Goes Here" | ||||
| msgstr "Овде иде наслов прозора" | ||||
|  | ||||
| # bug: plural-forms | ||||
| #: ../src/ui/theme-viewer.c:1053 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g " | ||||
| "seconds wall clock time including X server resources (%g milliseconds per " | ||||
| "frame)\n" | ||||
| msgstr "" | ||||
| "Нацртао је %d оквира за %g клијентских секунди (%g милисекунди по оквиру) и " | ||||
| "%g секунди времена на зидном часовнику укључујући и ресурсе Икс сервера (%g " | ||||
| "милисекунди по оквиру)\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1273 | ||||
| msgid "position expression test returned TRUE but set error" | ||||
| msgstr "провера израза положаја је вратила тачно, али је поставила грешку" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1275 | ||||
| msgid "position expression test returned FALSE but didn't set error" | ||||
| msgstr "провера израза положаја је вратила нетачно, али није поставила грешку" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1279 | ||||
| msgid "Error was expected but none given" | ||||
| msgstr "Очекивана је грешка, али није дата" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1281 | ||||
| #, c-format | ||||
| msgid "Error %d was expected but %d given" | ||||
| msgstr "Очекивана је грешка „%d“, али је дата „%d“" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1287 | ||||
| #, c-format | ||||
| msgid "Error not expected but one was returned: %s" | ||||
| msgstr "Грешка није очекивана, али је враћена једна: %s" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1291 | ||||
| #, c-format | ||||
| msgid "x value was %d, %d was expected" | ||||
| msgstr "x вредност је била „%d“, а очекивана је „%d“" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1294 | ||||
| #, c-format | ||||
| msgid "y value was %d, %d was expected" | ||||
| msgstr "y вредност је била „%d“, а очекивана је „%d“" | ||||
|  | ||||
| # bug: plural-forms | ||||
| #: ../src/ui/theme-viewer.c:1359 | ||||
| #, c-format | ||||
| msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n" | ||||
| msgstr "%d израза координата је обрађено за %g секунде (просек %g секунде)\n" | ||||
|   | ||||
							
								
								
									
										425
									
								
								po/sr@latin.po
									
									
									
									
									
								
							
							
						
						
									
										425
									
								
								po/sr@latin.po
									
									
									
									
									
								
							| @@ -212,7 +212,7 @@ msgstr "Prikažite podelu na desno" | ||||
|  | ||||
| #. This probably means that a non-WM compositor like xcompmgr is running; | ||||
| #. * we have no way to get it to exit | ||||
| #: ../src/compositor/compositor.c:589 | ||||
| #: ../src/compositor/compositor.c:507 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Another compositing manager is already running on screen %i on display \"%s" | ||||
| @@ -220,11 +220,11 @@ msgid "" | ||||
| msgstr "" | ||||
| "Neki drugi kompozitni upravnik je već pokrenut na prikazu %i erkana „%s“." | ||||
|  | ||||
| #: ../src/compositor/meta-background.c:1076 | ||||
| #: ../src/compositor/meta-background.c:1111 | ||||
| msgid "background texture could not be created from file" | ||||
| msgstr "sklop pozadine ne može biti stvoren iz datoteke" | ||||
|  | ||||
| #: ../src/core/bell.c:322 | ||||
| #: ../src/core/bell.c:320 | ||||
| msgid "Bell event" | ||||
| msgstr "Zvonca" | ||||
|  | ||||
| @@ -258,17 +258,17 @@ msgstr "_Sačekaj" | ||||
| msgid "_Force Quit" | ||||
| msgstr "_Primoraj izlaz" | ||||
|  | ||||
| #: ../src/core/display.c:421 | ||||
| #: ../src/core/display.c:401 | ||||
| #, c-format | ||||
| msgid "Missing %s extension required for compositing" | ||||
| msgstr "Nedostaje potreban kompozitni dodatak %s" | ||||
|  | ||||
| #: ../src/core/display.c:513 | ||||
| #: ../src/core/display.c:493 | ||||
| #, c-format | ||||
| msgid "Failed to open X Window System display '%s'\n" | ||||
| msgstr "Nisam uspeo da otvorim ekran „%s“ Iks sistema prozora\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1136 | ||||
| #: ../src/core/keybindings.c:929 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Some other program is already using the key %s with modifiers %x as a " | ||||
| @@ -277,41 +277,42 @@ msgstr "" | ||||
| "Neki drugi program već koristi taster %s sa izmenjivačima %x za neku " | ||||
| "funkciju\n" | ||||
|  | ||||
| #: ../src/core/keybindings.c:1333 | ||||
| #: ../src/core/keybindings.c:1129 | ||||
| #, c-format | ||||
| #| msgid "\"%s\" is not a valid value for focus attribute" | ||||
| msgid "\"%s\" is not a valid accelerator\n" | ||||
| msgstr "„%s“ nije ispravna prečica\n" | ||||
|  | ||||
| #: ../src/core/main.c:197 | ||||
| #: ../src/core/main.c:196 | ||||
| msgid "Disable connection to session manager" | ||||
| msgstr "Isključuje vezu sa upravnikom sesije" | ||||
|  | ||||
| #: ../src/core/main.c:203 | ||||
| #: ../src/core/main.c:202 | ||||
| msgid "Replace the running window manager" | ||||
| msgstr "Menja tekućeg upravnika prozorima" | ||||
|  | ||||
| #: ../src/core/main.c:209 | ||||
| #: ../src/core/main.c:208 | ||||
| msgid "Specify session management ID" | ||||
| msgstr "Navodi IB upravnika sesije" | ||||
|  | ||||
| #: ../src/core/main.c:214 | ||||
| #: ../src/core/main.c:213 | ||||
| msgid "X Display to use" | ||||
| msgstr "Iks ekran koji će biti korišćen" | ||||
|  | ||||
| #: ../src/core/main.c:220 | ||||
| #: ../src/core/main.c:219 | ||||
| msgid "Initialize session from savefile" | ||||
| msgstr "Pokreće sesiju iz datoteke čuvanja" | ||||
|  | ||||
| #: ../src/core/main.c:226 | ||||
| #: ../src/core/main.c:225 | ||||
| msgid "Make X calls synchronous" | ||||
| msgstr "Čini Iks pozive usklađenim" | ||||
|  | ||||
| #: ../src/core/main.c:534 | ||||
| #: ../src/core/main.c:494 | ||||
| #, c-format | ||||
| msgid "Failed to scan themes directory: %s\n" | ||||
| msgstr "Nisam uspeo da pročitam direktorijum tema: %s\n" | ||||
|  | ||||
| #: ../src/core/main.c:550 | ||||
| #: ../src/core/main.c:510 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not find a theme! Be sure %s exists and contains the usual themes.\n" | ||||
| @@ -356,7 +357,7 @@ msgstr "Ispisuje izdanje" | ||||
| msgid "Mutter plugin to use" | ||||
| msgstr "Priključci Matera za korišćenje" | ||||
|  | ||||
| #: ../src/core/prefs.c:1202 | ||||
| #: ../src/core/prefs.c:1087 | ||||
| msgid "" | ||||
| "Workarounds for broken applications disabled. Some applications may not " | ||||
| "behave properly.\n" | ||||
| @@ -364,12 +365,12 @@ msgstr "" | ||||
| "Rešenja za oštećene programe su isključena. Neke aplikacije se mogu ponašati " | ||||
| "čudno.\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1277 | ||||
| #: ../src/core/prefs.c:1162 | ||||
| #, c-format | ||||
| msgid "Could not parse font description \"%s\" from GSettings key %s\n" | ||||
| msgstr "Ne mogu da obradim opis „%s“ iz ključa „%s“ u Gnomovim podešavanjima\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1343 | ||||
| #: ../src/core/prefs.c:1228 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for mouse button " | ||||
| @@ -378,24 +379,24 @@ msgstr "" | ||||
| "„%s“ je pronađen u bazi podešavanja što nije ispravna vrednost koja menja " | ||||
| "ponašanje tastera miša\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1909 | ||||
| #: ../src/core/prefs.c:1780 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "\"%s\" found in configuration database is not a valid value for keybinding " | ||||
| "\"%s\"\n" | ||||
| msgstr "„%s“ iz baze sa podešavanjima nije ispravna kombinacija tastera „%s“\n" | ||||
|  | ||||
| #: ../src/core/prefs.c:1999 | ||||
| #: ../src/core/prefs.c:1879 | ||||
| #, c-format | ||||
| msgid "Workspace %d" | ||||
| msgstr "%d. radni prostor" | ||||
|  | ||||
| #: ../src/core/screen.c:534 | ||||
| #: ../src/core/screen.c:673 | ||||
| #, c-format | ||||
| msgid "Screen %d on display '%s' is invalid\n" | ||||
| msgstr "Prikaz „%d“ na ekranu „%s“ nije ispravan\n" | ||||
|  | ||||
| #: ../src/core/screen.c:550 | ||||
| #: ../src/core/screen.c:689 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Screen %d on display \"%s\" already has a window manager; try using the --" | ||||
| @@ -404,18 +405,18 @@ msgstr "" | ||||
| "Prikaz „%d“ na ekranu „%s“ već ima upravnika prozora; pokušajte da koristite " | ||||
| "opciju „--replace“ da zamenite trenutnog upravnika prozora.\n" | ||||
|  | ||||
| #: ../src/core/screen.c:577 | ||||
| #: ../src/core/screen.c:716 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Could not acquire window manager selection on screen %d display \"%s\"\n" | ||||
| msgstr "Ne mogu da dobijem izbor upravnika prozora na prikazu %d erkana „%s“\n" | ||||
|  | ||||
| #: ../src/core/screen.c:655 | ||||
| #: ../src/core/screen.c:794 | ||||
| #, c-format | ||||
| msgid "Screen %d on display \"%s\" already has a window manager\n" | ||||
| msgstr "Prikaz %d na ekranu „%s“ već ima upravnika prozora\n" | ||||
|  | ||||
| #: ../src/core/screen.c:846 | ||||
| #: ../src/core/screen.c:979 | ||||
| #, c-format | ||||
| msgid "Could not release screen %d on display \"%s\"\n" | ||||
| msgstr "Ne mogu da otpustim prikaz %d na ekranu „%s“\n" | ||||
| @@ -475,43 +476,44 @@ msgstr "" | ||||
| "Ovi prozori ne podržavaju mogućnost „sačuvaj trenutna podešavanja“ pa ćete " | ||||
| "morati ručno da ih ponovo pokrenete kada se sledeći put prijavite." | ||||
|  | ||||
| #: ../src/core/util.c:84 | ||||
| #: ../src/core/util.c:80 | ||||
| #, c-format | ||||
| msgid "Failed to open debug log: %s\n" | ||||
| msgstr "Nisam uspeo da otvorim dnevnik grešaka: %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:94 | ||||
| #: ../src/core/util.c:90 | ||||
| #, c-format | ||||
| msgid "Failed to fdopen() log file %s: %s\n" | ||||
| msgstr "Nisam uspeo da „fdopen()“ datoteku dnevnika „%s“: %s\n" | ||||
|  | ||||
| #: ../src/core/util.c:100 | ||||
| #: ../src/core/util.c:96 | ||||
| #, c-format | ||||
| msgid "Opened log file %s\n" | ||||
| msgstr "Otvorena je datoteka dnevnika „%s“\n" | ||||
|  | ||||
| #: ../src/core/util.c:119 | ||||
| #: ../src/core/util.c:115 ../src/tools/mutter-message.c:149 | ||||
| #, c-format | ||||
| msgid "Mutter was compiled without support for verbose mode\n" | ||||
| msgstr "Mater je preveden bez podrške za opširan režim\n" | ||||
|  | ||||
| #: ../src/core/util.c:264 | ||||
| #: ../src/core/util.c:259 | ||||
| msgid "Window manager: " | ||||
| msgstr "Upravnik prozora: " | ||||
|  | ||||
| #: ../src/core/util.c:414 | ||||
| #: ../src/core/util.c:407 | ||||
| msgid "Bug in window manager: " | ||||
| msgstr "Greška u upravniku prozora: " | ||||
|  | ||||
| #: ../src/core/util.c:445 | ||||
| #: ../src/core/util.c:438 | ||||
| msgid "Window manager warning: " | ||||
| msgstr "Upozorenje upravnika prozora: " | ||||
|  | ||||
| #: ../src/core/util.c:473 | ||||
| #: ../src/core/util.c:466 | ||||
| msgid "Window manager error: " | ||||
| msgstr "Greška upravnika prozora: " | ||||
|  | ||||
| #. first time through | ||||
| #: ../src/core/window.c:7533 | ||||
| #: ../src/core/window.c:7539 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER " | ||||
| @@ -527,7 +529,7 @@ msgstr "" | ||||
| #. * MWM but not WM_NORMAL_HINTS are basically broken. We complain | ||||
| #. * about these apps but make them work. | ||||
| #. | ||||
| #: ../src/core/window.c:8257 | ||||
| #: ../src/core/window.c:8263 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Window %s sets an MWM hint indicating it isn't resizable, but sets min size " | ||||
| @@ -537,22 +539,22 @@ msgstr "" | ||||
| "ali je postavio najmanju veličinu %d x %d i najveću veličinu %d x %d što nema " | ||||
| "mnogo smisla.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:347 | ||||
| #: ../src/core/window-props.c:318 | ||||
| #, c-format | ||||
| msgid "Application set a bogus _NET_WM_PID %lu\n" | ||||
| msgstr "Program je postavio netačan _NET_WM_PID %lu\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:463 | ||||
| #: ../src/core/window-props.c:434 | ||||
| #, c-format | ||||
| msgid "%s (on %s)" | ||||
| msgstr "%s (na %s)" | ||||
|  | ||||
| #: ../src/core/window-props.c:1546 | ||||
| #: ../src/core/window-props.c:1517 | ||||
| #, c-format | ||||
| msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n" | ||||
| msgstr "Neispravan prozor 0x%lx naveden kao WM_TRANSIENT_FOR za %s.\n" | ||||
|  | ||||
| #: ../src/core/window-props.c:1557 | ||||
| #: ../src/core/window-props.c:1528 | ||||
| #, c-format | ||||
| msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n" | ||||
| msgstr "WM_TRANSIENT_FOR prozor 0x%lx za %s će napraviti petlju.\n" | ||||
| @@ -717,104 +719,109 @@ msgstr "Bira prozor iz jezička iskakanja" | ||||
| msgid "Cancel tab popup" | ||||
| msgstr "Otkazivanje jezička iskakanja" | ||||
|  | ||||
| #: ../src/tools/mutter-message.c:123 | ||||
| #, c-format | ||||
| msgid "Usage: %s\n" | ||||
| msgstr "Upotreba: %s\n" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:67 | ||||
| #: ../src/ui/menu.c:69 | ||||
| msgid "Mi_nimize" | ||||
| msgstr "U_manji" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:69 | ||||
| #: ../src/ui/menu.c:71 | ||||
| msgid "Ma_ximize" | ||||
| msgstr "U_većaj" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:71 | ||||
| #: ../src/ui/menu.c:73 | ||||
| msgid "Unma_ximize" | ||||
| msgstr "Poništi u_većanje" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:73 | ||||
| #: ../src/ui/menu.c:75 | ||||
| msgid "Roll _Up" | ||||
| msgstr "_Zamotaj" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:75 | ||||
| #: ../src/ui/menu.c:77 | ||||
| msgid "_Unroll" | ||||
| msgstr "_Odmotaj" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:77 | ||||
| #: ../src/ui/menu.c:79 | ||||
| msgid "_Move" | ||||
| msgstr "_Premesti" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:79 | ||||
| #: ../src/ui/menu.c:81 | ||||
| msgid "_Resize" | ||||
| msgstr "P_romeni veličinu" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:81 | ||||
| #: ../src/ui/menu.c:83 | ||||
| msgid "Move Titlebar On_screen" | ||||
| msgstr "Premesti traku _naslova na ekran" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:84 ../src/ui/menu.c:86 | ||||
| #: ../src/ui/menu.c:86 ../src/ui/menu.c:88 | ||||
| msgid "Always on _Top" | ||||
| msgstr "Uvek _iznad ostalih" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:88 | ||||
| #: ../src/ui/menu.c:90 | ||||
| msgid "_Always on Visible Workspace" | ||||
| msgstr "_Uvek na vidljivom radnom prostoru" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:90 | ||||
| #: ../src/ui/menu.c:92 | ||||
| msgid "_Only on This Workspace" | ||||
| msgstr "Samo na _ovom radnom prostoru" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:92 | ||||
| #: ../src/ui/menu.c:94 | ||||
| msgid "Move to Workspace _Left" | ||||
| msgstr "Premesti na radni prostor le_vo" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:94 | ||||
| #: ../src/ui/menu.c:96 | ||||
| msgid "Move to Workspace R_ight" | ||||
| msgstr "Premesti na radni prostor de_sno" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:96 | ||||
| #: ../src/ui/menu.c:98 | ||||
| msgid "Move to Workspace _Up" | ||||
| msgstr "Premesti na radni prostor go_re" | ||||
|  | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:98 | ||||
| #: ../src/ui/menu.c:100 | ||||
| msgid "Move to Workspace _Down" | ||||
| msgstr "Premesti na radni prostor do_le" | ||||
|  | ||||
| #. separator | ||||
| #. Translators: Translate this string the same way as you do in libwnck! | ||||
| #: ../src/ui/menu.c:102 | ||||
| #: ../src/ui/menu.c:104 | ||||
| msgid "_Close" | ||||
| msgstr "_Zatvori" | ||||
|  | ||||
| #: ../src/ui/menu.c:202 | ||||
| #: ../src/ui/menu.c:204 | ||||
| #, c-format | ||||
| msgid "Workspace %d%n" | ||||
| msgstr "Radni prostor %d%n" | ||||
|  | ||||
| #: ../src/ui/menu.c:212 | ||||
| #: ../src/ui/menu.c:214 | ||||
| #, c-format | ||||
| msgid "Workspace 1_0" | ||||
| msgstr "1_0. radni prostor" | ||||
|  | ||||
| #: ../src/ui/menu.c:214 | ||||
| #: ../src/ui/menu.c:216 | ||||
| #, c-format | ||||
| msgid "Workspace %s%d" | ||||
| msgstr "%s%d. radni prostor" | ||||
|  | ||||
| #: ../src/ui/menu.c:384 | ||||
| #: ../src/ui/menu.c:397 | ||||
| msgid "Move to Another _Workspace" | ||||
| msgstr "Premesti na drugi _radni prostor" | ||||
|  | ||||
| @@ -916,48 +923,48 @@ msgstr "Mod5" | ||||
| msgid "%d x %d" | ||||
| msgstr "%d x %d" | ||||
|  | ||||
| #: ../src/ui/theme.c:236 | ||||
| #: ../src/ui/theme.c:235 | ||||
| msgid "top" | ||||
| msgstr "gornju" | ||||
|  | ||||
| #: ../src/ui/theme.c:238 | ||||
| #: ../src/ui/theme.c:237 | ||||
| msgid "bottom" | ||||
| msgstr "donju" | ||||
|  | ||||
| #: ../src/ui/theme.c:240 | ||||
| #: ../src/ui/theme.c:239 | ||||
| msgid "left" | ||||
| msgstr "levu" | ||||
|  | ||||
| #: ../src/ui/theme.c:242 | ||||
| #: ../src/ui/theme.c:241 | ||||
| msgid "right" | ||||
| msgstr "desnu" | ||||
|  | ||||
| #: ../src/ui/theme.c:270 | ||||
| #: ../src/ui/theme.c:269 | ||||
| #, c-format | ||||
| msgid "frame geometry does not specify \"%s\" dimension" | ||||
| msgstr "geometrija okvira ne podešava „%s“ dimenziju" | ||||
|  | ||||
| #: ../src/ui/theme.c:289 | ||||
| #: ../src/ui/theme.c:288 | ||||
| #, c-format | ||||
| msgid "frame geometry does not specify dimension \"%s\" for border \"%s\"" | ||||
| msgstr "geometrija okvira ne podešava „%s“ dimenziju za ivicu „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:326 | ||||
| #: ../src/ui/theme.c:325 | ||||
| #, c-format | ||||
| msgid "Button aspect ratio %g is not reasonable" | ||||
| msgstr "Odnos razmere dugmeta %g nije razuman" | ||||
|  | ||||
| #: ../src/ui/theme.c:338 | ||||
| #: ../src/ui/theme.c:337 | ||||
| #, c-format | ||||
| msgid "Frame geometry does not specify size of buttons" | ||||
| msgstr "Geometrija okvira ne podešava veličinu dugmića" | ||||
|  | ||||
| #: ../src/ui/theme.c:1051 | ||||
| #: ../src/ui/theme.c:1050 | ||||
| #, c-format | ||||
| msgid "Gradients should have at least two colors" | ||||
| msgstr "Prelivi moraju imati najmanje dve boje" | ||||
|  | ||||
| #: ../src/ui/theme.c:1203 | ||||
| #: ../src/ui/theme.c:1202 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK custom color specification must have color name and fallback in " | ||||
| @@ -966,7 +973,7 @@ msgstr "" | ||||
| "Specifikacija proizvoljne GTK boje mora imati naziv boje i prebacivanje u " | ||||
| "zagradi, na primer gtk:custom(foo,bar); ne mogu da obradim „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1219 | ||||
| #: ../src/ui/theme.c:1218 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-" | ||||
| @@ -975,7 +982,7 @@ msgstr "" | ||||
| "Neispravan znak „%c“ parametra naziv_boje u gtk:custom, iaspravni su samo A-" | ||||
| "Za-z0-9-_" | ||||
|  | ||||
| #: ../src/ui/theme.c:1233 | ||||
| #: ../src/ui/theme.c:1232 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not " | ||||
| @@ -984,7 +991,7 @@ msgstr "" | ||||
| "Gtk:proizvoljni format je „gtk:custom(naziv_boje,prebacivanje)“, „%s“ se ne " | ||||
| "uklapa u format" | ||||
|  | ||||
| #: ../src/ui/theme.c:1278 | ||||
| #: ../src/ui/theme.c:1277 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] " | ||||
| @@ -993,7 +1000,7 @@ msgstr "" | ||||
| "Specifikacija GTK boje mora imati navedeno stanje u zagradi, na primer „gtk:fg" | ||||
| "[NORMAL]“ gde je „NORMAL“ stanje; ne mogu da obradim „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1292 | ||||
| #: ../src/ui/theme.c:1291 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "GTK color specification must have a close bracket after the state, e.g. gtk:" | ||||
| @@ -1002,17 +1009,17 @@ msgstr "" | ||||
| "Specifikacija GTK boje mora imati navedeno stanje u zagradi, na primer „gtk:fg" | ||||
| "[NORMAL]“ gde je „NORMAL“ stanje; ne mogu da obradim „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1303 | ||||
| #: ../src/ui/theme.c:1302 | ||||
| #, c-format | ||||
| msgid "Did not understand state \"%s\" in color specification" | ||||
| msgstr "Nisam razumeo stanje „%s“ u specifikaciji boje" | ||||
|  | ||||
| #: ../src/ui/theme.c:1316 | ||||
| #: ../src/ui/theme.c:1315 | ||||
| #, c-format | ||||
| msgid "Did not understand color component \"%s\" in color specification" | ||||
| msgstr "Nisam razumeo deo boje „%s“ u specifikaciji boje" | ||||
|  | ||||
| #: ../src/ui/theme.c:1345 | ||||
| #: ../src/ui/theme.c:1344 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the " | ||||
| @@ -1021,55 +1028,55 @@ msgstr "" | ||||
| "Format smeše je „blend/bg_color/fg_color/alpha“, „%s“ se ne uklapa u traženi " | ||||
| "format zapisa" | ||||
|  | ||||
| #: ../src/ui/theme.c:1356 | ||||
| #: ../src/ui/theme.c:1355 | ||||
| #, c-format | ||||
| msgid "Could not parse alpha value \"%s\" in blended color" | ||||
| msgstr "Ne mogu da obradim alfa vrednost „%s“ u smešanoj boji" | ||||
|  | ||||
| #: ../src/ui/theme.c:1366 | ||||
| #: ../src/ui/theme.c:1365 | ||||
| #, c-format | ||||
| msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0" | ||||
| msgstr "Alfa vrednost „%s“ u smešanoj boji nije između 0.0 i 1.0" | ||||
|  | ||||
| #: ../src/ui/theme.c:1413 | ||||
| #: ../src/ui/theme.c:1412 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format" | ||||
| msgstr "Format senke je „shade/base_color/factor“, „%s“ se ne uklapa u format" | ||||
|  | ||||
| #: ../src/ui/theme.c:1424 | ||||
| #: ../src/ui/theme.c:1423 | ||||
| #, c-format | ||||
| msgid "Could not parse shade factor \"%s\" in shaded color" | ||||
| msgstr "Ne mogu da obradim faktor senke „%s“ u osenčenoj boji" | ||||
|  | ||||
| #: ../src/ui/theme.c:1434 | ||||
| #: ../src/ui/theme.c:1433 | ||||
| #, c-format | ||||
| msgid "Shade factor \"%s\" in shaded color is negative" | ||||
| msgstr "Faktor senke „%s“ u osenčenoj boji je negativan" | ||||
|  | ||||
| #: ../src/ui/theme.c:1463 | ||||
| #: ../src/ui/theme.c:1462 | ||||
| #, c-format | ||||
| msgid "Could not parse color \"%s\"" | ||||
| msgstr "Ne mogu da obradim boju „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1780 | ||||
| #: ../src/ui/theme.c:1779 | ||||
| #, c-format | ||||
| msgid "Coordinate expression contains character '%s' which is not allowed" | ||||
| msgstr "Izraz koordinata sadrži znak „%s“ koji nije dozvoljen" | ||||
|  | ||||
| #: ../src/ui/theme.c:1807 | ||||
| #: ../src/ui/theme.c:1806 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression contains floating point number '%s' which could not be " | ||||
| "parsed" | ||||
| msgstr "Izraz koordinata sadrži decimalni broj „%s“ koji ne može biti obrađen" | ||||
|  | ||||
| #: ../src/ui/theme.c:1821 | ||||
| #: ../src/ui/theme.c:1820 | ||||
| #, c-format | ||||
| msgid "Coordinate expression contains integer '%s' which could not be parsed" | ||||
| msgstr "Izraz koordinata sadrži celi broj „%s“ koji ne može biti obrađen" | ||||
|  | ||||
| #: ../src/ui/theme.c:1942 | ||||
| #: ../src/ui/theme.c:1941 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression contained unknown operator at the start of this text: " | ||||
| @@ -1077,17 +1084,17 @@ msgid "" | ||||
| msgstr "" | ||||
| "Izraz sa koordinatama sadrži nepoznati operator na početku ovog teksta: „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:1999 | ||||
| #: ../src/ui/theme.c:1998 | ||||
| #, c-format | ||||
| msgid "Coordinate expression was empty or not understood" | ||||
| msgstr "Izraz sa koordinatama je bio prazan ili nerazumljiv" | ||||
|  | ||||
| #: ../src/ui/theme.c:2112 ../src/ui/theme.c:2122 ../src/ui/theme.c:2156 | ||||
| #: ../src/ui/theme.c:2111 ../src/ui/theme.c:2121 ../src/ui/theme.c:2155 | ||||
| #, c-format | ||||
| msgid "Coordinate expression results in division by zero" | ||||
| msgstr "Izraz sa koordinatama rezultira u deljenju nulom" | ||||
|  | ||||
| #: ../src/ui/theme.c:2164 | ||||
| #: ../src/ui/theme.c:2163 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression tries to use mod operator on a floating-point number" | ||||
| @@ -1095,23 +1102,23 @@ msgstr "" | ||||
| "Izraz sa koordinatam pokušava da koristi operator ostatka pri deljenju za " | ||||
| "decimalni broj" | ||||
|  | ||||
| #: ../src/ui/theme.c:2220 | ||||
| #: ../src/ui/theme.c:2219 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression has an operator \"%s\" where an operand was expected" | ||||
| msgstr "Izraz sa koordinatama ima operator „%s“ gde je očekivan operand" | ||||
|  | ||||
| #: ../src/ui/theme.c:2229 | ||||
| #: ../src/ui/theme.c:2228 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had an operand where an operator was expected" | ||||
| msgstr "Izraz sa koordinatama imaše operand gde je očekivan operator" | ||||
|  | ||||
| #: ../src/ui/theme.c:2237 | ||||
| #: ../src/ui/theme.c:2236 | ||||
| #, c-format | ||||
| msgid "Coordinate expression ended with an operator instead of an operand" | ||||
| msgstr "Izraz sa koordinarama je završio sa operatorom umesto sa operandom" | ||||
|  | ||||
| #: ../src/ui/theme.c:2247 | ||||
| #: ../src/ui/theme.c:2246 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Coordinate expression has operator \"%c\" following operator \"%c\" with no " | ||||
| @@ -1120,37 +1127,37 @@ msgstr "" | ||||
| "Izraz sa koordinatama ima operator „%c“, a zatim operator „%c“ bez operanda " | ||||
| "između" | ||||
|  | ||||
| #: ../src/ui/theme.c:2398 ../src/ui/theme.c:2443 | ||||
| #: ../src/ui/theme.c:2397 ../src/ui/theme.c:2442 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had unknown variable or constant \"%s\"" | ||||
| msgstr "Izraz sa koordinatama ima nepoznatu promenljivu ili konstanti „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:2497 | ||||
| #: ../src/ui/theme.c:2496 | ||||
| #, c-format | ||||
| msgid "Coordinate expression parser overflowed its buffer." | ||||
| msgstr "Izraz sa koordinatama je bio preveliki za smeštaj i obradu." | ||||
|  | ||||
| #: ../src/ui/theme.c:2526 | ||||
| #: ../src/ui/theme.c:2525 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had a close parenthesis with no open parenthesis" | ||||
| msgstr "Izraz sa koordinatama ima zatvorene zagrade bez otvorenih zagrada" | ||||
|  | ||||
| #: ../src/ui/theme.c:2590 | ||||
| #: ../src/ui/theme.c:2589 | ||||
| #, c-format | ||||
| msgid "Coordinate expression had an open parenthesis with no close parenthesis" | ||||
| msgstr "Izraz sa koordinatama ima otvorenu zagradu bez zatvorene zagrade" | ||||
|  | ||||
| #: ../src/ui/theme.c:2601 | ||||
| #: ../src/ui/theme.c:2600 | ||||
| #, c-format | ||||
| msgid "Coordinate expression doesn't seem to have any operators or operands" | ||||
| msgstr "Izraz sa koordinatama izgleda da nema ni jedan operator ili operand" | ||||
|  | ||||
| #: ../src/ui/theme.c:2814 ../src/ui/theme.c:2834 ../src/ui/theme.c:2854 | ||||
| #: ../src/ui/theme.c:2813 ../src/ui/theme.c:2833 ../src/ui/theme.c:2853 | ||||
| #, c-format | ||||
| msgid "Theme contained an expression that resulted in an error: %s\n" | ||||
| msgstr "Tema sadrži izraz koji rezultira greškom: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:4500 | ||||
| #: ../src/ui/theme.c:4499 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be " | ||||
| @@ -1159,25 +1166,25 @@ msgstr "" | ||||
| "<button function=„%s“ state=„%s“ draw_ops=\"whatever\"/> mora biti naveden " | ||||
| "za ovaj stil okvira" | ||||
|  | ||||
| #: ../src/ui/theme.c:5011 ../src/ui/theme.c:5036 | ||||
| #: ../src/ui/theme.c:5010 ../src/ui/theme.c:5035 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>" | ||||
| msgstr "" | ||||
| "Nedostaje <frame state=„%s“ resize=„%s“ focus=„%s“ style=\"whatever\"/>" | ||||
|  | ||||
| #: ../src/ui/theme.c:5082 | ||||
| #: ../src/ui/theme.c:5083 | ||||
| #, c-format | ||||
| msgid "Failed to load theme \"%s\": %s\n" | ||||
| msgstr "Nisam uspeo da učitam temu „%s“: %s\n" | ||||
|  | ||||
| #: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232 | ||||
| #: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246 | ||||
| #: ../src/ui/theme.c:5219 ../src/ui/theme.c:5226 ../src/ui/theme.c:5233 | ||||
| #: ../src/ui/theme.c:5240 ../src/ui/theme.c:5247 | ||||
| #, c-format | ||||
| msgid "No <%s> set for theme \"%s\"" | ||||
| msgstr "Nije definisan element <%s> za temu „%s“" | ||||
|  | ||||
| #: ../src/ui/theme.c:5254 | ||||
| #: ../src/ui/theme.c:5255 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "No frame style set for window type \"%s\" in theme \"%s\", add a <window " | ||||
| @@ -1186,14 +1193,14 @@ msgstr "" | ||||
| "Nije podešen stil okvira za prozor tipa „%s“ u temi „%s“. Dodajte <window " | ||||
| "type=„%s“ style_set=\"whatever\"/> element" | ||||
|  | ||||
| #: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786 | ||||
| #: ../src/ui/theme.c:5662 ../src/ui/theme.c:5724 ../src/ui/theme.c:5787 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "User-defined constants must begin with a capital letter; \"%s\" does not" | ||||
| msgstr "" | ||||
| "Korisnički definisane konstante moraju početi velikim slovom; „%s“ ne počinje" | ||||
|  | ||||
| #: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794 | ||||
| #: ../src/ui/theme.c:5670 ../src/ui/theme.c:5732 ../src/ui/theme.c:5795 | ||||
| #, c-format | ||||
| msgid "Constant \"%s\" has already been defined" | ||||
| msgstr "Konstanta „%s“ je već definisana" | ||||
| @@ -1576,7 +1583,209 @@ msgstr "Nije dozvoljen tekst unutar elementa <%s>" | ||||
| msgid "<%s> specified twice for this theme" | ||||
| msgstr "<%s> je naveden dva puta u ovoj temi" | ||||
|  | ||||
| #: ../src/ui/theme-parser.c:4336 | ||||
| #: ../src/ui/theme-parser.c:4334 | ||||
| #, c-format | ||||
| msgid "Failed to find a valid file for theme %s\n" | ||||
| msgstr "Nisam uspeo da pronađem ispravnu datoteku za temu „%s“\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:99 | ||||
| msgid "_Windows" | ||||
| msgstr "_Prozori" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:100 | ||||
| msgid "_Dialog" | ||||
| msgstr "_Prozorče" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:101 | ||||
| msgid "_Modal dialog" | ||||
| msgstr "_Važno prozorče" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:102 | ||||
| msgid "_Utility" | ||||
| msgstr "_Alatka" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:103 | ||||
| msgid "_Splashscreen" | ||||
| msgstr "_Uvodni ekran" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:104 | ||||
| msgid "_Top dock" | ||||
| msgstr "_Gornje pripajanje" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:105 | ||||
| msgid "_Bottom dock" | ||||
| msgstr "_Donje pripajanje" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:106 | ||||
| msgid "_Left dock" | ||||
| msgstr "_Levo pripajanje" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:107 | ||||
| msgid "_Right dock" | ||||
| msgstr "D_esno pripajanje" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:108 | ||||
| msgid "_All docks" | ||||
| msgstr "_Sva pripajanja" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:109 | ||||
| msgid "Des_ktop" | ||||
| msgstr "_Radna površ" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:115 | ||||
| msgid "Open another one of these windows" | ||||
| msgstr "Otvori neki drugi od ovih prozora" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:117 | ||||
| msgid "This is a demo button with an 'open' icon" | ||||
| msgstr "Ovo je probno dugme sa „otvori“ ikonom" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:119 | ||||
| msgid "This is a demo button with a 'quit' icon" | ||||
| msgstr "Ovo je probno dugme sa „izađi“ ikonicom" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:248 | ||||
| msgid "This is a sample message in a sample dialog" | ||||
| msgstr "Ovo je primer poruke u probnom prozorčetu" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:328 | ||||
| #, c-format | ||||
| msgid "Fake menu item %d\n" | ||||
| msgstr "Lažna stavka izbornika %d\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:363 | ||||
| msgid "Border-only window" | ||||
| msgstr "Prozor samo sa ivicom" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:365 | ||||
| msgid "Bar" | ||||
| msgstr "Traka" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:382 | ||||
| msgid "Normal Application Window" | ||||
| msgstr "Običan prozor programa" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:386 | ||||
| msgid "Dialog Box" | ||||
| msgstr "Prozorče" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:390 | ||||
| msgid "Modal Dialog Box" | ||||
| msgstr "Važno prozorče" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:394 | ||||
| msgid "Utility Palette" | ||||
| msgstr "Paleta alata" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:398 | ||||
| msgid "Torn-off Menu" | ||||
| msgstr "Otkinuti izbornik" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:402 | ||||
| msgid "Border" | ||||
| msgstr "Ivica" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:406 | ||||
| msgid "Attached Modal Dialog" | ||||
| msgstr "Priloženo važno prozorče" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:737 | ||||
| #, c-format | ||||
| msgid "Button layout test %d" | ||||
| msgstr "Proba rasporeda dugmića %d" | ||||
|  | ||||
| # bug: plural-forms | ||||
| #: ../src/ui/theme-viewer.c:766 | ||||
| #, c-format | ||||
| msgid "%g milliseconds to draw one window frame" | ||||
| msgstr "%g milisekundi za iscrtavanje okvira jednog prozora" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:811 | ||||
| #, c-format | ||||
| msgid "Usage: metacity-theme-viewer [THEMENAME]\n" | ||||
| msgstr "Upotreba: metacity-theme-viewer [NAZIV_TEME]\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:818 | ||||
| #, c-format | ||||
| msgid "Error loading theme: %s\n" | ||||
| msgstr "Greška prilikom učitavanja teme: %s\n" | ||||
|  | ||||
| # bug: plural-forms | ||||
| #: ../src/ui/theme-viewer.c:824 | ||||
| #, c-format | ||||
| msgid "Loaded theme \"%s\" in %g seconds\n" | ||||
| msgstr "Učitana je tema „%s“ za %g sekunde\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:869 | ||||
| msgid "Normal Title Font" | ||||
| msgstr "Običan slovni lik naslova" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:875 | ||||
| msgid "Small Title Font" | ||||
| msgstr "Mali slovni lik naslova" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:881 | ||||
| msgid "Large Title Font" | ||||
| msgstr "Veliki slovni lik naslova" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:886 | ||||
| msgid "Button Layouts" | ||||
| msgstr "Raspored dugmića" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:891 | ||||
| msgid "Benchmark" | ||||
| msgstr "Provera brzine" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:947 | ||||
| msgid "Window Title Goes Here" | ||||
| msgstr "Ovde ide naslov prozora" | ||||
|  | ||||
| # bug: plural-forms | ||||
| #: ../src/ui/theme-viewer.c:1053 | ||||
| #, c-format | ||||
| msgid "" | ||||
| "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g " | ||||
| "seconds wall clock time including X server resources (%g milliseconds per " | ||||
| "frame)\n" | ||||
| msgstr "" | ||||
| "Nacrtao je %d okvira za %g klijentskih sekundi (%g milisekundi po okviru) i " | ||||
| "%g sekundi vremena na zidnom časovniku uključujući i resurse Iks servera (%g " | ||||
| "milisekundi po okviru)\n" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1273 | ||||
| msgid "position expression test returned TRUE but set error" | ||||
| msgstr "provera izraza položaja je vratila tačno, ali je postavila grešku" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1275 | ||||
| msgid "position expression test returned FALSE but didn't set error" | ||||
| msgstr "provera izraza položaja je vratila netačno, ali nije postavila grešku" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1279 | ||||
| msgid "Error was expected but none given" | ||||
| msgstr "Očekivana je greška, ali nije data" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1281 | ||||
| #, c-format | ||||
| msgid "Error %d was expected but %d given" | ||||
| msgstr "Očekivana je greška „%d“, ali je data „%d“" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1287 | ||||
| #, c-format | ||||
| msgid "Error not expected but one was returned: %s" | ||||
| msgstr "Greška nije očekivana, ali je vraćena jedna: %s" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1291 | ||||
| #, c-format | ||||
| msgid "x value was %d, %d was expected" | ||||
| msgstr "x vrednost je bila „%d“, a očekivana je „%d“" | ||||
|  | ||||
| #: ../src/ui/theme-viewer.c:1294 | ||||
| #, c-format | ||||
| msgid "y value was %d, %d was expected" | ||||
| msgstr "y vrednost je bila „%d“, a očekivana je „%d“" | ||||
|  | ||||
| # bug: plural-forms | ||||
| #: ../src/ui/theme-viewer.c:1359 | ||||
| #, c-format | ||||
| msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n" | ||||
| msgstr "%d izraza koordinata je obrađeno za %g sekunde (prosek %g sekunde)\n" | ||||
|   | ||||
							
								
								
									
										1
									
								
								protocol/Makefile.am
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								protocol/Makefile.am
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| EXTRA_DIST = xserver.xml | ||||
							
								
								
									
										30
									
								
								protocol/gtk-shell.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								protocol/gtk-shell.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | ||||
| <protocol name="gtk"> | ||||
|  | ||||
|   <interface name="gtk_shell" version="1"> | ||||
|     <enum name="capability"> | ||||
|       <entry name="global_app_menu" value="1"/> | ||||
|       <entry name="global_menu_bar" value="2"/> | ||||
|     </enum> | ||||
|  | ||||
|     <event name="capabilities"> | ||||
|       <arg name="capabilities" type="uint"/> | ||||
|     </event> | ||||
|  | ||||
|     <request name="get_gtk_surface"> | ||||
|       <arg name="gtk_surface" type="new_id" interface="gtk_surface"/> | ||||
|       <arg name="surface" type="object" interface="wl_surface"/> | ||||
|     </request> | ||||
|   </interface> | ||||
|  | ||||
|   <interface name="gtk_surface" version="1"> | ||||
|     <request name="set_dbus_properties"> | ||||
|       <arg name="application_id" type="string" allow-null="true"/> | ||||
|       <arg name="app_menu_path" type="string" allow-null="true"/> | ||||
|       <arg name="menubar_path" type="string" allow-null="true"/> | ||||
|       <arg name="window_object_path" type="string" allow-null="true"/> | ||||
|       <arg name="application_object_path" type="string" allow-null="true"/> | ||||
|       <arg name="unique_bus_name" type="string" allow-null="true"/> | ||||
|     </request> | ||||
|   </interface> | ||||
|  | ||||
| </protocol> | ||||
							
								
								
									
										18
									
								
								protocol/xserver.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								protocol/xserver.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| <protocol name="xserver"> | ||||
|  | ||||
|   <interface name="xserver" version="1"> | ||||
|     <request name="set_window_id"> | ||||
|       <arg name="surface" type="object" interface="wl_surface"/> | ||||
|       <arg name="id" type="uint"/> | ||||
|     </request> | ||||
|  | ||||
|     <event name="client"> | ||||
|       <arg name="fd" type="fd"/> | ||||
|     </event> | ||||
|  | ||||
|     <event name="listen_socket"> | ||||
|       <arg name="fd" type="fd"/> | ||||
|     </event> | ||||
|   </interface> | ||||
|  | ||||
| </protocol> | ||||
							
								
								
									
										124
									
								
								src/Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										124
									
								
								src/Makefile.am
									
									
									
									
									
								
							| @@ -1,7 +1,7 @@ | ||||
| # Flag build for parallelism; see https://savannah.gnu.org/patch/?6905 | ||||
| .AUTOPARALLEL: | ||||
|  | ||||
| lib_LTLIBRARIES = libmutter.la | ||||
| lib_LTLIBRARIES = libmutter-wayland.la | ||||
|  | ||||
| SUBDIRS=compositor/plugins | ||||
|  | ||||
| @@ -10,6 +10,7 @@ INCLUDES=								\ | ||||
| 	-DCOGL_ENABLE_EXPERIMENTAL_API					\ | ||||
| 	-DCOGL_ENABLE_EXPERIMENTAL_2_0_API                              \ | ||||
| 	$(MUTTER_CFLAGS)						\ | ||||
| 	-I$(top_builddir)						\ | ||||
| 	-I$(srcdir)							\ | ||||
| 	-I$(srcdir)/core						\ | ||||
| 	-I$(srcdir)/ui							\ | ||||
| @@ -29,13 +30,24 @@ INCLUDES=								\ | ||||
| 	-DMUTTER_PLUGIN_DIR=\"@MUTTER_PLUGIN_DIR@\"			\ | ||||
| 	-DGETTEXT_PACKAGE=\"$(GETTEXT_PACKAGE)\" | ||||
|  | ||||
| mutter_built_sources = \ | ||||
| 	$(dbus_idle_built_sources)	\ | ||||
| 	$(dbus_xrandr_built_sources)	\ | ||||
| 	mutter-enum-types.h		\ | ||||
| 	mutter-enum-types.c | ||||
| INCLUDES += \ | ||||
| 	-I$(srcdir)/wayland						\ | ||||
| 	-I$(builddir)/wayland						\ | ||||
| 	-DXWAYLAND_PATH='"@XWAYLAND_PATH@"' | ||||
|  | ||||
| libmutter_la_SOURCES =				\ | ||||
| mutter_built_sources = \ | ||||
| 	$(dbus_idle_built_sources)		\ | ||||
| 	$(dbus_xrandr_built_sources)		\ | ||||
| 	mutter-enum-types.h 			\ | ||||
| 	mutter-enum-types.c			\ | ||||
| 	wayland/gtk-shell-protocol.c		\ | ||||
| 	wayland/gtk-shell-server-protocol.h	\ | ||||
| 	wayland/gtk-shell-client-protocol.h	\ | ||||
| 	wayland/xserver-protocol.c		\ | ||||
| 	wayland/xserver-server-protocol.h	\ | ||||
| 	wayland/xserver-client-protocol.h | ||||
|  | ||||
| libmutter_wayland_la_SOURCES =			\ | ||||
| 	core/async-getprop.c			\ | ||||
| 	core/async-getprop.h			\ | ||||
| 	core/barrier.c				\ | ||||
| @@ -64,6 +76,7 @@ libmutter_la_SOURCES =				\ | ||||
| 	compositor/meta-shadow-factory.c	\ | ||||
| 	compositor/meta-shadow-factory-private.h	\ | ||||
| 	compositor/meta-shaped-texture.c	\ | ||||
| 	compositor/meta-shaped-texture-private.h 	\ | ||||
| 	compositor/meta-texture-rectangle.c	\ | ||||
| 	compositor/meta-texture-rectangle.h	\ | ||||
| 	compositor/meta-texture-tower.c		\ | ||||
| @@ -121,6 +134,7 @@ libmutter_la_SOURCES =				\ | ||||
| 	core/meta-xrandr-shared.h		\ | ||||
| 	core/monitor.c				\ | ||||
| 	core/monitor-config.c			\ | ||||
| 	core/monitor-kms.c			\ | ||||
| 	core/monitor-private.h			\ | ||||
| 	core/monitor-xrandr.c			\ | ||||
| 	core/mutter-Xatomtype.h			\ | ||||
| @@ -140,6 +154,7 @@ libmutter_la_SOURCES =				\ | ||||
| 	core/stack-tracker.h			\ | ||||
| 	core/util.c				\ | ||||
| 	meta/util.h				\ | ||||
| 	core/util-private.h			\ | ||||
| 	core/window-props.c			\ | ||||
| 	core/window-props.h			\ | ||||
| 	core/window.c				\ | ||||
| @@ -171,8 +186,30 @@ libmutter_la_SOURCES =				\ | ||||
| 	ui/ui.c					\ | ||||
| 	$(mutter_built_sources) | ||||
|  | ||||
| libmutter_la_LDFLAGS = -no-undefined | ||||
| libmutter_la_LIBADD  = $(MUTTER_LIBS) | ||||
| libmutter_wayland_la_SOURCES +=			\ | ||||
| 	wayland/meta-wayland.c			\ | ||||
| 	wayland/meta-wayland-private.h		\ | ||||
| 	wayland/meta-xwayland-private.h		\ | ||||
| 	wayland/meta-xwayland.c			\ | ||||
| 	wayland/meta-wayland-data-device.c      \ | ||||
| 	wayland/meta-wayland-data-device.h      \ | ||||
| 	wayland/meta-wayland-keyboard.c		\ | ||||
| 	wayland/meta-wayland-keyboard.h		\ | ||||
| 	wayland/meta-wayland-pointer.c		\ | ||||
| 	wayland/meta-wayland-pointer.h		\ | ||||
| 	wayland/meta-wayland-seat.c		\ | ||||
| 	wayland/meta-wayland-seat.h		\ | ||||
| 	wayland/meta-wayland-stage.h		\ | ||||
| 	wayland/meta-wayland-stage.c		\ | ||||
| 	wayland/meta-wayland-surface.c		\ | ||||
| 	wayland/meta-wayland-surface.h		\ | ||||
| 	wayland/meta-wayland-types.h		\ | ||||
| 	wayland/meta-wayland-versions.h		\ | ||||
| 	wayland/meta-weston-launch.c		\ | ||||
| 	wayland/meta-weston-launch.h | ||||
|  | ||||
| libmutter_wayland_la_LDFLAGS = -no-undefined | ||||
| libmutter_wayland_la_LIBADD  = $(MUTTER_LIBS) | ||||
|  | ||||
| # Headers installed for plugins; introspected information will | ||||
| # be extracted into Mutter-<version>.gir | ||||
| @@ -210,16 +247,27 @@ libmutterinclude_base_headers =		\ | ||||
| libmutterinclude_extra_headers =		\ | ||||
| 	meta/atomnames.h | ||||
|  | ||||
| libmutterincludedir = $(includedir)/mutter/meta | ||||
| libmutterincludedir = $(includedir)/mutter-wayland/meta | ||||
|  | ||||
| libmutterinclude_HEADERS =			\ | ||||
| 	$(libmutterinclude_base_headers)	\ | ||||
| 	$(libmutterinclude_extra_headers) | ||||
|  | ||||
| bin_PROGRAMS=mutter | ||||
| bin_PROGRAMS=mutter-wayland | ||||
|  | ||||
| mutter_SOURCES = core/mutter.c | ||||
| mutter_LDADD = $(MUTTER_LIBS) libmutter.la | ||||
| mutter_wayland_SOURCES = core/mutter.c | ||||
| mutter_wayland_LDADD = $(MUTTER_LIBS) libmutter-wayland.la | ||||
|  | ||||
| bin_PROGRAMS+=mutter-launch | ||||
|  | ||||
| mutter_launch_SOURCES = wayland/weston-launch.c wayland/weston-launch.h | ||||
|  | ||||
| mutter_launch_CFLAGS = $(MUTTER_LAUNCH_CFLAGS) -DLIBDIR=\"$(libdir)\" | ||||
| mutter_launch_LDFLAGS = $(MUTTER_LAUNCH_LIBS) -lpam | ||||
|  | ||||
| install-exec-hook: | ||||
| 	-chown root $(DESTDIR)$(bindir)/mutter-launch | ||||
| 	-chmod u+s $(DESTDIR)$(bindir)/mutter-launch | ||||
|  | ||||
| if HAVE_INTROSPECTION | ||||
| include $(INTROSPECTION_MAKEFILE) | ||||
| @@ -241,15 +289,15 @@ typelib_DATA = Meta-$(api_version).typelib | ||||
|  | ||||
| INTROSPECTION_GIRS = Meta-$(api_version).gir | ||||
|  | ||||
| Meta-$(api_version).gir: libmutter.la | ||||
| Meta-$(api_version).gir: libmutter-wayland.la | ||||
| @META_GIR@_INCLUDES = GObject-2.0 GDesktopEnums-3.0 Gdk-3.0 Gtk-3.0 Clutter-1.0 xlib-2.0 xfixes-4.0 Cogl-1.0 | ||||
| @META_GIR@_EXPORT_PACKAGES = libmutter | ||||
| @META_GIR@_EXPORT_PACKAGES = libmutter-wayland | ||||
| @META_GIR@_CFLAGS = $(INCLUDES) | ||||
| @META_GIR@_LIBS = libmutter.la | ||||
| @META_GIR@_LIBS = libmutter-wayland.la | ||||
| @META_GIR@_FILES =				\ | ||||
| 	mutter-enum-types.h			\ | ||||
| 	$(libmutterinclude_base_headers)	\ | ||||
| 	$(filter %.c,$(libmutter_la_SOURCES)) | ||||
| 	$(filter %.c,$(libmutter_wayland_la_SOURCES)) | ||||
| @META_GIR@_SCANNERFLAGS = --warn-all --warn-error | ||||
|  | ||||
| endif | ||||
| @@ -260,22 +308,17 @@ testasyncgetprop_SOURCES = core/testasyncgetprop.c | ||||
|  | ||||
| noinst_PROGRAMS=testboxes testgradient testasyncgetprop | ||||
|  | ||||
| testboxes_LDADD = $(MUTTER_LIBS) libmutter.la | ||||
| testgradient_LDADD = $(MUTTER_LIBS) libmutter.la | ||||
| testasyncgetprop_LDADD = $(MUTTER_LIBS) libmutter.la | ||||
| testboxes_LDADD = $(MUTTER_LIBS) libmutter-wayland.la | ||||
| testgradient_LDADD = $(MUTTER_LIBS) libmutter-wayland.la | ||||
| testasyncgetprop_LDADD = $(MUTTER_LIBS) libmutter-wayland.la | ||||
|  | ||||
| @INTLTOOL_DESKTOP_RULE@ | ||||
|  | ||||
| desktopfilesdir=$(datadir)/applications | ||||
| desktopfiles_in_files=mutter.desktop.in | ||||
| desktopfiles_in_files=mutter-wayland.desktop.in | ||||
| desktopfiles_files=$(desktopfiles_in_files:.desktop.in=.desktop) | ||||
| desktopfiles_DATA = $(desktopfiles_files) | ||||
|  | ||||
| wmpropertiesdir=$(datadir)/gnome/wm-properties | ||||
| wmproperties_in_files=mutter-wm.desktop.in | ||||
| wmproperties_files=$(wmproperties_in_files:.desktop.in=.desktop) | ||||
| wmproperties_DATA = $(wmproperties_files) | ||||
|  | ||||
| xmldir       = @GNOME_KEYBINDINGS_KEYSDIR@ | ||||
| xml_in_files = \ | ||||
|         50-mutter-navigation.xml.in	\ | ||||
| @@ -283,7 +326,9 @@ xml_in_files = \ | ||||
|         50-mutter-windows.xml.in | ||||
| xml_DATA     = $(xml_in_files:.xml.in=.xml) | ||||
|  | ||||
| gsettings_SCHEMAS = org.gnome.mutter.gschema.xml | ||||
| dbus_idle_built_sources = meta-dbus-idle-monitor.c meta-dbus-idle-monitor.h | ||||
|  | ||||
| gsettings_SCHEMAS = org.gnome.mutter.gschema.xml org.gnome.mutter.wayland.gschema.xml | ||||
| @INTLTOOL_XML_NOMERGE_RULE@ | ||||
| @GSETTINGS_RULES@ | ||||
|  | ||||
| @@ -291,9 +336,10 @@ convertdir = $(datadir)/GConf/gsettings | ||||
| convert_DATA = mutter-schemas.convert | ||||
|  | ||||
| CLEANFILES =					\ | ||||
| 	mutter.desktop				\ | ||||
| 	mutter-wayland.desktop			\ | ||||
| 	mutter-wm.desktop			\ | ||||
| 	org.gnome.mutter.gschema.xml		\ | ||||
| 	org.gnome.mutter.wayland.gschema.xml	\ | ||||
| 	$(xml_DATA)				\ | ||||
| 	$(mutter_built_sources)			\ | ||||
| 	$(typelib_DATA)				\ | ||||
| @@ -301,7 +347,7 @@ CLEANFILES =					\ | ||||
|  | ||||
| pkgconfigdir = $(libdir)/pkgconfig | ||||
|  | ||||
| pkgconfig_DATA = libmutter.pc mutter-plugins.pc | ||||
| pkgconfig_DATA = libmutter-wayland.pc | ||||
|  | ||||
| EXTRA_DIST=$(desktopfiles_files) 	\ | ||||
| 	$(wmproperties_files)		\ | ||||
| @@ -310,13 +356,12 @@ EXTRA_DIST=$(desktopfiles_files) 	\ | ||||
| 	$(wmproperties_in_files)	\ | ||||
| 	$(xml_in_files)			\ | ||||
| 	org.gnome.mutter.gschema.xml.in \ | ||||
| 	idle-monitor.xml \ | ||||
| 	xrandr.xml \ | ||||
| 	org.gnome.mutter.wayland.gschema.xml.in \ | ||||
| 	mutter-schemas.convert \ | ||||
| 	libmutter.pc.in \ | ||||
| 	mutter-plugins.pc.in  \ | ||||
| 	libmutter-wayland.pc.in \ | ||||
| 	mutter-enum-types.h.in \ | ||||
| 	mutter-enum-types.c.in | ||||
| 	mutter-enum-types.c.in \ | ||||
| 	xrandr.xml idle-monitor.xml | ||||
|  | ||||
| BUILT_SOURCES = $(mutter_built_sources) | ||||
| MUTTER_STAMP_FILES = stamp-mutter-enum-types.h | ||||
| @@ -350,7 +395,6 @@ $(dbus_xrandr_built_sources) : Makefile.am xrandr.xml | ||||
| 		--generate-c-code meta-dbus-xrandr					\ | ||||
| 		$(srcdir)/xrandr.xml | ||||
|  | ||||
| dbus_idle_built_sources = meta-dbus-idle-monitor.c meta-dbus-idle-monitor.h | ||||
|  | ||||
| $(dbus_idle_built_sources) : Makefile.am idle-monitor.xml | ||||
| 	$(AM_V_GEN)gdbus-codegen							\ | ||||
| @@ -359,3 +403,13 @@ $(dbus_idle_built_sources) : Makefile.am idle-monitor.xml | ||||
| 		--generate-c-code meta-dbus-idle-monitor				\ | ||||
| 		--c-generate-object-manager						\ | ||||
| 		$(srcdir)/idle-monitor.xml | ||||
|  | ||||
| wayland/%-protocol.c : $(top_builddir)/protocol/%.xml | ||||
| 	mkdir -p wayland | ||||
| 	$(AM_V_GEN)$(WAYLAND_SCANNER) code < $< > $@ | ||||
| wayland/%-server-protocol.h : $(top_builddir)/protocol/%.xml | ||||
| 	mkdir -p wayland | ||||
| 	$(AM_V_GEN)$(WAYLAND_SCANNER) server-header < $< > $@ | ||||
| wayland/%-client-protocol.h : $(top_builddir)/protocol/%.xml | ||||
| 	mkdir -p wayland | ||||
| 	$(AM_V_GEN)$(WAYLAND_SCANNER) client-header < $< > $@ | ||||
|   | ||||
| @@ -84,6 +84,10 @@ | ||||
| #include "meta-window-group.h" | ||||
| #include "window-private.h" /* to check window->hidden */ | ||||
| #include "display-private.h" /* for meta_display_lookup_x_window() */ | ||||
| #include "util-private.h" | ||||
| #include "meta-wayland-private.h" | ||||
| #include "meta-wayland-pointer.h" | ||||
| #include "meta-wayland-keyboard.h" | ||||
| #include <X11/extensions/shape.h> | ||||
| #include <X11/extensions/Xcomposite.h> | ||||
|  | ||||
| @@ -172,7 +176,7 @@ process_damage (MetaCompositor     *compositor, | ||||
|   if (window_actor == NULL) | ||||
|     return; | ||||
|  | ||||
|   meta_window_actor_process_damage (window_actor, event); | ||||
|   meta_window_actor_process_x11_damage (window_actor, event); | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -327,29 +331,37 @@ void | ||||
| meta_set_stage_input_region (MetaScreen   *screen, | ||||
|                              XserverRegion region) | ||||
| { | ||||
|   MetaCompScreen *info = meta_screen_get_compositor_data (screen); | ||||
|   MetaDisplay  *display = meta_screen_get_display (screen); | ||||
|   Display      *xdpy    = meta_display_get_xdisplay (display); | ||||
|   /* As a wayland compositor we can simply ignore all this trickery | ||||
|    * for setting an input region on the stage for capturing events in | ||||
|    * clutter since all input comes to us first and we get to choose | ||||
|    * who else sees them. | ||||
|    */ | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       MetaCompScreen *info = meta_screen_get_compositor_data (screen); | ||||
|       MetaDisplay  *display = meta_screen_get_display (screen); | ||||
|       Display      *xdpy    = meta_display_get_xdisplay (display); | ||||
|  | ||||
|   if (info->stage && info->output) | ||||
|     { | ||||
|       do_set_stage_input_region (screen, region); | ||||
|       if (info->stage && info->output) | ||||
|         { | ||||
|           do_set_stage_input_region (screen, region); | ||||
|         } | ||||
|       else  | ||||
|         { | ||||
|           /* Reset info->pending_input_region if one existed before and set the new | ||||
|            * one to use it later. */  | ||||
|           if (info->pending_input_region) | ||||
|             { | ||||
|               XFixesDestroyRegion (xdpy, info->pending_input_region); | ||||
|               info->pending_input_region = None; | ||||
|             } | ||||
|           if (region != None) | ||||
|             { | ||||
|               info->pending_input_region = XFixesCreateRegion (xdpy, NULL, 0); | ||||
|               XFixesCopyRegion (xdpy, info->pending_input_region, region); | ||||
|             } | ||||
|         }  | ||||
|     } | ||||
|   else  | ||||
|     { | ||||
|       /* Reset info->pending_input_region if one existed before and set the new | ||||
|        * one to use it later. */  | ||||
|       if (info->pending_input_region) | ||||
|         { | ||||
|           XFixesDestroyRegion (xdpy, info->pending_input_region); | ||||
|           info->pending_input_region = None; | ||||
|         } | ||||
|       if (region != None) | ||||
|         { | ||||
|           info->pending_input_region = XFixesCreateRegion (xdpy, NULL, 0); | ||||
|           XFixesCopyRegion (xdpy, info->pending_input_region, region); | ||||
|         } | ||||
|     }  | ||||
| } | ||||
|  | ||||
| void | ||||
| @@ -380,63 +392,55 @@ meta_focus_stage_window (MetaScreen *screen, | ||||
|   if (!stage) | ||||
|     return; | ||||
|  | ||||
|   window = clutter_x11_get_stage_window (stage); | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       window = clutter_x11_get_stage_window (stage); | ||||
|  | ||||
|   if (window == None) | ||||
|     return; | ||||
|       if (window == None) | ||||
|         return; | ||||
|  | ||||
|   meta_display_set_input_focus_xwindow (screen->display, | ||||
|                                         screen, | ||||
|                                         window, | ||||
|                                         timestamp); | ||||
|       meta_display_set_input_focus_xwindow (screen->display, | ||||
|                                             screen, | ||||
|                                             META_FOCUS_STAGE, | ||||
|                                             window, | ||||
|                                             timestamp); | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       meta_display_set_input_focus_xwindow (screen->display, | ||||
|                                             screen, | ||||
|                                             META_FOCUS_STAGE, | ||||
|                                             None, | ||||
|                                             timestamp); | ||||
|     } | ||||
| } | ||||
|  | ||||
| gboolean | ||||
| meta_stage_is_focused (MetaScreen *screen) | ||||
| { | ||||
|   ClutterStage *stage; | ||||
|   Window window; | ||||
|  | ||||
|   stage = CLUTTER_STAGE (meta_get_stage_for_screen (screen)); | ||||
|   if (!stage) | ||||
|     return FALSE; | ||||
|  | ||||
|   window = clutter_x11_get_stage_window (stage); | ||||
|  | ||||
|   if (window == None) | ||||
|     return FALSE; | ||||
|  | ||||
|   return (screen->display->focus_xwindow == window); | ||||
|   return (screen->display->focus_type == META_FOCUS_STAGE); | ||||
| } | ||||
|  | ||||
| gboolean | ||||
| meta_begin_modal_for_plugin (MetaScreen       *screen, | ||||
|                              MetaPlugin       *plugin, | ||||
|                              MetaModalOptions  options, | ||||
|                              guint32           timestamp) | ||||
| static gboolean | ||||
| begin_modal_x11 (MetaScreen       *screen, | ||||
|                  MetaPlugin       *plugin, | ||||
|                  MetaModalOptions  options, | ||||
|                  guint32           timestamp) | ||||
| { | ||||
|   /* To some extent this duplicates code in meta_display_begin_grab_op(), but there | ||||
|    * are significant differences in how we handle grabs that make it difficult to | ||||
|    * merge the two. | ||||
|    */ | ||||
|   MetaDisplay    *display    = meta_screen_get_display (screen); | ||||
|   Display        *xdpy       = meta_display_get_xdisplay (display); | ||||
|   MetaCompositor *compositor = display->compositor; | ||||
|   ClutterStage *stage; | ||||
|   Window grab_window; | ||||
|   Cursor cursor = None; | ||||
|   gboolean pointer_grabbed = FALSE; | ||||
|   gboolean keyboard_grabbed = FALSE; | ||||
|   int result; | ||||
|  | ||||
|   stage = CLUTTER_STAGE (meta_get_stage_for_screen (screen)); | ||||
|   if (!stage) | ||||
|     return FALSE; | ||||
|  | ||||
|   grab_window = clutter_x11_get_stage_window (stage); | ||||
|  | ||||
|   if (compositor->modal_plugin != NULL || display->grab_op != META_GRAB_OP_NONE) | ||||
|     return FALSE; | ||||
|   MetaDisplay    *display     = meta_screen_get_display (screen); | ||||
|   Display        *xdpy        = meta_display_get_xdisplay (display); | ||||
|   MetaCompScreen *info        = meta_screen_get_compositor_data (screen); | ||||
|   Window          grab_window = clutter_x11_get_stage_window (CLUTTER_STAGE (info->stage)); | ||||
|   Cursor          cursor      = None; | ||||
|   int             result; | ||||
|   gboolean        pointer_grabbed = FALSE; | ||||
|   gboolean        keyboard_grabbed = FALSE; | ||||
|  | ||||
|   if ((options & META_MODAL_POINTER_ALREADY_GRABBED) == 0) | ||||
|     { | ||||
| @@ -486,14 +490,6 @@ meta_begin_modal_for_plugin (MetaScreen       *screen, | ||||
|       keyboard_grabbed = TRUE; | ||||
|     } | ||||
|  | ||||
|   display->grab_op = META_GRAB_OP_COMPOSITOR; | ||||
|   display->grab_window = NULL; | ||||
|   display->grab_screen = screen; | ||||
|   display->grab_have_pointer = TRUE; | ||||
|   display->grab_have_keyboard = TRUE; | ||||
|  | ||||
|   compositor->modal_plugin = plugin; | ||||
|  | ||||
|   return TRUE; | ||||
|  | ||||
|  fail: | ||||
| @@ -505,6 +501,80 @@ meta_begin_modal_for_plugin (MetaScreen       *screen, | ||||
|   return FALSE; | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| begin_modal_wayland (MetaScreen       *screen, | ||||
|                      MetaPlugin       *plugin, | ||||
|                      MetaModalOptions  options, | ||||
|                      guint32           timestamp) | ||||
| { | ||||
|   MetaWaylandCompositor *compositor; | ||||
|   gboolean pointer_grabbed = FALSE; | ||||
|   gboolean keyboard_grabbed = FALSE; | ||||
|  | ||||
|   compositor = meta_wayland_compositor_get_default (); | ||||
|  | ||||
|   if ((options & META_MODAL_POINTER_ALREADY_GRABBED) == 0) | ||||
|     { | ||||
|       if (!meta_wayland_pointer_begin_modal (&compositor->seat->pointer)) | ||||
|         goto fail; | ||||
|  | ||||
|       pointer_grabbed = TRUE; | ||||
|     } | ||||
|   if ((options & META_MODAL_KEYBOARD_ALREADY_GRABBED) == 0) | ||||
|     { | ||||
|       if (!meta_wayland_keyboard_begin_modal (&compositor->seat->keyboard, | ||||
|                                               timestamp)) | ||||
|         goto fail; | ||||
|  | ||||
|       keyboard_grabbed = TRUE; | ||||
|     } | ||||
|  | ||||
|   return TRUE; | ||||
|  | ||||
|  fail: | ||||
|   if (pointer_grabbed) | ||||
|     meta_wayland_pointer_end_modal (&compositor->seat->pointer); | ||||
|   if (keyboard_grabbed) | ||||
|     meta_wayland_keyboard_end_modal (&compositor->seat->keyboard, timestamp); | ||||
|  | ||||
|   return FALSE; | ||||
| } | ||||
|  | ||||
| gboolean | ||||
| meta_begin_modal_for_plugin (MetaScreen       *screen, | ||||
|                              MetaPlugin       *plugin, | ||||
|                              MetaModalOptions  options, | ||||
|                              guint32           timestamp) | ||||
| { | ||||
|   /* To some extent this duplicates code in meta_display_begin_grab_op(), but there | ||||
|    * are significant differences in how we handle grabs that make it difficult to | ||||
|    * merge the two. | ||||
|    */ | ||||
|   MetaDisplay    *display    = meta_screen_get_display (screen); | ||||
|   MetaCompositor *compositor = display->compositor; | ||||
|   gboolean ok; | ||||
|  | ||||
|   if (compositor->modal_plugin != NULL || display->grab_op != META_GRAB_OP_NONE) | ||||
|     return FALSE; | ||||
|  | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     ok = begin_modal_wayland (screen, plugin, options, timestamp); | ||||
|   else | ||||
|     ok = begin_modal_x11 (screen, plugin, options, timestamp); | ||||
|   if (!ok) | ||||
|     return FALSE; | ||||
|  | ||||
|   display->grab_op = META_GRAB_OP_COMPOSITOR; | ||||
|   display->grab_window = NULL; | ||||
|   display->grab_screen = screen; | ||||
|   display->grab_have_pointer = TRUE; | ||||
|   display->grab_have_keyboard = TRUE; | ||||
|  | ||||
|   compositor->modal_plugin = plugin; | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_end_modal_for_plugin (MetaScreen     *screen, | ||||
|                            MetaPlugin     *plugin, | ||||
| @@ -516,8 +586,19 @@ meta_end_modal_for_plugin (MetaScreen     *screen, | ||||
|  | ||||
|   g_return_if_fail (compositor->modal_plugin == plugin); | ||||
|  | ||||
|   XIUngrabDevice (xdpy, META_VIRTUAL_CORE_POINTER_ID, timestamp); | ||||
|   XIUngrabDevice (xdpy, META_VIRTUAL_CORE_KEYBOARD_ID, timestamp); | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       MetaWaylandCompositor *compositor = meta_wayland_compositor_get_default (); | ||||
|  | ||||
|       meta_wayland_pointer_end_modal (&compositor->seat->pointer); | ||||
|       meta_wayland_keyboard_end_modal (&compositor->seat->keyboard, | ||||
|                                        timestamp); | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       XIUngrabDevice (xdpy, META_VIRTUAL_CORE_POINTER_ID, timestamp); | ||||
|       XIUngrabDevice (xdpy, META_VIRTUAL_CORE_KEYBOARD_ID, timestamp); | ||||
|     } | ||||
|  | ||||
|   display->grab_op = META_GRAB_OP_NONE; | ||||
|   display->grab_window = NULL; | ||||
| @@ -569,6 +650,11 @@ redirect_windows (MetaCompositor *compositor, | ||||
|   guint        n_retries; | ||||
|   guint        max_retries; | ||||
|  | ||||
|   /* If we're running with wayland, connected to a headless xwayland | ||||
|    * server then all the windows are implicitly redirected offscreen | ||||
|    * already and it would generate an error to try and explicitly | ||||
|    * redirect them via XCompositeRedirectSubwindows() */ | ||||
|  | ||||
|   if (meta_get_replace_current_wm ()) | ||||
|     max_retries = 5; | ||||
|   else | ||||
| @@ -609,8 +695,9 @@ meta_compositor_manage_screen (MetaCompositor *compositor, | ||||
|   MetaCompScreen *info; | ||||
|   MetaDisplay    *display       = meta_screen_get_display (screen); | ||||
|   Display        *xdisplay      = meta_display_get_xdisplay (display); | ||||
|   Window          xwin; | ||||
|   Window          xwin = None; | ||||
|   gint            width, height; | ||||
|   MetaWaylandCompositor *wayland_compositor; | ||||
|  | ||||
|   /* Check if the screen is already managed */ | ||||
|   if (meta_screen_get_compositor_data (screen)) | ||||
| @@ -623,7 +710,14 @@ meta_compositor_manage_screen (MetaCompositor *compositor, | ||||
|    * We have to initialize info->pending_input_region to an empty region explicitly,  | ||||
|    * because None value is used to mean that the whole screen is an input region. | ||||
|    */ | ||||
|   info->pending_input_region = XFixesCreateRegion (xdisplay, NULL, 0); | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     info->pending_input_region = XFixesCreateRegion (xdisplay, NULL, 0); | ||||
|   else | ||||
|     { | ||||
|       /* Stage input region trickery isn't needed when we're running as a | ||||
|        * wayland compositor. */ | ||||
|       info->pending_input_region = None; | ||||
|     } | ||||
|  | ||||
|   info->screen = screen; | ||||
|  | ||||
| @@ -634,7 +728,56 @@ meta_compositor_manage_screen (MetaCompositor *compositor, | ||||
|  | ||||
|   meta_screen_set_cm_selection (screen); | ||||
|  | ||||
|   info->stage = clutter_stage_new (); | ||||
|   /* We will have already created a stage if running as a wayland | ||||
|    * compositor... */ | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       wayland_compositor = meta_wayland_compositor_get_default (); | ||||
|       info->stage = wayland_compositor->stage; | ||||
|  | ||||
|       meta_screen_get_size (screen, &width, &height); | ||||
|       clutter_actor_set_size (info->stage, width, height); | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       info->stage = clutter_stage_new (); | ||||
|  | ||||
|       meta_screen_get_size (screen, &width, &height); | ||||
|       clutter_actor_realize (info->stage); | ||||
|  | ||||
|       xwin = clutter_x11_get_stage_window (CLUTTER_STAGE (info->stage)); | ||||
|  | ||||
|       XResizeWindow (xdisplay, xwin, width, height); | ||||
|  | ||||
|         { | ||||
|           long event_mask; | ||||
|           unsigned char mask_bits[XIMaskLen (XI_LASTEVENT)] = { 0 }; | ||||
|           XIEventMask mask = { XIAllMasterDevices, sizeof (mask_bits), mask_bits }; | ||||
|           XWindowAttributes attr; | ||||
|  | ||||
|           meta_core_add_old_event_mask (xdisplay, xwin, &mask); | ||||
|  | ||||
|           XISetMask (mask.mask, XI_KeyPress); | ||||
|           XISetMask (mask.mask, XI_KeyRelease); | ||||
|           XISetMask (mask.mask, XI_ButtonPress); | ||||
|           XISetMask (mask.mask, XI_ButtonRelease); | ||||
|           XISetMask (mask.mask, XI_Enter); | ||||
|           XISetMask (mask.mask, XI_Leave); | ||||
|           XISetMask (mask.mask, XI_FocusIn); | ||||
|           XISetMask (mask.mask, XI_FocusOut); | ||||
|           XISetMask (mask.mask, XI_Motion); | ||||
|           XIClearMask (mask.mask, XI_TouchBegin); | ||||
|           XIClearMask (mask.mask, XI_TouchEnd); | ||||
|           XIClearMask (mask.mask, XI_TouchUpdate); | ||||
|           XISelectEvents (xdisplay, xwin, &mask, 1); | ||||
|  | ||||
|           event_mask = ExposureMask | PropertyChangeMask | StructureNotifyMask; | ||||
|           if (XGetWindowAttributes (xdisplay, xwin, &attr)) | ||||
|             event_mask |= attr.your_event_mask; | ||||
|  | ||||
|           XSelectInput (xdisplay, xwin, event_mask); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   clutter_stage_set_paint_callback (CLUTTER_STAGE (info->stage), | ||||
|                                     after_stage_paint, | ||||
| @@ -643,42 +786,6 @@ meta_compositor_manage_screen (MetaCompositor *compositor, | ||||
|  | ||||
|   clutter_stage_set_sync_delay (CLUTTER_STAGE (info->stage), META_SYNC_DELAY); | ||||
|  | ||||
|   meta_screen_get_size (screen, &width, &height); | ||||
|   clutter_actor_realize (info->stage); | ||||
|  | ||||
|   xwin = clutter_x11_get_stage_window (CLUTTER_STAGE (info->stage)); | ||||
|  | ||||
|   XResizeWindow (xdisplay, xwin, width, height); | ||||
|  | ||||
|   { | ||||
|     long event_mask; | ||||
|     unsigned char mask_bits[XIMaskLen (XI_LASTEVENT)] = { 0 }; | ||||
|     XIEventMask mask = { XIAllMasterDevices, sizeof (mask_bits), mask_bits }; | ||||
|     XWindowAttributes attr; | ||||
|  | ||||
|     meta_core_add_old_event_mask (xdisplay, xwin, &mask); | ||||
|  | ||||
|     XISetMask (mask.mask, XI_KeyPress); | ||||
|     XISetMask (mask.mask, XI_KeyRelease); | ||||
|     XISetMask (mask.mask, XI_ButtonPress); | ||||
|     XISetMask (mask.mask, XI_ButtonRelease); | ||||
|     XISetMask (mask.mask, XI_Enter); | ||||
|     XISetMask (mask.mask, XI_Leave); | ||||
|     XISetMask (mask.mask, XI_FocusIn); | ||||
|     XISetMask (mask.mask, XI_FocusOut); | ||||
|     XISetMask (mask.mask, XI_Motion); | ||||
|     XIClearMask (mask.mask, XI_TouchBegin); | ||||
|     XIClearMask (mask.mask, XI_TouchEnd); | ||||
|     XIClearMask (mask.mask, XI_TouchUpdate); | ||||
|     XISelectEvents (xdisplay, xwin, &mask, 1); | ||||
|  | ||||
|     event_mask = ExposureMask | PropertyChangeMask | StructureNotifyMask; | ||||
|     if (XGetWindowAttributes (xdisplay, xwin, &attr)) | ||||
|       event_mask |= attr.your_event_mask; | ||||
|  | ||||
|     XSelectInput (xdisplay, xwin, event_mask); | ||||
|   } | ||||
|  | ||||
|   info->window_group = meta_window_group_new (screen); | ||||
|   info->top_window_group = meta_window_group_new (screen); | ||||
|  | ||||
| @@ -687,53 +794,66 @@ meta_compositor_manage_screen (MetaCompositor *compositor, | ||||
|  | ||||
|   info->plugin_mgr = meta_plugin_manager_new (screen); | ||||
|  | ||||
|   /* | ||||
|    * Delay the creation of the overlay window as long as we can, to avoid | ||||
|    * blanking out the screen. This means that during the plugin loading, the | ||||
|    * overlay window is not accessible; if the plugin needs to access it | ||||
|    * directly, it should hook into the "show" signal on stage, and do | ||||
|    * its stuff there. | ||||
|    */ | ||||
|   info->output = get_output_window (screen); | ||||
|   XReparentWindow (xdisplay, xwin, info->output, 0, 0); | ||||
|  | ||||
|  /* Make sure there isn't any left-over output shape on the  | ||||
|   * overlay window by setting the whole screen to be an | ||||
|   * output region. | ||||
|   *  | ||||
|   * Note: there doesn't seem to be any real chance of that | ||||
|   *  because the X server will destroy the overlay window | ||||
|   *  when the last client using it exits. | ||||
|   */ | ||||
|   XFixesSetWindowShapeRegion (xdisplay, info->output, ShapeBounding, 0, 0, None); | ||||
|  | ||||
|   do_set_stage_input_region (screen, info->pending_input_region); | ||||
|   if (info->pending_input_region != None) | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       XFixesDestroyRegion (xdisplay, info->pending_input_region); | ||||
|       info->pending_input_region = None; | ||||
|       /* NB: When running as a wayland compositor we don't need an X | ||||
|        * composite overlay window, and we don't need to play any input | ||||
|        * region tricks to redirect events into clutter. */ | ||||
|       info->output = None; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       /* | ||||
|        * Delay the creation of the overlay window as long as we can, to avoid | ||||
|        * blanking out the screen. This means that during the plugin loading, the | ||||
|        * overlay window is not accessible; if the plugin needs to access it | ||||
|        * directly, it should hook into the "show" signal on stage, and do | ||||
|        * its stuff there. | ||||
|        */ | ||||
|       info->output = get_output_window (screen); | ||||
|       XReparentWindow (xdisplay, xwin, info->output, 0, 0); | ||||
|  | ||||
|   /* Map overlay window before redirecting windows offscreen so we catch their | ||||
|    * contents until we show the stage. | ||||
|    */ | ||||
|   XMapWindow (xdisplay, info->output); | ||||
|       /* Make sure there isn't any left-over output shape on the  | ||||
|        * overlay window by setting the whole screen to be an | ||||
|        * output region. | ||||
|        *  | ||||
|        * Note: there doesn't seem to be any real chance of that | ||||
|        *  because the X server will destroy the overlay window | ||||
|        *  when the last client using it exits. | ||||
|        */ | ||||
|       XFixesSetWindowShapeRegion (xdisplay, info->output, ShapeBounding, 0, 0, None); | ||||
|  | ||||
|   redirect_windows (compositor, screen); | ||||
|       do_set_stage_input_region (screen, info->pending_input_region); | ||||
|       if (info->pending_input_region != None) | ||||
|         { | ||||
|           XFixesDestroyRegion (xdisplay, info->pending_input_region); | ||||
|           info->pending_input_region = None; | ||||
|         } | ||||
|  | ||||
|       /* Map overlay window before redirecting windows offscreen so we catch their | ||||
|        * contents until we show the stage. | ||||
|        */ | ||||
|       XMapWindow (xdisplay, info->output); | ||||
|  | ||||
|       redirect_windows (compositor, screen); | ||||
|     } | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_compositor_unmanage_screen (MetaCompositor *compositor, | ||||
|                                  MetaScreen     *screen) | ||||
| { | ||||
|   MetaDisplay    *display       = meta_screen_get_display (screen); | ||||
|   Display        *xdisplay      = meta_display_get_xdisplay (display); | ||||
|   Window          xroot         = meta_screen_get_xroot (screen); | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       MetaDisplay    *display       = meta_screen_get_display (screen); | ||||
|       Display        *xdisplay      = meta_display_get_xdisplay (display); | ||||
|       Window          xroot         = meta_screen_get_xroot (screen); | ||||
|  | ||||
|   /* This is the most important part of cleanup - we have to do this | ||||
|    * before giving up the window manager selection or the next | ||||
|    * window manager won't be able to redirect subwindows */ | ||||
|   XCompositeUnredirectSubwindows (xdisplay, xroot, CompositeRedirectManual); | ||||
|       /* This is the most important part of cleanup - we have to do this | ||||
|        * before giving up the window manager selection or the next | ||||
|        * window manager won't be able to redirect subwindows */ | ||||
|       XCompositeUnredirectSubwindows (xdisplay, xroot, CompositeRedirectManual); | ||||
|     } | ||||
| } | ||||
|  | ||||
| /* | ||||
| @@ -805,15 +925,18 @@ meta_compositor_remove_window (MetaCompositor *compositor, | ||||
|   if (!window_actor) | ||||
|     return; | ||||
|  | ||||
|   screen = meta_window_get_screen (window); | ||||
|   info = meta_screen_get_compositor_data (screen); | ||||
|  | ||||
|   if (window_actor == info->unredirected_window) | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       meta_window_actor_set_redirected (window_actor, TRUE); | ||||
|       meta_shape_cow_for_window (meta_window_get_screen (meta_window_actor_get_meta_window (info->unredirected_window)), | ||||
|                                  NULL); | ||||
|       info->unredirected_window = NULL; | ||||
|       screen = meta_window_get_screen (window); | ||||
|       info = meta_screen_get_compositor_data (screen); | ||||
|  | ||||
|       if (window_actor == info->unredirected_window) | ||||
|         { | ||||
|           meta_window_actor_set_redirected (window_actor, TRUE); | ||||
|           meta_shape_cow_for_window (meta_window_get_screen (meta_window_actor_get_meta_window (info->unredirected_window)), | ||||
|                                      NULL); | ||||
|           info->unredirected_window = NULL; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   meta_window_actor_destroy (window_actor); | ||||
| @@ -997,7 +1120,8 @@ meta_compositor_process_event (MetaCompositor *compositor, | ||||
|       break; | ||||
|  | ||||
|     default: | ||||
|       if (event->type == meta_display_get_damage_event_base (compositor->display) + XDamageNotify) | ||||
|       if (!meta_is_wayland_compositor () && | ||||
|           event->type == meta_display_get_damage_event_base (compositor->display) + XDamageNotify) | ||||
|         { | ||||
|           /* Core code doesn't handle damage events, so we need to extract the MetaWindow | ||||
|            * ourselves | ||||
| @@ -1016,7 +1140,7 @@ meta_compositor_process_event (MetaCompositor *compositor, | ||||
|  | ||||
|   /* Clutter needs to know about MapNotify events otherwise it will | ||||
|      think the stage is invisible */ | ||||
|   if (event->type == MapNotify) | ||||
|   if (!meta_is_wayland_compositor () && event->type == MapNotify) | ||||
|     clutter_x11_handle_event (event); | ||||
|  | ||||
|   /* The above handling is basically just "observing" the events, so we return | ||||
| @@ -1361,20 +1485,38 @@ meta_compositor_sync_screen_size (MetaCompositor  *compositor, | ||||
| { | ||||
|   MetaDisplay    *display = meta_screen_get_display (screen); | ||||
|   MetaCompScreen *info    = meta_screen_get_compositor_data (screen); | ||||
|   Display        *xdisplay; | ||||
|   Window          xwin; | ||||
|  | ||||
|   DEBUG_TRACE ("meta_compositor_sync_screen_size\n"); | ||||
|   g_return_if_fail (info); | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       /* FIXME: when we support a sliced stage, this is the place to do it | ||||
|          But! This is not the place to apply KMS config, here we only | ||||
|          notify Clutter/Cogl/GL that the framebuffer sizes changed. | ||||
|  | ||||
|   xdisplay = meta_display_get_xdisplay (display); | ||||
|   xwin = clutter_x11_get_stage_window (CLUTTER_STAGE (info->stage)); | ||||
|          And because for now clutter does not do sliced, we use one | ||||
|          framebuffer the size of the whole screen, and when running on | ||||
|          bare metal MetaMonitorManager will do the necessary tricks to | ||||
|          show the right portions on the right screens. | ||||
|       */ | ||||
|  | ||||
|   XResizeWindow (xdisplay, xwin, width, height); | ||||
|       clutter_actor_set_size (info->stage, width, height); | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       Display        *xdisplay; | ||||
|       Window          xwin; | ||||
|  | ||||
|       DEBUG_TRACE ("meta_compositor_sync_screen_size\n"); | ||||
|       g_return_if_fail (info); | ||||
|  | ||||
|       xdisplay = meta_display_get_xdisplay (display); | ||||
|       xwin = clutter_x11_get_stage_window (CLUTTER_STAGE (info->stage)); | ||||
|  | ||||
|       XResizeWindow (xdisplay, xwin, width, height); | ||||
|     } | ||||
|  | ||||
|   meta_verbose ("Changed size for stage on screen %d to %dx%d\n", | ||||
| 		meta_screen_get_screen_number (screen), | ||||
| 		width, height); | ||||
|                 meta_screen_get_screen_number (screen), | ||||
|                 width, height); | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -1438,29 +1580,32 @@ pre_paint_windows (MetaCompScreen *info) | ||||
|   if (info->windows == NULL) | ||||
|     return; | ||||
|  | ||||
|   top_window = g_list_last (info->windows)->data; | ||||
|  | ||||
|   if (meta_window_actor_should_unredirect (top_window) && | ||||
|       info->disable_unredirect_count == 0) | ||||
|     expected_unredirected_window = top_window; | ||||
|  | ||||
|   if (info->unredirected_window != expected_unredirected_window) | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       if (info->unredirected_window != NULL) | ||||
|         { | ||||
|           meta_window_actor_set_redirected (info->unredirected_window, TRUE); | ||||
|           meta_shape_cow_for_window (meta_window_get_screen (meta_window_actor_get_meta_window (info->unredirected_window)), | ||||
|                                      NULL); | ||||
|         } | ||||
|       top_window = g_list_last (info->windows)->data; | ||||
|  | ||||
|       if (expected_unredirected_window != NULL) | ||||
|         { | ||||
|           meta_shape_cow_for_window (meta_window_get_screen (meta_window_actor_get_meta_window (top_window)), | ||||
|                                      meta_window_actor_get_meta_window (top_window)); | ||||
|           meta_window_actor_set_redirected (top_window, FALSE); | ||||
|         } | ||||
|       if (meta_window_actor_should_unredirect (top_window) && | ||||
|           info->disable_unredirect_count == 0) | ||||
|         expected_unredirected_window = top_window; | ||||
|  | ||||
|       info->unredirected_window = expected_unredirected_window; | ||||
|       if (info->unredirected_window != expected_unredirected_window) | ||||
|         { | ||||
|           if (info->unredirected_window != NULL) | ||||
|             { | ||||
|               meta_window_actor_set_redirected (info->unredirected_window, TRUE); | ||||
|               meta_shape_cow_for_window (meta_window_get_screen (meta_window_actor_get_meta_window (info->unredirected_window)), | ||||
|                                          NULL); | ||||
|             } | ||||
|  | ||||
|           if (expected_unredirected_window != NULL) | ||||
|             { | ||||
|               meta_shape_cow_for_window (meta_window_get_screen (meta_window_actor_get_meta_window (top_window)), | ||||
|                                          meta_window_actor_get_meta_window (top_window)); | ||||
|               meta_window_actor_set_redirected (top_window, FALSE); | ||||
|             } | ||||
|  | ||||
|           info->unredirected_window = expected_unredirected_window; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   for (l = info->windows; l; l = l->next) | ||||
|   | ||||
| @@ -37,6 +37,7 @@ | ||||
| #include "mutter-enum-types.h" | ||||
| #include <meta/errors.h> | ||||
| #include <meta/meta-background.h> | ||||
| #include "util-private.h" | ||||
| #include "meta-background-actor-private.h" | ||||
|  | ||||
| #define FRAGMENT_SHADER_DECLARATIONS                                           \ | ||||
|   | ||||
| @@ -189,10 +189,20 @@ _meta_plugin_xevent_filter (MetaPlugin *plugin, | ||||
| { | ||||
|   MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin); | ||||
|  | ||||
|   /* When mutter is running as a wayland compositor, things like input | ||||
|    * events just come directly from clutter so it won't have disabled | ||||
|    * clutter's event retrieval and won't need to forward it events (if | ||||
|    * it did it would lead to recursion). Also when running as a | ||||
|    * wayland compositor we shouldn't be assuming that we're running | ||||
|    * with the clutter x11 backend. | ||||
|    */ | ||||
|  | ||||
|   if (klass->xevent_filter && klass->xevent_filter (plugin, xev)) | ||||
|     return TRUE; | ||||
|   else | ||||
|   else if (!meta_is_wayland_compositor ()) | ||||
|     return clutter_x11_handle_event (xev) != CLUTTER_X11_FILTER_CONTINUE; | ||||
|   else | ||||
|     return FALSE; | ||||
| } | ||||
|  | ||||
| void | ||||
|   | ||||
							
								
								
									
										44
									
								
								src/compositor/meta-shaped-texture-private.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								src/compositor/meta-shaped-texture-private.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| /* | ||||
|  * shaped texture | ||||
|  * | ||||
|  * An actor to draw a texture clipped to a list of rectangles | ||||
|  * | ||||
|  * Authored By Neil Roberts  <neil@linux.intel.com> | ||||
|  * | ||||
|  * Copyright (C) 2008 Intel Corporation | ||||
|  *               2013 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 the Free Software Foundation; either version 2 of the | ||||
|  * License, or (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, but | ||||
|  * WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
|  * General Public License for more details. | ||||
|  * | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program; if not, write to the Free Software | ||||
|  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA | ||||
|  * 02111-1307, USA. | ||||
|  */ | ||||
|  | ||||
| #ifndef __META_SHAPED_TEXTURE_PRIVATE_H__ | ||||
| #define __META_SHAPED_TEXTURE_PRIVATE_H__ | ||||
|  | ||||
| #include <meta/meta-shaped-texture.h> | ||||
| #include "meta-wayland-private.h" | ||||
|  | ||||
| ClutterActor *meta_shaped_texture_new_with_xwindow (Window xwindow); | ||||
| ClutterActor *meta_shaped_texture_new_with_wayland_surface  (MetaWaylandSurface *surface); | ||||
| void meta_shaped_texture_set_wayland_surface                (MetaShapedTexture  *stex, | ||||
|                                                              MetaWaylandSurface *surface); | ||||
| MetaWaylandSurface *meta_shaped_texture_get_wayland_surface (MetaShapedTexture *stex); | ||||
|  | ||||
| void meta_shaped_texture_set_pixmap (MetaShapedTexture *stex, | ||||
|                                      Pixmap             pixmap); | ||||
| void meta_shaped_texture_attach_wayland_buffer (MetaShapedTexture  *stex, | ||||
|                                                 MetaWaylandBuffer  *buffer); | ||||
|  | ||||
| #endif | ||||
| @@ -30,9 +30,14 @@ | ||||
| #include <config.h> | ||||
|  | ||||
| #include <meta/meta-shaped-texture.h> | ||||
| #include <meta/util.h> | ||||
| #include "clutter-utils.h" | ||||
| #include "meta-texture-tower.h" | ||||
|  | ||||
| #include "meta-shaped-texture-private.h" | ||||
| #include "meta-wayland-private.h" | ||||
| #include <cogl/cogl-wayland-server.h> | ||||
|  | ||||
| #include <clutter/clutter.h> | ||||
| #include <cogl/cogl.h> | ||||
| #include <cogl/cogl-texture-pixmap-x11.h> | ||||
| @@ -56,6 +61,13 @@ static void meta_shaped_texture_get_preferred_height (ClutterActor *self, | ||||
|  | ||||
| static gboolean meta_shaped_texture_get_paint_volume (ClutterActor *self, ClutterPaintVolume *volume); | ||||
|  | ||||
| typedef enum _MetaShapedTextureType | ||||
| { | ||||
|   META_SHAPED_TEXTURE_TYPE_X11_PIXMAP, | ||||
|   META_SHAPED_TEXTURE_TYPE_WAYLAND_SURFACE, | ||||
| } MetaShapedTextureType; | ||||
|  | ||||
|  | ||||
| G_DEFINE_TYPE (MetaShapedTexture, meta_shaped_texture, | ||||
|                CLUTTER_TYPE_ACTOR); | ||||
|  | ||||
| @@ -66,11 +78,23 @@ G_DEFINE_TYPE (MetaShapedTexture, meta_shaped_texture, | ||||
| struct _MetaShapedTexturePrivate | ||||
| { | ||||
|   MetaTextureTower *paint_tower; | ||||
|   Pixmap pixmap; | ||||
|   CoglTexturePixmapX11 *texture; | ||||
|  | ||||
|   MetaShapedTextureType type; | ||||
|   union { | ||||
|     struct { | ||||
|       Pixmap pixmap; | ||||
|     } x11; | ||||
|     struct { | ||||
|       MetaWaylandSurface *surface; | ||||
|     } wayland; | ||||
|   }; | ||||
|  | ||||
|   CoglTexture *texture; | ||||
|  | ||||
|   CoglTexture *mask_texture; | ||||
|  | ||||
|   cairo_region_t *clip_region; | ||||
|   cairo_region_t *input_shape_region; | ||||
|   cairo_region_t *opaque_region; | ||||
|  | ||||
|   guint tex_width, tex_height; | ||||
| @@ -103,7 +127,10 @@ meta_shaped_texture_init (MetaShapedTexture *self) | ||||
|   priv = self->priv = META_SHAPED_TEXTURE_GET_PRIVATE (self); | ||||
|  | ||||
|   priv->paint_tower = meta_texture_tower_new (); | ||||
|  | ||||
|   priv->type = META_SHAPED_TEXTURE_TYPE_X11_PIXMAP; | ||||
|   priv->texture = NULL; | ||||
|  | ||||
|   priv->mask_texture = NULL; | ||||
|   priv->create_mipmaps = TRUE; | ||||
| } | ||||
| @@ -197,6 +224,50 @@ paint_clipped_rectangle (CoglFramebuffer       *fb, | ||||
| } | ||||
|  | ||||
|  | ||||
| static void | ||||
| set_cogl_texture (MetaShapedTexture *stex, | ||||
|                   CoglTexture       *cogl_tex) | ||||
| { | ||||
|   MetaShapedTexturePrivate *priv; | ||||
|   guint width, height; | ||||
|  | ||||
|   g_return_if_fail (META_IS_SHAPED_TEXTURE (stex)); | ||||
|  | ||||
|   priv = stex->priv; | ||||
|  | ||||
|   if (priv->texture) | ||||
|     cogl_object_unref (priv->texture); | ||||
|  | ||||
|   priv->texture = cogl_object_ref (cogl_tex); | ||||
|  | ||||
|   if (cogl_tex != NULL) | ||||
|     { | ||||
|       width = cogl_texture_get_width (COGL_TEXTURE (cogl_tex)); | ||||
|       height = cogl_texture_get_height (COGL_TEXTURE (cogl_tex)); | ||||
|  | ||||
|       if (width != priv->tex_width || | ||||
|           height != priv->tex_height) | ||||
|         { | ||||
|           priv->tex_width = width; | ||||
|           priv->tex_height = height; | ||||
|  | ||||
|           clutter_actor_queue_relayout (CLUTTER_ACTOR (stex)); | ||||
|         } | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       /* size changed to 0 going to an invalid handle */ | ||||
|       priv->tex_width = 0; | ||||
|       priv->tex_height = 0; | ||||
|       clutter_actor_queue_relayout (CLUTTER_ACTOR (stex)); | ||||
|     } | ||||
|  | ||||
|   /* NB: We don't queue a redraw of the actor here because we don't | ||||
|    * know how much of the buffer has changed with respect to the | ||||
|    * previous buffer. We only queue a redraw in response to surface | ||||
|    * damage. */ | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_shaped_texture_paint (ClutterActor *actor) | ||||
| { | ||||
| @@ -394,45 +465,60 @@ meta_shaped_texture_pick (ClutterActor       *actor, | ||||
|   MetaShapedTexture *stex = (MetaShapedTexture *) actor; | ||||
|   MetaShapedTexturePrivate *priv = stex->priv; | ||||
|  | ||||
|   if (!clutter_actor_should_pick_paint (actor) || | ||||
|       (priv->clip_region && cairo_region_is_empty (priv->clip_region))) | ||||
|     return; | ||||
|  | ||||
|   /* If there is no region then use the regular pick */ | ||||
|   if (priv->mask_texture == NULL) | ||||
|   if (priv->input_shape_region == NULL) | ||||
|     CLUTTER_ACTOR_CLASS (meta_shaped_texture_parent_class)->pick (actor, color); | ||||
|   else if (clutter_actor_should_pick_paint (actor)) | ||||
|   else | ||||
|     { | ||||
|       CoglTexture *paint_tex; | ||||
|       ClutterActorBox alloc; | ||||
|       guint tex_width, tex_height; | ||||
|       int n_rects; | ||||
|       float *rectangles; | ||||
|       int i; | ||||
|       CoglPipeline *pipeline; | ||||
|       CoglContext *ctx; | ||||
|       CoglFramebuffer *fb; | ||||
|       CoglColor cogl_color; | ||||
|  | ||||
|       paint_tex = COGL_TEXTURE (priv->texture); | ||||
|       /* Note: We don't bother trying to intersect the pick and clip regions | ||||
|        * since needing to copy the region, do the intersection, and probably | ||||
|        * increase the number of rectangles seems more likely to have a negative | ||||
|        * effect. | ||||
|        * | ||||
|        * NB: Most of the time when just using rectangles for picking then | ||||
|        * picking shouldn't involve any rendering, and minimizing the number of | ||||
|        * rectangles has more benefit than reducing the area of the pick | ||||
|        * region. | ||||
|        */ | ||||
|  | ||||
|       if (paint_tex == NULL) | ||||
|         return; | ||||
|       n_rects = cairo_region_num_rectangles (priv->input_shape_region); | ||||
|       rectangles = g_alloca (sizeof (float) * 4 * n_rects); | ||||
|  | ||||
|       tex_width = cogl_texture_get_width (paint_tex); | ||||
|       tex_height = cogl_texture_get_height (paint_tex); | ||||
|       for (i = 0; i < n_rects; i++) | ||||
|         { | ||||
|           cairo_rectangle_int_t rect; | ||||
|           int pos = i * 4; | ||||
|  | ||||
|       if (tex_width == 0 || tex_height == 0) /* no contents yet */ | ||||
|         return; | ||||
|           cairo_region_get_rectangle (priv->input_shape_region, i, &rect); | ||||
|  | ||||
|           rectangles[pos] = rect.x; | ||||
|           rectangles[pos + 1] = rect.y; | ||||
|           rectangles[pos + 2] = rect.x + rect.width; | ||||
|           rectangles[pos + 3] = rect.y + rect.height; | ||||
|         } | ||||
|  | ||||
|       ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ()); | ||||
|       fb = cogl_get_draw_framebuffer (); | ||||
|  | ||||
|       cogl_color_init_from_4ub (&cogl_color, color->red, color->green, color->blue, color->alpha); | ||||
|  | ||||
|       pipeline = get_masked_pipeline (ctx); | ||||
|       cogl_pipeline_set_layer_texture (pipeline, 1, priv->mask_texture); | ||||
|       pipeline = cogl_pipeline_new (ctx); | ||||
|       cogl_pipeline_set_color (pipeline, &cogl_color); | ||||
|  | ||||
|       clutter_actor_get_allocation_box (actor, &alloc); | ||||
|  | ||||
|       cogl_framebuffer_draw_rectangle (fb, pipeline, | ||||
|                                        0, 0, | ||||
|                                        alloc.x2 - alloc.x1, | ||||
|                                        alloc.y2 - alloc.y1); | ||||
|       cogl_framebuffer_draw_rectangles (fb, pipeline, | ||||
|                                         rectangles, n_rects); | ||||
|       cogl_object_unref (pipeline); | ||||
|     } | ||||
| } | ||||
| @@ -483,11 +569,45 @@ meta_shaped_texture_get_paint_volume (ClutterActor *self, | ||||
| } | ||||
|  | ||||
| ClutterActor * | ||||
| meta_shaped_texture_new (void) | ||||
| meta_shaped_texture_new_with_wayland_surface (MetaWaylandSurface *surface) | ||||
| { | ||||
|   ClutterActor *self = g_object_new (META_TYPE_SHAPED_TEXTURE, NULL); | ||||
|   ClutterActor *actor = g_object_new (META_TYPE_SHAPED_TEXTURE, NULL); | ||||
|   MetaShapedTexturePrivate *priv = META_SHAPED_TEXTURE (actor)->priv; | ||||
|  | ||||
|   return self; | ||||
|   /* XXX: it could probably be better to have a "type" construct-only | ||||
|    * property or create wayland/x11 subclasses */ | ||||
|   priv->type = META_SHAPED_TEXTURE_TYPE_WAYLAND_SURFACE; | ||||
|  | ||||
|   meta_shaped_texture_set_wayland_surface (META_SHAPED_TEXTURE (actor), | ||||
|                                            surface); | ||||
|  | ||||
|   return actor; | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_shaped_texture_set_wayland_surface (MetaShapedTexture *stex, | ||||
|                                          MetaWaylandSurface *surface) | ||||
| { | ||||
|   MetaShapedTexturePrivate *priv = stex->priv; | ||||
|  | ||||
|   priv->wayland.surface = surface; | ||||
|  | ||||
|   if (surface && surface->buffer_ref.buffer) | ||||
|     meta_shaped_texture_attach_wayland_buffer (stex, | ||||
|                                                surface->buffer_ref.buffer); | ||||
| } | ||||
|  | ||||
| MetaWaylandSurface * | ||||
| meta_shaped_texture_get_wayland_surface (MetaShapedTexture *stex) | ||||
| { | ||||
|   MetaShapedTexturePrivate *priv = stex->priv; | ||||
|   return priv->wayland.surface; | ||||
| } | ||||
|  | ||||
| ClutterActor * | ||||
| meta_shaped_texture_new_with_xwindow (Window xwindow) | ||||
| { | ||||
|   return g_object_new (META_TYPE_SHAPED_TEXTURE, NULL); | ||||
| } | ||||
|  | ||||
| void | ||||
| @@ -506,8 +626,7 @@ meta_shaped_texture_set_create_mipmaps (MetaShapedTexture *stex, | ||||
|     { | ||||
|       CoglTexture *base_texture; | ||||
|       priv->create_mipmaps = create_mipmaps; | ||||
|       base_texture = create_mipmaps ? | ||||
|         COGL_TEXTURE (priv->texture) : NULL; | ||||
|       base_texture = create_mipmaps ? priv->texture : NULL; | ||||
|       meta_texture_tower_set_base_texture (priv->paint_tower, base_texture); | ||||
|     } | ||||
| } | ||||
| @@ -533,6 +652,111 @@ meta_shaped_texture_set_mask_texture (MetaShapedTexture *stex, | ||||
|   clutter_actor_queue_redraw (CLUTTER_ACTOR (stex)); | ||||
| } | ||||
|  | ||||
| static void | ||||
| wayland_surface_update_area (MetaShapedTexture *stex, | ||||
|                              int                x, | ||||
|                              int                y, | ||||
|                              int                width, | ||||
|                              int                height) | ||||
| { | ||||
|   MetaShapedTexturePrivate *priv; | ||||
|   MetaWaylandBuffer *buffer; | ||||
|  | ||||
|   priv = stex->priv; | ||||
|  | ||||
|   g_return_if_fail (priv->type == META_SHAPED_TEXTURE_TYPE_WAYLAND_SURFACE); | ||||
|   g_return_if_fail (priv->texture != NULL); | ||||
|  | ||||
|   buffer = priv->wayland.surface->buffer_ref.buffer; | ||||
|  | ||||
|   if (buffer) | ||||
|     { | ||||
|       struct wl_resource *resource = buffer->resource; | ||||
|       struct wl_shm_buffer *shm_buffer = wl_shm_buffer_get (resource); | ||||
|  | ||||
|       if (shm_buffer) | ||||
|         { | ||||
|           CoglPixelFormat format; | ||||
|  | ||||
|           switch (wl_shm_buffer_get_format (shm_buffer)) | ||||
|             { | ||||
| #if G_BYTE_ORDER == G_BIG_ENDIAN | ||||
|             case WL_SHM_FORMAT_ARGB8888: | ||||
|               format = COGL_PIXEL_FORMAT_ARGB_8888_PRE; | ||||
|               break; | ||||
|             case WL_SHM_FORMAT_XRGB8888: | ||||
|               format = COGL_PIXEL_FORMAT_ARGB_8888; | ||||
|               break; | ||||
| #elif G_BYTE_ORDER == G_LITTLE_ENDIAN | ||||
|             case WL_SHM_FORMAT_ARGB8888: | ||||
|               format = COGL_PIXEL_FORMAT_BGRA_8888_PRE; | ||||
|               break; | ||||
|             case WL_SHM_FORMAT_XRGB8888: | ||||
|               format = COGL_PIXEL_FORMAT_BGRA_8888; | ||||
|               break; | ||||
| #endif | ||||
|             default: | ||||
|               g_warn_if_reached (); | ||||
|               format = COGL_PIXEL_FORMAT_ARGB_8888; | ||||
|             } | ||||
|  | ||||
|           cogl_texture_set_region (priv->texture, | ||||
|                                    x, y, | ||||
|                                    x, y, | ||||
|                                    width, height, | ||||
|                                    width, height, | ||||
|                                    format, | ||||
|                                    wl_shm_buffer_get_stride (shm_buffer), | ||||
|                                    wl_shm_buffer_get_data (shm_buffer)); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| get_clip (MetaShapedTexture *stex, | ||||
|           int x, | ||||
|           int y, | ||||
|           int width, | ||||
|           int height, | ||||
|           cairo_rectangle_int_t *clip) | ||||
| { | ||||
|   ClutterActor *self = CLUTTER_ACTOR (stex); | ||||
|   MetaShapedTexturePrivate *priv; | ||||
|   ClutterActorBox allocation; | ||||
|   float scale_x; | ||||
|   float scale_y; | ||||
|  | ||||
|   /* NB: clutter_actor_queue_redraw_with_clip expects a box in the actor's | ||||
|    * coordinate space so we need to convert from surface coordinates to | ||||
|    * actor coordinates... | ||||
|    */ | ||||
|  | ||||
|   /* Calling clutter_actor_get_allocation_box() is enormously expensive | ||||
|    * if the actor has an out-of-date allocation, since it triggers | ||||
|    * a full redraw. clutter_actor_queue_redraw_with_clip() would redraw | ||||
|    * the whole stage anyways in that case, so just go ahead and do | ||||
|    * it here. | ||||
|    */ | ||||
|   if (!clutter_actor_has_allocation (self)) | ||||
|     return FALSE; | ||||
|  | ||||
|   priv = stex->priv; | ||||
|  | ||||
|   if (priv->tex_width == 0 || priv->tex_height == 0) | ||||
|     return FALSE; | ||||
|  | ||||
|   clutter_actor_get_allocation_box (self, &allocation); | ||||
|  | ||||
|   scale_x = (allocation.x2 - allocation.x1) / priv->tex_width; | ||||
|   scale_y = (allocation.y2 - allocation.y1) / priv->tex_height; | ||||
|  | ||||
|   clip->x = x * scale_x; | ||||
|   clip->y = y * scale_y; | ||||
|   clip->width = width * scale_x; | ||||
|   clip->height = height * scale_y; | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * meta_shaped_texture_update_area: | ||||
| @@ -561,18 +785,29 @@ meta_shaped_texture_update_area (MetaShapedTexture *stex, | ||||
| 				 cairo_region_t    *unobscured_region) | ||||
| { | ||||
|   MetaShapedTexturePrivate *priv; | ||||
|   const cairo_rectangle_int_t clip = { x, y, width, height }; | ||||
|   cairo_rectangle_int_t clip; | ||||
|   gboolean has_clip; | ||||
|  | ||||
|   priv = stex->priv; | ||||
|  | ||||
|   if (priv->texture == NULL) | ||||
|     return FALSE; | ||||
|  | ||||
|   cogl_texture_pixmap_x11_update_area (priv->texture, | ||||
|                                        x, y, width, height); | ||||
|   switch (priv->type) | ||||
|     { | ||||
|     case META_SHAPED_TEXTURE_TYPE_X11_PIXMAP: | ||||
|       cogl_texture_pixmap_x11_update_area (COGL_TEXTURE_PIXMAP_X11 (priv->texture), | ||||
|                                            x, y, width, height); | ||||
|       break; | ||||
|     case META_SHAPED_TEXTURE_TYPE_WAYLAND_SURFACE: | ||||
|       wayland_surface_update_area (stex, x, y, width, height); | ||||
|       break; | ||||
|     } | ||||
|  | ||||
|   meta_texture_tower_update_area (priv->paint_tower, x, y, width, height); | ||||
|  | ||||
|   has_clip = get_clip (stex, x, y, width, height, &clip); | ||||
|  | ||||
|   if (unobscured_region) | ||||
|     { | ||||
|       cairo_region_t *intersection; | ||||
| @@ -581,7 +816,8 @@ meta_shaped_texture_update_area (MetaShapedTexture *stex, | ||||
|         return FALSE; | ||||
|  | ||||
|       intersection = cairo_region_copy (unobscured_region); | ||||
|       cairo_region_intersect_rectangle (intersection, &clip); | ||||
|       if (has_clip) | ||||
| 	cairo_region_intersect_rectangle (intersection, &clip); | ||||
|  | ||||
|       if (!cairo_region_is_empty (intersection)) | ||||
|         { | ||||
| @@ -598,52 +834,14 @@ meta_shaped_texture_update_area (MetaShapedTexture *stex, | ||||
|       return FALSE; | ||||
|     } | ||||
|  | ||||
|   clutter_actor_queue_redraw_with_clip (CLUTTER_ACTOR (stex), &clip); | ||||
|   if (has_clip) | ||||
|     clutter_actor_queue_redraw_with_clip (CLUTTER_ACTOR (stex), &clip); | ||||
|   else | ||||
|     clutter_actor_queue_redraw (CLUTTER_ACTOR (stex)); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| static void | ||||
| set_cogl_texture (MetaShapedTexture    *stex, | ||||
|                   CoglTexturePixmapX11 *cogl_tex) | ||||
| { | ||||
|   MetaShapedTexturePrivate *priv; | ||||
|   guint width, height; | ||||
|  | ||||
|   g_return_if_fail (META_IS_SHAPED_TEXTURE (stex)); | ||||
|  | ||||
|   priv = stex->priv; | ||||
|  | ||||
|   if (priv->texture != NULL) | ||||
|     cogl_object_unref (priv->texture); | ||||
|  | ||||
|   priv->texture = cogl_tex; | ||||
|  | ||||
|   if (cogl_tex != NULL) | ||||
|     { | ||||
|       width = cogl_texture_get_width (COGL_TEXTURE (cogl_tex)); | ||||
|       height = cogl_texture_get_height (COGL_TEXTURE (cogl_tex)); | ||||
|  | ||||
|       if (width != priv->tex_width || | ||||
|           height != priv->tex_height) | ||||
|         { | ||||
|           priv->tex_width = width; | ||||
|           priv->tex_height = height; | ||||
|  | ||||
|           clutter_actor_queue_relayout (CLUTTER_ACTOR (stex)); | ||||
|         } | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       /* size changed to 0 going to an inavlid texture */ | ||||
|       priv->tex_width = 0; | ||||
|       priv->tex_height = 0; | ||||
|       clutter_actor_queue_relayout (CLUTTER_ACTOR (stex)); | ||||
|     } | ||||
|  | ||||
|   clutter_actor_queue_redraw (CLUTTER_ACTOR (stex)); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * meta_shaped_texture_set_pixmap: | ||||
|  * @stex: The #MetaShapedTexture | ||||
| @@ -659,16 +857,18 @@ meta_shaped_texture_set_pixmap (MetaShapedTexture *stex, | ||||
|  | ||||
|   priv = stex->priv; | ||||
|  | ||||
|   if (priv->pixmap == pixmap) | ||||
|   if (priv->x11.pixmap == pixmap) | ||||
|     return; | ||||
|  | ||||
|   priv->pixmap = pixmap; | ||||
|   priv->x11.pixmap = pixmap; | ||||
|  | ||||
|   if (pixmap != None) | ||||
|     { | ||||
|       CoglContext *ctx = | ||||
|         clutter_backend_get_cogl_context (clutter_get_default_backend ()); | ||||
|       set_cogl_texture (stex, cogl_texture_pixmap_x11_new (ctx, pixmap, FALSE, NULL)); | ||||
|       CoglTexture *texture = | ||||
|         COGL_TEXTURE (cogl_texture_pixmap_x11_new (ctx, pixmap, FALSE, NULL)); | ||||
|       set_cogl_texture (stex, texture); | ||||
|     } | ||||
|   else | ||||
|     set_cogl_texture (stex, NULL); | ||||
| @@ -678,6 +878,33 @@ meta_shaped_texture_set_pixmap (MetaShapedTexture *stex, | ||||
|                                          COGL_TEXTURE (priv->texture)); | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_shaped_texture_attach_wayland_buffer (MetaShapedTexture  *stex, | ||||
|                                            MetaWaylandBuffer  *buffer) | ||||
| { | ||||
|   MetaShapedTexturePrivate *priv; | ||||
|  | ||||
|   g_return_if_fail (META_IS_SHAPED_TEXTURE (stex)); | ||||
|  | ||||
|   priv = stex->priv; | ||||
|  | ||||
|   /* TODO: we should change this api to be something like | ||||
|    * meta_shaped_texture_notify_buffer_attach() since we now maintain | ||||
|    * a reference to the MetaWaylandSurface where we can access the | ||||
|    * buffer without it being explicitly passed as an argument. | ||||
|    */ | ||||
|   g_return_if_fail (priv->wayland.surface->buffer_ref.buffer == buffer); | ||||
|  | ||||
|   if (buffer) | ||||
|     set_cogl_texture (stex, buffer->texture); | ||||
|   else | ||||
|     set_cogl_texture (stex, NULL); | ||||
|  | ||||
|   if (priv->create_mipmaps) | ||||
|     meta_texture_tower_set_base_texture (priv->paint_tower, | ||||
|                                          COGL_TEXTURE (priv->texture)); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * meta_shaped_texture_get_texture: | ||||
|  * @stex: The #MetaShapedTexture | ||||
| @@ -691,6 +918,41 @@ meta_shaped_texture_get_texture (MetaShapedTexture *stex) | ||||
|   return COGL_TEXTURE (stex->priv->texture); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * meta_shaped_texture_set_input_shape_region: | ||||
|  * @stex: a #MetaShapedTexture | ||||
|  * @shape_region: the region of the texture that should respond to | ||||
|  *    input. | ||||
|  * | ||||
|  * Determines what region of the texture should accept input. For | ||||
|  * X based windows this is defined by the ShapeInput region of the | ||||
|  * window. | ||||
|  */ | ||||
| void | ||||
| meta_shaped_texture_set_input_shape_region (MetaShapedTexture *stex, | ||||
|                                             cairo_region_t    *shape_region) | ||||
| { | ||||
|   MetaShapedTexturePrivate *priv; | ||||
|  | ||||
|   g_return_if_fail (META_IS_SHAPED_TEXTURE (stex)); | ||||
|  | ||||
|   priv = stex->priv; | ||||
|  | ||||
|   if (priv->input_shape_region != NULL) | ||||
|     { | ||||
|       cairo_region_destroy (priv->input_shape_region); | ||||
|       priv->input_shape_region = NULL; | ||||
|     } | ||||
|  | ||||
|   if (shape_region != NULL) | ||||
|     { | ||||
|       cairo_region_reference (shape_region); | ||||
|       priv->input_shape_region = shape_region; | ||||
|     } | ||||
|  | ||||
|   clutter_actor_queue_redraw (CLUTTER_ACTOR (stex)); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * meta_shaped_texture_set_clip_region: | ||||
|  * @stex: a #MetaShapedTexture | ||||
|   | ||||
| @@ -62,7 +62,6 @@ struct _MetaTextureTower | ||||
|   CoglTexture *textures[MAX_TEXTURE_LEVELS]; | ||||
|   CoglOffscreen *fbos[MAX_TEXTURE_LEVELS]; | ||||
|   Box invalid[MAX_TEXTURE_LEVELS]; | ||||
|   CoglPipeline *pipeline_template; | ||||
| }; | ||||
|  | ||||
| /** | ||||
| @@ -94,9 +93,6 @@ meta_texture_tower_free (MetaTextureTower *tower) | ||||
| { | ||||
|   g_return_if_fail (tower != NULL); | ||||
|  | ||||
|   if (tower->pipeline_template != NULL) | ||||
|     cogl_object_unref (tower->pipeline_template); | ||||
|  | ||||
|   meta_texture_tower_set_base_texture (tower, NULL); | ||||
|  | ||||
|   g_slice_free (MetaTextureTower, tower); | ||||
| @@ -387,7 +383,7 @@ texture_tower_create_texture (MetaTextureTower *tower, | ||||
|   tower->invalid[level].y2 = height; | ||||
| } | ||||
|  | ||||
| static void | ||||
| static gboolean | ||||
| texture_tower_revalidate_fbo (MetaTextureTower *tower, | ||||
|                               int               level) | ||||
| { | ||||
| @@ -398,50 +394,174 @@ texture_tower_revalidate_fbo (MetaTextureTower *tower, | ||||
|   int dest_texture_width = cogl_texture_get_width (dest_texture); | ||||
|   int dest_texture_height = cogl_texture_get_height (dest_texture); | ||||
|   Box *invalid = &tower->invalid[level]; | ||||
|   CoglFramebuffer *fb; | ||||
|   CoglError *catch_error = NULL; | ||||
|   CoglPipeline *pipeline; | ||||
|   CoglMatrix modelview; | ||||
|  | ||||
|   if (tower->fbos[level] == NULL) | ||||
|     tower->fbos[level] = cogl_offscreen_new_with_texture (dest_texture); | ||||
|     tower->fbos[level] = cogl_offscreen_new_to_texture (dest_texture); | ||||
|  | ||||
|   fb = COGL_FRAMEBUFFER (tower->fbos[level]); | ||||
|   if (tower->fbos[level] == NULL) | ||||
|     return FALSE; | ||||
|  | ||||
|   if (!cogl_framebuffer_allocate (fb, &catch_error)) | ||||
|   cogl_push_framebuffer (COGL_FRAMEBUFFER (tower->fbos[level])); | ||||
|  | ||||
|   cogl_ortho (0, dest_texture_width, dest_texture_height, 0, -1., 1.); | ||||
|  | ||||
|   cogl_matrix_init_identity (&modelview); | ||||
|   cogl_set_modelview_matrix (&modelview); | ||||
|  | ||||
|   cogl_set_source_texture (tower->textures[level - 1]); | ||||
|   cogl_rectangle_with_texture_coords (invalid->x1, invalid->y1, | ||||
|                                       invalid->x2, invalid->y2, | ||||
|                                       (2. * invalid->x1) / source_texture_width, | ||||
|                                       (2. * invalid->y1) / source_texture_height, | ||||
|                                       (2. * invalid->x2) / source_texture_width, | ||||
|                                       (2. * invalid->y2) / source_texture_height); | ||||
|  | ||||
|   cogl_pop_framebuffer (); | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| static void | ||||
| fill_copy (guchar       *buf, | ||||
|            const guchar *source, | ||||
|            int           width) | ||||
| { | ||||
|   memcpy (buf, source, width * 4); | ||||
| } | ||||
|  | ||||
| static void | ||||
| fill_scale_down (guchar       *buf, | ||||
|                  const guchar *source, | ||||
|                  int           width) | ||||
| { | ||||
|   while (width > 1) | ||||
|     { | ||||
|       cogl_error_free (catch_error); | ||||
|       return; | ||||
|       buf[0] = (source[0] + source[4]) / 2; | ||||
|       buf[1] = (source[1] + source[5]) / 2; | ||||
|       buf[2] = (source[2] + source[6]) / 2; | ||||
|       buf[3] = (source[3] + source[7]) / 2; | ||||
|  | ||||
|       buf += 4; | ||||
|       source += 8; | ||||
|       width -= 2; | ||||
|     } | ||||
|  | ||||
|   cogl_framebuffer_orthographic (fb, 0, 0, dest_texture_width, dest_texture_height, -1., 1.); | ||||
|  | ||||
|   if (!tower->pipeline_template) | ||||
|   if (width > 0) | ||||
|     { | ||||
|       CoglContext *ctx = | ||||
|         clutter_backend_get_cogl_context (clutter_get_default_backend ()); | ||||
|       tower->pipeline_template = cogl_pipeline_new (ctx); | ||||
|       cogl_pipeline_set_blend (tower->pipeline_template, "RGBA = ADD (SRC_COLOR, 0)", NULL); | ||||
|       buf[0] = source[0] / 2; | ||||
|       buf[1] = source[1] / 2; | ||||
|       buf[2] = source[2] / 2; | ||||
|       buf[3] = source[3] / 2; | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void | ||||
| texture_tower_revalidate_client (MetaTextureTower *tower, | ||||
|                                  int               level) | ||||
| { | ||||
|   CoglTexture *source_texture = tower->textures[level - 1]; | ||||
|   int source_texture_width = cogl_texture_get_width (source_texture); | ||||
|   int source_texture_height = cogl_texture_get_height (source_texture); | ||||
|   guint source_rowstride; | ||||
|   guchar *source_data; | ||||
|   CoglTexture *dest_texture = tower->textures[level]; | ||||
|   int dest_texture_width = cogl_texture_get_width (dest_texture); | ||||
|   int dest_texture_height = cogl_texture_get_height (dest_texture); | ||||
|   int dest_x = tower->invalid[level].x1; | ||||
|   int dest_y = tower->invalid[level].y1; | ||||
|   int dest_width = tower->invalid[level].x2 - tower->invalid[level].x1; | ||||
|   int dest_height = tower->invalid[level].y2 - tower->invalid[level].y1; | ||||
|   guchar *dest_data; | ||||
|   guchar *source_tmp1 = NULL, *source_tmp2 = NULL; | ||||
|   int i, j; | ||||
|  | ||||
|   source_rowstride = source_texture_width * 4; | ||||
|  | ||||
|   source_data = g_malloc (source_texture_height * source_rowstride); | ||||
|   cogl_texture_get_data (source_texture, TEXTURE_FORMAT, source_rowstride, | ||||
|                          source_data); | ||||
|  | ||||
|   dest_data = g_malloc (dest_height * dest_width * 4); | ||||
|  | ||||
|   if (dest_texture_height < source_texture_height) | ||||
|     { | ||||
|       source_tmp1 = g_malloc (dest_width * 4); | ||||
|       source_tmp2 = g_malloc (dest_width * 4); | ||||
|     } | ||||
|  | ||||
|   pipeline = cogl_pipeline_copy (tower->pipeline_template); | ||||
|   cogl_pipeline_set_layer_texture (pipeline, 0, tower->textures[level - 1]); | ||||
|   for (i = 0; i < dest_height; i++) | ||||
|     { | ||||
|       guchar *dest_row = dest_data + i * dest_width * 4; | ||||
|       if (dest_texture_height < source_texture_height) | ||||
|         { | ||||
|           guchar *source1, *source2; | ||||
|           guchar *dest; | ||||
|  | ||||
|   cogl_framebuffer_draw_textured_rectangle (fb, pipeline, | ||||
|                                             invalid->x1, invalid->y1, | ||||
|                                             invalid->x2, invalid->y2, | ||||
|                                             (2. * invalid->x1) / source_texture_width, | ||||
|                                             (2. * invalid->y1) / source_texture_height, | ||||
|                                             (2. * invalid->x2) / source_texture_width, | ||||
|                                             (2. * invalid->y2) / source_texture_height); | ||||
|           if (dest_texture_width < source_texture_width) | ||||
|             { | ||||
|               fill_scale_down (source_tmp1, | ||||
|                                source_data + ((i + dest_y) * 2) * source_rowstride + dest_x * 2 * 4, | ||||
|                                dest_width * 2); | ||||
|               fill_scale_down (source_tmp2, | ||||
|                                source_data + ((i + dest_y) * 2 + 1) * source_rowstride + dest_x * 2 * 4, | ||||
|                                dest_width * 2); | ||||
|             } | ||||
|           else | ||||
|             { | ||||
|               fill_copy (source_tmp1, | ||||
|                          source_data + ((i + dest_y) * 2) * source_rowstride + dest_x * 4, | ||||
|                          dest_width); | ||||
|               fill_copy (source_tmp2, | ||||
|                          source_data + ((i + dest_y) * 2 + 1) * source_rowstride + dest_x * 4, | ||||
|                          dest_width); | ||||
|             } | ||||
|  | ||||
|   cogl_object_unref (pipeline); | ||||
|           source1 = source_tmp1; | ||||
|           source2 = source_tmp2; | ||||
|  | ||||
|           dest = dest_row; | ||||
|           for (j = 0; j < dest_width * 4; j++) | ||||
|             *(dest++) = (*(source1++) + *(source2++)) / 2; | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           if (dest_texture_width < source_texture_width) | ||||
|             fill_scale_down (dest_row, | ||||
|                              source_data + (i + dest_y) * source_rowstride + dest_x * 2 * 4, | ||||
|                              dest_width * 2); | ||||
|           else | ||||
|             fill_copy (dest_row, | ||||
|                        source_data + (i + dest_y) * source_rowstride, | ||||
|                        dest_width); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   cogl_texture_set_region (dest_texture, | ||||
|                            0, 0, | ||||
|                            dest_x, dest_y, | ||||
|                            dest_width, dest_height, | ||||
|                            dest_width, dest_height, | ||||
|                            TEXTURE_FORMAT, | ||||
|                            4 * dest_width, | ||||
|                            dest_data); | ||||
|  | ||||
|   if (dest_texture_height < source_texture_height) | ||||
|     { | ||||
|       g_free (source_tmp1); | ||||
|       g_free (source_tmp2); | ||||
|     } | ||||
|  | ||||
|   g_free (source_data); | ||||
|   g_free (dest_data); | ||||
| } | ||||
|  | ||||
| static void | ||||
| texture_tower_revalidate (MetaTextureTower *tower, | ||||
|                           int               level) | ||||
| { | ||||
|   texture_tower_revalidate_fbo (tower, level); | ||||
|   if (!texture_tower_revalidate_fbo (tower, level)) | ||||
|     texture_tower_revalidate_client (tower, level); | ||||
| } | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -5,6 +5,9 @@ | ||||
|  | ||||
| #include <config.h> | ||||
|  | ||||
| #include <wayland-server.h> | ||||
| #include <meta-wayland-private.h> | ||||
|  | ||||
| #include <X11/extensions/Xdamage.h> | ||||
| #include <meta/compositor-mutter.h> | ||||
|  | ||||
| @@ -24,8 +27,18 @@ void meta_window_actor_unmaximize (MetaWindowActor *self, | ||||
|                                    MetaRectangle   *old_rect, | ||||
|                                    MetaRectangle   *new_rect); | ||||
|  | ||||
| void meta_window_actor_process_damage (MetaWindowActor    *self, | ||||
|                                        XDamageNotifyEvent *event); | ||||
| void meta_window_actor_process_x11_damage (MetaWindowActor    *self, | ||||
|                                            XDamageNotifyEvent *event); | ||||
|  | ||||
| void meta_window_actor_process_wayland_damage (MetaWindowActor *self, | ||||
|                                                int              x, | ||||
|                                                int              y, | ||||
|                                                int              width, | ||||
|                                                int              height); | ||||
| void meta_window_actor_set_wayland_surface    (MetaWindowActor    *self, | ||||
|                                                MetaWaylandSurface *surface); | ||||
| void meta_window_actor_attach_wayland_buffer  (MetaWindowActor   *self, | ||||
|                                                MetaWaylandBuffer *buffer); | ||||
|  | ||||
| void meta_window_actor_pre_paint      (MetaWindowActor    *self); | ||||
| void meta_window_actor_post_paint     (MetaWindowActor    *self); | ||||
|   | ||||
| @@ -27,10 +27,12 @@ | ||||
| #include "xprops.h" | ||||
|  | ||||
| #include "compositor-private.h" | ||||
| #include "meta-shaped-texture-private.h" | ||||
| #include "meta-shadow-factory-private.h" | ||||
| #include "meta-window-actor-private.h" | ||||
| #include "meta-texture-rectangle.h" | ||||
| #include "region-utils.h" | ||||
| #include "meta-wayland-private.h" | ||||
| #include "monitor-private.h" | ||||
|  | ||||
| enum { | ||||
| @@ -64,14 +66,12 @@ struct _MetaWindowActorPrivate | ||||
|   MetaShadow       *focused_shadow; | ||||
|   MetaShadow       *unfocused_shadow; | ||||
|  | ||||
|   Pixmap            back_pixmap; | ||||
|  | ||||
|   Damage            damage; | ||||
|  | ||||
|   guint8            opacity; | ||||
|  | ||||
|   /* A region that matches the shape of the window, including frame bounds */ | ||||
|   cairo_region_t   *shape_region; | ||||
|   /* If the window has an input shape, a region that matches the shape */ | ||||
|   cairo_region_t   *input_region; | ||||
|   /* The opaque region, from _NET_WM_OPAQUE_REGION, intersected with | ||||
|    * the shape region. */ | ||||
|   cairo_region_t   *opaque_region; | ||||
| @@ -108,31 +108,41 @@ struct _MetaWindowActorPrivate | ||||
|   /* List of FrameData for recent frames */ | ||||
|   GList            *frames; | ||||
|  | ||||
|   Pixmap            back_pixmap; /* Not used in wayland compositor mode */ | ||||
|   Damage            damage; /* Not used in wayland compositor mode */ | ||||
|  | ||||
|   guint		    visible                : 1; | ||||
|   guint		    mapped                 : 1; | ||||
|   guint		    argb32                 : 1; | ||||
|   guint		    disposed               : 1; | ||||
|   guint             redecorating           : 1; | ||||
|  | ||||
|   guint		    needs_damage_all       : 1; | ||||
|   guint		    received_damage        : 1; | ||||
|   guint             repaint_scheduled      : 1; | ||||
|  | ||||
|   /* If set, the client needs to be sent a _NET_WM_FRAME_DRAWN | ||||
|    * client message using the most recent frame in ->frames */ | ||||
|   guint             needs_frame_drawn      : 1; | ||||
|   guint             repaint_scheduled      : 1; | ||||
|  | ||||
|   guint		    needs_pixmap           : 1; | ||||
|   guint             needs_reshape          : 1; | ||||
|   guint             recompute_focused_shadow   : 1; | ||||
|   guint             recompute_unfocused_shadow : 1; | ||||
|   guint		    size_changed           : 1; | ||||
|   guint             updates_frozen         : 1; | ||||
|  | ||||
|   guint		    needs_destroy	   : 1; | ||||
|  | ||||
|   guint             no_shadow              : 1; | ||||
|  | ||||
|  | ||||
|   /*  | ||||
|    * None of these are used in wayland compositor mode... | ||||
|    */ | ||||
|  | ||||
|   guint		    needs_damage_all       : 1; | ||||
|   guint		    received_x11_damage    : 1; | ||||
|  | ||||
|   guint		    needs_pixmap           : 1; | ||||
|  | ||||
|   guint		    x11_size_changed       : 1; | ||||
|   guint             updates_frozen         : 1; | ||||
|  | ||||
|   guint             unredirected           : 1; | ||||
|  | ||||
|   /* This is used to detect fullscreen windows that need to be unredirected */ | ||||
| @@ -176,7 +186,7 @@ static gboolean meta_window_actor_get_paint_volume (ClutterActor       *actor, | ||||
|                                                     ClutterPaintVolume *volume); | ||||
|  | ||||
|  | ||||
| static void     meta_window_actor_detach     (MetaWindowActor *self); | ||||
| static void meta_window_actor_detach_x11_pixmap     (MetaWindowActor *self); | ||||
| static gboolean meta_window_actor_has_shadow (MetaWindowActor *self); | ||||
|  | ||||
| static void meta_window_actor_handle_updates (MetaWindowActor *self); | ||||
| @@ -316,18 +326,21 @@ window_decorated_notify (MetaWindow *mw, | ||||
|   else | ||||
|     new_xwindow = meta_window_get_xwindow (mw); | ||||
|  | ||||
|   meta_window_actor_detach (self); | ||||
|  | ||||
|   /* | ||||
|    * First of all, clean up any resources we are currently using and will | ||||
|    * be replacing. | ||||
|    */ | ||||
|   if (priv->damage != None) | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       meta_error_trap_push (display); | ||||
|       XDamageDestroy (xdisplay, priv->damage); | ||||
|       meta_error_trap_pop (display); | ||||
|       priv->damage = None; | ||||
|       meta_window_actor_detach_x11_pixmap (self); | ||||
|  | ||||
|       /* | ||||
|        * First of all, clean up any resources we are currently using and will | ||||
|        * be replacing. | ||||
|        */ | ||||
|       if (priv->damage != None) | ||||
|         { | ||||
|           meta_error_trap_push (display); | ||||
|           XDamageDestroy (xdisplay, priv->damage); | ||||
|           meta_error_trap_pop (display); | ||||
|           priv->damage = None; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   priv->xwindow = new_xwindow; | ||||
| @@ -356,22 +369,38 @@ meta_window_actor_constructed (GObject *object) | ||||
|   Window                  xwindow  = priv->xwindow; | ||||
|   MetaWindow             *window   = priv->window; | ||||
|   Display                *xdisplay = meta_display_get_xdisplay (display); | ||||
|   XRenderPictFormat      *format; | ||||
|  | ||||
|   priv->damage = XDamageCreate (xdisplay, xwindow, | ||||
|                                 XDamageReportBoundingBox); | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     priv->damage = XDamageCreate (xdisplay, xwindow, | ||||
|                                   XDamageReportBoundingBox); | ||||
|  | ||||
|   format = XRenderFindVisualFormat (xdisplay, window->xvisual); | ||||
|   if (window->client_type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|     { | ||||
|       XRenderPictFormat      *format; | ||||
|  | ||||
|   if (format && format->type == PictTypeDirect && format->direct.alphaMask) | ||||
|     priv->argb32 = TRUE; | ||||
|       format = XRenderFindVisualFormat (xdisplay, window->xvisual); | ||||
|  | ||||
|       if (format && format->type == PictTypeDirect && format->direct.alphaMask) | ||||
|         priv->argb32 = TRUE; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       /* XXX: parse shm formats to determine argb32 */ | ||||
|       priv->argb32 = TRUE; | ||||
|     } | ||||
|  | ||||
|   if (!priv->actor) | ||||
|     { | ||||
|       priv->actor = meta_shaped_texture_new (); | ||||
|       if (meta_is_wayland_compositor ()) | ||||
|         priv->actor = meta_shaped_texture_new_with_wayland_surface (window->surface); | ||||
|       else | ||||
|         priv->actor = meta_shaped_texture_new_with_xwindow (xwindow); | ||||
|  | ||||
|       clutter_actor_add_child (CLUTTER_ACTOR (self), priv->actor); | ||||
|  | ||||
|       if (meta_is_wayland_compositor ()) | ||||
|         clutter_actor_set_reactive (priv->actor, TRUE); | ||||
|  | ||||
|       /* | ||||
|        * Since we are holding a pointer to this actor independently of the | ||||
|        * ClutterContainer internals, and provide a public API to access it, | ||||
| @@ -397,9 +426,10 @@ meta_window_actor_constructed (GObject *object) | ||||
|  | ||||
|   meta_window_actor_update_opacity (self); | ||||
|  | ||||
|   /* Start off with an empty region to maintain the invariant that | ||||
|      the shape region is always set */ | ||||
|   /* Start off with empty regions to maintain the invariant that | ||||
|      these regions are always set */ | ||||
|   priv->shape_region = cairo_region_create (); | ||||
|   priv->input_region = cairo_region_create (); | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -418,11 +448,10 @@ meta_window_actor_dispose (GObject *object) | ||||
|   priv->disposed = TRUE; | ||||
|  | ||||
|   screen   = priv->screen; | ||||
|   display  = meta_screen_get_display (screen); | ||||
|   xdisplay = meta_display_get_xdisplay (display); | ||||
|   info     = meta_screen_get_compositor_data (screen); | ||||
|  | ||||
|   meta_window_actor_detach (self); | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     meta_window_actor_detach_x11_pixmap (self); | ||||
|  | ||||
|   if (priv->send_frame_messages_timer != 0) | ||||
|     { | ||||
| @@ -432,6 +461,7 @@ meta_window_actor_dispose (GObject *object) | ||||
|  | ||||
|   g_clear_pointer (&priv->unobscured_region, cairo_region_destroy); | ||||
|   g_clear_pointer (&priv->shape_region, cairo_region_destroy); | ||||
|   g_clear_pointer (&priv->input_region, cairo_region_destroy); | ||||
|   g_clear_pointer (&priv->opaque_region, cairo_region_destroy); | ||||
|   g_clear_pointer (&priv->shadow_clip, cairo_region_destroy); | ||||
|  | ||||
| @@ -440,8 +470,11 @@ meta_window_actor_dispose (GObject *object) | ||||
|   g_clear_pointer (&priv->unfocused_shadow, meta_shadow_unref); | ||||
|   g_clear_pointer (&priv->shadow_shape, meta_window_shape_unref); | ||||
|  | ||||
|   if (priv->damage != None) | ||||
|   if (!meta_is_wayland_compositor () && priv->damage != None) | ||||
|     { | ||||
|       display  = meta_screen_get_display (screen); | ||||
|       xdisplay = meta_display_get_xdisplay (display); | ||||
|  | ||||
|       meta_error_trap_push (display); | ||||
|       XDamageDestroy (xdisplay, priv->damage); | ||||
|       meta_error_trap_pop (display); | ||||
| @@ -925,7 +958,8 @@ meta_window_actor_showing_on_its_workspace (MetaWindowActor *self) | ||||
| static void | ||||
| meta_window_actor_freeze (MetaWindowActor *self) | ||||
| { | ||||
|   self->priv->freeze_count++; | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     self->priv->freeze_count++; | ||||
| } | ||||
|  | ||||
| static | ||||
| @@ -1012,30 +1046,33 @@ meta_window_actor_damage_all (MetaWindowActor *self) | ||||
| static void | ||||
| meta_window_actor_thaw (MetaWindowActor *self) | ||||
| { | ||||
|   self->priv->freeze_count--; | ||||
|  | ||||
|   if (G_UNLIKELY (self->priv->freeze_count < 0)) | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       g_warning ("Error in freeze/thaw accounting."); | ||||
|       self->priv->freeze_count = 0; | ||||
|       return; | ||||
|       self->priv->freeze_count--; | ||||
|  | ||||
|       if (G_UNLIKELY (self->priv->freeze_count < 0)) | ||||
|         { | ||||
|           g_warning ("Error in freeze/thaw accounting."); | ||||
|           self->priv->freeze_count = 0; | ||||
|           return; | ||||
|         } | ||||
|  | ||||
|       if (self->priv->freeze_count) | ||||
|         return; | ||||
|  | ||||
|       /* We sometimes ignore moves and resizes on frozen windows */ | ||||
|       meta_window_actor_sync_actor_geometry (self, FALSE); | ||||
|  | ||||
|       /* We do this now since we might be going right back into the | ||||
|        * frozen state */ | ||||
|       meta_window_actor_handle_updates (self); | ||||
|  | ||||
|       /* Since we ignore damage events while a window is frozen for certain effects | ||||
|        * we may need to issue an update_area() covering the whole pixmap if we | ||||
|        * don't know what real damage has happened. */ | ||||
|       if (self->priv->needs_damage_all) | ||||
|         meta_window_actor_damage_all (self); | ||||
|     } | ||||
|  | ||||
|   if (self->priv->freeze_count) | ||||
|     return; | ||||
|  | ||||
|   /* We sometimes ignore moves and resizes on frozen windows */ | ||||
|   meta_window_actor_sync_actor_geometry (self, FALSE); | ||||
|  | ||||
|   /* We do this now since we might be going right back into the | ||||
|    * frozen state */ | ||||
|   meta_window_actor_handle_updates (self); | ||||
|  | ||||
|   /* Since we ignore damage events while a window is frozen for certain effects | ||||
|    * we may need to issue an update_area() covering the whole pixmap if we | ||||
|    * don't know what real damage has happened. */ | ||||
|   if (self->priv->needs_damage_all) | ||||
|     meta_window_actor_damage_all (self); | ||||
| } | ||||
|  | ||||
| void | ||||
| @@ -1083,7 +1120,7 @@ meta_window_actor_queue_frame_drawn (MetaWindowActor *self, | ||||
|         { | ||||
|           queue_send_frame_messages_timeout (self); | ||||
|         } | ||||
|       else if (priv->mapped && !priv->needs_pixmap) | ||||
|       else if (priv->mapped && (!meta_is_wayland_compositor () || !priv->needs_pixmap)) | ||||
|         { | ||||
|           const cairo_rectangle_int_t clip = { 0, 0, 1, 1 }; | ||||
|           clutter_actor_queue_redraw_with_clip (priv->actor, &clip); | ||||
| @@ -1109,7 +1146,7 @@ is_frozen (MetaWindowActor *self) | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_window_actor_queue_create_pixmap (MetaWindowActor *self) | ||||
| meta_window_actor_queue_create_x11_pixmap (MetaWindowActor *self) | ||||
| { | ||||
|   MetaWindowActorPrivate *priv = self->priv; | ||||
|  | ||||
| @@ -1213,11 +1250,14 @@ meta_window_actor_after_effects (MetaWindowActor *self) | ||||
|   meta_window_actor_sync_visibility (self); | ||||
|   meta_window_actor_sync_actor_geometry (self, FALSE); | ||||
|  | ||||
|   if (!meta_window_is_mapped (priv->window)) | ||||
|     meta_window_actor_detach (self); | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       if (!meta_window_is_mapped (priv->window)) | ||||
|         meta_window_actor_detach_x11_pixmap (self); | ||||
|  | ||||
|   if (priv->needs_pixmap) | ||||
|     clutter_actor_queue_redraw (priv->actor); | ||||
|       if (priv->needs_pixmap) | ||||
|         clutter_actor_queue_redraw (priv->actor); | ||||
|     } | ||||
| } | ||||
|  | ||||
| void | ||||
| @@ -1298,7 +1338,7 @@ meta_window_actor_effect_completed (MetaWindowActor *self, | ||||
|  * pixmap for a new size. | ||||
|  */ | ||||
| static void | ||||
| meta_window_actor_detach (MetaWindowActor *self) | ||||
| meta_window_actor_detach_x11_pixmap (MetaWindowActor *self) | ||||
| { | ||||
|   MetaWindowActorPrivate *priv     = self->priv; | ||||
|   MetaScreen            *screen   = priv->screen; | ||||
| @@ -1319,7 +1359,7 @@ meta_window_actor_detach (MetaWindowActor *self) | ||||
|   XFreePixmap (xdisplay, priv->back_pixmap); | ||||
|   priv->back_pixmap = None; | ||||
|  | ||||
|   meta_window_actor_queue_create_pixmap (self); | ||||
|   meta_window_actor_queue_create_x11_pixmap (self); | ||||
| } | ||||
|  | ||||
| gboolean | ||||
| @@ -1349,7 +1389,7 @@ meta_window_actor_should_unredirect (MetaWindowActor *self) | ||||
|   if (meta_window_is_override_redirect (metaWindow)) | ||||
|     return TRUE; | ||||
|  | ||||
|   if (priv->does_full_damage) | ||||
|   if (!meta_is_wayland_compositor () && priv->does_full_damage) | ||||
|     return TRUE; | ||||
|  | ||||
|   return FALSE; | ||||
| @@ -1369,7 +1409,7 @@ meta_window_actor_set_redirected (MetaWindowActor *self, gboolean state) | ||||
|       meta_error_trap_push (display); | ||||
|       XCompositeRedirectWindow (xdisplay, xwin, CompositeRedirectManual); | ||||
|       meta_error_trap_pop (display); | ||||
|       meta_window_actor_detach (self); | ||||
|       meta_window_actor_detach_x11_pixmap (self); | ||||
|       self->priv->unredirected = FALSE; | ||||
|     } | ||||
|   else | ||||
| @@ -1391,6 +1431,9 @@ meta_window_actor_destroy (MetaWindowActor *self) | ||||
|  | ||||
|   priv = self->priv; | ||||
|  | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     meta_shaped_texture_set_wayland_surface (META_SHAPED_TEXTURE (priv->actor), NULL); | ||||
|  | ||||
|   window = priv->window; | ||||
|   window_type = meta_window_get_window_type (window); | ||||
|   meta_window_set_compositor_private (window, NULL); | ||||
| @@ -1432,12 +1475,18 @@ meta_window_actor_sync_actor_geometry (MetaWindowActor *self, | ||||
|  | ||||
|   meta_window_get_input_rect (priv->window, &window_rect); | ||||
|  | ||||
|   if (priv->last_width != window_rect.width || | ||||
|       priv->last_height != window_rect.height) | ||||
|   /* When running as a display server we catch size changes when new | ||||
|      buffers are attached */ | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       priv->size_changed = TRUE; | ||||
|       priv->last_width = window_rect.width; | ||||
|       priv->last_height = window_rect.height; | ||||
|       if (priv->last_width != window_rect.width || | ||||
|           priv->last_height != window_rect.height) | ||||
|         { | ||||
|           priv->x11_size_changed = TRUE; | ||||
|  | ||||
|           priv->last_width = window_rect.width; | ||||
|           priv->last_height = window_rect.height; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   /* Normally we want freezing a window to also freeze its position; this allows | ||||
| @@ -1450,10 +1499,13 @@ meta_window_actor_sync_actor_geometry (MetaWindowActor *self, | ||||
|   if (is_frozen (self) && !did_placement) | ||||
|     return; | ||||
|  | ||||
|   if (priv->size_changed) | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       meta_window_actor_queue_create_pixmap (self); | ||||
|       meta_window_actor_update_shape (self); | ||||
|       if (priv->x11_size_changed) | ||||
|         { | ||||
|           meta_window_actor_queue_create_x11_pixmap (self); | ||||
|           meta_window_actor_update_shape (self); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   if (meta_window_actor_effect_in_progress (self)) | ||||
| @@ -1617,16 +1669,25 @@ meta_window_actor_new (MetaWindow *window) | ||||
|   MetaWindowActor        *self; | ||||
|   MetaWindowActorPrivate *priv; | ||||
|   MetaFrame		 *frame; | ||||
|   Window		  top_window; | ||||
|   Window		  top_window = None; | ||||
|   ClutterActor           *window_group; | ||||
|  | ||||
|   frame = meta_window_get_frame (window); | ||||
|   if (frame) | ||||
|     top_window = meta_frame_get_xwindow (frame); | ||||
|   else | ||||
|     top_window = meta_window_get_xwindow (window); | ||||
|   if (window->client_type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|     { | ||||
|       frame = meta_window_get_frame (window); | ||||
|       if (frame) | ||||
|         top_window = meta_frame_get_xwindow (frame); | ||||
|       else | ||||
|         top_window = meta_window_get_xwindow (window); | ||||
|  | ||||
|   meta_verbose ("add window: Meta %p, xwin 0x%x\n", window, (guint)top_window); | ||||
|       meta_verbose ("add window: Meta %p, xwin 0x%x\n", window, (guint)top_window); | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       meta_verbose ("add window: Meta %p, wayland surface %p\n", | ||||
|                     window, window->surface); | ||||
|       top_window = None; | ||||
|     } | ||||
|  | ||||
|   self = g_object_new (META_TYPE_WINDOW_ACTOR, | ||||
|                        "meta-window",         window, | ||||
| @@ -1635,22 +1696,25 @@ meta_window_actor_new (MetaWindow *window) | ||||
|                        NULL); | ||||
|  | ||||
|   priv = self->priv; | ||||
|  | ||||
|   priv->last_width = -1; | ||||
|   priv->last_height = -1; | ||||
|  | ||||
|   priv->mapped = meta_window_toplevel_is_mapped (priv->window); | ||||
|   if (priv->mapped) | ||||
|     meta_window_actor_queue_create_pixmap (self); | ||||
|  | ||||
|   meta_window_actor_set_updates_frozen (self, | ||||
|                                         meta_window_updates_are_frozen (priv->window)); | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       priv->last_width = -1; | ||||
|       priv->last_height = -1; | ||||
|  | ||||
|   /* If a window doesn't start off with updates frozen, we should | ||||
|    * we should send a _NET_WM_FRAME_DRAWN immediately after the first drawn. | ||||
|    */ | ||||
|   if (priv->window->extended_sync_request_counter && !priv->updates_frozen) | ||||
|     meta_window_actor_queue_frame_drawn (self, FALSE); | ||||
|       if (priv->mapped) | ||||
|         meta_window_actor_queue_create_x11_pixmap (self); | ||||
|  | ||||
|       meta_window_actor_set_updates_frozen (self, | ||||
|                                             meta_window_updates_are_frozen (priv->window)); | ||||
|  | ||||
|       /* If a window doesn't start off with updates frozen, we should | ||||
|        * we should send a _NET_WM_FRAME_DRAWN immediately after the first drawn. | ||||
|        */ | ||||
|       if (priv->window->extended_sync_request_counter && !priv->updates_frozen) | ||||
|         meta_window_actor_queue_frame_drawn (self, FALSE); | ||||
|     } | ||||
|  | ||||
|   meta_window_actor_sync_actor_geometry (self, priv->window->placed); | ||||
|  | ||||
| @@ -1685,7 +1749,8 @@ meta_window_actor_mapped (MetaWindowActor *self) | ||||
|  | ||||
|   priv->mapped = TRUE; | ||||
|  | ||||
|   meta_window_actor_queue_create_pixmap (self); | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     meta_window_actor_queue_create_x11_pixmap (self); | ||||
| } | ||||
|  | ||||
| void | ||||
| @@ -1700,8 +1765,11 @@ meta_window_actor_unmapped (MetaWindowActor *self) | ||||
|   if (meta_window_actor_effect_in_progress (self)) | ||||
|     return; | ||||
|  | ||||
|   meta_window_actor_detach (self); | ||||
|   priv->needs_pixmap = FALSE; | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       meta_window_actor_detach_x11_pixmap (self); | ||||
|       priv->needs_pixmap = FALSE; | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
| @@ -1719,10 +1787,21 @@ meta_window_actor_get_obscured_region (MetaWindowActor *self) | ||||
| { | ||||
|   MetaWindowActorPrivate *priv = self->priv; | ||||
|  | ||||
|   if (priv->back_pixmap && priv->opacity == 0xff && !priv->window->shaded) | ||||
|     return priv->opaque_region; | ||||
|   else | ||||
|     return NULL; | ||||
|   if (!priv->window->shaded) | ||||
|     { | ||||
|       if (meta_is_wayland_compositor ()) | ||||
|         { | ||||
|           if (priv->opacity == 0xff) | ||||
|             return priv->opaque_region; | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           if (priv->back_pixmap && priv->opacity == 0xff) | ||||
|             return priv->opaque_region; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| #if 0 | ||||
| @@ -1862,8 +1941,11 @@ meta_window_actor_reset_clip_regions (MetaWindowActor *self) | ||||
|   g_clear_pointer (&priv->shadow_clip, cairo_region_destroy); | ||||
| } | ||||
|  | ||||
| /* When running as a wayland compositor we don't make requests for | ||||
|  * replacement pixmaps when resizing windows, we will instead be | ||||
|  * asked to attach replacement buffers by the clients. */ | ||||
| static void | ||||
| check_needs_pixmap (MetaWindowActor *self) | ||||
| check_needs_x11_pixmap (MetaWindowActor *self) | ||||
| { | ||||
|   MetaWindowActorPrivate *priv     = self->priv; | ||||
|   MetaScreen          *screen   = priv->screen; | ||||
| @@ -1885,10 +1967,10 @@ check_needs_pixmap (MetaWindowActor *self) | ||||
|  | ||||
|   compositor = meta_display_get_compositor (display); | ||||
|  | ||||
|   if (priv->size_changed) | ||||
|   if (priv->x11_size_changed) | ||||
|     { | ||||
|       meta_window_actor_detach (self); | ||||
|       priv->size_changed = FALSE; | ||||
|       meta_window_actor_detach_x11_pixmap (self); | ||||
|       priv->x11_size_changed = FALSE; | ||||
|     } | ||||
|  | ||||
|   meta_error_trap_push (display); | ||||
| @@ -2020,14 +2102,14 @@ check_needs_shadow (MetaWindowActor *self) | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_window_actor_process_damage (MetaWindowActor    *self, | ||||
|                                   XDamageNotifyEvent *event) | ||||
| meta_window_actor_process_x11_damage (MetaWindowActor    *self, | ||||
|                                       XDamageNotifyEvent *event) | ||||
| { | ||||
|   MetaWindowActorPrivate *priv = self->priv; | ||||
|   MetaCompScreen *info = meta_screen_get_compositor_data (priv->screen); | ||||
|   gboolean redraw_queued; | ||||
|  | ||||
|   priv->received_damage = TRUE; | ||||
|   priv->received_x11_damage = TRUE; | ||||
|  | ||||
|   if (meta_window_is_fullscreen (priv->window) && g_list_last (info->windows)->data == self && !priv->unredirected) | ||||
|     { | ||||
| @@ -2085,6 +2167,27 @@ meta_window_actor_process_damage (MetaWindowActor    *self, | ||||
|  | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_window_actor_process_wayland_damage (MetaWindowActor *self, | ||||
|                                           int x, | ||||
|                                           int y, | ||||
|                                           int width, | ||||
|                                           int height) | ||||
| { | ||||
|   MetaWindowActorPrivate *priv = self->priv; | ||||
|   gboolean redraw_queued; | ||||
|  | ||||
|   if (!priv->mapped) | ||||
|     return; | ||||
|  | ||||
|   redraw_queued = meta_shaped_texture_update_area (META_SHAPED_TEXTURE (priv->actor), | ||||
|                                                    x, y, width, height, | ||||
|                                                    clutter_actor_has_mapped_clones (priv->actor) ? | ||||
|                                                    NULL : priv->unobscured_region); | ||||
|  | ||||
|   priv->repaint_scheduled = priv->repaint_scheduled  || redraw_queued; | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_window_actor_sync_visibility (MetaWindowActor *self) | ||||
| { | ||||
| @@ -2256,9 +2359,46 @@ meta_window_actor_update_shape_region (MetaWindowActor       *self, | ||||
|   priv->shape_region = region; | ||||
|  | ||||
|   g_clear_pointer (&priv->shadow_shape, meta_window_shape_unref); | ||||
|  | ||||
|   meta_window_actor_invalidate_shadow (self); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_window_actor_update_input_region (MetaWindowActor       *self, | ||||
|                                        cairo_rectangle_int_t *client_area) | ||||
| { | ||||
|   MetaWindowActorPrivate *priv = self->priv; | ||||
|   MetaShapedTexture *stex = META_SHAPED_TEXTURE (priv->actor); | ||||
|   cairo_region_t *region = NULL; | ||||
|  | ||||
|   if (priv->window->frame != NULL && priv->window->input_region != NULL) | ||||
|     { | ||||
|       region = meta_frame_get_frame_bounds (priv->window->frame); | ||||
|  | ||||
|       cairo_region_subtract_rectangle (region, client_area); | ||||
|  | ||||
|       /* input_region is in client window coordinates, so translate the | ||||
|        * input region into that coordinate system and back */ | ||||
|       cairo_region_translate (region, -client_area->x, -client_area->y); | ||||
|       cairo_region_union (region, priv->window->input_region); | ||||
|       cairo_region_translate (region, client_area->x, client_area->y); | ||||
|     } | ||||
|   else if (priv->window->shape_region != NULL) | ||||
|     { | ||||
|       region = cairo_region_reference (priv->window->input_region); | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       /* If we don't have a shape on the server, that means that | ||||
|        * we have an implicit shape of one rectangle covering the | ||||
|        * entire window. */ | ||||
|       region = cairo_region_create_rectangle (client_area); | ||||
|     } | ||||
|  | ||||
|   meta_shaped_texture_set_input_shape_region (stex, region); | ||||
|   cairo_region_destroy (region); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_window_actor_update_opaque_region (MetaWindowActor *self) | ||||
| { | ||||
| @@ -2319,10 +2459,10 @@ check_needs_reshape (MetaWindowActor *self) | ||||
|     client_area.height = priv->window->rect.height; | ||||
|  | ||||
|   meta_window_actor_update_shape_region (self, &client_area); | ||||
|   meta_window_actor_update_input_region (self, &client_area); | ||||
|   meta_window_actor_update_opaque_region (self); | ||||
|  | ||||
|   priv->needs_reshape = FALSE; | ||||
|   meta_window_actor_invalidate_shadow (self); | ||||
| } | ||||
|  | ||||
| void | ||||
| @@ -2338,6 +2478,67 @@ meta_window_actor_update_shape (MetaWindowActor *self) | ||||
|   clutter_actor_queue_redraw (priv->actor); | ||||
| } | ||||
|  | ||||
| static void | ||||
| maybe_emit_size_changed (MetaWindowActor *self, | ||||
|                          MetaWaylandBuffer *new_buffer) | ||||
| { | ||||
|   MetaWindowActorPrivate *priv = self->priv; | ||||
|   int                     width = 0, height = 0; | ||||
|  | ||||
|   if (new_buffer) | ||||
|     { | ||||
|       width = new_buffer->width; | ||||
|       height = new_buffer->height; | ||||
|     } | ||||
|  | ||||
|   if (priv->last_width != width || priv->last_height != height) | ||||
|     { | ||||
|       meta_window_actor_update_shape (self); | ||||
|  | ||||
|       /* ::size-changed is supposed to refer to meta_window_get_outer_rect() | ||||
|        * but here we are only looking at buffer size changes. | ||||
|        * | ||||
|        * Emitting it here works pretty much OK because a new buffer size (which | ||||
|        * will correspond to the outer rect with the addition of invisible | ||||
|        * borders) also normally implies a change to the outer rect. In the rare | ||||
|        * case where a change to the window size was exactly balanced by a | ||||
|        * change to the invisible borders, we would miss emitting the signal. | ||||
|        */ | ||||
|       g_signal_emit (self, signals[SIZE_CHANGED], 0); | ||||
|  | ||||
|       priv->last_width = width; | ||||
|       priv->last_height = height; | ||||
|     } | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_window_actor_set_wayland_surface (MetaWindowActor *self, | ||||
|                                        MetaWaylandSurface *surface) | ||||
| { | ||||
|   MetaWindowActorPrivate *priv = self->priv; | ||||
|  | ||||
|   meta_shaped_texture_set_wayland_surface (META_SHAPED_TEXTURE (priv->actor), | ||||
|                                            surface); | ||||
|   if (surface && surface->buffer_ref.buffer) | ||||
|     maybe_emit_size_changed (self, surface->buffer_ref.buffer); | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_window_actor_attach_wayland_buffer (MetaWindowActor *self, | ||||
|                                          MetaWaylandBuffer *buffer) | ||||
| { | ||||
|   MetaWindowActorPrivate *priv = self->priv; | ||||
|   MetaShapedTexture *stex = META_SHAPED_TEXTURE (priv->actor); | ||||
|   CoglTexture *prev_tex = meta_shaped_texture_get_texture (stex); | ||||
|  | ||||
|   meta_shaped_texture_attach_wayland_buffer (stex, buffer); | ||||
|  | ||||
|   if (!prev_tex) | ||||
|     meta_window_actor_sync_actor_geometry (self, FALSE); | ||||
|  | ||||
|   maybe_emit_size_changed (self, buffer); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_window_actor_handle_updates (MetaWindowActor *self) | ||||
| { | ||||
| @@ -2353,42 +2554,46 @@ meta_window_actor_handle_updates (MetaWindowActor *self) | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|   if (priv->unredirected) | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       /* Nothing to do here until/if the window gets redirected again */ | ||||
|       return; | ||||
|       if (priv->unredirected) | ||||
|         { | ||||
|           /* Nothing to do here until/if the window gets redirected again */ | ||||
|           return; | ||||
|         } | ||||
|  | ||||
|       if (priv->received_x11_damage) | ||||
|         { | ||||
|           meta_error_trap_push (display); | ||||
|           XDamageSubtract (xdisplay, priv->damage, None, None); | ||||
|           meta_error_trap_pop (display); | ||||
|  | ||||
|           /* We need to make sure that any X drawing that happens before the | ||||
|            * XDamageSubtract() above is visible to subsequent GL rendering; | ||||
|            * the only standardized way to do this is EXT_x11_sync_object, | ||||
|            * which isn't yet widely available. For now, we count on details | ||||
|            * of Xorg and the open source drivers, and hope for the best | ||||
|            * otherwise. | ||||
|            * | ||||
|            * Xorg and open source driver specifics: | ||||
|            * | ||||
|            * The X server makes sure to flush drawing to the kernel before | ||||
|            * sending out damage events, but since we use DamageReportBoundingBox | ||||
|            * there may be drawing between the last damage event and the | ||||
|            * XDamageSubtract() that needs to be flushed as well. | ||||
|            * | ||||
|            * Xorg always makes sure that drawing is flushed to the kernel | ||||
|            * before writing events or responses to the client, so any round trip | ||||
|            * request at this point is sufficient to flush the GLX buffers. | ||||
|            */ | ||||
|           XSync (xdisplay, False); | ||||
|  | ||||
|           priv->received_x11_damage = FALSE; | ||||
|         } | ||||
|  | ||||
|       check_needs_x11_pixmap (self); | ||||
|     } | ||||
|  | ||||
|   if (priv->received_damage) | ||||
|     { | ||||
|       meta_error_trap_push (display); | ||||
|       XDamageSubtract (xdisplay, priv->damage, None, None); | ||||
|       meta_error_trap_pop (display); | ||||
|  | ||||
|       /* We need to make sure that any X drawing that happens before the | ||||
|        * XDamageSubtract() above is visible to subsequent GL rendering; | ||||
|        * the only standardized way to do this is EXT_x11_sync_object, | ||||
|        * which isn't yet widely available. For now, we count on details | ||||
|        * of Xorg and the open source drivers, and hope for the best | ||||
|        * otherwise. | ||||
|        * | ||||
|        * Xorg and open source driver specifics: | ||||
|        * | ||||
|        * The X server makes sure to flush drawing to the kernel before | ||||
|        * sending out damage events, but since we use DamageReportBoundingBox | ||||
|        * there may be drawing between the last damage event and the | ||||
|        * XDamageSubtract() that needs to be flushed as well. | ||||
|        * | ||||
|        * Xorg always makes sure that drawing is flushed to the kernel | ||||
|        * before writing events or responses to the client, so any round trip | ||||
|        * request at this point is sufficient to flush the GLX buffers. | ||||
|        */ | ||||
|       XSync (xdisplay, False); | ||||
|  | ||||
|       priv->received_damage = FALSE; | ||||
|     } | ||||
|  | ||||
|   check_needs_pixmap (self); | ||||
|   check_needs_reshape (self); | ||||
|   check_needs_shadow (self); | ||||
| } | ||||
| @@ -2590,16 +2795,20 @@ void | ||||
| meta_window_actor_set_updates_frozen (MetaWindowActor *self, | ||||
|                                       gboolean         updates_frozen) | ||||
| { | ||||
|   MetaWindowActorPrivate *priv = self->priv; | ||||
|  | ||||
|   updates_frozen = updates_frozen != FALSE; | ||||
|  | ||||
|   if (priv->updates_frozen != updates_frozen) | ||||
|   /* On wayland we shouldn't need to ever freeze updates... */ | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       priv->updates_frozen = updates_frozen; | ||||
|       if (updates_frozen) | ||||
|         meta_window_actor_freeze (self); | ||||
|       else | ||||
|         meta_window_actor_thaw (self); | ||||
|       MetaWindowActorPrivate *priv = self->priv; | ||||
|  | ||||
|       updates_frozen = updates_frozen != FALSE; | ||||
|  | ||||
|       if (priv->updates_frozen != updates_frozen) | ||||
|         { | ||||
|           priv->updates_frozen = updates_frozen; | ||||
|           if (updates_frozen) | ||||
|             meta_window_actor_freeze (self); | ||||
|           else | ||||
|             meta_window_actor_thaw (self); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -13,6 +13,7 @@ | ||||
| #include "meta-window-group.h" | ||||
| #include "meta-background-actor-private.h" | ||||
| #include "meta-background-group-private.h" | ||||
| #include "window-private.h" | ||||
|  | ||||
| struct _MetaWindowGroupClass | ||||
| { | ||||
| @@ -154,14 +155,18 @@ meta_window_group_paint (ClutterActor *actor) | ||||
|  | ||||
|   clip_region = cairo_region_create_rectangle (&clip_rect); | ||||
|  | ||||
|   if (info->unredirected_window != NULL) | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       cairo_rectangle_int_t unredirected_rect; | ||||
|       MetaWindow *window = meta_window_actor_get_meta_window (info->unredirected_window); | ||||
|       info = meta_screen_get_compositor_data (window_group->screen); | ||||
|       if (info->unredirected_window != NULL) | ||||
|         { | ||||
|           cairo_rectangle_int_t unredirected_rect; | ||||
|           MetaWindow *window = meta_window_actor_get_meta_window (info->unredirected_window); | ||||
|  | ||||
|       meta_window_get_outer_rect (window, (MetaRectangle *)&unredirected_rect); | ||||
|       cairo_region_subtract_rectangle (unobscured_region, &unredirected_rect); | ||||
|       cairo_region_subtract_rectangle (clip_region, &unredirected_rect); | ||||
|           meta_window_get_outer_rect (window, (MetaRectangle *)&unredirected_rect); | ||||
|           cairo_region_subtract_rectangle (unobscured_region, &unredirected_rect); | ||||
|           cairo_region_subtract_rectangle (clip_region, &unredirected_rect); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   /* We walk the list from top to bottom (opposite of painting order), | ||||
| @@ -174,7 +179,8 @@ meta_window_group_paint (ClutterActor *actor) | ||||
|       if (!CLUTTER_ACTOR_IS_VISIBLE (child)) | ||||
|         continue; | ||||
|  | ||||
|       if (info->unredirected_window != NULL && | ||||
|       if (!meta_is_wayland_compositor () && | ||||
|           info->unredirected_window != NULL && | ||||
|           child == CLUTTER_ACTOR (info->unredirected_window)) | ||||
|         continue; | ||||
|  | ||||
| @@ -248,7 +254,6 @@ meta_window_group_paint (ClutterActor *actor) | ||||
|             meta_background_group_set_clip_region (META_BACKGROUND_GROUP (child), clip_region); | ||||
|           else | ||||
|             meta_background_actor_set_clip_region (META_BACKGROUND_ACTOR (child), clip_region); | ||||
|  | ||||
|           cairo_region_translate (clip_region, x, y); | ||||
|         } | ||||
|     } | ||||
|   | ||||
| @@ -21,15 +21,14 @@ | ||||
|  * 02111-1307, USA. | ||||
|  */ | ||||
|  | ||||
| #include <config.h> | ||||
|  | ||||
| #include <meta/meta-plugin.h> | ||||
| #include <meta/window.h> | ||||
| #include <meta/util.h> | ||||
| #include <meta/meta-background-group.h> | ||||
| #include <meta/meta-background-actor.h> | ||||
|  | ||||
| #include <libintl.h> | ||||
| #define _(x) dgettext (GETTEXT_PACKAGE, x) | ||||
| #define N_(x) x | ||||
| #include <meta/util.h> | ||||
| #include <glib/gi18n-lib.h> | ||||
|  | ||||
| #include <clutter/clutter.h> | ||||
| #include <gmodule.h> | ||||
|   | ||||
| @@ -366,11 +366,25 @@ meta_barrier_fire_event (MetaBarrier    *barrier, | ||||
| } | ||||
|  | ||||
| gboolean | ||||
| meta_display_process_barrier_event (MetaDisplay    *display, | ||||
|                                     XIBarrierEvent *xev) | ||||
| meta_display_process_barrier_event (MetaDisplay *display, | ||||
|                                     XIEvent     *event) | ||||
| { | ||||
|   MetaBarrier *barrier; | ||||
|   XIBarrierEvent *xev; | ||||
|  | ||||
|   if (event == NULL) | ||||
|     return FALSE; | ||||
|  | ||||
|   switch (event->evtype) | ||||
|     { | ||||
|     case XI_BarrierHit: | ||||
|     case XI_BarrierLeave: | ||||
|       break; | ||||
|     default: | ||||
|       return FALSE; | ||||
|     } | ||||
|  | ||||
|   xev = (XIBarrierEvent *) event; | ||||
|   barrier = g_hash_table_lookup (display->xids, &xev->barrier); | ||||
|   if (barrier != NULL) | ||||
|     { | ||||
|   | ||||
| @@ -53,6 +53,7 @@ | ||||
| #include "bell.h" | ||||
| #include "screen-private.h" | ||||
| #include "window-private.h" | ||||
| #include "util-private.h" | ||||
| #include <meta/prefs.h> | ||||
| #include <meta/compositor.h> | ||||
| #ifdef HAVE_LIBCANBERRA | ||||
|   | ||||
| @@ -35,7 +35,8 @@ typedef enum | ||||
|   META_DO_GRAVITY_ADJUST    = 1 << 1, | ||||
|   META_IS_USER_ACTION       = 1 << 2, | ||||
|   META_IS_MOVE_ACTION       = 1 << 3, | ||||
|   META_IS_RESIZE_ACTION     = 1 << 4 | ||||
|   META_IS_RESIZE_ACTION     = 1 << 4, | ||||
|   META_IS_WAYLAND_RESIZE    = 1 << 5 | ||||
| } MetaMoveResizeFlags; | ||||
|  | ||||
| void meta_window_constrain (MetaWindow          *window, | ||||
|   | ||||
| @@ -29,6 +29,7 @@ | ||||
| #include "workspace-private.h" | ||||
| #include <meta/prefs.h> | ||||
| #include <meta/errors.h> | ||||
| #include "util-private.h" | ||||
|  | ||||
| /* Looks up the MetaWindow representing the frame of the given X window. | ||||
|  * Used as a helper function by a bunch of the functions below. | ||||
| @@ -154,7 +155,7 @@ meta_core_get (Display *xdisplay, | ||||
|         break; | ||||
|  | ||||
|       default: | ||||
|         meta_warning(_("Unknown window information request: %d"), request); | ||||
|         meta_warning("Unknown window information request: %d\n", request); | ||||
|     } | ||||
|  | ||||
|     request = va_arg (args, MetaCoreGetType); | ||||
| @@ -270,6 +271,8 @@ meta_core_lower_beneath_grab_window (Display *xdisplay, | ||||
|   MetaDisplay *display; | ||||
|   MetaScreen *screen; | ||||
|   MetaWindow *grab_window; | ||||
|   MetaStackWindow stack_window; | ||||
|   MetaStackWindow stack_sibling; | ||||
|  | ||||
|   display = meta_display_for_x_display (xdisplay); | ||||
|   screen = meta_display_screen_for_xwindow (display, xwindow); | ||||
| @@ -282,9 +285,13 @@ meta_core_lower_beneath_grab_window (Display *xdisplay, | ||||
|   changes.sibling = grab_window->frame ? grab_window->frame->xwindow | ||||
|                                        : grab_window->xwindow; | ||||
|  | ||||
|   stack_window.any.type = META_WINDOW_CLIENT_TYPE_X11; | ||||
|   stack_window.x11.xwindow = xwindow; | ||||
|   stack_sibling.any.type = META_WINDOW_CLIENT_TYPE_X11; | ||||
|   stack_sibling.x11.xwindow = changes.sibling; | ||||
|   meta_stack_tracker_record_lower_below (screen->stack_tracker, | ||||
|                                          xwindow, | ||||
|                                          changes.sibling, | ||||
|                                          &stack_window, | ||||
|                                          &stack_sibling, | ||||
|                                          XNextRequest (screen->display->xdisplay)); | ||||
|  | ||||
|   meta_error_trap_push (display); | ||||
| @@ -469,26 +476,6 @@ meta_core_change_workspace (Display *xdisplay, | ||||
|                                                                     new_workspace)); | ||||
| } | ||||
|  | ||||
| int | ||||
| meta_core_get_num_workspaces (Screen  *xscreen) | ||||
| { | ||||
|   MetaScreen *screen; | ||||
|  | ||||
|   screen = meta_screen_for_x_screen (xscreen); | ||||
|  | ||||
|   return meta_screen_get_n_workspaces (screen); | ||||
| } | ||||
|  | ||||
| int | ||||
| meta_core_get_active_workspace (Screen *xscreen) | ||||
| { | ||||
|   MetaScreen *screen; | ||||
|  | ||||
|   screen = meta_screen_for_x_screen (xscreen); | ||||
|  | ||||
|   return meta_workspace_index (screen->active_workspace); | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_core_show_window_menu (Display *xdisplay, | ||||
|                             Window   frame_xwindow, | ||||
|   | ||||
| @@ -153,8 +153,6 @@ void meta_core_change_workspace (Display *xdisplay, | ||||
|                                  Window   frame_xwindow, | ||||
|                                  int      new_workspace); | ||||
|  | ||||
| int meta_core_get_num_workspaces (Screen  *xscreen); | ||||
| int meta_core_get_active_workspace (Screen *xscreen); | ||||
| int meta_core_get_frame_workspace (Display *xdisplay, | ||||
|                                    Window frame_xwindow); | ||||
| const char* meta_core_get_workspace_name_with_index (Display *xdisplay, | ||||
|   | ||||
| @@ -25,7 +25,7 @@ | ||||
| #define _XOPEN_SOURCE /* for kill() */ | ||||
|  | ||||
| #include <config.h> | ||||
| #include <meta/util.h> | ||||
| #include "util-private.h" | ||||
| #include "window-private.h" | ||||
| #include <meta/errors.h> | ||||
| #include <meta/workspace.h> | ||||
|   | ||||
| @@ -39,6 +39,7 @@ | ||||
| #include "keybindings-private.h" | ||||
| #include <meta/prefs.h> | ||||
| #include <meta/barrier.h> | ||||
| #include <clutter/clutter.h> | ||||
|  | ||||
| #ifdef HAVE_STARTUP_NOTIFICATION | ||||
| #include <libsn/sn.h> | ||||
| @@ -86,6 +87,14 @@ typedef enum { | ||||
|   META_TILE_MAXIMIZED | ||||
| } MetaTileMode; | ||||
|  | ||||
| typedef enum { | ||||
|   META_FOCUS_NONE = 0, | ||||
|   META_FOCUS_X_CLIENT = 1, | ||||
|   META_FOCUS_WAYLAND_CLIENT = 2, | ||||
|   META_FOCUS_NO_FOCUS_WINDOW = 3, | ||||
|   META_FOCUS_STAGE = 4 | ||||
| } MetaFocusType; | ||||
|  | ||||
| struct _MetaDisplay | ||||
| { | ||||
|   GObject parent_instance; | ||||
| @@ -117,6 +126,7 @@ struct _MetaDisplay | ||||
|    * like the no_focus_window or the stage X window. */ | ||||
|   Window focus_xwindow; | ||||
|   gulong focus_serial; | ||||
|   MetaFocusType focus_type; | ||||
|  | ||||
|   /* last timestamp passed to XSetInputFocus */ | ||||
|   guint32 last_focus_time; | ||||
| @@ -145,6 +155,7 @@ struct _MetaDisplay | ||||
|   GSList *screens; | ||||
|   MetaScreen *active_screen; | ||||
|   GHashTable *xids; | ||||
|   GHashTable *wayland_windows; | ||||
|   int error_traps; | ||||
|   int (* error_trap_handler) (Display     *display, | ||||
|                               XErrorEvent *error);   | ||||
| @@ -179,7 +190,7 @@ struct _MetaDisplay | ||||
|   MetaWindow* autoraise_window; | ||||
|  | ||||
|   /* Alt+click button grabs */ | ||||
|   unsigned int window_grab_modifiers; | ||||
|   ClutterModifierType window_grab_modifiers; | ||||
|    | ||||
|   /* current window operation */ | ||||
|   MetaGrabOp  grab_op; | ||||
| @@ -371,6 +382,11 @@ void        meta_display_register_x_window   (MetaDisplay *display, | ||||
| void        meta_display_unregister_x_window (MetaDisplay *display, | ||||
|                                               Window       xwindow); | ||||
|  | ||||
| void        meta_display_register_wayland_window   (MetaDisplay *display, | ||||
|                                                     MetaWindow  *window); | ||||
| void        meta_display_unregister_wayland_window (MetaDisplay *display, | ||||
|                                                     MetaWindow  *window); | ||||
|  | ||||
| #ifdef HAVE_XSYNC | ||||
| MetaWindow* meta_display_lookup_sync_alarm     (MetaDisplay *display, | ||||
|                                                 XSyncAlarm   alarm); | ||||
| @@ -458,23 +474,29 @@ void meta_display_queue_autoraise_callback  (MetaDisplay *display, | ||||
| void meta_display_remove_autoraise_callback (MetaDisplay *display); | ||||
|  | ||||
| void meta_display_overlay_key_activate (MetaDisplay *display); | ||||
| void meta_display_accelerator_activate (MetaDisplay *display, | ||||
|                                         guint        action, | ||||
|                                         guint        deviceid, | ||||
|                                         guint        timestamp); | ||||
| void meta_display_accelerator_activate (MetaDisplay     *display, | ||||
|                                         guint            action, | ||||
|                                         ClutterKeyEvent *event); | ||||
| gboolean meta_display_modifiers_accelerator_activate (MetaDisplay *display); | ||||
|  | ||||
| /* In above-tab-keycode.c */ | ||||
| guint meta_display_get_above_tab_keycode (MetaDisplay *display); | ||||
|  | ||||
| gboolean meta_display_handle_xevent (MetaDisplay *display, | ||||
|                                      XEvent      *event); | ||||
|  | ||||
| gboolean meta_display_handle_event (MetaDisplay        *display, | ||||
|                                     const ClutterEvent *event); | ||||
|  | ||||
| #ifdef HAVE_XI23 | ||||
| gboolean meta_display_process_barrier_event (MetaDisplay    *display, | ||||
|                                              XIBarrierEvent *event); | ||||
| gboolean meta_display_process_barrier_event (MetaDisplay *display, | ||||
|                                              XIEvent     *event); | ||||
| #endif /* HAVE_XI23 */ | ||||
|  | ||||
| void meta_display_set_input_focus_xwindow (MetaDisplay *display, | ||||
|                                            MetaScreen  *screen, | ||||
|                                            Window       window, | ||||
|                                            guint32      timestamp); | ||||
| void meta_display_set_input_focus_xwindow (MetaDisplay   *display, | ||||
|                                            MetaScreen    *screen, | ||||
|                                            MetaFocusType  type, | ||||
|                                            Window         window, | ||||
|                                            guint32        timestamp); | ||||
|  | ||||
| #endif | ||||
|   | ||||
							
								
								
									
										2400
									
								
								src/core/display.c
									
									
									
									
									
								
							
							
						
						
									
										2400
									
								
								src/core/display.c
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -47,6 +47,7 @@ meta_window_ensure_frame (MetaWindow *window) | ||||
|   XSetWindowAttributes attrs; | ||||
|   Visual *visual; | ||||
|   gulong create_serial; | ||||
|   MetaStackWindow stack_window; | ||||
|    | ||||
|   if (window->frame) | ||||
|     return; | ||||
| @@ -105,8 +106,10 @@ meta_window_ensure_frame (MetaWindow *window) | ||||
| 						frame->rect.height, | ||||
| 						frame->window->screen->number, | ||||
|                                                 &create_serial); | ||||
|   stack_window.any.type = META_WINDOW_CLIENT_TYPE_X11; | ||||
|   stack_window.x11.xwindow = frame->xwindow; | ||||
|   meta_stack_tracker_record_add (window->screen->stack_tracker, | ||||
|                                  frame->xwindow, | ||||
|                                  &stack_window, | ||||
|                                  create_serial); | ||||
|  | ||||
|   meta_verbose ("Frame for %s is 0x%lx\n", frame->window->desc, frame->xwindow); | ||||
| @@ -138,8 +141,9 @@ meta_window_ensure_frame (MetaWindow *window) | ||||
|   window->rect.x = 0; | ||||
|   window->rect.y = 0; | ||||
|  | ||||
|   stack_window.x11.xwindow = window->xwindow; | ||||
|   meta_stack_tracker_record_remove (window->screen->stack_tracker, | ||||
|                                     window->xwindow, | ||||
|                                     &stack_window, | ||||
|                                     XNextRequest (window->display->xdisplay)); | ||||
|   XReparentWindow (window->display->xdisplay, | ||||
|                    window->xwindow, | ||||
| @@ -174,6 +178,7 @@ meta_window_destroy_frame (MetaWindow *window) | ||||
| { | ||||
|   MetaFrame *frame; | ||||
|   MetaFrameBorders borders; | ||||
|   MetaStackWindow stack_window; | ||||
|    | ||||
|   if (window->frame == NULL) | ||||
|     return; | ||||
| @@ -200,8 +205,10 @@ meta_window_destroy_frame (MetaWindow *window) | ||||
|                   "Incrementing unmaps_pending on %s for reparent back to root\n", window->desc); | ||||
|       window->unmaps_pending += 1; | ||||
|     } | ||||
|   stack_window.any.type = META_WINDOW_CLIENT_TYPE_X11; | ||||
|   stack_window.x11.xwindow = window->xwindow; | ||||
|   meta_stack_tracker_record_add (window->screen->stack_tracker, | ||||
|                                  window->xwindow, | ||||
|                                  &stack_window, | ||||
|                                  XNextRequest (window->display->xdisplay)); | ||||
|   XReparentWindow (window->display->xdisplay, | ||||
|                    window->xwindow, | ||||
|   | ||||
| @@ -66,9 +66,9 @@ gboolean meta_window_grab_all_keys          (MetaWindow  *window, | ||||
|                                              guint32      timestamp); | ||||
| void     meta_window_ungrab_all_keys        (MetaWindow  *window, | ||||
|                                              guint32      timestamp); | ||||
| gboolean meta_display_process_key_event     (MetaDisplay   *display, | ||||
|                                              MetaWindow    *window, | ||||
|                                              XIDeviceEvent *event); | ||||
| gboolean meta_display_process_key_event     (MetaDisplay     *display, | ||||
|                                              MetaWindow      *window, | ||||
|                                              ClutterKeyEvent *event); | ||||
| void     meta_display_process_mapping_event (MetaDisplay *display, | ||||
|                                              XEvent      *event); | ||||
|  | ||||
| @@ -81,7 +81,3 @@ gboolean meta_prefs_remove_keybinding       (const char    *name); | ||||
|  | ||||
|  | ||||
| #endif | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -48,15 +48,17 @@ | ||||
|  | ||||
| #include <config.h> | ||||
| #include <meta/main.h> | ||||
| #include <meta/util.h> | ||||
| #include "util-private.h" | ||||
| #include "display-private.h" | ||||
| #include <meta/errors.h> | ||||
| #include "ui.h" | ||||
| #include "session.h" | ||||
| #include <meta/prefs.h> | ||||
| #include <meta/compositor.h> | ||||
| #include "meta-wayland-private.h" | ||||
|  | ||||
| #include <glib-object.h> | ||||
| #include <glib-unix.h> | ||||
| #include <gdk/gdkx.h> | ||||
|  | ||||
| #include <stdlib.h> | ||||
| @@ -189,6 +191,7 @@ static gchar    *opt_client_id; | ||||
| static gboolean  opt_replace_wm; | ||||
| static gboolean  opt_disable_sm; | ||||
| static gboolean  opt_sync; | ||||
| static gboolean  opt_wayland; | ||||
|  | ||||
| static GOptionEntry meta_options[] = { | ||||
|   { | ||||
| @@ -226,6 +229,12 @@ static GOptionEntry meta_options[] = { | ||||
|     N_("Make X calls synchronous"), | ||||
|     NULL | ||||
|   }, | ||||
|   { | ||||
|     "wayland", 0, 0, G_OPTION_ARG_NONE, | ||||
|     &opt_wayland, | ||||
|     N_("Run as a wayland compositor"), | ||||
|     NULL | ||||
|   }, | ||||
|   {NULL} | ||||
| }; | ||||
|  | ||||
| @@ -247,6 +256,14 @@ meta_get_option_context (void) | ||||
|   bindtextdomain (GETTEXT_PACKAGE, MUTTER_LOCALEDIR); | ||||
|   bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8"); | ||||
|  | ||||
|   /* We must set the windowing backend here, because Clutter creates the backend | ||||
|      object when the first call is made. | ||||
|  | ||||
|      We consider running from mutter-launch equivalent to running from bare metal. | ||||
|   */ | ||||
|   if (getenv ("WESTON_LAUNCHER_SOCK")) | ||||
|     clutter_set_windowing_backend (CLUTTER_WINDOWING_EGL); | ||||
|  | ||||
|   ctx = g_option_context_new (NULL); | ||||
|   g_option_context_add_main_entries (ctx, meta_options, GETTEXT_PACKAGE); | ||||
|   g_option_context_add_group (ctx, clutter_get_option_group_without_init ()); | ||||
| @@ -346,28 +363,17 @@ meta_finalize (void) | ||||
|   if (display) | ||||
|     meta_display_close (display, | ||||
|                         CurrentTime); /* I doubt correct timestamps matter here */ | ||||
| } | ||||
|  | ||||
| static int sigterm_pipe_fds[2] = { -1, -1 }; | ||||
|  | ||||
| static void | ||||
| sigterm_handler (int signum) | ||||
| { | ||||
|   if (sigterm_pipe_fds[1] >= 0) | ||||
|     { | ||||
|       int G_GNUC_UNUSED dummy; | ||||
|  | ||||
|       dummy = write (sigterm_pipe_fds[1], "", 1); | ||||
|       close (sigterm_pipe_fds[1]); | ||||
|       sigterm_pipe_fds[1] = -1; | ||||
|     } | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     meta_wayland_finalize (); | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| on_sigterm (void) | ||||
| on_sigterm (gpointer user_data) | ||||
| { | ||||
|   meta_quit (META_EXIT_SUCCESS); | ||||
|   return FALSE; | ||||
|   meta_quit (EXIT_SUCCESS); | ||||
|  | ||||
|   return G_SOURCE_REMOVE; | ||||
| } | ||||
|  | ||||
| /** | ||||
| @@ -381,7 +387,6 @@ meta_init (void) | ||||
| { | ||||
|   struct sigaction act; | ||||
|   sigset_t empty_mask; | ||||
|   GIOChannel *channel; | ||||
|    | ||||
|   sigemptyset (&empty_mask); | ||||
|   act.sa_handler = SIG_IGN; | ||||
| @@ -396,26 +401,15 @@ meta_init (void) | ||||
|                 g_strerror (errno)); | ||||
| #endif | ||||
|  | ||||
|   if (pipe (sigterm_pipe_fds) != 0) | ||||
|     g_printerr ("Failed to create SIGTERM pipe: %s\n", | ||||
|                 g_strerror (errno)); | ||||
|  | ||||
|   channel = g_io_channel_unix_new (sigterm_pipe_fds[0]); | ||||
|   g_io_channel_set_flags (channel, G_IO_FLAG_NONBLOCK, NULL); | ||||
|   g_io_add_watch (channel, G_IO_IN, (GIOFunc) on_sigterm, NULL); | ||||
|   g_io_channel_set_close_on_unref (channel, TRUE); | ||||
|   g_io_channel_unref (channel); | ||||
|  | ||||
|   act.sa_handler = &sigterm_handler; | ||||
|   if (sigaction (SIGTERM, &act, NULL) < 0) | ||||
|     g_printerr ("Failed to register SIGTERM handler: %s\n", | ||||
| 		g_strerror (errno)); | ||||
|   g_unix_signal_add (SIGTERM, on_sigterm, NULL); | ||||
|  | ||||
|   if (g_getenv ("MUTTER_VERBOSE")) | ||||
|     meta_set_verbose (TRUE); | ||||
|   if (g_getenv ("MUTTER_DEBUG")) | ||||
|     meta_set_debugging (TRUE); | ||||
|  | ||||
|   meta_set_is_wayland_compositor (opt_wayland); | ||||
|  | ||||
|   if (g_get_home_dir ()) | ||||
|     if (chdir (g_get_home_dir ()) < 0) | ||||
|       meta_warning ("Could not change to home directory %s.\n", | ||||
| @@ -427,9 +421,16 @@ meta_init (void) | ||||
|   g_irepository_prepend_search_path (MUTTER_PKGLIBDIR); | ||||
| #endif | ||||
|  | ||||
|   meta_set_syncing (opt_sync || (g_getenv ("MUTTER_SYNC") != NULL)); | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       /* NB: When running as a hybrid wayland compositor we run our own headless X | ||||
|        * server so the user can't control the X display to connect too. */ | ||||
|       meta_wayland_init (); | ||||
|     } | ||||
|   else | ||||
|     meta_select_display (opt_display_name); | ||||
|  | ||||
|   meta_select_display (opt_display_name); | ||||
|   meta_set_syncing (opt_sync || (g_getenv ("MUTTER_SYNC") != NULL)); | ||||
|    | ||||
|   if (opt_replace_wm) | ||||
|     meta_set_replace_current_wm (TRUE); | ||||
| @@ -441,10 +442,17 @@ meta_init (void) | ||||
|    | ||||
|   meta_ui_init (); | ||||
|  | ||||
|   /* | ||||
|    * Clutter can only be initialized after the UI. | ||||
|    */ | ||||
|   meta_clutter_init (); | ||||
|   /* If we are running with wayland then we don't wait until we have | ||||
|    * an X connection before initializing clutter we instead initialize | ||||
|    * it earlier since we need to initialize the GL driver so the driver | ||||
|    * can register any needed wayland extensions. */ | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       /* | ||||
|        * Clutter can only be initialized after the UI. | ||||
|        */ | ||||
|       meta_clutter_init (); | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| /* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */ | ||||
|  | ||||
| /* | ||||
|  * Copyright (C) 2013 Red Hat, Inc. | ||||
|  * Copyright 2013 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 | ||||
| @@ -25,10 +25,24 @@ | ||||
| #define META_CURSOR_TRACKER_PRIVATE_H | ||||
|  | ||||
| #include <meta/meta-cursor-tracker.h> | ||||
| #include <wayland-server.h> | ||||
| #include <clutter/clutter.h> | ||||
|  | ||||
| gboolean meta_cursor_tracker_handle_xevent (MetaCursorTracker *tracker, | ||||
| 					    XEvent            *xevent); | ||||
|  | ||||
| void     meta_cursor_tracker_set_root_cursor (MetaCursorTracker *tracker, | ||||
|                                               MetaCursor         cursor); | ||||
| void     meta_cursor_tracker_revert_root     (MetaCursorTracker *tracker); | ||||
| void     meta_cursor_tracker_set_buffer      (MetaCursorTracker  *tracker, | ||||
|                                               struct wl_resource *buffer, | ||||
|                                               int                 hot_x, | ||||
|                                               int                 hot_y); | ||||
|  | ||||
| void     meta_cursor_tracker_update_position (MetaCursorTracker *tracker, | ||||
| 					      int                new_x, | ||||
| 					      int                new_y); | ||||
| void     meta_cursor_tracker_paint           (MetaCursorTracker *tracker); | ||||
| void     meta_cursor_tracker_queue_redraw    (MetaCursorTracker *tracker, | ||||
| 					      ClutterActor      *stage); | ||||
| #endif | ||||
|   | ||||
| @@ -24,36 +24,65 @@ | ||||
| /** | ||||
|  * SECTION:cursor-tracker | ||||
|  * @title: MetaCursorTracker | ||||
|  * @short_description: Mutter cursor tracking helper | ||||
|  * @short_description: Mutter cursor tracking helper. Originally only | ||||
|  *                     tracking the cursor image, now more of a "core | ||||
|  *                     pointer abstraction" | ||||
|  */ | ||||
|  | ||||
| #include <config.h> | ||||
| #include <string.h> | ||||
| #include <meta/main.h> | ||||
| #include <meta/util.h> | ||||
| #include <meta/errors.h> | ||||
|  | ||||
| #include <cogl/cogl.h> | ||||
| #include <cogl/cogl-wayland-server.h> | ||||
| #include <clutter/clutter.h> | ||||
| #include <gbm.h> | ||||
|  | ||||
| #include <gdk/gdk.h> | ||||
|  | ||||
| #include <X11/cursorfont.h> | ||||
| #include <X11/extensions/Xfixes.h> | ||||
| #include <X11/Xcursor/Xcursor.h> | ||||
|  | ||||
| #include "meta-cursor-tracker-private.h" | ||||
| #include "screen-private.h" | ||||
| #include "meta-wayland-private.h" | ||||
| #include "monitor-private.h" | ||||
|  | ||||
| #define META_WAYLAND_DEFAULT_CURSOR_HOTSPOT_X 7 | ||||
| #define META_WAYLAND_DEFAULT_CURSOR_HOTSPOT_Y 4 | ||||
|  | ||||
| typedef struct { | ||||
|   CoglTexture2D *texture; | ||||
|   struct gbm_bo *bo; | ||||
|   int hot_x, hot_y; | ||||
|  | ||||
|   int ref_count; | ||||
| } MetaCursorReference; | ||||
|  | ||||
| struct _MetaCursorTracker { | ||||
|   GObject parent_instance; | ||||
|  | ||||
|   MetaScreen *screen; | ||||
|  | ||||
|   gboolean is_showing; | ||||
|   gboolean has_cursor; | ||||
|   gboolean has_hw_cursor; | ||||
|  | ||||
|   CoglTexture2D *sprite; | ||||
|   int hot_x, hot_y; | ||||
|   MetaCursorReference *sprite; | ||||
|   MetaCursorReference *root_cursor; | ||||
|   MetaCursorReference *default_cursors[META_CURSOR_LAST]; | ||||
|  | ||||
|   int current_x, current_y; | ||||
|   MetaRectangle current_rect; | ||||
|   MetaRectangle previous_rect; | ||||
|   gboolean previous_is_valid; | ||||
|  | ||||
|   CoglPipeline *pipeline; | ||||
|   int drm_fd; | ||||
|   struct gbm_device *gbm; | ||||
| }; | ||||
|  | ||||
| struct _MetaCursorTrackerClass { | ||||
| @@ -69,14 +98,419 @@ enum { | ||||
|  | ||||
| static guint signals[LAST_SIGNAL]; | ||||
|  | ||||
| static void meta_cursor_tracker_set_sprite (MetaCursorTracker   *tracker, | ||||
|                                             MetaCursorReference *sprite); | ||||
|  | ||||
| static void meta_cursor_tracker_set_crtc_has_hw_cursor (MetaCursorTracker *tracker, | ||||
|                                                         MetaCRTC          *crtc, | ||||
|                                                         gboolean           has_hw_cursor); | ||||
|  | ||||
| static MetaCursorReference * | ||||
| meta_cursor_reference_ref (MetaCursorReference *self) | ||||
| { | ||||
|   g_assert (self->ref_count > 0); | ||||
|   self->ref_count++; | ||||
|  | ||||
|   return self; | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_cursor_reference_unref (MetaCursorReference *self) | ||||
| { | ||||
|   self->ref_count--; | ||||
|  | ||||
|   if (self->ref_count == 0) | ||||
|     { | ||||
|       cogl_object_unref (self->texture); | ||||
|       if (self->bo) | ||||
|         gbm_bo_destroy (self->bo); | ||||
|  | ||||
|       g_slice_free (MetaCursorReference, self); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void | ||||
| translate_meta_cursor (MetaCursor   cursor, | ||||
|                        guint       *glyph_out, | ||||
|                        const char **name_out) | ||||
| { | ||||
|   guint glyph = XC_num_glyphs; | ||||
|   const char *name = NULL; | ||||
|  | ||||
|   switch (cursor) | ||||
|     { | ||||
|     case META_CURSOR_DEFAULT: | ||||
|       glyph = XC_left_ptr; | ||||
|       break; | ||||
|     case META_CURSOR_NORTH_RESIZE: | ||||
|       glyph = XC_top_side; | ||||
|       break; | ||||
|     case META_CURSOR_SOUTH_RESIZE: | ||||
|       glyph = XC_bottom_side; | ||||
|       break; | ||||
|     case META_CURSOR_WEST_RESIZE: | ||||
|       glyph = XC_left_side; | ||||
|       break; | ||||
|     case META_CURSOR_EAST_RESIZE: | ||||
|       glyph = XC_right_side; | ||||
|       break; | ||||
|     case META_CURSOR_SE_RESIZE: | ||||
|       glyph = XC_bottom_right_corner; | ||||
|       break; | ||||
|     case META_CURSOR_SW_RESIZE: | ||||
|       glyph = XC_bottom_left_corner; | ||||
|       break; | ||||
|     case META_CURSOR_NE_RESIZE: | ||||
|       glyph = XC_top_right_corner; | ||||
|       break; | ||||
|     case META_CURSOR_NW_RESIZE: | ||||
|       glyph = XC_top_left_corner; | ||||
|       break; | ||||
|     case META_CURSOR_MOVE_OR_RESIZE_WINDOW: | ||||
|       glyph = XC_fleur; | ||||
|       break; | ||||
|     case META_CURSOR_BUSY: | ||||
|       glyph = XC_watch; | ||||
|       break; | ||||
|     case META_CURSOR_DND_IN_DRAG: | ||||
|       name = "dnd-none"; | ||||
|       break; | ||||
|     case META_CURSOR_DND_MOVE: | ||||
|       name = "dnd-move"; | ||||
|       break; | ||||
|     case META_CURSOR_DND_COPY: | ||||
|       name = "dnd-copy"; | ||||
|       break; | ||||
|     case META_CURSOR_DND_UNSUPPORTED_TARGET: | ||||
|       name = "dnd-none"; | ||||
|       break; | ||||
|     case META_CURSOR_POINTING_HAND: | ||||
|       glyph = XC_hand2; | ||||
|       break; | ||||
|     case META_CURSOR_CROSSHAIR: | ||||
|       glyph = XC_crosshair; | ||||
|       break; | ||||
|     case META_CURSOR_IBEAM: | ||||
|       glyph = XC_xterm; | ||||
|       break; | ||||
|  | ||||
|     default: | ||||
|       g_assert_not_reached (); | ||||
|       glyph = 0; /* silence compiler */ | ||||
|       break; | ||||
|     } | ||||
|  | ||||
|   *glyph_out = glyph; | ||||
|   *name_out = name; | ||||
| } | ||||
|  | ||||
| static Cursor | ||||
| load_cursor_on_server (MetaDisplay *display, | ||||
|                        MetaCursor   cursor) | ||||
| { | ||||
|   Cursor xcursor; | ||||
|   guint glyph; | ||||
|   const char *name; | ||||
|  | ||||
|   translate_meta_cursor (cursor, &glyph, &name); | ||||
|  | ||||
|   if (name != NULL) | ||||
|     xcursor = XcursorLibraryLoadCursor (display->xdisplay, name); | ||||
|   else | ||||
|     xcursor = XCreateFontCursor (display->xdisplay, glyph); | ||||
|  | ||||
|   return xcursor; | ||||
| } | ||||
|  | ||||
| Cursor | ||||
| meta_display_create_x_cursor (MetaDisplay *display, | ||||
|                               MetaCursor cursor) | ||||
| { | ||||
|   return load_cursor_on_server (display, cursor); | ||||
| } | ||||
|  | ||||
| static XcursorImage * | ||||
| load_cursor_on_client (MetaDisplay *display, | ||||
|                        MetaCursor   cursor) | ||||
| { | ||||
|   XcursorImage *image; | ||||
|   guint glyph; | ||||
|   const char *name; | ||||
|   const char *theme = XcursorGetTheme (display->xdisplay); | ||||
|   int size = XcursorGetDefaultSize (display->xdisplay); | ||||
|  | ||||
|   translate_meta_cursor (cursor, &glyph, &name); | ||||
|  | ||||
|   if (name != NULL) | ||||
|     image = XcursorLibraryLoadImage (name, theme, size); | ||||
|   else | ||||
|     image = XcursorShapeLoadImage (glyph, theme, size); | ||||
|  | ||||
|   return image; | ||||
| } | ||||
|  | ||||
| static MetaCursorReference * | ||||
| meta_cursor_reference_from_theme (MetaCursorTracker  *tracker, | ||||
|                                   MetaCursor          cursor) | ||||
| { | ||||
|   XcursorImage *image; | ||||
|   int width, height, rowstride; | ||||
|   CoglPixelFormat cogl_format; | ||||
|   uint32_t gbm_format; | ||||
|   ClutterBackend *clutter_backend; | ||||
|   CoglContext *cogl_context; | ||||
|   MetaCursorReference *self; | ||||
|  | ||||
|   image = load_cursor_on_client (tracker->screen->display, cursor); | ||||
|   if (!image) | ||||
|     return NULL; | ||||
|  | ||||
|   width           = image->width; | ||||
|   height          = image->height; | ||||
|   rowstride       = width * 4; | ||||
|  | ||||
|   gbm_format = GBM_FORMAT_ARGB8888; | ||||
| #if G_BYTE_ORDER == G_LITTLE_ENDIAN | ||||
|   cogl_format = COGL_PIXEL_FORMAT_BGRA_8888; | ||||
| #else | ||||
|   cogl_format = COGL_PIXEL_FORMAT_ARGB_8888; | ||||
| #endif | ||||
|  | ||||
|   self = g_slice_new0 (MetaCursorReference); | ||||
|   self->ref_count = 1; | ||||
|   self->hot_x = image->xhot; | ||||
|   self->hot_y = image->yhot; | ||||
|  | ||||
|   clutter_backend = clutter_get_default_backend (); | ||||
|   cogl_context = clutter_backend_get_cogl_context (clutter_backend); | ||||
|   self->texture = cogl_texture_2d_new_from_data (cogl_context, | ||||
|                                                  width, height, | ||||
|                                                  cogl_format, | ||||
|                                                  COGL_PIXEL_FORMAT_ANY, | ||||
|                                                  rowstride, | ||||
|                                                  (uint8_t*)image->pixels, | ||||
|                                                  NULL); | ||||
|  | ||||
|   if (tracker->gbm) | ||||
|     { | ||||
|       if (width > 64 || height > 64) | ||||
|         { | ||||
|           meta_warning ("Invalid theme cursor size (must be at most 64x64)\n"); | ||||
|           goto out; | ||||
|         } | ||||
|  | ||||
|       if (gbm_device_is_format_supported (tracker->gbm, gbm_format, | ||||
|                                           GBM_BO_USE_CURSOR_64X64 | GBM_BO_USE_WRITE)) | ||||
|         { | ||||
|           uint32_t buf[64 * 64]; | ||||
|           int i; | ||||
|  | ||||
|           self->bo = gbm_bo_create (tracker->gbm, 64, 64, | ||||
|                                     gbm_format, GBM_BO_USE_CURSOR_64X64 | GBM_BO_USE_WRITE); | ||||
|  | ||||
|           memset (buf, 0, sizeof(buf)); | ||||
|           for (i = 0; i < height; i++) | ||||
|             memcpy (buf + i * 64, image->pixels + i * width, width * 4); | ||||
|  | ||||
|           gbm_bo_write (self->bo, buf, 64 * 64 * 4); | ||||
|         } | ||||
|       else | ||||
|         meta_warning ("HW cursor for format %d not supported\n", gbm_format); | ||||
|     } | ||||
|  | ||||
|  out: | ||||
|   XcursorImageDestroy (image); | ||||
|  | ||||
|   return self; | ||||
| } | ||||
|  | ||||
| static MetaCursorReference * | ||||
| meta_cursor_reference_take_texture (CoglTexture2D *texture) | ||||
| { | ||||
|   MetaCursorReference *self; | ||||
|  | ||||
|   self = g_slice_new0 (MetaCursorReference); | ||||
|   self->ref_count = 1; | ||||
|  | ||||
|   self->texture = texture; | ||||
|  | ||||
|   return self; | ||||
| } | ||||
|  | ||||
| static MetaCursorReference * | ||||
| meta_cursor_reference_from_buffer (MetaCursorTracker  *tracker, | ||||
|                                    struct wl_resource *buffer, | ||||
|                                    int                 hot_x, | ||||
|                                    int                 hot_y) | ||||
| { | ||||
|   ClutterBackend *backend; | ||||
|   CoglContext *cogl_context; | ||||
|   MetaCursorReference *self; | ||||
|   CoglPixelFormat cogl_format, cogl_internal_format; | ||||
|   struct wl_shm_buffer *shm_buffer; | ||||
|   uint32_t gbm_format; | ||||
|  | ||||
|   self = g_slice_new0 (MetaCursorReference); | ||||
|   self->ref_count = 1; | ||||
|   self->hot_x = hot_x; | ||||
|   self->hot_y = hot_y; | ||||
|   | ||||
|   backend = clutter_get_default_backend (); | ||||
|   cogl_context = clutter_backend_get_cogl_context (backend); | ||||
|  | ||||
|   shm_buffer = wl_shm_buffer_get (buffer); | ||||
|   if (shm_buffer) | ||||
|     { | ||||
|       int rowstride = wl_shm_buffer_get_stride (shm_buffer); | ||||
|       int width = wl_shm_buffer_get_width (shm_buffer); | ||||
|       int height = wl_shm_buffer_get_height (shm_buffer); | ||||
|  | ||||
|       switch (wl_shm_buffer_get_format (shm_buffer)) | ||||
|         { | ||||
| #if G_BYTE_ORDER == G_BIG_ENDIAN | ||||
|           case WL_SHM_FORMAT_ARGB8888: | ||||
|             cogl_format = COGL_PIXEL_FORMAT_ARGB_8888_PRE; | ||||
|             cogl_internal_format = COGL_PIXEL_FORMAT_ANY; | ||||
|             gbm_format = GBM_FORMAT_ARGB8888; | ||||
|             break; | ||||
|           case WL_SHM_FORMAT_XRGB8888: | ||||
|             cogl_format = COGL_PIXEL_FORMAT_ARGB_8888; | ||||
|             cogl_internal_format = COGL_PIXEL_FORMAT_RGB_888; | ||||
|             gbm_format = GBM_FORMAT_XRGB8888; | ||||
|             break; | ||||
| #else | ||||
|           case WL_SHM_FORMAT_ARGB8888: | ||||
|             cogl_format = COGL_PIXEL_FORMAT_BGRA_8888_PRE; | ||||
|             cogl_internal_format = COGL_PIXEL_FORMAT_ANY; | ||||
|             gbm_format = GBM_FORMAT_ARGB8888; | ||||
|             break; | ||||
|           case WL_SHM_FORMAT_XRGB8888: | ||||
|             cogl_format = COGL_PIXEL_FORMAT_BGRA_8888; | ||||
|             cogl_internal_format = COGL_PIXEL_FORMAT_BGR_888; | ||||
|             gbm_format = GBM_FORMAT_XRGB8888; | ||||
|             break; | ||||
| #endif | ||||
|           default: | ||||
|             g_warn_if_reached (); | ||||
|             cogl_format = COGL_PIXEL_FORMAT_ARGB_8888; | ||||
|             cogl_internal_format = COGL_PIXEL_FORMAT_ANY; | ||||
|             gbm_format = GBM_FORMAT_ARGB8888; | ||||
|         } | ||||
|  | ||||
|       self->texture = cogl_texture_2d_new_from_data (cogl_context, | ||||
|                                                      width, height, | ||||
|                                                      cogl_format, | ||||
|                                                      cogl_internal_format, | ||||
|                                                      rowstride, | ||||
|                                                      wl_shm_buffer_get_data (shm_buffer), | ||||
|                                                      NULL); | ||||
|  | ||||
|       if (width > 64 || height > 64) | ||||
|         { | ||||
|           meta_warning ("Invalid cursor size (must be at most 64x64), falling back to software (GL) cursors\n"); | ||||
|           return self; | ||||
|         } | ||||
|  | ||||
|       if (tracker->gbm) | ||||
|         { | ||||
|           if (gbm_device_is_format_supported (tracker->gbm, gbm_format, | ||||
|                                               GBM_BO_USE_CURSOR_64X64 | GBM_BO_USE_WRITE)) | ||||
|             { | ||||
|               uint8_t *data; | ||||
|               uint8_t buf[4 * 64 * 64]; | ||||
|               int i; | ||||
|  | ||||
|               self->bo = gbm_bo_create (tracker->gbm, 64, 64, | ||||
|                                         gbm_format, GBM_BO_USE_CURSOR_64X64 | GBM_BO_USE_WRITE); | ||||
|  | ||||
|               data = wl_shm_buffer_get_data (shm_buffer); | ||||
|               memset (buf, 0, sizeof(buf)); | ||||
|               for (i = 0; i < height; i++) | ||||
|                 memcpy (buf + i * 4 * 64, data + i * rowstride, 4 * width); | ||||
|  | ||||
|               gbm_bo_write (self->bo, buf, 64 * 64 * 4); | ||||
|             } | ||||
|           else | ||||
|             meta_warning ("HW cursor for format %d not supported\n", gbm_format); | ||||
|         } | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       int width, height; | ||||
|  | ||||
|       self->texture = cogl_wayland_texture_2d_new_from_buffer (cogl_context, buffer, NULL); | ||||
|       width = cogl_texture_get_width (COGL_TEXTURE (self->texture)); | ||||
|       height = cogl_texture_get_height (COGL_TEXTURE (self->texture)); | ||||
|  | ||||
|       /* HW cursors must be 64x64, but 64x64 is huge, and no cursor theme actually uses | ||||
|          that, so themed cursors must be padded with transparent pixels to fill the | ||||
|          overlay. This is trivial if we have CPU access to the data, but it's not | ||||
|          possible if the buffer is in GPU memory (and possibly tiled too), so if we | ||||
|          don't get the right size, we fallback to GL. | ||||
|       */ | ||||
|       if (width != 64 || height != 64) | ||||
|         { | ||||
|           meta_warning ("Invalid cursor size (must be 64x64), falling back to software (GL) cursors\n"); | ||||
|           return self; | ||||
|         } | ||||
|  | ||||
|       if (tracker->gbm) | ||||
|         { | ||||
|           cogl_format = cogl_texture_get_format (COGL_TEXTURE (self->texture)); | ||||
|           switch (cogl_format) | ||||
|             { | ||||
| #if G_BYTE_ORDER == G_LITTLE_ENDIAN | ||||
|             case COGL_PIXEL_FORMAT_ARGB_8888_PRE: | ||||
|             case COGL_PIXEL_FORMAT_ARGB_8888: | ||||
|               gbm_format = GBM_FORMAT_BGRA8888; | ||||
|               break; | ||||
|             case COGL_PIXEL_FORMAT_BGRA_8888_PRE: | ||||
|             case COGL_PIXEL_FORMAT_BGRA_8888: | ||||
|               break; | ||||
|             case COGL_PIXEL_FORMAT_RGB_888: | ||||
|               break; | ||||
| #else | ||||
|             case COGL_PIXEL_FORMAT_ARGB_8888_PRE: | ||||
|             case COGL_PIXEL_FORMAT_ARGB_8888: | ||||
|               gbm_format = GBM_FORMAT_ARGB8888; | ||||
|               break; | ||||
|             case COGL_PIXEL_FORMAT_BGRA_8888_PRE: | ||||
|             case COGL_PIXEL_FORMAT_BGRA_8888: | ||||
|               gbm_format = GBM_FORMAT_BGRA8888; | ||||
|               break; | ||||
|             case COGL_PIXEL_FORMAT_RGB_888: | ||||
|               gbm_format = GBM_FORMAT_RGB888; | ||||
|               break; | ||||
| #endif | ||||
|             default: | ||||
|               meta_warning ("Unknown cogl format %d\n", cogl_format); | ||||
|               return self; | ||||
|             } | ||||
|  | ||||
|           if (gbm_device_is_format_supported (tracker->gbm, gbm_format, | ||||
|                                               GBM_BO_USE_CURSOR_64X64)) | ||||
|             { | ||||
|               self->bo = gbm_bo_import (tracker->gbm, GBM_BO_IMPORT_WL_BUFFER, | ||||
|                                         buffer, GBM_BO_USE_CURSOR_64X64); | ||||
|               if (!self->bo) | ||||
|                 meta_warning ("Importing HW cursor from wl_buffer failed\n"); | ||||
|             } | ||||
|           else | ||||
|             meta_warning ("HW cursor for format %d not supported\n", gbm_format); | ||||
|         } | ||||
|      } | ||||
|  | ||||
|   return self; | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_cursor_tracker_init (MetaCursorTracker *self) | ||||
| { | ||||
|   /* (JS) Best (?) that can be assumed since XFixes doesn't provide a way of | ||||
|    * detecting if the system mouse cursor is showing or not. | ||||
|    * | ||||
|    * On wayland we start with the cursor showing | ||||
|    */ | ||||
|      detecting if the system mouse cursor is showing or not. | ||||
|  | ||||
|      On wayland we start with the cursor showing | ||||
|   */ | ||||
|   self->is_showing = TRUE; | ||||
| } | ||||
|  | ||||
| @@ -84,9 +518,21 @@ static void | ||||
| meta_cursor_tracker_finalize (GObject *object) | ||||
| { | ||||
|   MetaCursorTracker *self = META_CURSOR_TRACKER (object); | ||||
|   int i; | ||||
|  | ||||
|   if (self->sprite) | ||||
|     cogl_object_unref (self->sprite); | ||||
|     meta_cursor_reference_unref (self->sprite); | ||||
|   if (self->root_cursor) | ||||
|     meta_cursor_reference_unref (self->root_cursor); | ||||
|  | ||||
|   for (i = 0; i < META_CURSOR_LAST; i++) | ||||
|     if (self->default_cursors[i]) | ||||
|       meta_cursor_reference_unref (self->default_cursors[i]); | ||||
|  | ||||
|   if (self->pipeline) | ||||
|     cogl_object_unref (self->pipeline); | ||||
|   if (self->gbm) | ||||
|     gbm_device_destroy (self->gbm); | ||||
|  | ||||
|   G_OBJECT_CLASS (meta_cursor_tracker_parent_class)->finalize (object); | ||||
| } | ||||
| @@ -106,6 +552,60 @@ meta_cursor_tracker_class_init (MetaCursorTrackerClass *klass) | ||||
|                                           G_TYPE_NONE, 0); | ||||
| } | ||||
|  | ||||
| static void | ||||
| on_monitors_changed (MetaMonitorManager *monitors, | ||||
|                      MetaCursorTracker  *tracker) | ||||
| { | ||||
|   MetaCRTC *crtcs; | ||||
|   unsigned int i, n_crtcs; | ||||
|  | ||||
|   if (!tracker->has_hw_cursor) | ||||
|     return; | ||||
|  | ||||
|   /* Go through the new list of monitors, find out where the cursor is */ | ||||
|   meta_monitor_manager_get_resources (monitors, NULL, NULL, &crtcs, &n_crtcs, NULL, NULL); | ||||
|  | ||||
|   for (i = 0; i < n_crtcs; i++) | ||||
|     { | ||||
|       MetaRectangle *rect = &crtcs[i].rect; | ||||
|       gboolean has; | ||||
|  | ||||
|       has = meta_rectangle_overlap (&tracker->current_rect, rect); | ||||
|  | ||||
|       /* Need to do it unconditionally here, our tracking is | ||||
|          wrong because we reloaded the CRTCs */ | ||||
|       meta_cursor_tracker_set_crtc_has_hw_cursor (tracker, &crtcs[i], has); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static MetaCursorTracker * | ||||
| make_wayland_cursor_tracker (MetaScreen *screen) | ||||
| { | ||||
|   MetaWaylandCompositor *compositor; | ||||
|   CoglContext *ctx; | ||||
|   MetaMonitorManager *monitors; | ||||
|   MetaCursorTracker *self; | ||||
|  | ||||
|   self = g_object_new (META_TYPE_CURSOR_TRACKER, NULL); | ||||
|   self->screen = screen; | ||||
|  | ||||
|   ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ()); | ||||
|   self->pipeline = cogl_pipeline_new (ctx); | ||||
|  | ||||
|   compositor = meta_wayland_compositor_get_default (); | ||||
|   compositor->seat->cursor_tracker = self; | ||||
|  | ||||
|   self->drm_fd = compositor->drm_fd; | ||||
|   if (self->drm_fd >= 0) | ||||
|     self->gbm = gbm_create_device (compositor->drm_fd); | ||||
|  | ||||
|   monitors = meta_monitor_manager_get (); | ||||
|   g_signal_connect_object (monitors, "monitors-changed", | ||||
|                            G_CALLBACK (on_monitors_changed), self, 0); | ||||
|  | ||||
|   return self; | ||||
| } | ||||
|  | ||||
| static MetaCursorTracker * | ||||
| make_x11_cursor_tracker (MetaScreen *screen) | ||||
| { | ||||
| @@ -135,7 +635,12 @@ meta_cursor_tracker_get_for_screen (MetaScreen *screen) | ||||
|   if (screen->cursor_tracker) | ||||
|     return screen->cursor_tracker; | ||||
|  | ||||
|   self = make_x11_cursor_tracker (screen); | ||||
| #ifdef HAVE_WAYLAND | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     self = make_wayland_cursor_tracker (screen); | ||||
|   else | ||||
| #endif | ||||
|     self = make_x11_cursor_tracker (screen); | ||||
|  | ||||
|   screen->cursor_tracker = self; | ||||
|   return self; | ||||
| @@ -147,6 +652,9 @@ meta_cursor_tracker_handle_xevent (MetaCursorTracker *tracker, | ||||
| { | ||||
|   XFixesCursorNotifyEvent *notify_event; | ||||
|  | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     return FALSE; | ||||
|  | ||||
|   if (xevent->xany.type != tracker->screen->display->xfixes_event_base + XFixesCursorNotify) | ||||
|     return FALSE; | ||||
|  | ||||
| @@ -154,7 +662,7 @@ meta_cursor_tracker_handle_xevent (MetaCursorTracker *tracker, | ||||
|   if (notify_event->subtype != XFixesDisplayCursorNotify) | ||||
|     return FALSE; | ||||
|  | ||||
|   g_clear_pointer (&tracker->sprite, cogl_object_unref); | ||||
|   g_clear_pointer (&tracker->sprite, meta_cursor_reference_unref); | ||||
|   g_signal_emit (tracker, signals[CURSOR_CHANGED], 0); | ||||
|  | ||||
|   return TRUE; | ||||
| @@ -217,9 +725,9 @@ ensure_xfixes_cursor (MetaCursorTracker *tracker) | ||||
|  | ||||
|   if (sprite != NULL) | ||||
|     { | ||||
|       tracker->sprite = sprite; | ||||
|       tracker->hot_x = cursor_image->xhot; | ||||
|       tracker->hot_y = cursor_image->yhot; | ||||
|       tracker->sprite = meta_cursor_reference_take_texture (sprite); | ||||
|       tracker->sprite->hot_x = cursor_image->xhot; | ||||
|       tracker->sprite->hot_y = cursor_image->yhot; | ||||
|     } | ||||
|   XFree (cursor_image); | ||||
| } | ||||
| @@ -234,9 +742,13 @@ meta_cursor_tracker_get_sprite (MetaCursorTracker *tracker) | ||||
| { | ||||
|   g_return_val_if_fail (META_IS_CURSOR_TRACKER (tracker), NULL); | ||||
|  | ||||
|   ensure_xfixes_cursor (tracker); | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     ensure_xfixes_cursor (tracker); | ||||
|  | ||||
|   return COGL_TEXTURE (tracker->sprite); | ||||
|   if (tracker->sprite) | ||||
|     return COGL_TEXTURE (tracker->sprite->texture); | ||||
|   else | ||||
|     return NULL; | ||||
| } | ||||
|  | ||||
| /** | ||||
| @@ -253,12 +765,37 @@ meta_cursor_tracker_get_hot (MetaCursorTracker *tracker, | ||||
| { | ||||
|   g_return_if_fail (META_IS_CURSOR_TRACKER (tracker)); | ||||
|  | ||||
|   ensure_xfixes_cursor (tracker); | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     ensure_xfixes_cursor (tracker); | ||||
|  | ||||
|   if (x) | ||||
|     *x = tracker->hot_x; | ||||
|   if (y) | ||||
|     *y = tracker->hot_y; | ||||
|   if (tracker->sprite) | ||||
|     { | ||||
|       if (x) | ||||
|         *x = tracker->sprite->hot_x; | ||||
|       if (y) | ||||
|         *y = tracker->sprite->hot_y; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       if (x) | ||||
|         *x = 0; | ||||
|       if (y) | ||||
|         *y = 0; | ||||
|     } | ||||
| } | ||||
|  | ||||
| static MetaCursorReference * | ||||
| ensure_wayland_cursor (MetaCursorTracker *tracker, | ||||
|                        MetaCursor         cursor) | ||||
| { | ||||
|   if (tracker->default_cursors[cursor]) | ||||
|     return tracker->default_cursors[cursor]; | ||||
|  | ||||
|   tracker->default_cursors[cursor] = meta_cursor_reference_from_theme (tracker, cursor); | ||||
|   if (!tracker->default_cursors[cursor]) | ||||
|     meta_warning ("Failed to load cursor from theme\n"); | ||||
|  | ||||
|   return tracker->default_cursors[cursor]; | ||||
| } | ||||
|  | ||||
| void | ||||
| @@ -274,13 +811,236 @@ meta_cursor_tracker_set_root_cursor (MetaCursorTracker *tracker, | ||||
|   XDefineCursor (display->xdisplay, tracker->screen->xroot, xcursor); | ||||
|   XFlush (display->xdisplay); | ||||
|   XFreeCursor (display->xdisplay, xcursor); | ||||
|  | ||||
|   /* Now update the real root cursor */ | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       MetaCursorReference *ref; | ||||
|  | ||||
|       ref = ensure_wayland_cursor (tracker, cursor); | ||||
|  | ||||
|       g_clear_pointer (&tracker->root_cursor, meta_cursor_reference_unref); | ||||
|       tracker->root_cursor = meta_cursor_reference_ref (ref); | ||||
|     } | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_cursor_tracker_get_pointer (MetaCursorTracker   *tracker, | ||||
|                                  int                 *x, | ||||
|                                  int                 *y, | ||||
|                                  ClutterModifierType *mods) | ||||
| meta_cursor_tracker_revert_root (MetaCursorTracker *tracker) | ||||
| { | ||||
|   meta_cursor_tracker_set_sprite (tracker, tracker->root_cursor); | ||||
| } | ||||
|  | ||||
| static void | ||||
| update_hw_cursor (MetaCursorTracker *tracker) | ||||
| { | ||||
|   MetaMonitorManager *monitors; | ||||
|   MetaCRTC *crtcs; | ||||
|   unsigned int i, n_crtcs; | ||||
|   gboolean enabled; | ||||
|  | ||||
|   enabled = tracker->has_cursor && tracker->sprite->bo != NULL; | ||||
|   tracker->has_hw_cursor = enabled; | ||||
|  | ||||
|   monitors = meta_monitor_manager_get (); | ||||
|   meta_monitor_manager_get_resources (monitors, NULL, NULL, &crtcs, &n_crtcs, NULL, NULL); | ||||
|  | ||||
|   for (i = 0; i < n_crtcs; i++) | ||||
|     { | ||||
|       MetaRectangle *rect = &crtcs[i].rect; | ||||
|       gboolean has; | ||||
|  | ||||
|       has = enabled && meta_rectangle_overlap (&tracker->current_rect, rect); | ||||
|  | ||||
|       if (has || crtcs[i].has_hw_cursor) | ||||
|         meta_cursor_tracker_set_crtc_has_hw_cursor (tracker, &crtcs[i], has); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void | ||||
| move_hw_cursor (MetaCursorTracker *tracker) | ||||
| { | ||||
|   MetaMonitorManager *monitors; | ||||
|   MetaCRTC *crtcs; | ||||
|   unsigned int i, n_crtcs; | ||||
|  | ||||
|   monitors = meta_monitor_manager_get (); | ||||
|   meta_monitor_manager_get_resources (monitors, NULL, NULL, &crtcs, &n_crtcs, NULL, NULL); | ||||
|  | ||||
|   g_assert (tracker->has_hw_cursor); | ||||
|  | ||||
|   for (i = 0; i < n_crtcs; i++) | ||||
|     { | ||||
|       MetaRectangle *rect = &crtcs[i].rect; | ||||
|       gboolean has; | ||||
|  | ||||
|       has = meta_rectangle_overlap (&tracker->current_rect, rect); | ||||
|  | ||||
|       if (has != crtcs[i].has_hw_cursor) | ||||
|         meta_cursor_tracker_set_crtc_has_hw_cursor (tracker, &crtcs[i], has); | ||||
|       if (has) | ||||
|         drmModeMoveCursor (tracker->drm_fd, crtcs[i].crtc_id, | ||||
|                            tracker->current_rect.x - rect->x, | ||||
|                            tracker->current_rect.y - rect->y); | ||||
|     } | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_cursor_tracker_set_buffer (MetaCursorTracker  *tracker, | ||||
|                                 struct wl_resource *buffer, | ||||
|                                 int                 hot_x, | ||||
|                                 int                 hot_y) | ||||
| { | ||||
|   MetaCursorReference *new_cursor; | ||||
|  | ||||
|   if (buffer) | ||||
|     { | ||||
|       new_cursor = meta_cursor_reference_from_buffer (tracker, buffer, hot_x, hot_y); | ||||
|       meta_cursor_tracker_set_sprite (tracker, new_cursor); | ||||
|       meta_cursor_reference_unref (new_cursor); | ||||
|     } | ||||
|   else | ||||
|     meta_cursor_tracker_set_sprite (tracker, NULL); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_cursor_tracker_set_sprite (MetaCursorTracker   *tracker, | ||||
|                                 MetaCursorReference *sprite) | ||||
| { | ||||
|   g_assert (meta_is_wayland_compositor ()); | ||||
|  | ||||
|   if (sprite == tracker->sprite) | ||||
|     return; | ||||
|  | ||||
|   g_clear_pointer (&tracker->sprite, meta_cursor_reference_unref); | ||||
|  | ||||
|   if (sprite) | ||||
|     { | ||||
|       tracker->sprite = meta_cursor_reference_ref (sprite); | ||||
|       cogl_pipeline_set_layer_texture (tracker->pipeline, 0, COGL_TEXTURE (tracker->sprite->texture)); | ||||
|     } | ||||
|   else | ||||
|     cogl_pipeline_set_layer_texture (tracker->pipeline, 0, NULL); | ||||
|  | ||||
|   tracker->has_cursor = tracker->sprite != NULL && tracker->is_showing; | ||||
|   update_hw_cursor (tracker); | ||||
|  | ||||
|   g_signal_emit (tracker, signals[CURSOR_CHANGED], 0); | ||||
|  | ||||
|   meta_cursor_tracker_update_position (tracker, tracker->current_x, tracker->current_y); | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_cursor_tracker_update_position (MetaCursorTracker *tracker, | ||||
|                                      int                new_x, | ||||
|                                      int                new_y) | ||||
| { | ||||
|   g_assert (meta_is_wayland_compositor ()); | ||||
|  | ||||
|   tracker->current_x = new_x; | ||||
|   tracker->current_y = new_y; | ||||
|  | ||||
|   if (tracker->sprite) | ||||
|     { | ||||
|       tracker->current_rect.x = tracker->current_x - tracker->sprite->hot_x; | ||||
|       tracker->current_rect.y = tracker->current_y - tracker->sprite->hot_y; | ||||
|       tracker->current_rect.width = cogl_texture_get_width (COGL_TEXTURE (tracker->sprite->texture)); | ||||
|       tracker->current_rect.height = cogl_texture_get_height (COGL_TEXTURE (tracker->sprite->texture)); | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       tracker->current_rect.x = 0; | ||||
|       tracker->current_rect.y = 0; | ||||
|       tracker->current_rect.width = 0; | ||||
|       tracker->current_rect.height = 0; | ||||
|     } | ||||
|  | ||||
|   if (tracker->has_hw_cursor) | ||||
|     move_hw_cursor (tracker); | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_cursor_tracker_paint (MetaCursorTracker *tracker) | ||||
| { | ||||
|   g_assert (meta_is_wayland_compositor ()); | ||||
|  | ||||
|   if (tracker->has_hw_cursor || !tracker->has_cursor) | ||||
|     return; | ||||
|  | ||||
|   cogl_framebuffer_draw_rectangle (cogl_get_draw_framebuffer (), | ||||
|                                    tracker->pipeline, | ||||
|                                    tracker->current_rect.x, | ||||
|                                    tracker->current_rect.y, | ||||
|                                    tracker->current_rect.x + | ||||
|                                    tracker->current_rect.width, | ||||
|                                    tracker->current_rect.y + | ||||
|                                    tracker->current_rect.height); | ||||
|  | ||||
|   tracker->previous_rect = tracker->current_rect; | ||||
|   tracker->previous_is_valid = TRUE; | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_cursor_tracker_queue_redraw (MetaCursorTracker *tracker, | ||||
|                                   ClutterActor      *stage) | ||||
| { | ||||
|   cairo_rectangle_int_t clip; | ||||
|  | ||||
|   g_assert (meta_is_wayland_compositor ()); | ||||
|  | ||||
|   if (tracker->previous_is_valid) | ||||
|     { | ||||
|       cairo_rectangle_int_t clip = { | ||||
|         .x = tracker->previous_rect.x, | ||||
|         .y = tracker->previous_rect.y, | ||||
|         .width = tracker->previous_rect.width, | ||||
|         .height = tracker->previous_rect.height | ||||
|       }; | ||||
|       clutter_actor_queue_redraw_with_clip (stage, &clip); | ||||
|       tracker->previous_is_valid = FALSE; | ||||
|     } | ||||
|  | ||||
|   if (tracker->has_hw_cursor || !tracker->has_cursor) | ||||
|     return; | ||||
|  | ||||
|   clip.x = tracker->current_rect.x; | ||||
|   clip.y = tracker->current_rect.y; | ||||
|   clip.width = tracker->current_rect.width; | ||||
|   clip.height = tracker->current_rect.height; | ||||
|   clutter_actor_queue_redraw_with_clip (stage, &clip); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_cursor_tracker_set_crtc_has_hw_cursor (MetaCursorTracker *tracker, | ||||
|                                             MetaCRTC          *crtc, | ||||
|                                             gboolean           has) | ||||
| { | ||||
|   if (has) | ||||
|     { | ||||
|       union gbm_bo_handle handle; | ||||
|       int width, height; | ||||
|       int hot_x, hot_y; | ||||
|  | ||||
|       handle = gbm_bo_get_handle (tracker->sprite->bo); | ||||
|       width = gbm_bo_get_width (tracker->sprite->bo); | ||||
|       height = gbm_bo_get_height (tracker->sprite->bo); | ||||
|       hot_x = tracker->sprite->hot_x; | ||||
|       hot_y = tracker->sprite->hot_y; | ||||
|  | ||||
|       drmModeSetCursor2 (tracker->drm_fd, crtc->crtc_id, handle.u32, | ||||
|                          width, height, hot_x, hot_y); | ||||
|       crtc->has_hw_cursor = TRUE; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       drmModeSetCursor2 (tracker->drm_fd, crtc->crtc_id, 0, 0, 0, 0, 0); | ||||
|       crtc->has_hw_cursor = FALSE; | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void | ||||
| get_pointer_position_gdk (int         *x, | ||||
|                           int         *y, | ||||
|                           int         *mods) | ||||
| { | ||||
|   GdkDeviceManager *gmanager; | ||||
|   GdkDevice *gdevice; | ||||
| @@ -295,6 +1055,41 @@ meta_cursor_tracker_get_pointer (MetaCursorTracker   *tracker, | ||||
|                         NULL, (GdkModifierType*)mods); | ||||
| } | ||||
|  | ||||
| static void | ||||
| get_pointer_position_clutter (int         *x, | ||||
|                               int         *y, | ||||
|                               int         *mods) | ||||
| { | ||||
|   ClutterDeviceManager *cmanager; | ||||
|   ClutterInputDevice *cdevice; | ||||
|   ClutterPoint point; | ||||
|  | ||||
|   cmanager = clutter_device_manager_get_default (); | ||||
|   cdevice = clutter_device_manager_get_core_device (cmanager, CLUTTER_POINTER_DEVICE); | ||||
|  | ||||
|   clutter_input_device_get_coords (cdevice, NULL, &point); | ||||
|   *x = point.x; | ||||
|   *y = point.y; | ||||
|   *mods = clutter_input_device_get_modifier_state (cdevice); | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_cursor_tracker_get_pointer (MetaCursorTracker   *tracker, | ||||
|                                  int                 *x, | ||||
|                                  int                 *y, | ||||
|                                  ClutterModifierType *mods) | ||||
| { | ||||
|   /* We can't use the clutter interface when not running as a wayland compositor, | ||||
|      because we need to query the server, rather than using the last cached value. | ||||
|      OTOH, on wayland we can't use GDK, because that only sees the events | ||||
|      we forward to xwayland. | ||||
|   */ | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     get_pointer_position_clutter (x, y, (int*)mods); | ||||
|   else | ||||
|     get_pointer_position_gdk (x, y, (int*)mods); | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_cursor_tracker_set_pointer_visible (MetaCursorTracker *tracker, | ||||
|                                          gboolean           visible) | ||||
| @@ -303,10 +1098,23 @@ meta_cursor_tracker_set_pointer_visible (MetaCursorTracker *tracker, | ||||
|     return; | ||||
|   tracker->is_showing = visible; | ||||
|  | ||||
|   if (visible) | ||||
|     XFixesShowCursor (tracker->screen->display->xdisplay, | ||||
|                       tracker->screen->xroot); | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       MetaWaylandCompositor *compositor; | ||||
|  | ||||
|       compositor = meta_wayland_compositor_get_default (); | ||||
|  | ||||
|       tracker->has_cursor = tracker->sprite != NULL && visible; | ||||
|       update_hw_cursor (tracker); | ||||
|       meta_cursor_tracker_queue_redraw (tracker, compositor->stage); | ||||
|     } | ||||
|   else | ||||
|     XFixesHideCursor (tracker->screen->display->xdisplay, | ||||
|                       tracker->screen->xroot); | ||||
|     { | ||||
|       if (visible) | ||||
|         XFixesShowCursor (tracker->screen->display->xdisplay, | ||||
|                           tracker->screen->xroot); | ||||
|       else | ||||
|         XFixesHideCursor (tracker->screen->display->xdisplay, | ||||
|                           tracker->screen->xroot); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -26,5 +26,6 @@ | ||||
|  | ||||
| void meta_idle_monitor_handle_xevent_all (XEvent *xevent); | ||||
|  | ||||
| void meta_idle_monitor_reset_idletime (MetaIdleMonitor *monitor); | ||||
|  | ||||
| void meta_idle_monitor_init_dbus (void); | ||||
|   | ||||
| @@ -57,6 +57,9 @@ struct _MetaIdleMonitor | ||||
|   int          sync_event_base; | ||||
|   XSyncCounter counter; | ||||
|   XSyncAlarm   user_active_alarm; | ||||
|  | ||||
|   /* Wayland implementation */ | ||||
|   guint64      last_event_time; | ||||
| }; | ||||
|  | ||||
| struct _MetaIdleMonitorClass | ||||
| @@ -76,6 +79,9 @@ typedef struct | ||||
|   /* x11 */ | ||||
|   XSyncAlarm                xalarm; | ||||
|   int                       idle_source_id; | ||||
|  | ||||
|   /* wayland */ | ||||
|   GSource                  *timeout_source; | ||||
| } MetaIdleMonitorWatch; | ||||
|  | ||||
| enum | ||||
| @@ -305,6 +311,9 @@ idle_monitor_watch_free (MetaIdleMonitorWatch *watch) | ||||
|       g_hash_table_remove (monitor->alarms, (gpointer) watch->xalarm); | ||||
|     } | ||||
|  | ||||
|   if (watch->timeout_source != NULL) | ||||
|     g_source_destroy (watch->timeout_source); | ||||
|  | ||||
|   g_object_unref (monitor); | ||||
|   g_slice_free (MetaIdleMonitorWatch, watch); | ||||
| } | ||||
| @@ -384,8 +393,11 @@ meta_idle_monitor_constructed (GObject *object) | ||||
| { | ||||
|   MetaIdleMonitor *monitor = META_IDLE_MONITOR (object); | ||||
|  | ||||
|   monitor->display = meta_get_display ()->xdisplay; | ||||
|   init_xsync (monitor); | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       monitor->display = meta_get_display ()->xdisplay; | ||||
|       init_xsync (monitor); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -464,6 +476,25 @@ meta_idle_monitor_get_for_device (int device_id) | ||||
|   return device_monitors[device_id]; | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| wayland_dispatch_timeout (GSource     *source, | ||||
|                           GSourceFunc  callback, | ||||
|                           gpointer     user_data) | ||||
| { | ||||
|   MetaIdleMonitorWatch *watch = user_data; | ||||
|  | ||||
|   fire_watch (watch); | ||||
|   g_source_set_ready_time (watch->timeout_source, -1); | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| static GSourceFuncs wayland_source_funcs = { | ||||
|   NULL, /* prepare */ | ||||
|   NULL, /* check */ | ||||
|   wayland_dispatch_timeout, | ||||
|   NULL, /* finalize */ | ||||
| }; | ||||
|  | ||||
| static gboolean | ||||
| fire_watch_idle (gpointer data) | ||||
| { | ||||
| @@ -492,20 +523,37 @@ make_watch (MetaIdleMonitor           *monitor, | ||||
|   watch->notify = notify; | ||||
|   watch->timeout_msec = timeout_msec; | ||||
|  | ||||
|   if (timeout_msec != 0) | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       watch->xalarm = _xsync_alarm_set (monitor, XSyncPositiveTransition, timeout_msec, TRUE); | ||||
|       if (timeout_msec != 0) | ||||
|         { | ||||
|           GSource *source = g_source_new (&wayland_source_funcs, sizeof (GSource)); | ||||
|  | ||||
|       g_hash_table_add (monitor->alarms, (gpointer) watch->xalarm); | ||||
|           g_source_set_callback (source, NULL, watch, NULL); | ||||
|           g_source_set_ready_time (source, monitor->last_event_time + timeout_msec * 1000); | ||||
|           g_source_attach (source, NULL); | ||||
|           g_source_unref (source); | ||||
|  | ||||
|       if (meta_idle_monitor_get_idletime (monitor) > (gint64)timeout_msec) | ||||
|         watch->idle_source_id = g_idle_add (fire_watch_idle, watch); | ||||
|           watch->timeout_source = source; | ||||
|         } | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       watch->xalarm = monitor->user_active_alarm; | ||||
|       if (timeout_msec != 0) | ||||
|         { | ||||
|           watch->xalarm = _xsync_alarm_set (monitor, XSyncPositiveTransition, timeout_msec, TRUE); | ||||
|  | ||||
|       set_alarm_enabled (monitor->display, monitor->user_active_alarm, TRUE); | ||||
|           g_hash_table_add (monitor->alarms, (gpointer) watch->xalarm); | ||||
|  | ||||
|           if (meta_idle_monitor_get_idletime (monitor) > (gint64)timeout_msec) | ||||
|             watch->idle_source_id = g_idle_add (fire_watch_idle, watch); | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           watch->xalarm = monitor->user_active_alarm; | ||||
|  | ||||
|           set_alarm_enabled (monitor->display, monitor->user_active_alarm, TRUE); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   g_hash_table_insert (monitor->watches, | ||||
| @@ -622,10 +670,69 @@ meta_idle_monitor_get_idletime (MetaIdleMonitor *monitor) | ||||
| { | ||||
|   XSyncValue value; | ||||
|  | ||||
|   if (!XSyncQueryCounter (monitor->display, monitor->counter, &value)) | ||||
|     return -1; | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       return (g_get_monotonic_time () - monitor->last_event_time) / 1000; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       if (!XSyncQueryCounter (monitor->display, monitor->counter, &value)) | ||||
|         return -1; | ||||
|  | ||||
|   return _xsyncvalue_to_int64 (value); | ||||
|       return _xsyncvalue_to_int64 (value); | ||||
|     } | ||||
| } | ||||
|  | ||||
| typedef struct { | ||||
|   MetaIdleMonitor *monitor; | ||||
|   GList *fired_watches; | ||||
| } CheckWaylandClosure; | ||||
|  | ||||
| static gboolean | ||||
| check_wayland_watch (gpointer key, | ||||
|                      gpointer value, | ||||
|                      gpointer user_data) | ||||
| { | ||||
|   MetaIdleMonitorWatch *watch = value; | ||||
|   CheckWaylandClosure *closure = user_data; | ||||
|   gboolean steal; | ||||
|  | ||||
|   if (watch->timeout_msec == 0) | ||||
|     { | ||||
|       closure->fired_watches = g_list_prepend (closure->fired_watches, watch); | ||||
|       steal = TRUE; | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       g_source_set_ready_time (watch->timeout_source, | ||||
|                                closure->monitor->last_event_time + | ||||
|                                watch->timeout_msec * 1000); | ||||
|       steal = FALSE; | ||||
|     } | ||||
|  | ||||
|   return steal; | ||||
| } | ||||
|  | ||||
| static void | ||||
| fire_wayland_watch (gpointer watch, | ||||
|                     gpointer data) | ||||
| { | ||||
|   fire_watch (watch); | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_idle_monitor_reset_idletime (MetaIdleMonitor *monitor) | ||||
| { | ||||
|   CheckWaylandClosure closure; | ||||
|  | ||||
|   monitor->last_event_time = g_get_monotonic_time (); | ||||
|  | ||||
|   closure.monitor = monitor; | ||||
|   closure.fired_watches = NULL; | ||||
|   g_hash_table_foreach_steal (monitor->watches, check_wayland_watch, &closure); | ||||
|  | ||||
|   g_list_foreach (closure.fired_watches, fire_wayland_watch, NULL); | ||||
|   g_list_free (closure.fired_watches); | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
|   | ||||
| @@ -99,8 +99,9 @@ static gboolean meta_monitor_config_assign_crtcs (MetaConfiguration  *config, | ||||
|                                                   GPtrArray          *crtcs, | ||||
|                                                   GPtrArray          *outputs); | ||||
|  | ||||
| static void     power_client_changed_cb (UpClient *client, | ||||
|                                          gpointer  user_data); | ||||
| static void     power_client_changed_cb (UpClient   *client, | ||||
|                                          GParamSpec *pspec, | ||||
|                                          gpointer    user_data); | ||||
|  | ||||
| static void | ||||
| free_output_key (MetaOutputKey *key) | ||||
| @@ -232,7 +233,7 @@ meta_monitor_config_init (MetaMonitorConfig *self) | ||||
|   self->up_client = up_client_new (); | ||||
|   self->lid_is_closed = up_client_get_lid_is_closed (self->up_client); | ||||
|  | ||||
|   g_signal_connect_object (self->up_client, "changed", | ||||
|   g_signal_connect_object (self->up_client, "notify::lid-is-closed", | ||||
|                            G_CALLBACK (power_client_changed_cb), self, 0); | ||||
| } | ||||
|  | ||||
| @@ -824,9 +825,6 @@ meta_monitor_config_get_stored (MetaMonitorConfig *self, | ||||
|   MetaConfiguration key; | ||||
|   MetaConfiguration *stored; | ||||
|  | ||||
|   if (n_outputs == 0) | ||||
|     return NULL; | ||||
|  | ||||
|   make_config_key (&key, outputs, n_outputs, -1); | ||||
|   stored = g_hash_table_lookup (self->configs, &key); | ||||
|  | ||||
| @@ -1234,12 +1232,6 @@ meta_monitor_config_make_default (MetaMonitorConfig  *self, | ||||
|   outputs = meta_monitor_manager_get_outputs (manager, &n_outputs); | ||||
|   meta_monitor_manager_get_screen_limits (manager, &max_width, &max_height); | ||||
|  | ||||
|   if (n_outputs == 0) | ||||
|     { | ||||
|       meta_verbose ("No output connected, not applying configuration\n"); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|   default_config = make_default_config (self, outputs, n_outputs, max_width, max_height); | ||||
|  | ||||
|   if (default_config != NULL) | ||||
| @@ -1344,8 +1336,9 @@ turn_off_laptop_display (MetaMonitorConfig  *self, | ||||
| } | ||||
|  | ||||
| static void | ||||
| power_client_changed_cb (UpClient *client, | ||||
|                          gpointer  user_data) | ||||
| power_client_changed_cb (UpClient   *client, | ||||
|                          GParamSpec *pspec, | ||||
|                          gpointer    user_data) | ||||
| { | ||||
|   MetaMonitorManager *manager = meta_monitor_manager_get (); | ||||
|   MetaMonitorConfig *self = user_data; | ||||
|   | ||||
							
								
								
									
										939
									
								
								src/core/monitor-kms.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										939
									
								
								src/core/monitor-kms.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,939 @@ | ||||
| /* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */ | ||||
|  | ||||
| /*  | ||||
|  * Copyright (C) 2013 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 the Free Software Foundation; either version 2 of the | ||||
|  * License, or (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, but | ||||
|  * WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
|  * General Public License for more details. | ||||
|  *  | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program; if not, write to the Free Software | ||||
|  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA | ||||
|  * 02111-1307, USA. | ||||
|  * | ||||
|  * Author: Giovanni Campagna <gcampagn@redhat.com> | ||||
|  */ | ||||
|  | ||||
| #include "config.h" | ||||
|  | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
| #include <clutter/clutter.h> | ||||
|  | ||||
| #include <errno.h> | ||||
| #include <sys/ioctl.h> | ||||
| #include <sys/mman.h> | ||||
| #include <unistd.h> | ||||
| #include <xf86drm.h> | ||||
| #include <xf86drmMode.h> | ||||
|  | ||||
| #include <meta/main.h> | ||||
| #include <meta/errors.h> | ||||
| #include "monitor-private.h" | ||||
| #include "edid.h" | ||||
|  | ||||
| #define ALL_WL_TRANSFORMS ((1 << (WL_OUTPUT_TRANSFORM_FLIPPED_270 + 1)) - 1) | ||||
|  | ||||
| typedef struct { | ||||
|   drmModeConnector *connector; | ||||
|  | ||||
|   unsigned n_encoders; | ||||
|   drmModeEncoderPtr *encoders; | ||||
|   drmModeEncoderPtr  current_encoder; | ||||
|  | ||||
|   /* bitmasks of encoder position in the resources array */ | ||||
|   uint32_t encoder_mask; | ||||
|   uint32_t enc_clone_mask; | ||||
|  | ||||
|   uint32_t dpms_prop_id; | ||||
|   uint32_t edid_blob_id; | ||||
| } MetaOutputKms; | ||||
|  | ||||
| struct _MetaMonitorManagerKms | ||||
| { | ||||
|   MetaMonitorManager parent_instance; | ||||
|  | ||||
|   int fd; | ||||
|  | ||||
|   drmModeConnector **connectors; | ||||
|   unsigned int       n_connectors; | ||||
|  | ||||
|   drmModeEncoder   **encoders; | ||||
|   unsigned int       n_encoders; | ||||
|  | ||||
|   drmModeEncoder    *current_encoder; | ||||
| }; | ||||
|  | ||||
| struct _MetaMonitorManagerKmsClass | ||||
| { | ||||
|   MetaMonitorManagerClass parent_class; | ||||
| }; | ||||
|  | ||||
| G_DEFINE_TYPE (MetaMonitorManagerKms, meta_monitor_manager_kms, META_TYPE_MONITOR_MANAGER); | ||||
|  | ||||
| static void | ||||
| free_resources (MetaMonitorManagerKms *manager_kms) | ||||
| { | ||||
|   unsigned i; | ||||
|  | ||||
|   for (i = 0; i < manager_kms->n_encoders; i++) | ||||
|     drmModeFreeEncoder (manager_kms->encoders[i]); | ||||
|   for (i = 0; i < manager_kms->n_connectors; i++) | ||||
|     drmModeFreeConnector (manager_kms->connectors[i]); | ||||
|  | ||||
|   g_free (manager_kms->encoders); | ||||
|   g_free (manager_kms->connectors); | ||||
| } | ||||
|  | ||||
| static int | ||||
| compare_outputs (const void *one, | ||||
|                  const void *two) | ||||
| { | ||||
|   const MetaOutput *o_one = one, *o_two = two; | ||||
|  | ||||
|   return strcmp (o_one->name, o_two->name); | ||||
| } | ||||
|  | ||||
| static char * | ||||
| make_output_name (drmModeConnector *connector) | ||||
| { | ||||
|   static const char * const connector_type_names[] = { | ||||
|     "unknown", "VGA", "DVII", "DVID", "DVID", "Composite", | ||||
|     "SVIDEO", "LVDS", "Component", "9PinDIN", "DisplayPort", | ||||
|     "HDMIA", "HDMIB", "TV", "eDP" | ||||
|   }; | ||||
|   const char *connector_type_name; | ||||
|  | ||||
|   if (connector->connector_type >= 0 && | ||||
|       connector->connector_type < G_N_ELEMENTS (connector_type_names)) | ||||
|     connector_type_name = connector_type_names[connector->connector_type]; | ||||
|   else | ||||
|     connector_type_name = "unknown"; | ||||
|  | ||||
|   return g_strdup_printf ("%s%d", connector_type_name, connector->connector_id); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_output_destroy_notify (MetaOutput *output) | ||||
| { | ||||
|   MetaOutputKms *output_kms; | ||||
|   unsigned i; | ||||
|  | ||||
|   output_kms = output->driver_private; | ||||
|  | ||||
|   for (i = 0; i < output_kms->n_encoders; i++) | ||||
|     drmModeFreeEncoder (output_kms->encoders[i]); | ||||
|   g_free (output_kms->encoders); | ||||
|  | ||||
|   g_slice_free (MetaOutputKms, output_kms); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_monitor_mode_destroy_notify (MetaMonitorMode *output) | ||||
| { | ||||
|   g_slice_free (drmModeModeInfo, output->driver_private); | ||||
| } | ||||
|  | ||||
| static gboolean | ||||
| drm_mode_equal (gconstpointer one, | ||||
|                 gconstpointer two) | ||||
| { | ||||
|   const drmModeModeInfo *m_one = one; | ||||
|   const drmModeModeInfo *m_two = two; | ||||
|  | ||||
|   return m_one->clock == m_two->clock && | ||||
|     m_one->hdisplay == m_two->hdisplay && | ||||
|     m_one->hsync_start == m_two->hsync_start && | ||||
|     m_one->hsync_end == m_two->hsync_end && | ||||
|     m_one->htotal == m_two->htotal && | ||||
|     m_one->hskew == m_two->hskew && | ||||
|     m_one->vdisplay == m_two->vdisplay && | ||||
|     m_one->vsync_start == m_two->vsync_start && | ||||
|     m_one->vsync_end == m_two->vsync_end && | ||||
|     m_one->vtotal == m_two->vtotal && | ||||
|     m_one->vscan == m_two->vscan && | ||||
|     m_one->vrefresh == m_two->vrefresh && | ||||
|     m_one->flags == m_two->flags && | ||||
|     m_one->type == m_two->type && | ||||
|     strncmp (m_one->name, m_two->name, DRM_DISPLAY_MODE_LEN) == 0; | ||||
| } | ||||
|  | ||||
| static guint | ||||
| drm_mode_hash (gconstpointer ptr) | ||||
| { | ||||
|   const drmModeModeInfo *mode = ptr; | ||||
|   guint hash = 0; | ||||
|  | ||||
|   /* We don't include the name in the hash because it's generally | ||||
|      derived from the other fields (hdisplay, vdisplay and flags) | ||||
|   */ | ||||
|  | ||||
|   hash ^= mode->clock; | ||||
|   hash ^= mode->hdisplay ^ mode->hsync_start ^ mode->hsync_end; | ||||
|   hash ^= mode->vdisplay ^ mode->vsync_start ^ mode->vsync_end; | ||||
|   hash ^= mode->vrefresh; | ||||
|   hash ^= mode->flags ^ mode->type; | ||||
|  | ||||
|   return hash; | ||||
| } | ||||
|  | ||||
| static void | ||||
| find_properties (MetaMonitorManagerKms *manager_kms, | ||||
|                  MetaOutputKms         *output_kms) | ||||
| { | ||||
|   drmModePropertyPtr prop; | ||||
|   int i; | ||||
|  | ||||
|   for (i = 0; i < output_kms->connector->count_props; i++) | ||||
|     { | ||||
|       prop = drmModeGetProperty (manager_kms->fd, output_kms->connector->props[i]); | ||||
|       if (!prop) | ||||
|         continue; | ||||
|  | ||||
|       if ((prop->flags & DRM_MODE_PROP_ENUM) && | ||||
|           strcmp(prop->name, "DPMS") == 0) | ||||
|         output_kms->dpms_prop_id = prop->prop_id; | ||||
|       else if ((prop->flags & DRM_MODE_PROP_BLOB) && | ||||
|                strcmp (prop->name, "EDID") == 0) | ||||
|         output_kms->edid_blob_id = output_kms->connector->prop_values[i]; | ||||
|  | ||||
|       drmModeFreeProperty(prop); | ||||
|     } | ||||
| } | ||||
|  | ||||
| static GBytes * | ||||
| read_output_edid (MetaMonitorManagerKms *manager_kms, | ||||
|                   MetaOutput            *output) | ||||
| { | ||||
|   MetaOutputKms *output_kms = output->driver_private; | ||||
|   drmModePropertyBlobPtr edid_blob = NULL; | ||||
|  | ||||
|   if (output_kms->edid_blob_id == 0) | ||||
|     return NULL; | ||||
|  | ||||
|   edid_blob = drmModeGetPropertyBlob (manager_kms->fd, output_kms->edid_blob_id); | ||||
|   if (!edid_blob) | ||||
|     { | ||||
|       meta_warning ("Failed to read EDID of output %s: %s\n", output->name, strerror(errno)); | ||||
|       return NULL; | ||||
|     } | ||||
|  | ||||
|   if (edid_blob->length > 0) | ||||
|     return g_bytes_new_with_free_func (edid_blob->data, edid_blob->length, | ||||
|                                        (GDestroyNotify)drmModeFreePropertyBlob, edid_blob); | ||||
|   else | ||||
|     { | ||||
|       drmModeFreePropertyBlob (edid_blob); | ||||
|       return NULL; | ||||
|     } | ||||
| } | ||||
|  | ||||
| static MetaMonitorMode * | ||||
| find_meta_mode (MetaMonitorManager    *manager, | ||||
|                 const drmModeModeInfo *drm_mode) | ||||
| { | ||||
|   unsigned k; | ||||
|  | ||||
|   for (k = 0; k < manager->n_modes; k++) | ||||
|     { | ||||
|       if (drm_mode_equal (drm_mode, manager->modes[k].driver_private)) | ||||
|         return &manager->modes[k]; | ||||
|     } | ||||
|  | ||||
|   g_assert_not_reached (); | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| static MetaOutput * | ||||
| find_output_by_id (MetaOutput *outputs, | ||||
|                    unsigned    n_outputs, | ||||
|                    glong       id) | ||||
| { | ||||
|   unsigned i; | ||||
|  | ||||
|   for (i = 0; i < n_outputs; i++) | ||||
|     if (outputs[i].output_id == id) | ||||
|       return &outputs[i]; | ||||
|  | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_monitor_manager_kms_read_current (MetaMonitorManager *manager) | ||||
| { | ||||
|   MetaMonitorManagerKms *manager_kms = META_MONITOR_MANAGER_KMS (manager); | ||||
|   drmModeRes *resources; | ||||
|   GHashTable *modes; | ||||
|   GHashTableIter iter; | ||||
|   drmModeModeInfo *mode; | ||||
|   unsigned int i, j, k; | ||||
|   unsigned int n_actual_outputs; | ||||
|   int width, height; | ||||
|   MetaOutput *old_outputs; | ||||
|   unsigned int n_old_outputs; | ||||
|  | ||||
|   resources = drmModeGetResources(manager_kms->fd); | ||||
|   modes = g_hash_table_new (drm_mode_hash, drm_mode_equal); | ||||
|  | ||||
|   manager->max_screen_width = resources->max_width; | ||||
|   manager->max_screen_height = resources->max_height; | ||||
|  | ||||
|   manager->power_save_mode = META_POWER_SAVE_ON; | ||||
|  | ||||
|   old_outputs = manager->outputs; | ||||
|   n_old_outputs = manager->n_outputs; | ||||
|  | ||||
|   /* Note: we must not free the public structures (output, crtc, monitor | ||||
|      mode and monitor info) here, they must be kept alive until the API | ||||
|      users are done with them after we emit monitors-changed, and thus | ||||
|      are freed by the platform-independent layer. */ | ||||
|   free_resources (manager_kms); | ||||
|  | ||||
|   manager_kms->n_connectors = resources->count_connectors; | ||||
|   manager_kms->connectors = g_new (drmModeConnector *, manager_kms->n_connectors); | ||||
|   for (i = 0; i < manager_kms->n_connectors; i++) | ||||
|     { | ||||
|       drmModeConnector *connector; | ||||
|  | ||||
|       connector = drmModeGetConnector (manager_kms->fd, resources->connectors[i]); | ||||
|       manager_kms->connectors[i] = connector; | ||||
|  | ||||
|       if (connector->connection == DRM_MODE_CONNECTED) | ||||
|         { | ||||
|           /* Collect all modes for this connector */ | ||||
|           for (j = 0; j < (unsigned)connector->count_modes; j++) | ||||
|             g_hash_table_add (modes, &connector->modes[j]); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   manager_kms->n_encoders = resources->count_encoders; | ||||
|   manager_kms->encoders = g_new (drmModeEncoder *, manager_kms->n_encoders); | ||||
|   for (i = 0; i < manager_kms->n_encoders; i++) | ||||
|     { | ||||
|       manager_kms->encoders[i] = drmModeGetEncoder (manager_kms->fd, | ||||
|                                                     resources->encoders[i]); | ||||
|     } | ||||
|  | ||||
|   manager->n_modes = g_hash_table_size (modes); | ||||
|   manager->modes = g_new0 (MetaMonitorMode, manager->n_modes); | ||||
|   g_hash_table_iter_init (&iter, modes); | ||||
|   i = 0; | ||||
|   while (g_hash_table_iter_next (&iter, NULL, (gpointer)&mode)) | ||||
|     { | ||||
|       MetaMonitorMode *meta_mode; | ||||
|  | ||||
|       meta_mode = &manager->modes[i]; | ||||
|  | ||||
|       meta_mode->mode_id = i; | ||||
|       meta_mode->name = g_strndup (mode->name, DRM_DISPLAY_MODE_LEN); | ||||
|       meta_mode->width = mode->hdisplay; | ||||
|       meta_mode->height = mode->vdisplay; | ||||
|       meta_mode->refresh_rate = (1000 * mode->clock / | ||||
|                                  ((float)mode->htotal * mode->vtotal)); | ||||
|  | ||||
|       meta_mode->driver_private = g_slice_dup (drmModeModeInfo, mode); | ||||
|       meta_mode->driver_notify = (GDestroyNotify)meta_monitor_mode_destroy_notify; | ||||
|  | ||||
|       i++; | ||||
|     } | ||||
|   g_hash_table_destroy (modes); | ||||
|  | ||||
|   manager->n_crtcs = resources->count_crtcs; | ||||
|   manager->crtcs = g_new0 (MetaCRTC, manager->n_crtcs); | ||||
|   width = 0; height = 0; | ||||
|   for (i = 0; i < (unsigned)resources->count_crtcs; i++) | ||||
|     { | ||||
|       drmModeCrtc *crtc; | ||||
|       MetaCRTC *meta_crtc; | ||||
|  | ||||
|       crtc = drmModeGetCrtc (manager_kms->fd, resources->crtcs[i]); | ||||
|  | ||||
|       meta_crtc = &manager->crtcs[i]; | ||||
|  | ||||
|       meta_crtc->crtc_id = crtc->crtc_id; | ||||
|       meta_crtc->rect.x = crtc->x; | ||||
|       meta_crtc->rect.y = crtc->y; | ||||
|       meta_crtc->rect.width = crtc->width; | ||||
|       meta_crtc->rect.height = crtc->height; | ||||
|       meta_crtc->is_dirty = FALSE; | ||||
|       meta_crtc->transform = WL_OUTPUT_TRANSFORM_NORMAL; | ||||
|       /* FIXME: implement! */ | ||||
|       meta_crtc->all_transforms = 1 << WL_OUTPUT_TRANSFORM_NORMAL; | ||||
|  | ||||
|       if (crtc->mode_valid) | ||||
|         { | ||||
|           for (j = 0; j < manager->n_modes; j++) | ||||
|             { | ||||
|               if (drm_mode_equal (&crtc->mode, manager->modes[j].driver_private)) | ||||
|                 { | ||||
|                   meta_crtc->current_mode = &manager->modes[j]; | ||||
|                   break; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|           width = MAX (width, meta_crtc->rect.x + meta_crtc->rect.width); | ||||
|           height = MAX (height, meta_crtc->rect.y + meta_crtc->rect.height); | ||||
|         } | ||||
|  | ||||
|       drmModeFreeCrtc (crtc); | ||||
|     } | ||||
|  | ||||
|   manager->screen_width = width; | ||||
|   manager->screen_height = height; | ||||
|  | ||||
|   manager->outputs = g_new0 (MetaOutput, manager_kms->n_connectors); | ||||
|   n_actual_outputs = 0; | ||||
|  | ||||
|   for (i = 0; i < manager_kms->n_connectors; i++) | ||||
|     { | ||||
|       MetaOutput *meta_output, *old_output; | ||||
|       MetaOutputKms *output_kms; | ||||
|       drmModeConnector *connector; | ||||
|       GArray *crtcs; | ||||
|       unsigned int crtc_mask; | ||||
|       GBytes *edid; | ||||
|  | ||||
|       connector = manager_kms->connectors[i]; | ||||
|       meta_output = &manager->outputs[n_actual_outputs]; | ||||
|  | ||||
|       if (connector->connection == DRM_MODE_CONNECTED) | ||||
| 	{ | ||||
|           meta_output->driver_private = output_kms = g_slice_new0 (MetaOutputKms); | ||||
|           meta_output->driver_notify = (GDestroyNotify)meta_output_destroy_notify; | ||||
|  | ||||
| 	  meta_output->output_id = connector->connector_id; | ||||
| 	  meta_output->name = make_output_name (connector); | ||||
| 	  meta_output->width_mm = connector->mmWidth; | ||||
| 	  meta_output->height_mm = connector->mmHeight; | ||||
|  | ||||
|           switch (connector->subpixel) | ||||
|             { | ||||
|             case DRM_MODE_SUBPIXEL_NONE: | ||||
|               meta_output->subpixel_order = COGL_SUBPIXEL_ORDER_NONE; | ||||
|               break; | ||||
|             case DRM_MODE_SUBPIXEL_HORIZONTAL_RGB: | ||||
|               meta_output->subpixel_order = COGL_SUBPIXEL_ORDER_HORIZONTAL_RGB; | ||||
|               break; | ||||
|             case DRM_MODE_SUBPIXEL_HORIZONTAL_BGR: | ||||
|               meta_output->subpixel_order = COGL_SUBPIXEL_ORDER_HORIZONTAL_BGR; | ||||
|               break; | ||||
|             case DRM_MODE_SUBPIXEL_VERTICAL_RGB: | ||||
|               meta_output->subpixel_order = COGL_SUBPIXEL_ORDER_VERTICAL_RGB; | ||||
|               break; | ||||
|             case DRM_MODE_SUBPIXEL_VERTICAL_BGR: | ||||
|               meta_output->subpixel_order = COGL_SUBPIXEL_ORDER_VERTICAL_BGR; | ||||
|               break; | ||||
|             case DRM_MODE_SUBPIXEL_UNKNOWN: | ||||
|             default: | ||||
|               meta_output->subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN; | ||||
|               break; | ||||
|             } | ||||
|  | ||||
| 	  meta_output->n_modes = connector->count_modes; | ||||
| 	  meta_output->modes = g_new0 (MetaMonitorMode *, meta_output->n_modes); | ||||
| 	  for (j = 0; j < meta_output->n_modes; j++) | ||||
|             meta_output->modes[j] = find_meta_mode (manager, &connector->modes[j]); | ||||
| 	  meta_output->preferred_mode = meta_output->modes[0]; | ||||
|  | ||||
|           output_kms->connector = connector; | ||||
|           output_kms->n_encoders = connector->count_encoders; | ||||
|           output_kms->encoders = g_new0 (drmModeEncoderPtr, output_kms->n_encoders); | ||||
|  | ||||
|           crtc_mask = ~(unsigned int)0; | ||||
| 	  for (j = 0; j < output_kms->n_encoders; j++) | ||||
| 	    { | ||||
|               output_kms->encoders[j] = drmModeGetEncoder (manager_kms->fd, connector->encoders[j]); | ||||
|  | ||||
|               /* We only list CRTCs as supported if they are supported by all encoders | ||||
|                  for this connectors. | ||||
|  | ||||
|                  This is what xf86-video-modesetting does (see drmmode_output_init()) | ||||
|               */ | ||||
|               crtc_mask &= output_kms->encoders[j]->possible_crtcs; | ||||
|  | ||||
|               if (output_kms->encoders[j]->encoder_id == connector->encoder_id) | ||||
|                 output_kms->current_encoder = output_kms->encoders[j]; | ||||
|             } | ||||
|  | ||||
|           crtcs = g_array_new (FALSE, FALSE, sizeof (MetaCRTC*)); | ||||
|  | ||||
|           for (j = 0; j < manager->n_crtcs; j++) | ||||
|             { | ||||
|               if (crtc_mask & (1 << j)) | ||||
|                 { | ||||
|                   MetaCRTC *crtc = &manager->crtcs[j]; | ||||
|                   g_array_append_val (crtcs, crtc); | ||||
| 		} | ||||
| 	    } | ||||
|  | ||||
| 	  meta_output->n_possible_crtcs = crtcs->len; | ||||
| 	  meta_output->possible_crtcs = (void*)g_array_free (crtcs, FALSE); | ||||
|  | ||||
|           if (output_kms->current_encoder && output_kms->current_encoder->crtc_id != 0) | ||||
|             { | ||||
|               for (j = 0; j < manager->n_crtcs; j++) | ||||
|                 { | ||||
|                   if (manager->crtcs[j].crtc_id == output_kms->current_encoder->crtc_id) | ||||
|                     { | ||||
|                       meta_output->crtc = &manager->crtcs[j]; | ||||
|                       break; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|           else | ||||
|             meta_output->crtc = NULL; | ||||
|  | ||||
|           old_output = find_output_by_id (old_outputs, n_old_outputs, | ||||
|                                           meta_output->output_id); | ||||
|           if (old_output) | ||||
|             { | ||||
|               meta_output->is_primary = old_output->is_primary; | ||||
|               meta_output->is_presentation = old_output->is_presentation; | ||||
|             } | ||||
|           else | ||||
|             { | ||||
|               meta_output->is_primary = FALSE; | ||||
|               meta_output->is_presentation = FALSE; | ||||
|             } | ||||
|  | ||||
|           find_properties (manager_kms, output_kms); | ||||
|  | ||||
|           edid = read_output_edid (manager_kms, meta_output); | ||||
|           if (edid) | ||||
|             { | ||||
|               MonitorInfo *parsed_edid; | ||||
|               gsize len; | ||||
|  | ||||
|               parsed_edid = decode_edid (g_bytes_get_data (edid, &len)); | ||||
|               if (parsed_edid) | ||||
|                 { | ||||
|                   meta_output->vendor = g_strndup (parsed_edid->manufacturer_code, 4); | ||||
|                   meta_output->product = g_strndup (parsed_edid->dsc_product_name, 14); | ||||
|                   meta_output->serial = g_strndup (parsed_edid->dsc_serial_number, 14); | ||||
|  | ||||
|                   g_free (parsed_edid); | ||||
|                 } | ||||
|  | ||||
|               g_bytes_unref (edid); | ||||
|             } | ||||
|           if (!meta_output->vendor) | ||||
|             { | ||||
|               meta_output->vendor = g_strdup ("unknown"); | ||||
|               meta_output->product = g_strdup ("unknown"); | ||||
|               meta_output->serial = g_strdup ("unknown"); | ||||
|             } | ||||
|  | ||||
|           /* FIXME: backlight is a very driver specific thing unfortunately, | ||||
|              every DDX does its own thing, and the dumb KMS API does not include it. | ||||
|  | ||||
|              For example, xf86-video-intel has a list of paths to probe in /sys/class/backlight | ||||
|              (one for each major HW maker, and then some). | ||||
|              We can't do the same because we're not root. | ||||
|              It might be best to leave backlight out of the story and rely on the setuid | ||||
|              helper in gnome-settings-daemon. | ||||
|           */ | ||||
| 	  meta_output->backlight_min = 0; | ||||
|           meta_output->backlight_max = 0; | ||||
|           meta_output->backlight = -1; | ||||
|  | ||||
| 	  n_actual_outputs++; | ||||
| 	} | ||||
|     } | ||||
|  | ||||
|   manager->n_outputs = n_actual_outputs; | ||||
|   manager->outputs = g_renew (MetaOutput, manager->outputs, manager->n_outputs); | ||||
|  | ||||
|   /* Sort the outputs for easier handling in MetaMonitorConfig */ | ||||
|   qsort (manager->outputs, manager->n_outputs, sizeof (MetaOutput), compare_outputs); | ||||
|  | ||||
|   /* Now fix the clones. | ||||
|      Code mostly inspired by xf86-video-modesetting. */ | ||||
|  | ||||
|   /* XXX: intel hardware doesn't usually have clones, but I only have laptops with | ||||
|      intel cards, so this code was never tested! */ | ||||
|   for (i = 0; i < manager->n_outputs; i++) | ||||
|     { | ||||
|       MetaOutput *meta_output; | ||||
|       MetaOutputKms *output_kms; | ||||
|  | ||||
|       meta_output = &manager->outputs[i]; | ||||
|       output_kms = meta_output->driver_private; | ||||
|  | ||||
|       output_kms->enc_clone_mask = 0xff; | ||||
|       output_kms->encoder_mask = 0; | ||||
|  | ||||
|       for (j = 0; j < output_kms->n_encoders; j++) | ||||
| 	{ | ||||
| 	  for (k = 0; k < manager_kms->n_encoders; k++) | ||||
| 	    { | ||||
| 	      if (output_kms->encoders[j]->encoder_id == manager_kms->encoders[k]->encoder_id) | ||||
| 		{ | ||||
|                   output_kms->encoder_mask |= (1 << k); | ||||
| 		  break; | ||||
| 		} | ||||
| 	    } | ||||
|  | ||||
|           output_kms->enc_clone_mask &= output_kms->encoders[j]->possible_clones; | ||||
| 	} | ||||
|     } | ||||
|  | ||||
|   for (i = 0; i < manager->n_outputs; i++) | ||||
|     { | ||||
|       MetaOutput *meta_output; | ||||
|       MetaOutputKms *output_kms; | ||||
|  | ||||
|       meta_output = &manager->outputs[i]; | ||||
|       output_kms = meta_output->driver_private; | ||||
|  | ||||
|       if (output_kms->enc_clone_mask == 0) | ||||
|         continue; | ||||
|  | ||||
|       for (j = 0; j < manager->n_outputs; j++) | ||||
|         { | ||||
|           MetaOutput *meta_clone; | ||||
|           MetaOutputKms *clone_kms; | ||||
|  | ||||
|           meta_clone = &manager->outputs[i]; | ||||
|           clone_kms = meta_clone->driver_private; | ||||
|  | ||||
|           if (meta_clone == meta_output) | ||||
|             continue; | ||||
|  | ||||
|           if (clone_kms->encoder_mask == 0) | ||||
|             continue; | ||||
|  | ||||
|           if (clone_kms->encoder_mask == output_kms->enc_clone_mask) | ||||
|             { | ||||
|               meta_output->n_possible_clones++; | ||||
|               meta_output->possible_clones = g_renew (MetaOutput *, | ||||
|                                                       meta_output->possible_clones, | ||||
|                                                       meta_output->n_possible_clones); | ||||
|               meta_output->possible_clones[meta_output->n_possible_clones - 1] = meta_clone; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   drmModeFreeResources (resources); | ||||
| } | ||||
|  | ||||
| static GBytes * | ||||
| meta_monitor_manager_kms_read_edid (MetaMonitorManager *manager, | ||||
|                                     MetaOutput         *output) | ||||
| { | ||||
|   MetaMonitorManagerKms *manager_kms = META_MONITOR_MANAGER_KMS (manager); | ||||
|  | ||||
|   return read_output_edid (manager_kms, output); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_monitor_manager_kms_set_power_save_mode (MetaMonitorManager *manager, | ||||
|                                               MetaPowerSave       mode) | ||||
| { | ||||
|   MetaMonitorManagerKms *manager_kms = META_MONITOR_MANAGER_KMS (manager); | ||||
|   uint64_t state; | ||||
|   unsigned i; | ||||
|  | ||||
|   switch (mode) { | ||||
|   case META_POWER_SAVE_ON: | ||||
|     state = DRM_MODE_DPMS_ON; | ||||
|     break; | ||||
|   case META_POWER_SAVE_STANDBY: | ||||
|     state = DRM_MODE_DPMS_STANDBY; | ||||
|     break; | ||||
|   case META_POWER_SAVE_SUSPEND: | ||||
|     state = DRM_MODE_DPMS_SUSPEND; | ||||
|     break; | ||||
|   case META_POWER_SAVE_OFF: | ||||
|     state = DRM_MODE_DPMS_SUSPEND; | ||||
|     break; | ||||
|   default: | ||||
|     return; | ||||
|   } | ||||
|  | ||||
|   for (i = 0; i < manager->n_outputs; i++) | ||||
|     { | ||||
|       MetaOutput *meta_output; | ||||
|       MetaOutputKms *output_kms; | ||||
|  | ||||
|       meta_output = &manager->outputs[i]; | ||||
|       output_kms = meta_output->driver_private; | ||||
|  | ||||
|       if (output_kms->dpms_prop_id != 0) | ||||
|         { | ||||
|           int ok = drmModeConnectorSetProperty(manager_kms->fd, meta_output->output_id, | ||||
|                                                output_kms->dpms_prop_id, state); | ||||
|  | ||||
|           if (ok < 0) | ||||
|             meta_warning ("Failed to set power save mode for output %s: %s\n", | ||||
|                           meta_output->name, strerror (errno)); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| static void | ||||
| crtc_free (CoglKmsCrtc *crtc) | ||||
| { | ||||
|   g_free (crtc->connectors); | ||||
|   g_slice_free (CoglKmsCrtc, crtc); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_monitor_manager_kms_apply_configuration (MetaMonitorManager *manager, | ||||
|                                               MetaCRTCInfo       **crtcs, | ||||
|                                               unsigned int         n_crtcs, | ||||
|                                               MetaOutputInfo     **outputs, | ||||
|                                               unsigned int         n_outputs) | ||||
| { | ||||
|   ClutterBackend *backend; | ||||
|   CoglContext *cogl_context; | ||||
|   CoglDisplay *cogl_display; | ||||
|   unsigned i; | ||||
|   GPtrArray *cogl_crtcs; | ||||
|   int screen_width, screen_height; | ||||
|   gboolean ok; | ||||
|   GError *error; | ||||
|  | ||||
|   cogl_crtcs = g_ptr_array_new_full (manager->n_crtcs, (GDestroyNotify)crtc_free); | ||||
|   screen_width = 0; screen_height = 0; | ||||
|   for (i = 0; i < n_crtcs; i++) | ||||
|     { | ||||
|       MetaCRTCInfo *crtc_info = crtcs[i]; | ||||
|       MetaCRTC *crtc = crtc_info->crtc; | ||||
|       CoglKmsCrtc *cogl_crtc; | ||||
|  | ||||
|       crtc->is_dirty = TRUE; | ||||
|  | ||||
|       cogl_crtc = g_slice_new0 (CoglKmsCrtc); | ||||
|       g_ptr_array_add (cogl_crtcs, cogl_crtc); | ||||
|  | ||||
|       if (crtc_info->mode == NULL) | ||||
|         { | ||||
|           cogl_crtc->id = crtc->crtc_id; | ||||
|           cogl_crtc->x = 0; | ||||
|           cogl_crtc->y = 0; | ||||
|           cogl_crtc->count = 0; | ||||
|           memset (&cogl_crtc->mode, 0, sizeof (drmModeModeInfo)); | ||||
|           cogl_crtc->connectors = NULL; | ||||
|           cogl_crtc->count = 0; | ||||
|  | ||||
|           crtc->rect.x = 0; | ||||
|           crtc->rect.y = 0; | ||||
|           crtc->rect.width = 0; | ||||
|           crtc->rect.height = 0; | ||||
|           crtc->current_mode = NULL; | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           MetaMonitorMode *mode; | ||||
|           uint32_t *connectors; | ||||
|           unsigned int j, n_connectors; | ||||
|           int width, height; | ||||
|  | ||||
|           mode = crtc_info->mode; | ||||
|  | ||||
|           cogl_crtc->id = crtc->crtc_id; | ||||
|           cogl_crtc->x = crtc_info->x; | ||||
|           cogl_crtc->y = crtc_info->y; | ||||
|           cogl_crtc->count = n_connectors = crtc_info->outputs->len; | ||||
|           cogl_crtc->connectors = connectors = g_new (uint32_t, n_connectors); | ||||
|  | ||||
|           for (j = 0; j < n_connectors; j++) | ||||
|             { | ||||
|               MetaOutput *output = g_ptr_array_index (crtc_info->outputs, j); | ||||
|  | ||||
|               connectors[j] = output->output_id; | ||||
|  | ||||
|               output->is_dirty = TRUE; | ||||
|               output->crtc = crtc; | ||||
|             } | ||||
|  | ||||
|           memcpy (&cogl_crtc->mode, crtc_info->mode->driver_private, | ||||
|                   sizeof (drmModeModeInfo)); | ||||
|  | ||||
|           if (meta_monitor_transform_is_rotated (crtc_info->transform)) | ||||
|             { | ||||
|               width = mode->height; | ||||
|               height = mode->width; | ||||
|             } | ||||
|           else | ||||
|             { | ||||
|               width = mode->width; | ||||
|               height = mode->height; | ||||
|             } | ||||
|  | ||||
|           screen_width = MAX (screen_width, crtc_info->x + width); | ||||
|           screen_height = MAX (screen_height, crtc_info->y + height); | ||||
|  | ||||
|           crtc->rect.x = crtc_info->x; | ||||
|           crtc->rect.y = crtc_info->y; | ||||
|           crtc->rect.width = width; | ||||
|           crtc->rect.height = height; | ||||
|           crtc->current_mode = mode; | ||||
|           crtc->transform = crtc_info->transform; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   /* Disable CRTCs not mentioned in the list (they have is_dirty == FALSE, | ||||
|      because they weren't seen in the first loop) */ | ||||
|   for (i = 0; i < manager->n_crtcs; i++) | ||||
|     { | ||||
|       MetaCRTC *crtc = &manager->crtcs[i]; | ||||
|       CoglKmsCrtc *cogl_crtc; | ||||
|  | ||||
|       crtc->logical_monitor = NULL; | ||||
|  | ||||
|       if (crtc->is_dirty) | ||||
|         { | ||||
|           crtc->is_dirty = FALSE; | ||||
|           continue; | ||||
|         } | ||||
|  | ||||
|       cogl_crtc = g_slice_new0 (CoglKmsCrtc); | ||||
|       g_ptr_array_add (cogl_crtcs, cogl_crtc); | ||||
|  | ||||
|       cogl_crtc->id = crtc->crtc_id; | ||||
|       cogl_crtc->x = 0; | ||||
|       cogl_crtc->y = 0; | ||||
|       cogl_crtc->count = 0; | ||||
|       memset (&cogl_crtc->mode, 0, sizeof (drmModeModeInfo)); | ||||
|       cogl_crtc->connectors = NULL; | ||||
|       cogl_crtc->count = 0; | ||||
|  | ||||
|       crtc->rect.x = 0; | ||||
|       crtc->rect.y = 0; | ||||
|       crtc->rect.width = 0; | ||||
|       crtc->rect.height = 0; | ||||
|       crtc->current_mode = NULL; | ||||
|     } | ||||
|  | ||||
|   backend = clutter_get_default_backend (); | ||||
|   cogl_context = clutter_backend_get_cogl_context (backend); | ||||
|   cogl_display = cogl_context_get_display (cogl_context); | ||||
|  | ||||
|   error = NULL; | ||||
|   ok = cogl_kms_display_set_layout (cogl_display, screen_width, screen_height, | ||||
|                                     (CoglKmsCrtc**)cogl_crtcs->pdata, cogl_crtcs->len, &error); | ||||
|   g_ptr_array_unref (cogl_crtcs); | ||||
|  | ||||
|   if (!ok) | ||||
|     { | ||||
|       meta_warning ("Applying display configuration failed: %s\n", error->message); | ||||
|       g_error_free (error); | ||||
|       return; | ||||
|     } | ||||
|  | ||||
|   for (i = 0; i < n_outputs; i++) | ||||
|     { | ||||
|       MetaOutputInfo *output_info = outputs[i]; | ||||
|       MetaOutput *output = output_info->output; | ||||
|  | ||||
|       output->is_primary = output_info->is_primary; | ||||
|       output->is_presentation = output_info->is_presentation; | ||||
|     } | ||||
|  | ||||
|   /* Disable outputs not mentioned in the list */ | ||||
|   for (i = 0; i < manager->n_outputs; i++) | ||||
|     { | ||||
|       MetaOutput *output = &manager->outputs[i]; | ||||
|  | ||||
|       if (output->is_dirty) | ||||
|         { | ||||
|           output->is_dirty = FALSE; | ||||
|           continue; | ||||
|         } | ||||
|  | ||||
|       output->crtc = NULL; | ||||
|       output->is_primary = FALSE; | ||||
|     } | ||||
|  | ||||
|   manager->screen_width = screen_width; | ||||
|   manager->screen_height = screen_height; | ||||
|  | ||||
|   meta_monitor_manager_rebuild_derived (manager); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_monitor_manager_kms_get_crtc_gamma (MetaMonitorManager  *manager, | ||||
|                                          MetaCRTC            *crtc, | ||||
|                                          gsize               *size, | ||||
|                                          unsigned short     **red, | ||||
|                                          unsigned short     **green, | ||||
|                                          unsigned short     **blue) | ||||
| { | ||||
|   MetaMonitorManagerKms *manager_kms = META_MONITOR_MANAGER_KMS (manager); | ||||
|   drmModeCrtc *kms_crtc; | ||||
|  | ||||
|   kms_crtc = drmModeGetCrtc (manager_kms->fd, crtc->crtc_id); | ||||
|  | ||||
|   *size = kms_crtc->gamma_size; | ||||
|   *red = g_new (unsigned short, *size); | ||||
|   *green = g_new (unsigned short, *size); | ||||
|   *blue = g_new (unsigned short, *size); | ||||
|  | ||||
|   drmModeCrtcGetGamma (manager_kms->fd, crtc->crtc_id, *size, *red, *green, *blue); | ||||
|  | ||||
|   drmModeFreeCrtc (kms_crtc); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_monitor_manager_kms_set_crtc_gamma (MetaMonitorManager *manager, | ||||
|                                          MetaCRTC           *crtc, | ||||
|                                          gsize               size, | ||||
|                                          unsigned short     *red, | ||||
|                                          unsigned short     *green, | ||||
|                                          unsigned short     *blue) | ||||
| { | ||||
|   MetaMonitorManagerKms *manager_kms = META_MONITOR_MANAGER_KMS (manager); | ||||
|  | ||||
|   drmModeCrtcSetGamma (manager_kms->fd, crtc->crtc_id, size, red, green, blue); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_monitor_manager_kms_init (MetaMonitorManagerKms *manager_kms) | ||||
| { | ||||
|   ClutterBackend *backend; | ||||
|   CoglContext *cogl_context; | ||||
|   CoglDisplay *cogl_display; | ||||
|   CoglRenderer *cogl_renderer; | ||||
|  | ||||
|   backend = clutter_get_default_backend (); | ||||
|   cogl_context = clutter_backend_get_cogl_context (backend); | ||||
|   cogl_display = cogl_context_get_display (cogl_context); | ||||
|   cogl_renderer = cogl_display_get_renderer (cogl_display); | ||||
|  | ||||
|   manager_kms->fd = cogl_kms_renderer_get_kms_fd (cogl_renderer); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_monitor_manager_kms_finalize (GObject *object) | ||||
| { | ||||
|   MetaMonitorManagerKms *manager_kms = META_MONITOR_MANAGER_KMS (object); | ||||
|  | ||||
|   free_resources (manager_kms); | ||||
|  | ||||
|   G_OBJECT_CLASS (meta_monitor_manager_kms_parent_class)->finalize (object); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_monitor_manager_kms_class_init (MetaMonitorManagerKmsClass *klass) | ||||
| { | ||||
|   MetaMonitorManagerClass *manager_class = META_MONITOR_MANAGER_CLASS (klass); | ||||
|   GObjectClass *object_class = G_OBJECT_CLASS (klass); | ||||
|  | ||||
|   object_class->finalize = meta_monitor_manager_kms_finalize; | ||||
|  | ||||
|   manager_class->read_current = meta_monitor_manager_kms_read_current; | ||||
|   manager_class->read_edid = meta_monitor_manager_kms_read_edid; | ||||
|   manager_class->apply_configuration = meta_monitor_manager_kms_apply_configuration; | ||||
|   manager_class->set_power_save_mode = meta_monitor_manager_kms_set_power_save_mode; | ||||
|   manager_class->get_crtc_gamma = meta_monitor_manager_kms_get_crtc_gamma; | ||||
|   manager_class->set_crtc_gamma = meta_monitor_manager_kms_set_crtc_gamma; | ||||
| } | ||||
|  | ||||
| @@ -116,6 +116,9 @@ struct _MetaOutput | ||||
|   */ | ||||
|   gboolean is_primary; | ||||
|   gboolean is_presentation; | ||||
|  | ||||
|   gpointer driver_private; | ||||
|   GDestroyNotify driver_notify; | ||||
| }; | ||||
|  | ||||
| struct _MetaCRTC | ||||
| @@ -133,16 +136,23 @@ struct _MetaCRTC | ||||
|  | ||||
|   /* Used when changing configuration */ | ||||
|   gboolean is_dirty; | ||||
|  | ||||
|   /* Updated by MetaCursorTracker */ | ||||
|   gboolean has_hw_cursor; | ||||
| }; | ||||
|  | ||||
| struct _MetaMonitorMode | ||||
| { | ||||
|   /* The low-level ID of this mode, used to apply back configuration */ | ||||
|   glong mode_id; | ||||
|   char *name; | ||||
|  | ||||
|   int width; | ||||
|   int height; | ||||
|   float refresh_rate; | ||||
|  | ||||
|   gpointer driver_private; | ||||
|   GDestroyNotify driver_notify; | ||||
| }; | ||||
|  | ||||
| /** | ||||
| @@ -351,6 +361,18 @@ typedef struct _MetaMonitorManagerXrandr         MetaMonitorManagerXrandr; | ||||
|  | ||||
| GType meta_monitor_manager_xrandr_get_type (void); | ||||
|  | ||||
| #define META_TYPE_MONITOR_MANAGER_KMS            (meta_monitor_manager_kms_get_type ()) | ||||
| #define META_MONITOR_MANAGER_KMS(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_MONITOR_MANAGER_KMS, MetaMonitorManagerKms)) | ||||
| #define META_MONITOR_MANAGER_KMS_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass),  META_TYPE_MONITOR_MANAGER_KMS, MetaMonitorManagerKmsClass)) | ||||
| #define META_IS_MONITOR_MANAGER_KMS(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_MONITOR_MANAGER_KMS)) | ||||
| #define META_IS_MONITOR_MANAGER_KMS_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass),  META_TYPE_MONITOR_MANAGER_KMS)) | ||||
| #define META_MONITOR_MANAGER_KMS_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj),  META_TYPE_MONITOR_MANAGER_KMS, MetaMonitorManagerKmsClass)) | ||||
|  | ||||
| typedef struct _MetaMonitorManagerKmsClass    MetaMonitorManagerKmsClass; | ||||
| typedef struct _MetaMonitorManagerKms         MetaMonitorManagerKms; | ||||
|  | ||||
| GType meta_monitor_manager_kms_get_type (void); | ||||
|  | ||||
| #define META_TYPE_MONITOR_CONFIG            (meta_monitor_config_get_type ()) | ||||
| #define META_MONITOR_CONFIG(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_MONITOR_CONFIG, MetaMonitorConfig)) | ||||
| #define META_MONITOR_CONFIG_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass),  META_TYPE_MONITOR_CONFIG, MetaMonitorConfigClass)) | ||||
| @@ -383,6 +405,8 @@ void               meta_output_info_free (MetaOutputInfo *info); | ||||
|  | ||||
| void               meta_monitor_manager_free_output_array (MetaOutput *old_outputs, | ||||
|                                                            int         n_old_outputs); | ||||
| void               meta_monitor_manager_free_mode_array (MetaMonitorMode *old_modes, | ||||
|                                                          int              n_old_modes); | ||||
|  | ||||
| /* Returns true if transform causes width and height to be inverted | ||||
|    This is true for the odd transforms in the enum */ | ||||
|   | ||||
| @@ -651,13 +651,11 @@ output_set_presentation_xrandr (MetaMonitorManagerXrandr *manager_xrandr, | ||||
|   MetaDisplay *display = meta_get_display (); | ||||
|   int value = presentation; | ||||
|  | ||||
|   meta_error_trap_push (display); | ||||
|   XRRChangeOutputProperty (manager_xrandr->xdisplay, | ||||
|                            (XID)output->output_id, | ||||
|                            display->atom__MUTTER_PRESENTATION_OUTPUT, | ||||
|                            XA_CARDINAL, 32, PropModeReplace, | ||||
|                            (unsigned char*) &value, 1); | ||||
|   meta_error_trap_pop (display); | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -979,7 +977,7 @@ meta_monitor_manager_xrandr_handle_xevent (MetaMonitorManager *manager, | ||||
|   MetaOutput *old_outputs; | ||||
|   MetaCRTC *old_crtcs; | ||||
|   MetaMonitorMode *old_modes; | ||||
|   int n_old_outputs; | ||||
|   unsigned int n_old_outputs, n_old_modes; | ||||
|  | ||||
|   if ((event->type - manager_xrandr->rr_event_base) != RRScreenChangeNotify) | ||||
|     return FALSE; | ||||
| @@ -990,6 +988,7 @@ meta_monitor_manager_xrandr_handle_xevent (MetaMonitorManager *manager, | ||||
|   old_outputs = manager->outputs; | ||||
|   n_old_outputs = manager->n_outputs; | ||||
|   old_modes = manager->modes; | ||||
|   n_old_modes = manager->n_modes; | ||||
|   old_crtcs = manager->crtcs; | ||||
|  | ||||
|   manager->serial++; | ||||
| @@ -1024,7 +1023,7 @@ meta_monitor_manager_xrandr_handle_xevent (MetaMonitorManager *manager, | ||||
|     } | ||||
|  | ||||
|   meta_monitor_manager_free_output_array (old_outputs, n_old_outputs); | ||||
|   g_free (old_modes); | ||||
|   meta_monitor_manager_free_mode_array (old_modes, n_old_modes); | ||||
|   g_free (old_crtcs); | ||||
|  | ||||
|   return TRUE; | ||||
|   | ||||
| @@ -33,9 +33,10 @@ | ||||
| #include <clutter/clutter.h> | ||||
|  | ||||
| #include <meta/main.h> | ||||
| #include <meta/util.h> | ||||
| #include "util-private.h" | ||||
| #include <meta/errors.h> | ||||
| #include "monitor-private.h" | ||||
| #include "meta-wayland-private.h" | ||||
|  | ||||
| #include "meta-dbus-xrandr.h" | ||||
|  | ||||
| @@ -64,59 +65,23 @@ static void initialize_dbus_interface (MetaMonitorManager *manager); | ||||
| static void | ||||
| read_current_dummy (MetaMonitorManager *manager) | ||||
| { | ||||
|   /* The dummy monitor config has: | ||||
|      - one enabled output, LVDS, primary, at 0x0 and 1024x768 | ||||
|      - one free CRTC | ||||
|      - two disabled outputs | ||||
|      - three modes, 1024x768, 800x600 and 640x480 | ||||
|      - no clones are possible (use different CRTCs) | ||||
|  | ||||
|      Low-level IDs should be assigned sequentially, to | ||||
|      mimick what XRandR and KMS do | ||||
|   */ | ||||
|  | ||||
|   manager->max_screen_width = 65535; | ||||
|   manager->max_screen_height = 65535; | ||||
|   manager->screen_width = 1024; | ||||
|   manager->screen_height = 768; | ||||
|  | ||||
|   manager->modes = g_new0 (MetaMonitorMode, 6); | ||||
|   manager->n_modes = 6; | ||||
|   manager->modes = g_new0 (MetaMonitorMode, 1); | ||||
|   manager->n_modes = 1; | ||||
|  | ||||
|   manager->modes[0].mode_id = 1; | ||||
|   manager->modes[0].mode_id = 0; | ||||
|   manager->modes[0].width = 1024; | ||||
|   manager->modes[0].height = 768; | ||||
|   manager->modes[0].refresh_rate = 60.0; | ||||
|  | ||||
|   manager->modes[1].mode_id = 2; | ||||
|   manager->modes[1].width = 800; | ||||
|   manager->modes[1].height = 600; | ||||
|   manager->modes[1].refresh_rate = 60.0; | ||||
|   manager->crtcs = g_new0 (MetaCRTC, 1); | ||||
|   manager->n_crtcs = 1; | ||||
|  | ||||
|   manager->modes[2].mode_id = 3; | ||||
|   manager->modes[2].width = 640; | ||||
|   manager->modes[2].height = 480; | ||||
|   manager->modes[2].refresh_rate = 60.0; | ||||
|  | ||||
|   manager->modes[3].mode_id = 4; | ||||
|   manager->modes[3].width = 1920; | ||||
|   manager->modes[3].height = 1080; | ||||
|   manager->modes[3].refresh_rate = 60.0; | ||||
|  | ||||
|   manager->modes[4].mode_id = 5; | ||||
|   manager->modes[4].width = 1920; | ||||
|   manager->modes[4].height = 1080; | ||||
|   manager->modes[4].refresh_rate = 55.0; | ||||
|  | ||||
|   manager->modes[5].mode_id = 6; | ||||
|   manager->modes[5].width = 1600; | ||||
|   manager->modes[5].height = 900; | ||||
|   manager->modes[5].refresh_rate = 60.0; | ||||
|  | ||||
|   manager->crtcs = g_new0 (MetaCRTC, 3); | ||||
|   manager->n_crtcs = 3; | ||||
|  | ||||
|   manager->crtcs[0].crtc_id = 4; | ||||
|   manager->crtcs[0].crtc_id = 1; | ||||
|   manager->crtcs[0].rect.x = 0; | ||||
|   manager->crtcs[0].rect.y = 0; | ||||
|   manager->crtcs[0].rect.width = manager->modes[0].width; | ||||
| @@ -127,111 +92,30 @@ read_current_dummy (MetaMonitorManager *manager) | ||||
|   manager->crtcs[0].is_dirty = FALSE; | ||||
|   manager->crtcs[0].logical_monitor = NULL; | ||||
|  | ||||
|   manager->crtcs[1].crtc_id = 5; | ||||
|   manager->crtcs[1].rect.x = 0; | ||||
|   manager->crtcs[1].rect.y = 0; | ||||
|   manager->crtcs[1].rect.width = 0; | ||||
|   manager->crtcs[1].rect.height = 0; | ||||
|   manager->crtcs[1].current_mode = NULL; | ||||
|   manager->crtcs[1].transform = WL_OUTPUT_TRANSFORM_NORMAL; | ||||
|   manager->crtcs[1].all_transforms = ALL_WL_TRANSFORMS; | ||||
|   manager->crtcs[1].is_dirty = FALSE; | ||||
|   manager->crtcs[1].logical_monitor = NULL; | ||||
|   manager->outputs = g_new0 (MetaOutput, 1); | ||||
|   manager->n_outputs = 1; | ||||
|  | ||||
|   manager->crtcs[2].crtc_id = 5; | ||||
|   manager->crtcs[2].rect.x = 0; | ||||
|   manager->crtcs[2].rect.y = 0; | ||||
|   manager->crtcs[2].rect.width = 0; | ||||
|   manager->crtcs[2].rect.height = 0; | ||||
|   manager->crtcs[2].current_mode = NULL; | ||||
|   manager->crtcs[2].transform = WL_OUTPUT_TRANSFORM_NORMAL; | ||||
|   manager->crtcs[2].all_transforms = ALL_WL_TRANSFORMS; | ||||
|   manager->crtcs[2].is_dirty = FALSE; | ||||
|   manager->crtcs[2].logical_monitor = NULL; | ||||
|  | ||||
|   manager->outputs = g_new0 (MetaOutput, 3); | ||||
|   manager->n_outputs = 3; | ||||
|  | ||||
|   manager->outputs[0].crtc = NULL; | ||||
|   manager->outputs[0].output_id = 6; | ||||
|   manager->outputs[0].name = g_strdup ("HDMI"); | ||||
|   manager->outputs[0].crtc = &manager->crtcs[0]; | ||||
|   manager->outputs[0].output_id = 1; | ||||
|   manager->outputs[0].name = g_strdup ("LVDS"); | ||||
|   manager->outputs[0].vendor = g_strdup ("MetaProducts Inc."); | ||||
|   manager->outputs[0].product = g_strdup ("unknown"); | ||||
|   manager->outputs[0].serial = g_strdup ("0xC0F01A"); | ||||
|   manager->outputs[0].width_mm = 510; | ||||
|   manager->outputs[0].height_mm = 287; | ||||
|   manager->outputs[0].serial = g_strdup ("0xC0FFEE"); | ||||
|   manager->outputs[0].width_mm = 222; | ||||
|   manager->outputs[0].height_mm = 125; | ||||
|   manager->outputs[0].subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN; | ||||
|   manager->outputs[0].preferred_mode = &manager->modes[3]; | ||||
|   manager->outputs[0].n_modes = 5; | ||||
|   manager->outputs[0].modes = g_new0 (MetaMonitorMode *, 5); | ||||
|   manager->outputs[0].preferred_mode = &manager->modes[0]; | ||||
|   manager->outputs[0].n_modes = 1; | ||||
|   manager->outputs[0].modes = g_new0 (MetaMonitorMode *, 1); | ||||
|   manager->outputs[0].modes[0] = &manager->modes[0]; | ||||
|   manager->outputs[0].modes[1] = &manager->modes[1]; | ||||
|   manager->outputs[0].modes[2] = &manager->modes[2]; | ||||
|   manager->outputs[0].modes[3] = &manager->modes[3]; | ||||
|   manager->outputs[0].modes[4] = &manager->modes[4]; | ||||
|   manager->outputs[0].n_possible_crtcs = 3; | ||||
|   manager->outputs[0].possible_crtcs = g_new0 (MetaCRTC *, 3); | ||||
|   manager->outputs[0].n_possible_crtcs = 1; | ||||
|   manager->outputs[0].possible_crtcs = g_new0 (MetaCRTC *, 1); | ||||
|   manager->outputs[0].possible_crtcs[0] = &manager->crtcs[0]; | ||||
|   manager->outputs[0].possible_crtcs[1] = &manager->crtcs[1]; | ||||
|   manager->outputs[0].possible_crtcs[2] = &manager->crtcs[2]; | ||||
|   manager->outputs[0].n_possible_clones = 0; | ||||
|   manager->outputs[0].possible_clones = g_new0 (MetaOutput *, 0); | ||||
|   manager->outputs[0].backlight = -1; | ||||
|   manager->outputs[0].backlight_min = 0; | ||||
|   manager->outputs[0].backlight_max = 0; | ||||
|  | ||||
|   manager->outputs[1].crtc = &manager->crtcs[0]; | ||||
|   manager->outputs[1].output_id = 7; | ||||
|   manager->outputs[1].name = g_strdup ("LVDS"); | ||||
|   manager->outputs[1].vendor = g_strdup ("MetaProducts Inc."); | ||||
|   manager->outputs[1].product = g_strdup ("unknown"); | ||||
|   manager->outputs[1].serial = g_strdup ("0xC0FFEE"); | ||||
|   manager->outputs[1].width_mm = 222; | ||||
|   manager->outputs[1].height_mm = 125; | ||||
|   manager->outputs[1].subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN; | ||||
|   manager->outputs[1].preferred_mode = &manager->modes[5]; | ||||
|   manager->outputs[1].n_modes = 4; | ||||
|   manager->outputs[1].modes = g_new0 (MetaMonitorMode *, 4); | ||||
|   manager->outputs[1].modes[0] = &manager->modes[0]; | ||||
|   manager->outputs[1].modes[1] = &manager->modes[1]; | ||||
|   manager->outputs[1].modes[2] = &manager->modes[2]; | ||||
|   manager->outputs[1].modes[3] = &manager->modes[5]; | ||||
|   manager->outputs[1].n_possible_crtcs = 3; | ||||
|   manager->outputs[1].possible_crtcs = g_new0 (MetaCRTC *, 3); | ||||
|   manager->outputs[1].possible_crtcs[0] = &manager->crtcs[0]; | ||||
|   manager->outputs[1].possible_crtcs[1] = &manager->crtcs[1]; | ||||
|   manager->outputs[1].possible_crtcs[2] = &manager->crtcs[2]; | ||||
|   manager->outputs[1].n_possible_clones = 0; | ||||
|   manager->outputs[1].possible_clones = g_new0 (MetaOutput *, 0); | ||||
|   manager->outputs[1].backlight = -1; | ||||
|   manager->outputs[1].backlight_min = 0; | ||||
|   manager->outputs[1].backlight_max = 0; | ||||
|  | ||||
|   manager->outputs[2].crtc = NULL; | ||||
|   manager->outputs[2].output_id = 8; | ||||
|   manager->outputs[2].name = g_strdup ("VGA"); | ||||
|   manager->outputs[2].vendor = g_strdup ("MetaProducts Inc."); | ||||
|   manager->outputs[2].product = g_strdup ("unknown"); | ||||
|   manager->outputs[2].serial = g_strdup ("0xC4FE"); | ||||
|   manager->outputs[2].width_mm = 309; | ||||
|   manager->outputs[2].height_mm = 174; | ||||
|   manager->outputs[2].subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN; | ||||
|   manager->outputs[2].preferred_mode = &manager->modes[0]; | ||||
|   manager->outputs[2].n_modes = 3; | ||||
|   manager->outputs[2].modes = g_new0 (MetaMonitorMode *, 3); | ||||
|   manager->outputs[2].modes[0] = &manager->modes[0]; | ||||
|   manager->outputs[2].modes[1] = &manager->modes[1]; | ||||
|   manager->outputs[2].modes[2] = &manager->modes[2]; | ||||
|   manager->outputs[2].n_possible_crtcs = 3; | ||||
|   manager->outputs[2].possible_crtcs = g_new0 (MetaCRTC *, 3); | ||||
|   manager->outputs[2].possible_crtcs[0] = &manager->crtcs[0]; | ||||
|   manager->outputs[2].possible_crtcs[1] = &manager->crtcs[1]; | ||||
|   manager->outputs[2].possible_crtcs[2] = &manager->crtcs[2]; | ||||
|   manager->outputs[2].n_possible_clones = 0; | ||||
|   manager->outputs[2].possible_clones = g_new0 (MetaOutput *, 0); | ||||
|   manager->outputs[2].backlight = -1; | ||||
|   manager->outputs[2].backlight_min = 0; | ||||
|   manager->outputs[2].backlight_max = 0; | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -471,6 +355,24 @@ make_logical_config (MetaMonitorManager *manager) | ||||
|   manager->monitor_infos = (void*)g_array_free (monitor_infos, FALSE); | ||||
| } | ||||
|  | ||||
| static GType | ||||
| get_default_backend (void) | ||||
| { | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     { | ||||
|       MetaWaylandCompositor *compositor; | ||||
|  | ||||
|       compositor = meta_wayland_compositor_get_default (); | ||||
|  | ||||
|       if (meta_wayland_compositor_is_native (compositor)) | ||||
|         return META_TYPE_MONITOR_MANAGER_KMS; | ||||
|       else | ||||
|         return META_TYPE_MONITOR_MANAGER; | ||||
|     } | ||||
|   else | ||||
|     return META_TYPE_MONITOR_MANAGER_XRANDR; | ||||
| } | ||||
|  | ||||
| static MetaMonitorManager * | ||||
| meta_monitor_manager_new (void) | ||||
| { | ||||
| @@ -480,7 +382,7 @@ meta_monitor_manager_new (void) | ||||
|   env = g_getenv ("META_DEBUG_MULTIMONITOR"); | ||||
|  | ||||
|   if (env == NULL) | ||||
|     type = META_TYPE_MONITOR_MANAGER_XRANDR; | ||||
|     type = get_default_backend (); | ||||
|   else if (strcmp (env, "xrandr") == 0) | ||||
|     type = META_TYPE_MONITOR_MANAGER_XRANDR; | ||||
|   else | ||||
| @@ -515,17 +417,18 @@ meta_monitor_manager_constructed (GObject *object) | ||||
|       MetaOutput *old_outputs; | ||||
|       MetaCRTC *old_crtcs; | ||||
|       MetaMonitorMode *old_modes; | ||||
|       int n_old_outputs; | ||||
|       unsigned int n_old_outputs, n_old_modes; | ||||
|  | ||||
|       old_outputs = manager->outputs; | ||||
|       n_old_outputs = manager->n_outputs; | ||||
|       old_modes = manager->modes; | ||||
|       n_old_modes = manager->n_modes; | ||||
|       old_crtcs = manager->crtcs; | ||||
|  | ||||
|       read_current_config (manager); | ||||
|  | ||||
|       meta_monitor_manager_free_output_array (old_outputs, n_old_outputs); | ||||
|       g_free (old_modes); | ||||
|       meta_monitor_manager_free_mode_array (old_modes, n_old_modes); | ||||
|       g_free (old_crtcs); | ||||
|     } | ||||
|  | ||||
| @@ -567,19 +470,39 @@ meta_monitor_manager_free_output_array (MetaOutput *old_outputs, | ||||
|       g_free (old_outputs[i].modes); | ||||
|       g_free (old_outputs[i].possible_crtcs); | ||||
|       g_free (old_outputs[i].possible_clones); | ||||
|  | ||||
|       if (old_outputs[i].driver_notify) | ||||
|         old_outputs[i].driver_notify (&old_outputs[i]); | ||||
|     } | ||||
|  | ||||
|   g_free (old_outputs); | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_monitor_manager_free_mode_array (MetaMonitorMode *old_modes, | ||||
|                                       int              n_old_modes) | ||||
| { | ||||
|   int i; | ||||
|  | ||||
|   for (i = 0; i < n_old_modes; i++) | ||||
|     { | ||||
|       g_free (old_modes[i].name); | ||||
|  | ||||
|       if (old_modes[i].driver_notify) | ||||
|         old_modes[i].driver_notify (&old_modes[i]); | ||||
|     } | ||||
|  | ||||
|   g_free (old_modes); | ||||
| } | ||||
|  | ||||
| static void | ||||
| meta_monitor_manager_finalize (GObject *object) | ||||
| { | ||||
|   MetaMonitorManager *manager = META_MONITOR_MANAGER (object); | ||||
|  | ||||
|   meta_monitor_manager_free_output_array (manager->outputs, manager->n_outputs); | ||||
|   meta_monitor_manager_free_mode_array (manager->modes, manager->n_modes); | ||||
|   g_free (manager->monitor_infos); | ||||
|   g_free (manager->modes); | ||||
|   g_free (manager->crtcs); | ||||
|  | ||||
|   G_OBJECT_CLASS (meta_monitor_manager_parent_class)->finalize (object); | ||||
| @@ -758,13 +681,13 @@ meta_monitor_manager_handle_get_resources (MetaDBusDisplayConfig *skeleton, | ||||
|  | ||||
|       g_variant_builder_add (&crtc_builder, "(uxiiiiiuaua{sv})", | ||||
|                              i, /* ID */ | ||||
|                              (gint64)crtc->crtc_id, | ||||
|                              crtc->crtc_id, | ||||
|                              (int)crtc->rect.x, | ||||
|                              (int)crtc->rect.y, | ||||
|                              (int)crtc->rect.width, | ||||
|                              (int)crtc->rect.height, | ||||
|                              (int)(crtc->current_mode ? crtc->current_mode - manager->modes : -1), | ||||
|                              (guint32)crtc->transform, | ||||
|                              crtc->transform, | ||||
|                              &transforms, | ||||
|                              NULL /* properties */); | ||||
|     } | ||||
| @@ -806,6 +729,9 @@ meta_monitor_manager_handle_get_resources (MetaDBusDisplayConfig *skeleton, | ||||
|                              g_variant_new_take_string (make_display_name (manager, output))); | ||||
|       g_variant_builder_add (&properties, "{sv}", "backlight", | ||||
|                              g_variant_new_int32 (output->backlight)); | ||||
|       g_variant_builder_add (&properties, "{sv}", "min-backlight-step", | ||||
|                              g_variant_new_int32 ((output->backlight_max - output->backlight_min) ? | ||||
|                                                   100 / (output->backlight_max - output->backlight_min) : -1)); | ||||
|       g_variant_builder_add (&properties, "{sv}", "primary", | ||||
|                              g_variant_new_boolean (output->is_primary)); | ||||
|       g_variant_builder_add (&properties, "{sv}", "presentation", | ||||
| @@ -832,7 +758,7 @@ meta_monitor_manager_handle_get_resources (MetaDBusDisplayConfig *skeleton, | ||||
|  | ||||
|       g_variant_builder_add (&output_builder, "(uxiausauaua{sv})", | ||||
|                              i, /* ID */ | ||||
|                              (gint64)output->output_id, | ||||
|                              output->output_id, | ||||
|                              (int)(output->crtc ? output->crtc - manager->crtcs : -1), | ||||
|                              &crtcs, | ||||
|                              output->name, | ||||
| @@ -847,9 +773,9 @@ meta_monitor_manager_handle_get_resources (MetaDBusDisplayConfig *skeleton, | ||||
|  | ||||
|       g_variant_builder_add (&mode_builder, "(uxuud)", | ||||
|                              i, /* ID */ | ||||
|                              (gint64)mode->mode_id, | ||||
|                              (guint32)mode->width, | ||||
|                              (guint32)mode->height, | ||||
|                              mode->mode_id, | ||||
|                              mode->width, | ||||
|                              mode->height, | ||||
|                              (double)mode->refresh_rate); | ||||
|     } | ||||
|  | ||||
| @@ -1438,12 +1364,21 @@ meta_monitor_manager_get_resources (MetaMonitorManager  *manager, | ||||
|                                     MetaOutput         **outputs, | ||||
|                                     unsigned int        *n_outputs) | ||||
| { | ||||
|   *modes = manager->modes; | ||||
|   *n_modes = manager->n_modes; | ||||
|   *crtcs = manager->crtcs; | ||||
|   *n_crtcs = manager->n_crtcs; | ||||
|   *outputs = manager->outputs; | ||||
|   *n_outputs = manager->n_outputs; | ||||
|   if (modes) | ||||
|     { | ||||
|       *modes = manager->modes; | ||||
|       *n_modes = manager->n_modes; | ||||
|     } | ||||
|   if (crtcs) | ||||
|     { | ||||
|       *crtcs = manager->crtcs; | ||||
|       *n_crtcs = manager->n_crtcs; | ||||
|     } | ||||
|   if (outputs) | ||||
|     { | ||||
|       *outputs = manager->outputs; | ||||
|       *n_outputs = manager->n_outputs; | ||||
|     } | ||||
| } | ||||
|  | ||||
| int | ||||
|   | ||||
| @@ -25,6 +25,7 @@ | ||||
|  | ||||
| #include <meta/main.h> | ||||
| #include <meta/util.h> | ||||
| #include <glib/gi18n-lib.h> | ||||
| #include "meta-plugin-manager.h" | ||||
|  | ||||
| #include <glib.h> | ||||
|   | ||||
| @@ -31,7 +31,7 @@ | ||||
| #include <config.h> | ||||
| #include <meta/prefs.h> | ||||
| #include "ui.h" | ||||
| #include <meta/util.h> | ||||
| #include "util-private.h" | ||||
| #include "meta-plugin-manager.h" | ||||
| #include <glib.h> | ||||
| #include <gio/gio.h> | ||||
| @@ -1199,8 +1199,8 @@ maybe_give_disable_workarounds_warning (void) | ||||
|     { | ||||
|       first_disable = FALSE; | ||||
|  | ||||
|       meta_warning (_("Workarounds for broken applications disabled. " | ||||
|                       "Some applications may not behave properly.\n")); | ||||
|       meta_warning ("Workarounds for broken applications disabled. " | ||||
|                     "Some applications may not behave properly.\n"); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -1274,8 +1274,8 @@ titlebar_handler (GVariant *value, | ||||
|  | ||||
|   if (desc == NULL) | ||||
|     { | ||||
|       meta_warning (_("Could not parse font description " | ||||
|                       "\"%s\" from GSettings key %s\n"), | ||||
|       meta_warning ("Could not parse font description " | ||||
|                     "\"%s\" from GSettings key %s\n", | ||||
|                     string_value ? string_value : "(null)", | ||||
|                     KEY_TITLEBAR_FONT); | ||||
|       return FALSE; | ||||
| @@ -1340,8 +1340,8 @@ mouse_button_mods_handler (GVariant *value, | ||||
|       meta_topic (META_DEBUG_KEYBINDINGS, | ||||
|                   "Failed to parse new GSettings value\n"); | ||||
|            | ||||
|       meta_warning (_("\"%s\" found in configuration database is " | ||||
|                       "not a valid value for mouse button modifier\n"), | ||||
|       meta_warning ("\"%s\" found in configuration database is " | ||||
|                     "not a valid value for mouse button modifier\n", | ||||
|                     string_value); | ||||
|  | ||||
|       return FALSE; | ||||
| @@ -1906,7 +1906,7 @@ update_binding (MetaKeyPref *binding, | ||||
|         { | ||||
|           meta_topic (META_DEBUG_KEYBINDINGS, | ||||
|                       "Failed to parse new GSettings value\n"); | ||||
|           meta_warning (_("\"%s\" found in configuration database is not a valid value for keybinding \"%s\"\n"), | ||||
|           meta_warning ("\"%s\" found in configuration database is not a valid value for keybinding \"%s\"\n", | ||||
|                         strokes[i], binding->name); | ||||
|  | ||||
|           /* Value is kept and will thus be removed next time we save the key. | ||||
|   | ||||
| @@ -243,12 +243,14 @@ void     meta_screen_workspace_switched (MetaScreen         *screen, | ||||
|  | ||||
| void meta_screen_set_active_workspace_hint (MetaScreen *screen); | ||||
|  | ||||
| Window   meta_screen_create_guard_window (Display *xdisplay, MetaScreen *screen); | ||||
|  | ||||
| gboolean meta_screen_handle_xevent (MetaScreen *screen, | ||||
|                                     XEvent     *xevent); | ||||
|  | ||||
| int meta_screen_xinerama_index_to_monitor_index (MetaScreen *screen, | ||||
|                                                  int         index); | ||||
| int meta_screen_monitor_index_to_xinerama_index (MetaScreen *screen, | ||||
|                                                  int         index); | ||||
|  | ||||
| gboolean meta_screen_handle_xevent (MetaScreen *screen, | ||||
|                                     XEvent     *xevent); | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -33,7 +33,7 @@ | ||||
| #include <config.h> | ||||
| #include "screen-private.h" | ||||
| #include <meta/main.h> | ||||
| #include <meta/util.h> | ||||
| #include "util-private.h" | ||||
| #include <meta/errors.h> | ||||
| #include "window-private.h" | ||||
| #include "frame.h" | ||||
| @@ -45,6 +45,7 @@ | ||||
| #include <meta/compositor.h> | ||||
| #include "mutter-enum-types.h" | ||||
| #include "core.h" | ||||
| #include "meta-wayland-private.h" | ||||
| #include "meta-cursor-tracker-private.h" | ||||
|  | ||||
| #include <X11/extensions/Xinerama.h> | ||||
| @@ -309,8 +310,6 @@ set_supported_hint (MetaScreen *screen) | ||||
| #include <meta/atomnames.h> | ||||
| #undef item | ||||
| #undef EWMH_ATOMS_ONLY | ||||
|  | ||||
|     screen->display->atom__GTK_FRAME_EXTENTS, | ||||
|   }; | ||||
|  | ||||
|   XChangeProperty (screen->display->xdisplay, screen->xroot, | ||||
| @@ -448,12 +447,13 @@ reload_monitor_infos (MetaScreen *screen) | ||||
|  * should effectively be forwarded to events on the background actor, | ||||
|  * providing that the scene graph is set up correctly. | ||||
|  */ | ||||
| static Window | ||||
| create_guard_window (Display *xdisplay, MetaScreen *screen) | ||||
| Window | ||||
| meta_screen_create_guard_window (Display *xdisplay, MetaScreen *screen) | ||||
| { | ||||
|   XSetWindowAttributes attributes; | ||||
|   Window guard_window; | ||||
|   gulong create_serial; | ||||
|   MetaStackWindow stack_window; | ||||
|    | ||||
|   attributes.event_mask = NoEventMask; | ||||
|   attributes.override_redirect = True; | ||||
| @@ -486,12 +486,14 @@ create_guard_window (Display *xdisplay, MetaScreen *screen) | ||||
|     XISelectEvents (xdisplay, guard_window, &mask, 1); | ||||
|   } | ||||
|  | ||||
|   stack_window.any.type = META_WINDOW_CLIENT_TYPE_X11; | ||||
|   stack_window.x11.xwindow = guard_window; | ||||
|   meta_stack_tracker_record_add (screen->stack_tracker, | ||||
|                                  guard_window, | ||||
|                                  &stack_window, | ||||
|                                  create_serial); | ||||
|  | ||||
|   meta_stack_tracker_record_lower (screen->stack_tracker, | ||||
|                                    guard_window, | ||||
|                                    &stack_window, | ||||
|                                    XNextRequest (xdisplay)); | ||||
|   XLowerWindow (xdisplay, guard_window); | ||||
|   XMapWindow (xdisplay, guard_window); | ||||
| @@ -577,7 +579,7 @@ meta_screen_new (MetaDisplay *display, | ||||
|  | ||||
|   if (XGetSelectionOwner (xdisplay, wm_sn_atom) != new_wm_sn_owner) | ||||
|     { | ||||
|       meta_warning (_("Could not acquire window manager selection on screen %d display \"%s\"\n"), | ||||
|       meta_warning ("Could not acquire window manager selection on screen %d display \"%s\"\n", | ||||
|                     number, display->name); | ||||
|  | ||||
|       XDestroyWindow (xdisplay, new_wm_sn_owner); | ||||
| @@ -672,8 +674,9 @@ meta_screen_new (MetaDisplay *display, | ||||
|   screen->xscreen = ScreenOfDisplay (xdisplay, number); | ||||
|   screen->xroot = xroot; | ||||
|   screen->rect.x = screen->rect.y = 0; | ||||
|    | ||||
|   meta_monitor_manager_initialize (); | ||||
|  | ||||
|   if (!meta_is_wayland_compositor ()) | ||||
|     meta_monitor_manager_initialize (); | ||||
|  | ||||
|   manager = meta_monitor_manager_get (); | ||||
|   g_signal_connect (manager, "monitors-changed", | ||||
| @@ -847,7 +850,7 @@ meta_screen_free (MetaScreen *screen, | ||||
|   meta_error_trap_push_with_return (screen->display); | ||||
|   XSelectInput (screen->display->xdisplay, screen->xroot, 0); | ||||
|   if (meta_error_trap_pop_with_return (screen->display) != Success) | ||||
|     meta_warning (_("Could not release screen %d on display \"%s\"\n"), | ||||
|     meta_warning ("Could not release screen %d on display \"%s\"\n", | ||||
|                   screen->number, screen->display->name); | ||||
|  | ||||
|   unset_wm_check_hint (screen); | ||||
| @@ -934,8 +937,8 @@ meta_screen_manage_all_windows (MetaScreen *screen) | ||||
|   meta_display_grab (screen->display); | ||||
|  | ||||
|   if (screen->guard_window == None) | ||||
|     screen->guard_window = create_guard_window (screen->display->xdisplay, | ||||
|                                                 screen); | ||||
|     screen->guard_window = | ||||
|       meta_screen_create_guard_window (screen->display->xdisplay, screen); | ||||
|  | ||||
|   windows = list_windows (screen); | ||||
|  | ||||
| @@ -1739,12 +1742,15 @@ meta_screen_tile_preview_update_timeout (gpointer data) | ||||
|     { | ||||
|       Window xwindow; | ||||
|       gulong create_serial; | ||||
|       MetaStackWindow stack_window; | ||||
|  | ||||
|       screen->tile_preview = meta_tile_preview_new (screen->number); | ||||
|       xwindow = meta_tile_preview_get_xwindow (screen->tile_preview, | ||||
|                                                &create_serial); | ||||
|       stack_window.any.type = META_WINDOW_CLIENT_TYPE_X11; | ||||
|       stack_window.x11.xwindow = xwindow; | ||||
|       meta_stack_tracker_record_add (screen->stack_tracker, | ||||
|                                      xwindow, | ||||
|                                      &stack_window, | ||||
|                                      create_serial); | ||||
|     } | ||||
|  | ||||
| @@ -3686,10 +3692,6 @@ gboolean | ||||
| meta_screen_handle_xevent (MetaScreen *screen, | ||||
|                            XEvent     *xevent) | ||||
| { | ||||
|   /* Go through our helpers and see if they want this event. | ||||
|      Currently, only MetaCursorTracker. | ||||
|   */ | ||||
|  | ||||
|   if (meta_cursor_tracker_handle_xevent (screen->cursor_tracker, xevent)) | ||||
|     return TRUE; | ||||
|  | ||||
|   | ||||
| @@ -25,6 +25,8 @@ | ||||
|  | ||||
| #include <config.h> | ||||
|  | ||||
| #include "util-private.h" | ||||
| #include <meta/main.h> | ||||
| #include "session.h" | ||||
| #include <X11/Xatom.h> | ||||
|  | ||||
| @@ -531,6 +533,12 @@ die_callback (SmcConn smc_conn, SmPointer client_data) | ||||
|    * Anything that wants us to go away outside of session management | ||||
|    * can use kill(). | ||||
|    */ | ||||
|  | ||||
|   /* All of that is true - unless we're a wayland compositor. In which | ||||
|    * case the X server won't go down until we do, so we must die first. | ||||
|    */ | ||||
|   if (meta_is_wayland_compositor ()) | ||||
|     meta_quit (0); | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -840,14 +848,14 @@ save_state (void) | ||||
|   if (mkdir (mutter_dir, 0700) < 0 && | ||||
|       errno != EEXIST) | ||||
|     { | ||||
|       meta_warning (_("Could not create directory '%s': %s\n"), | ||||
|       meta_warning ("Could not create directory '%s': %s\n", | ||||
|                     mutter_dir, g_strerror (errno)); | ||||
|     } | ||||
|  | ||||
|   if (mkdir (session_dir, 0700) < 0 && | ||||
|       errno != EEXIST) | ||||
|     { | ||||
|       meta_warning (_("Could not create directory '%s': %s\n"), | ||||
|       meta_warning ("Could not create directory '%s': %s\n", | ||||
|                     session_dir, g_strerror (errno)); | ||||
|     } | ||||
|  | ||||
| @@ -857,7 +865,7 @@ save_state (void) | ||||
|  | ||||
|   if (outfile == NULL) | ||||
|     { | ||||
|       meta_warning (_("Could not open session file '%s' for writing: %s\n"), | ||||
|       meta_warning ("Could not open session file '%s' for writing: %s\n", | ||||
|                     full_save_file (), g_strerror (errno)); | ||||
|       goto out; | ||||
|     } | ||||
| @@ -998,12 +1006,12 @@ save_state (void) | ||||
|       /* FIXME need a dialog for this */ | ||||
|       if (ferror (outfile)) | ||||
|         { | ||||
|           meta_warning (_("Error writing session file '%s': %s\n"), | ||||
|           meta_warning ("Error writing session file '%s': %s\n", | ||||
|                         full_save_file (), g_strerror (errno)); | ||||
|         } | ||||
|       if (fclose (outfile)) | ||||
|         { | ||||
|           meta_warning (_("Error closing session file '%s': %s\n"), | ||||
|           meta_warning ("Error closing session file '%s': %s\n", | ||||
|                         full_save_file (), g_strerror (errno)); | ||||
|         } | ||||
|     } | ||||
| @@ -1133,7 +1141,7 @@ load_state (const char *previous_save_file) | ||||
|  | ||||
|  error: | ||||
|    | ||||
|   meta_warning (_("Failed to parse saved session file: %s\n"), | ||||
|   meta_warning ("Failed to parse saved session file: %s\n", | ||||
|                 error->message); | ||||
|   g_error_free (error); | ||||
|  | ||||
| @@ -1182,7 +1190,7 @@ start_element_handler  (GMarkupParseContext *context, | ||||
|               g_set_error (error, | ||||
|                            G_MARKUP_ERROR, | ||||
|                        G_MARKUP_ERROR_PARSE, | ||||
|                            _("<mutter_session> attribute seen but we already have the session ID")); | ||||
|                            "<mutter_session> attribute seen but we already have the session ID"); | ||||
|               return; | ||||
|             } | ||||
|            | ||||
| @@ -1195,7 +1203,7 @@ start_element_handler  (GMarkupParseContext *context, | ||||
|               g_set_error (error, | ||||
|                            G_MARKUP_ERROR, | ||||
|                            G_MARKUP_ERROR_UNKNOWN_ATTRIBUTE, | ||||
|                            _("Unknown attribute %s on <%s> element"), | ||||
|                            "Unknown attribute %s on <%s> element", | ||||
|                            name, "mutter_session"); | ||||
|               return; | ||||
|             } | ||||
| @@ -1212,7 +1220,7 @@ start_element_handler  (GMarkupParseContext *context, | ||||
|           g_set_error (error, | ||||
|                        G_MARKUP_ERROR, | ||||
|                        G_MARKUP_ERROR_PARSE, | ||||
|                        _("nested <window> tag")); | ||||
|                        "nested <window> tag"); | ||||
|           return; | ||||
|         } | ||||
|        | ||||
| @@ -1270,7 +1278,7 @@ start_element_handler  (GMarkupParseContext *context, | ||||
|               g_set_error (error, | ||||
|                            G_MARKUP_ERROR, | ||||
|                            G_MARKUP_ERROR_UNKNOWN_ATTRIBUTE, | ||||
|                            _("Unknown attribute %s on <%s> element"), | ||||
|                            "Unknown attribute %s on <%s> element", | ||||
|                            name, "window"); | ||||
|               session_info_free (pd->info); | ||||
|               pd->info = NULL; | ||||
| @@ -1302,7 +1310,7 @@ start_element_handler  (GMarkupParseContext *context, | ||||
|               g_set_error (error, | ||||
|                            G_MARKUP_ERROR, | ||||
|                            G_MARKUP_ERROR_UNKNOWN_ATTRIBUTE, | ||||
|                            _("Unknown attribute %s on <%s> element"), | ||||
|                            "Unknown attribute %s on <%s> element", | ||||
|                            name, "window"); | ||||
|               session_info_free (pd->info); | ||||
|               pd->info = NULL; | ||||
| @@ -1374,7 +1382,7 @@ start_element_handler  (GMarkupParseContext *context, | ||||
|               g_set_error (error, | ||||
|                            G_MARKUP_ERROR, | ||||
|                            G_MARKUP_ERROR_UNKNOWN_ATTRIBUTE, | ||||
|                            _("Unknown attribute %s on <%s> element"), | ||||
|                            "Unknown attribute %s on <%s> element", | ||||
|                            name, "maximized"); | ||||
|               return; | ||||
|             } | ||||
| @@ -1434,7 +1442,7 @@ start_element_handler  (GMarkupParseContext *context, | ||||
|               g_set_error (error, | ||||
|                            G_MARKUP_ERROR, | ||||
|                            G_MARKUP_ERROR_UNKNOWN_ATTRIBUTE, | ||||
|                            _("Unknown attribute %s on <%s> element"), | ||||
|                            "Unknown attribute %s on <%s> element", | ||||
|                            name, "geometry"); | ||||
|               return; | ||||
|             } | ||||
| @@ -1454,7 +1462,7 @@ start_element_handler  (GMarkupParseContext *context, | ||||
|       g_set_error (error, | ||||
|                    G_MARKUP_ERROR, | ||||
|                    G_MARKUP_ERROR_UNKNOWN_ELEMENT, | ||||
|                    _("Unknown element %s"), | ||||
|                    "Unknown element %s", | ||||
|                    element_name); | ||||
|       return; | ||||
|     } | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -37,36 +37,55 @@ | ||||
| #define META_STACK_TRACKER_H | ||||
|  | ||||
| #include <meta/screen.h> | ||||
| #include <meta/window.h> | ||||
|  | ||||
| typedef struct _MetaStackTracker MetaStackTracker; | ||||
|  | ||||
| typedef union _MetaStackWindow | ||||
| { | ||||
|   struct { | ||||
|     MetaWindowClientType type; | ||||
|   } any; | ||||
|   struct { | ||||
|     MetaWindowClientType type; | ||||
|     Window xwindow; | ||||
|   } x11; | ||||
|   struct { | ||||
|     MetaWindowClientType type; | ||||
|     MetaWindow *meta_window; | ||||
|   } wayland; | ||||
| } MetaStackWindow; | ||||
|  | ||||
| gboolean meta_stack_window_equal (const MetaStackWindow *a, | ||||
|                                   const MetaStackWindow *b); | ||||
|  | ||||
| MetaStackTracker *meta_stack_tracker_new  (MetaScreen       *screen); | ||||
| void              meta_stack_tracker_free (MetaStackTracker *tracker); | ||||
|  | ||||
| /* These functions are called when we make an X call that changes the | ||||
|  * stacking order; this allows MetaStackTracker to predict stacking | ||||
|  * order before it receives events back from the X server */ | ||||
| void meta_stack_tracker_record_add             (MetaStackTracker *tracker, | ||||
| 						Window            window, | ||||
|                                                 gulong            serial); | ||||
| void meta_stack_tracker_record_remove          (MetaStackTracker *tracker, | ||||
| 						Window            window, | ||||
|                                                 gulong            serial); | ||||
| void meta_stack_tracker_record_restack_windows (MetaStackTracker *tracker, | ||||
| 						Window           *windows, | ||||
| 						int               n_windows, | ||||
|                                                 gulong            serial); | ||||
| void meta_stack_tracker_record_raise_above     (MetaStackTracker *tracker, | ||||
| 						Window            window, | ||||
| 						Window            sibling, | ||||
|                                                 gulong            serial); | ||||
| void meta_stack_tracker_record_lower_below    (MetaStackTracker *tracker, | ||||
| 						Window            window, | ||||
| 						Window            sibling, | ||||
|                                                 gulong            serial); | ||||
| void meta_stack_tracker_record_lower           (MetaStackTracker *tracker, | ||||
| 						Window            window, | ||||
|                                                 gulong            serial); | ||||
| void meta_stack_tracker_record_add             (MetaStackTracker      *tracker, | ||||
|                                                 const MetaStackWindow *window, | ||||
|                                                 gulong                 serial); | ||||
| void meta_stack_tracker_record_remove          (MetaStackTracker      *tracker, | ||||
|                                                 const MetaStackWindow *window, | ||||
|                                                 gulong                 serial); | ||||
| void meta_stack_tracker_record_restack_windows (MetaStackTracker      *tracker, | ||||
|                                                 const MetaStackWindow *windows, | ||||
| 						int                    n_windows, | ||||
|                                                 gulong                 serial); | ||||
| void meta_stack_tracker_record_raise_above     (MetaStackTracker      *tracker, | ||||
|                                                 const MetaStackWindow *window, | ||||
|                                                 const MetaStackWindow *sibling, | ||||
|                                                 gulong                 serial); | ||||
| void meta_stack_tracker_record_lower_below    (MetaStackTracker       *tracker, | ||||
|                                                const MetaStackWindow  *window, | ||||
|                                                const MetaStackWindow  *sibling, | ||||
|                                                gulong                  serial); | ||||
| void meta_stack_tracker_record_lower           (MetaStackTracker      *tracker, | ||||
|                                                 const MetaStackWindow *window, | ||||
|                                                 gulong                 serial); | ||||
|  | ||||
| /* These functions are used to update the stack when we get events | ||||
|  * reflecting changes to the stacking order */ | ||||
| @@ -79,9 +98,9 @@ void meta_stack_tracker_reparent_event  (MetaStackTracker    *tracker, | ||||
| void meta_stack_tracker_configure_event (MetaStackTracker    *tracker, | ||||
| 					 XConfigureEvent     *event); | ||||
|  | ||||
| void meta_stack_tracker_get_stack  (MetaStackTracker  *tracker, | ||||
|                                     Window           **windows, | ||||
|                                     int               *n_windows); | ||||
| void meta_stack_tracker_get_stack  (MetaStackTracker      *tracker, | ||||
|                                     MetaStackWindow      **windows, | ||||
|                                     int                   *n_entries); | ||||
|  | ||||
| void meta_stack_tracker_sync_stack       (MetaStackTracker *tracker); | ||||
| void meta_stack_tracker_queue_sync_stack (MetaStackTracker *tracker); | ||||
|   | ||||
							
								
								
									
										534
									
								
								src/core/stack.c
									
									
									
									
									
								
							
							
						
						
									
										534
									
								
								src/core/stack.c
									
									
									
									
									
								
							| @@ -52,7 +52,7 @@ | ||||
|  | ||||
| #define WINDOW_IN_STACK(w) (w->stack_position >= 0) | ||||
|  | ||||
| static void stack_sync_to_server (MetaStack *stack); | ||||
| static void stack_sync_to_xserver (MetaStack *stack); | ||||
| static void meta_window_set_stack_position_no_sync (MetaWindow *window, | ||||
|                                                     int         position); | ||||
| static void stack_do_window_deletions (MetaStack *stack); | ||||
| @@ -71,14 +71,14 @@ meta_stack_new (MetaScreen *screen) | ||||
|   stack = g_new (MetaStack, 1); | ||||
|  | ||||
|   stack->screen = screen; | ||||
|   stack->windows = g_array_new (FALSE, FALSE, sizeof (Window)); | ||||
|   stack->xwindows = g_array_new (FALSE, FALSE, sizeof (Window)); | ||||
|  | ||||
|   stack->sorted = NULL; | ||||
|   stack->added = NULL; | ||||
|   stack->removed = NULL; | ||||
|  | ||||
|   stack->freeze_count = 0; | ||||
|   stack->last_root_children_stacked = NULL; | ||||
|   stack->last_all_root_children_stacked = NULL; | ||||
|  | ||||
|   stack->n_positions = 0; | ||||
|  | ||||
| @@ -89,17 +89,34 @@ meta_stack_new (MetaScreen *screen) | ||||
|   return stack; | ||||
| } | ||||
|  | ||||
| static void | ||||
| free_last_all_root_children_stacked_cache (MetaStack *stack) | ||||
| { | ||||
|   unsigned int i; | ||||
|  | ||||
|   for (i = 0; i < stack->last_all_root_children_stacked->len; i++) | ||||
|     { | ||||
|       MetaStackWindow *window = &g_array_index (stack->last_all_root_children_stacked, MetaStackWindow, i); | ||||
|       if (window->any.type == META_WINDOW_CLIENT_TYPE_WAYLAND) | ||||
|         g_object_remove_weak_pointer (G_OBJECT (window->wayland.meta_window), | ||||
|                                       (gpointer *)&window->wayland.meta_window); | ||||
|     } | ||||
|  | ||||
|   g_array_free (stack->last_all_root_children_stacked, TRUE); | ||||
|   stack->last_all_root_children_stacked = NULL; | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_stack_free (MetaStack *stack) | ||||
| { | ||||
|   g_array_free (stack->windows, TRUE); | ||||
|   g_array_free (stack->xwindows, TRUE); | ||||
|  | ||||
|   g_list_free (stack->sorted); | ||||
|   g_list_free (stack->added); | ||||
|   g_list_free (stack->removed); | ||||
|  | ||||
|   if (stack->last_root_children_stacked) | ||||
|     g_array_free (stack->last_root_children_stacked, TRUE); | ||||
|   if (stack->last_all_root_children_stacked) | ||||
|     free_last_all_root_children_stacked_cache (stack); | ||||
|    | ||||
|   g_free (stack); | ||||
| } | ||||
| @@ -121,7 +138,7 @@ meta_stack_add (MetaStack  *stack, | ||||
|               "Window %s has stack_position initialized to %d\n", | ||||
|               window->desc, window->stack_position); | ||||
|    | ||||
|   stack_sync_to_server (stack); | ||||
|   stack_sync_to_xserver (stack); | ||||
|   meta_stack_update_window_tile_matches (stack, window->screen->active_workspace); | ||||
| } | ||||
|  | ||||
| @@ -157,7 +174,7 @@ meta_stack_remove (MetaStack  *stack, | ||||
|     stack->removed = g_list_prepend (stack->removed, | ||||
|                                      GUINT_TO_POINTER (window->frame->xwindow)); | ||||
|    | ||||
|   stack_sync_to_server (stack); | ||||
|   stack_sync_to_xserver (stack); | ||||
|   meta_stack_update_window_tile_matches (stack, window->screen->active_workspace); | ||||
| } | ||||
|  | ||||
| @@ -167,7 +184,7 @@ meta_stack_update_layer (MetaStack  *stack, | ||||
| { | ||||
|   stack->need_relayer = TRUE; | ||||
|    | ||||
|   stack_sync_to_server (stack); | ||||
|   stack_sync_to_xserver (stack); | ||||
|   meta_stack_update_window_tile_matches (stack, window->screen->active_workspace); | ||||
| } | ||||
|  | ||||
| @@ -177,7 +194,7 @@ meta_stack_update_transient (MetaStack  *stack, | ||||
| { | ||||
|   stack->need_constrain = TRUE; | ||||
|    | ||||
|   stack_sync_to_server (stack); | ||||
|   stack_sync_to_xserver (stack); | ||||
|   meta_stack_update_window_tile_matches (stack, window->screen->active_workspace); | ||||
| } | ||||
|  | ||||
| @@ -206,7 +223,7 @@ meta_stack_raise (MetaStack  *stack, | ||||
|  | ||||
|   meta_window_set_stack_position_no_sync (window, max_stack_position); | ||||
|  | ||||
|   stack_sync_to_server (stack); | ||||
|   stack_sync_to_xserver (stack); | ||||
|   meta_stack_update_window_tile_matches (stack, window->screen->active_workspace); | ||||
| } | ||||
|  | ||||
| @@ -234,7 +251,7 @@ meta_stack_lower (MetaStack  *stack, | ||||
|  | ||||
|   meta_window_set_stack_position_no_sync (window, min_stack_position); | ||||
|    | ||||
|   stack_sync_to_server (stack); | ||||
|   stack_sync_to_xserver (stack); | ||||
|   meta_stack_update_window_tile_matches (stack, window->screen->active_workspace); | ||||
| } | ||||
|  | ||||
| @@ -250,7 +267,7 @@ meta_stack_thaw (MetaStack *stack) | ||||
|   g_return_if_fail (stack->freeze_count > 0); | ||||
|    | ||||
|   stack->freeze_count -= 1; | ||||
|   stack_sync_to_server (stack); | ||||
|   stack_sync_to_xserver (stack); | ||||
|   meta_stack_update_window_tile_matches (stack, NULL); | ||||
| } | ||||
|  | ||||
| @@ -829,7 +846,7 @@ stack_do_window_deletions (MetaStack *stack) | ||||
|       /* We go from the end figuring removals are more | ||||
|        * likely to be recent. | ||||
|        */ | ||||
|       i = stack->windows->len; | ||||
|       i = stack->xwindows->len; | ||||
|       while (i > 0) | ||||
|         { | ||||
|           --i; | ||||
| @@ -840,9 +857,9 @@ stack_do_window_deletions (MetaStack *stack) | ||||
|            * both the window->xwindow and window->frame->xwindow | ||||
|            * in the removal list. | ||||
|            */ | ||||
|           if (xwindow == g_array_index (stack->windows, Window, i)) | ||||
|           if (xwindow == g_array_index (stack->xwindows, Window, i)) | ||||
|             { | ||||
|               g_array_remove_index (stack->windows, i); | ||||
|               g_array_remove_index (stack->xwindows, i); | ||||
|               goto next; | ||||
|             } | ||||
|         } | ||||
| @@ -871,10 +888,10 @@ stack_do_window_additions (MetaStack *stack) | ||||
|                   "Adding %d windows to sorted list\n", | ||||
|                   n_added); | ||||
|        | ||||
|       old_size = stack->windows->len; | ||||
|       g_array_set_size (stack->windows, old_size + n_added); | ||||
|       old_size = stack->xwindows->len; | ||||
|       g_array_set_size (stack->xwindows, old_size + n_added); | ||||
|        | ||||
|       end = &g_array_index (stack->windows, Window, old_size); | ||||
|       end = &g_array_index (stack->xwindows, Window, old_size); | ||||
|  | ||||
|       /* stack->added has the most recent additions at the | ||||
|        * front of the list, so we need to reverse it | ||||
| @@ -1029,6 +1046,102 @@ stack_ensure_sorted (MetaStack *stack) | ||||
|   stack_do_resort (stack); | ||||
| } | ||||
|  | ||||
| static MetaStackWindow * | ||||
| find_top_most_managed_window (MetaScreen *screen, | ||||
|                               const MetaStackWindow *ignore) | ||||
| { | ||||
|   MetaStackTracker *stack_tracker = screen->stack_tracker; | ||||
|   MetaStackWindow *windows; | ||||
|   int n_windows; | ||||
|   int i; | ||||
|  | ||||
|   meta_stack_tracker_get_stack (stack_tracker, | ||||
|                                 &windows, &n_windows); | ||||
|  | ||||
|   /* Children are in order from bottom to top. We want to | ||||
|    * find the topmost managed child, then configure | ||||
|    * our window to be above it. | ||||
|    */ | ||||
|   for (i = n_windows -1; i >= 0; i--) | ||||
|     { | ||||
|       MetaStackWindow *other_window = &windows[i]; | ||||
|  | ||||
|       if (other_window->any.type == ignore->any.type && | ||||
|           ((other_window->any.type == META_WINDOW_CLIENT_TYPE_X11 && | ||||
|             other_window->x11.xwindow == ignore->x11.xwindow) || | ||||
|            other_window->wayland.meta_window == ignore->wayland.meta_window)) | ||||
|         { | ||||
|           /* Do nothing. This means we're already the topmost managed | ||||
|            * window, but it DOES NOT mean we are already just above | ||||
|            * the topmost managed window. This is important because if | ||||
|            * an override redirect window is up, and we map a new | ||||
|            * managed window, the new window is probably above the old | ||||
|            * popup by default, and we want to push it below that | ||||
|            * popup. So keep looking for a sibling managed window | ||||
|            * to be moved below. | ||||
|            */ | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           if (other_window->any.type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|             { | ||||
|               MetaWindow *other = meta_display_lookup_x_window (screen->display, | ||||
|                                                                 other_window->x11.xwindow); | ||||
|  | ||||
|               if (other != NULL && !other->override_redirect) | ||||
|                 return other_window; | ||||
|             } | ||||
|           else | ||||
|             { | ||||
|               /* All wayland windows are currently considered "managed" | ||||
|                * TODO: consider wayland pop-up windows like override | ||||
|                * redirect windows here. */ | ||||
|               return other_window; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| /* When moving an X window we sometimes need an X based sibling. | ||||
|  * | ||||
|  * If the given sibling is X based this function returns it back | ||||
|  * otherwise it searches downwards looking for the nearest X window. | ||||
|  * | ||||
|  * If no X based sibling could be found return NULL. */ | ||||
| static MetaStackWindow * | ||||
| find_x11_sibling_downwards (MetaScreen *screen, | ||||
|                             MetaStackWindow *sibling) | ||||
| { | ||||
|   MetaStackTracker *stack_tracker = screen->stack_tracker; | ||||
|   MetaStackWindow *windows; | ||||
|   int n_windows; | ||||
|   int i; | ||||
|  | ||||
|   if (sibling->any.type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|     return sibling; | ||||
|  | ||||
|   meta_stack_tracker_get_stack (stack_tracker, | ||||
|                                 &windows, &n_windows); | ||||
|  | ||||
|   /* NB: Children are in order from bottom to top and we | ||||
|    * want to search downwards for the nearest X window. | ||||
|    */ | ||||
|  | ||||
|   for (i = n_windows - 1; i >= 0; i--) | ||||
|     if (meta_stack_window_equal (&windows[i], sibling)) | ||||
|       break; | ||||
|  | ||||
|   for (; i >= 0; i--) | ||||
|     { | ||||
|       if (windows[i].any.type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|         return &windows[i]; | ||||
|     } | ||||
|  | ||||
|   return NULL; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * raise_window_relative_to_managed_windows: | ||||
|  * | ||||
| @@ -1053,84 +1166,74 @@ stack_ensure_sorted (MetaStack *stack) | ||||
|  */ | ||||
| static void | ||||
| raise_window_relative_to_managed_windows (MetaScreen *screen, | ||||
|                                           Window      xwindow) | ||||
|                                           const MetaStackWindow *window) | ||||
| { | ||||
|   gulong serial = 0; | ||||
|   MetaStackWindow *sibling; | ||||
|  | ||||
|   Window *children; | ||||
|   int n_children; | ||||
|   int i; | ||||
|  | ||||
|   meta_stack_tracker_get_stack (screen->stack_tracker, | ||||
|                                 &children, &n_children); | ||||
|  | ||||
|   /* Children are in order from bottom to top. We want to | ||||
|    * find the topmost managed child, then configure | ||||
|    * our window to be above it. | ||||
|    */ | ||||
|   i = n_children - 1; | ||||
|   while (i >= 0) | ||||
|   sibling = find_top_most_managed_window (screen, window); | ||||
|   if (!sibling) | ||||
|     { | ||||
|       if (children[i] == xwindow) | ||||
|       if (window->any.type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|         { | ||||
|           /* Do nothing. This means we're already the topmost managed | ||||
|            * window, but it DOES NOT mean we are already just above | ||||
|            * the topmost managed window. This is important because if | ||||
|            * an override redirect window is up, and we map a new | ||||
|            * managed window, the new window is probably above the old | ||||
|            * popup by default, and we want to push it below that | ||||
|            * popup. So keep looking for a sibling managed window | ||||
|            * to be moved below. | ||||
|            */ | ||||
|           serial = XNextRequest (screen->display->xdisplay); | ||||
|           meta_error_trap_push (screen->display); | ||||
|           XLowerWindow (screen->display->xdisplay, | ||||
|                         window->x11.xwindow); | ||||
|           meta_error_trap_pop (screen->display); | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           MetaWindow *other = meta_display_lookup_x_window (screen->display, | ||||
|                                                             children[i]); | ||||
|           if (other != NULL && !other->override_redirect) | ||||
|             { | ||||
|               XWindowChanges changes; | ||||
|  | ||||
|               /* children[i] is the topmost managed child */ | ||||
|       /* No sibling to use, just lower ourselves to the bottom | ||||
|        * to be sure we're below any override redirect windows. | ||||
|            */ | ||||
|       meta_stack_tracker_record_lower (screen->stack_tracker, | ||||
|                                        window, | ||||
|                                        serial); | ||||
|       return; | ||||
|         } | ||||
|  | ||||
|   /* window is the topmost managed child */ | ||||
|               meta_topic (META_DEBUG_STACK, | ||||
|                           "Moving 0x%lx above topmost managed child window 0x%lx\n", | ||||
|                           xwindow, children[i]); | ||||
|               window->any.type == META_WINDOW_CLIENT_TYPE_X11 ? window->x11.xwindow: 0, | ||||
|               sibling->any.type == META_WINDOW_CLIENT_TYPE_X11 ? sibling->x11.xwindow: 0); | ||||
|  | ||||
|               changes.sibling = children[i]; | ||||
|   if (window->any.type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|     { | ||||
|       XWindowChanges changes; | ||||
|       MetaStackWindow *x11_sibling = find_x11_sibling_downwards (screen, sibling); | ||||
|       serial = XNextRequest (screen->display->xdisplay); | ||||
|  | ||||
|       if (x11_sibling) | ||||
|         { | ||||
|           changes.sibling = x11_sibling->x11.xwindow; | ||||
|               changes.stack_mode = Above; | ||||
|  | ||||
|               meta_error_trap_push (screen->display); | ||||
|               meta_stack_tracker_record_raise_above (screen->stack_tracker, | ||||
|                                                      xwindow, | ||||
|                                                      children[i], | ||||
|                                                      XNextRequest (screen->display->xdisplay)); | ||||
|               XConfigureWindow (screen->display->xdisplay, | ||||
|                                 xwindow, | ||||
|                             window->x11.xwindow, | ||||
|                                 CWSibling | CWStackMode, | ||||
|                                 &changes); | ||||
|               meta_error_trap_pop (screen->display); | ||||
|  | ||||
|               break; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|       --i; | ||||
|     } | ||||
|  | ||||
|   if (i < 0) | ||||
|       else | ||||
|     { | ||||
|       /* No sibling to use, just lower ourselves to the bottom | ||||
|        * to be sure we're below any override redirect windows. | ||||
|        */ | ||||
|       meta_error_trap_push (screen->display); | ||||
|       meta_stack_tracker_record_lower (screen->stack_tracker, | ||||
|                                        xwindow, | ||||
|                                        XNextRequest (screen->display->xdisplay)); | ||||
|       XLowerWindow (screen->display->xdisplay, | ||||
|                     xwindow); | ||||
|                         window->x11.xwindow); | ||||
|       meta_error_trap_pop (screen->display); | ||||
|     } | ||||
| } | ||||
|  | ||||
|   meta_stack_tracker_record_raise_above (screen->stack_tracker, | ||||
|                                          window, | ||||
|                                          sibling, | ||||
|                                          serial); | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * stack_sync_to_server: | ||||
|  * | ||||
| @@ -1145,13 +1248,16 @@ raise_window_relative_to_managed_windows (MetaScreen *screen, | ||||
|  * job of computing the minimal set of stacking requests needed. | ||||
|  */ | ||||
| static void | ||||
| stack_sync_to_server (MetaStack *stack) | ||||
| stack_sync_to_xserver (MetaStack *stack) | ||||
| { | ||||
|   GArray *stacked; | ||||
|   GArray *root_children_stacked; | ||||
|   GArray *x11_stacked; | ||||
|   GArray *x11_root_children_stacked; | ||||
|   GArray *all_root_children_stacked; /* wayland OR x11 */ | ||||
|   GList *tmp; | ||||
|   GArray *all_hidden; | ||||
|   GArray *x11_hidden; | ||||
|   GArray *x11_hidden_stack_windows; | ||||
|   int n_override_redirect = 0; | ||||
|   MetaStackWindow guard_stack_window; | ||||
|    | ||||
|   /* Bail out if frozen */ | ||||
|   if (stack->freeze_count > 0) | ||||
| @@ -1166,13 +1272,17 @@ stack_sync_to_server (MetaStack *stack) | ||||
|    * _NET hints, and "root_children_stacked" is in top-to-bottom | ||||
|    * order for XRestackWindows() | ||||
|    */ | ||||
|   stacked = g_array_new (FALSE, FALSE, sizeof (Window)); | ||||
|   root_children_stacked = g_array_new (FALSE, FALSE, sizeof (Window)); | ||||
|   all_hidden = g_array_new (FALSE, FALSE, sizeof (Window)); | ||||
|   x11_stacked = g_array_new (FALSE, FALSE, sizeof (Window)); | ||||
|  | ||||
|   all_root_children_stacked = g_array_new (FALSE, FALSE, sizeof (MetaStackWindow)); | ||||
|   x11_root_children_stacked = g_array_new (FALSE, FALSE, sizeof (Window)); | ||||
|  | ||||
|   x11_hidden_stack_windows = g_array_new (FALSE, FALSE, sizeof (MetaStackWindow)); | ||||
|   x11_hidden = g_array_new (FALSE, FALSE, sizeof (Window)); | ||||
|  | ||||
|   /* The screen guard window sits above all hidden windows and acts as | ||||
|    * a barrier to input reaching these windows. */ | ||||
|   g_array_append_val (all_hidden, stack->screen->guard_window); | ||||
|   g_array_append_val (x11_hidden, stack->screen->guard_window); | ||||
|  | ||||
|   meta_topic (META_DEBUG_STACK, "Top to bottom: "); | ||||
|   meta_push_no_msg_prefix (); | ||||
| @@ -1181,6 +1291,9 @@ stack_sync_to_server (MetaStack *stack) | ||||
|     { | ||||
|       MetaWindow *w = tmp->data; | ||||
|       Window top_level_window; | ||||
|       MetaStackWindow stack_window; | ||||
|  | ||||
|       stack_window.any.type = w->client_type; | ||||
|        | ||||
|       meta_topic (META_DEBUG_STACK, "%u:%d - %s ", | ||||
| 		  w->layer, w->stack_position, w->desc); | ||||
| @@ -1189,60 +1302,93 @@ stack_sync_to_server (MetaStack *stack) | ||||
|       if (w->override_redirect) | ||||
| 	n_override_redirect++; | ||||
|       else | ||||
| 	g_array_prepend_val (stacked, w->xwindow); | ||||
| 	g_array_prepend_val (x11_stacked, w->xwindow); | ||||
|        | ||||
|       if (w->frame) | ||||
| 	top_level_window = w->frame->xwindow; | ||||
|       else | ||||
| 	top_level_window = w->xwindow; | ||||
|  | ||||
|       if (w->client_type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|         stack_window.x11.xwindow = top_level_window; | ||||
|       else | ||||
|         stack_window.wayland.meta_window = w; | ||||
|  | ||||
|       /* We don't restack hidden windows along with the rest, though they are | ||||
|        * reflected in the _NET hints. Hidden windows all get pushed below | ||||
|        * the screens fullscreen guard_window. */ | ||||
|       if (w->hidden) | ||||
| 	{ | ||||
| 	  g_array_append_val (all_hidden, top_level_window); | ||||
|           if (w->client_type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|             { | ||||
|               MetaStackWindow stack_window; | ||||
|  | ||||
|               stack_window.any.type = META_WINDOW_CLIENT_TYPE_X11; | ||||
|               stack_window.x11.xwindow = top_level_window; | ||||
|  | ||||
|               g_array_append_val (x11_hidden_stack_windows, stack_window); | ||||
|               g_array_append_val (x11_hidden, top_level_window); | ||||
|             } | ||||
| 	  continue; | ||||
| 	} | ||||
|  | ||||
|       g_array_append_val (all_root_children_stacked, stack_window); | ||||
|  | ||||
|       /* build XRestackWindows() array from top to bottom */ | ||||
|       g_array_append_val (root_children_stacked, top_level_window); | ||||
|       if (w->client_type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|         g_array_append_val (x11_root_children_stacked, top_level_window); | ||||
|       else | ||||
|         { | ||||
|           MetaStackWindow *new; | ||||
|  | ||||
|           /* So we can determine later if a cached stack window is | ||||
|            * stale because the corresponding window has been freed we | ||||
|            * associate a weak pointer with the new window. */ | ||||
|           new = &g_array_index (all_root_children_stacked, MetaStackWindow, all_root_children_stacked->len - 1); | ||||
|           g_object_add_weak_pointer (G_OBJECT (new->wayland.meta_window), | ||||
|                                      (gpointer *)&new->wayland.meta_window); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   meta_topic (META_DEBUG_STACK, "\n"); | ||||
|   meta_pop_no_msg_prefix (); | ||||
|  | ||||
|   /* All windows should be in some stacking order */ | ||||
|   if (stacked->len != stack->windows->len - n_override_redirect) | ||||
|   /* All X windows should be in some stacking order */ | ||||
|   if (x11_stacked->len != stack->xwindows->len - n_override_redirect) | ||||
|     meta_bug ("%u windows stacked, %u windows exist in stack\n", | ||||
|               stacked->len, stack->windows->len); | ||||
|               x11_stacked->len, stack->xwindows->len); | ||||
|    | ||||
|   /* Sync to server */ | ||||
|  | ||||
|   meta_topic (META_DEBUG_STACK, "Restacking %u windows\n", | ||||
|               root_children_stacked->len); | ||||
|               all_root_children_stacked->len); | ||||
|    | ||||
|   meta_error_trap_push (stack->screen->display); | ||||
|  | ||||
|   if (stack->last_root_children_stacked == NULL) | ||||
|   if (stack->last_all_root_children_stacked == NULL) | ||||
|     { | ||||
|       /* Just impose our stack, we don't know the previous state. | ||||
|        * This involves a ton of circulate requests and may flicker. | ||||
|        */ | ||||
|       meta_topic (META_DEBUG_STACK, "Don't know last stack state, restacking everything\n"); | ||||
|  | ||||
|       if (root_children_stacked->len > 0) | ||||
|       if (all_root_children_stacked->len > 1) | ||||
|         { | ||||
|           meta_stack_tracker_record_restack_windows (stack->screen->stack_tracker, | ||||
|                                                      (Window *) root_children_stacked->data, | ||||
|                                                      root_children_stacked->len, | ||||
|                                                      XNextRequest (stack->screen->display->xdisplay)); | ||||
|           gulong serial = 0; | ||||
|           if (x11_root_children_stacked->len > 1) | ||||
|             { | ||||
|               serial = XNextRequest (stack->screen->display->xdisplay); | ||||
|           XRestackWindows (stack->screen->display->xdisplay, | ||||
|                            (Window *) root_children_stacked->data, | ||||
|                            root_children_stacked->len); | ||||
|                                (Window *) x11_root_children_stacked->data, | ||||
|                                x11_root_children_stacked->len); | ||||
|             } | ||||
|           meta_stack_tracker_record_restack_windows (stack->screen->stack_tracker, | ||||
|                                                      (MetaStackWindow *) all_root_children_stacked->data, | ||||
|                                                      all_root_children_stacked->len, | ||||
|                                                      serial); | ||||
|         } | ||||
|     } | ||||
|   else if (root_children_stacked->len > 0) | ||||
|   else if (all_root_children_stacked->len > 0) | ||||
|     { | ||||
|       /* Try to do minimal window moves to get the stack in order */ | ||||
|       /* A point of note: these arrays include frames not client windows, | ||||
| @@ -1250,28 +1396,34 @@ stack_sync_to_server (MetaStack *stack) | ||||
|        * was saved, then we may have inefficiency, but I don't think things | ||||
|        * break... | ||||
|        */ | ||||
|       const Window *old_stack = (Window *) stack->last_root_children_stacked->data; | ||||
|       const Window *new_stack = (Window *) root_children_stacked->data; | ||||
|       const int old_len = stack->last_root_children_stacked->len; | ||||
|       const int new_len = root_children_stacked->len; | ||||
|       const Window *oldp = old_stack; | ||||
|       const Window *newp = new_stack; | ||||
|       const Window *old_end = old_stack + old_len; | ||||
|       const Window *new_end = new_stack + new_len; | ||||
|       Window last_window = None; | ||||
|        | ||||
|       const MetaStackWindow *old_stack = (MetaStackWindow *) stack->last_all_root_children_stacked->data; | ||||
|       const MetaStackWindow *new_stack = (MetaStackWindow *) all_root_children_stacked->data; | ||||
|       const int old_len = stack->last_all_root_children_stacked->len; | ||||
|       const int new_len = all_root_children_stacked->len; | ||||
|       const MetaStackWindow *oldp = old_stack; | ||||
|       const MetaStackWindow *newp = new_stack; | ||||
|       const MetaStackWindow *old_end = old_stack + old_len; | ||||
|       const MetaStackWindow *new_end = new_stack + new_len; | ||||
|       Window last_xwindow = None; | ||||
|       const MetaStackWindow *last_window = NULL; | ||||
|  | ||||
|       while (oldp != old_end && | ||||
|              newp != new_end) | ||||
|         { | ||||
|           if (*oldp == *newp) | ||||
|           if (meta_stack_window_equal (oldp, newp)) | ||||
|             { | ||||
|               /* Stacks are the same here, move on */ | ||||
|               ++oldp; | ||||
|               last_window = *newp; | ||||
|               if (newp->any.type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|                 last_xwindow = newp->x11.xwindow; | ||||
|               last_window = newp; | ||||
|               ++newp; | ||||
|             } | ||||
|           else if (meta_display_lookup_x_window (stack->screen->display, | ||||
|                                                  *oldp) == NULL) | ||||
|           else if ((oldp->any.type == META_WINDOW_CLIENT_TYPE_X11 && | ||||
|                     meta_display_lookup_x_window (stack->screen->display, | ||||
|                                                   oldp->x11.xwindow) == NULL) || | ||||
|                    (oldp->any.type == META_WINDOW_CLIENT_TYPE_WAYLAND && | ||||
|                     oldp->wayland.meta_window == NULL)) | ||||
|             { | ||||
|               /* *oldp is no longer known to us (probably destroyed), | ||||
|                * so we can just skip it | ||||
| @@ -1280,75 +1432,161 @@ stack_sync_to_server (MetaStack *stack) | ||||
|             } | ||||
|           else | ||||
|             { | ||||
|               /* Move *newp below last_window */ | ||||
|               if (last_window == None) | ||||
|               /* Move *newp below the last_window */ | ||||
|               if (!last_window) | ||||
|                 { | ||||
|                   meta_topic (META_DEBUG_STACK, "Using window 0x%lx as topmost (but leaving it in-place)\n", *newp); | ||||
|                   meta_topic (META_DEBUG_STACK, "Using window 0x%lx as topmost (but leaving it in-place)\n", | ||||
|                               newp->x11.xwindow); | ||||
|  | ||||
|                   raise_window_relative_to_managed_windows (stack->screen, | ||||
|                                                             *newp); | ||||
|                   raise_window_relative_to_managed_windows (stack->screen, newp); | ||||
|                 } | ||||
|               else if (newp->any.type == META_WINDOW_CLIENT_TYPE_X11 && | ||||
|                        last_xwindow == None) | ||||
|                 { | ||||
|                   /* In this case we have an X window that we need to | ||||
|                    * put below a wayland window and this is the | ||||
|                    * topmost X window. */ | ||||
|                    | ||||
|                   /* In X terms (because this is the topmost X window) | ||||
|                    * we want to | ||||
|                    * raise_window_relative_to_managed_windows() to | ||||
|                    * ensure the X window is below override-redirect | ||||
|                    * pop-up windows. | ||||
|                    * | ||||
|                    * In Wayland terms we just want to ensure | ||||
|                    * newp is lowered below last_window (which | ||||
|                    * notably doesn't require an X request because we | ||||
|                    * know last_window isn't an X window). | ||||
|                    */ | ||||
|  | ||||
|                   raise_window_relative_to_managed_windows (stack->screen, newp); | ||||
|  | ||||
|                   meta_stack_tracker_record_lower_below (stack->screen->stack_tracker, | ||||
|                                                          newp, last_window, | ||||
|                                                          0); /* no x request serial */ | ||||
|                 } | ||||
|               else | ||||
|                 { | ||||
|                   /* This means that if last_window is dead, but not | ||||
|                   gulong serial = 0; | ||||
|  | ||||
|                   /* This means that if last_xwindow is dead, but not | ||||
|                    * *newp, then we fail to restack *newp; but on | ||||
|                    * unmanaging last_window, we'll fix it up. | ||||
|                    * unmanaging last_xwindow, we'll fix it up. | ||||
|                    */ | ||||
|                    | ||||
|                   XWindowChanges changes; | ||||
|                   meta_topic (META_DEBUG_STACK, "Placing window 0x%lx below 0x%lx\n", | ||||
|                               newp->any.type == META_WINDOW_CLIENT_TYPE_X11 ? newp->x11.xwindow : 0, | ||||
|                               last_xwindow); | ||||
|  | ||||
|                   changes.sibling = last_window; | ||||
|                   if (newp->any.type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|                     { | ||||
|                   XWindowChanges changes; | ||||
|                       serial = XNextRequest (stack->screen->display->xdisplay); | ||||
|  | ||||
|                       changes.sibling = last_xwindow; | ||||
|                   changes.stack_mode = Below; | ||||
|  | ||||
|                   meta_topic (META_DEBUG_STACK, "Placing window 0x%lx below 0x%lx\n", | ||||
|                               *newp, last_window); | ||||
|  | ||||
|                   meta_stack_tracker_record_lower_below (stack->screen->stack_tracker, | ||||
|                                                          *newp, last_window, | ||||
|                                                          XNextRequest (stack->screen->display->xdisplay)); | ||||
|                   XConfigureWindow (stack->screen->display->xdisplay, | ||||
|                                     *newp, | ||||
|                                         newp->x11.xwindow, | ||||
|                                     CWSibling | CWStackMode, | ||||
|                                     &changes); | ||||
|                 } | ||||
|  | ||||
|               last_window = *newp; | ||||
|                   meta_stack_tracker_record_lower_below (stack->screen->stack_tracker, | ||||
|                                                          newp, last_window, | ||||
|                                                          serial); | ||||
|                 } | ||||
|  | ||||
|               if (newp->any.type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|                 last_xwindow = newp->x11.xwindow; | ||||
|               last_window = newp; | ||||
|               ++newp; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|       if (newp != new_end) | ||||
|         { | ||||
|           const MetaStackWindow *x_ref; | ||||
|           unsigned long serial = 0; | ||||
|  | ||||
|           /* Restack remaining windows */ | ||||
|           meta_topic (META_DEBUG_STACK, "Restacking remaining %d windows\n", | ||||
|                         (int) (new_end - newp)); | ||||
|  | ||||
|           /* rewind until we find the last stacked X window that we can use | ||||
|            * as a reference point for re-stacking remaining X windows */ | ||||
|           if (newp != new_stack) | ||||
|             for (x_ref = newp - 1; | ||||
|                  x_ref->any.type != META_WINDOW_CLIENT_TYPE_X11 && x_ref > new_stack; | ||||
|                  x_ref--) | ||||
|               ; | ||||
|           else | ||||
|             x_ref = new_stack; | ||||
|  | ||||
|           /* If we didn't find an X window looking backwards then walk forwards | ||||
|            * through the remaining windows to find the first remaining X window | ||||
|            * instead. */ | ||||
|           if (x_ref->any.type != META_WINDOW_CLIENT_TYPE_X11) | ||||
|             { | ||||
|               for (x_ref = newp; | ||||
|                    x_ref->any.type != META_WINDOW_CLIENT_TYPE_X11 && x_ref > new_stack; | ||||
|                    x_ref++) | ||||
|                 ; | ||||
|             } | ||||
|  | ||||
|           /* If there are any X windows remaining unstacked then restack them */ | ||||
|           if (x_ref->any.type == META_WINDOW_CLIENT_TYPE_X11) | ||||
|             { | ||||
|               int i; | ||||
|  | ||||
|               for (i = x11_root_children_stacked->len - 1; i; i--) | ||||
|                 { | ||||
|                   Window *reference = &g_array_index (x11_root_children_stacked, Window, i); | ||||
|  | ||||
|                   if (*reference == x_ref->x11.xwindow) | ||||
|                     { | ||||
|                       int n = x11_root_children_stacked->len - i; | ||||
|  | ||||
|                       /* There's no point restacking if there's only one X window */ | ||||
|                       if (n == 1) | ||||
|                         break; | ||||
|  | ||||
|                       serial = XNextRequest (stack->screen->display->xdisplay); | ||||
|                       XRestackWindows (stack->screen->display->xdisplay, | ||||
|                                        reference, n); | ||||
|                       break; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|           /* We need to include an already-stacked window | ||||
|            * in the restack call, so we get in the proper position | ||||
|            * with respect to it. | ||||
|            */ | ||||
|           if (newp != new_stack) | ||||
|             --newp; | ||||
|             newp = MIN (newp - 1, x_ref); | ||||
|           meta_stack_tracker_record_restack_windows (stack->screen->stack_tracker, | ||||
|                                                      (Window *) newp, new_end - newp, | ||||
|                                                      XNextRequest (stack->screen->display->xdisplay)); | ||||
|           XRestackWindows (stack->screen->display->xdisplay, | ||||
|                            (Window *) newp, new_end - newp); | ||||
|                                                      newp, new_end - newp, | ||||
|                                                      serial); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   /* Push hidden windows to the bottom of the stack under the guard window */ | ||||
|   /* Push hidden X windows to the bottom of the stack under the guard window */ | ||||
|   guard_stack_window.any.type = META_WINDOW_CLIENT_TYPE_X11; | ||||
|   guard_stack_window.x11.xwindow = stack->screen->guard_window; | ||||
|   meta_stack_tracker_record_lower (stack->screen->stack_tracker, | ||||
|                                    stack->screen->guard_window, | ||||
|                                    &guard_stack_window, | ||||
|                                    XNextRequest (stack->screen->display->xdisplay)); | ||||
|   XLowerWindow (stack->screen->display->xdisplay, stack->screen->guard_window); | ||||
|   meta_stack_tracker_record_restack_windows (stack->screen->stack_tracker, | ||||
|                                              (Window *)all_hidden->data, | ||||
|                                              all_hidden->len, | ||||
|                                              (MetaStackWindow *)x11_hidden_stack_windows->data, | ||||
|                                              x11_hidden_stack_windows->len, | ||||
|                                              XNextRequest (stack->screen->display->xdisplay)); | ||||
|   XRestackWindows (stack->screen->display->xdisplay, | ||||
| 		   (Window *)all_hidden->data, | ||||
| 		   all_hidden->len); | ||||
|   g_array_free (all_hidden, TRUE); | ||||
| 		   (Window *)x11_hidden->data, | ||||
| 		   x11_hidden->len); | ||||
|   g_array_free (x11_hidden, TRUE); | ||||
|   g_array_free (x11_hidden_stack_windows, TRUE); | ||||
|  | ||||
|   meta_error_trap_pop (stack->screen->display); | ||||
|   /* on error, a window was destroyed; it should eventually | ||||
| @@ -1363,21 +1601,23 @@ stack_sync_to_server (MetaStack *stack) | ||||
|                    stack->screen->display->atom__NET_CLIENT_LIST, | ||||
|                    XA_WINDOW, | ||||
|                    32, PropModeReplace, | ||||
|                    (unsigned char *)stack->windows->data, | ||||
|                    stack->windows->len); | ||||
|                    (unsigned char *)stack->xwindows->data, | ||||
|                    stack->xwindows->len); | ||||
|   XChangeProperty (stack->screen->display->xdisplay, | ||||
|                    stack->screen->xroot, | ||||
|                    stack->screen->display->atom__NET_CLIENT_LIST_STACKING, | ||||
|                    XA_WINDOW, | ||||
|                    32, PropModeReplace, | ||||
|                    (unsigned char *)stacked->data, | ||||
|                    stacked->len); | ||||
|                    (unsigned char *)x11_stacked->data, | ||||
|                    x11_stacked->len); | ||||
|  | ||||
|   g_array_free (stacked, TRUE); | ||||
|   g_array_free (x11_stacked, TRUE); | ||||
|  | ||||
|   if (stack->last_root_children_stacked) | ||||
|     g_array_free (stack->last_root_children_stacked, TRUE); | ||||
|   stack->last_root_children_stacked = root_children_stacked; | ||||
|   if (stack->last_all_root_children_stacked) | ||||
|     free_last_all_root_children_stacked_cache (stack); | ||||
|   stack->last_all_root_children_stacked = all_root_children_stacked; | ||||
|  | ||||
|   g_array_free (x11_root_children_stacked, TRUE); | ||||
|  | ||||
|   /* That was scary... */ | ||||
| } | ||||
| @@ -1728,7 +1968,7 @@ meta_stack_set_positions (MetaStack *stack, | ||||
|   meta_topic (META_DEBUG_STACK, | ||||
|               "Reset the stack positions of (nearly) all windows\n"); | ||||
|  | ||||
|   stack_sync_to_server (stack); | ||||
|   stack_sync_to_xserver (stack); | ||||
|   meta_stack_update_window_tile_matches (stack, NULL); | ||||
| } | ||||
|  | ||||
| @@ -1791,7 +2031,7 @@ meta_window_set_stack_position (MetaWindow *window, | ||||
|                                 int         position) | ||||
| { | ||||
|   meta_window_set_stack_position_no_sync (window, position); | ||||
|   stack_sync_to_server (window->screen->stack); | ||||
|   stack_sync_to_xserver (window->screen->stack); | ||||
|   meta_stack_update_window_tile_matches (window->screen->stack, | ||||
|                                          window->screen->active_workspace); | ||||
| } | ||||
|   | ||||
| @@ -60,7 +60,7 @@ struct _MetaStack | ||||
|    * A sequence of all the Windows (X handles, not MetaWindows) of the windows | ||||
|    * we manage, sorted in order.  Suitable to be passed into _NET_CLIENT_LIST. | ||||
|    */ | ||||
|   GArray *windows; | ||||
|   GArray *xwindows; | ||||
|  | ||||
|   /** The MetaWindows of the windows we manage, sorted in order. */ | ||||
|   GList *sorted; | ||||
| @@ -99,7 +99,7 @@ struct _MetaStack | ||||
|    * The last-known stack of all windows, bottom to top.  We cache it here | ||||
|    * so that subsequent times we'll be able to do incremental moves. | ||||
|    */ | ||||
|   GArray *last_root_children_stacked; | ||||
|   GArray *last_all_root_children_stacked; | ||||
|  | ||||
|   /** | ||||
|    * Number of stack positions; same as the length of added, but | ||||
|   | ||||
							
								
								
									
										37
									
								
								src/core/util-private.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								src/core/util-private.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | ||||
| /* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */ | ||||
|  | ||||
| /* Mutter utilities */ | ||||
|  | ||||
| /*  | ||||
|  * Copyright (C) 2001 Havoc Pennington | ||||
|  * Copyright (C) 2005 Elijah Newren | ||||
|  *  | ||||
|  * 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 the Free Software Foundation; either version 2 of the | ||||
|  * License, or (at your option) any later version. | ||||
|  * | ||||
|  * This program is distributed in the hope that it will be useful, but | ||||
|  * WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||
|  * General Public License for more details. | ||||
|  *  | ||||
|  * You should have received a copy of the GNU General Public License | ||||
|  * along with this program; if not, write to the Free Software | ||||
|  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA | ||||
|  * 02111-1307, USA. | ||||
|  */ | ||||
|  | ||||
| #ifndef META_UTIL_PRIVATE_H | ||||
| #define META_UTIL_PRIVATE_H | ||||
|  | ||||
| #include <meta/util.h> | ||||
| #include <glib/gi18n-lib.h> | ||||
|  | ||||
| void     meta_set_verbose (gboolean setting); | ||||
| void     meta_set_debugging (gboolean setting); | ||||
| void     meta_set_syncing (gboolean setting); | ||||
| void     meta_set_replace_current_wm (gboolean setting); | ||||
| void     meta_set_is_wayland_compositor (gboolean setting); | ||||
|  | ||||
| #endif | ||||
| @@ -31,7 +31,7 @@ | ||||
|  | ||||
| #include <config.h> | ||||
| #include <meta/common.h> | ||||
| #include <meta/util.h> | ||||
| #include "util-private.h" | ||||
| #include <meta/main.h> | ||||
|  | ||||
| #include <clutter/clutter.h> /* For clutter_threads_add_repaint_func() */ | ||||
| @@ -55,6 +55,7 @@ static gint verbose_topics = 0; | ||||
| static gboolean is_debugging = FALSE; | ||||
| static gboolean replace_current = FALSE; | ||||
| static int no_prefix = 0; | ||||
| static gboolean is_wayland_compositor = FALSE; | ||||
|  | ||||
| #ifdef WITH_VERBOSE_MODE | ||||
| static FILE* logfile = NULL; | ||||
| @@ -81,7 +82,7 @@ ensure_logfile (void) | ||||
|        | ||||
|       if (err != NULL) | ||||
|         { | ||||
|           meta_warning (_("Failed to open debug log: %s\n"), | ||||
|           meta_warning ("Failed to open debug log: %s\n", | ||||
|                         err->message); | ||||
|           g_error_free (err); | ||||
|           return; | ||||
| @@ -91,13 +92,13 @@ ensure_logfile (void) | ||||
|        | ||||
|       if (logfile == NULL) | ||||
|         { | ||||
|           meta_warning (_("Failed to fdopen() log file %s: %s\n"), | ||||
|           meta_warning ("Failed to fdopen() log file %s: %s\n", | ||||
|                         filename, strerror (errno)); | ||||
|           close (fd); | ||||
|         } | ||||
|       else | ||||
|         { | ||||
|           g_printerr (_("Opened log file %s\n"), filename); | ||||
|           g_printerr ("Opened log file %s\n", filename); | ||||
|         } | ||||
|        | ||||
|       g_free (filename); | ||||
| @@ -194,6 +195,18 @@ meta_set_replace_current_wm (gboolean setting) | ||||
|   replace_current = setting; | ||||
| } | ||||
|  | ||||
| gboolean | ||||
| meta_is_wayland_compositor (void) | ||||
| { | ||||
|   return is_wayland_compositor; | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_set_is_wayland_compositor (gboolean value) | ||||
| { | ||||
|   is_wayland_compositor = value; | ||||
| } | ||||
|  | ||||
| char * | ||||
| meta_g_utf8_strndup (const gchar *src, | ||||
|                      gsize        n) | ||||
| @@ -261,7 +274,7 @@ meta_debug_spew_real (const char *format, ...) | ||||
|   out = logfile ? logfile : stderr; | ||||
|    | ||||
|   if (no_prefix == 0) | ||||
|     utf8_fputs (_("Window manager: "), out); | ||||
|     utf8_fputs ("Window manager: ", out); | ||||
|   utf8_fputs (str, out); | ||||
|  | ||||
|   fflush (out); | ||||
| @@ -411,7 +424,7 @@ meta_bug (const char *format, ...) | ||||
| #endif | ||||
|  | ||||
|   if (no_prefix == 0) | ||||
|     utf8_fputs (_("Bug in window manager: "), out); | ||||
|     utf8_fputs ("Bug in window manager: ", out); | ||||
|   utf8_fputs (str, out); | ||||
|  | ||||
|   fflush (out); | ||||
| @@ -442,7 +455,7 @@ meta_warning (const char *format, ...) | ||||
| #endif | ||||
|  | ||||
|   if (no_prefix == 0) | ||||
|     utf8_fputs (_("Window manager warning: "), out); | ||||
|     utf8_fputs ("Window manager warning: ", out); | ||||
|   utf8_fputs (str, out); | ||||
|  | ||||
|   fflush (out); | ||||
| @@ -470,7 +483,7 @@ meta_fatal (const char *format, ...) | ||||
| #endif | ||||
|  | ||||
|   if (no_prefix == 0) | ||||
|     utf8_fputs (_("Window manager error: "), out); | ||||
|     utf8_fputs ("Window manager error: ", out); | ||||
|   utf8_fputs (str, out); | ||||
|  | ||||
|   fflush (out); | ||||
|   | ||||
| @@ -44,6 +44,8 @@ | ||||
| #include <X11/Xutil.h> | ||||
| #include <cairo.h> | ||||
| #include <gdk-pixbuf/gdk-pixbuf.h> | ||||
| #include <clutter/clutter.h> | ||||
| #include "meta-wayland-types.h" | ||||
|  | ||||
| typedef struct _MetaWindowQueue MetaWindowQueue; | ||||
|  | ||||
| @@ -69,6 +71,7 @@ typedef enum { | ||||
|   _NET_WM_BYPASS_COMPOSITOR_HINT_OFF = 2, | ||||
| } MetaBypassCompositorHintValue; | ||||
|  | ||||
|  | ||||
| struct _MetaWindow | ||||
| { | ||||
|   GObject parent_instance; | ||||
| @@ -77,6 +80,10 @@ struct _MetaWindow | ||||
|   MetaScreen *screen; | ||||
|   const MetaMonitorInfo *monitor; | ||||
|   MetaWorkspace *workspace; | ||||
|   MetaWindowClientType client_type; | ||||
| #ifdef HAVE_WAYLAND | ||||
|   MetaWaylandSurface *surface; | ||||
| #endif | ||||
|   Window xwindow; | ||||
|   /* may be NULL! not all windows get decorated */ | ||||
|   MetaFrame *frame; | ||||
| @@ -121,6 +128,7 @@ struct _MetaWindow | ||||
|   Window xtransient_for; | ||||
|   Window xgroup_leader; | ||||
|   Window xclient_leader; | ||||
|   MetaWindow *transient_for; | ||||
|  | ||||
|   /* Initial workspace property */ | ||||
|   int initial_workspace;   | ||||
| @@ -352,6 +360,9 @@ struct _MetaWindow | ||||
|   /* if non-NULL, the opaque region _NET_WM_OPAQUE_REGION */ | ||||
|   cairo_region_t *opaque_region; | ||||
|  | ||||
|   /* the input shape region for picking */ | ||||
|   cairo_region_t *input_region; | ||||
|  | ||||
|   /* if TRUE, the we have the new form of sync request counter which | ||||
|    * also handles application frames */ | ||||
|   guint extended_sync_request_counter : 1; | ||||
| @@ -394,6 +405,12 @@ struct _MetaWindow | ||||
|    */ | ||||
|   MetaRectangle rect; | ||||
|  | ||||
|   /* The size and position we want the window to be (i.e. what we last asked | ||||
|    * the client to configure). | ||||
|    * This is only used for wayland clients. | ||||
|    */ | ||||
|   MetaRectangle expected_rect; | ||||
|  | ||||
|   gboolean has_custom_frame_extents; | ||||
|   GtkBorder custom_frame_extents; | ||||
|  | ||||
| @@ -490,6 +507,10 @@ MetaWindow* meta_window_new_with_attrs     (MetaDisplay       *display, | ||||
|                                             gboolean           must_be_viewable, | ||||
|                                             MetaCompEffect     effect, | ||||
|                                             XWindowAttributes *attrs); | ||||
| MetaWindow *meta_window_new_for_wayland    (MetaDisplay        *display, | ||||
|                                             int                 width, | ||||
|                                             int                 height, | ||||
|                                             MetaWaylandSurface *surface); | ||||
| void        meta_window_unmanage           (MetaWindow  *window, | ||||
|                                             guint32      timestamp); | ||||
| void        meta_window_calc_showing       (MetaWindow  *window); | ||||
| @@ -587,6 +608,11 @@ void     meta_window_move_resize_request(MetaWindow *window, | ||||
|                                          int         y, | ||||
|                                          int         width, | ||||
|                                          int         height); | ||||
| void     meta_window_move_resize_wayland (MetaWindow *window, | ||||
|                                           int         width, | ||||
|                                           int         height, | ||||
|                                           int         dx, | ||||
|                                           int         dy); | ||||
| gboolean meta_window_configure_request (MetaWindow *window, | ||||
|                                         XEvent     *event); | ||||
| gboolean meta_window_property_notify   (MetaWindow *window, | ||||
| @@ -617,8 +643,8 @@ void meta_window_update_sync_request_counter (MetaWindow *window, | ||||
|                                               gint64      new_counter_value); | ||||
| #endif /* HAVE_XSYNC */ | ||||
|  | ||||
| void meta_window_handle_mouse_grab_op_event (MetaWindow *window, | ||||
|                                              XIDeviceEvent *xev); | ||||
| void meta_window_handle_mouse_grab_op_event (MetaWindow         *window, | ||||
|                                              const ClutterEvent *event); | ||||
|  | ||||
| GList* meta_window_get_workspaces (MetaWindow *window); | ||||
|  | ||||
| @@ -653,7 +679,9 @@ void meta_window_update_layer (MetaWindow *window); | ||||
|  | ||||
| void meta_window_recalc_features    (MetaWindow *window); | ||||
|  | ||||
| /* recalc_window_type is x11 only, wayland does its thing and then calls type_changed */ | ||||
| void meta_window_recalc_window_type (MetaWindow *window); | ||||
| void meta_window_type_changed       (MetaWindow *window); | ||||
|  | ||||
| void meta_window_stack_just_below (MetaWindow *window, | ||||
|                                    MetaWindow *below_this_one); | ||||
| @@ -682,8 +710,33 @@ void meta_window_set_opaque_region        (MetaWindow     *window, | ||||
|                                            cairo_region_t *region); | ||||
| void meta_window_update_opaque_region_x11 (MetaWindow *window); | ||||
|  | ||||
| void meta_window_set_input_region         (MetaWindow     *window, | ||||
|                                            cairo_region_t *region); | ||||
| void meta_window_update_input_region_x11  (MetaWindow *window); | ||||
|  | ||||
| void meta_window_set_shape_region         (MetaWindow     *window, | ||||
|                                            cairo_region_t *region); | ||||
| void meta_window_update_shape_region_x11  (MetaWindow *window); | ||||
|  | ||||
| void meta_window_set_title                (MetaWindow *window, | ||||
|                                            const char *title); | ||||
| void meta_window_set_wm_class             (MetaWindow *window, | ||||
|                                            const char *wm_class, | ||||
|                                            const char *wm_instance); | ||||
| void meta_window_set_gtk_dbus_properties  (MetaWindow *window, | ||||
|                                            const char *application_id, | ||||
|                                            const char *unique_bus_name, | ||||
|                                            const char *appmenu_path, | ||||
|                                            const char *menubar_path, | ||||
|                                            const char *application_object_path, | ||||
|                                            const char *window_object_path); | ||||
|  | ||||
| void meta_window_set_transient_for        (MetaWindow *window, | ||||
|                                            MetaWindow *parent); | ||||
|  | ||||
| void meta_window_handle_enter (MetaWindow  *window, | ||||
|                                guint32      timestamp, | ||||
|                                guint        root_x, | ||||
|                                guint        root_y); | ||||
|  | ||||
| #endif | ||||
|   | ||||
| @@ -48,6 +48,7 @@ | ||||
| #include <X11/Xatom.h> | ||||
| #include <unistd.h> | ||||
| #include <string.h> | ||||
| #include "util-private.h" | ||||
|  | ||||
| #ifndef HOST_NAME_MAX | ||||
| /* Solaris headers apparently don't define this so do so manually; #326745 */ | ||||
| @@ -344,7 +345,7 @@ reload_net_wm_pid (MetaWindow    *window, | ||||
|       gulong cardinal = (int) value->v.cardinal; | ||||
|        | ||||
|       if (cardinal <= 0) | ||||
|         meta_warning (_("Application set a bogus _NET_WM_PID %lu\n"), | ||||
|         meta_warning ("Application set a bogus _NET_WM_PID %lu\n", | ||||
|                       cardinal); | ||||
|       else | ||||
|         { | ||||
| @@ -489,28 +490,19 @@ static void | ||||
| set_window_title (MetaWindow *window, | ||||
|                   const char *title) | ||||
| { | ||||
|   char *str; | ||||
|   char *new_title = NULL; | ||||
|   | ||||
|   gboolean modified = | ||||
|     set_title_text (window, | ||||
|                     window->using_net_wm_visible_name, | ||||
|                     title, | ||||
|                     window->display->atom__NET_WM_VISIBLE_NAME, | ||||
|                     &window->title); | ||||
|                     &new_title); | ||||
|   window->using_net_wm_visible_name = modified; | ||||
|    | ||||
|   /* strndup is a hack since GNU libc has broken %.10s */ | ||||
|   str = g_strndup (window->title, 10); | ||||
|   g_free (window->desc); | ||||
|   window->desc = g_strdup_printf ("0x%lx (%s)", window->xwindow, str); | ||||
|   g_free (str); | ||||
|   meta_window_set_title (window, new_title); | ||||
|  | ||||
|   if (window->frame) | ||||
|     meta_ui_set_frame_title (window->screen->ui, | ||||
|                              window->frame->xwindow, | ||||
|                              window->title); | ||||
|  | ||||
|   g_object_notify (G_OBJECT (window), "title"); | ||||
|   g_free (new_title); | ||||
| } | ||||
|  | ||||
| static void | ||||
| @@ -875,23 +867,15 @@ reload_wm_class (MetaWindow    *window, | ||||
|                  MetaPropValue *value, | ||||
|                  gboolean       initial) | ||||
| { | ||||
|   if (window->res_class) | ||||
|     g_free (window->res_class); | ||||
|   if (window->res_name) | ||||
|     g_free (window->res_name); | ||||
|  | ||||
|   window->res_class = NULL; | ||||
|   window->res_name = NULL; | ||||
|  | ||||
|   if (value->type != META_PROP_VALUE_INVALID) | ||||
|     {  | ||||
|       if (value->v.class_hint.res_name) | ||||
|         window->res_name = g_strdup (value->v.class_hint.res_name); | ||||
|  | ||||
|       if (value->v.class_hint.res_class) | ||||
|         window->res_class = g_strdup (value->v.class_hint.res_class); | ||||
|  | ||||
|       g_object_notify (G_OBJECT (window), "wm-class"); | ||||
|     { | ||||
|       meta_window_set_wm_class (window, | ||||
|                                 value->v.class_hint.res_class, | ||||
|                                 value->v.class_hint.res_name); | ||||
|     } | ||||
|   else | ||||
|     { | ||||
|       meta_window_set_wm_class (window, NULL, NULL); | ||||
|     } | ||||
|  | ||||
|   meta_verbose ("Window %s class: '%s' name: '%s'\n", | ||||
| @@ -1534,7 +1518,7 @@ reload_transient_for (MetaWindow    *window, | ||||
|                       gboolean       initial) | ||||
| { | ||||
|   MetaWindow *parent = NULL; | ||||
|   Window transient_for, old_transient_for; | ||||
|   Window transient_for; | ||||
|  | ||||
|   if (value->type != META_PROP_VALUE_INVALID) | ||||
|     { | ||||
| @@ -1543,8 +1527,7 @@ reload_transient_for (MetaWindow    *window, | ||||
|       parent = meta_display_lookup_x_window (window->display, transient_for); | ||||
|       if (!parent) | ||||
|         { | ||||
|           meta_warning (_("Invalid WM_TRANSIENT_FOR window 0x%lx specified " | ||||
|                           "for %s.\n"), | ||||
|           meta_warning ("Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n", | ||||
|                         transient_for, window->desc); | ||||
|           transient_for = None; | ||||
|         } | ||||
| @@ -1554,8 +1537,7 @@ reload_transient_for (MetaWindow    *window, | ||||
|         { | ||||
|           if (parent == window) | ||||
|             { | ||||
|               meta_warning (_("WM_TRANSIENT_FOR window 0x%lx for %s " | ||||
|                               "would create loop.\n"), | ||||
|               meta_warning ("WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n", | ||||
|                             transient_for, window->desc); | ||||
|               transient_for = None; | ||||
|               break; | ||||
| @@ -1571,10 +1553,6 @@ reload_transient_for (MetaWindow    *window, | ||||
|   if (transient_for == window->xtransient_for) | ||||
|     return; | ||||
|  | ||||
|   if (meta_window_appears_focused (window) && window->xtransient_for != None) | ||||
|     meta_window_propagate_focus_appearance (window, FALSE); | ||||
|  | ||||
|   old_transient_for = window->xtransient_for; | ||||
|   window->xtransient_for = transient_for; | ||||
|  | ||||
|   window->transient_parent_is_root_window = | ||||
| @@ -1586,46 +1564,14 @@ reload_transient_for (MetaWindow    *window, | ||||
|   else | ||||
|     meta_verbose ("Window %s is not transient\n", window->desc); | ||||
|  | ||||
|   /* may now be a dialog */ | ||||
|   meta_window_recalc_window_type (window); | ||||
|  | ||||
|   if (!window->constructing) | ||||
|   if (window->transient_parent_is_root_window || window->xtransient_for == None) | ||||
|     meta_window_set_transient_for (window, NULL); | ||||
|   else | ||||
|     { | ||||
|       /* If the window attaches, detaches, or changes attached | ||||
|        * parents, we need to destroy the MetaWindow and let a new one | ||||
|        * be created (which happens as a side effect of | ||||
|        * meta_window_unmanage()). The condition below is correct | ||||
|        * because we know window->xtransient_for has changed. | ||||
|        */ | ||||
|       if (window->attached || meta_window_should_attach_to_parent (window)) | ||||
|         { | ||||
|           guint32 timestamp; | ||||
|  | ||||
|           window->xtransient_for = old_transient_for; | ||||
|           timestamp = meta_display_get_current_time_roundtrip (window->display); | ||||
|           meta_window_unmanage (window, timestamp); | ||||
|           return; | ||||
|         } | ||||
|       parent = meta_display_lookup_x_window (window->display, | ||||
|                                              window->xtransient_for); | ||||
|       meta_window_set_transient_for (window, parent); | ||||
|     } | ||||
|  | ||||
|   /* update stacking constraints */ | ||||
|   if (!window->override_redirect) | ||||
|     meta_stack_update_transient (window->screen->stack, window); | ||||
|  | ||||
|   /* possibly change its group. We treat being a window's transient as | ||||
|    * equivalent to making it your group leader, to work around shortcomings | ||||
|    * in programs such as xmms-- see #328211. | ||||
|    */ | ||||
|   if (window->xtransient_for != None && | ||||
|       window->xgroup_leader != None && | ||||
|       window->xtransient_for != window->xgroup_leader) | ||||
|     meta_window_group_leader_changed (window); | ||||
|  | ||||
|   if (!window->constructing && !window->override_redirect) | ||||
|     meta_window_queue (window, META_QUEUE_MOVE_RESIZE); | ||||
|  | ||||
|   if (meta_window_appears_focused (window) && window->xtransient_for != None) | ||||
|     meta_window_propagate_focus_appearance (window, TRUE); | ||||
| } | ||||
|  | ||||
| static void | ||||
|   | ||||
							
								
								
									
										1939
									
								
								src/core/window.c
									
									
									
									
									
								
							
							
						
						
									
										1939
									
								
								src/core/window.c
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -83,7 +83,7 @@ from The Open Group. | ||||
| #include <config.h> | ||||
| #include "xprops.h" | ||||
| #include <meta/errors.h> | ||||
| #include <meta/util.h> | ||||
| #include "util-private.h" | ||||
| #include "async-getprop.h" | ||||
| #include "ui.h" | ||||
| #include "mutter-Xatomtype.h" | ||||
| @@ -152,7 +152,7 @@ validate_or_free_results (GetPropertyResults *results, | ||||
|   if (res_name == NULL) | ||||
|     res_name = "unknown"; | ||||
|    | ||||
|   meta_warning (_("Window 0x%lx has property %s\nthat was expected to have type %s format %d\nand actually has type %s format %d n_items %d.\nThis is most likely an application bug, not a window manager bug.\nThe window has title=\"%s\" class=\"%s\" name=\"%s\"\n"), | ||||
|   meta_warning ("Window 0x%lx has property %s\nthat was expected to have type %s format %d\nand actually has type %s format %d n_items %d.\nThis is most likely an application bug, not a window manager bug.\nThe window has title=\"%s\" class=\"%s\" name=\"%s\"\n", | ||||
|                 results->xwindow, | ||||
|                 prop_name ? prop_name : "(bad atom)", | ||||
|                 expected_name ? expected_name : "(bad atom)", | ||||
| @@ -408,7 +408,7 @@ utf8_string_from_results (GetPropertyResults *results, | ||||
|       char *name; | ||||
|  | ||||
|       name = XGetAtomName (results->display->xdisplay, results->xatom); | ||||
|       meta_warning (_("Property %s on window 0x%lx contained invalid UTF-8\n"), | ||||
|       meta_warning ("Property %s on window 0x%lx contained invalid UTF-8\n", | ||||
|                     name, results->xwindow); | ||||
|       meta_XFree (name); | ||||
|       XFree (results->prop); | ||||
| @@ -491,7 +491,7 @@ utf8_list_from_results (GetPropertyResults *results, | ||||
|           meta_error_trap_push (results->display); | ||||
|           name = XGetAtomName (results->display->xdisplay, results->xatom); | ||||
|           meta_error_trap_pop (results->display); | ||||
|           meta_warning (_("Property %s on window 0x%lx contained invalid UTF-8 for item %d in the list\n"), | ||||
|           meta_warning ("Property %s on window 0x%lx contained invalid UTF-8 for item %d in the list\n", | ||||
|                         name, results->xwindow, i); | ||||
|           meta_XFree (name); | ||||
|           meta_XFree (results->prop); | ||||
| @@ -536,6 +536,81 @@ meta_prop_get_utf8_list (MetaDisplay   *display, | ||||
|   return utf8_list_from_results (&results, str_p, n_str_p); | ||||
| } | ||||
|  | ||||
| /* this one freakishly returns g_malloc memory */ | ||||
| static gboolean | ||||
| latin1_list_from_results (GetPropertyResults *results, | ||||
|                         char             ***str_p, | ||||
|                         int                *n_str_p) | ||||
| { | ||||
|   int i; | ||||
|   int n_strings; | ||||
|   char **retval; | ||||
|   const char *p; | ||||
|    | ||||
|   *str_p = NULL; | ||||
|   *n_str_p = 0; | ||||
|  | ||||
|   if (!validate_or_free_results (results, 8, XA_STRING, FALSE)) | ||||
|     return FALSE; | ||||
|    | ||||
|   /* I'm not sure this is right, but I'm guessing the | ||||
|    * property is nul-separated | ||||
|    */ | ||||
|   i = 0; | ||||
|   n_strings = 0; | ||||
|   while (i < (int) results->n_items) | ||||
|     { | ||||
|       if (results->prop[i] == '\0') | ||||
|         ++n_strings; | ||||
|       ++i; | ||||
|     } | ||||
|  | ||||
|   if (results->prop[results->n_items - 1] != '\0') | ||||
|     ++n_strings; | ||||
|   | ||||
|   /* we're guaranteed that results->prop has a nul on the end | ||||
|    * by XGetWindowProperty | ||||
|    */ | ||||
|    | ||||
|   retval = g_new0 (char*, n_strings + 1); | ||||
|  | ||||
|   p = (char *)results->prop; | ||||
|   i = 0; | ||||
|   while (i < n_strings) | ||||
|     { | ||||
|       retval[i] = g_strdup (p); | ||||
|        | ||||
|       p = p + strlen (p) + 1; | ||||
|       ++i; | ||||
|     } | ||||
|    | ||||
|   *str_p = retval; | ||||
|   *n_str_p = i; | ||||
|  | ||||
|   meta_XFree (results->prop); | ||||
|   results->prop = NULL; | ||||
|  | ||||
|   return TRUE; | ||||
| } | ||||
|  | ||||
| gboolean | ||||
| meta_prop_get_latin1_list (MetaDisplay   *display, | ||||
|                            Window         xwindow, | ||||
|                            Atom           xatom, | ||||
|                            char        ***str_p, | ||||
|                            int           *n_str_p) | ||||
| { | ||||
|   GetPropertyResults results; | ||||
|  | ||||
|   *str_p = NULL; | ||||
|  | ||||
|   if (!get_property (display, xwindow, xatom, | ||||
|                      XA_STRING, &results)) | ||||
|     return FALSE; | ||||
|  | ||||
|   return latin1_list_from_results (&results, str_p, n_str_p); | ||||
| } | ||||
|  | ||||
| void | ||||
| meta_prop_set_utf8_string_hint (MetaDisplay *display, | ||||
|                                 Window xwindow, | ||||
|   | ||||
| @@ -102,6 +102,11 @@ gboolean meta_prop_get_utf8_list     (MetaDisplay   *display, | ||||
|                                       Atom           xatom, | ||||
|                                       char        ***str_p, | ||||
|                                       int           *n_str_p); | ||||
| gboolean meta_prop_get_latin1_list   (MetaDisplay   *display, | ||||
|                                       Window         xwindow, | ||||
|                                       Atom           xatom, | ||||
|                                       char        ***str_p, | ||||
|                                       int           *n_str_p); | ||||
| void     meta_prop_set_utf8_string_hint | ||||
|                                      (MetaDisplay *display, | ||||
|                                       Window xwindow, | ||||
|   | ||||
							
								
								
									
										18
									
								
								src/libmutter-wayland.pc.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								src/libmutter-wayland.pc.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| prefix=@prefix@ | ||||
| exec_prefix=@exec_prefix@ | ||||
| libdir=@libdir@ | ||||
| includedir=@includedir@ | ||||
| girdir=@libdir@/mutter-wayland | ||||
| typelibdir=@libdir@/mutter-wayland | ||||
|  | ||||
| mutter_major_version=@MUTTER_MAJOR_VERSION@ | ||||
| mutter_minor_version=@MUTTER_MINOR_VERSION@ | ||||
| mutter_micro_version=@MUTTER_MICRO_VERSION@ | ||||
| mutter_plugin_api_version=@MUTTER_PLUGIN_API_VERSION@ | ||||
|  | ||||
| Name: libmutter-wayland | ||||
| Description: Mutter window manager library (Wayland branch) | ||||
| Requires: gsettings-desktop-schemas gtk+-3.0 @CLUTTER_PACKAGE@ x11 wayland-server | ||||
| Version: @VERSION@ | ||||
| Libs: -L${libdir} -lmutter-wayland | ||||
| Cflags: -I${includedir}/mutter-wayland -DMUTTER_MAJOR_VERSION=${mutter_major_version} -DMUTTER_MINOR_VERSION=${mutter_minor_version} -DMUTTER_MICRO_VERSION=${mutter_micro_version} -DMUTTER_PLUGIN_API_VERSION=${mutter_plugin_api_version} | ||||
| @@ -1,18 +0,0 @@ | ||||
| prefix=@prefix@ | ||||
| exec_prefix=@exec_prefix@ | ||||
| libdir=@libdir@ | ||||
| includedir=@includedir@ | ||||
| girdir=@libdir@/mutter | ||||
| typelibdir=@libdir@/mutter | ||||
|  | ||||
| mutter_major_version=@MUTTER_MAJOR_VERSION@ | ||||
| mutter_minor_version=@MUTTER_MINOR_VERSION@ | ||||
| mutter_micro_version=@MUTTER_MICRO_VERSION@ | ||||
| mutter_plugin_api_version=@MUTTER_PLUGIN_API_VERSION@ | ||||
|  | ||||
| Name: libmutter | ||||
| Description: Mutter window manager library | ||||
| Requires: gsettings-desktop-schemas gtk+-3.0 @CLUTTER_PACKAGE@ x11 | ||||
| Version: @VERSION@ | ||||
| Libs: -L${libdir} -lmutter | ||||
| Cflags: -I${includedir}/mutter -DMUTTER_MAJOR_VERSION=${mutter_major_version} -DMUTTER_MINOR_VERSION=${mutter_minor_version} -DMUTTER_MICRO_VERSION=${mutter_micro_version} -DMUTTER_PLUGIN_API_VERSION=${mutter_plugin_api_version} | ||||
| @@ -81,6 +81,7 @@ item(TIMESTAMP) | ||||
| item(VERSION) | ||||
| item(ATOM_PAIR) | ||||
| item(BACKLIGHT) | ||||
| item(_XKB_RULES_NAMES) | ||||
|  | ||||
| /* Oddities: These are used, and we need atoms for them, | ||||
|  * but when we need all _NET_WM hints (i.e. when we're making | ||||
|   | ||||
| @@ -31,6 +31,7 @@ | ||||
| #include <X11/Xlib.h> | ||||
| #include <X11/extensions/XInput.h> | ||||
| #include <X11/extensions/XInput2.h> | ||||
| #include <clutter/clutter.h> | ||||
| #include <glib.h> | ||||
| #include <gtk/gtk.h> | ||||
|  | ||||
|   | ||||
| @@ -35,13 +35,6 @@ gboolean meta_keybindings_set_custom_handler (const gchar        *name, | ||||
| 					      gpointer            user_data, | ||||
| 					      GDestroyNotify      free_data); | ||||
|  | ||||
| void meta_keybindings_switch_window (MetaDisplay    *display, | ||||
| 				     MetaScreen     *screen, | ||||
| 				     MetaWindow     *event_window, | ||||
|                                      XIDeviceEvent  *event, | ||||
| 				     MetaKeyBinding *binding); | ||||
|  | ||||
|  | ||||
| void     meta_screen_ungrab_all_keys (MetaScreen *screen, guint32 timestamp); | ||||
| gboolean meta_screen_grab_all_keys (MetaScreen *screen, guint32 timestamp); | ||||
| #endif | ||||
|   | ||||
| @@ -64,8 +64,6 @@ struct _MetaShapedTexture | ||||
|  | ||||
| GType meta_shaped_texture_get_type (void) G_GNUC_CONST; | ||||
|  | ||||
| ClutterActor *meta_shaped_texture_new (void); | ||||
|  | ||||
| void meta_shaped_texture_set_create_mipmaps (MetaShapedTexture *stex, | ||||
| 					     gboolean           create_mipmaps); | ||||
|  | ||||
| @@ -76,13 +74,12 @@ gboolean meta_shaped_texture_update_area (MetaShapedTexture *stex, | ||||
|                                           int                height, | ||||
|                                           cairo_region_t    *unobscured_region); | ||||
|  | ||||
| void meta_shaped_texture_set_pixmap (MetaShapedTexture *stex, | ||||
|                                      Pixmap             pixmap); | ||||
|  | ||||
| CoglTexture * meta_shaped_texture_get_texture (MetaShapedTexture *stex); | ||||
|  | ||||
| void meta_shaped_texture_set_mask_texture (MetaShapedTexture *stex, | ||||
|                                            CoglTexture       *mask_texture); | ||||
| void meta_shaped_texture_set_input_shape_region (MetaShapedTexture *stex, | ||||
|                                                  cairo_region_t    *shape_region); | ||||
|  | ||||
| void meta_shaped_texture_set_clip_region (MetaShapedTexture *stex, | ||||
| 					  cairo_region_t    *clip_region); | ||||
|   | ||||
| @@ -391,17 +391,17 @@ struct _MetaKeyCombo | ||||
|  * @display: a #MetaDisplay | ||||
|  * @screen: a #MetaScreen | ||||
|  * @window: a #MetaWindow | ||||
|  * @event: (type gpointer): a #XIDeviceEvent | ||||
|  * @event: a #ClutterKeyEvent | ||||
|  * @binding: a #MetaKeyBinding | ||||
|  * @user_data: data passed to the function | ||||
|  * | ||||
|  */ | ||||
| typedef void (* MetaKeyHandlerFunc) (MetaDisplay    *display, | ||||
|                                      MetaScreen     *screen, | ||||
|                                      MetaWindow     *window, | ||||
|                                      XIDeviceEvent  *event, | ||||
|                                      MetaKeyBinding *binding, | ||||
|                                      gpointer        user_data); | ||||
| typedef void (* MetaKeyHandlerFunc) (MetaDisplay     *display, | ||||
|                                      MetaScreen      *screen, | ||||
|                                      MetaWindow      *window, | ||||
|                                      ClutterKeyEvent *event, | ||||
|                                      MetaKeyBinding  *binding, | ||||
|                                      gpointer         user_data); | ||||
|  | ||||
| typedef struct _MetaKeyHandler MetaKeyHandler; | ||||
|  | ||||
|   | ||||
| @@ -31,12 +31,9 @@ | ||||
| #include <meta/common.h> | ||||
|  | ||||
| gboolean meta_is_verbose  (void); | ||||
| void     meta_set_verbose (gboolean setting); | ||||
| gboolean meta_is_debugging (void); | ||||
| void     meta_set_debugging (gboolean setting); | ||||
| gboolean meta_is_syncing (void); | ||||
| void     meta_set_syncing (gboolean setting); | ||||
| void     meta_set_replace_current_wm (gboolean setting); | ||||
| gboolean meta_is_wayland_compositor (void); | ||||
|  | ||||
| void meta_debug_spew_real (const char *format, | ||||
|                            ...) G_GNUC_PRINTF (1, 2); | ||||
| @@ -122,10 +119,6 @@ const char* meta_gravity_to_string (int gravity); | ||||
|  | ||||
| char* meta_external_binding_name_for_action (guint keybinding_action); | ||||
|  | ||||
| #include <libintl.h> | ||||
| #define _(x) dgettext (GETTEXT_PACKAGE, x) | ||||
| #define N_(x) x | ||||
|  | ||||
| char* meta_g_utf8_strndup (const gchar *src, gsize n); | ||||
|  | ||||
| void  meta_free_gslist_and_elements (GSList *list_to_deep_free); | ||||
|   | ||||
| @@ -81,6 +81,16 @@ typedef enum | ||||
|   META_MAXIMIZE_VERTICAL   = 1 << 1 | ||||
| } MetaMaximizeFlags; | ||||
|  | ||||
| /** | ||||
|  * MetaWindowClientType: | ||||
|  * @META_WINDOW_CLIENT_TYPE_WAYLAND: A Wayland based window | ||||
|  * @META_WINDOW_CLIENT_TYPE_X11: An X11 based window | ||||
|  */ | ||||
| typedef enum { | ||||
|   META_WINDOW_CLIENT_TYPE_WAYLAND, | ||||
|   META_WINDOW_CLIENT_TYPE_X11 | ||||
| } MetaWindowClientType; | ||||
|  | ||||
| #define META_TYPE_WINDOW            (meta_window_get_type ()) | ||||
| #define META_WINDOW(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_WINDOW, MetaWindow)) | ||||
| #define META_WINDOW_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass),  META_TYPE_WINDOW, MetaWindowClass)) | ||||
| @@ -140,8 +150,7 @@ void meta_window_unset_demands_attention (MetaWindow *window); | ||||
| const char* meta_window_get_startup_id (MetaWindow *window); | ||||
| void meta_window_change_workspace_by_index (MetaWindow *window, | ||||
|                                             gint        space_index, | ||||
|                                             gboolean    append, | ||||
|                                             guint32     timestamp); | ||||
|                                             gboolean    append); | ||||
| void meta_window_change_workspace          (MetaWindow  *window, | ||||
|                                             MetaWorkspace *workspace); | ||||
| GObject *meta_window_get_compositor_private (MetaWindow *window); | ||||
|   | ||||
| @@ -1,17 +0,0 @@ | ||||
| prefix=@prefix@ | ||||
| exec_prefix=@exec_prefix@ | ||||
| libdir=@libdir@ | ||||
| includedir=@includedir@ | ||||
| plugindir=@MUTTER_PLUGIN_DIR@ | ||||
| libgnome_serverdir=@libexecdir@ | ||||
| mutter_major_version=@MUTTER_MAJOR_VERSION@ | ||||
| mutter_minor_version=@MUTTER_MINOR_VERSION@ | ||||
| mutter_micro_version=@MUTTER_MICRO_VERSION@ | ||||
| mutter_plugin_api_version=@MUTTER_PLUGIN_API_VERSION@ | ||||
|  | ||||
| Name: mutter-plugins | ||||
| Description: Dev parameters for mutter plugins | ||||
| Requires: @CLUTTER_PACKAGE@ | ||||
| Version: @VERSION@ | ||||
| Libs: @CLUTTER_LIBS@ | ||||
| Cflags: @CLUTTER_CFLAGS@ -DWITH_CLUTTER -I${includedir}/mutter/mutter-private -DMUTTER_MAJOR_VERSION=${mutter_major_version} -DMUTTER_MINOR_VERSION=${mutter_minor_version} -DMUTTER_MICRO_VERSION=${mutter_micro_version} -DMUTTER_PLUGIN_API_VERSION=${mutter_plugin_api_version} -DMUTTER_PLUGIN_DIR=\"${plugindir}\" | ||||
| @@ -1,7 +1,7 @@ | ||||
| [Desktop Entry] | ||||
| Type=Application | ||||
| _Name=Mutter | ||||
| Exec=mutter | ||||
| _Name=Mutter (wayland compositor) | ||||
| Exec=mutter-launch -- mutter --wayland | ||||
| NoDisplay=true | ||||
| # name of loadable control center module | ||||
| X-GNOME-WMSettingsModule=metacity | ||||
| @@ -12,6 +12,5 @@ X-GnomeWMSettingsLibrary=metacity | ||||
| X-GNOME-Bugzilla-Bugzilla=GNOME | ||||
| X-GNOME-Bugzilla-Product=mutter | ||||
| X-GNOME-Bugzilla-Component=general | ||||
| X-GNOME-Autostart-Phase=WindowManager | ||||
| X-GNOME-Provides=windowmanager | ||||
| X-GNOME-Autostart-Phase=DisplayServer | ||||
| X-GNOME-Autostart-Notify=true | ||||
| @@ -1,20 +0,0 @@ | ||||
| [Desktop Entry] | ||||
| Type=Application | ||||
| _Name=Mutter | ||||
| Exec=mutter | ||||
| # name of loadable control center module | ||||
| X-GNOME-WMSettingsModule=metacity | ||||
| # name we put on the WM spec check window | ||||
| X-GNOME-WMName=Mutter | ||||
| # back compat only  | ||||
| X-GnomeWMSettingsLibrary=metacity | ||||
| X-GNOME-Bugzilla-Bugzilla=GNOME | ||||
| X-GNOME-Bugzilla-Product=mutter | ||||
| X-GNOME-Bugzilla-Component=general | ||||
| X-GNOME-Autostart-Phase=WindowManager | ||||
| X-GNOME-Provides=windowmanager | ||||
| X-GNOME-Autostart-Notify=true | ||||
|  | ||||
| [Window Manager] | ||||
| SessionManaged=true | ||||
|  | ||||
							
								
								
									
										33
									
								
								src/org.gnome.mutter.wayland.gschema.xml.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								src/org.gnome.mutter.wayland.gschema.xml.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| <schemalist> | ||||
|   <schema id="org.gnome.mutter.wayland.keybindings" path="/org/gnome/mutter/wayland/keybindings/" | ||||
| 	  gettext-domain="@GETTEXT_DOMAIN@"> | ||||
|     <key name="switch-to-session-1" type="as"> | ||||
|       <default><![CDATA[['<Primary><Alt>F1']]]></default> | ||||
|       <_summary>Switch to VT 1</_summary> | ||||
|     </key> | ||||
|     <key name="switch-to-session-2" type="as"> | ||||
|       <default><![CDATA[['<Primary><Alt>F2']]]></default> | ||||
|       <_summary>Switch to VT 2</_summary> | ||||
|     </key> | ||||
|     <key name="switch-to-session-3" type="as"> | ||||
|       <default><![CDATA[['<Primary><Alt>F3']]]></default> | ||||
|       <_summary>Switch to VT 3</_summary> | ||||
|     </key> | ||||
|     <key name="switch-to-session-4" type="as"> | ||||
|       <default><![CDATA[['<Primary><Alt>F4']]]></default> | ||||
|       <_summary>Switch to VT 4</_summary> | ||||
|     </key> | ||||
|     <key name="switch-to-session-5" type="as"> | ||||
|       <default><![CDATA[['<Primary><Alt>F5']]]></default> | ||||
|       <_summary>Switch to VT 5</_summary> | ||||
|     </key> | ||||
|     <key name="switch-to-session-6" type="as"> | ||||
|       <default><![CDATA[['<Primary><Alt>F6']]]></default> | ||||
|       <_summary>Switch to VT 6</_summary> | ||||
|     </key> | ||||
|     <key name="switch-to-session-7" type="as"> | ||||
|       <default><![CDATA[['<Primary><Alt>F7']]]></default> | ||||
|       <_summary>Switch to VT 7</_summary> | ||||
|     </key> | ||||
|   </schema> | ||||
| </schemalist> | ||||
| @@ -28,7 +28,7 @@ | ||||
| #include <string.h> | ||||
| #include "menu.h" | ||||
| #include <meta/main.h> | ||||
| #include <meta/util.h> | ||||
| #include "util-private.h" | ||||
| #include "core.h" | ||||
| #include "metaaccellabel.h" | ||||
| #include "ui.h" | ||||
|   | ||||
| @@ -35,7 +35,7 @@ | ||||
| #include "metaaccellabel.h" | ||||
| #include <gtk/gtk.h> | ||||
| #include <string.h> | ||||
| #include <meta/util.h> | ||||
| #include "util-private.h" | ||||
|  | ||||
| static void     meta_accel_label_destroy      (GtkWidget           *object); | ||||
| static void     meta_accel_label_finalize     (GObject             *object); | ||||
|   | ||||
| @@ -23,7 +23,7 @@ | ||||
|  | ||||
| #include <config.h> | ||||
| #include "resizepopup.h" | ||||
| #include <meta/util.h> | ||||
| #include "util-private.h" | ||||
| #include <gtk/gtk.h> | ||||
| #include <gdk/gdkx.h> | ||||
|  | ||||
|   | ||||
| @@ -23,7 +23,7 @@ | ||||
|  | ||||
| #include <config.h> | ||||
| #include "theme-private.h" | ||||
| #include <meta/util.h> | ||||
| #include "util-private.h" | ||||
| #include <string.h> | ||||
| #include <stdlib.h> | ||||
|  | ||||
|   | ||||
| @@ -39,7 +39,7 @@ | ||||
| #include <config.h> | ||||
| #include "theme-private.h" | ||||
| #include "frames.h" /* for META_TYPE_FRAMES */ | ||||
| #include <meta/util.h> | ||||
| #include "util-private.h" | ||||
| #include <meta/gradient.h> | ||||
| #include <meta/prefs.h> | ||||
| #include <gtk/gtk.h> | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user