Compare commits
	
		
			655 Commits
		
	
	
		
			wip/waylan
			...
			3.11.92-wa
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					56e8c3b625 | ||
| 
						 | 
					ce3d9fb89f | ||
| 
						 | 
					27c018ab98 | ||
| 
						 | 
					a1427c7130 | ||
| 
						 | 
					91ad92c968 | ||
| 
						 | 
					f0c7b518e6 | ||
| 
						 | 
					5fa5ace5e6 | ||
| 
						 | 
					044c06bff3 | ||
| 
						 | 
					a3ccc4fd1c | ||
| 
						 | 
					0a20f7458c | ||
| 
						 | 
					9c94f8ae47 | ||
| 
						 | 
					f940292cfe | ||
| 
						 | 
					48a36356dd | ||
| 
						 | 
					f05983be42 | ||
| 
						 | 
					dfcefd3315 | ||
| 
						 | 
					3fe755e684 | ||
| 
						 | 
					0eb86de807 | ||
| 
						 | 
					ff635bad3b | ||
| 
						 | 
					43a409dec4 | ||
| 
						 | 
					b087fce062 | ||
| 
						 | 
					420f322910 | ||
| 
						 | 
					4bf6e0ae8c | ||
| 
						 | 
					97872e70a5 | ||
| 
						 | 
					be57308663 | ||
| 
						 | 
					33f1bd96f5 | ||
| 
						 | 
					9ba49358e5 | ||
| 
						 | 
					8b2b65246a | ||
| 
						 | 
					4fdbb466e1 | ||
| 
						 | 
					da48b18188 | ||
| 
						 | 
					a5f1790828 | ||
| 
						 | 
					6efcf2526d | ||
| 
						 | 
					d6a27195d3 | ||
| 
						 | 
					8f151842fb | ||
| 
						 | 
					6f7023bc6b | ||
| 
						 | 
					63b158e4da | ||
| 
						 | 
					b3364cad3e | ||
| 
						 | 
					3502cfba34 | ||
| 
						 | 
					5cc6becb63 | ||
| 
						 | 
					ae8f21a3dc | ||
| 
						 | 
					0cdf3bd383 | ||
| 
						 | 
					3de58189c0 | ||
| 
						 | 
					5270c469a3 | ||
| 
						 | 
					7504f16e59 | ||
| 
						 | 
					cdb7947dd1 | ||
| 
						 | 
					cdfc6f5b53 | ||
| 
						 | 
					fcb2ab41b2 | ||
| 
						 | 
					f5bd7c5f50 | ||
| 
						 | 
					cb549154aa | ||
| 
						 | 
					ada9610e30 | ||
| 
						 | 
					f11bf44525 | ||
| 
						 | 
					1f15c85c00 | ||
| 
						 | 
					8b4c5459c0 | ||
| 
						 | 
					d07d5d1328 | ||
| 
						 | 
					535685742a | ||
| 
						 | 
					62e45b6d5e | ||
| 
						 | 
					3c6dd5bf6d | ||
| 
						 | 
					0f85986340 | ||
| 
						 | 
					93ac0329db | ||
| 
						 | 
					c539dfe0d7 | ||
| 
						 | 
					1502d2a79f | ||
| 
						 | 
					a9d8107c3d | ||
| 
						 | 
					a5d2c51392 | ||
| 
						 | 
					d1ea17e6a4 | ||
| 
						 | 
					b37ad66e9d | ||
| 
						 | 
					c1f15348a5 | ||
| 
						 | 
					857561baed | ||
| 
						 | 
					a44cc9ef47 | ||
| 
						 | 
					d47b7ba038 | ||
| 
						 | 
					f21312e2fd | ||
| 
						 | 
					394af33607 | ||
| 
						 | 
					7314cdac94 | ||
| 
						 | 
					81025e37ea | ||
| 
						 | 
					1bb9f1e333 | ||
| 
						 | 
					b11c75c1c9 | ||
| 
						 | 
					757b626aee | ||
| 
						 | 
					fb3df5243f | ||
| 
						 | 
					e34792d9f0 | ||
| 
						 | 
					f397c32192 | ||
| 
						 | 
					f79314d7b5 | ||
| 
						 | 
					55c61259d8 | ||
| 
						 | 
					5298cf0a3a | ||
| 
						 | 
					f1dc1a0cbc | ||
| 
						 | 
					2cf80bc647 | ||
| 
						 | 
					40c15f6e2a | ||
| 
						 | 
					a8849621c9 | ||
| 
						 | 
					49c0be11d6 | ||
| 
						 | 
					9df8e831be | ||
| 
						 | 
					84c6b2a3fa | ||
| 
						 | 
					06cd669ccb | ||
| 
						 | 
					81eb7d9537 | ||
| 
						 | 
					dd8d8e436d | ||
| 
						 | 
					d6b6b363ad | ||
| 
						 | 
					254e2e993c | ||
| 
						 | 
					c595a9c29f | ||
| 
						 | 
					dfc7f7222b | ||
| 
						 | 
					ef278eb547 | ||
| 
						 | 
					38e26e5cc3 | ||
| 
						 | 
					9773a879c3 | ||
| 
						 | 
					abd2abcde6 | ||
| 
						 | 
					a8f4651c72 | ||
| 
						 | 
					54df7934ea | ||
| 
						 | 
					9052efb0d9 | ||
| 
						 | 
					b346f98eb0 | ||
| 
						 | 
					365af53797 | ||
| 
						 | 
					bee59ec0e1 | ||
| 
						 | 
					91384a32b4 | ||
| 
						 | 
					72bd5fb814 | ||
| 
						 | 
					46af3ef9f6 | ||
| 
						 | 
					d417c615d5 | ||
| 
						 | 
					46cbd0bf48 | ||
| 
						 | 
					f3b6fead4d | ||
| 
						 | 
					80de8ec643 | ||
| 
						 | 
					4f7e2a9f3f | ||
| 
						 | 
					701e06d55d | ||
| 
						 | 
					94f39a493f | ||
| 
						 | 
					ddc171220a | ||
| 
						 | 
					0313b38dd6 | ||
| 
						 | 
					d41fba6558 | ||
| 
						 | 
					770b58b367 | ||
| 
						 | 
					77838c2ca3 | ||
| 
						 | 
					e56cbfbd0f | ||
| 
						 | 
					a27fb19473 | ||
| 
						 | 
					674bcef6da | ||
| 
						 | 
					86c1c30245 | ||
| 
						 | 
					283546b379 | ||
| 
						 | 
					98e3e5e50f | ||
| 
						 | 
					b6a0d4d368 | ||
| 
						 | 
					28859c604f | ||
| 
						 | 
					9e51d98f4a | ||
| 
						 | 
					268a4c92ba | ||
| 
						 | 
					71367e14d5 | ||
| 
						 | 
					5c99eae8a9 | ||
| 
						 | 
					89aa5df711 | ||
| 
						 | 
					b9a5d710b7 | ||
| 
						 | 
					65dd54a4db | ||
| 
						 | 
					b00fa70d91 | ||
| 
						 | 
					360d423faa | ||
| 
						 | 
					394b44a2c2 | ||
| 
						 | 
					ed6821a819 | ||
| 
						 | 
					23b0f7be43 | ||
| 
						 | 
					7f195aec7a | ||
| 
						 | 
					da13e3d237 | ||
| 
						 | 
					75184d4c55 | ||
| 
						 | 
					eb75306f8a | ||
| 
						 | 
					98c4b82907 | ||
| 
						 | 
					640102c03b | ||
| 
						 | 
					c0d791cd6e | ||
| 
						 | 
					41d5e69de5 | ||
| 
						 | 
					2dc7371944 | ||
| 
						 | 
					ec2c3e1438 | ||
| 
						 | 
					c5c3806a04 | ||
| 
						 | 
					ac0c7df4a3 | ||
| 
						 | 
					d85845426c | ||
| 
						 | 
					060e60f2a0 | ||
| 
						 | 
					26cf75d5a4 | ||
| 
						 | 
					9f5087e97d | ||
| 
						 | 
					45624f2edf | ||
| 
						 | 
					153f843ea6 | ||
| 
						 | 
					f0cd9b0687 | ||
| 
						 | 
					1783bf20ec | ||
| 
						 | 
					9b24ae2033 | ||
| 
						 | 
					0be4622e14 | ||
| 
						 | 
					bcd5446cdc | ||
| 
						 | 
					04b5232960 | ||
| 
						 | 
					f860df4b2d | ||
| 
						 | 
					ff8c4b1bcf | ||
| 
						 | 
					337c69e223 | ||
| 
						 | 
					14841475b5 | ||
| 
						 | 
					7283fb320f | ||
| 
						 | 
					020cfa7283 | ||
| 
						 | 
					83aca0b53d | ||
| 
						 | 
					0b055fae2e | ||
| 
						 | 
					bc79259398 | ||
| 
						 | 
					7ebf5aa69a | ||
| 
						 | 
					7499621ecb | ||
| 
						 | 
					4de3f7ca29 | ||
| 
						 | 
					17462c21e8 | ||
| 
						 | 
					c964ef4e01 | ||
| 
						 | 
					0dccc440b6 | ||
| 
						 | 
					48f7232492 | ||
| 
						 | 
					ff5867e4d3 | ||
| 
						 | 
					a5d950f453 | ||
| 
						 | 
					7615d17293 | ||
| 
						 | 
					374e30043b | ||
| 
						 | 
					f771bb88d6 | ||
| 
						 | 
					7ef8d21e48 | ||
| 
						 | 
					c251eb8ec0 | ||
| 
						 | 
					1e6b3faa83 | ||
| 
						 | 
					e62fe956fd | ||
| 
						 | 
					24c5290d7f | ||
| 
						 | 
					00c8d3c897 | ||
| 
						 | 
					cc13f8f65e | ||
| 
						 | 
					47f4c9db7b | ||
| 
						 | 
					4c621cc30f | ||
| 
						 | 
					756a412436 | ||
| 
						 | 
					be16c2fe71 | ||
| 
						 | 
					a364c2a96b | ||
| 
						 | 
					414259a7f8 | ||
| 
						 | 
					283a81eac0 | ||
| 
						 | 
					2a145262c7 | ||
| 
						 | 
					57728b4322 | ||
| 
						 | 
					ef24fb6296 | ||
| 
						 | 
					86f057a712 | ||
| 
						 | 
					dcd628d289 | ||
| 
						 | 
					6038877c4c | ||
| 
						 | 
					4e6321c239 | ||
| 
						 | 
					304a525744 | ||
| 
						 | 
					f26de405dd | ||
| 
						 | 
					ed18580118 | ||
| 
						 | 
					b65649186d | ||
| 
						 | 
					515dc08a97 | ||
| 
						 | 
					2e7a56a28f | ||
| 
						 | 
					c485637a61 | ||
| 
						 | 
					f9f2a82e18 | ||
| 
						 | 
					2f4563132a | ||
| 
						 | 
					e3a0f2c546 | ||
| 
						 | 
					d39baeb8ad | ||
| 
						 | 
					f27f6aab78 | ||
| 
						 | 
					a66060e21a | ||
| 
						 | 
					11aa3c030b | ||
| 
						 | 
					bd1bec5617 | ||
| 
						 | 
					d9659d4b36 | ||
| 
						 | 
					d043d9943b | ||
| 
						 | 
					a0ef7c7142 | ||
| 
						 | 
					4efe4483fb | ||
| 
						 | 
					aec3edb1cc | ||
| 
						 | 
					0c5a6ad775 | ||
| 
						 | 
					2be5401b1e | ||
| 
						 | 
					f16e9b2ee7 | ||
| 
						 | 
					06380938d4 | ||
| 
						 | 
					87b20d7f2a | ||
| 
						 | 
					593db0baee | ||
| 
						 | 
					6b66553493 | ||
| 
						 | 
					ddaae9c923 | ||
| 
						 | 
					0c7a7d7527 | ||
| 
						 | 
					6561b53346 | ||
| 
						 | 
					def5e86673 | ||
| 
						 | 
					0c213c8fee | ||
| 
						 | 
					912a0abd26 | ||
| 
						 | 
					d694260ad2 | ||
| 
						 | 
					8566566451 | ||
| 
						 | 
					0ce64e46e8 | ||
| 
						 | 
					a8336669a3 | ||
| 
						 | 
					f6db756326 | ||
| 
						 | 
					27ab516f41 | ||
| 
						 | 
					9542b464bf | ||
| 
						 | 
					1ebaaa1950 | ||
| 
						 | 
					71efbf0330 | ||
| 
						 | 
					a6539463be | ||
| 
						 | 
					b8e096db82 | ||
| 
						 | 
					3e98ffaf99 | ||
| 
						 | 
					0a9754f305 | ||
| 
						 | 
					965a784c8a | ||
| 
						 | 
					2db9f55669 | ||
| 
						 | 
					3e73babaf7 | ||
| 
						 | 
					66c4555dc7 | ||
| 
						 | 
					183ad75603 | ||
| 
						 | 
					66fc32ee14 | ||
| 
						 | 
					d6396cf2c4 | ||
| 
						 | 
					c9b7104117 | ||
| 
						 | 
					6bf1a66b7c | ||
| 
						 | 
					7e7b671b8e | ||
| 
						 | 
					e04a55d1a2 | ||
| 
						 | 
					8905bd2280 | ||
| 
						 | 
					b09e1399c0 | ||
| 
						 | 
					59c8b949ad | ||
| 
						 | 
					6dbb3fddce | ||
| 
						 | 
					f166240225 | ||
| 
						 | 
					91b789c707 | ||
| 
						 | 
					14db280fab | ||
| 
						 | 
					f7097e6f66 | ||
| 
						 | 
					ff89f1e271 | ||
| 
						 | 
					6a8a4bfdcd | ||
| 
						 | 
					cd35982d4e | ||
| 
						 | 
					2f6f0f252c | ||
| 
						 | 
					13651949ed | ||
| 
						 | 
					fdeb72224c | ||
| 
						 | 
					92e36e7076 | ||
| 
						 | 
					d74796ee80 | ||
| 
						 | 
					3e35cac67a | ||
| 
						 | 
					1f7a6bf845 | ||
| 
						 | 
					365442c1ff | ||
| 
						 | 
					c8d185fc74 | ||
| 
						 | 
					9567fa9c6a | ||
| 
						 | 
					7a8de0c0af | ||
| 
						 | 
					10fead9ba1 | ||
| 
						 | 
					d5d5c2167a | ||
| 
						 | 
					b9755ea725 | ||
| 
						 | 
					39fee9f5a2 | ||
| 
						 | 
					d6282716b2 | ||
| 
						 | 
					60d9bee3bf | ||
| 
						 | 
					a09fa3b0e4 | ||
| 
						 | 
					9edff6f250 | ||
| 
						 | 
					7d3012fd67 | ||
| 
						 | 
					225e20a898 | ||
| 
						 | 
					1a62ac9276 | ||
| 
						 | 
					45cb151443 | ||
| 
						 | 
					55b18f9671 | ||
| 
						 | 
					4f4b1bfc37 | ||
| 
						 | 
					9348c9bd4b | ||
| 
						 | 
					16de7f66fb | ||
| 
						 | 
					799c27484d | ||
| 
						 | 
					c3b0faec82 | ||
| 
						 | 
					9c876722a0 | ||
| 
						 | 
					96fc93d744 | ||
| 
						 | 
					20545941fa | ||
| 
						 | 
					59f79e8294 | ||
| 
						 | 
					ac32b9ef95 | ||
| 
						 | 
					ba484be754 | ||
| 
						 | 
					a318198ab4 | ||
| 
						 | 
					e6391c2896 | ||
| 
						 | 
					7ea537fad7 | ||
| 
						 | 
					03146c2967 | ||
| 
						 | 
					0a81314337 | ||
| 
						 | 
					fa7a5782c6 | ||
| 
						 | 
					e3b64912b6 | ||
| 
						 | 
					a0fe392665 | ||
| 
						 | 
					0e5f365d55 | ||
| 
						 | 
					bfc906cbc4 | ||
| 
						 | 
					8e6f8087e8 | ||
| 
						 | 
					56207ddb6a | ||
| 
						 | 
					8cb9cfb7b8 | ||
| 
						 | 
					be698b597b | ||
| 
						 | 
					1d61a0f9b5 | ||
| 
						 | 
					788bd59857 | ||
| 
						 | 
					2391606cc5 | ||
| 
						 | 
					7155d7e043 | ||
| 
						 | 
					419dfd333a | ||
| 
						 | 
					b4535f2622 | ||
| 
						 | 
					9b21346427 | ||
| 
						 | 
					7b15d21e40 | ||
| 
						 | 
					7b597b8c62 | ||
| 
						 | 
					7a4adce44f | ||
| 
						 | 
					a5f0db5ecb | ||
| 
						 | 
					577624adef | ||
| 
						 | 
					af46ef3b96 | ||
| 
						 | 
					39d26be941 | ||
| 
						 | 
					7bfc9109f7 | ||
| 
						 | 
					becbad56ef | ||
| 
						 | 
					384a34c27d | ||
| 
						 | 
					002c5b8f87 | ||
| 
						 | 
					1d3dbea20c | ||
| 
						 | 
					ebe6e3180e | ||
| 
						 | 
					a3de799939 | ||
| 
						 | 
					0caf7381bb | ||
| 
						 | 
					a42305edab | ||
| 
						 | 
					732c059235 | ||
| 
						 | 
					ef2b6e7d00 | ||
| 
						 | 
					9c1b972ca1 | ||
| 
						 | 
					cb33e1942a | ||
| 
						 | 
					7009d1e470 | ||
| 
						 | 
					c54a19825b | ||
| 
						 | 
					8131f34eb6 | ||
| 
						 | 
					f29241d90e | ||
| 
						 | 
					bad48ea815 | ||
| 
						 | 
					66af41f4a9 | ||
| 
						 | 
					e30be380dd | ||
| 
						 | 
					65f2e29375 | ||
| 
						 | 
					98dbba1e17 | ||
| 
						 | 
					422648e2eb | ||
| 
						 | 
					f0fa4d831a | ||
| 
						 | 
					1b600f5867 | ||
| 
						 | 
					fd8cc9b7a8 | ||
| 
						 | 
					ca5b5e6bc4 | ||
| 
						 | 
					ee683ff187 | ||
| 
						 | 
					57602adfe7 | ||
| 
						 | 
					1481836ed6 | ||
| 
						 | 
					309f78ff52 | ||
| 
						 | 
					6436459381 | ||
| 
						 | 
					65b39212d5 | ||
| 
						 | 
					283649b8d7 | ||
| 
						 | 
					fa65c380db | ||
| 
						 | 
					58b39233f5 | ||
| 
						 | 
					82066e02c5 | ||
| 
						 | 
					c36aa5e696 | ||
| 
						 | 
					29197d40c6 | ||
| 
						 | 
					8d5ab6b5b3 | ||
| 
						 | 
					a796938b39 | ||
| 
						 | 
					3813113f1a | ||
| 
						 | 
					1be117e430 | ||
| 
						 | 
					622c7a021b | ||
| 
						 | 
					4d2d2f285b | ||
| 
						 | 
					0924c7d61b | ||
| 
						 | 
					2746608eb2 | ||
| 
						 | 
					fe26cb5989 | ||
| 
						 | 
					602307e694 | ||
| 
						 | 
					b2c18c4a78 | ||
| 
						 | 
					1e211722c7 | ||
| 
						 | 
					461f74ef18 | ||
| 
						 | 
					3f022ca963 | ||
| 
						 | 
					20e92c5a72 | ||
| 
						 | 
					0850da44d7 | ||
| 
						 | 
					37ba264190 | ||
| 
						 | 
					6c12c928df | ||
| 
						 | 
					9c5733caf0 | ||
| 
						 | 
					21d8b8310a | ||
| 
						 | 
					c46af91d54 | ||
| 
						 | 
					d44574f738 | ||
| 
						 | 
					a9424255a5 | ||
| 
						 | 
					5089a63d76 | ||
| 
						 | 
					f9a2c64460 | ||
| 
						 | 
					7841042a85 | ||
| 
						 | 
					ea1b8cdc22 | ||
| 
						 | 
					52b48cfbef | ||
| 
						 | 
					644f3e1275 | ||
| 
						 | 
					304005e04f | ||
| 
						 | 
					025ab35af7 | ||
| 
						 | 
					a27744503b | ||
| 
						 | 
					1011331caf | ||
| 
						 | 
					0ccef81789 | ||
| 
						 | 
					4780f74a40 | ||
| 
						 | 
					57866fb267 | ||
| 
						 | 
					d3bc7570d0 | ||
| 
						 | 
					74e43a4702 | ||
| 
						 | 
					0764b2058a | ||
| 
						 | 
					7a787d7946 | ||
| 
						 | 
					eec0f5df47 | ||
| 
						 | 
					ba3968a822 | ||
| 
						 | 
					762fa0e116 | ||
| 
						 | 
					0be57b621b | ||
| 
						 | 
					7d88b3593b | ||
| 
						 | 
					858db7081a | ||
| 
						 | 
					5af7f619c8 | ||
| 
						 | 
					e5e35e5a7f | ||
| 
						 | 
					6d639ac528 | ||
| 
						 | 
					aa3643cdde | ||
| 
						 | 
					8a3501ffe1 | ||
| 
						 | 
					5ea443eb4b | ||
| 
						 | 
					a37a8c6497 | ||
| 
						 | 
					ebf6862a10 | ||
| 
						 | 
					6c0e16c482 | ||
| 
						 | 
					40b1e7312d | ||
| 
						 | 
					1c0e6f26e2 | ||
| 
						 | 
					f4fc498e65 | ||
| 
						 | 
					a8632c2546 | ||
| 
						 | 
					600a0f836f | ||
| 
						 | 
					0ac142d39e | ||
| 
						 | 
					abd368be00 | ||
| 
						 | 
					a8ac2cc275 | ||
| 
						 | 
					2f14b5cc3f | ||
| 
						 | 
					2930612e64 | ||
| 
						 | 
					2952d3671d | ||
| 
						 | 
					1b5ace8256 | ||
| 
						 | 
					2ebecc5370 | ||
| 
						 | 
					02144d17e9 | ||
| 
						 | 
					71496c8909 | ||
| 
						 | 
					594b15abf1 | ||
| 
						 | 
					bbe3641844 | ||
| 
						 | 
					0cc5cf940b | ||
| 
						 | 
					153d8efcf5 | ||
| 
						 | 
					be744775c1 | ||
| 
						 | 
					5959457c73 | ||
| 
						 | 
					0824eb7c96 | ||
| 
						 | 
					d945501be6 | ||
| 
						 | 
					ca342c4573 | ||
| 
						 | 
					4326d0bf3a | ||
| 
						 | 
					a6ebc70170 | ||
| 
						 | 
					3025cb7c48 | ||
| 
						 | 
					17f48baf3a | ||
| 
						 | 
					333661a9d8 | ||
| 
						 | 
					b9da43b753 | ||
| 
						 | 
					097ee776c7 | ||
| 
						 | 
					a4a8f1f863 | ||
| 
						 | 
					f36a627330 | ||
| 
						 | 
					a1087c3f30 | ||
| 
						 | 
					aad275b9a2 | ||
| 
						 | 
					f0397eab94 | ||
| 
						 | 
					392e224831 | ||
| 
						 | 
					6867d44573 | ||
| 
						 | 
					a841fff2ac | ||
| 
						 | 
					26aa10a974 | ||
| 
						 | 
					f6144082b1 | ||
| 
						 | 
					957513242c | ||
| 
						 | 
					17fd25e216 | ||
| 
						 | 
					e91268a250 | ||
| 
						 | 
					82cb4e8267 | ||
| 
						 | 
					68eb87cc58 | ||
| 
						 | 
					f3e52d5b18 | ||
| 
						 | 
					2b2b2d3191 | ||
| 
						 | 
					9461c612de | ||
| 
						 | 
					f0280a8868 | ||
| 
						 | 
					c749f7b6fb | ||
| 
						 | 
					74462133ca | ||
| 
						 | 
					7c45d6594c | ||
| 
						 | 
					ea916b6c49 | ||
| 
						 | 
					a02d734243 | ||
| 
						 | 
					735b736110 | ||
| 
						 | 
					bbbb9ac53c | ||
| 
						 | 
					8dd97b4998 | ||
| 
						 | 
					73a9082062 | ||
| 
						 | 
					4091f5493d | ||
| 
						 | 
					d96b053c9d | ||
| 
						 | 
					1f569bef76 | ||
| 
						 | 
					1a88176cc0 | ||
| 
						 | 
					662c9729bc | ||
| 
						 | 
					56a0dd6b2c | ||
| 
						 | 
					9dc6028b3d | ||
| 
						 | 
					932e913d88 | ||
| 
						 | 
					b72315e27a | ||
| 
						 | 
					3c7cd1f38c | ||
| 
						 | 
					1946c548bf | ||
| 
						 | 
					cf181fe109 | ||
| 
						 | 
					63b9110f93 | ||
| 
						 | 
					ae44bff0b1 | ||
| 
						 | 
					23ba3e527f | ||
| 
						 | 
					08df9bf559 | ||
| 
						 | 
					648639fffe | ||
| 
						 | 
					6cc014a941 | ||
| 
						 | 
					b7b95123ed | ||
| 
						 | 
					153463790a | ||
| 
						 | 
					875bbec949 | ||
| 
						 | 
					666e5f1f98 | ||
| 
						 | 
					e6790038dd | ||
| 
						 | 
					e86c53230f | ||
| 
						 | 
					4ea4658abf | ||
| 
						 | 
					58f6ab0a27 | ||
| 
						 | 
					9c0cc664d1 | ||
| 
						 | 
					84d26e31f1 | ||
| 
						 | 
					64a848fcb7 | ||
| 
						 | 
					429583ae8b | ||
| 
						 | 
					93ae868987 | ||
| 
						 | 
					72a900787f | ||
| 
						 | 
					7186841db0 | ||
| 
						 | 
					ab080e3e6b | ||
| 
						 | 
					ad84aef766 | ||
| 
						 | 
					7908eca579 | ||
| 
						 | 
					237d990dea | ||
| 
						 | 
					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 | 
							
								
								
									
										18
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							@@ -48,10 +48,11 @@ po/*.pot
 | 
			
		||||
50-metacity-key.xml
 | 
			
		||||
libmutter-wayland.pc
 | 
			
		||||
mutter-wayland
 | 
			
		||||
mutter-theme-viewer
 | 
			
		||||
mutter-wayland.desktop
 | 
			
		||||
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
 | 
			
		||||
@@ -77,6 +78,12 @@ src/stamp-mutter-marshal.h
 | 
			
		||||
src/meta-dbus-xrandr.[ch]
 | 
			
		||||
src/meta-dbus-idle-monitor.[ch]
 | 
			
		||||
src/mutter-plugins.pc
 | 
			
		||||
src/gtk-shell-protocol.c
 | 
			
		||||
src/gtk-shell-server-protocol.h
 | 
			
		||||
src/xdg-shell-protocol.c
 | 
			
		||||
src/xdg-shell-server-protocol.h
 | 
			
		||||
src/xserver-protocol.c
 | 
			
		||||
src/xserver-server-protocol.h
 | 
			
		||||
doc/reference/*.args
 | 
			
		||||
doc/reference/*.bak
 | 
			
		||||
doc/reference/*.hierarchy
 | 
			
		||||
@@ -94,3 +101,10 @@ doc/reference/meta-undocumented.txt
 | 
			
		||||
doc/reference/meta-unused.txt
 | 
			
		||||
doc/reference/meta-docs.sgml
 | 
			
		||||
doc/reference/meta.types
 | 
			
		||||
gtk-doc.m4
 | 
			
		||||
intltool.m4
 | 
			
		||||
libtool.m4
 | 
			
		||||
ltoptions.m4
 | 
			
		||||
ltsugar.m4
 | 
			
		||||
ltversion.m4
 | 
			
		||||
lt~obsolete.m4
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										159
									
								
								COMPLIANCE
									
									
									
									
									
								
							
							
						
						
									
										159
									
								
								COMPLIANCE
									
									
									
									
									
								
							@@ -1,159 +0,0 @@
 | 
			
		||||
Metacity Standards Compliance
 | 
			
		||||
=============================
 | 
			
		||||
$Id$
 | 
			
		||||
 | 
			
		||||
1) Introduction
 | 
			
		||||
2) EWMH Compliance
 | 
			
		||||
  a. Root Window Properties
 | 
			
		||||
  b. Root Window Messages
 | 
			
		||||
  c. Application Window Properties
 | 
			
		||||
  d. Window Manager Protocols
 | 
			
		||||
3) ICCCM Compliance
 | 
			
		||||
 | 
			
		||||
1) Introduction
 | 
			
		||||
---------------
 | 
			
		||||
 | 
			
		||||
This document details metacity compliance with the relevent standards.
 | 
			
		||||
The format of this document is as follows:
 | 
			
		||||
 | 
			
		||||
[-/+?] Hint Name/Feature Name (Version number)
 | 
			
		||||
       Errata/Comments
 | 
			
		||||
 | 
			
		||||
The first character indicates the level of compliance as follows:
 | 
			
		||||
    -   none
 | 
			
		||||
    /   partial
 | 
			
		||||
    +   complete
 | 
			
		||||
    ?   unknown
 | 
			
		||||
 | 
			
		||||
The title indicates a feature or a hint in the specification, and the
 | 
			
		||||
version number indicates the minimum version of the specification
 | 
			
		||||
supported by metacity.  Later versions may be supported if no
 | 
			
		||||
incompatible changes have been made in the specification.
 | 
			
		||||
 | 
			
		||||
2) EWMH Compliance
 | 
			
		||||
------------------
 | 
			
		||||
 | 
			
		||||
The EWMH, or Extended Window Manager Hints is a freedesktop.org-
 | 
			
		||||
developed standard to support a number of conventions for
 | 
			
		||||
communication between the window manager and clients.  It builds on
 | 
			
		||||
and extends the ICCCM (See Section 3).  A copy of the current EWMH
 | 
			
		||||
standard is available at http://freedesktop.org/Standards/wm-spec/
 | 
			
		||||
 | 
			
		||||
  a. Root Window Properties
 | 
			
		||||
  -------------------------
 | 
			
		||||
 | 
			
		||||
+ _NET_SUPPORTED (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_CLIENT_LIST (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_NUMBER_OF_DESKTOPS (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_DESKTOP_GEOMETRY (1.3)
 | 
			
		||||
  Metacity does not implement large desktops, so this is kept set to
 | 
			
		||||
  the screen size.
 | 
			
		||||
 | 
			
		||||
+ _NET_DESKTOP_VIEWPORT (1.3)
 | 
			
		||||
  Metacity does not implement viewports, so this is a constant (0,0).
 | 
			
		||||
 | 
			
		||||
+ _NET_CURRENT_DESKTOP (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_DESKTOP_NAMES (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_ACTIVE_WINDOW (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_WORKAREA (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_SUPPORTING_WM_CHECK (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_VIRTUAL_ROOTS (1.3)
 | 
			
		||||
  Metacity does not read or set this property, but it does not use
 | 
			
		||||
  virtual roots to implement virtual desktops, so it complies with the
 | 
			
		||||
  specification.
 | 
			
		||||
 | 
			
		||||
+ _NET_DESKTOP_LAYOUT (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_SHOWING_DESKTOP (1.3)
 | 
			
		||||
 | 
			
		||||
  b. Root Window Messages
 | 
			
		||||
  -----------------------
 | 
			
		||||
 | 
			
		||||
+ _NET_CLOSE_WINDOW (1.3)
 | 
			
		||||
 | 
			
		||||
- _NET_MOVERESIZE_WINDOW (1.3)
 | 
			
		||||
  Metacity supports this message, but the specification is unclear on
 | 
			
		||||
  the layout of the detail value, and as such it is #if 0'd in the code
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_MOVERESIZE (1.3)
 | 
			
		||||
 | 
			
		||||
- _NET_RESTACK_WINDOW (1.3)
 | 
			
		||||
  Metacity will raise or lower windows in response to this message,
 | 
			
		||||
  but the sibling restack modes are not supported, and it is currently
 | 
			
		||||
  #if 0'd in the code.
 | 
			
		||||
 | 
			
		||||
+ _NET_REQUEST_FRAME_EXTENTS (1.3)  
 | 
			
		||||
 | 
			
		||||
  c. Application Window Properties
 | 
			
		||||
  --------------------------------
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_NAME (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_VISIBLE_NAME (1.3)
 | 
			
		||||
  Metacity does not set this property, but metacity will never display
 | 
			
		||||
  a name different from _NET_WM_NAME
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_ICON_NAME (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_VISIBLE_ICON_NAME (1.3)
 | 
			
		||||
  Metacity does not set this property, but metacity will never display
 | 
			
		||||
  a name different from _NET_WM_NAME
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_DESKTOP (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_WINDOW_TYPE (1.3)
 | 
			
		||||
 | 
			
		||||
/ _NET_WM_STATE (1.3)
 | 
			
		||||
  This property is read and updated according to the specification,
 | 
			
		||||
  but see caveat below.
 | 
			
		||||
  Metacity does not recognize separate vertical and horizontal
 | 
			
		||||
  maximization states.  Currently metacity will do a two-dimensional
 | 
			
		||||
  maximization if either property is set.
 | 
			
		||||
  See: http://bugzilla.gnome.org/show_bug.cgi?id=113601
 | 
			
		||||
  Metacity doesn't implement viewports so _NET_WM_STATE_STICKY is
 | 
			
		||||
  unimplemented.
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_ALLOWED_ACTIONS (1.3)
 | 
			
		||||
  Metacity keeps this hint up to date.  The code is somewhat crufty
 | 
			
		||||
  and should be rewritten, though it is functional.
 | 
			
		||||
  See: http://bugzilla.gnome.org/show_bug.cgi?id=90420
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_STRUT (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_STRUT_PARTIAL (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_ICON_GEOMETRY (1.3)
 | 
			
		||||
  Metacity uses this property to draw minimize/restore animations
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_ICON (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_PID (1.3)
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_HANDLED_ICONS (1.3)
 | 
			
		||||
  Metacity does not read or set this property.  However, metacity
 | 
			
		||||
  never manages iconified windows, and so has no need to do so.
 | 
			
		||||
 | 
			
		||||
+ _NET_WM_USER_TIME (1.3)
 | 
			
		||||
  Metacity uses this property to prevent applications from stealing
 | 
			
		||||
  focus if supported by the toolkit.
 | 
			
		||||
 | 
			
		||||
+ _NET_FRAME_EXTENTS (1.3)
 | 
			
		||||
  If set in response to a _NET_REQUEST_FRAME_EXTENTS message received
 | 
			
		||||
  prior to the window being mapped, this may be an estimate.  This is,
 | 
			
		||||
  however, expressly allowed by the specification.
 | 
			
		||||
 | 
			
		||||
  d. Window Manager Protocols
 | 
			
		||||
  ---------------------------
 | 
			
		||||
+ _NET_WM_PING (1.3)
 | 
			
		||||
 | 
			
		||||
3) ICCCM Compliance
 | 
			
		||||
-------------------
 | 
			
		||||
TODO
 | 
			
		||||
							
								
								
									
										41
									
								
								COPYING
									
									
									
									
									
								
							
							
						
						
									
										41
									
								
								COPYING
									
									
									
									
									
								
							@@ -1,12 +1,12 @@
 | 
			
		||||
		    GNU GENERAL PUBLIC LICENSE
 | 
			
		||||
		       Version 2, June 1991
 | 
			
		||||
                    GNU GENERAL PUBLIC LICENSE
 | 
			
		||||
                       Version 2, June 1991
 | 
			
		||||
 | 
			
		||||
 Copyright (C) 1989, 1991 Free Software Foundation, Inc.
 | 
			
		||||
     59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 | 
			
		||||
 Copyright (C) 1989, 1991 Free Software Foundation, Inc.,
 | 
			
		||||
 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 | 
			
		||||
 Everyone is permitted to copy and distribute verbatim copies
 | 
			
		||||
 of this license document, but changing it is not allowed.
 | 
			
		||||
 | 
			
		||||
			    Preamble
 | 
			
		||||
                            Preamble
 | 
			
		||||
 | 
			
		||||
  The licenses for most software are designed to take away your
 | 
			
		||||
freedom to share and change it.  By contrast, the GNU General Public
 | 
			
		||||
@@ -15,7 +15,7 @@ software--to make sure the software is free for all its users.  This
 | 
			
		||||
General Public License applies to most of the Free Software
 | 
			
		||||
Foundation's software and to any other program whose authors commit to
 | 
			
		||||
using it.  (Some other Free Software Foundation software is covered by
 | 
			
		||||
the GNU Library General Public License instead.)  You can apply it to
 | 
			
		||||
the GNU Lesser General Public License instead.)  You can apply it to
 | 
			
		||||
your programs, too.
 | 
			
		||||
 | 
			
		||||
  When we speak of free software, we are referring to freedom, not
 | 
			
		||||
@@ -55,8 +55,8 @@ patent must be licensed for everyone's free use or not licensed at all.
 | 
			
		||||
 | 
			
		||||
  The precise terms and conditions for copying, distribution and
 | 
			
		||||
modification follow.
 | 
			
		||||
 | 
			
		||||
		    GNU GENERAL PUBLIC LICENSE
 | 
			
		||||
 | 
			
		||||
                    GNU GENERAL PUBLIC LICENSE
 | 
			
		||||
   TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
 | 
			
		||||
 | 
			
		||||
  0. This License applies to any program or other work which contains
 | 
			
		||||
@@ -110,7 +110,7 @@ above, provided that you also meet all of these conditions:
 | 
			
		||||
    License.  (Exception: if the Program itself is interactive but
 | 
			
		||||
    does not normally print such an announcement, your work based on
 | 
			
		||||
    the Program is not required to print an announcement.)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
These requirements apply to the modified work as a whole.  If
 | 
			
		||||
identifiable sections of that work are not derived from the Program,
 | 
			
		||||
and can be reasonably considered independent and separate works in
 | 
			
		||||
@@ -168,7 +168,7 @@ access to copy from a designated place, then offering equivalent
 | 
			
		||||
access to copy the source code from the same place counts as
 | 
			
		||||
distribution of the source code, even though third parties are not
 | 
			
		||||
compelled to copy the source along with the object code.
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  4. You may not copy, modify, sublicense, or distribute the Program
 | 
			
		||||
except as expressly provided under this License.  Any attempt
 | 
			
		||||
otherwise to copy, modify, sublicense or distribute the Program is
 | 
			
		||||
@@ -225,7 +225,7 @@ impose that choice.
 | 
			
		||||
 | 
			
		||||
This section is intended to make thoroughly clear what is believed to
 | 
			
		||||
be a consequence of the rest of this License.
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  8. If the distribution and/or use of the Program is restricted in
 | 
			
		||||
certain countries either by patents or by copyrighted interfaces, the
 | 
			
		||||
original copyright holder who places the Program under this License
 | 
			
		||||
@@ -255,7 +255,7 @@ make exceptions for this.  Our decision will be guided by the two goals
 | 
			
		||||
of preserving the free status of all derivatives of our free software and
 | 
			
		||||
of promoting the sharing and reuse of software generally.
 | 
			
		||||
 | 
			
		||||
			    NO WARRANTY
 | 
			
		||||
                            NO WARRANTY
 | 
			
		||||
 | 
			
		||||
  11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
 | 
			
		||||
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW.  EXCEPT WHEN
 | 
			
		||||
@@ -277,9 +277,9 @@ YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
 | 
			
		||||
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
 | 
			
		||||
POSSIBILITY OF SUCH DAMAGES.
 | 
			
		||||
 | 
			
		||||
		     END OF TERMS AND CONDITIONS
 | 
			
		||||
 | 
			
		||||
	    How to Apply These Terms to Your New Programs
 | 
			
		||||
                     END OF TERMS AND CONDITIONS
 | 
			
		||||
 | 
			
		||||
            How to Apply These Terms to Your New Programs
 | 
			
		||||
 | 
			
		||||
  If you develop a new program, and you want it to be of the greatest
 | 
			
		||||
possible use to the public, the best way to achieve this is to make it
 | 
			
		||||
@@ -303,17 +303,16 @@ the "copyright" line and a pointer to where the full notice is found.
 | 
			
		||||
    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
 | 
			
		||||
 | 
			
		||||
    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.,
 | 
			
		||||
    51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 | 
			
		||||
 | 
			
		||||
Also add information on how to contact you by electronic and paper mail.
 | 
			
		||||
 | 
			
		||||
If the program is interactive, make it output a short notice like this
 | 
			
		||||
when it starts in an interactive mode:
 | 
			
		||||
 | 
			
		||||
    Gnomovision version 69, Copyright (C) year  name of author
 | 
			
		||||
    Gnomovision version 69, Copyright (C) year name of author
 | 
			
		||||
    Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
 | 
			
		||||
    This is free software, and you are welcome to redistribute it
 | 
			
		||||
    under certain conditions; type `show c' for details.
 | 
			
		||||
@@ -336,5 +335,5 @@ necessary.  Here is a sample; alter the names:
 | 
			
		||||
This General Public License does not permit incorporating your program into
 | 
			
		||||
proprietary programs.  If your program is a subroutine library, you may
 | 
			
		||||
consider it more useful to permit linking proprietary applications with the
 | 
			
		||||
library.  If this is what you want to do, use the GNU Library General
 | 
			
		||||
library.  If this is what you want to do, use the GNU Lesser General
 | 
			
		||||
Public License instead of this License.
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										298
									
								
								HACKING
									
									
									
									
									
								
							
							
						
						
									
										298
									
								
								HACKING
									
									
									
									
									
								
							@@ -1,298 +0,0 @@
 | 
			
		||||
Intro...
 | 
			
		||||
 | 
			
		||||
Window managers have a few ways in which they are significantly different
 | 
			
		||||
from other applications.  This file, combined with the code overview in
 | 
			
		||||
doc/code-overview.txt, should hopefully provide a series of relatively
 | 
			
		||||
quick pointers (hopefully only a few minutes each) to some of the places
 | 
			
		||||
one can look to orient themselves and get started.  Some of this will be
 | 
			
		||||
general to window managers on X, much will be specific to Metacity, and
 | 
			
		||||
there's probably some information that's common to programs in general but
 | 
			
		||||
is nonetheless useful.
 | 
			
		||||
 | 
			
		||||
Overview
 | 
			
		||||
  Administrative issues
 | 
			
		||||
  Minimal Building/Testing Environment
 | 
			
		||||
  Relevant standards and X properties
 | 
			
		||||
  Debugging and testing
 | 
			
		||||
    Debugging logs
 | 
			
		||||
    Adding information to the log
 | 
			
		||||
    Valgrind
 | 
			
		||||
    Testing Utilities
 | 
			
		||||
  Technical gotchas to keep in mind
 | 
			
		||||
  Other important reading
 | 
			
		||||
    Extra reading
 | 
			
		||||
    Ideas for tasks to work on
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
Administrative issues
 | 
			
		||||
  Don't commit substantive code in here without asking hp@redhat.com.
 | 
			
		||||
  Adding translations, no-brainer typo fixes, etc. is fine.
 | 
			
		||||
 | 
			
		||||
  The code could use cleanup in a lot of places, feel free to do so.
 | 
			
		||||
 | 
			
		||||
  See http://developer.gnome.org/dotplan/for_maintainers.html for
 | 
			
		||||
  information on how to make a release.  The only difference from those
 | 
			
		||||
  instructions is that the minor version number of a Metacity release
 | 
			
		||||
  should always be a number from the Fibonacci sequence.
 | 
			
		||||
 | 
			
		||||
Minimal Building/Testing Environment
 | 
			
		||||
  You do not need to _install_ a development version of Metacity to
 | 
			
		||||
  build, run and test it; you can run it from some temporary
 | 
			
		||||
  directory.  Also, you do not need to build all of Gnome in order to
 | 
			
		||||
  build a development version of Metacity -- odds are, you may be able
 | 
			
		||||
  to build metacity from CVS without building any other modules.
 | 
			
		||||
 | 
			
		||||
  As long as you have gtk+ >= 3.0 and GIO >= 2.25.10 with your distro
 | 
			
		||||
  (gtk+ >= 2.6 if you manually revert the change from bug 348633), you
 | 
			
		||||
  should be able to install your distro's development packages
 | 
			
		||||
  (e.g. gtk2-devel, glib-devel, startup-notification-devel on
 | 
			
		||||
  Fedora; also, remember to install the gnome-common package which is
 | 
			
		||||
  needed for building cvs versions of Gnome modules like Metacity) as
 | 
			
		||||
  well as the standard development tools (gcc, autoconf, automake,
 | 
			
		||||
  pkg-config, intltool, and libtool) and be ready to build and test
 | 
			
		||||
  Metacity.  Steps to do so:
 | 
			
		||||
 | 
			
		||||
  $ svn checkout http://svn.gnome.org/svn/metacity/trunk metacity
 | 
			
		||||
  $ cd metacity
 | 
			
		||||
  $ ./autogen.sh --prefix /usr
 | 
			
		||||
  $ make
 | 
			
		||||
  $ ./src/metacity --replace
 | 
			
		||||
 | 
			
		||||
  Again, note that you do not need to run 'make install'.
 | 
			
		||||
 | 
			
		||||
Relevant standards and X properties
 | 
			
		||||
  There are two documents that describe some basics about how window
 | 
			
		||||
  managers should behave: the ICCCM (Inter-Client Communication Conventions
 | 
			
		||||
  Manual) and EWMH (Extended Window Manager Hints).  You can find these at
 | 
			
		||||
  the following locations:
 | 
			
		||||
    ICCCM - http://tronche.com/gui/x/icccm/
 | 
			
		||||
    EWMH  - :pserver:anoncvs@pdx.freedesktop.org:/cvs
 | 
			
		||||
  The ICCCM is usually available in RPM or DEB format as well.  There is
 | 
			
		||||
  actually an online version of the EWMH, but it is almost always woefully
 | 
			
		||||
  out of date.  Just get it from cvs with these commands (the backslash
 | 
			
		||||
  means include the stuff from the next line):
 | 
			
		||||
    cvs -d :pserver:anoncvs@cvs.freedesktop.org:/cvs/icccm-extensions login
 | 
			
		||||
    cvs -d :pserver:anoncvs@cvs.freedesktop.org:/cvs/icccm-extensions \
 | 
			
		||||
      checkout wm-spec
 | 
			
		||||
 | 
			
		||||
  DO NOT GO AND READ THOSE THINGS.  THEY ARE REALLY, REALLY BORING.
 | 
			
		||||
 | 
			
		||||
  If you do, you'll probably end up catching up on your sleep instead of
 | 
			
		||||
  hacking on Metacity. ;-)  Instead, just look at the table of contents and
 | 
			
		||||
  glance at a page or two to get an idea of what's in there.  Then only
 | 
			
		||||
  refer to it if you see something weird in the code and you don't know
 | 
			
		||||
  what it is but has some funny looking name like you see in one of those
 | 
			
		||||
  two documents.
 | 
			
		||||
 | 
			
		||||
  You can refer to the COMPLIANCE file for additional information on these
 | 
			
		||||
  specifications and Metacity's compliance therewith.
 | 
			
		||||
 | 
			
		||||
  One of the major things those documents cover that are useful to learn
 | 
			
		||||
  about immediately are X properties.  The right way to learn about those,
 | 
			
		||||
  though, is through hand on experimentation with the xprop command (and
 | 
			
		||||
  then look up things you find from xprop in those two manuals if you're
 | 
			
		||||
  curious enough).  First, try running
 | 
			
		||||
    xprop
 | 
			
		||||
  in a terminal and click on one of the windows on your screen.  That gives
 | 
			
		||||
  you the x properties for that window.  Look through them and get a basic
 | 
			
		||||
  idea of what's there for kicks.  Note that you can get rid of some of the
 | 
			
		||||
  verboseness by grepping out the _NET_WM_ICON stuff, i.e.
 | 
			
		||||
    xprop | grep -v _NET_WM_ICON
 | 
			
		||||
  Next, try running
 | 
			
		||||
    xprop -root
 | 
			
		||||
  in a terminal.  There's all the properties of the root window (which you
 | 
			
		||||
  can think of as the "main" Xserver window).  You can also manually
 | 
			
		||||
  specify individual windows that you want the properties of with
 | 
			
		||||
    xprop -id <id>
 | 
			
		||||
  if you know the id of the window in question.  You can get the id of a
 | 
			
		||||
  given window by either running xwininfo, e.g.
 | 
			
		||||
    xwininfo | grep "Window id" | cut -f 4 -d ' '
 | 
			
		||||
  or by looking at the _NET_CLIENT_STACKING property of the root
 | 
			
		||||
  window.  Finally, it can also be useful to add "-spy" (without the
 | 
			
		||||
  quotes) to the xprop command to get it to continually monitor that
 | 
			
		||||
  window and report any changes to you.
 | 
			
		||||
 | 
			
		||||
Debugging information
 | 
			
		||||
  Trying to run a window manager under a typical debugger, such as gdb,
 | 
			
		||||
  unfortunately just doesn't work very well.  So, we have to resort to
 | 
			
		||||
  other methods.
 | 
			
		||||
 | 
			
		||||
  Debugging logs
 | 
			
		||||
 | 
			
		||||
  First, note that you can start a new version of metacity to replace the
 | 
			
		||||
  existing one by running
 | 
			
		||||
    metacity --replace
 | 
			
		||||
  (which also comes in handy in the form "./src/metacity --replace" when
 | 
			
		||||
  trying to quickly test a small change while hacking on metacity without
 | 
			
		||||
  doing a full "make install", though I'm going off topic...)  This will
 | 
			
		||||
  allow you to see any warnings printed at the terminal.  Sometimes it's
 | 
			
		||||
  useful to have these directed to a logfile instead, which you can do by
 | 
			
		||||
  running
 | 
			
		||||
    METACITY_USE_LOGFILE=1 metacity --replace
 | 
			
		||||
  The logfile it uses will be printed in the terminal.  Sometimes, it's
 | 
			
		||||
  useful to get more information than just warnings.  You can set
 | 
			
		||||
  METACITY_VERBOSE to do that, like so:
 | 
			
		||||
    METACITY_VERBOSE=1 METACITY_USE_LOGFILE=1 metacity --replace
 | 
			
		||||
  (note that METACITY_VERBOSE=1 can be problematic without
 | 
			
		||||
  METACITY_USE_LOGFILE=1; avoid it unless running in from something that
 | 
			
		||||
  won't be managed by the new Metacity--see bug 305091 for more details).
 | 
			
		||||
  There are also other flags, such as METACITY_DEBUG, most of which I
 | 
			
		||||
  haven't tried and don't know what they do.  Go to the source code
 | 
			
		||||
  directory and run
 | 
			
		||||
    grep "METACITY_" * | grep getenv
 | 
			
		||||
  to find out what the other ones are.
 | 
			
		||||
 | 
			
		||||
  Adding information to the log
 | 
			
		||||
 | 
			
		||||
  Since we can't single step with a debugger, we often have to fall back to
 | 
			
		||||
  the primitive method of getting information we want to know: adding
 | 
			
		||||
  "print" statements.  Metacity has a fairly structured way to do this,
 | 
			
		||||
  using the functions meta_warning, meta_topic, and meta_verbose.  All
 | 
			
		||||
  three have the same basic format as printf, except that meta_topic also
 | 
			
		||||
  takes a leading enumeration parameter to specify the type of message
 | 
			
		||||
  being shown (makes it easier for grepping in a verbose log).  You'll find
 | 
			
		||||
  tons of examples in the source code if you need them; just do a quick
 | 
			
		||||
  grep or look in most any file.  Note that meta_topic and meta_verbose
 | 
			
		||||
  messages only appear if verbosity is turned on.  I tend to frequently add
 | 
			
		||||
  temporary meta_warning statements (or switch meta_topic or meta_verbose
 | 
			
		||||
  ones to meta_warning ones) and then undo the changes once I've learned
 | 
			
		||||
  the info that I needed.
 | 
			
		||||
 | 
			
		||||
  There is also a meta_print_backtrace (which again is only active if
 | 
			
		||||
  verbosity is turned on) that can also be useful if you want to learn how
 | 
			
		||||
  a particular line of code gets called.  And, of course, there's always
 | 
			
		||||
  g_assert if you want to make sure some section isn't executed (or isn't
 | 
			
		||||
  executed under certain conditions).
 | 
			
		||||
 | 
			
		||||
  Valgrind
 | 
			
		||||
 | 
			
		||||
  Valgrind is awesome for finding memory leaks or corruption and
 | 
			
		||||
  uninitialized variables.  But I also tend to use it in a non-traditional
 | 
			
		||||
  way as a partial substitute for a normal debugger: it can provide me with
 | 
			
		||||
  a stack trace of where metacity is crashing if I made a change that
 | 
			
		||||
  caused it to do so, which is one of the major uses of debuggers.  (And,
 | 
			
		||||
  what makes it cooler than a debugger is that there will also often be
 | 
			
		||||
  warnings pinpointing the cause of the crash from either some kind of
 | 
			
		||||
  simple memory corruption or an uninitialized variable).  Sometimes, when
 | 
			
		||||
  I merely want to know what is calling a particular function I'll just
 | 
			
		||||
  throw in an "int i; printf("%d\n", i);" just because valgrind will give
 | 
			
		||||
  me a full stacktrace whenever it sees that uninitialized variable being
 | 
			
		||||
  used (yes, I could use meta_print_backtrace, but that means I have to
 | 
			
		||||
  turn verbosity on).
 | 
			
		||||
 | 
			
		||||
  To run metacity under valgrind, use options typical for any Gnome
 | 
			
		||||
  program, such as
 | 
			
		||||
    valgrind --log-file=metacity.log --tool=memcheck --num-callers=48 \
 | 
			
		||||
    --leak-check=yes --leak-resolution=high --show-reachable=yes     \
 | 
			
		||||
    ./src/metacity --replace
 | 
			
		||||
  where, again, the backslashes mean to join all the stuff on the following
 | 
			
		||||
  line with the previous one.
 | 
			
		||||
 | 
			
		||||
  However, there is a downside.  Things run a little bit slowly, and it
 | 
			
		||||
  appears that you'll need about 1.5GB of ram, which unfortunately prevents
 | 
			
		||||
  most people from trying this.
 | 
			
		||||
 | 
			
		||||
  Testing Utilities
 | 
			
		||||
 | 
			
		||||
  src/run-metacity.sh
 | 
			
		||||
    The script src/run-metacity.sh is useful to hack on the window manager. 
 | 
			
		||||
    It runs metacity in an Xnest. e.g.:
 | 
			
		||||
      CLIENTS=3 ./run-metacity.sh
 | 
			
		||||
    or 
 | 
			
		||||
      DEBUG=memprof ./run-metacity.sh
 | 
			
		||||
    or
 | 
			
		||||
      DEBUG_TEST=1 ./run-metacity-sh
 | 
			
		||||
    or whatever.
 | 
			
		||||
 | 
			
		||||
  metacity-message
 | 
			
		||||
    The tool metacity-message can be used as follows:
 | 
			
		||||
      metacity-message reload-theme
 | 
			
		||||
      metacity-message restart
 | 
			
		||||
      metacity-message enable-keybindings
 | 
			
		||||
      metacity-message disable-keybindings
 | 
			
		||||
    The first of these is useful for testing themes, the second is just
 | 
			
		||||
    another way (besides the --restart flag to metacity itself) of
 | 
			
		||||
    restarting metacity, and the third is useful for testing Metacity when
 | 
			
		||||
    running it under an Xnest (typically, the Metacity under the Xnest
 | 
			
		||||
    wouldn't get keybinding notifications--making keyboard navigation not
 | 
			
		||||
    work--but if you disable the keybindings for the global Metacity then
 | 
			
		||||
    the Metacity under the Xnest can then get those keybinding notifications).
 | 
			
		||||
 | 
			
		||||
  metacity-window-demo
 | 
			
		||||
    metacity-window-demo is good for trying behavior of various kinds
 | 
			
		||||
    of window without launching a full desktop.
 | 
			
		||||
 | 
			
		||||
Technical gotchas to keep in mind
 | 
			
		||||
  Files that include gdk.h or gtk.h are not supposed to include
 | 
			
		||||
  display.h or window.h or other core files.  Files in the core
 | 
			
		||||
  (display.[hc], window.[hc]) are not supposed to include gdk.h or
 | 
			
		||||
  gtk.h.  Reasons:
 | 
			
		||||
 | 
			
		||||
    "Basically you don't want GDK most of the time. It adds
 | 
			
		||||
    abstractions that cause problems, because they aren't designed to
 | 
			
		||||
    be used in a WM where we do weird stuff (display grabs, and just
 | 
			
		||||
    being the WM). At best GDK adds inefficiency, at worst it breaks
 | 
			
		||||
    things in weird ways where you have to be a GDK guru to figure
 | 
			
		||||
    them out. Owen also told me that they didn't want to start adding
 | 
			
		||||
    a lot of hacks to GDK to let a WM use it; we both agreed back in
 | 
			
		||||
    the mists of time that metacity would only use it for the "UI"
 | 
			
		||||
    bits as it does.
 | 
			
		||||
 | 
			
		||||
    Having the split in the source code contains and makes very clear
 | 
			
		||||
    the interface between the WM and GDK/GTK. This keeps people from
 | 
			
		||||
    introducing extra GDK/GTK usage when it isn't needed or
 | 
			
		||||
    appropriate. Also, it speeds up the compilation a bit, though this
 | 
			
		||||
    was perhaps more relevant 5 years ago than it is now.
 | 
			
		||||
 | 
			
		||||
    There was also a very old worry that the GDK stuff might have to
 | 
			
		||||
    be in a separate process to work right; that turned out to be
 | 
			
		||||
    untrue. Though who knows what issues the CM will introduce."
 | 
			
		||||
 | 
			
		||||
  Remember that strings stored in X properties are not in UTF-8, and they
 | 
			
		||||
  have to end up in UTF-8 before we try putting them through Pango.
 | 
			
		||||
 | 
			
		||||
  If you make any X request involving a client window, you have to
 | 
			
		||||
  meta_error_trap_push() around the call; this is not necessary for X
 | 
			
		||||
  requests on the frame windows.
 | 
			
		||||
 | 
			
		||||
  Remember that not all windows have frames, and window->frame can be NULL.
 | 
			
		||||
 | 
			
		||||
Other important reading & where to get started
 | 
			
		||||
  Extra reading
 | 
			
		||||
 | 
			
		||||
  There are some other important things to read to get oriented as well.
 | 
			
		||||
  These are:
 | 
			
		||||
    http://pobox.com/~hp/features.html
 | 
			
		||||
    rationales.txt
 | 
			
		||||
    doc/code-overview.txt
 | 
			
		||||
 | 
			
		||||
  It pays to read http://pobox.com/~hp/features.html in order
 | 
			
		||||
  to understand the philosophy of Metacity.
 | 
			
		||||
 | 
			
		||||
  The rationales.txt file has two things: (1) a list of design choices with
 | 
			
		||||
  links in the form of bugzilla bugs that discuss the issue, and (2) a list
 | 
			
		||||
  outstanding bug categories, each of which is tracked by a particular
 | 
			
		||||
  tracker bug in bugzilla from which you can find several closely related
 | 
			
		||||
  bug reports.
 | 
			
		||||
 | 
			
		||||
  doc/code-overview.txt provides a fairly good overview of the code,
 | 
			
		||||
  including coverage of the function of the various files, the main
 | 
			
		||||
  structures and their relationships, and places to start looking in the
 | 
			
		||||
  code tailored to general categories of tasks.
 | 
			
		||||
 | 
			
		||||
  Ideas for tasks to work on
 | 
			
		||||
 | 
			
		||||
  There are a variety of things you could work on in the code.  You may
 | 
			
		||||
  have ideas of your own, but in case you don't, let me provide a list of
 | 
			
		||||
  ideas you could choose from:
 | 
			
		||||
 | 
			
		||||
  If you're ambitious, there's a list of things Havoc made that he'd really
 | 
			
		||||
  like to see tackled, which you can find at
 | 
			
		||||
  http://log.ometer.com/2004-05.html.  Be sure to double check with someone
 | 
			
		||||
  to make sure the item is still relevant if you're interested in one of
 | 
			
		||||
  these.  Another place to look for ideas, of course, is bugzilla.  One can
 | 
			
		||||
  just do queries and look for things that look fixable.
 | 
			
		||||
 | 
			
		||||
  However, perhaps the best way of getting ideas of related tasks to work
 | 
			
		||||
  on, is to look at the second half of the rationales.txt file, which tries
 | 
			
		||||
  to group bugs by type.
 | 
			
		||||
@@ -1,8 +0,0 @@
 | 
			
		||||
Tomas Frydrych
 | 
			
		||||
Email: tf linux intel com
 | 
			
		||||
Userid: tomasf
 | 
			
		||||
 | 
			
		||||
Owen Taylor
 | 
			
		||||
Email: otaylor redhat com
 | 
			
		||||
Userid: otaylor
 | 
			
		||||
 | 
			
		||||
@@ -1,43 +0,0 @@
 | 
			
		||||
Currently active maintainers
 | 
			
		||||
--------------------------------
 | 
			
		||||
 | 
			
		||||
Elijah Newren
 | 
			
		||||
Email: newren gmail com
 | 
			
		||||
Userid: newren
 | 
			
		||||
 | 
			
		||||
  - Usually won't touch the theme bugs (isn't interested) or the
 | 
			
		||||
    compositor (until open source nvidia drivers are up to snuff).
 | 
			
		||||
    Tends to be most interested in libwnck/gtk interactions, focus
 | 
			
		||||
    issues, constraints problems, and raising/stacking, but works on
 | 
			
		||||
    just about anything other than themes and the compositor.
 | 
			
		||||
 | 
			
		||||
Thomas Thurman
 | 
			
		||||
Email: thomas thurman org uk
 | 
			
		||||
Userid: tthurman
 | 
			
		||||
 | 
			
		||||
  - Responsible for all theme bugs and the compositor (thank goodness
 | 
			
		||||
    Thomas got involved, eh?).  I'm sure he'll replace this sentence
 | 
			
		||||
    with his interests when he reads it.  ;-)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
Semi-active maintainers
 | 
			
		||||
--------------------------------
 | 
			
		||||
 | 
			
		||||
Havoc Pennington
 | 
			
		||||
Email: hp  redhat com
 | 
			
		||||
Userid: hp
 | 
			
		||||
  - Original author.  Doesn't patch metacity anymore, but is active in
 | 
			
		||||
    answering questions, responding to bugs, providing very helpful
 | 
			
		||||
    suggestions and insight, and even assisting with debugging.
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
Important historical figureheads
 | 
			
		||||
--------------------------------
 | 
			
		||||
 | 
			
		||||
Rob Adams (readams  readams net)
 | 
			
		||||
  - Was the main maintainer of metacity for a while; particular areas
 | 
			
		||||
    of focus included xinerama, placement, and an older version of the
 | 
			
		||||
    constraints code.  Still responds to bugs every once in a while.
 | 
			
		||||
 | 
			
		||||
Søren Sandmann (sandmann  redhat com)
 | 
			
		||||
  - Wrote most of the current compositing manager code + libcm
 | 
			
		||||
@@ -1,8 +1,8 @@
 | 
			
		||||
 | 
			
		||||
SUBDIRS=src protocol data po doc
 | 
			
		||||
 | 
			
		||||
EXTRA_DIST = HACKING MAINTAINERS rationales.txt
 | 
			
		||||
SUBDIRS=src po doc
 | 
			
		||||
 | 
			
		||||
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}
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										194
									
								
								NEWS
									
									
									
									
									
								
							
							
						
						
									
										194
									
								
								NEWS
									
									
									
									
									
								
							@@ -1,3 +1,197 @@
 | 
			
		||||
3.11.92
 | 
			
		||||
=======
 | 
			
		||||
* Fix identification of CSD windows [Owen; #723029]
 | 
			
		||||
* Update keyboard state unconditionally [Rui; #722847]
 | 
			
		||||
* Misc bug fixes and cleanups [Owen, Rui, Giovanni, Matthias, Adel, Ryan,
 | 
			
		||||
  Jasper, Marek, Florian; #723580, #726123, #726683]
 | 
			
		||||
 | 
			
		||||
Contributors:
 | 
			
		||||
  Giovanni Campagna, Marek Chalupa, Matthias Clasen, Adel Gadllah, Ryan Lortie,
 | 
			
		||||
  Rui Matos, Florian Müllner, Jasper St. Pierre, Owen W. Taylor
 | 
			
		||||
 | 
			
		||||
3.11.91
 | 
			
		||||
=======
 | 
			
		||||
* Don't use keysym to match keybindings [Rui; #678001]
 | 
			
		||||
* Fix message tray icons showing up blank (again) [Adel; #725180]
 | 
			
		||||
* Improve keybinding lookups [Rui; #725588]
 | 
			
		||||
* Fix dynamic updates of titlebar style properties [Owen; #725751]
 | 
			
		||||
* Fix positioning of manually positioned windows [Owen; #724049]
 | 
			
		||||
* Misc bug fixes and cleanups [Jasper, Carlos, Adel, Giovanni, Florian; #720631,
 | 
			
		||||
  #724969, #725216, #724402, #722266, #725338, #725525]
 | 
			
		||||
 | 
			
		||||
Contributors:
 | 
			
		||||
  Giovanni Campagna, Adel Gadllah, Carlos Garnacho, Rui Matos, Florian Müllner,
 | 
			
		||||
  Jasper St. Pierre, Owen W. Taylor
 | 
			
		||||
 | 
			
		||||
3.11.90
 | 
			
		||||
=======
 | 
			
		||||
* Fix double-scaling on high DPI resolutions [Adel; #723931]
 | 
			
		||||
* Make tile previews a compositor effect [Stefano, Florian; #665758]
 | 
			
		||||
* Misc. bug fixes and cleanups [Ryan, Giovanni, Jasper, Adel; #722530, #724257,
 | 
			
		||||
  #724258, #720631, #724364, #724472]
 | 
			
		||||
 | 
			
		||||
Contributors:
 | 
			
		||||
  Giovanni Campagna, Marek Chalupa, Stefano Facchini, Adel Gadllah,
 | 
			
		||||
  Ryan Lortie, Florian Müllner, Jasper St. Pierre, Rico Tzschichholz
 | 
			
		||||
 | 
			
		||||
3.11.5
 | 
			
		||||
======
 | 
			
		||||
* Fix CSD titlebars being placed off-screen [Jasper; #719772]
 | 
			
		||||
* Add support for subsurfaces [Jonas; #705502]
 | 
			
		||||
* Expose MetaWindow:skip-taskbar property [Florian; #723307]
 | 
			
		||||
* Fix legacy tray icons showing up blank [Adel; #721596]
 | 
			
		||||
* Fix configuration of cloned monitors [Adel; #710610]
 | 
			
		||||
* Misc bug fixes and cleanups [Jasper, Adel, Marek, Jonas; #720631, #723468,
 | 
			
		||||
  #720818, #723563, #723564]
 | 
			
		||||
 | 
			
		||||
Contributors:
 | 
			
		||||
  Jonas Ådahl, Marek Ch, Adel Gadllah, Florian Müllner, Jasper St. Pierre
 | 
			
		||||
 | 
			
		||||
3.11.4
 | 
			
		||||
======
 | 
			
		||||
* Don't leave focus on windows that are being unmanaged [Owen; #711618]
 | 
			
		||||
* Reduce server grabs [Daniel Drake; #721345, #721709]
 | 
			
		||||
* Improve heuristic to determine display output name [Cosimo Cecchi; #721674]
 | 
			
		||||
* Atomically unmaximize both directions [Jasper; #722108]
 | 
			
		||||
* Misc bug fixes [Debarshi, Andika, Florian; #721517, #721674, #722347]
 | 
			
		||||
 | 
			
		||||
Contributors:
 | 
			
		||||
  Cosimo Cecchi, Daniel Drake, Florian Müllner, Debarshi Ray, Jasper St. Pierre,
 | 
			
		||||
  Andika Triwidada, Owen W. Taylor
 | 
			
		||||
 | 
			
		||||
3.11.3
 | 
			
		||||
======
 | 
			
		||||
* Fix focus issues with external OSKs[Jasper; #715030]
 | 
			
		||||
* Add a MetaCullable interface [Jasper; #714706]
 | 
			
		||||
* Fix window keybindings [Rui; #719724]
 | 
			
		||||
* Fix settings keyboard/pointer focus for new clients [Rui; #719725]
 | 
			
		||||
* Fix window group paint volume [Owen; #719669]
 | 
			
		||||
* Fix frame extents problems [Owen; #714707]
 | 
			
		||||
* Add shortcut to move windows between monitors [Florian; #671054]
 | 
			
		||||
* Fix problems with focus tracking [Owen; #720558]
 | 
			
		||||
* Misc. bug fixes and cleanups: [Rui, Colin, Lionel, Jasper, Owen; #712833,
 | 
			
		||||
  #719557, #719695, #719833, #678989, #720417, #720630]
 | 
			
		||||
 | 
			
		||||
Contributors:
 | 
			
		||||
  Lionel Landwerlin, Rui Matos, Alberto Milone, Florian Müllner,
 | 
			
		||||
  Jasper St. Pierre, Rico Tzschichholz, Owen W. Taylor, Colin Walters
 | 
			
		||||
 | 
			
		||||
3.11.2
 | 
			
		||||
======
 | 
			
		||||
* Support setting a NULL opaque region [Andreas; #711518]
 | 
			
		||||
* Sync keymap from X to wayland [Giovanni; #707446]
 | 
			
		||||
* Implement support for subsurfaces [Jonas; #705502]
 | 
			
		||||
* Don't focus the no-focus-window for globally active windows [Jasper; #710296]
 | 
			
		||||
* Support "hotplug_mode_update" property [Marc-André; #711216]
 | 
			
		||||
* Fix resize operations using mouse-button-modifier [Lionel; #710251]
 | 
			
		||||
* Fix position of attached modals for CSD windows [Giovanni, Owen; #707194]
 | 
			
		||||
* Misc. bug fixes [Rui, Jasper, Neil, Florian; #712247, #711731]
 | 
			
		||||
 | 
			
		||||
Contributors:
 | 
			
		||||
  Giovanni Campagna, Andreas Heider, Lionel Landwerlin, Marc-André Lureau,
 | 
			
		||||
  Rui Matos, Florian Müllner, Neil Roberts, Sindhu S, Jasper St. Pierre,
 | 
			
		||||
  Rico Tzschichholz, Owen W. Taylor, Jonas Ådahl
 | 
			
		||||
 | 
			
		||||
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:
 | 
			
		||||
  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]
 | 
			
		||||
* Misc bug fixes [Dan, Giovanni, Jasper; #708813, #708420]
 | 
			
		||||
 | 
			
		||||
Contributors:
 | 
			
		||||
  Giovanni Campagna, Adel Gadllah, Dan Horák, Hans Petter Jansson,
 | 
			
		||||
  Jasper St. Pierre
 | 
			
		||||
 | 
			
		||||
3.10.0.1
 | 
			
		||||
========
 | 
			
		||||
* Fix bug when a window changed size twice in a single frame - this
 | 
			
		||||
  can happen with GTK+ client-side decorations [Giovanni, Owen; #708367]
 | 
			
		||||
 | 
			
		||||
Contributors:
 | 
			
		||||
  Giovanni Campagna, Owen Taylor
 | 
			
		||||
 | 
			
		||||
3.10.0
 | 
			
		||||
======
 | 
			
		||||
* Update dependencies [Giovanni; #708210]
 | 
			
		||||
 | 
			
		||||
3.9.92
 | 
			
		||||
======
 | 
			
		||||
* 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]
 | 
			
		||||
* Remove holes generated by disabling the laptop lid [Giovanni; #707473]
 | 
			
		||||
* Misc bug fixes [Giovanni, Pavel, Adel; #707649, #706124, #707584, #707851, #707929,
 | 
			
		||||
  #708070]
 | 
			
		||||
 | 
			
		||||
Contributors:
 | 
			
		||||
  Adel Gadllah, Giovanni Campagna, Kalev Lember, Pavel Vasin
 | 
			
		||||
 | 
			
		||||
Translations:
 | 
			
		||||
  Мирослав Николић po/sr, sr@latin.po, Мирослав Николић [sr, sr@latin],
 | 
			
		||||
  Chao-Hsiung Liao [zh_HK, zh_TW], Yuri Myasoedov [ru],
 | 
			
		||||
  Ville-Pekka Vainio [fi], Changwoo Ryu [ko], A S Alam [pa],
 | 
			
		||||
  Mattias Põldaru [et], Rūdolfs Mazurs [lv], Ihar Hrachyshka [be],
 | 
			
		||||
  Nilamdyuti Goswami [as], Andika Triwidada [id], Baurzhan Muftakhidinov [kk],
 | 
			
		||||
  Benjamin Steinwender [de]
 | 
			
		||||
 | 
			
		||||
3.9.91
 | 
			
		||||
======
 | 
			
		||||
* Drop man pages for removed utilities [Kalev; #706579]
 | 
			
		||||
* 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]
 | 
			
		||||
* 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, #707267, #706982, #706289]
 | 
			
		||||
 | 
			
		||||
Contributors:
 | 
			
		||||
  Giovanni Campagna, Cosimo Cecchi, Adel Gadllah, Colin Guthrie, Kalev Lember,
 | 
			
		||||
  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],
 | 
			
		||||
  Milo Casagrande [it], Balázs Úr [hu], Seán de Búrca [ga], Fran Diéguez [gl],
 | 
			
		||||
  Daniel Mustieles [es], Aurimas Černius [lt], Gil Forcada [ca]
 | 
			
		||||
 | 
			
		||||
3.9.90
 | 
			
		||||
======
 | 
			
		||||
* First release from the wayland branch, includes basic support for running
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										416
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										416
									
								
								README
									
									
									
									
									
								
							@@ -1,416 +0,0 @@
 | 
			
		||||
The original codebase named "Metacity" is not a meta-City as in an
 | 
			
		||||
urban center, but rather Meta-ness as in the state of being
 | 
			
		||||
meta. i.e. metacity : meta as opacity : opaque. Also it may have
 | 
			
		||||
something to do with the Meta key on UNIX keyboards.
 | 
			
		||||
 | 
			
		||||
Since then, it has been renamed mutter after a rebase on top of
 | 
			
		||||
clutter as a compositing manager.
 | 
			
		||||
 | 
			
		||||
COMPILING MUTTER
 | 
			
		||||
===
 | 
			
		||||
 | 
			
		||||
You need GTK+ 2.2.  For startup notification to work you need
 | 
			
		||||
libstartup-notification at
 | 
			
		||||
http://www.freedesktop.org/software/startup-notification/ or on the
 | 
			
		||||
GNOME ftp site.
 | 
			
		||||
You need Clutter 1.0. You need gobject-introspection 0.6.3.
 | 
			
		||||
 | 
			
		||||
REPORTING BUGS AND SUBMITTING PATCHES
 | 
			
		||||
===
 | 
			
		||||
 | 
			
		||||
Report new bugs on http://bugzilla.gnome.org. Please check for
 | 
			
		||||
duplicates, *especially* if you are reporting a feature request. 
 | 
			
		||||
 | 
			
		||||
Please do *not* add "me too!" or "yes I really want this!" comments to
 | 
			
		||||
feature requests in bugzilla. Please read
 | 
			
		||||
http://pobox.com/~hp/features.html prior to adding any kind of flame
 | 
			
		||||
about missing features or misfeatures.
 | 
			
		||||
 | 
			
		||||
Feel free to send patches too; Metacity is relatively small and
 | 
			
		||||
simple, so if you find a bug or want to add a feature it should be
 | 
			
		||||
pretty easy.  Send me mail, or put the patch in bugzilla.
 | 
			
		||||
 | 
			
		||||
See the HACKING file for some notes on hacking Mutter.
 | 
			
		||||
 | 
			
		||||
MUTTER FEATURES
 | 
			
		||||
===
 | 
			
		||||
 | 
			
		||||
 - Uses GTK+ 2.0 for drawing window frames. This means colors, fonts, 
 | 
			
		||||
   etc. come from GTK+ theme.
 | 
			
		||||
 | 
			
		||||
 - Does not expose the concept of "window manager" to the user.  Some
 | 
			
		||||
   of the features in the GNOME control panel and other parts of the
 | 
			
		||||
   desktop happen to be implemented in metacity, such as changing your
 | 
			
		||||
   window border theme, or changing your window navigation shortcuts,
 | 
			
		||||
   but the user doesn't need to know this.
 | 
			
		||||
 | 
			
		||||
 - Includes only the window manager; does not try to be a desktop
 | 
			
		||||
   environment. The pager, configuration, etc. are all separate and
 | 
			
		||||
   modular. The "libwnck" library (which I also wrote) is available
 | 
			
		||||
   for writing metacity extensions, pagers, and so on. (But libwnck
 | 
			
		||||
   isn't metacity specific, or GNOME-dependent; it requires only GTK,
 | 
			
		||||
   and should work with KWin, fvwm2, and other EWMH-compliant WMs.)
 | 
			
		||||
 | 
			
		||||
 - Has a simple theme system and a couple of extra themes come with it.
 | 
			
		||||
   Change themes via gsettings:
 | 
			
		||||
     gsettings set org.gnome.desktop.wm.preferences theme Crux
 | 
			
		||||
     gsettings set org.gnome.desktop.wm.preferences theme Gorilla
 | 
			
		||||
     gsettings set org.gnome.desktop.wm.preferences theme Atlanta
 | 
			
		||||
     gsettings set org.gnome.desktop.wm.preferences theme Bright
 | 
			
		||||
 | 
			
		||||
   See theme-format.txt for docs on the theme format. Use 
 | 
			
		||||
   metacity-theme-viewer to preview themes.
 | 
			
		||||
 | 
			
		||||
 - Change number of workspaces via gsettings:
 | 
			
		||||
     gsettings set org.gnome.desktop.wm.preferences num-workspaces 5
 | 
			
		||||
 | 
			
		||||
   Can also change workspaces from GNOME 2 pager.
 | 
			
		||||
 | 
			
		||||
 - Change focus mode:
 | 
			
		||||
     gsettings set org.gnome.desktop.wm.preferences focus-mode mouse
 | 
			
		||||
     gsettings set org.gnome.desktop.wm.preferences focus-mode sloppy
 | 
			
		||||
     gsettings set org.gnome.desktop.wm.preferences focus-mode click
 | 
			
		||||
 | 
			
		||||
 - Global keybinding defaults include:   
 | 
			
		||||
 | 
			
		||||
    Alt-Tab                forward cycle window focus
 | 
			
		||||
    Alt-Shift-Tab          backward cycle focus
 | 
			
		||||
    Alt-Ctrl-Tab           forward cycle focus among panels
 | 
			
		||||
    Alt-Ctrl-Shift-Tab     backward cycle focus among panels
 | 
			
		||||
    Alt-Escape             cycle window focus without a popup thingy
 | 
			
		||||
    Ctrl-Alt-Left Arrow    previous workspace
 | 
			
		||||
    Ctrl-Alt-Right Arrow   next workspace
 | 
			
		||||
    Ctrl-Alt-D             minimize/unminimize all, to show desktop
 | 
			
		||||
 | 
			
		||||
   Change keybindings for example:
 | 
			
		||||
 | 
			
		||||
     gsettings set org.gnome.desktop.wm.keybindings switch-to-workspace-1 '[<Alt>F1]'
 | 
			
		||||
   
 | 
			
		||||
   Also try the GNOME keyboard shortcuts control panel.
 | 
			
		||||
 | 
			
		||||
 - Window keybindings:
 | 
			
		||||
 | 
			
		||||
    Alt-space         window menu
 | 
			
		||||
 | 
			
		||||
    Mnemonics work in the menu. That is, Alt-space then underlined
 | 
			
		||||
    letter in the menu item works.
 | 
			
		||||
 | 
			
		||||
    Choose Move from menu, and arrow keys to move the window.
 | 
			
		||||
 | 
			
		||||
    While moving, hold down Control to move slower, and 
 | 
			
		||||
      Shift to snap to edges.
 | 
			
		||||
 | 
			
		||||
    Choose Resize from menu, and nothing happens yet, but 
 | 
			
		||||
      eventually I might implement something.
 | 
			
		||||
 | 
			
		||||
    Keybindings for things like maximize window, vertical maximize,
 | 
			
		||||
    etc. can be bound, but may not all exist by default. See
 | 
			
		||||
    metacity.schemas.
 | 
			
		||||
 | 
			
		||||
 - Window mouse bindings:
 | 
			
		||||
 | 
			
		||||
    Clicking anywhere on frame with button 1 will raise/focus window
 | 
			
		||||
    
 | 
			
		||||
    If you click a window control, such as the close button, then the 
 | 
			
		||||
     control will activate on button release if you are still over it
 | 
			
		||||
     on release (as with most GUI toolkits)
 | 
			
		||||
 | 
			
		||||
    If you click and drag borders with button 1 it resizes the window
 | 
			
		||||
    
 | 
			
		||||
    If you click and drag the titlebar with button 1 it moves the 
 | 
			
		||||
     window.
 | 
			
		||||
 | 
			
		||||
    If you click anywhere on the frame with button 2 it lowers the 
 | 
			
		||||
     window.
 | 
			
		||||
 | 
			
		||||
    If you click anywhere on the frame with button 3 it shows the 
 | 
			
		||||
     window menu.
 | 
			
		||||
 | 
			
		||||
    If you hold down Super (windows key) and click inside a window, it
 | 
			
		||||
     will move the window (buttons 1 and 2) or show menu (button 3).
 | 
			
		||||
     Or you can configure a different modifier for this.
 | 
			
		||||
 | 
			
		||||
    If you pick up a window with button 1 and then switch workspaces
 | 
			
		||||
     the window will come with you to the new workspace, this is 
 | 
			
		||||
     a feature copied from Enlightenment.
 | 
			
		||||
 | 
			
		||||
    If you hold down Shift while moving a window, the window snaps
 | 
			
		||||
     to edges of other windows and the screen.
 | 
			
		||||
 | 
			
		||||
 - Session management:
 | 
			
		||||
 | 
			
		||||
    Mutter connects to the session manager and will set itself up to
 | 
			
		||||
     be respawned. It theoretically restores sizes/positions/workspace
 | 
			
		||||
     for session-aware applications.
 | 
			
		||||
 | 
			
		||||
 - Mutter implements much of the EWMH window manager specification
 | 
			
		||||
   from freedesktop.org, as well as the older ICCCM.  Please refer to
 | 
			
		||||
   the COMPLIANCE file for information on mutter compliance with
 | 
			
		||||
   these standards.
 | 
			
		||||
 | 
			
		||||
 - Uses Pango to render text, so has cool i18n capabilities. 
 | 
			
		||||
   Supports UTF-8 window titles and such.
 | 
			
		||||
 | 
			
		||||
 - There are simple animations for actions such as minimization, 
 | 
			
		||||
   to help users see what is happening. Should probably 
 | 
			
		||||
   have a few more of these and make them nicer.
 | 
			
		||||
 | 
			
		||||
 - if you have the proper X setup, set the GDK_USE_XFT=1 
 | 
			
		||||
   environment variable to get antialiased window titles.
 | 
			
		||||
 | 
			
		||||
 - considers the panel when placing windows and maximizing
 | 
			
		||||
   them.
 | 
			
		||||
 | 
			
		||||
 - handles the window manager selection from the ICCCM. Will exit if
 | 
			
		||||
   another WM claims it, and can claim it from another WM if you pass
 | 
			
		||||
   the --replace argument. So if you're running another
 | 
			
		||||
   ICCCM-compliant WM, you can run "mutter --replace" to replace it
 | 
			
		||||
   with Metacity.
 | 
			
		||||
 | 
			
		||||
 - does basic colormap handling
 | 
			
		||||
 | 
			
		||||
 - and much more! well, maybe not a lot more.
 | 
			
		||||
 | 
			
		||||
HOW TO ADD EXTERNAL FEATURES
 | 
			
		||||
===
 | 
			
		||||
 | 
			
		||||
You can write a mutter "plugin" such as a pager, window list, icon
 | 
			
		||||
box, task menu, or even things like "window matching" using the
 | 
			
		||||
Extended Window Manager Hints. See http://www.freedesktop.org for the
 | 
			
		||||
EWMH specification. An easy-to-use library called "libwnck" is
 | 
			
		||||
available that uses the EWMH and is specifically designed for writing
 | 
			
		||||
WM accessories.
 | 
			
		||||
 | 
			
		||||
You might be interested in existing accessories such as "Devil's Pie"
 | 
			
		||||
by Ross Burton, which add features to Mutter (or other
 | 
			
		||||
EWMH-compliant WMs).
 | 
			
		||||
 | 
			
		||||
MUTTER BUGS, NON-FEATURES, AND CAVEATS
 | 
			
		||||
===
 | 
			
		||||
 | 
			
		||||
See bugzilla: http://bugzilla.gnome.org/query.cgi
 | 
			
		||||
 | 
			
		||||
FAQ
 | 
			
		||||
===
 | 
			
		||||
 | 
			
		||||
Q: Will you add my feature?
 | 
			
		||||
 | 
			
		||||
A: If it makes sense to turn on unconditionally, or is genuinely a
 | 
			
		||||
   harmless preference that I would not be embarrassed to put in a
 | 
			
		||||
   simple, uncluttered, user-friendly configuration dialog.
 | 
			
		||||
 | 
			
		||||
   If the only rationale for your feature is that other window
 | 
			
		||||
   managers have it, or that you are personally used to it, or
 | 
			
		||||
   something like that, then I will not be impressed. Metacity is
 | 
			
		||||
   firmly in the "choose good defaults" camp rather than the "offer 6
 | 
			
		||||
   equally broken ways to do it, and let the user pick one" camp.
 | 
			
		||||
 | 
			
		||||
   This is part of a "no crackrock" policy, despite some exceptions
 | 
			
		||||
   I'm mildly embarrassed about. For example, multiple workspaces
 | 
			
		||||
   probably constitute crackrock, they confuse most users and really
 | 
			
		||||
   are not that useful if you have a decent tasklist and so on. But I
 | 
			
		||||
   am too used to them to turn them off.  Or alternatively
 | 
			
		||||
   iconification/tasklist is crack, and workspaces/pager are good. But
 | 
			
		||||
   having both is certainly a bit wrong.  Sloppy focus is probably
 | 
			
		||||
   crackrock too.
 | 
			
		||||
 | 
			
		||||
   But don't think unlimited crack is OK just because I slipped up a
 | 
			
		||||
   little. No slippery slope here.
 | 
			
		||||
 | 
			
		||||
   Don't let this discourage patches and fixes - I love those. ;-)
 | 
			
		||||
   Just be prepared to hear the above objections if your patch adds
 | 
			
		||||
   some crack-ridden configuration option.
 | 
			
		||||
 | 
			
		||||
   http://pobox.com/~hp/free-software-ui.html
 | 
			
		||||
   http://pobox.com/~hp/features.html   
 | 
			
		||||
 | 
			
		||||
Q: Will Mutter be part of GNOME?
 | 
			
		||||
 | 
			
		||||
A: It is not officially part of GNOME as of GNOME 2.27. We are
 | 
			
		||||
   hoping to have mutter officially included as of GNOME 2.28. 
 | 
			
		||||
 | 
			
		||||
Q: Why does Mutter remember the workspace/position of some apps 
 | 
			
		||||
   but not others across logout/login?
 | 
			
		||||
 | 
			
		||||
A: Mutter only stores sizes/positions for apps that are session
 | 
			
		||||
   managed. As far as I can determine, there is no way to attempt to
 | 
			
		||||
   remember workspace/position for non-session-aware apps without
 | 
			
		||||
   causing a lot of weird effects.
 | 
			
		||||
 | 
			
		||||
   The reason is that you don't know which non-SM-aware apps were
 | 
			
		||||
   launched by the session. When you initially log in, Metacity sees a
 | 
			
		||||
   bunch of new windows appear. But it can't distinguish between
 | 
			
		||||
   windows that were stored in your session, or windows you just
 | 
			
		||||
   launched after logging in. If Metacity tried to guess that a window
 | 
			
		||||
   was from the session, it could e.g. end up maximizing a dialog, or
 | 
			
		||||
   put a window you just launched on another desktop or in a weird
 | 
			
		||||
   place. And in fact I see a lot of bugs like this in window managers
 | 
			
		||||
   that try to handle non-session-aware apps.
 | 
			
		||||
 | 
			
		||||
   However, for session-aware apps, Mutter can tell that the
 | 
			
		||||
   application instance is from the session and thus restore it
 | 
			
		||||
   reliably, assuming the app properly restores the windows it had 
 | 
			
		||||
   open on session save.
 | 
			
		||||
   
 | 
			
		||||
   So the correct way to fix the situation is to make apps
 | 
			
		||||
   session-aware. libSM has come with X for years, it's very
 | 
			
		||||
   standardized, it's shared by GNOME and KDE - even twm is
 | 
			
		||||
   session-aware. So anyone who won't take a patch to add SM is more
 | 
			
		||||
   archaic than twm - and you should flame them. ;-)
 | 
			
		||||
 | 
			
		||||
   Docs on session management:
 | 
			
		||||
    http://www.fifi.org/doc/xspecs/xsmp.txt.gz
 | 
			
		||||
    http://www.fifi.org/doc/xspecs/SMlib.txt.gz
 | 
			
		||||
 | 
			
		||||
   See also the ICCCM section on SM. For GNOME apps, use the
 | 
			
		||||
   GnomeClient object. For a simple example of using libSM directly,
 | 
			
		||||
   twm/session.c in the twm source code is pretty easy to understand.
 | 
			
		||||
 | 
			
		||||
Q: How about adding viewports in addition to workspaces?
 | 
			
		||||
 | 
			
		||||
A: I could conceivably be convinced to use viewports _instead_ of
 | 
			
		||||
   workspaces, though currently I'm not thinking that. But I don't
 | 
			
		||||
   think it makes any sense to have both; it's just confusing. They
 | 
			
		||||
   are functionally equivalent.
 | 
			
		||||
 | 
			
		||||
   You may think this means that you won't have certain keybindings, 
 | 
			
		||||
   or something like that. This is a misconception. The only 
 | 
			
		||||
   _fundamental_ difference between viewports and workspaces is that 
 | 
			
		||||
   with viewports, windows can "overlap" and appear partially on 
 | 
			
		||||
   one and partially on another. All other differences that
 | 
			
		||||
   traditionally exist in other window managers are accidental - 
 | 
			
		||||
   the features commonly associated with viewports can be implemented
 | 
			
		||||
   for workspaces, and vice versa.
 | 
			
		||||
 | 
			
		||||
   So I don't want to have two kinds of
 | 
			
		||||
   workspace/desktop/viewport/whatever, but I'm willing to add
 | 
			
		||||
   features traditionally associated with either kind if those
 | 
			
		||||
   features make sense.
 | 
			
		||||
 | 
			
		||||
Q: Why is the panel always on top?
 | 
			
		||||
 | 
			
		||||
A: Because it's a better user interface, and until we made this not
 | 
			
		||||
   configurable a bunch of apps were not getting fixed (the app
 | 
			
		||||
   authors were just saying "put your panel on the bottom" instead of
 | 
			
		||||
   properly supporting fullscreen mode, and such).
 | 
			
		||||
 | 
			
		||||
   rationales.txt has the bugzilla URL for some flamefesting on this,
 | 
			
		||||
   if you want to go back and relive the glory.
 | 
			
		||||
   Read these and the bugzilla stuff before asking/commenting:
 | 
			
		||||
     http://pobox.com/~hp/free-software-ui.html
 | 
			
		||||
     http://pobox.com/~hp/features.html   
 | 
			
		||||
 | 
			
		||||
Q: Why is there no edge flipping?
 | 
			
		||||
 | 
			
		||||
A: This one is also in rationales.txt. Because "ouija board" UI, where
 | 
			
		||||
   you just move the mouse around and the computer guesses what you
 | 
			
		||||
   mean, has a lot of issues. This includes mouse focus, shade-hover
 | 
			
		||||
   mode, edge flipping, autoraise, etc. Metacity has mouse focus and
 | 
			
		||||
   autoraise as a compromise, but these features are all confusing for
 | 
			
		||||
   many users, and cause problems with accessibility, fitt's law, and
 | 
			
		||||
   so on.
 | 
			
		||||
 | 
			
		||||
   Read these and the bugzilla stuff before asking/commenting:
 | 
			
		||||
     http://pobox.com/~hp/free-software-ui.html
 | 
			
		||||
     http://pobox.com/~hp/features.html   
 | 
			
		||||
 | 
			
		||||
Q: Why does wireframe move/resize suck?
 | 
			
		||||
 | 
			
		||||
A: You can turn it on with the reduced_resources setting.
 | 
			
		||||
 | 
			
		||||
   But: it has low usability, and is a pain
 | 
			
		||||
   to implement, and there's no reason opaque move/resize should be a
 | 
			
		||||
   problem on any setup that can run a modern desktop worth a darn to
 | 
			
		||||
   begin with.
 | 
			
		||||
 | 
			
		||||
   Read these and the bugzilla stuff before asking/commenting:
 | 
			
		||||
     http://pobox.com/~hp/free-software-ui.html
 | 
			
		||||
     http://pobox.com/~hp/features.html   
 | 
			
		||||
 | 
			
		||||
   The reason we had to add wireframe anyway was broken 
 | 
			
		||||
   proprietary apps that can't handle lots of resize events.
 | 
			
		||||
 | 
			
		||||
Q: Why no XYZ?
 | 
			
		||||
 | 
			
		||||
A: You are probably getting the idea by now - check rationales.txt,
 | 
			
		||||
   query/search bugzilla, and read http://pobox.com/~hp/features.html
 | 
			
		||||
   and http://pobox.com/~hp/free-software-ui.html
 | 
			
		||||
 | 
			
		||||
   Then sit down and answer the question for yourself.  Is the feature
 | 
			
		||||
   good? What's the rationale for it? Answer "why" not just "why not."
 | 
			
		||||
   Justify in terms of users as a whole, not just users like
 | 
			
		||||
   yourself. How else can you solve the same problem? etc. If that
 | 
			
		||||
   leads you to a strong opinion, then please, post the rationale for
 | 
			
		||||
   discussion to an appropriate bugzilla bug, or to
 | 
			
		||||
   usability@gnome.org.
 | 
			
		||||
 | 
			
		||||
   Please don't just "me too!" on bugzilla bugs, please don't think
 | 
			
		||||
   flames will get you anywhere, and please don't repeat rationale
 | 
			
		||||
   that's already been offered.
 | 
			
		||||
 | 
			
		||||
Q: Your dumb web pages you made me read talk about solving problems in
 | 
			
		||||
   fundamental ways instead of adding preferences or workarounds.
 | 
			
		||||
   What are some examples where metacity has done this?
 | 
			
		||||
 | 
			
		||||
A: There are quite a few, though many opportunities remain.  Sometimes
 | 
			
		||||
   the real fix involves application changes. The metacity approach is
 | 
			
		||||
   that it's OK to require apps to change, though there are also
 | 
			
		||||
   plenty of workarounds in metacity for battles considered too hard
 | 
			
		||||
   to fight.
 | 
			
		||||
 | 
			
		||||
   Here are some examples:
 | 
			
		||||
 | 
			
		||||
   - fullscreen mode was introduced to allow position constraints,
 | 
			
		||||
     panel-on-top, and other such things to apply to normal windows
 | 
			
		||||
     while still allowing video players etc. to "just work"
 | 
			
		||||
 | 
			
		||||
   - "whether to include minimized windows in Alt+Tab" was solved 
 | 
			
		||||
     by putting minimized windows at the *end* of the tab order. 
 | 
			
		||||
 | 
			
		||||
   - Whether to pop up a feedback display during Alt+Tab was solved by
 | 
			
		||||
     having both Alt+Tab and Alt+Esc
 | 
			
		||||
 | 
			
		||||
   - Whether to have a "kill" feature was solved by automatically
 | 
			
		||||
     detecting and offering to kill stuck apps. Better, metacity
 | 
			
		||||
     actually does "kill -9" on the process, it doesn't just
 | 
			
		||||
     disconnect the process from the X server. You'll appreciate this
 | 
			
		||||
     if you ever did a "kill" on Netscape 4, and watched it keep
 | 
			
		||||
     eating 100% CPU even though the X server had booted it.
 | 
			
		||||
 | 
			
		||||
   - The workspaces vs. viewports mess was avoided by adding
 | 
			
		||||
     directional navigation and such to workspaces, see discussion
 | 
			
		||||
     earlier in this file.
 | 
			
		||||
 | 
			
		||||
   - Instead of configurable placement algorithms, there's just one 
 | 
			
		||||
     that works fairly well most of the time.
 | 
			
		||||
 | 
			
		||||
   - To avoid excess CPU use during opaque move/resize, we rate limit
 | 
			
		||||
     the updates to the application window's size.
 | 
			
		||||
 | 
			
		||||
   - Instead of configurable "show size of window while resizing,"
 | 
			
		||||
     it's only shown for windows where it matters, such as terminals.
 | 
			
		||||
     (Only use-case given for all windows is for web designers
 | 
			
		||||
     choosing their web browser size, but there are web sites and
 | 
			
		||||
     desktop backgrounds that do this for you.)
 | 
			
		||||
 | 
			
		||||
   - Using startup notification, applications open on the workspace
 | 
			
		||||
     where you launched them, not the active workspace when their
 | 
			
		||||
     window is opened.
 | 
			
		||||
 | 
			
		||||
   - and much more.
 | 
			
		||||
 | 
			
		||||
Q: I think mutter sucks.
 | 
			
		||||
 | 
			
		||||
A: Feel free to use any WM you like. The reason metacity follows the
 | 
			
		||||
   ICCCM and EWMH specifications is that it makes metacity a modular,
 | 
			
		||||
   interchangeable part in the desktop. libwnck-based apps such as the
 | 
			
		||||
   GNOME window list will work just fine with any EWMH-compliant WM.
 | 
			
		||||
 | 
			
		||||
Q: Did you spend a lot of time on this?
 | 
			
		||||
 | 
			
		||||
A: Originally the answer was no. Sadly the answer is now yes.
 | 
			
		||||
 | 
			
		||||
Q: How can you claim that you are anti-crack, while still 
 | 
			
		||||
   writing a window manager?
 | 
			
		||||
 | 
			
		||||
A: I have no comment on that.
 | 
			
		||||
@@ -1,11 +1,11 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
#!/bin/sh
 | 
			
		||||
# Run this to generate all the initial makefiles, etc.
 | 
			
		||||
 | 
			
		||||
srcdir=`dirname $0`
 | 
			
		||||
test -z "$srcdir" && srcdir=.
 | 
			
		||||
 | 
			
		||||
PKG_NAME="mutter"
 | 
			
		||||
REQUIRED_AUTOMAKE_VERSION=1.13
 | 
			
		||||
REQUIRED_AUTOMAKE_VERSION=1.10
 | 
			
		||||
 | 
			
		||||
(test -f $srcdir/configure.ac \
 | 
			
		||||
  && test -d $srcdir/src) || {
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										33
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										33
									
								
								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], [9])
 | 
			
		||||
m4_define([mutter_micro_version], [90])
 | 
			
		||||
m4_define([mutter_minor_version], [11])
 | 
			
		||||
m4_define([mutter_micro_version], [92])
 | 
			
		||||
 | 
			
		||||
m4_define([mutter_version],
 | 
			
		||||
          [mutter_major_version.mutter_minor_version.mutter_micro_version])
 | 
			
		||||
@@ -77,9 +78,9 @@ MUTTER_PC_MODULES="
 | 
			
		||||
   cairo >= 1.10.0
 | 
			
		||||
   gsettings-desktop-schemas >= 3.7.3
 | 
			
		||||
   xcomposite >= 0.2 xfixes xrender xdamage xi >= 1.6.0
 | 
			
		||||
   $CLUTTER_PACKAGE >= 1.14.3
 | 
			
		||||
   cogl-1.0 >= 1.13.3
 | 
			
		||||
   upower-glib > 0.9.11
 | 
			
		||||
   $CLUTTER_PACKAGE >= 1.17.5
 | 
			
		||||
   cogl-1.0 >= 1.17.1
 | 
			
		||||
   upower-glib >= 0.99.0
 | 
			
		||||
   gnome-desktop-3.0
 | 
			
		||||
"
 | 
			
		||||
 | 
			
		||||
@@ -139,6 +140,7 @@ 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)
 | 
			
		||||
 | 
			
		||||
# Unconditionally use this dir to avoid a circular dep with gnomecc
 | 
			
		||||
GNOME_KEYBINDINGS_KEYSDIR="${datadir}/gnome-control-center/keybindings"
 | 
			
		||||
@@ -203,22 +205,7 @@ 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)
 | 
			
		||||
 | 
			
		||||
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])
 | 
			
		||||
MUTTER_PC_MODULES="$MUTTER_PC_MODULES xcursor"
 | 
			
		||||
 | 
			
		||||
AC_PATH_PROG([WAYLAND_SCANNER],[wayland-scanner],[no])
 | 
			
		||||
AS_IF([test "x$WAYLAND_SCANNER" = "xno"],
 | 
			
		||||
@@ -226,7 +213,7 @@ AS_IF([test "x$WAYLAND_SCANNER" = "xno"],
 | 
			
		||||
AC_SUBST([WAYLAND_SCANNER])
 | 
			
		||||
AC_SUBST(XWAYLAND_PATH)
 | 
			
		||||
 | 
			
		||||
MUTTER_PC_MODULES="$MUTTER_PC_MODULES wayland-server"
 | 
			
		||||
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],
 | 
			
		||||
@@ -466,8 +453,6 @@ doc/reference/meta-docs.sgml
 | 
			
		||||
src/Makefile
 | 
			
		||||
src/libmutter-wayland.pc
 | 
			
		||||
src/compositor/plugins/Makefile
 | 
			
		||||
protocol/Makefile
 | 
			
		||||
data/Makefile
 | 
			
		||||
po/Makefile.in
 | 
			
		||||
])
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1,3 +0,0 @@
 | 
			
		||||
defaultcursordir = $(pkgdatadir)/cursors
 | 
			
		||||
 | 
			
		||||
dist_defaultcursor_DATA = left_ptr.png
 | 
			
		||||
										
											Binary file not shown.
										
									
								
							| 
		 Before Width: | Height: | Size: 736 B  | 
@@ -1,4 +1,4 @@
 | 
			
		||||
SUBDIRS = man reference
 | 
			
		||||
 | 
			
		||||
EXTRA_DIST=theme-format.txt dialogs.txt code-overview.txt \
 | 
			
		||||
	how-to-get-focus-right.txt
 | 
			
		||||
	how-to-get-focus-right.txt rationales.txt
 | 
			
		||||
 
 | 
			
		||||
@@ -1,4 +1,3 @@
 | 
			
		||||
man_MANS = mutter.1 mutter-theme-viewer.1 \
 | 
			
		||||
	   mutter-window-demo.1 mutter-message.1
 | 
			
		||||
man_MANS = mutter.1
 | 
			
		||||
 | 
			
		||||
EXTRA_DIST = $(man_MANS)
 | 
			
		||||
 
 | 
			
		||||
@@ -1,60 +0,0 @@
 | 
			
		||||
.\"                                      Hey, EMACS: -*- nroff -*-
 | 
			
		||||
.\" First parameter, NAME, should be all caps
 | 
			
		||||
.\" Second parameter, SECTION, should be 1-8, maybe w/ subsection
 | 
			
		||||
.\" other parameters are allowed: see man(7), man(1)
 | 
			
		||||
.\" -----
 | 
			
		||||
.\" This file was confirmed to be licenced under the GPL
 | 
			
		||||
.\" by its author and copyright holder, Akira TAGOH, on June 1st 2008:
 | 
			
		||||
.\"
 | 
			
		||||
.\" > I'm comfortable with DFSG-free. that sounds great if you think it's
 | 
			
		||||
.\" > useful and worth containing it in upstream.
 | 
			
		||||
.\" ...
 | 
			
		||||
.\" > Right I know. any licenses that is DFSG-free, I'm ok with whatever,
 | 
			
		||||
.\" > since I have contributed that for Debian. so GPL is no problem for me.
 | 
			
		||||
.\" -----
 | 
			
		||||
.TH MUTTER\-MESSAGE 1 "28 August 2002"
 | 
			
		||||
.\" Please adjust this date whenever revising the manpage.
 | 
			
		||||
.\"
 | 
			
		||||
.\" Some roff macros, for reference:
 | 
			
		||||
.\" .nh        disable hyphenation
 | 
			
		||||
.\" .hy        enable hyphenation
 | 
			
		||||
.\" .ad l      left justify
 | 
			
		||||
.\" .ad b      justify to both left and right margins
 | 
			
		||||
.\" .nf        disable filling
 | 
			
		||||
.\" .fi        enable filling
 | 
			
		||||
.\" .br        insert line break
 | 
			
		||||
.\" .sp <n>    insert n+1 empty lines
 | 
			
		||||
.\" for manpage-specific macros, see man(7)
 | 
			
		||||
.SH NAME
 | 
			
		||||
MUTTER\-MESSAGE \- a command to send a message to Mutter
 | 
			
		||||
.SH SYNOPSIS
 | 
			
		||||
.B MUTTER\-MESSAGE
 | 
			
		||||
[restart|reload\-theme|enable\-keybindings|disable\-keybindings]
 | 
			
		||||
.SH DESCRIPTION
 | 
			
		||||
This manual page documents briefly the
 | 
			
		||||
.B mutter\-message\fP.
 | 
			
		||||
This manual page was written for the Debian distribution
 | 
			
		||||
because the original program does not have a manual page.
 | 
			
		||||
.PP
 | 
			
		||||
.\" TeX users may be more comfortable with the \fB<whatever>\fP and
 | 
			
		||||
.\" \fI<whatever>\fP escape sequences to invode bold face and italics, 
 | 
			
		||||
.\" respectively.
 | 
			
		||||
\fBmutter\-message\fP send a specified message to \fBmutter\fP(1).
 | 
			
		||||
.SH OPTIONS
 | 
			
		||||
.TP
 | 
			
		||||
.B restart
 | 
			
		||||
Restart \fBmutter\fP(1) which is running.
 | 
			
		||||
.TP
 | 
			
		||||
.B reload-theme
 | 
			
		||||
Reload a theme which is specified on gsettings database.
 | 
			
		||||
.TP
 | 
			
		||||
.B enable-keybindings
 | 
			
		||||
Enable all of keybindings which is specified on gsettings database.
 | 
			
		||||
.TP
 | 
			
		||||
.B disable-keybindings
 | 
			
		||||
Disable all of keybindings which is specified on gsettings database.
 | 
			
		||||
.SH SEE ALSO
 | 
			
		||||
.BR mutter (1)
 | 
			
		||||
.SH AUTHOR
 | 
			
		||||
This manual page was written by Akira TAGOH <tagoh@debian.org>,
 | 
			
		||||
for the Debian GNU/Linux system (but may be used by others).
 | 
			
		||||
@@ -1,43 +0,0 @@
 | 
			
		||||
.\" In .TH, FOO should be all caps, SECTION should be 1-8, maybe w/ subsection
 | 
			
		||||
.\" other parms are allowed: see man(7), man(1)
 | 
			
		||||
.\"
 | 
			
		||||
.\" Based on template provided by Tom Christiansen <tchrist@jhereg.perl.com>.
 | 
			
		||||
.\" 
 | 
			
		||||
.TH MUTTER-THEME-VIEWER 1 "1 June 2004" 
 | 
			
		||||
.SH NAME
 | 
			
		||||
mutter-theme-viewer \- view mutter themes
 | 
			
		||||
.SH SYNOPSIS
 | 
			
		||||
.B mutter-theme-viewer
 | 
			
		||||
[
 | 
			
		||||
.I THEMENAME
 | 
			
		||||
]
 | 
			
		||||
.SH DESCRIPTION
 | 
			
		||||
.\" Putting a newline after each sentence can generate better output.
 | 
			
		||||
.B mutter-theme-viewer
 | 
			
		||||
allows you to preview any installed Mutter theme.
 | 
			
		||||
.PP
 | 
			
		||||
When designing a new Mutter theme, you can use
 | 
			
		||||
.B mutter-theme-viewer
 | 
			
		||||
to measure the performance of a window frame option, and to preview
 | 
			
		||||
the option.
 | 
			
		||||
.SH OPTIONS
 | 
			
		||||
.TP
 | 
			
		||||
.I THEMENAME
 | 
			
		||||
Name of the theme to be shown (\fIAtlanta\fR by default).
 | 
			
		||||
It is case-sensitive.
 | 
			
		||||
.SH FILES
 | 
			
		||||
.br
 | 
			
		||||
.nf
 | 
			
		||||
.TP
 | 
			
		||||
.I /usr/share/themes
 | 
			
		||||
system themes directory
 | 
			
		||||
.TP
 | 
			
		||||
.I /usr/share/themes/*/mutter-1/mutter-theme-1.xml
 | 
			
		||||
theme specification file
 | 
			
		||||
.SH AUTHOR
 | 
			
		||||
This manual page was written by Jose M. Moya <josem@die.upm.es>, for
 | 
			
		||||
the Debian  GNU/Linux system (but may be used by others).
 | 
			
		||||
.SH "SEE ALSO"
 | 
			
		||||
.\" Always quote multiple words for .SH
 | 
			
		||||
.BR mutter (1),
 | 
			
		||||
.BR mutter-window-demo (1).
 | 
			
		||||
@@ -1,25 +0,0 @@
 | 
			
		||||
.\" In .TH, FOO should be all caps, SECTION should be 1-8, maybe w/ subsection
 | 
			
		||||
.\" other parms are allowed: see man(7), man(1)
 | 
			
		||||
.\"
 | 
			
		||||
.\" Based on template provided by Tom Christiansen <tchrist@jhereg.perl.com>.
 | 
			
		||||
.\" 
 | 
			
		||||
.TH MUTTER-WINDOW-DEMO 1 "1 June 2004" 
 | 
			
		||||
.SH NAME
 | 
			
		||||
mutter-window-demo \- demo of window features
 | 
			
		||||
.SH SYNOPSIS
 | 
			
		||||
.B mutter-window-demo
 | 
			
		||||
.SH DESCRIPTION
 | 
			
		||||
.\" Putting a newline after each sentence can generate better output.
 | 
			
		||||
This program demonstrates various kinds of windows that window
 | 
			
		||||
managers and window manager themes should handle.
 | 
			
		||||
.PP
 | 
			
		||||
Be sure to tear off the menu and toolbar, those are also a special
 | 
			
		||||
kind of window.
 | 
			
		||||
.SH AUTHOR
 | 
			
		||||
This manual page was written by Jose M. Moya <josem@die.upm.es>, for
 | 
			
		||||
the Debian  GNU/Linux system (but may be used by others).
 | 
			
		||||
.SH "SEE ALSO"
 | 
			
		||||
.\" Always quote multiple words for .SH
 | 
			
		||||
.BR x-window-manager (1),
 | 
			
		||||
.BR mutter (1),
 | 
			
		||||
.BR mutter-theme-viewer (1).
 | 
			
		||||
@@ -49,8 +49,8 @@ FIXXREF_OPTIONS=
 | 
			
		||||
# Used for dependencies. The docs will be rebuilt if any of these change.
 | 
			
		||||
# e.g. HFILE_GLOB=$(top_srcdir)/gtk/*.h
 | 
			
		||||
# e.g. CFILE_GLOB=$(top_srcdir)/gtk/*.c
 | 
			
		||||
HFILE_GLOB=$(top_srcdir)/src/*.h
 | 
			
		||||
CFILE_GLOB=$(top_srcdir)/src/*.c
 | 
			
		||||
HFILE_GLOB=$(top_srcdir)/src/*/*.h
 | 
			
		||||
CFILE_GLOB=$(top_srcdir)/src/*/*.c
 | 
			
		||||
 | 
			
		||||
# Extra header to include when scanning, which are not under DOC_SOURCE_DIR
 | 
			
		||||
# e.g. EXTRA_HFILES=$(top_srcdir}/contrib/extra.h
 | 
			
		||||
 
 | 
			
		||||
@@ -96,8 +96,6 @@ meta_compositor_hide_window
 | 
			
		||||
meta_compositor_switch_workspace
 | 
			
		||||
meta_compositor_maximize_window
 | 
			
		||||
meta_compositor_unmaximize_window
 | 
			
		||||
meta_compositor_window_mapped
 | 
			
		||||
meta_compositor_window_unmapped
 | 
			
		||||
meta_compositor_sync_window_geometry
 | 
			
		||||
meta_compositor_set_updates_frozen
 | 
			
		||||
meta_compositor_queue_frame_drawn
 | 
			
		||||
@@ -207,7 +205,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>
 | 
			
		||||
@@ -389,6 +386,23 @@ MetaWindowActorPrivate
 | 
			
		||||
meta_window_actor_get_type
 | 
			
		||||
</SECTION>
 | 
			
		||||
 | 
			
		||||
<SECTION>
 | 
			
		||||
<FILE>meta-cullable</FILE>
 | 
			
		||||
<TITLE>MetaCullable</TITLE>
 | 
			
		||||
MetaCullable
 | 
			
		||||
MetaCullableInterface
 | 
			
		||||
meta_cullable_cull_out
 | 
			
		||||
meta_cullable_reset_culling
 | 
			
		||||
meta_cullable_cull_out_children
 | 
			
		||||
meta_cullable_reset_culling_children
 | 
			
		||||
<SUBSECTION Standard>
 | 
			
		||||
META_TYPE_CULLABLE
 | 
			
		||||
META_CULLABLE
 | 
			
		||||
META_IS_CULLABLE
 | 
			
		||||
META_CULLABLE_GET_IFACE
 | 
			
		||||
meta_cullable_get_type
 | 
			
		||||
</SECTION>
 | 
			
		||||
 | 
			
		||||
<SECTION>
 | 
			
		||||
<FILE>prefs</FILE>
 | 
			
		||||
MetaPreference
 | 
			
		||||
@@ -542,7 +556,10 @@ meta_window_is_override_redirect
 | 
			
		||||
meta_window_is_skip_taskbar
 | 
			
		||||
meta_window_get_rect
 | 
			
		||||
meta_window_get_input_rect
 | 
			
		||||
meta_window_get_frame_rect
 | 
			
		||||
meta_window_get_outer_rect
 | 
			
		||||
meta_window_client_rect_to_frame_rect
 | 
			
		||||
meta_window_frame_rect_to_client_rect
 | 
			
		||||
meta_window_get_screen
 | 
			
		||||
meta_window_get_display
 | 
			
		||||
meta_window_get_xwindow
 | 
			
		||||
 
 | 
			
		||||
@@ -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" />
 | 
			
		||||
 
 | 
			
		||||
@@ -44,6 +44,7 @@ is
 | 
			
		||||
it
 | 
			
		||||
ja
 | 
			
		||||
ka
 | 
			
		||||
kk
 | 
			
		||||
kn
 | 
			
		||||
ko
 | 
			
		||||
ku
 | 
			
		||||
 
 | 
			
		||||
@@ -16,14 +16,14 @@ src/core/monitor.c
 | 
			
		||||
src/core/mutter.c
 | 
			
		||||
src/core/prefs.c
 | 
			
		||||
src/core/screen.c
 | 
			
		||||
src/core/session.c
 | 
			
		||||
src/x11/session.c
 | 
			
		||||
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/x11/window-props.c
 | 
			
		||||
src/x11/xprops.c
 | 
			
		||||
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
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										441
									
								
								po/be.po
									
									
									
									
									
								
							
							
						
						
									
										441
									
								
								po/be.po
									
									
									
									
									
								
							@@ -1,10 +1,10 @@
 | 
			
		||||
# Ihar Hrachyshka <ihar.hrachyshka@gmail.com>, 2011.
 | 
			
		||||
# Ihar Hrachyshka <ihar.hrachyshka@gmail.com>, 2011, 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-03-01 15:50+0000\n"
 | 
			
		||||
"POT-Creation-Date: 2013-08-18 20:03+0000\n"
 | 
			
		||||
"PO-Revision-Date: 2012-10-13 17:44+0300\n"
 | 
			
		||||
"Last-Translator: Ігар Грачышка <ihar.hrachyshka@gmail.com>\n"
 | 
			
		||||
"Language-Team: Belarusian <i18n-bel-gnome@googlegroups.com>\n"
 | 
			
		||||
@@ -206,7 +206,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:507
 | 
			
		||||
#: ../src/compositor/compositor.c:589
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Another compositing manager is already running on screen %i on display \"%s"
 | 
			
		||||
@@ -214,11 +214,11 @@ msgid ""
 | 
			
		||||
msgstr ""
 | 
			
		||||
"Іншы кампазітны кіраўнік вокнаў ужо абслугоўвае экран %i дысплея \"%s\"."
 | 
			
		||||
 | 
			
		||||
#: ../src/compositor/meta-background.c:1111
 | 
			
		||||
#: ../src/compositor/meta-background.c:1076
 | 
			
		||||
msgid "background texture could not be created from file"
 | 
			
		||||
msgstr "не ўдалося стварыць фонавую тэкстуру з файла"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/bell.c:320
 | 
			
		||||
#: ../src/core/bell.c:322
 | 
			
		||||
msgid "Bell event"
 | 
			
		||||
msgstr "Падзея з сігналам"
 | 
			
		||||
 | 
			
		||||
@@ -251,18 +251,18 @@ msgstr "_Пачакаць"
 | 
			
		||||
msgid "_Force Quit"
 | 
			
		||||
msgstr "_Змусіць да выхаду"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/display.c:401
 | 
			
		||||
#: ../src/core/display.c:421
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Missing %s extension required for compositing"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"Адсутнічае пашырэнне \"%s\", патрэбнае для ажыццяўлення кампазітнага вываду"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/display.c:493
 | 
			
		||||
#: ../src/core/display.c:513
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to open X Window System display '%s'\n"
 | 
			
		||||
msgstr "Не ўдалося адкрыць X-дысплей аконнай сістэмы \"%s\"\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/keybindings.c:929
 | 
			
		||||
#: ../src/core/keybindings.c:1136
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Some other program is already using the key %s with modifiers %x as a "
 | 
			
		||||
@@ -271,41 +271,41 @@ msgstr ""
 | 
			
		||||
"Нейкая іншая праграма ўжо выкарыстоўвае як скарот клавішу %s з "
 | 
			
		||||
"мадыфікатарамі %x\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/keybindings.c:1129
 | 
			
		||||
#: ../src/core/keybindings.c:1333
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "\"%s\" is not a valid accelerator\n"
 | 
			
		||||
msgstr "\"%s\" - гэта хібны клавіятурны скарот\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:196
 | 
			
		||||
#: ../src/core/main.c:197
 | 
			
		||||
msgid "Disable connection to session manager"
 | 
			
		||||
msgstr "Выключыць злучэнне з кіраўніком сеансаў"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:202
 | 
			
		||||
#: ../src/core/main.c:203
 | 
			
		||||
msgid "Replace the running window manager"
 | 
			
		||||
msgstr "Замяніць дзейнага кіраўніка вокнаў"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:208
 | 
			
		||||
#: ../src/core/main.c:209
 | 
			
		||||
msgid "Specify session management ID"
 | 
			
		||||
msgstr "Вызначыць ідэнтыфікатар для кіравання сеансам"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:213
 | 
			
		||||
#: ../src/core/main.c:214
 | 
			
		||||
msgid "X Display to use"
 | 
			
		||||
msgstr "Патрэбны X-дысплей"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:219
 | 
			
		||||
#: ../src/core/main.c:220
 | 
			
		||||
msgid "Initialize session from savefile"
 | 
			
		||||
msgstr "Ініцыяваць сеанс з файла"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:225
 | 
			
		||||
#: ../src/core/main.c:226
 | 
			
		||||
msgid "Make X calls synchronous"
 | 
			
		||||
msgstr "Сінхронна выконваць выклікі X-сістэмы"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:494
 | 
			
		||||
#: ../src/core/main.c:534
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to scan themes directory: %s\n"
 | 
			
		||||
msgstr "Не ўдалося праглядзець каталог з матывамі аздаблення: %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:510
 | 
			
		||||
#: ../src/core/main.c:550
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
 | 
			
		||||
@@ -313,6 +313,19 @@ msgstr ""
 | 
			
		||||
"Не ўдалося адшукаць матыў аздаблення! Праверце, каб каталог %s існаваў і "
 | 
			
		||||
"змяшчаў звычайныя матывы.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/monitor.c:711
 | 
			
		||||
msgid "Built-in display"
 | 
			
		||||
msgstr "Убудаваны дысплей"
 | 
			
		||||
 | 
			
		||||
#. 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 "Невядомы %s"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/mutter.c:40
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
@@ -337,7 +350,7 @@ msgstr "Вывесці нумар версіі праграмы"
 | 
			
		||||
msgid "Mutter plugin to use"
 | 
			
		||||
msgstr "Патрэбны плугін Mutter"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1087
 | 
			
		||||
#: ../src/core/prefs.c:1202
 | 
			
		||||
msgid ""
 | 
			
		||||
"Workarounds for broken applications disabled. Some applications may not "
 | 
			
		||||
"behave properly.\n"
 | 
			
		||||
@@ -345,12 +358,12 @@ msgstr ""
 | 
			
		||||
"Асаблівыя паводзіны для некаторых хібных праграм выключаныя. Некаторыя "
 | 
			
		||||
"праграмы могуць перастаць працаваць, як мае быць.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1162
 | 
			
		||||
#: ../src/core/prefs.c:1277
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
 | 
			
		||||
msgstr "Не ўдалося разабраць азначэнне шрыфту \"%s\" з GSettings-ключа %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1228
 | 
			
		||||
#: ../src/core/prefs.c:1343
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"\"%s\" found in configuration database is not a valid value for mouse button "
 | 
			
		||||
@@ -359,7 +372,7 @@ msgstr ""
 | 
			
		||||
"Значэнне \"%s\", знойдзенае ў базе канфігурацыйных даных, не азначае "
 | 
			
		||||
"мадыфікатар мышынай кнопкі\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1780
 | 
			
		||||
#: ../src/core/prefs.c:1909
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"\"%s\" found in configuration database is not a valid value for keybinding "
 | 
			
		||||
@@ -368,17 +381,17 @@ msgstr ""
 | 
			
		||||
"Значэнне \"%s\", знойдзенае ў базе канфігурацыйных даных, не азначае "
 | 
			
		||||
"клавіятурны скарот \"%s\"\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1879
 | 
			
		||||
#: ../src/core/prefs.c:1999
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Workspace %d"
 | 
			
		||||
msgstr "Прастора працы %d"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:673
 | 
			
		||||
#: ../src/core/screen.c:534
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Screen %d on display '%s' is invalid\n"
 | 
			
		||||
msgstr "Экран %d на дысплеі \"%s\" хібны\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:689
 | 
			
		||||
#: ../src/core/screen.c:550
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Screen %d on display \"%s\" already has a window manager; try using the --"
 | 
			
		||||
@@ -387,19 +400,19 @@ msgstr ""
 | 
			
		||||
"Экран %d на дысплеі \"%s\" ужо мае аконнага кіраўніка. Каб замяніць яго "
 | 
			
		||||
"новым, дадайце опцыю --replace.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:716
 | 
			
		||||
#: ../src/core/screen.c:577
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Could not acquire window manager selection on screen %d display \"%s\"\n"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"Не ўдалося пераняць вылучэнне кіраўніка вокнаў для экрана %d дысплея \"%s\"\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:794
 | 
			
		||||
#: ../src/core/screen.c:655
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Screen %d on display \"%s\" already has a window manager\n"
 | 
			
		||||
msgstr "Экран %d на дысплеі \"%s\" ужо мае кіраўніка вокнаў\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:979
 | 
			
		||||
#: ../src/core/screen.c:846
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Could not release screen %d on display \"%s\"\n"
 | 
			
		||||
msgstr "Не ўдалося вызваліць экран %d на дысплеі \"%s\"\n"
 | 
			
		||||
@@ -460,46 +473,45 @@ msgstr ""
 | 
			
		||||
"Гэтыя вокны не падтрымліваюць функцыі захавання дзейнага ладу працы, і таму "
 | 
			
		||||
"іх прыйдзецца запусціць уручную пасля наступнага ўваходу ў сістэму."
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:80
 | 
			
		||||
#: ../src/core/util.c:84
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to open debug log: %s\n"
 | 
			
		||||
msgstr "Не ўдалося адкрыць адладачны журнал: %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:90
 | 
			
		||||
#: ../src/core/util.c:94
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to fdopen() log file %s: %s\n"
 | 
			
		||||
msgstr "Не ўдалося выканаць fdopen() для журнальнага файла %s: %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:96
 | 
			
		||||
#: ../src/core/util.c:100
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Opened log file %s\n"
 | 
			
		||||
msgstr "Журнальны файл %s адкрыты\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:115 ../src/tools/mutter-message.c:149
 | 
			
		||||
#, c-format
 | 
			
		||||
#: ../src/core/util.c:119
 | 
			
		||||
msgid "Mutter was compiled without support for verbose mode\n"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"Праграма \"Mutter\" была скампіляваная без падтрымкі падрабязнага "
 | 
			
		||||
"пратакаліравання\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:259
 | 
			
		||||
#: ../src/core/util.c:264
 | 
			
		||||
msgid "Window manager: "
 | 
			
		||||
msgstr "Кіраўнік вокнаў: "
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:407
 | 
			
		||||
#: ../src/core/util.c:414
 | 
			
		||||
msgid "Bug in window manager: "
 | 
			
		||||
msgstr "Хіба ў кіраўніку вокнаў: "
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:438
 | 
			
		||||
#: ../src/core/util.c:445
 | 
			
		||||
msgid "Window manager warning: "
 | 
			
		||||
msgstr "Перасцярога ад кіраўніка вокнаў: "
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:466
 | 
			
		||||
#: ../src/core/util.c:473
 | 
			
		||||
msgid "Window manager error: "
 | 
			
		||||
msgstr "Памылка кіраўніка вокнаў: "
 | 
			
		||||
 | 
			
		||||
#. first time through
 | 
			
		||||
#: ../src/core/window.c:7539
 | 
			
		||||
#: ../src/core/window.c:7533
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
 | 
			
		||||
@@ -515,7 +527,7 @@ msgstr ""
 | 
			
		||||
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
 | 
			
		||||
#. * about these apps but make them work.
 | 
			
		||||
#.
 | 
			
		||||
#: ../src/core/window.c:8263
 | 
			
		||||
#: ../src/core/window.c:8257
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
 | 
			
		||||
@@ -525,22 +537,22 @@ msgstr ""
 | 
			
		||||
"памеру, але разам з гэтым прызначыла для сябе мінімальны памер %d x %d і "
 | 
			
		||||
"максімальны памер %d x %d. Такія паводзіны не маюць сэнсу.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/window-props.c:318
 | 
			
		||||
#: ../src/core/window-props.c:347
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Application set a bogus _NET_WM_PID %lu\n"
 | 
			
		||||
msgstr "Праграма прызначыла памылковае значэнне _NET_WM_PID %lu\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/window-props.c:434
 | 
			
		||||
#: ../src/core/window-props.c:463
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "%s (on %s)"
 | 
			
		||||
msgstr "%s (на %s)"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/window-props.c:1517
 | 
			
		||||
#: ../src/core/window-props.c:1546
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
 | 
			
		||||
msgstr "Для %2$s вызначана хібнае акно WM_TRANSIENT_FOR 0x%1$lx.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/window-props.c:1528
 | 
			
		||||
#: ../src/core/window-props.c:1557
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
 | 
			
		||||
msgstr "WM_TRANSIENT_FOR акно 0x%lx для %s стварыла б цыкл.\n"
 | 
			
		||||
@@ -689,7 +701,8 @@ msgstr ""
 | 
			
		||||
 | 
			
		||||
#: ../src/org.gnome.mutter.gschema.xml.in.h:17
 | 
			
		||||
msgid "Auto maximize nearly monitor sized windows"
 | 
			
		||||
msgstr "Аўтаматычна максімалізаваць вокны, якія расцягнутыя амаль на ўвесь экран"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"Аўтаматычна максімалізаваць вокны, якія расцягнутыя амаль на ўвесь экран"
 | 
			
		||||
 | 
			
		||||
#: ../src/org.gnome.mutter.gschema.xml.in.h:18
 | 
			
		||||
msgid ""
 | 
			
		||||
@@ -707,109 +720,104 @@ 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:69
 | 
			
		||||
#: ../src/ui/menu.c:67
 | 
			
		||||
msgid "Mi_nimize"
 | 
			
		||||
msgstr "_Мінімалізаваць"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:71
 | 
			
		||||
#: ../src/ui/menu.c:69
 | 
			
		||||
msgid "Ma_ximize"
 | 
			
		||||
msgstr "Ма_ксімалізаваць"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:73
 | 
			
		||||
#: ../src/ui/menu.c:71
 | 
			
		||||
msgid "Unma_ximize"
 | 
			
		||||
msgstr "Скасаваць ма_ксімалізацыю"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:75
 | 
			
		||||
#: ../src/ui/menu.c:73
 | 
			
		||||
msgid "Roll _Up"
 | 
			
		||||
msgstr "_Скруціць акно ў загаловак"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:77
 | 
			
		||||
#: ../src/ui/menu.c:75
 | 
			
		||||
msgid "_Unroll"
 | 
			
		||||
msgstr "Рас_круціць акно з загалоўка"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:79
 | 
			
		||||
#: ../src/ui/menu.c:77
 | 
			
		||||
msgid "_Move"
 | 
			
		||||
msgstr "_Перамясціць акно"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:81
 | 
			
		||||
#: ../src/ui/menu.c:79
 | 
			
		||||
msgid "_Resize"
 | 
			
		||||
msgstr "_Змяніць памер акна"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:83
 | 
			
		||||
#: ../src/ui/menu.c:81
 | 
			
		||||
msgid "Move Titlebar On_screen"
 | 
			
		||||
msgstr "Перамясціць загаловак акна па _экране"
 | 
			
		||||
 | 
			
		||||
#. separator
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:86 ../src/ui/menu.c:88
 | 
			
		||||
#: ../src/ui/menu.c:84 ../src/ui/menu.c:86
 | 
			
		||||
msgid "Always on _Top"
 | 
			
		||||
msgstr "Заўсёды _наверсе"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:90
 | 
			
		||||
#: ../src/ui/menu.c:88
 | 
			
		||||
msgid "_Always on Visible Workspace"
 | 
			
		||||
msgstr "Заўсёды на _бачнай прасторы працы"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:92
 | 
			
		||||
#: ../src/ui/menu.c:90
 | 
			
		||||
msgid "_Only on This Workspace"
 | 
			
		||||
msgstr "_Толькі на гэтай прасторы працы"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:94
 | 
			
		||||
#: ../src/ui/menu.c:92
 | 
			
		||||
msgid "Move to Workspace _Left"
 | 
			
		||||
msgstr "Перамясціць на прастору працы з_лева"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:96
 | 
			
		||||
#: ../src/ui/menu.c:94
 | 
			
		||||
msgid "Move to Workspace R_ight"
 | 
			
		||||
msgstr "Перамясціць на прастору працы с_права"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:98
 | 
			
		||||
#: ../src/ui/menu.c:96
 | 
			
		||||
msgid "Move to Workspace _Up"
 | 
			
		||||
msgstr "Перамясціць на прастору працы з_верху"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:100
 | 
			
		||||
#: ../src/ui/menu.c:98
 | 
			
		||||
msgid "Move to Workspace _Down"
 | 
			
		||||
msgstr "Перамясціць на прастору працы з_нізу"
 | 
			
		||||
 | 
			
		||||
#. separator
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:104
 | 
			
		||||
#: ../src/ui/menu.c:102
 | 
			
		||||
msgid "_Close"
 | 
			
		||||
msgstr "_Закрыць акно"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/menu.c:204
 | 
			
		||||
#: ../src/ui/menu.c:202
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Workspace %d%n"
 | 
			
		||||
msgstr "Прастора працы %d%n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/menu.c:214
 | 
			
		||||
#: ../src/ui/menu.c:212
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Workspace 1_0"
 | 
			
		||||
msgstr "Прастора працы 1_0"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/menu.c:216
 | 
			
		||||
#: ../src/ui/menu.c:214
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Workspace %s%d"
 | 
			
		||||
msgstr "Прастора працы %s%d"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/menu.c:397
 | 
			
		||||
#: ../src/ui/menu.c:384
 | 
			
		||||
msgid "Move to Another _Workspace"
 | 
			
		||||
msgstr "П_ерамясціць на іншую прастору працы"
 | 
			
		||||
 | 
			
		||||
@@ -911,49 +919,49 @@ msgstr "Mod5"
 | 
			
		||||
msgid "%d x %d"
 | 
			
		||||
msgstr "%d x %d"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:235
 | 
			
		||||
#: ../src/ui/theme.c:236
 | 
			
		||||
msgid "top"
 | 
			
		||||
msgstr "верхнюю"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:237
 | 
			
		||||
#: ../src/ui/theme.c:238
 | 
			
		||||
msgid "bottom"
 | 
			
		||||
msgstr "ніжнюю"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:239
 | 
			
		||||
#: ../src/ui/theme.c:240
 | 
			
		||||
msgid "left"
 | 
			
		||||
msgstr "левую"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:241
 | 
			
		||||
#: ../src/ui/theme.c:242
 | 
			
		||||
msgid "right"
 | 
			
		||||
msgstr "правую"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:269
 | 
			
		||||
#: ../src/ui/theme.c:270
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "frame geometry does not specify \"%s\" dimension"
 | 
			
		||||
msgstr "апісанне геаметрыі рамкі акна не вызначае %s граніцу"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:288
 | 
			
		||||
#: ../src/ui/theme.c:289
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "frame geometry does not specify dimension \"%s\" for border \"%s\""
 | 
			
		||||
msgstr ""
 | 
			
		||||
"апісанне геаметрыі рамкі акна не вызначае %s граніцу для аблямоўкі \"%s\""
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:325
 | 
			
		||||
#: ../src/ui/theme.c:326
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Button aspect ratio %g is not reasonable"
 | 
			
		||||
msgstr "Прапорцыі кнопкі %g не маюць сэнсу"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:337
 | 
			
		||||
#: ../src/ui/theme.c:338
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Frame geometry does not specify size of buttons"
 | 
			
		||||
msgstr "Апісанне геаметрыі рамкі акна не вызначае памер кнопак"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1050
 | 
			
		||||
#: ../src/ui/theme.c:1051
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Gradients should have at least two colors"
 | 
			
		||||
msgstr "Градыент мусіць мець прынамсі два колеры"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1202
 | 
			
		||||
#: ../src/ui/theme.c:1203
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"GTK custom color specification must have color name and fallback in "
 | 
			
		||||
@@ -962,7 +970,7 @@ msgstr ""
 | 
			
		||||
"Уласная спецыфікацыя колеру GTK мусіць змяшчаць назвы асноўнага і запаснога "
 | 
			
		||||
"колераў у дужках, напрыклад, gtk:custom(foo,bar). Не ўдалося разабраць \"%s\""
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1218
 | 
			
		||||
#: ../src/ui/theme.c:1219
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
 | 
			
		||||
@@ -971,7 +979,7 @@ msgstr ""
 | 
			
		||||
"Хібны знак \"%c\" у параметры color_name спецыфікацыі gtk:custom, дазволеныя "
 | 
			
		||||
"толькі A-Za-z0-9-_"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1232
 | 
			
		||||
#: ../src/ui/theme.c:1233
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
 | 
			
		||||
@@ -980,7 +988,7 @@ msgstr ""
 | 
			
		||||
"Фармат gtk:custom: \"gtk:custom(назва_колеру,запасны_колер)\"; \"%s\" не "
 | 
			
		||||
"адпавядае фармату"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1277
 | 
			
		||||
#: ../src/ui/theme.c:1278
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
 | 
			
		||||
@@ -989,7 +997,7 @@ msgstr ""
 | 
			
		||||
"Спецыфікацыя колеру GTK мусіць мець стан у квадратных дужках, напрыклад, gtk:"
 | 
			
		||||
"fg[NORMAL], дзе NORMAL - гэта стан. Не ўдалося разабраць \"%s\""
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1291
 | 
			
		||||
#: ../src/ui/theme.c:1292
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"GTK color specification must have a close bracket after the state, e.g. gtk:"
 | 
			
		||||
@@ -999,17 +1007,17 @@ msgstr ""
 | 
			
		||||
"напрыклад, gtk:fg[NORMAL], дзе NORMAL - гэта стан. Не ўдалося разабраць \"%s"
 | 
			
		||||
"\""
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1302
 | 
			
		||||
#: ../src/ui/theme.c:1303
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Did not understand state \"%s\" in color specification"
 | 
			
		||||
msgstr "Незразумелы стан \"%s\" у спецыфікацыі колеру"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1315
 | 
			
		||||
#: ../src/ui/theme.c:1316
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Did not understand color component \"%s\" in color specification"
 | 
			
		||||
msgstr "Незразумелы складнік колеру \"%s\" у спецыфікацыі колеру"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1344
 | 
			
		||||
#: ../src/ui/theme.c:1345
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the "
 | 
			
		||||
@@ -1018,58 +1026,58 @@ msgstr ""
 | 
			
		||||
"Фармат змяшанага колеру - \"blend/bg_color/fg_color/alpha\". \"%s\" не "
 | 
			
		||||
"адпавядае фармату."
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1355
 | 
			
		||||
#: ../src/ui/theme.c:1356
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Could not parse alpha value \"%s\" in blended color"
 | 
			
		||||
msgstr "Не ўдалося разабраць значэнне альфа \"%s\" ў змяшаным колеры"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1365
 | 
			
		||||
#: ../src/ui/theme.c:1366
 | 
			
		||||
#, 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:1412
 | 
			
		||||
#: ../src/ui/theme.c:1413
 | 
			
		||||
#, 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:1423
 | 
			
		||||
#: ../src/ui/theme.c:1424
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Could not parse shade factor \"%s\" in shaded color"
 | 
			
		||||
msgstr "Не ўдалося разабраць каэфіцыент ценю \"%s\" у зацененым колеры"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1433
 | 
			
		||||
#: ../src/ui/theme.c:1434
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Shade factor \"%s\" in shaded color is negative"
 | 
			
		||||
msgstr "Каэфіцыент ценю \"%s\" у зацененым колеры адмоўны"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1462
 | 
			
		||||
#: ../src/ui/theme.c:1463
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Could not parse color \"%s\""
 | 
			
		||||
msgstr "Не ўдалося разабраць колер \"%s\""
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1779
 | 
			
		||||
#: ../src/ui/theme.c:1780
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression contains character '%s' which is not allowed"
 | 
			
		||||
msgstr "Каардынатны выраз змяшчае забаронены знак \"%s\""
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1806
 | 
			
		||||
#: ../src/ui/theme.c:1807
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Coordinate expression contains floating point number '%s' which could not be "
 | 
			
		||||
"parsed"
 | 
			
		||||
msgstr "Каардынатны выраз змяшчае незразумелы лік з нефіксаванай коскай \"%s\""
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1820
 | 
			
		||||
#: ../src/ui/theme.c:1821
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression contains integer '%s' which could not be parsed"
 | 
			
		||||
msgstr "Каардынатны выраз змяшчае незразумелы цэлы лік \"%s\""
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1941
 | 
			
		||||
#: ../src/ui/theme.c:1942
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Coordinate expression contained unknown operator at the start of this text: "
 | 
			
		||||
@@ -1077,17 +1085,17 @@ msgid ""
 | 
			
		||||
msgstr ""
 | 
			
		||||
"Каардынатны выраз змяшчае невядомы аператар у пачатку гэтага тэксту: \"%s\""
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1998
 | 
			
		||||
#: ../src/ui/theme.c:1999
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression was empty or not understood"
 | 
			
		||||
msgstr "Каардынатны выраз пусты ці незразумелы"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2111 ../src/ui/theme.c:2121 ../src/ui/theme.c:2155
 | 
			
		||||
#: ../src/ui/theme.c:2112 ../src/ui/theme.c:2122 ../src/ui/theme.c:2156
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression results in division by zero"
 | 
			
		||||
msgstr "Каардынатны выраз вымагае дзялення на нуль"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2163
 | 
			
		||||
#: ../src/ui/theme.c:2164
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Coordinate expression tries to use mod operator on a floating-point number"
 | 
			
		||||
@@ -1095,24 +1103,24 @@ msgstr ""
 | 
			
		||||
"Каардынатны выраз спрабуе ўжыць аператар дзялення па модулі для ліку з "
 | 
			
		||||
"нефіксаванай коскай"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2219
 | 
			
		||||
#: ../src/ui/theme.c:2220
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Coordinate expression has an operator \"%s\" where an operand was expected"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"У каардынатным выразе ўжыты аператар \"%s\" там, дзе мусіў быць аперанд"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2228
 | 
			
		||||
#: ../src/ui/theme.c:2229
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression had an operand where an operator was expected"
 | 
			
		||||
msgstr "У каардынатным выразе ўжыты аперанд там, дзе мусіў быць аператар"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2236
 | 
			
		||||
#: ../src/ui/theme.c:2237
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression ended with an operator instead of an operand"
 | 
			
		||||
msgstr "Каардынатны выраз заканчваецца аператарам, а не аперандам"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2246
 | 
			
		||||
#: ../src/ui/theme.c:2247
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Coordinate expression has operator \"%c\" following operator \"%c\" with no "
 | 
			
		||||
@@ -1121,41 +1129,41 @@ msgstr ""
 | 
			
		||||
"У каардынатным выразе за аператарам \"%c\" ідзе аператар \"%c\", але паміж "
 | 
			
		||||
"імі няма аперанда"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2397 ../src/ui/theme.c:2442
 | 
			
		||||
#: ../src/ui/theme.c:2398 ../src/ui/theme.c:2443
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression had unknown variable or constant \"%s\""
 | 
			
		||||
msgstr "У каардынатным выразе невядомая зменная альбо канстанта \"%s\""
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2496
 | 
			
		||||
#: ../src/ui/theme.c:2497
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression parser overflowed its buffer."
 | 
			
		||||
msgstr "Прылада для разбору каардынатных выразаў перапоўніла свой буфер."
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2525
 | 
			
		||||
#: ../src/ui/theme.c:2526
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression had a close parenthesis with no open parenthesis"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"У каардынатным выразе ўжытыя дужкі, якія закрываюцца, але няма тых, якія б "
 | 
			
		||||
"адкрываліся"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2589
 | 
			
		||||
#: ../src/ui/theme.c:2590
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression had an open parenthesis with no close parenthesis"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"У каардынатным выразе ўжытыя дужкі, якія адкрываюцца, але няма тых, якія б "
 | 
			
		||||
"закрываліся"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2600
 | 
			
		||||
#: ../src/ui/theme.c:2601
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression doesn't seem to have any operators or operands"
 | 
			
		||||
msgstr "У каардынатным выразе няма ні аператараў, ні аперандаў"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2813 ../src/ui/theme.c:2833 ../src/ui/theme.c:2853
 | 
			
		||||
#: ../src/ui/theme.c:2814 ../src/ui/theme.c:2834 ../src/ui/theme.c:2854
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Theme contained an expression that resulted in an error: %s\n"
 | 
			
		||||
msgstr "Матыў аздаблення змяшчае выраз, які стаў прычынай памылкі: %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:4499
 | 
			
		||||
#: ../src/ui/theme.c:4500
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be "
 | 
			
		||||
@@ -1164,25 +1172,25 @@ msgstr ""
 | 
			
		||||
"Для гэтага стылю рамкі трэба вызначыць <button function=\"%s\" state=\"%s\" "
 | 
			
		||||
"draw_ops=\"whatever\"/>"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5010 ../src/ui/theme.c:5035
 | 
			
		||||
#: ../src/ui/theme.c:5011 ../src/ui/theme.c:5036
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"Няма <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"што-небудзь\"/>"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5083
 | 
			
		||||
#: ../src/ui/theme.c:5082
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to load theme \"%s\": %s\n"
 | 
			
		||||
msgstr "Не ўдалося загрузіць матыў аздаблення \"%s\": %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../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
 | 
			
		||||
#: ../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
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "No <%s> set for theme \"%s\""
 | 
			
		||||
msgstr "Для матыву аздаблення \"%2$s\" не прызначана <%1$s>"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5255
 | 
			
		||||
#: ../src/ui/theme.c:5254
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
 | 
			
		||||
@@ -1191,7 +1199,7 @@ msgstr ""
 | 
			
		||||
"Стыль рамкі не вызначаны для вокнаў тыпу \"%s\" для матыву аздаблення \"%s"
 | 
			
		||||
"\". Дадайце <window type=\"%s\" style_set=\"штосьці\"/>."
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5662 ../src/ui/theme.c:5724 ../src/ui/theme.c:5787
 | 
			
		||||
#: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"User-defined constants must begin with a capital letter; \"%s\" does not"
 | 
			
		||||
@@ -1199,7 +1207,7 @@ msgstr ""
 | 
			
		||||
"Назвы канстантаў, вызначаных карыстальнікам, мусяць пачынацца з вялікай "
 | 
			
		||||
"літары. \"%s\" не адпавядае гэтаму патрабаванню."
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5670 ../src/ui/theme.c:5732 ../src/ui/theme.c:5795
 | 
			
		||||
#: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Constant \"%s\" has already been defined"
 | 
			
		||||
msgstr "Канстанта \"%s\" ужо азначана"
 | 
			
		||||
@@ -1585,207 +1593,8 @@ msgstr "Выкарыстанне тэксту ўнутры элемента <%s>
 | 
			
		||||
msgid "<%s> specified twice for this theme"
 | 
			
		||||
msgstr "<%s> двойчы вызначаны для гэтага матыву аздаблення"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-parser.c:4334
 | 
			
		||||
#: ../src/ui/theme-parser.c:4336
 | 
			
		||||
#, 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"
 | 
			
		||||
 | 
			
		||||
#: ../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"
 | 
			
		||||
 | 
			
		||||
#: ../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 "Месца для загалоўка акна"
 | 
			
		||||
 | 
			
		||||
#: ../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 секунд каляндарнага часу, уключна з рэсурсамі X-сервера (%g мілісекунд "
 | 
			
		||||
"на рамку)\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:1273
 | 
			
		||||
msgid "position expression test returned TRUE but set error"
 | 
			
		||||
msgstr "выпрабаванне выразу пазіцыі вярнула TRUE, але паведаміла аб памылцы"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:1275
 | 
			
		||||
msgid "position expression test returned FALSE but didn't set error"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"выпрабаванне выразу пазіцыі вярнула FALSE, але не паведаміла аб памылцы"
 | 
			
		||||
 | 
			
		||||
#: ../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"
 | 
			
		||||
 | 
			
		||||
#: ../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"
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										231
									
								
								po/et.po
									
									
									
									
									
								
							
							
						
						
									
										231
									
								
								po/et.po
									
									
									
									
									
								
							@@ -14,8 +14,8 @@ 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-03-12 18:53+0000\n"
 | 
			
		||||
"PO-Revision-Date: 2013-03-12 20:55+0300\n"
 | 
			
		||||
"POT-Creation-Date: 2013-09-10 15:25+0000\n"
 | 
			
		||||
"PO-Revision-Date: 2013-09-11 23:20+0300\n"
 | 
			
		||||
"Last-Translator: Mattias Põldaru <mahfiaz@gmail.com>\n"
 | 
			
		||||
"Language-Team: Estonian <>\n"
 | 
			
		||||
"Language: et\n"
 | 
			
		||||
@@ -23,6 +23,7 @@ msgstr ""
 | 
			
		||||
"Content-Type: text/plain; charset=UTF-8\n"
 | 
			
		||||
"Content-Transfer-Encoding: 8bit\n"
 | 
			
		||||
"Plural-Forms: nplurals=2; plural=(n!=1);\n"
 | 
			
		||||
"X-Generator: Poedit 1.5.4\n"
 | 
			
		||||
 | 
			
		||||
msgid "Navigation"
 | 
			
		||||
msgstr "Navigeerimine"
 | 
			
		||||
@@ -249,6 +250,17 @@ msgid ""
 | 
			
		||||
msgstr ""
 | 
			
		||||
"Teemat ei leitud! Veendu, et %s on olemas ja sisaldab harilikke teemasid.\n"
 | 
			
		||||
 | 
			
		||||
msgid "Built-in display"
 | 
			
		||||
msgstr "Sisseehitatud kuva"
 | 
			
		||||
 | 
			
		||||
#. 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"'
 | 
			
		||||
#.
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Unknown %s"
 | 
			
		||||
msgstr "Tundmatu %s"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"mutter %s\n"
 | 
			
		||||
@@ -381,7 +393,6 @@ msgstr "Tõrge logifaili %s avamisel funktsiooniga fdopen(): %s\n"
 | 
			
		||||
msgid "Opened log file %s\n"
 | 
			
		||||
msgstr "Avati logifail %s\n"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Mutter was compiled without support for verbose mode\n"
 | 
			
		||||
msgstr "Mutter kompileeriti ilma jutuka režiimi toeta\n"
 | 
			
		||||
 | 
			
		||||
@@ -572,10 +583,6 @@ msgstr "Akna valimine tabulaatori hüpikaknalt"
 | 
			
		||||
msgid "Cancel tab popup"
 | 
			
		||||
msgstr "Tabulaatori hüpikakna katkestamine"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Usage: %s\n"
 | 
			
		||||
msgstr "Kasutamine: %s\n"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
msgid "Mi_nimize"
 | 
			
		||||
msgstr "_Minimeeri"
 | 
			
		||||
@@ -1281,159 +1288,151 @@ msgstr "Selle teema jaoks on <%s> määratud kaks korda"
 | 
			
		||||
msgid "Failed to find a valid file for theme %s\n"
 | 
			
		||||
msgstr "Tõrge %s teema jaoks korrektse faili leidmisel\n"
 | 
			
		||||
 | 
			
		||||
msgid "_Windows"
 | 
			
		||||
msgstr "_Aknad"
 | 
			
		||||
#~ msgid "Usage: %s\n"
 | 
			
		||||
#~ msgstr "Kasutamine: %s\n"
 | 
			
		||||
 | 
			
		||||
msgid "_Dialog"
 | 
			
		||||
msgstr "_Dialoog"
 | 
			
		||||
#~ msgid "_Windows"
 | 
			
		||||
#~ msgstr "_Aknad"
 | 
			
		||||
 | 
			
		||||
msgid "_Modal dialog"
 | 
			
		||||
msgstr "_Modaaldialoog"
 | 
			
		||||
#~ msgid "_Dialog"
 | 
			
		||||
#~ msgstr "_Dialoog"
 | 
			
		||||
 | 
			
		||||
msgid "_Utility"
 | 
			
		||||
msgstr "_Utiliit"
 | 
			
		||||
#~ msgid "_Modal dialog"
 | 
			
		||||
#~ msgstr "_Modaaldialoog"
 | 
			
		||||
 | 
			
		||||
msgid "_Splashscreen"
 | 
			
		||||
msgstr "_Käivitusekraan"
 | 
			
		||||
#~ msgid "_Utility"
 | 
			
		||||
#~ msgstr "_Utiliit"
 | 
			
		||||
 | 
			
		||||
msgid "_Top dock"
 | 
			
		||||
msgstr "Ü_lemine dokk"
 | 
			
		||||
#~ msgid "_Splashscreen"
 | 
			
		||||
#~ msgstr "_Käivitusekraan"
 | 
			
		||||
 | 
			
		||||
msgid "_Bottom dock"
 | 
			
		||||
msgstr "_Alumine dokk"
 | 
			
		||||
#~ msgid "_Top dock"
 | 
			
		||||
#~ msgstr "Ü_lemine dokk"
 | 
			
		||||
 | 
			
		||||
msgid "_Left dock"
 | 
			
		||||
msgstr "_Vasak dokk"
 | 
			
		||||
#~ msgid "_Bottom dock"
 | 
			
		||||
#~ msgstr "_Alumine dokk"
 | 
			
		||||
 | 
			
		||||
msgid "_Right dock"
 | 
			
		||||
msgstr "_Parem dokk"
 | 
			
		||||
#~ msgid "_Left dock"
 | 
			
		||||
#~ msgstr "_Vasak dokk"
 | 
			
		||||
 | 
			
		||||
msgid "_All docks"
 | 
			
		||||
msgstr "_Kõik dokid"
 | 
			
		||||
#~ msgid "_Right dock"
 | 
			
		||||
#~ msgstr "_Parem dokk"
 | 
			
		||||
 | 
			
		||||
msgid "Des_ktop"
 | 
			
		||||
msgstr "_Töölaud"
 | 
			
		||||
#~ msgid "_All docks"
 | 
			
		||||
#~ msgstr "_Kõik dokid"
 | 
			
		||||
 | 
			
		||||
msgid "Open another one of these windows"
 | 
			
		||||
msgstr "Ava neist akendest järgmine"
 | 
			
		||||
#~ msgid "Des_ktop"
 | 
			
		||||
#~ msgstr "_Töölaud"
 | 
			
		||||
 | 
			
		||||
msgid "This is a demo button with an 'open' icon"
 | 
			
		||||
msgstr "See on näidisnupp koos 'ava' ikooniga"
 | 
			
		||||
#~ msgid "Open another one of these windows"
 | 
			
		||||
#~ msgstr "Ava neist akendest järgmine"
 | 
			
		||||
 | 
			
		||||
msgid "This is a demo button with a 'quit' icon"
 | 
			
		||||
msgstr "See on näidisnupp koos 'lõpeta' ikooniga"
 | 
			
		||||
#~ msgid "This is a demo button with an 'open' icon"
 | 
			
		||||
#~ msgstr "See on näidisnupp koos 'ava' ikooniga"
 | 
			
		||||
 | 
			
		||||
msgid "This is a sample message in a sample dialog"
 | 
			
		||||
msgstr "See on näidisteade näidisdialoogis"
 | 
			
		||||
#~ msgid "This is a demo button with a 'quit' icon"
 | 
			
		||||
#~ msgstr "See on näidisnupp koos 'lõpeta' ikooniga"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Fake menu item %d\n"
 | 
			
		||||
msgstr "Võltsitud menüüpunkt %d\n"
 | 
			
		||||
#~ msgid "This is a sample message in a sample dialog"
 | 
			
		||||
#~ msgstr "See on näidisteade näidisdialoogis"
 | 
			
		||||
 | 
			
		||||
msgid "Border-only window"
 | 
			
		||||
msgstr "Ainult raamiga aken"
 | 
			
		||||
#~ msgid "Fake menu item %d\n"
 | 
			
		||||
#~ msgstr "Võltsitud menüüpunkt %d\n"
 | 
			
		||||
 | 
			
		||||
msgid "Bar"
 | 
			
		||||
msgstr "Riba"
 | 
			
		||||
#~ msgid "Border-only window"
 | 
			
		||||
#~ msgstr "Ainult raamiga aken"
 | 
			
		||||
 | 
			
		||||
msgid "Normal Application Window"
 | 
			
		||||
msgstr "Tavaline rakenduseaken"
 | 
			
		||||
#~ msgid "Bar"
 | 
			
		||||
#~ msgstr "Riba"
 | 
			
		||||
 | 
			
		||||
msgid "Dialog Box"
 | 
			
		||||
msgstr "Dialoogikast"
 | 
			
		||||
#~ msgid "Normal Application Window"
 | 
			
		||||
#~ msgstr "Tavaline rakenduseaken"
 | 
			
		||||
 | 
			
		||||
msgid "Modal Dialog Box"
 | 
			
		||||
msgstr "Modaalne dialoogikast"
 | 
			
		||||
#~ msgid "Dialog Box"
 | 
			
		||||
#~ msgstr "Dialoogikast"
 | 
			
		||||
 | 
			
		||||
msgid "Utility Palette"
 | 
			
		||||
msgstr "Rakendite palett"
 | 
			
		||||
#~ msgid "Modal Dialog Box"
 | 
			
		||||
#~ msgstr "Modaalne dialoogikast"
 | 
			
		||||
 | 
			
		||||
msgid "Torn-off Menu"
 | 
			
		||||
msgstr "Ärarebitav menüü"
 | 
			
		||||
#~ msgid "Utility Palette"
 | 
			
		||||
#~ msgstr "Rakendite palett"
 | 
			
		||||
 | 
			
		||||
msgid "Border"
 | 
			
		||||
msgstr "Raam"
 | 
			
		||||
#~ msgid "Torn-off Menu"
 | 
			
		||||
#~ msgstr "Ärarebitav menüü"
 | 
			
		||||
 | 
			
		||||
msgid "Attached Modal Dialog"
 | 
			
		||||
msgstr "Kinnistatud modaaldialoog"
 | 
			
		||||
#~ msgid "Border"
 | 
			
		||||
#~ msgstr "Raam"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Button layout test %d"
 | 
			
		||||
msgstr "Nuppude paigutuse test %d"
 | 
			
		||||
#~ msgid "Attached Modal Dialog"
 | 
			
		||||
#~ msgstr "Kinnistatud modaaldialoog"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "%g milliseconds to draw one window frame"
 | 
			
		||||
msgstr "%g millisekundit kulub ühe akna raami joonistamiseks"
 | 
			
		||||
#~ msgid "Button layout test %d"
 | 
			
		||||
#~ msgstr "Nuppude paigutuse test %d"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
 | 
			
		||||
msgstr "Kasutamine: metacity-theme-viewer [TEEMANIMI]\n"
 | 
			
		||||
#~ msgid "%g milliseconds to draw one window frame"
 | 
			
		||||
#~ msgstr "%g millisekundit kulub ühe akna raami joonistamiseks"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Error loading theme: %s\n"
 | 
			
		||||
msgstr "Viga teema laadimisel: %s\n"
 | 
			
		||||
#~ msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
 | 
			
		||||
#~ msgstr "Kasutamine: metacity-theme-viewer [TEEMANIMI]\n"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Loaded theme \"%s\" in %g seconds\n"
 | 
			
		||||
msgstr "Teema \"%s\" laaditi %g sekundiga\n"
 | 
			
		||||
#~ msgid "Error loading theme: %s\n"
 | 
			
		||||
#~ msgstr "Viga teema laadimisel: %s\n"
 | 
			
		||||
 | 
			
		||||
msgid "Normal Title Font"
 | 
			
		||||
msgstr "Tiitli tavasuurusega kirjatüüp"
 | 
			
		||||
#~ msgid "Loaded theme \"%s\" in %g seconds\n"
 | 
			
		||||
#~ msgstr "Teema \"%s\" laaditi %g sekundiga\n"
 | 
			
		||||
 | 
			
		||||
msgid "Small Title Font"
 | 
			
		||||
msgstr "Tiitli väike kirjatüüp"
 | 
			
		||||
#~ msgid "Normal Title Font"
 | 
			
		||||
#~ msgstr "Tiitli tavasuurusega kirjatüüp"
 | 
			
		||||
 | 
			
		||||
msgid "Large Title Font"
 | 
			
		||||
msgstr "Tiitli suur kirjatüüp"
 | 
			
		||||
#~ msgid "Small Title Font"
 | 
			
		||||
#~ msgstr "Tiitli väike kirjatüüp"
 | 
			
		||||
 | 
			
		||||
msgid "Button Layouts"
 | 
			
		||||
msgstr "Nuppude paigutus"
 | 
			
		||||
#~ msgid "Large Title Font"
 | 
			
		||||
#~ msgstr "Tiitli suur kirjatüüp"
 | 
			
		||||
 | 
			
		||||
msgid "Benchmark"
 | 
			
		||||
msgstr "Jõudlus"
 | 
			
		||||
#~ msgid "Button Layouts"
 | 
			
		||||
#~ msgstr "Nuppude paigutus"
 | 
			
		||||
 | 
			
		||||
msgid "Window Title Goes Here"
 | 
			
		||||
msgstr "Siia tuleb akna pealkiri"
 | 
			
		||||
#~ msgid "Benchmark"
 | 
			
		||||
#~ msgstr "Jõudlus"
 | 
			
		||||
 | 
			
		||||
#, 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 ""
 | 
			
		||||
"Joonistati %d kaadrit %g kliendi-kella sekundiga (%g millisekundit kaadrile) "
 | 
			
		||||
"ja %g sekundiga seinakella järgi, millesse on kaasatud X-serveri "
 | 
			
		||||
"ressursikasutus (%g millisekundit kaadrile)\n"
 | 
			
		||||
#~ msgid "Window Title Goes Here"
 | 
			
		||||
#~ msgstr "Siia tuleb akna pealkiri"
 | 
			
		||||
 | 
			
		||||
msgid "position expression test returned TRUE but set error"
 | 
			
		||||
msgstr "asukoha avaldise kontroll tagastas TÕENE, aga määras vea"
 | 
			
		||||
#~ 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 ""
 | 
			
		||||
#~ "Joonistati %d kaadrit %g kliendi-kella sekundiga (%g millisekundit "
 | 
			
		||||
#~ "kaadrile) ja %g sekundiga seinakella järgi, millesse on kaasatud X-"
 | 
			
		||||
#~ "serveri ressursikasutus (%g millisekundit kaadrile)\n"
 | 
			
		||||
 | 
			
		||||
msgid "position expression test returned FALSE but didn't set error"
 | 
			
		||||
msgstr "asukoha avaldise kontroll tagastas VÄÄR, aga ei määranud viga"
 | 
			
		||||
#~ msgid "position expression test returned TRUE but set error"
 | 
			
		||||
#~ msgstr "asukoha avaldise kontroll tagastas TÕENE, aga määras vea"
 | 
			
		||||
 | 
			
		||||
msgid "Error was expected but none given"
 | 
			
		||||
msgstr "Oodati viga, aga ühtegi ei edastatud"
 | 
			
		||||
#~ msgid "position expression test returned FALSE but didn't set error"
 | 
			
		||||
#~ msgstr "asukoha avaldise kontroll tagastas VÄÄR, aga ei määranud viga"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Error %d was expected but %d given"
 | 
			
		||||
msgstr "Oodati viga %d, aga edastati viga %d"
 | 
			
		||||
#~ msgid "Error was expected but none given"
 | 
			
		||||
#~ msgstr "Oodati viga, aga ühtegi ei edastatud"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Error not expected but one was returned: %s"
 | 
			
		||||
msgstr "Viga ei oodatud, aga üks edastati: %s"
 | 
			
		||||
#~ msgid "Error %d was expected but %d given"
 | 
			
		||||
#~ msgstr "Oodati viga %d, aga edastati viga %d"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "x value was %d, %d was expected"
 | 
			
		||||
msgstr "x väärtus oli %d, oodati väärtust %d"
 | 
			
		||||
#~ msgid "Error not expected but one was returned: %s"
 | 
			
		||||
#~ msgstr "Viga ei oodatud, aga üks edastati: %s"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "y value was %d, %d was expected"
 | 
			
		||||
msgstr "y väärtus oli %d, oodati väärtust %d"
 | 
			
		||||
#~ msgid "x value was %d, %d was expected"
 | 
			
		||||
#~ msgstr "x väärtus oli %d, oodati väärtust %d"
 | 
			
		||||
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"%d koordinaatide avaldis töödeldi %g sekundiga (keskmine %g sekundit)\n"
 | 
			
		||||
#~ msgid "y value was %d, %d was expected"
 | 
			
		||||
#~ msgstr "y väärtus oli %d, oodati väärtust %d"
 | 
			
		||||
 | 
			
		||||
#~ msgid ""
 | 
			
		||||
#~ "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
 | 
			
		||||
#~ msgstr ""
 | 
			
		||||
#~ "%d koordinaatide avaldis töödeldi %g sekundiga (keskmine %g sekundit)\n"
 | 
			
		||||
 | 
			
		||||
#~ msgid "Minimize window"
 | 
			
		||||
#~ msgstr "Akna minimeerimine"
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										327
									
								
								po/id.po
									
									
									
									
									
								
							
							
						
						
									
										327
									
								
								po/id.po
									
									
									
									
									
								
							@@ -11,15 +11,15 @@ 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-03-28 10:28+0000\n"
 | 
			
		||||
"PO-Revision-Date: 2013-03-30 11:24+0700\n"
 | 
			
		||||
"POT-Creation-Date: 2013-08-18 20:03+0000\n"
 | 
			
		||||
"PO-Revision-Date: 2013-09-14 15:44+0700\n"
 | 
			
		||||
"Last-Translator: Andika Triwidada <andika@gmail.com>\n"
 | 
			
		||||
"Language-Team: Indonesian <gnome@i15n.org>\n"
 | 
			
		||||
"Language: id\n"
 | 
			
		||||
"MIME-Version: 1.0\n"
 | 
			
		||||
"Content-Type: text/plain; charset=UTF-8\n"
 | 
			
		||||
"Content-Transfer-Encoding: 8bit\n"
 | 
			
		||||
"X-Generator: Poedit 1.5.5\n"
 | 
			
		||||
"X-Generator: Poedit 1.5.7\n"
 | 
			
		||||
"Plural-Forms: nplurals=1; plural=0;\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/50-mutter-navigation.xml.in.h:1
 | 
			
		||||
@@ -212,7 +212,7 @@ msgstr "Tampilan dipisah ke kanan"
 | 
			
		||||
 | 
			
		||||
#. 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:568
 | 
			
		||||
#: ../src/compositor/compositor.c:589
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Another compositing manager is already running on screen %i on display \"%s"
 | 
			
		||||
@@ -220,7 +220,7 @@ msgid ""
 | 
			
		||||
msgstr ""
 | 
			
		||||
"Manajer komposit lain telah berjalan pada layar %i pada tampilan \"%s\"."
 | 
			
		||||
 | 
			
		||||
#: ../src/compositor/meta-background.c:1065
 | 
			
		||||
#: ../src/compositor/meta-background.c:1076
 | 
			
		||||
msgid "background texture could not be created from file"
 | 
			
		||||
msgstr "tekstur latar tak bisa dibuat dari berkas"
 | 
			
		||||
 | 
			
		||||
@@ -257,24 +257,24 @@ msgstr "_Tunggu"
 | 
			
		||||
msgid "_Force Quit"
 | 
			
		||||
msgstr "_Matikan Paksa"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/display.c:401
 | 
			
		||||
#: ../src/core/display.c:421
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Missing %s extension required for compositing"
 | 
			
		||||
msgstr "Kehilangan ekstensi %s yang diperlukan untuk pengkomposisian"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/display.c:493
 | 
			
		||||
#: ../src/core/display.c:513
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to open X Window System display '%s'\n"
 | 
			
		||||
msgstr "Gagal membuka tampilan X Window System '%s'\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/keybindings.c:935
 | 
			
		||||
#: ../src/core/keybindings.c:1136
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Some other program is already using the key %s with modifiers %x as a "
 | 
			
		||||
"binding\n"
 | 
			
		||||
msgstr "Ada program lain yang menggunakan tombol %s dengan kombinasi %x\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/keybindings.c:1135
 | 
			
		||||
#: ../src/core/keybindings.c:1333
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "\"%s\" is not a valid accelerator\n"
 | 
			
		||||
msgstr "\"%s\" bukan akselerator yang valid\n"
 | 
			
		||||
@@ -314,6 +314,19 @@ msgid ""
 | 
			
		||||
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
 | 
			
		||||
msgstr "Tak menemukan tema! Pastikan %s ada dan berisi tema yang biasa.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/monitor.c:711
 | 
			
		||||
msgid "Built-in display"
 | 
			
		||||
msgstr "Tampilan bawaan"
 | 
			
		||||
 | 
			
		||||
#. 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 "%s tidak dikenal"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/mutter.c:40
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
@@ -338,7 +351,7 @@ msgstr "Cetak versi"
 | 
			
		||||
msgid "Mutter plugin to use"
 | 
			
		||||
msgstr "Pengaya Mutter yang dipakai"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1095
 | 
			
		||||
#: ../src/core/prefs.c:1202
 | 
			
		||||
msgid ""
 | 
			
		||||
"Workarounds for broken applications disabled. Some applications may not "
 | 
			
		||||
"behave properly.\n"
 | 
			
		||||
@@ -346,12 +359,12 @@ msgstr ""
 | 
			
		||||
"Pencegahan kesalahan bagi aplikasi yang rusak sedang dinonaktifkan. Mungkin "
 | 
			
		||||
"nanti ada beberapa aplikasi yang akan bertingkah aneh.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1170
 | 
			
		||||
#: ../src/core/prefs.c:1277
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
 | 
			
		||||
msgstr "Tak dapat mengurai deskripsi fonta \"%s\" dari kunci GSettings %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1236
 | 
			
		||||
#: ../src/core/prefs.c:1343
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"\"%s\" found in configuration database is not a valid value for mouse button "
 | 
			
		||||
@@ -360,7 +373,7 @@ msgstr ""
 | 
			
		||||
"\"%s\" yang ada pada database konfigurasi bukanlah nilai yang benar untuk "
 | 
			
		||||
"tombol mouse.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1788
 | 
			
		||||
#: ../src/core/prefs.c:1909
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"\"%s\" found in configuration database is not a valid value for keybinding "
 | 
			
		||||
@@ -369,17 +382,17 @@ msgstr ""
 | 
			
		||||
"\"%s\" yang ada pada database konfigurasi bernilai tidak benar untuk "
 | 
			
		||||
"kombinasi tombol \"%s\"\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1887
 | 
			
		||||
#: ../src/core/prefs.c:1999
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Workspace %d"
 | 
			
		||||
msgstr "Area kerja %d"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:691
 | 
			
		||||
#: ../src/core/screen.c:534
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Screen %d on display '%s' is invalid\n"
 | 
			
		||||
msgstr "Layar %d pada tampilan '%s' tidak benar\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:707
 | 
			
		||||
#: ../src/core/screen.c:550
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Screen %d on display \"%s\" already has a window manager; try using the --"
 | 
			
		||||
@@ -388,7 +401,7 @@ msgstr ""
 | 
			
		||||
"Layar %d pada tampilan \"%s\" sudah memiliki pengatur jendela. Cobalah "
 | 
			
		||||
"gunakan pilihan --replace untuk mengganti pengatur jendela yang aktif.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:734
 | 
			
		||||
#: ../src/core/screen.c:577
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Could not acquire window manager selection on screen %d display \"%s\"\n"
 | 
			
		||||
@@ -396,12 +409,12 @@ msgstr ""
 | 
			
		||||
"Tidak dapat mendapatkan pilihan pengatur jendela pada layar %d tampilan \"%s"
 | 
			
		||||
"\"\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:812
 | 
			
		||||
#: ../src/core/screen.c:655
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Screen %d on display \"%s\" already has a window manager\n"
 | 
			
		||||
msgstr "Layar %d pada tampilan \"%s\" sudah ada pengatur jendelanya\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:998
 | 
			
		||||
#: ../src/core/screen.c:846
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Could not release screen %d on display \"%s\"\n"
 | 
			
		||||
msgstr "Layar %d pada tampilan \"%s\" tidak dapat dilepas\n"
 | 
			
		||||
@@ -476,8 +489,7 @@ msgstr "Gagal melakukan fdopen pada berkas log %s: %s\n"
 | 
			
		||||
msgid "Opened log file %s\n"
 | 
			
		||||
msgstr "Berkas log yang dibuka %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:119 ../src/tools/mutter-message.c:149
 | 
			
		||||
#, c-format
 | 
			
		||||
#: ../src/core/util.c:119
 | 
			
		||||
msgid "Mutter was compiled without support for verbose mode\n"
 | 
			
		||||
msgstr "Muter dikompilasi tanpa dukungan mode riuh\n"
 | 
			
		||||
 | 
			
		||||
@@ -485,20 +497,20 @@ msgstr "Muter dikompilasi tanpa dukungan mode riuh\n"
 | 
			
		||||
msgid "Window manager: "
 | 
			
		||||
msgstr "Pengatur jendela: "
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:412
 | 
			
		||||
#: ../src/core/util.c:414
 | 
			
		||||
msgid "Bug in window manager: "
 | 
			
		||||
msgstr "Bug pada pengatur jendela: "
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:443
 | 
			
		||||
#: ../src/core/util.c:445
 | 
			
		||||
msgid "Window manager warning: "
 | 
			
		||||
msgstr "Peringatan pengatur jendela: "
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:471
 | 
			
		||||
#: ../src/core/util.c:473
 | 
			
		||||
msgid "Window manager error: "
 | 
			
		||||
msgstr "Eror pengatur jendela: "
 | 
			
		||||
 | 
			
		||||
#. first time through
 | 
			
		||||
#: ../src/core/window.c:7596
 | 
			
		||||
#: ../src/core/window.c:7533
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
 | 
			
		||||
@@ -514,7 +526,7 @@ msgstr ""
 | 
			
		||||
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
 | 
			
		||||
#. * about these apps but make them work.
 | 
			
		||||
#.
 | 
			
		||||
#: ../src/core/window.c:8320
 | 
			
		||||
#: ../src/core/window.c:8257
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
 | 
			
		||||
@@ -524,22 +536,22 @@ msgstr ""
 | 
			
		||||
"ukurannya, sedangkan ukuran minimalnya adalah %d x %d dan maksimal %d x %d "
 | 
			
		||||
"yang tidak masuk di akal.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/window-props.c:318
 | 
			
		||||
#: ../src/core/window-props.c:347
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Application set a bogus _NET_WM_PID %lu\n"
 | 
			
		||||
msgstr "Aplikasi telah membuat _NET_WM_PID %lu bohongan\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/window-props.c:434
 | 
			
		||||
#: ../src/core/window-props.c:463
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "%s (on %s)"
 | 
			
		||||
msgstr "%s (pada %s)"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/window-props.c:1517
 | 
			
		||||
#: ../src/core/window-props.c:1546
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
 | 
			
		||||
msgstr "WM_TRANSIENT_FOR salah jendela 0x%lx ditentukan untuk %s.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/window-props.c:1528
 | 
			
		||||
#: ../src/core/window-props.c:1557
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
 | 
			
		||||
msgstr "Jendela WM_TRANSIENT_FOR 0x%lx untuk %s akan membuat loop.\n"
 | 
			
		||||
@@ -703,109 +715,104 @@ msgstr "Pilih jendela dari popup tab"
 | 
			
		||||
msgid "Cancel tab popup"
 | 
			
		||||
msgstr "Batalkan popup tab"
 | 
			
		||||
 | 
			
		||||
#: ../src/tools/mutter-message.c:123
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Usage: %s\n"
 | 
			
		||||
msgstr "Cara pakai: %s\n"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:69
 | 
			
		||||
#: ../src/ui/menu.c:67
 | 
			
		||||
msgid "Mi_nimize"
 | 
			
		||||
msgstr "Kecilka_n"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:71
 | 
			
		||||
#: ../src/ui/menu.c:69
 | 
			
		||||
msgid "Ma_ximize"
 | 
			
		||||
msgstr "Pe_rbesar"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:73
 | 
			
		||||
#: ../src/ui/menu.c:71
 | 
			
		||||
msgid "Unma_ximize"
 | 
			
		||||
msgstr "Kem_balikan"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:75
 | 
			
		||||
#: ../src/ui/menu.c:73
 | 
			
		||||
msgid "Roll _Up"
 | 
			
		||||
msgstr "G_ulung"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:77
 | 
			
		||||
#: ../src/ui/menu.c:75
 | 
			
		||||
msgid "_Unroll"
 | 
			
		||||
msgstr "B_uka"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:79
 | 
			
		||||
#: ../src/ui/menu.c:77
 | 
			
		||||
msgid "_Move"
 | 
			
		||||
msgstr "_Pindahkan"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:81
 | 
			
		||||
#: ../src/ui/menu.c:79
 | 
			
		||||
msgid "_Resize"
 | 
			
		||||
msgstr "Ganti·Uku_ran"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:83
 | 
			
		||||
#: ../src/ui/menu.c:81
 | 
			
		||||
msgid "Move Titlebar On_screen"
 | 
			
		||||
msgstr "Pindahkan Judul Pada _layar"
 | 
			
		||||
 | 
			
		||||
#. separator
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:86 ../src/ui/menu.c:88
 | 
			
		||||
#: ../src/ui/menu.c:84 ../src/ui/menu.c:86
 | 
			
		||||
msgid "Always on _Top"
 | 
			
		||||
msgstr "Selalu di A_tas"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:90
 | 
			
		||||
#: ../src/ui/menu.c:88
 | 
			
		||||
msgid "_Always on Visible Workspace"
 | 
			
		||||
msgstr "T_ampak pada Area Kerja Aktif"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:92
 | 
			
		||||
#: ../src/ui/menu.c:90
 | 
			
		||||
msgid "_Only on This Workspace"
 | 
			
		||||
msgstr "_Tampak pada Area Kerja Ini Saja"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:94
 | 
			
		||||
#: ../src/ui/menu.c:92
 | 
			
		||||
msgid "Move to Workspace _Left"
 | 
			
		||||
msgstr "Pindahkan ke Area Kerja _Kiri"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:96
 | 
			
		||||
#: ../src/ui/menu.c:94
 | 
			
		||||
msgid "Move to Workspace R_ight"
 | 
			
		||||
msgstr "Pindahkan ke A_rea Kerja Kanan"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:98
 | 
			
		||||
#: ../src/ui/menu.c:96
 | 
			
		||||
msgid "Move to Workspace _Up"
 | 
			
		||||
msgstr "Pindahkan ke Area Kerja Ata_s"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:100
 | 
			
		||||
#: ../src/ui/menu.c:98
 | 
			
		||||
msgid "Move to Workspace _Down"
 | 
			
		||||
msgstr "Pindahkan ke Area Kerja _Bawah"
 | 
			
		||||
 | 
			
		||||
#. separator
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:104
 | 
			
		||||
#: ../src/ui/menu.c:102
 | 
			
		||||
msgid "_Close"
 | 
			
		||||
msgstr "_Tutup"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/menu.c:204
 | 
			
		||||
#: ../src/ui/menu.c:202
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Workspace %d%n"
 | 
			
		||||
msgstr "Area Kerja %d%n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/menu.c:214
 | 
			
		||||
#: ../src/ui/menu.c:212
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Workspace 1_0"
 | 
			
		||||
msgstr "Area Kerja 1_0"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/menu.c:216
 | 
			
		||||
#: ../src/ui/menu.c:214
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Workspace %s%d"
 | 
			
		||||
msgstr "Area Kerja %s%d"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/menu.c:397
 | 
			
		||||
#: ../src/ui/menu.c:384
 | 
			
		||||
msgid "Move to Another _Workspace"
 | 
			
		||||
msgstr "Pindahkan ke Area Kerja _Lain"
 | 
			
		||||
 | 
			
		||||
@@ -1163,18 +1170,18 @@ msgid ""
 | 
			
		||||
msgstr ""
 | 
			
		||||
"<frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/> tidak ada"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5084
 | 
			
		||||
#: ../src/ui/theme.c:5082
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to load theme \"%s\": %s\n"
 | 
			
		||||
msgstr "Gagal membuka tema \"%s\": %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../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
 | 
			
		||||
#: ../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
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "No <%s> set for theme \"%s\""
 | 
			
		||||
msgstr "Tidak ada <%s> yang ditentukan untuk tema \"%s\""
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5256
 | 
			
		||||
#: ../src/ui/theme.c:5254
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
 | 
			
		||||
@@ -1183,14 +1190,14 @@ msgstr ""
 | 
			
		||||
"Tidak ada gaya frame untuk tipe window \"%s\" pada tema \"%s\". Tambah dulu "
 | 
			
		||||
"elemen <window type=\"%s\" style_set=\"whatever\"/>"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5663 ../src/ui/theme.c:5725 ../src/ui/theme.c:5788
 | 
			
		||||
#: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"User-defined constants must begin with a capital letter; \"%s\" does not"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"Konstanta buatan pengguna harus dimulai dengan huruf besar: \"%s\" tidak"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5671 ../src/ui/theme.c:5733 ../src/ui/theme.c:5796
 | 
			
		||||
#: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Constant \"%s\" has already been defined"
 | 
			
		||||
msgstr "Konstanta \"%s\" telah didefinisikan sebelumnya"
 | 
			
		||||
@@ -1578,201 +1585,3 @@ msgstr "<%s> disebutkan dua kali pada tema ini"
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to find a valid file for theme %s\n"
 | 
			
		||||
msgstr "Gagal menemukan berkas yang sah untuk tema %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:99
 | 
			
		||||
msgid "_Windows"
 | 
			
		||||
msgstr "_Jendela"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:100
 | 
			
		||||
msgid "_Dialog"
 | 
			
		||||
msgstr "_Dialog"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:101
 | 
			
		||||
msgid "_Modal dialog"
 | 
			
		||||
msgstr "Dialog _modal"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:102
 | 
			
		||||
msgid "_Utility"
 | 
			
		||||
msgstr "_Utilitas"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:103
 | 
			
		||||
msgid "_Splashscreen"
 | 
			
		||||
msgstr "Layar _pembuka"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:104
 | 
			
		||||
msgid "_Top dock"
 | 
			
		||||
msgstr "Dok a_tas"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:105
 | 
			
		||||
msgid "_Bottom dock"
 | 
			
		||||
msgstr "Dok _bawah"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:106
 | 
			
		||||
msgid "_Left dock"
 | 
			
		||||
msgstr "Dok k_iri"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:107
 | 
			
		||||
msgid "_Right dock"
 | 
			
		||||
msgstr "Dok kana_n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:108
 | 
			
		||||
msgid "_All docks"
 | 
			
		||||
msgstr "Semu_a dok"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:109
 | 
			
		||||
msgid "Des_ktop"
 | 
			
		||||
msgstr "Des_ktop"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:115
 | 
			
		||||
msgid "Open another one of these windows"
 | 
			
		||||
msgstr "Buka lagi jendela semacam ini"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:117
 | 
			
		||||
msgid "This is a demo button with an 'open' icon"
 | 
			
		||||
msgstr "Ini contoh tombol dengan ikon 'open'"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:119
 | 
			
		||||
msgid "This is a demo button with a 'quit' icon"
 | 
			
		||||
msgstr "Ini contoh tombol dengan ikon 'quit'"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:248
 | 
			
		||||
msgid "This is a sample message in a sample dialog"
 | 
			
		||||
msgstr "Ini contoh pesan pada suatu dialog"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:328
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Fake menu item %d\n"
 | 
			
		||||
msgstr "Item menu %d\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:363
 | 
			
		||||
msgid "Border-only window"
 | 
			
		||||
msgstr "Jendela dengan garis pembatas"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:365
 | 
			
		||||
msgid "Bar"
 | 
			
		||||
msgstr "Kotak"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:382
 | 
			
		||||
msgid "Normal Application Window"
 | 
			
		||||
msgstr "Jendela Aplikasi Normal"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:386
 | 
			
		||||
msgid "Dialog Box"
 | 
			
		||||
msgstr "Kotak Dialog"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:390
 | 
			
		||||
msgid "Modal Dialog Box"
 | 
			
		||||
msgstr "Kotak Dialog Modal"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:394
 | 
			
		||||
msgid "Utility Palette"
 | 
			
		||||
msgstr "Kotak Perkakas"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:398
 | 
			
		||||
msgid "Torn-off Menu"
 | 
			
		||||
msgstr "Menu Dapat Dilepas"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:402
 | 
			
		||||
msgid "Border"
 | 
			
		||||
msgstr "Batas"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:406
 | 
			
		||||
msgid "Attached Modal Dialog"
 | 
			
		||||
msgstr "Dialog Modal yang Dilampirkan"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:737
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Button layout test %d"
 | 
			
		||||
msgstr "Tes komposisi tombol %d"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:766
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "%g milliseconds to draw one window frame"
 | 
			
		||||
msgstr "lama waktu menggambar satu bingkai jendela %g milidetik"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:811
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
 | 
			
		||||
msgstr "Cara pakai: metacity-theme-viewer [NAMA TEMA]\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:818
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Error loading theme: %s\n"
 | 
			
		||||
msgstr "Ada error saat membaca tema: %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:824
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Loaded theme \"%s\" in %g seconds\n"
 | 
			
		||||
msgstr "Tema \"%s\" dibuka dalam %g detik\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:869
 | 
			
		||||
msgid "Normal Title Font"
 | 
			
		||||
msgstr "Judul dengan huruf normal"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:875
 | 
			
		||||
msgid "Small Title Font"
 | 
			
		||||
msgstr "Judul dengan huruf ukuran kecil"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:881
 | 
			
		||||
msgid "Large Title Font"
 | 
			
		||||
msgstr "Judul Raksasa"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:886
 | 
			
		||||
msgid "Button Layouts"
 | 
			
		||||
msgstr "Komposisi Tombol"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:891
 | 
			
		||||
msgid "Benchmark"
 | 
			
		||||
msgstr "Pengukuran"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:947
 | 
			
		||||
msgid "Window Title Goes Here"
 | 
			
		||||
msgstr "Ini tempat judul jendela"
 | 
			
		||||
 | 
			
		||||
#: ../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 frame dibuat dalam %g detik dalam waktu klien (%g milidetik per frame) "
 | 
			
		||||
"dan %g detik dalam waktu sebenarnya (%g milidetik per frame)\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:1273
 | 
			
		||||
msgid "position expression test returned TRUE but set error"
 | 
			
		||||
msgstr "tes ekspresi posisi berakhir TRUE tapi justru ada error"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:1275
 | 
			
		||||
msgid "position expression test returned FALSE but didn't set error"
 | 
			
		||||
msgstr "tes ekspresi posisi berakhir FALSE tapi tidak ada error"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:1279
 | 
			
		||||
msgid "Error was expected but none given"
 | 
			
		||||
msgstr "Seharusnya ada error, tapi ini kok tidak ada"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:1281
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Error %d was expected but %d given"
 | 
			
		||||
msgstr "Seharunya ada error %d, tapi yang terjadi %d"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:1287
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Error not expected but one was returned: %s"
 | 
			
		||||
msgstr "Seharusnya tidak ada error, tapi ini tiba-tiba ada error: %s"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:1291
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "x value was %d, %d was expected"
 | 
			
		||||
msgstr "nilai x sebelumnya %d, padahal seharusnya %d"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:1294
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "y value was %d, %d was expected"
 | 
			
		||||
msgstr "nilai y sebelumnya %d, padahal seharusnya %d"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:1359
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
 | 
			
		||||
msgstr "ekspresi koordinat %d diambil dalam %g detik (rata-rata %g detik)\n"
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										458
									
								
								po/ko.po
									
									
									
									
									
								
							
							
						
						
									
										458
									
								
								po/ko.po
									
									
									
									
									
								
							@@ -18,8 +18,8 @@ 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-03-01 15:50+0000\n"
 | 
			
		||||
"PO-Revision-Date: 2013-03-13 03:52+0900\n"
 | 
			
		||||
"POT-Creation-Date: 2013-08-18 20:03+0000\n"
 | 
			
		||||
"PO-Revision-Date: 2013-09-09 04:46+0900\n"
 | 
			
		||||
"Last-Translator: Changwoo Ryu <cwryu@debian.org>\n"
 | 
			
		||||
"Language-Team: GNOME Korea <gnome-kr@googlegroups.com>\n"
 | 
			
		||||
"Language: Korean\n"
 | 
			
		||||
@@ -218,7 +218,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:507
 | 
			
		||||
#: ../src/compositor/compositor.c:589
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Another compositing manager is already running on screen %i on display \"%s"
 | 
			
		||||
@@ -227,11 +227,11 @@ msgstr ""
 | 
			
		||||
"다른 창 구성 관리 프로그램이 이미 디스플레이 \"%2$s\" 화면 %1$i번에서 실행 중"
 | 
			
		||||
"입니다."
 | 
			
		||||
 | 
			
		||||
#: ../src/compositor/meta-background.c:1111
 | 
			
		||||
#: ../src/compositor/meta-background.c:1076
 | 
			
		||||
msgid "background texture could not be created from file"
 | 
			
		||||
msgstr "파일에서 배경 텍스처를 만들 수 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/bell.c:320
 | 
			
		||||
#: ../src/core/bell.c:322
 | 
			
		||||
msgid "Bell event"
 | 
			
		||||
msgstr "삑소리 이벤트"
 | 
			
		||||
 | 
			
		||||
@@ -263,17 +263,17 @@ msgstr "기다리기(_W)"
 | 
			
		||||
msgid "_Force Quit"
 | 
			
		||||
msgstr "강제로 끝내기(_F)"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/display.c:401
 | 
			
		||||
#: ../src/core/display.c:421
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Missing %s extension required for compositing"
 | 
			
		||||
msgstr "콤포짓에 필요한 %s 확장 기능이 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/display.c:493
 | 
			
		||||
#: ../src/core/display.c:513
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to open X Window System display '%s'\n"
 | 
			
		||||
msgstr "X 윈도 시스템 디스플레이 '%s'을(를) 여는데 실패하였습니다\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/keybindings.c:929
 | 
			
		||||
#: ../src/core/keybindings.c:1136
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Some other program is already using the key %s with modifiers %x as a "
 | 
			
		||||
@@ -282,41 +282,41 @@ msgstr ""
 | 
			
		||||
"다른 프로그램에서 이미 단축키로 변경 키 %2$x와(과) 키 %1$s을(를) 사용하고 있"
 | 
			
		||||
"습니다\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/keybindings.c:1129
 | 
			
		||||
#: ../src/core/keybindings.c:1333
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "\"%s\" is not a valid accelerator\n"
 | 
			
		||||
msgstr "\"%s\"은(는) 올바른 단축키가 아닙니다\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:196
 | 
			
		||||
#: ../src/core/main.c:197
 | 
			
		||||
msgid "Disable connection to session manager"
 | 
			
		||||
msgstr "세션 관리자와 연결 하지 않습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:202
 | 
			
		||||
#: ../src/core/main.c:203
 | 
			
		||||
msgid "Replace the running window manager"
 | 
			
		||||
msgstr "실행 중인 창 관리자를 바꿉니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:208
 | 
			
		||||
#: ../src/core/main.c:209
 | 
			
		||||
msgid "Specify session management ID"
 | 
			
		||||
msgstr "세션 관리 ID를 지정합니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:213
 | 
			
		||||
#: ../src/core/main.c:214
 | 
			
		||||
msgid "X Display to use"
 | 
			
		||||
msgstr "사용할 X 디스플레이"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:219
 | 
			
		||||
#: ../src/core/main.c:220
 | 
			
		||||
msgid "Initialize session from savefile"
 | 
			
		||||
msgstr "저장 파일에서 세션을 초기화 합니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:225
 | 
			
		||||
#: ../src/core/main.c:226
 | 
			
		||||
msgid "Make X calls synchronous"
 | 
			
		||||
msgstr "동기 X 호출을 합니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:494
 | 
			
		||||
#: ../src/core/main.c:534
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to scan themes directory: %s\n"
 | 
			
		||||
msgstr "테마 디렉터리를 읽는 데 실패했습니다: %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/main.c:510
 | 
			
		||||
#: ../src/core/main.c:550
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
 | 
			
		||||
@@ -324,6 +324,19 @@ msgstr ""
 | 
			
		||||
"테마를 찾을 수 없습니다! %s이(가) 있고 올바른 테마가 들어 있는지 확인하십시"
 | 
			
		||||
"오.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/monitor.c:711
 | 
			
		||||
msgid "Built-in display"
 | 
			
		||||
msgstr "내장 디스플레이"
 | 
			
		||||
 | 
			
		||||
#. 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 "알 수 없는 %s인치"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/mutter.c:40
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
@@ -347,18 +360,20 @@ msgstr "버전을 출력합니다"
 | 
			
		||||
msgid "Mutter plugin to use"
 | 
			
		||||
msgstr "사용할 머터 플러그인"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1087
 | 
			
		||||
#: ../src/core/prefs.c:1202
 | 
			
		||||
msgid ""
 | 
			
		||||
"Workarounds for broken applications disabled. Some applications may not "
 | 
			
		||||
"behave properly.\n"
 | 
			
		||||
msgstr "응용 프로그램에 대한 임시 방편을 막았습니다. 몇몇 응용 프로그램이 제대로 동작하지 않을것입니다.\n"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"응용 프로그램에 대한 임시 방편을 막았습니다. 몇몇 응용 프로그램이 제대로 동작"
 | 
			
		||||
"하지 않을것입니다.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1162
 | 
			
		||||
#: ../src/core/prefs.c:1277
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
 | 
			
		||||
msgstr "GSettings 키 %2$s에서 글꼴 지정 \"%1$s\"을(를) 분석할 수 없습니다\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1228
 | 
			
		||||
#: ../src/core/prefs.c:1343
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"\"%s\" found in configuration database is not a valid value for mouse button "
 | 
			
		||||
@@ -367,7 +382,7 @@ msgstr ""
 | 
			
		||||
"설정 데이터베이스에서 찾은 \"%s\"이(가) 마우스 단추 변경 키의 올바른 값이 아"
 | 
			
		||||
"닙니다\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1780
 | 
			
		||||
#: ../src/core/prefs.c:1909
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"\"%s\" found in configuration database is not a valid value for keybinding "
 | 
			
		||||
@@ -376,17 +391,17 @@ msgstr ""
 | 
			
		||||
"설정 데이터베이스에서 찾은 \"%s\"이(가) 단축키 \"%s\"에 대한 올바른 값이 아닙"
 | 
			
		||||
"니다\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/prefs.c:1879
 | 
			
		||||
#: ../src/core/prefs.c:1999
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Workspace %d"
 | 
			
		||||
msgstr "작업 공간 %d"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:673
 | 
			
		||||
#: ../src/core/screen.c:534
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Screen %d on display '%s' is invalid\n"
 | 
			
		||||
msgstr "디스플레이 '%2$s'의 화면 %1$d은(는) 잘못되었습니다\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:689
 | 
			
		||||
#: ../src/core/screen.c:550
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Screen %d on display \"%s\" already has a window manager; try using the --"
 | 
			
		||||
@@ -395,19 +410,19 @@ msgstr ""
 | 
			
		||||
"디스플레이 \"%2$s\"의 화면 %1$d에 이미 창 관리자가 실행되고 있습니다. 현재 "
 | 
			
		||||
"창 관리자를 무시하는 --replace 옵션을 써보십시오.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:716
 | 
			
		||||
#: ../src/core/screen.c:577
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Could not acquire window manager selection on screen %d display \"%s\"\n"
 | 
			
		||||
msgstr "디스플레이 \"%2$s\"의 화면 %1$d에 창 관리 선택을 가질 수 없습니다\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:794
 | 
			
		||||
#: ../src/core/screen.c:655
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Screen %d on display \"%s\" already has a window manager\n"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"디스플레이 \"%2$s\"의 화면 %1$d은(는) 이미 창 관리자가 실행되고 있습니다\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/screen.c:979
 | 
			
		||||
#: ../src/core/screen.c:846
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Could not release screen %d on display \"%s\"\n"
 | 
			
		||||
msgstr "디스플레이 \"%2$s\"의 화면 %1$d을(를) 떼어 놓을수 없습니다\n"
 | 
			
		||||
@@ -467,44 +482,43 @@ msgstr ""
 | 
			
		||||
"이 창은 "현재 설정 저장"을 지원하지 않기 때문에 다음 번에 로그인 "
 | 
			
		||||
"할 때 수동으로 다시 시작해야 합니다."
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:80
 | 
			
		||||
#: ../src/core/util.c:84
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to open debug log: %s\n"
 | 
			
		||||
msgstr "디버그 로그 열기 실패: %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:90
 | 
			
		||||
#: ../src/core/util.c:94
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to fdopen() log file %s: %s\n"
 | 
			
		||||
msgstr "로그 파일 %s을(를) fdopen()하기 실패: %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:96
 | 
			
		||||
#: ../src/core/util.c:100
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Opened log file %s\n"
 | 
			
		||||
msgstr "로그 파일 %s을(를) 엽니다\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:115 ../src/tools/mutter-message.c:149
 | 
			
		||||
#, c-format
 | 
			
		||||
#: ../src/core/util.c:119
 | 
			
		||||
msgid "Mutter was compiled without support for verbose mode\n"
 | 
			
		||||
msgstr "머터가 자세한 모드 지원 없이 컴파일 되었습니다\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:259
 | 
			
		||||
#: ../src/core/util.c:264
 | 
			
		||||
msgid "Window manager: "
 | 
			
		||||
msgstr "창 관리자: "
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:407
 | 
			
		||||
#: ../src/core/util.c:414
 | 
			
		||||
msgid "Bug in window manager: "
 | 
			
		||||
msgstr "창 관리자의 벌레: "
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:438
 | 
			
		||||
#: ../src/core/util.c:445
 | 
			
		||||
msgid "Window manager warning: "
 | 
			
		||||
msgstr "창 관리자 주의: "
 | 
			
		||||
 | 
			
		||||
#: ../src/core/util.c:466
 | 
			
		||||
#: ../src/core/util.c:473
 | 
			
		||||
msgid "Window manager error: "
 | 
			
		||||
msgstr "장 관리자 오류: "
 | 
			
		||||
 | 
			
		||||
#. first time through
 | 
			
		||||
#: ../src/core/window.c:7539
 | 
			
		||||
#: ../src/core/window.c:7533
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
 | 
			
		||||
@@ -520,7 +534,7 @@ msgstr ""
 | 
			
		||||
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
 | 
			
		||||
#. * about these apps but make them work.
 | 
			
		||||
#.
 | 
			
		||||
#: ../src/core/window.c:8263
 | 
			
		||||
#: ../src/core/window.c:8257
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
 | 
			
		||||
@@ -529,23 +543,23 @@ msgstr ""
 | 
			
		||||
"%s 창에서 크기 변경이 불가능하다는 MWM 힌트를 설정했지만, 최소 크기 %d x %d "
 | 
			
		||||
"및 최대 크기 %d x %d(으)로 설정했습니다. 앞뒤가 맞지 않습니다.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/window-props.c:318
 | 
			
		||||
#: ../src/core/window-props.c:347
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Application set a bogus _NET_WM_PID %lu\n"
 | 
			
		||||
msgstr "응용 프로그램이 가짜 _NET_WM_PID %lu을(를) 설정하였습니다\n"
 | 
			
		||||
 | 
			
		||||
# <창제목> (on <기계>)
 | 
			
		||||
#: ../src/core/window-props.c:434
 | 
			
		||||
#: ../src/core/window-props.c:463
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "%s (on %s)"
 | 
			
		||||
msgstr "%s (%s에서)"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/window-props.c:1517
 | 
			
		||||
#: ../src/core/window-props.c:1546
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
 | 
			
		||||
msgstr "%2$s에 대해 WM_TRANSIENT_FOR 0x%1$lx 창이 잘못되었습니다.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/window-props.c:1528
 | 
			
		||||
#: ../src/core/window-props.c:1557
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
 | 
			
		||||
msgstr "%2$s에 대해 WM_TRANSIENT_FOR 0x%1$lx 창은 무한 반복입니다.\n"
 | 
			
		||||
@@ -574,9 +588,7 @@ msgstr "창 0x%2$lx의 등록 정보 %1$s은(는) 잘못된 UTF-8이 들어 있
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Property %s on window 0x%lx contained invalid UTF-8 for item %d in the list\n"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"창 0x%2$lx의 등록 정보 %1$s은(는) 목록안의 항목 %3$d에 잘못된 UTF-8을 포함하"
 | 
			
		||||
"고 있습니다\n"
 | 
			
		||||
msgstr "창 0x%2$lx의 등록 정보 %1$s은(는) 목록안의 항목 %3$d에 잘못된 UTF-8 문자가 들어 있습니다\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/mutter.desktop.in.h:1 ../src/mutter-wm.desktop.in.h:1
 | 
			
		||||
msgid "Mutter"
 | 
			
		||||
@@ -705,109 +717,104 @@ 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:69
 | 
			
		||||
#: ../src/ui/menu.c:67
 | 
			
		||||
msgid "Mi_nimize"
 | 
			
		||||
msgstr "최소화(_N)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:71
 | 
			
		||||
#: ../src/ui/menu.c:69
 | 
			
		||||
msgid "Ma_ximize"
 | 
			
		||||
msgstr "최대화(_X)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:73
 | 
			
		||||
#: ../src/ui/menu.c:71
 | 
			
		||||
msgid "Unma_ximize"
 | 
			
		||||
msgstr "최대화 취소(_X)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:75
 | 
			
		||||
#: ../src/ui/menu.c:73
 | 
			
		||||
msgid "Roll _Up"
 | 
			
		||||
msgstr "말아올리기(_U)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:77
 | 
			
		||||
#: ../src/ui/menu.c:75
 | 
			
		||||
msgid "_Unroll"
 | 
			
		||||
msgstr "펼치기(_U)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:79
 | 
			
		||||
#: ../src/ui/menu.c:77
 | 
			
		||||
msgid "_Move"
 | 
			
		||||
msgstr "옮기기(_M)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:81
 | 
			
		||||
#: ../src/ui/menu.c:79
 | 
			
		||||
msgid "_Resize"
 | 
			
		||||
msgstr "크기 조정(_R)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:83
 | 
			
		||||
#: ../src/ui/menu.c:81
 | 
			
		||||
msgid "Move Titlebar On_screen"
 | 
			
		||||
msgstr "창 제목막대 화면에 표시(_S)"
 | 
			
		||||
 | 
			
		||||
#. separator
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:86 ../src/ui/menu.c:88
 | 
			
		||||
#: ../src/ui/menu.c:84 ../src/ui/menu.c:86
 | 
			
		||||
msgid "Always on _Top"
 | 
			
		||||
msgstr "항상 위(_T)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:90
 | 
			
		||||
#: ../src/ui/menu.c:88
 | 
			
		||||
msgid "_Always on Visible Workspace"
 | 
			
		||||
msgstr "항상 현재 작업 공간에 놓기(_A)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:92
 | 
			
		||||
#: ../src/ui/menu.c:90
 | 
			
		||||
msgid "_Only on This Workspace"
 | 
			
		||||
msgstr "이 작업 공간에만 놓기(_O)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:94
 | 
			
		||||
#: ../src/ui/menu.c:92
 | 
			
		||||
msgid "Move to Workspace _Left"
 | 
			
		||||
msgstr "왼쪽 작업 공간으로 옮기기(_L)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:96
 | 
			
		||||
#: ../src/ui/menu.c:94
 | 
			
		||||
msgid "Move to Workspace R_ight"
 | 
			
		||||
msgstr "오른쪽 작업 공간으로 옮기기(_I)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:98
 | 
			
		||||
#: ../src/ui/menu.c:96
 | 
			
		||||
msgid "Move to Workspace _Up"
 | 
			
		||||
msgstr "위쪽 작업 공간으로 옮기기(_U)"
 | 
			
		||||
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:100
 | 
			
		||||
#: ../src/ui/menu.c:98
 | 
			
		||||
msgid "Move to Workspace _Down"
 | 
			
		||||
msgstr "아래쪽 작업 공간으로 옮기기(_D)"
 | 
			
		||||
 | 
			
		||||
#. separator
 | 
			
		||||
#. Translators: Translate this string the same way as you do in libwnck!
 | 
			
		||||
#: ../src/ui/menu.c:104
 | 
			
		||||
#: ../src/ui/menu.c:102
 | 
			
		||||
msgid "_Close"
 | 
			
		||||
msgstr "닫기(_C)"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/menu.c:204
 | 
			
		||||
#: ../src/ui/menu.c:202
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Workspace %d%n"
 | 
			
		||||
msgstr "작업 공간 %d%n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/menu.c:214
 | 
			
		||||
#: ../src/ui/menu.c:212
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Workspace 1_0"
 | 
			
		||||
msgstr "작업 공간 1_0"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/menu.c:216
 | 
			
		||||
#: ../src/ui/menu.c:214
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Workspace %s%d"
 | 
			
		||||
msgstr "작업 공간 %s%d"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/menu.c:397
 | 
			
		||||
#: ../src/ui/menu.c:384
 | 
			
		||||
msgid "Move to Another _Workspace"
 | 
			
		||||
msgstr "다른 작업 공간으로 옮기기(_W)"
 | 
			
		||||
 | 
			
		||||
@@ -909,50 +916,50 @@ msgstr "Mod5"
 | 
			
		||||
msgid "%d x %d"
 | 
			
		||||
msgstr "%d x %d"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:235
 | 
			
		||||
#: ../src/ui/theme.c:236
 | 
			
		||||
msgid "top"
 | 
			
		||||
msgstr "맨 위"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:237
 | 
			
		||||
#: ../src/ui/theme.c:238
 | 
			
		||||
msgid "bottom"
 | 
			
		||||
msgstr "맨 아래"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:239
 | 
			
		||||
#: ../src/ui/theme.c:240
 | 
			
		||||
msgid "left"
 | 
			
		||||
msgstr "왼쪽"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:241
 | 
			
		||||
#: ../src/ui/theme.c:242
 | 
			
		||||
msgid "right"
 | 
			
		||||
msgstr "오른쪽"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:269
 | 
			
		||||
#: ../src/ui/theme.c:270
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "frame geometry does not specify \"%s\" dimension"
 | 
			
		||||
msgstr "프레임 위치가 \"%s\"차원으로 지정되지 않았습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:288
 | 
			
		||||
#: ../src/ui/theme.c:289
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "frame geometry does not specify dimension \"%s\" for border \"%s\""
 | 
			
		||||
msgstr ""
 | 
			
		||||
"프레임 위치가 가장자리 \"%2$s\" 가장자리의 \"%1$s\"차원으로 지정되지 않았습니"
 | 
			
		||||
"다."
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:325
 | 
			
		||||
#: ../src/ui/theme.c:326
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Button aspect ratio %g is not reasonable"
 | 
			
		||||
msgstr "단추의 가로세로 비 %g이(가) 적당하지 않습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:337
 | 
			
		||||
#: ../src/ui/theme.c:338
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Frame geometry does not specify size of buttons"
 | 
			
		||||
msgstr "프레임 위치가 단추의 크기로 지정되지 않았습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1050
 | 
			
		||||
#: ../src/ui/theme.c:1051
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Gradients should have at least two colors"
 | 
			
		||||
msgstr "서서히 변하는 색으로 지정하려면 최소 2색이 필요합니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1202
 | 
			
		||||
#: ../src/ui/theme.c:1203
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"GTK custom color specification must have color name and fallback in "
 | 
			
		||||
@@ -961,7 +968,7 @@ msgstr ""
 | 
			
		||||
"GTK 사용자 지정 색상 지정은 색 이름과 대체할 색을 괄호 안에 써야 합니다. 예"
 | 
			
		||||
"를 들어: gtk:custom(foo,bar). \"%s\"을(를) 분석할 수 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1218
 | 
			
		||||
#: ../src/ui/theme.c:1219
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
 | 
			
		||||
@@ -970,7 +977,7 @@ msgstr ""
 | 
			
		||||
"gtk:custom의 color_name 파라미터 안에 잘못된 문자 '%c'. A-Za-z0-9-_ 문자만 허"
 | 
			
		||||
"용합니다."
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1232
 | 
			
		||||
#: ../src/ui/theme.c:1233
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
 | 
			
		||||
@@ -979,7 +986,7 @@ msgstr ""
 | 
			
		||||
"gtk:custom 형식은 \"gtk:custom(색이름,대체색)\"입니다, \"%s\"(은)는 형식에 맞"
 | 
			
		||||
"지 않습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1277
 | 
			
		||||
#: ../src/ui/theme.c:1278
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
 | 
			
		||||
@@ -988,7 +995,7 @@ msgstr ""
 | 
			
		||||
"GTK 색상 지정은 중괄호안에 있어야 합니다. 예를 들어: gtk:fg[NORMAL], 여기서 "
 | 
			
		||||
"NORMAL이 값입니다. \"%s\"을(를) 분석할 수 없습니다."
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1291
 | 
			
		||||
#: ../src/ui/theme.c:1292
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"GTK color specification must have a close bracket after the state, e.g. gtk:"
 | 
			
		||||
@@ -997,17 +1004,17 @@ msgstr ""
 | 
			
		||||
"GTK 색상 지정은 값 뒤에 중괄호로 닫혀 있어야 합니다. 예를 들어: gtk:fg"
 | 
			
		||||
"[NORMAL], 여기서 NORMAL은 값입니다. \"%s\"을(를) 분석할 수 없습니다."
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1302
 | 
			
		||||
#: ../src/ui/theme.c:1303
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Did not understand state \"%s\" in color specification"
 | 
			
		||||
msgstr "색상 지정의 \"%s\" 값을 이해할 수 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1315
 | 
			
		||||
#: ../src/ui/theme.c:1316
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Did not understand color component \"%s\" in color specification"
 | 
			
		||||
msgstr "색상 지정의 색상 구성요소 \"%s\"을(를) 이해할 수 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1344
 | 
			
		||||
#: ../src/ui/theme.c:1345
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the "
 | 
			
		||||
@@ -1016,17 +1023,17 @@ msgstr ""
 | 
			
		||||
"섞기 형식은 \"blend/bg_color/fg_color/alpha\"입니다, \"%s\"은(는) 형식에 맞"
 | 
			
		||||
"지 않습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1355
 | 
			
		||||
#: ../src/ui/theme.c:1356
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Could not parse alpha value \"%s\" in blended color"
 | 
			
		||||
msgstr "색상 섞기에서 알파 값 \"%s\"을(를) 분석할 수 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1365
 | 
			
		||||
#: ../src/ui/theme.c:1366
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0"
 | 
			
		||||
msgstr "색상 섞기에서 알파 값 \"%s\"은(는) 0.0 과 1.0사이의 값이 아닙니다"
 | 
			
		||||
msgstr "색상 섞기에서 알파 값 \"%s\"은(는) 0.0과 1.0 사이의 값이 아닙니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1412
 | 
			
		||||
#: ../src/ui/theme.c:1413
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format"
 | 
			
		||||
@@ -1034,79 +1041,78 @@ msgstr ""
 | 
			
		||||
"그림자 형식은 \"shade/base_color/format\"입니다, \"%s\"(은)는 형식에 맞지 않"
 | 
			
		||||
"습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1423
 | 
			
		||||
#: ../src/ui/theme.c:1424
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Could not parse shade factor \"%s\" in shaded color"
 | 
			
		||||
msgstr "그림자색에서 그림자 인자 \"%s\"(을)를 해석할 수 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1433
 | 
			
		||||
#: ../src/ui/theme.c:1434
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Shade factor \"%s\" in shaded color is negative"
 | 
			
		||||
msgstr "그림자색에서 그림자 인자 \"%s\"(은)는 음수입니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1462
 | 
			
		||||
#: ../src/ui/theme.c:1463
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Could not parse color \"%s\""
 | 
			
		||||
msgstr "색상 \"%s\"을(를) 해석할 수 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1779
 | 
			
		||||
#: ../src/ui/theme.c:1780
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression contains character '%s' which is not allowed"
 | 
			
		||||
msgstr "좌표식에 허용되지 않는 문자 '%s'(이)가 포함되어 있습니다"
 | 
			
		||||
msgstr "좌표식에 허용되지 않는 문자 '%s'(이)가 들어 있습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1806
 | 
			
		||||
#: ../src/ui/theme.c:1807
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Coordinate expression contains floating point number '%s' which could not be "
 | 
			
		||||
"parsed"
 | 
			
		||||
msgstr "좌표식에 분석할 수 없는 부동소수점 숫자 '%s'이(가) 포함되어 있습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1820
 | 
			
		||||
#: ../src/ui/theme.c:1821
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression contains integer '%s' which could not be parsed"
 | 
			
		||||
msgstr "좌표식에 분석할 수 없는 정수 '%s'이(가) 포함되어 있습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1941
 | 
			
		||||
#: ../src/ui/theme.c:1942
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Coordinate expression contained unknown operator at the start of this text: "
 | 
			
		||||
"\"%s\""
 | 
			
		||||
msgstr ""
 | 
			
		||||
"좌표식에 이 글자 시작부분에 알 수 없는 연산자가 포함되어 있습니다: \"%s\""
 | 
			
		||||
msgstr "좌표식에 이 글자 시작부분에 알 수 없는 연산자가 들어 있습니다: \"%s\""
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:1998
 | 
			
		||||
#: ../src/ui/theme.c:1999
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression was empty or not understood"
 | 
			
		||||
msgstr "좌표식이 비어있거나 이해할 수 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2111 ../src/ui/theme.c:2121 ../src/ui/theme.c:2155
 | 
			
		||||
#: ../src/ui/theme.c:2112 ../src/ui/theme.c:2122 ../src/ui/theme.c:2156
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression results in division by zero"
 | 
			
		||||
msgstr "좌표식의 결과 값이 0로 나누었습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2163
 | 
			
		||||
#: ../src/ui/theme.c:2164
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Coordinate expression tries to use mod operator on a floating-point number"
 | 
			
		||||
msgstr "좌표식에서 부동소수점 수에 나머지 연산을 하려 합니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2219
 | 
			
		||||
#: ../src/ui/theme.c:2220
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Coordinate expression has an operator \"%s\" where an operand was expected"
 | 
			
		||||
msgstr "좌표식에서 피연산자가 들어갈 곳에 연산자 \"%s\"이(가) 있습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2228
 | 
			
		||||
#: ../src/ui/theme.c:2229
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression had an operand where an operator was expected"
 | 
			
		||||
msgstr "좌표식에서 연산자가 들어갈 곳에 피연산자가 있습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2236
 | 
			
		||||
#: ../src/ui/theme.c:2237
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression ended with an operator instead of an operand"
 | 
			
		||||
msgstr "좌표식에서 피연산자 대신에 연산자로 끝나있습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2246
 | 
			
		||||
#: ../src/ui/theme.c:2247
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Coordinate expression has operator \"%c\" following operator \"%c\" with no "
 | 
			
		||||
@@ -1115,37 +1121,37 @@ msgstr ""
 | 
			
		||||
"좌표식에서 피연산자가 없는 연산자 \"%2$c\"다음에 연산자 \"%1$c\"이(가) 있습니"
 | 
			
		||||
"다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2397 ../src/ui/theme.c:2442
 | 
			
		||||
#: ../src/ui/theme.c:2398 ../src/ui/theme.c:2443
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression had unknown variable or constant \"%s\""
 | 
			
		||||
msgstr "좌표식에 알 수 없는 변수나 상수 \"%s\"이(가) 있습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2496
 | 
			
		||||
#: ../src/ui/theme.c:2497
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression parser overflowed its buffer."
 | 
			
		||||
msgstr "좌표 계산 파서의 버퍼가 크기를 넘어갔습니다."
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2525
 | 
			
		||||
#: ../src/ui/theme.c:2526
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression had a close parenthesis with no open parenthesis"
 | 
			
		||||
msgstr "좌표식에 닫는 괄호는 있지만 여는 괄호가 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2589
 | 
			
		||||
#: ../src/ui/theme.c:2590
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression had an open parenthesis with no close parenthesis"
 | 
			
		||||
msgstr "좌표식에 여는 괄호는 있지만 닫는 괄호가 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2600
 | 
			
		||||
#: ../src/ui/theme.c:2601
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Coordinate expression doesn't seem to have any operators or operands"
 | 
			
		||||
msgstr "좌표식에 어떠한 연산자나 피연산자가 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:2813 ../src/ui/theme.c:2833 ../src/ui/theme.c:2853
 | 
			
		||||
#: ../src/ui/theme.c:2814 ../src/ui/theme.c:2834 ../src/ui/theme.c:2854
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Theme contained an expression that resulted in an error: %s\n"
 | 
			
		||||
msgstr "테마가 오류 값을 내는 표현식이 들어 있습니다: %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:4499
 | 
			
		||||
#: ../src/ui/theme.c:4500
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be "
 | 
			
		||||
@@ -1154,7 +1160,7 @@ msgstr ""
 | 
			
		||||
"이 프레임 스타일에는 <button function=\"%s\" style=\"%s\" draw_ops=\"whatever"
 | 
			
		||||
"\"/>가 지정되어야 합니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5010 ../src/ui/theme.c:5035
 | 
			
		||||
#: ../src/ui/theme.c:5011 ../src/ui/theme.c:5036
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
 | 
			
		||||
@@ -1162,18 +1168,18 @@ msgstr ""
 | 
			
		||||
"<frame state=\"%s\" resize=\"%s\" focus=\"%s\" state=\"whatever\"/> 가 없습니"
 | 
			
		||||
"다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5083
 | 
			
		||||
#: ../src/ui/theme.c:5082
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Failed to load theme \"%s\": %s\n"
 | 
			
		||||
msgstr "테마 \"%s\"을(를) 읽을 수 없습니다: %s\n"
 | 
			
		||||
 | 
			
		||||
#: ../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
 | 
			
		||||
#: ../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
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "No <%s> set for theme \"%s\""
 | 
			
		||||
msgstr "테마 \"%2$s\"의 <%1$s>(이)가 설정되지 않았습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5255
 | 
			
		||||
#: ../src/ui/theme.c:5254
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
 | 
			
		||||
@@ -1182,14 +1188,14 @@ msgstr ""
 | 
			
		||||
"테마 \"%2$s\"의 창 형식 \"%1$s\"에 대한 프레임 스타일이 없습니다,<window "
 | 
			
		||||
"type=\"%3$s\" style_set=\"whatever\"/> 엘리먼트를 추가하십시오"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5662 ../src/ui/theme.c:5724 ../src/ui/theme.c:5787
 | 
			
		||||
#: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
"User-defined constants must begin with a capital letter; \"%s\" does not"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"사용자 정의 상수는 대문자로 시작되어야 합니다. \"%s\"은(는) 그렇지 않습니다."
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme.c:5670 ../src/ui/theme.c:5732 ../src/ui/theme.c:5795
 | 
			
		||||
#: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Constant \"%s\" has already been defined"
 | 
			
		||||
msgstr "상수 \"%s\"은(는) 이미 지정되어 있습니다"
 | 
			
		||||
@@ -1324,9 +1330,7 @@ msgstr "<%s> 엘리먼트는 <%s> 아래에 허용되지 않습니다"
 | 
			
		||||
msgid ""
 | 
			
		||||
"Cannot specify both \"button_width\"/\"button_height\" and \"aspect_ratio\" "
 | 
			
		||||
"for buttons"
 | 
			
		||||
msgstr ""
 | 
			
		||||
"단추의 button_width/button_height 와 \"aspect_ratio\"를 한꺼번에 지정할 수 없"
 | 
			
		||||
"습니다"
 | 
			
		||||
msgstr "단추의 \"button_width\"/\"button_height\"와 \"aspect_ratio\"를 한꺼번에 지정할 수 없습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-parser.c:1450
 | 
			
		||||
#, c-format
 | 
			
		||||
@@ -1387,7 +1391,7 @@ msgstr "\"%s\"라 불리는 <draw_ops>는 정의되지 않았습니다"
 | 
			
		||||
#: ../src/ui/theme-parser.c:2706 ../src/ui/theme-parser.c:2802
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "Including draw_ops \"%s\" here would create a circular reference"
 | 
			
		||||
msgstr "draw_ops를 포함하는 \"%s\"이(가) 자기 자신을 참조하고 있습니다"
 | 
			
		||||
msgstr "여기서 draw_ops \"%s\"을(를) 포함하면 순환 참조가 됩니다."
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-parser.c:2917
 | 
			
		||||
#, c-format
 | 
			
		||||
@@ -1569,205 +1573,7 @@ msgstr "<%s> 엘리먼트 안에 텍스트가 허용되지 않습니다"
 | 
			
		||||
msgid "<%s> specified twice for this theme"
 | 
			
		||||
msgstr "이 테마에서 <%s> 태그가 두 번 지정되었습니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-parser.c:4334
 | 
			
		||||
#: ../src/ui/theme-parser.c:4336
 | 
			
		||||
#, 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 "창(_W)"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:100
 | 
			
		||||
msgid "_Dialog"
 | 
			
		||||
msgstr "대화 상자(_D)"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:101
 | 
			
		||||
msgid "_Modal dialog"
 | 
			
		||||
msgstr "모달 대화 상자(_M)"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:102
 | 
			
		||||
msgid "_Utility"
 | 
			
		||||
msgstr "도구(_U)"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:103
 | 
			
		||||
msgid "_Splashscreen"
 | 
			
		||||
msgstr "스플래시 화면(_S)"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:104
 | 
			
		||||
msgid "_Top dock"
 | 
			
		||||
msgstr "위 도크(_T)"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:105
 | 
			
		||||
msgid "_Bottom dock"
 | 
			
		||||
msgstr "아래 도크(_B)"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:106
 | 
			
		||||
msgid "_Left dock"
 | 
			
		||||
msgstr "왼쪽 도크(_L)"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:107
 | 
			
		||||
msgid "_Right dock"
 | 
			
		||||
msgstr "오른쪽 도크(_R)"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:108
 | 
			
		||||
msgid "_All docks"
 | 
			
		||||
msgstr "모든 도크(_A)"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:109
 | 
			
		||||
msgid "Des_ktop"
 | 
			
		||||
msgstr "데스크톱(_K)"
 | 
			
		||||
 | 
			
		||||
#: ../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"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:766
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "%g milliseconds to draw one window frame"
 | 
			
		||||
msgstr "창 프레임 하나를 그리는 데 %g ms"
 | 
			
		||||
 | 
			
		||||
#: ../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"
 | 
			
		||||
 | 
			
		||||
#: ../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 "창 제목이 여기에 들어갑니다"
 | 
			
		||||
 | 
			
		||||
#: ../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 "
 | 
			
		||||
"ms). 그리고 X 서버 리소스까지 포함해 실제 시간으로 %g 초가 걸렸습니다(한 프레"
 | 
			
		||||
"임에 %g ms).\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 "가로값이 %d입니다. 와야 하는 값은 %d입니다"
 | 
			
		||||
 | 
			
		||||
#: ../src/ui/theme-viewer.c:1294
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid "y value was %d, %d was expected"
 | 
			
		||||
msgstr "세로값이 %d입니다. 와야 하는 값은 %d입니다"
 | 
			
		||||
 | 
			
		||||
#: ../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"
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										18
									
								
								po/sr.po
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								po/sr.po
									
									
									
									
									
								
							@@ -10,8 +10,8 @@ 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-03-01 15:50+0000\n"
 | 
			
		||||
"PO-Revision-Date: 2013-03-11 11:40+0200\n"
 | 
			
		||||
"POT-Creation-Date: 2013-08-18 20:03+0000\n"
 | 
			
		||||
"PO-Revision-Date: 2013-09-06 09:19+0200\n"
 | 
			
		||||
"Last-Translator: Мирослав Николић <miroslavnikolic@rocketmail.com>\n"
 | 
			
		||||
"Language-Team: Serbian <gnom@prevod.org>\n"
 | 
			
		||||
"Language: sr\n"
 | 
			
		||||
@@ -320,6 +320,20 @@ msgstr ""
 | 
			
		||||
"Не могу да пронађем тему! Проверите да „%s“ постоји и да садржи уобичајене "
 | 
			
		||||
"теме.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/monitor.c:711
 | 
			
		||||
msgid "Built-in display"
 | 
			
		||||
msgstr "Уграђени дисплеј"
 | 
			
		||||
 | 
			
		||||
#. 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 "Непознат %s"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/mutter.c:40
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
 
 | 
			
		||||
@@ -10,8 +10,8 @@ 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-03-01 15:50+0000\n"
 | 
			
		||||
"PO-Revision-Date: 2013-03-11 11:40+0200\n"
 | 
			
		||||
"POT-Creation-Date: 2013-08-18 20:03+0000\n"
 | 
			
		||||
"PO-Revision-Date: 2013-09-06 09:19+0200\n"
 | 
			
		||||
"Last-Translator: Miroslav Nikolić <miroslavnikolic@rocketmail.com>\n"
 | 
			
		||||
"Language-Team: Serbian <gnom@prevod.org>\n"
 | 
			
		||||
"Language: sr\n"
 | 
			
		||||
@@ -320,6 +320,20 @@ msgstr ""
 | 
			
		||||
"Ne mogu da pronađem temu! Proverite da „%s“ postoji i da sadrži uobičajene "
 | 
			
		||||
"teme.\n"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/monitor.c:711
 | 
			
		||||
msgid "Built-in display"
 | 
			
		||||
msgstr "Ugrađeni 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 element %s"
 | 
			
		||||
msgid "Unknown %s"
 | 
			
		||||
msgstr "Nepoznat %s"
 | 
			
		||||
 | 
			
		||||
#: ../src/core/mutter.c:40
 | 
			
		||||
#, c-format
 | 
			
		||||
msgid ""
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										648
									
								
								po/zh_HK.po
									
									
									
									
									
								
							
							
						
						
									
										648
									
								
								po/zh_HK.po
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										648
									
								
								po/zh_TW.po
									
									
									
									
									
								
							
							
						
						
									
										648
									
								
								po/zh_TW.po
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -1 +0,0 @@
 | 
			
		||||
EXTRA_DIST = xserver.xml
 | 
			
		||||
@@ -29,6 +29,18 @@
 | 
			
		||||
	<KeyListEntry name="move-to-workspace-down"
 | 
			
		||||
	              _description="Move window one workspace down" />
 | 
			
		||||
 | 
			
		||||
	<KeyListEntry name="move-to-monitor-left"
 | 
			
		||||
	              _description="Move window one monitor to the left" />
 | 
			
		||||
 | 
			
		||||
	<KeyListEntry name="move-to-monitor-right"
 | 
			
		||||
	              _description="Move window one monitor to the right" />
 | 
			
		||||
 | 
			
		||||
	<KeyListEntry name="move-to-monitor-up"
 | 
			
		||||
	              _description="Move window one monitor up" />
 | 
			
		||||
 | 
			
		||||
	<KeyListEntry name="move-to-monitor-down"
 | 
			
		||||
	              _description="Move window one monitor down" />
 | 
			
		||||
 | 
			
		||||
	<KeyListEntry name="switch-applications"
 | 
			
		||||
	              _description="Switch applications"/>
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										121
									
								
								src/Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										121
									
								
								src/Makefile.am
									
									
									
									
									
								
							@@ -6,6 +6,7 @@ lib_LTLIBRARIES = libmutter-wayland.la
 | 
			
		||||
SUBDIRS=compositor/plugins
 | 
			
		||||
 | 
			
		||||
INCLUDES=								\
 | 
			
		||||
	-DCLUTTER_ENABLE_COMPOSITOR_API					\
 | 
			
		||||
	-DCLUTTER_ENABLE_EXPERIMENTAL_API				\
 | 
			
		||||
	-DCOGL_ENABLE_EXPERIMENTAL_API					\
 | 
			
		||||
	-DCOGL_ENABLE_EXPERIMENTAL_2_0_API                              \
 | 
			
		||||
@@ -28,11 +29,7 @@ INCLUDES=								\
 | 
			
		||||
	-DMUTTER_PLUGIN_API_VERSION=$(MUTTER_PLUGIN_API_VERSION)	\
 | 
			
		||||
	-DMUTTER_PKGLIBDIR=\"$(pkglibdir)\"				\
 | 
			
		||||
	-DMUTTER_PLUGIN_DIR=\"@MUTTER_PLUGIN_DIR@\"			\
 | 
			
		||||
	-DGETTEXT_PACKAGE=\"$(GETTEXT_PACKAGE)\"
 | 
			
		||||
 | 
			
		||||
INCLUDES += \
 | 
			
		||||
	-I$(srcdir)/wayland						\
 | 
			
		||||
	-I$(builddir)/wayland						\
 | 
			
		||||
	-DGETTEXT_PACKAGE=\"$(GETTEXT_PACKAGE)\"			\
 | 
			
		||||
	-DXWAYLAND_PATH='"@XWAYLAND_PATH@"'
 | 
			
		||||
 | 
			
		||||
mutter_built_sources = \
 | 
			
		||||
@@ -40,13 +37,20 @@ mutter_built_sources = \
 | 
			
		||||
	$(dbus_xrandr_built_sources)		\
 | 
			
		||||
	mutter-enum-types.h 			\
 | 
			
		||||
	mutter-enum-types.c			\
 | 
			
		||||
	wayland/xserver-protocol.c		\
 | 
			
		||||
	wayland/xserver-server-protocol.h	\
 | 
			
		||||
	wayland/xserver-client-protocol.h
 | 
			
		||||
	gtk-shell-protocol.c			\
 | 
			
		||||
	gtk-shell-server-protocol.h		\
 | 
			
		||||
	xdg-shell-protocol.c			\
 | 
			
		||||
	xdg-shell-server-protocol.h		\
 | 
			
		||||
	xserver-protocol.c			\
 | 
			
		||||
	xserver-server-protocol.h
 | 
			
		||||
 | 
			
		||||
wayland_protocols = \
 | 
			
		||||
	wayland/protocol/gtk-shell.xml		\
 | 
			
		||||
	wayland/protocol/xdg-shell.xml		\
 | 
			
		||||
	wayland/protocol/xserver.xml
 | 
			
		||||
 | 
			
		||||
libmutter_wayland_la_SOURCES =			\
 | 
			
		||||
	core/async-getprop.c			\
 | 
			
		||||
	core/async-getprop.h			\
 | 
			
		||||
	core/above-tab-keycode.c		\
 | 
			
		||||
	core/barrier.c				\
 | 
			
		||||
	meta/barrier.h				\
 | 
			
		||||
	core/bell.c				\
 | 
			
		||||
@@ -64,7 +68,8 @@ libmutter_wayland_la_SOURCES =			\
 | 
			
		||||
	compositor/meta-background-actor.c	\
 | 
			
		||||
	compositor/meta-background-actor-private.h	\
 | 
			
		||||
	compositor/meta-background-group.c	\
 | 
			
		||||
	compositor/meta-background-group-private.h	\
 | 
			
		||||
	compositor/meta-cullable.c		\
 | 
			
		||||
	compositor/meta-cullable.h		\
 | 
			
		||||
	compositor/meta-module.c		\
 | 
			
		||||
	compositor/meta-module.h		\
 | 
			
		||||
	compositor/meta-plugin.c		\
 | 
			
		||||
@@ -74,6 +79,12 @@ libmutter_wayland_la_SOURCES =			\
 | 
			
		||||
	compositor/meta-shadow-factory-private.h	\
 | 
			
		||||
	compositor/meta-shaped-texture.c	\
 | 
			
		||||
	compositor/meta-shaped-texture-private.h 	\
 | 
			
		||||
	compositor/meta-surface-actor.c		\
 | 
			
		||||
	compositor/meta-surface-actor.h		\
 | 
			
		||||
	compositor/meta-surface-actor-x11.c	\
 | 
			
		||||
	compositor/meta-surface-actor-x11.h	\
 | 
			
		||||
	compositor/meta-surface-actor-wayland.c	\
 | 
			
		||||
	compositor/meta-surface-actor-wayland.h	\
 | 
			
		||||
	compositor/meta-texture-rectangle.c	\
 | 
			
		||||
	compositor/meta-texture-rectangle.h	\
 | 
			
		||||
	compositor/meta-texture-tower.c		\
 | 
			
		||||
@@ -94,7 +105,6 @@ libmutter_wayland_la_SOURCES =			\
 | 
			
		||||
	meta/meta-shadow-factory.h		\
 | 
			
		||||
	meta/meta-window-actor.h		\
 | 
			
		||||
	meta/compositor-mutter.h 		\
 | 
			
		||||
	core/above-tab-keycode.c		\
 | 
			
		||||
	core/constraints.c			\
 | 
			
		||||
	core/constraints.h			\
 | 
			
		||||
	core/core.c				\
 | 
			
		||||
@@ -102,8 +112,6 @@ libmutter_wayland_la_SOURCES =			\
 | 
			
		||||
	core/display.c				\
 | 
			
		||||
	core/display-private.h			\
 | 
			
		||||
	meta/display.h				\
 | 
			
		||||
	ui/draw-workspace.c			\
 | 
			
		||||
	ui/draw-workspace.h			\
 | 
			
		||||
	core/edge-resistance.c			\
 | 
			
		||||
	core/edge-resistance.h			\
 | 
			
		||||
	core/edid-parse.c			\
 | 
			
		||||
@@ -114,13 +122,6 @@ libmutter_wayland_la_SOURCES =			\
 | 
			
		||||
	core/frame.h				\
 | 
			
		||||
	ui/gradient.c				\
 | 
			
		||||
	meta/gradient.h				\
 | 
			
		||||
	core/group-private.h			\
 | 
			
		||||
	core/group-props.c			\
 | 
			
		||||
	core/group-props.h			\
 | 
			
		||||
	core/group.c				\
 | 
			
		||||
	meta/group.h				\
 | 
			
		||||
	core/iconcache.c			\
 | 
			
		||||
	core/iconcache.h			\
 | 
			
		||||
	core/keybindings.c			\
 | 
			
		||||
	core/keybindings-private.h		\
 | 
			
		||||
	core/main.c				\
 | 
			
		||||
@@ -131,6 +132,7 @@ libmutter_wayland_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			\
 | 
			
		||||
@@ -142,23 +144,18 @@ libmutter_wayland_la_SOURCES =			\
 | 
			
		||||
	core/screen-private.h			\
 | 
			
		||||
	meta/screen.h				\
 | 
			
		||||
	meta/types.h				\
 | 
			
		||||
	core/session.c				\
 | 
			
		||||
	core/session.h				\
 | 
			
		||||
	core/stack.c				\
 | 
			
		||||
	core/stack.h				\
 | 
			
		||||
	core/stack-tracker.c			\
 | 
			
		||||
	core/stack-tracker.h			\
 | 
			
		||||
	core/util.c				\
 | 
			
		||||
	meta/util.h				\
 | 
			
		||||
	core/window-props.c			\
 | 
			
		||||
	core/window-props.h			\
 | 
			
		||||
	core/util-private.h			\
 | 
			
		||||
	core/window.c				\
 | 
			
		||||
	core/window-private.h			\
 | 
			
		||||
	meta/window.h				\
 | 
			
		||||
	core/workspace.c			\
 | 
			
		||||
	core/workspace-private.h		\
 | 
			
		||||
	core/xprops.c				\
 | 
			
		||||
	core/xprops.h				\
 | 
			
		||||
	meta/common.h				\
 | 
			
		||||
	core/core.h				\
 | 
			
		||||
	ui/ui.h					\
 | 
			
		||||
@@ -170,19 +167,31 @@ libmutter_wayland_la_SOURCES =			\
 | 
			
		||||
	ui/metaaccellabel.h			\
 | 
			
		||||
	ui/resizepopup.c			\
 | 
			
		||||
	ui/resizepopup.h			\
 | 
			
		||||
	ui/tabpopup.c				\
 | 
			
		||||
	ui/tabpopup.h				\
 | 
			
		||||
	ui/tile-preview.c			\
 | 
			
		||||
	ui/tile-preview.h			\
 | 
			
		||||
	ui/theme-parser.c			\
 | 
			
		||||
	ui/theme.c				\
 | 
			
		||||
	meta/theme.h				\
 | 
			
		||||
	ui/theme-private.h			\
 | 
			
		||||
	ui/ui.c					\
 | 
			
		||||
	$(mutter_built_sources)
 | 
			
		||||
 | 
			
		||||
libmutter_wayland_la_SOURCES +=			\
 | 
			
		||||
	x11/iconcache.c				\
 | 
			
		||||
	x11/iconcache.h				\
 | 
			
		||||
	x11/async-getprop.c			\
 | 
			
		||||
	x11/async-getprop.h			\
 | 
			
		||||
	x11/group-private.h			\
 | 
			
		||||
	x11/group-props.c			\
 | 
			
		||||
	x11/group-props.h			\
 | 
			
		||||
	x11/group.c				\
 | 
			
		||||
	meta/group.h				\
 | 
			
		||||
	x11/session.c				\
 | 
			
		||||
	x11/session.h				\
 | 
			
		||||
	x11/window-props.c			\
 | 
			
		||||
	x11/window-props.h			\
 | 
			
		||||
	x11/window-x11.c			\
 | 
			
		||||
	x11/window-x11.h			\
 | 
			
		||||
	x11/window-x11-private.h		\
 | 
			
		||||
	x11/xprops.c				\
 | 
			
		||||
	x11/xprops.h				\
 | 
			
		||||
	wayland/meta-wayland.c			\
 | 
			
		||||
	wayland/meta-wayland.h			\
 | 
			
		||||
	wayland/meta-wayland-private.h		\
 | 
			
		||||
	wayland/meta-xwayland-private.h		\
 | 
			
		||||
	wayland/meta-xwayland.c			\
 | 
			
		||||
@@ -195,7 +204,16 @@ libmutter_wayland_la_SOURCES +=			\
 | 
			
		||||
	wayland/meta-wayland-seat.c		\
 | 
			
		||||
	wayland/meta-wayland-seat.h		\
 | 
			
		||||
	wayland/meta-wayland-stage.h		\
 | 
			
		||||
	wayland/meta-wayland-stage.c
 | 
			
		||||
	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
 | 
			
		||||
 | 
			
		||||
nodist_libmutter_wayland_la_SOURCES =		\
 | 
			
		||||
	$(mutter_built_sources)
 | 
			
		||||
 | 
			
		||||
libmutter_wayland_la_LDFLAGS = -no-undefined
 | 
			
		||||
libmutter_wayland_la_LIBADD  = $(MUTTER_LIBS)
 | 
			
		||||
@@ -247,6 +265,17 @@ bin_PROGRAMS=mutter-wayland
 | 
			
		||||
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)
 | 
			
		||||
 | 
			
		||||
@@ -275,14 +304,14 @@ Meta-$(api_version).gir: libmutter-wayland.la
 | 
			
		||||
@META_GIR@_FILES =				\
 | 
			
		||||
	mutter-enum-types.h			\
 | 
			
		||||
	$(libmutterinclude_base_headers)	\
 | 
			
		||||
	$(filter %.c,$(libmutter_wayland_la_SOURCES))
 | 
			
		||||
	$(filter %.c,$(libmutter_wayland_la_SOURCES) $(nodist_libmutter_wayland_la_SOURCES))
 | 
			
		||||
@META_GIR@_SCANNERFLAGS = --warn-all --warn-error
 | 
			
		||||
 | 
			
		||||
endif
 | 
			
		||||
 | 
			
		||||
testboxes_SOURCES = core/testboxes.c
 | 
			
		||||
testgradient_SOURCES = ui/testgradient.c
 | 
			
		||||
testasyncgetprop_SOURCES = core/testasyncgetprop.c
 | 
			
		||||
testasyncgetprop_SOURCES = x11/testasyncgetprop.c
 | 
			
		||||
 | 
			
		||||
noinst_PROGRAMS=testboxes testgradient testasyncgetprop
 | 
			
		||||
 | 
			
		||||
@@ -306,7 +335,7 @@ xml_DATA     = $(xml_in_files:.xml.in=.xml)
 | 
			
		||||
 | 
			
		||||
dbus_idle_built_sources = meta-dbus-idle-monitor.c meta-dbus-idle-monitor.h
 | 
			
		||||
 | 
			
		||||
gsettings_SCHEMAS = org.gnome.mutter.gschema.xml
 | 
			
		||||
gsettings_SCHEMAS = org.gnome.mutter.gschema.xml org.gnome.mutter.wayland.gschema.xml
 | 
			
		||||
@INTLTOOL_XML_NOMERGE_RULE@
 | 
			
		||||
@GSETTINGS_RULES@
 | 
			
		||||
 | 
			
		||||
@@ -317,6 +346,7 @@ CLEANFILES =					\
 | 
			
		||||
	mutter-wayland.desktop			\
 | 
			
		||||
	mutter-wm.desktop			\
 | 
			
		||||
	org.gnome.mutter.gschema.xml		\
 | 
			
		||||
	org.gnome.mutter.wayland.gschema.xml	\
 | 
			
		||||
	$(xml_DATA)				\
 | 
			
		||||
	$(mutter_built_sources)			\
 | 
			
		||||
	$(typelib_DATA)				\
 | 
			
		||||
@@ -332,11 +362,14 @@ EXTRA_DIST=$(desktopfiles_files) 	\
 | 
			
		||||
	$(desktopfiles_in_files)	\
 | 
			
		||||
	$(wmproperties_in_files)	\
 | 
			
		||||
	$(xml_in_files)			\
 | 
			
		||||
	$(wayland_protocols)		\
 | 
			
		||||
	org.gnome.mutter.gschema.xml.in \
 | 
			
		||||
	org.gnome.mutter.wayland.gschema.xml.in \
 | 
			
		||||
	mutter-schemas.convert \
 | 
			
		||||
	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
 | 
			
		||||
@@ -370,7 +403,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							\
 | 
			
		||||
@@ -380,12 +412,7 @@ $(dbus_idle_built_sources) : Makefile.am idle-monitor.xml
 | 
			
		||||
		--c-generate-object-manager						\
 | 
			
		||||
		$(srcdir)/idle-monitor.xml
 | 
			
		||||
 | 
			
		||||
wayland/%-protocol.c : $(top_builddir)/protocol/%.xml
 | 
			
		||||
	mkdir -p wayland
 | 
			
		||||
%-protocol.c : $(srcdir)/wayland/protocol/%.xml
 | 
			
		||||
	$(AM_V_GEN)$(WAYLAND_SCANNER) code < $< > $@
 | 
			
		||||
wayland/%-server-protocol.h : $(top_builddir)/protocol/%.xml
 | 
			
		||||
	mkdir -p wayland
 | 
			
		||||
%-server-protocol.h : $(srcdir)/wayland/protocol/%.xml
 | 
			
		||||
	$(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 < $< > $@
 | 
			
		||||
 
 | 
			
		||||
@@ -16,9 +16,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include "clutter-utils.h"
 | 
			
		||||
@@ -95,8 +93,10 @@ meta_actor_vertices_are_untransformed (ClutterVertex *verts,
 | 
			
		||||
      v3x != v1x || v3y != v2y)
 | 
			
		||||
    return FALSE;
 | 
			
		||||
 | 
			
		||||
  *x_origin = x;
 | 
			
		||||
  *y_origin = y;
 | 
			
		||||
  if (x_origin)
 | 
			
		||||
    *x_origin = x;
 | 
			
		||||
  if (y_origin)
 | 
			
		||||
    *y_origin = y;
 | 
			
		||||
 | 
			
		||||
  return TRUE;
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -15,9 +15,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef __META_CLUTTER_UTILS_H__
 | 
			
		||||
 
 | 
			
		||||
@@ -16,9 +16,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <clutter/clutter.h>
 | 
			
		||||
@@ -50,7 +48,7 @@ meta_create_color_texture_4ub (guint8           red,
 | 
			
		||||
  CoglColor color;
 | 
			
		||||
  guint8 pixel[4];
 | 
			
		||||
 | 
			
		||||
  cogl_color_set_from_4ub (&color, red, green, blue, alpha);
 | 
			
		||||
  cogl_color_init_from_4ub (&color, red, green, blue, alpha);
 | 
			
		||||
  cogl_color_premultiply (&color);
 | 
			
		||||
 | 
			
		||||
  pixel[0] = cogl_color_get_red_byte (&color);
 | 
			
		||||
@@ -73,10 +71,8 @@ meta_create_color_texture_4ub (guint8           red,
 | 
			
		||||
 * @src_texture: (allow-none): texture to use initially for the layer
 | 
			
		||||
 *
 | 
			
		||||
 * Creates a pipeline with a single layer. Using a common template
 | 
			
		||||
 * allows sharing a shader for different uses in Mutter. To share the same
 | 
			
		||||
 * shader with all other pipelines that are just texture plus opacity
 | 
			
		||||
 * would require Cogl fixes.
 | 
			
		||||
 * (See http://bugzilla.clutter-project.org/show_bug.cgi?id=2425)
 | 
			
		||||
 * makes it easier for Cogl to share a shader for different uses in
 | 
			
		||||
 * Mutter.
 | 
			
		||||
 *
 | 
			
		||||
 * Return value: (transfer full): a newly created #CoglPipeline
 | 
			
		||||
 */
 | 
			
		||||
@@ -86,22 +82,21 @@ meta_create_texture_pipeline (CoglTexture *src_texture)
 | 
			
		||||
  static CoglPipeline *texture_pipeline_template = NULL;
 | 
			
		||||
  CoglPipeline *pipeline;
 | 
			
		||||
 | 
			
		||||
  /* We use a pipeline that has a dummy texture as a base for all
 | 
			
		||||
     texture pipelines. The idea is that only the Cogl texture object
 | 
			
		||||
     would be different in the children so it is likely that Cogl will
 | 
			
		||||
     be able to share GL programs between all the textures. */
 | 
			
		||||
  /* The only state used in the pipeline that would affect the shader
 | 
			
		||||
     generation is the texture type on the layer. Therefore we create
 | 
			
		||||
     a template pipeline which sets this state and all texture
 | 
			
		||||
     pipelines are created as a copy of this. That way Cogl can find
 | 
			
		||||
     the shader state for the pipeline more quickly by looking at the
 | 
			
		||||
     pipeline ancestry instead of resorting to the shader cache. */
 | 
			
		||||
  if (G_UNLIKELY (texture_pipeline_template == NULL))
 | 
			
		||||
    {
 | 
			
		||||
      CoglTexture *dummy_texture;
 | 
			
		||||
      CoglContext *ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ());
 | 
			
		||||
 | 
			
		||||
      dummy_texture = meta_create_color_texture_4ub (0xff, 0xff, 0xff, 0xff,
 | 
			
		||||
                                                     COGL_TEXTURE_NONE);
 | 
			
		||||
 | 
			
		||||
      CoglContext *ctx =
 | 
			
		||||
        clutter_backend_get_cogl_context (clutter_get_default_backend ());
 | 
			
		||||
 | 
			
		||||
      texture_pipeline_template = cogl_pipeline_new (ctx);
 | 
			
		||||
      cogl_pipeline_set_layer_texture (texture_pipeline_template, 0, dummy_texture);
 | 
			
		||||
      cogl_object_unref (dummy_texture);
 | 
			
		||||
      cogl_pipeline_set_layer_null_texture (texture_pipeline_template,
 | 
			
		||||
                                            0, /* layer */
 | 
			
		||||
                                            COGL_TEXTURE_TYPE_2D);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  pipeline = cogl_pipeline_copy (texture_pipeline_template);
 | 
			
		||||
 
 | 
			
		||||
@@ -15,9 +15,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef __META_COGL_UTILS_H__
 | 
			
		||||
 
 | 
			
		||||
@@ -17,20 +17,12 @@ struct _MetaCompositor
 | 
			
		||||
{
 | 
			
		||||
  MetaDisplay    *display;
 | 
			
		||||
 | 
			
		||||
  Atom            atom_x_root_pixmap;
 | 
			
		||||
  Atom            atom_net_wm_window_opacity;
 | 
			
		||||
  guint           repaint_func_id;
 | 
			
		||||
 | 
			
		||||
  ClutterActor   *shadow_src;
 | 
			
		||||
 | 
			
		||||
  MetaPlugin     *modal_plugin;
 | 
			
		||||
 | 
			
		||||
  gint64          server_time_query_time;
 | 
			
		||||
  gint64          server_time_offset;
 | 
			
		||||
 | 
			
		||||
  guint           server_time_is_monotonic_time : 1;
 | 
			
		||||
  guint           show_redraw : 1;
 | 
			
		||||
  guint           debug       : 1;
 | 
			
		||||
  guint           no_mipmaps  : 1;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
@@ -38,21 +30,17 @@ struct _MetaCompScreen
 | 
			
		||||
{
 | 
			
		||||
  MetaScreen            *screen;
 | 
			
		||||
 | 
			
		||||
  ClutterActor          *stage, *window_group, *top_window_group, *overlay_group;
 | 
			
		||||
  ClutterActor          *stage, *window_group, *top_window_group;
 | 
			
		||||
  ClutterActor          *background_actor;
 | 
			
		||||
  GList                 *windows;
 | 
			
		||||
  GHashTable            *windows_by_xid;
 | 
			
		||||
  Window                 output;
 | 
			
		||||
 | 
			
		||||
  CoglOnscreen          *onscreen;
 | 
			
		||||
  CoglFrameClosure      *frame_closure;
 | 
			
		||||
 | 
			
		||||
  /* Used for unredirecting fullscreen windows */
 | 
			
		||||
  guint                   disable_unredirect_count;
 | 
			
		||||
  MetaWindowActor             *unredirected_window;
 | 
			
		||||
 | 
			
		||||
  /* Before we create the output window */
 | 
			
		||||
  XserverRegion     pending_input_region;
 | 
			
		||||
  guint                  disable_unredirect_count;
 | 
			
		||||
  MetaWindow            *unredirected_window;
 | 
			
		||||
 | 
			
		||||
  gint                   switch_workspace_in_progress;
 | 
			
		||||
 | 
			
		||||
@@ -75,6 +63,4 @@ void     meta_end_modal_for_plugin   (MetaScreen       *screen,
 | 
			
		||||
gint64 meta_compositor_monotonic_time_to_server_time (MetaDisplay *display,
 | 
			
		||||
                                                      gint64       monotonic_time);
 | 
			
		||||
 | 
			
		||||
void meta_check_end_modal (MetaScreen *screen);
 | 
			
		||||
 | 
			
		||||
#endif /* META_COMPOSITOR_PRIVATE_H */
 | 
			
		||||
 
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -6,9 +6,6 @@
 | 
			
		||||
#include <meta/screen.h>
 | 
			
		||||
#include <meta/meta-background-actor.h>
 | 
			
		||||
 | 
			
		||||
void meta_background_actor_set_visible_region  (MetaBackgroundActor *self,
 | 
			
		||||
                                                cairo_region_t      *visible_region);
 | 
			
		||||
 | 
			
		||||
cairo_region_t *meta_background_actor_get_visible_region (MetaBackgroundActor *self);
 | 
			
		||||
cairo_region_t *meta_background_actor_get_clip_region (MetaBackgroundActor *self);
 | 
			
		||||
 | 
			
		||||
#endif /* META_BACKGROUND_ACTOR_PRIVATE_H */
 | 
			
		||||
 
 | 
			
		||||
@@ -14,9 +14,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 *
 | 
			
		||||
 * Portions adapted from gnome-shell/src/shell-global.c
 | 
			
		||||
 */
 | 
			
		||||
@@ -41,20 +39,35 @@
 | 
			
		||||
#include <meta/errors.h>
 | 
			
		||||
#include <meta/meta-background.h>
 | 
			
		||||
#include "meta-background-actor-private.h"
 | 
			
		||||
#include "meta-cullable.h"
 | 
			
		||||
 | 
			
		||||
struct _MetaBackgroundActorPrivate
 | 
			
		||||
{
 | 
			
		||||
  cairo_region_t *visible_region;
 | 
			
		||||
  cairo_region_t *clip_region;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
G_DEFINE_TYPE (MetaBackgroundActor, meta_background_actor, CLUTTER_TYPE_ACTOR);
 | 
			
		||||
static void cullable_iface_init (MetaCullableInterface *iface);
 | 
			
		||||
 | 
			
		||||
G_DEFINE_TYPE_WITH_CODE (MetaBackgroundActor, meta_background_actor, CLUTTER_TYPE_ACTOR,
 | 
			
		||||
                         G_IMPLEMENT_INTERFACE (META_TYPE_CULLABLE, cullable_iface_init));
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
set_clip_region (MetaBackgroundActor *self,
 | 
			
		||||
                 cairo_region_t      *clip_region)
 | 
			
		||||
{
 | 
			
		||||
  MetaBackgroundActorPrivate *priv = self->priv;
 | 
			
		||||
 | 
			
		||||
  g_clear_pointer (&priv->clip_region, (GDestroyNotify) cairo_region_destroy);
 | 
			
		||||
  if (clip_region)
 | 
			
		||||
    priv->clip_region = cairo_region_copy (clip_region);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_background_actor_dispose (GObject *object)
 | 
			
		||||
{
 | 
			
		||||
  MetaBackgroundActor *self = META_BACKGROUND_ACTOR (object);
 | 
			
		||||
 | 
			
		||||
  meta_background_actor_set_visible_region (self, NULL);
 | 
			
		||||
  set_clip_region (self, NULL);
 | 
			
		||||
 | 
			
		||||
  G_OBJECT_CLASS (meta_background_actor_parent_class)->dispose (object);
 | 
			
		||||
}
 | 
			
		||||
@@ -104,26 +117,6 @@ meta_background_actor_get_preferred_height (ClutterActor *actor,
 | 
			
		||||
    *natural_height_p = height;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
meta_background_actor_get_paint_volume (ClutterActor       *actor,
 | 
			
		||||
                                        ClutterPaintVolume *volume)
 | 
			
		||||
{
 | 
			
		||||
  ClutterContent *content;
 | 
			
		||||
  gfloat width, height;
 | 
			
		||||
 | 
			
		||||
  content = clutter_actor_get_content (actor);
 | 
			
		||||
 | 
			
		||||
  if (!content)
 | 
			
		||||
    return FALSE;
 | 
			
		||||
 | 
			
		||||
  clutter_content_get_preferred_size (content, &width, &height);
 | 
			
		||||
 | 
			
		||||
  clutter_paint_volume_set_width (volume, width);
 | 
			
		||||
  clutter_paint_volume_set_height (volume, height);
 | 
			
		||||
 | 
			
		||||
  return TRUE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_background_actor_class_init (MetaBackgroundActorClass *klass)
 | 
			
		||||
{
 | 
			
		||||
@@ -136,7 +129,6 @@ meta_background_actor_class_init (MetaBackgroundActorClass *klass)
 | 
			
		||||
 | 
			
		||||
  actor_class->get_preferred_width = meta_background_actor_get_preferred_width;
 | 
			
		||||
  actor_class->get_preferred_height = meta_background_actor_get_preferred_height;
 | 
			
		||||
  actor_class->get_paint_volume = meta_background_actor_get_paint_volume;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
@@ -166,35 +158,31 @@ meta_background_actor_new (void)
 | 
			
		||||
  return CLUTTER_ACTOR (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * meta_background_actor_set_visible_region:
 | 
			
		||||
 * @self: a #MetaBackgroundActor
 | 
			
		||||
 * @visible_region: (allow-none): the area of the actor (in allocate-relative
 | 
			
		||||
 *   coordinates) that is visible.
 | 
			
		||||
 *
 | 
			
		||||
 * Sets the area of the background that is unobscured by overlapping windows.
 | 
			
		||||
 * This is used to optimize and only paint the visible portions.
 | 
			
		||||
 */
 | 
			
		||||
void
 | 
			
		||||
meta_background_actor_set_visible_region (MetaBackgroundActor *self,
 | 
			
		||||
                                          cairo_region_t      *visible_region)
 | 
			
		||||
static void
 | 
			
		||||
meta_background_actor_cull_out (MetaCullable   *cullable,
 | 
			
		||||
                                cairo_region_t *unobscured_region,
 | 
			
		||||
                                cairo_region_t *clip_region)
 | 
			
		||||
{
 | 
			
		||||
  MetaBackgroundActorPrivate *priv;
 | 
			
		||||
  MetaBackgroundActor *self = META_BACKGROUND_ACTOR (cullable);
 | 
			
		||||
  set_clip_region (self, clip_region);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
  g_return_if_fail (META_IS_BACKGROUND_ACTOR (self));
 | 
			
		||||
static void
 | 
			
		||||
meta_background_actor_reset_culling (MetaCullable *cullable)
 | 
			
		||||
{
 | 
			
		||||
  MetaBackgroundActor *self = META_BACKGROUND_ACTOR (cullable);
 | 
			
		||||
  set_clip_region (self, NULL);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
  priv = self->priv;
 | 
			
		||||
 | 
			
		||||
  g_clear_pointer (&priv->visible_region,
 | 
			
		||||
                   (GDestroyNotify)
 | 
			
		||||
                   cairo_region_destroy);
 | 
			
		||||
 | 
			
		||||
  if (visible_region)
 | 
			
		||||
    priv->visible_region = cairo_region_copy (visible_region);
 | 
			
		||||
static void
 | 
			
		||||
cullable_iface_init (MetaCullableInterface *iface)
 | 
			
		||||
{
 | 
			
		||||
  iface->cull_out = meta_background_actor_cull_out;
 | 
			
		||||
  iface->reset_culling = meta_background_actor_reset_culling;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * meta_background_actor_get_visible_region:
 | 
			
		||||
 * meta_background_actor_get_clip_region:
 | 
			
		||||
 * @self: a #MetaBackgroundActor
 | 
			
		||||
 *
 | 
			
		||||
 * Return value (transfer full): a #cairo_region_t that represents the part of
 | 
			
		||||
@@ -202,16 +190,16 @@ meta_background_actor_set_visible_region (MetaBackgroundActor *self,
 | 
			
		||||
 * #MetaWindowActor objects.
 | 
			
		||||
 */
 | 
			
		||||
cairo_region_t *
 | 
			
		||||
meta_background_actor_get_visible_region (MetaBackgroundActor *self)
 | 
			
		||||
meta_background_actor_get_clip_region (MetaBackgroundActor *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaBackgroundActorPrivate *priv = self->priv;
 | 
			
		||||
  ClutterActorBox content_box;
 | 
			
		||||
  cairo_rectangle_int_t content_area = { 0 };
 | 
			
		||||
  cairo_region_t *visible_region;
 | 
			
		||||
  cairo_region_t *clip_region;
 | 
			
		||||
 | 
			
		||||
  g_return_val_if_fail (META_IS_BACKGROUND_ACTOR (self), NULL);
 | 
			
		||||
 | 
			
		||||
  if (!priv->visible_region)
 | 
			
		||||
  if (!priv->clip_region)
 | 
			
		||||
      return NULL;
 | 
			
		||||
 | 
			
		||||
  clutter_actor_get_content_box (CLUTTER_ACTOR (self), &content_box);
 | 
			
		||||
@@ -221,8 +209,8 @@ meta_background_actor_get_visible_region (MetaBackgroundActor *self)
 | 
			
		||||
  content_area.width = content_box.x2 - content_box.x1;
 | 
			
		||||
  content_area.height = content_box.y2 - content_box.y1;
 | 
			
		||||
 | 
			
		||||
  visible_region = cairo_region_create_rectangle (&content_area);
 | 
			
		||||
  cairo_region_intersect (visible_region, priv->visible_region);
 | 
			
		||||
  clip_region = cairo_region_create_rectangle (&content_area);
 | 
			
		||||
  cairo_region_intersect (clip_region, priv->clip_region);
 | 
			
		||||
 | 
			
		||||
  return visible_region;
 | 
			
		||||
  return clip_region;
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -1,11 +0,0 @@
 | 
			
		||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
 | 
			
		||||
 | 
			
		||||
#ifndef META_BACKGROUND_GROUP_PRIVATE_H
 | 
			
		||||
#define META_BACKGROUND_GROUP_PRIVATE_H
 | 
			
		||||
 | 
			
		||||
#include <meta/screen.h>
 | 
			
		||||
#include <meta/meta-background-group.h>
 | 
			
		||||
 | 
			
		||||
void meta_background_group_set_visible_region  (MetaBackgroundGroup *self,
 | 
			
		||||
                                                cairo_region_t      *visible_region);
 | 
			
		||||
#endif /* META_BACKGROUND_GROUP_PRIVATE_H */
 | 
			
		||||
@@ -16,87 +16,43 @@
 | 
			
		||||
 | 
			
		||||
#include <config.h>
 | 
			
		||||
 | 
			
		||||
#include "compositor-private.h"
 | 
			
		||||
#include "clutter-utils.h"
 | 
			
		||||
#include "meta-background-actor-private.h"
 | 
			
		||||
#include "meta-background-group-private.h"
 | 
			
		||||
#include <meta/meta-background-group.h>
 | 
			
		||||
#include "meta-cullable.h"
 | 
			
		||||
 | 
			
		||||
G_DEFINE_TYPE (MetaBackgroundGroup, meta_background_group, CLUTTER_TYPE_ACTOR);
 | 
			
		||||
static void cullable_iface_init (MetaCullableInterface *iface);
 | 
			
		||||
 | 
			
		||||
struct _MetaBackgroundGroupPrivate
 | 
			
		||||
{
 | 
			
		||||
  gpointer dummy;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_background_group_dispose (GObject *object)
 | 
			
		||||
{
 | 
			
		||||
  G_OBJECT_CLASS (meta_background_group_parent_class)->dispose (object);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
meta_background_group_get_paint_volume (ClutterActor       *actor,
 | 
			
		||||
                                        ClutterPaintVolume *volume)
 | 
			
		||||
{
 | 
			
		||||
  return clutter_paint_volume_set_from_allocation (volume, actor);
 | 
			
		||||
}
 | 
			
		||||
G_DEFINE_TYPE_WITH_CODE (MetaBackgroundGroup, meta_background_group, CLUTTER_TYPE_ACTOR,
 | 
			
		||||
                         G_IMPLEMENT_INTERFACE (META_TYPE_CULLABLE, cullable_iface_init));
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_background_group_class_init (MetaBackgroundGroupClass *klass)
 | 
			
		||||
{
 | 
			
		||||
  GObjectClass *object_class = G_OBJECT_CLASS (klass);
 | 
			
		||||
  ClutterActorClass *actor_class = CLUTTER_ACTOR_CLASS (klass);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
  actor_class->get_paint_volume = meta_background_group_get_paint_volume;
 | 
			
		||||
  object_class->dispose = meta_background_group_dispose;
 | 
			
		||||
static void
 | 
			
		||||
meta_background_group_cull_out (MetaCullable   *cullable,
 | 
			
		||||
                                cairo_region_t *unobscured_region,
 | 
			
		||||
                                cairo_region_t *clip_region)
 | 
			
		||||
{
 | 
			
		||||
  meta_cullable_cull_out_children (cullable, unobscured_region, clip_region);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
  g_type_class_add_private (klass, sizeof (MetaBackgroundGroupPrivate));
 | 
			
		||||
static void
 | 
			
		||||
meta_background_group_reset_culling (MetaCullable *cullable)
 | 
			
		||||
{
 | 
			
		||||
  meta_cullable_reset_culling_children (cullable);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
cullable_iface_init (MetaCullableInterface *iface)
 | 
			
		||||
{
 | 
			
		||||
  iface->cull_out = meta_background_group_cull_out;
 | 
			
		||||
  iface->reset_culling = meta_background_group_reset_culling;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_background_group_init (MetaBackgroundGroup *self)
 | 
			
		||||
{
 | 
			
		||||
  self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self,
 | 
			
		||||
                                            META_TYPE_BACKGROUND_GROUP,
 | 
			
		||||
                                            MetaBackgroundGroupPrivate);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * meta_background_group_set_visible_region:
 | 
			
		||||
 * @self: a #MetaBackgroundGroup
 | 
			
		||||
 * @visible_region: (allow-none): the parts of the background to paint
 | 
			
		||||
 *
 | 
			
		||||
 * Sets the area of the backgrounds that is unobscured by overlapping windows.
 | 
			
		||||
 * This is used to optimize and only paint the visible portions.
 | 
			
		||||
 */
 | 
			
		||||
void
 | 
			
		||||
meta_background_group_set_visible_region (MetaBackgroundGroup *self,
 | 
			
		||||
                                          cairo_region_t      *region)
 | 
			
		||||
{
 | 
			
		||||
  GList *children, *l;
 | 
			
		||||
 | 
			
		||||
  children = clutter_actor_get_children (CLUTTER_ACTOR (self));
 | 
			
		||||
  for (l = children; l; l = l->next)
 | 
			
		||||
    {
 | 
			
		||||
      ClutterActor *actor = l->data;
 | 
			
		||||
 | 
			
		||||
      if (META_IS_BACKGROUND_ACTOR (actor))
 | 
			
		||||
        {
 | 
			
		||||
          meta_background_actor_set_visible_region (META_BACKGROUND_ACTOR (actor), region);
 | 
			
		||||
        }
 | 
			
		||||
      else if (META_IS_BACKGROUND_GROUP (actor))
 | 
			
		||||
        {
 | 
			
		||||
          int x, y;
 | 
			
		||||
 | 
			
		||||
          if (!meta_actor_is_untransformed (actor, &x, &y))
 | 
			
		||||
            continue;
 | 
			
		||||
 | 
			
		||||
          cairo_region_translate (region, -x, -y);
 | 
			
		||||
          meta_background_group_set_visible_region (META_BACKGROUND_GROUP (actor), region);
 | 
			
		||||
          cairo_region_translate (region, x, y);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
  g_list_free (children);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
ClutterActor *
 | 
			
		||||
 
 | 
			
		||||
@@ -14,9 +14,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -37,6 +35,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                                           \
 | 
			
		||||
@@ -412,13 +411,13 @@ meta_background_paint_content (ClutterContent   *content,
 | 
			
		||||
   */
 | 
			
		||||
  if (META_IS_BACKGROUND_ACTOR (actor))
 | 
			
		||||
    {
 | 
			
		||||
      cairo_region_t *visible_region;
 | 
			
		||||
      visible_region = meta_background_actor_get_visible_region (META_BACKGROUND_ACTOR (actor));
 | 
			
		||||
      cairo_region_t *clip_region;
 | 
			
		||||
      clip_region = meta_background_actor_get_clip_region (META_BACKGROUND_ACTOR (actor));
 | 
			
		||||
 | 
			
		||||
      if (visible_region != NULL)
 | 
			
		||||
      if (clip_region != NULL)
 | 
			
		||||
        {
 | 
			
		||||
          cairo_region_intersect (paintable_region, visible_region);
 | 
			
		||||
          cairo_region_destroy (visible_region);
 | 
			
		||||
          cairo_region_intersect (paintable_region, clip_region);
 | 
			
		||||
          cairo_region_destroy (clip_region);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										201
									
								
								src/compositor/meta-cullable.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										201
									
								
								src/compositor/meta-cullable.c
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,201 @@
 | 
			
		||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright (C) 2013 Red Hat
 | 
			
		||||
 *
 | 
			
		||||
 * 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, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 *
 | 
			
		||||
 * Written by:
 | 
			
		||||
 *     Owen Taylor <otaylor@redhat.com>
 | 
			
		||||
 *     Ray Strode <rstrode@redhat.com>
 | 
			
		||||
 *     Jasper St. Pierre <jstpierre@mecheye.net>
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include "config.h"
 | 
			
		||||
#include "meta-cullable.h"
 | 
			
		||||
#include "clutter-utils.h"
 | 
			
		||||
 | 
			
		||||
G_DEFINE_INTERFACE (MetaCullable, meta_cullable, CLUTTER_TYPE_ACTOR);
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * SECTION:meta-cullable
 | 
			
		||||
 * @title: MetaCullable
 | 
			
		||||
 * @short_description: CPU culling operations for efficient drawing
 | 
			
		||||
 *
 | 
			
		||||
 * When we are painting a stack of 5-10 large actors, the standard
 | 
			
		||||
 * bottom-to-top method of drawing every actor results in a tremendous
 | 
			
		||||
 * amount of overdraw. If these actors are painting textures like
 | 
			
		||||
 * windows, it can easily max out the available memory bandwidth on a
 | 
			
		||||
 * low-end graphics chipset. It's even worse if window textures are
 | 
			
		||||
 * being accessed over the AGP bus.
 | 
			
		||||
 *
 | 
			
		||||
 * #MetaCullable is our solution. The basic technique applied here is to
 | 
			
		||||
 * do a pre-pass before painting where we walk each actor from top to bottom
 | 
			
		||||
 * and ask each actor to "cull itself out". We pass in a region it can copy
 | 
			
		||||
 * to clip its drawing to, and the actor can subtract its fully opaque pixels
 | 
			
		||||
 * so that actors underneath know not to draw there as well.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * meta_cullable_cull_out_children:
 | 
			
		||||
 * @cullable: The #MetaCullable
 | 
			
		||||
 * @unobscured_region: The unobscured region, as passed into cull_out()
 | 
			
		||||
 * @clip_region: The clip region, as passed into cull_out()
 | 
			
		||||
 *
 | 
			
		||||
 * This is a helper method for actors that want to recurse over their
 | 
			
		||||
 * child actors, and cull them out.
 | 
			
		||||
 *
 | 
			
		||||
 * See #MetaCullable and meta_cullable_cull_out() for more details.
 | 
			
		||||
 */
 | 
			
		||||
void
 | 
			
		||||
meta_cullable_cull_out_children (MetaCullable   *cullable,
 | 
			
		||||
                                 cairo_region_t *unobscured_region,
 | 
			
		||||
                                 cairo_region_t *clip_region)
 | 
			
		||||
{
 | 
			
		||||
  ClutterActor *actor = CLUTTER_ACTOR (cullable);
 | 
			
		||||
  ClutterActor *child;
 | 
			
		||||
  ClutterActorIter iter;
 | 
			
		||||
 | 
			
		||||
  clutter_actor_iter_init (&iter, actor);
 | 
			
		||||
  while (clutter_actor_iter_prev (&iter, &child))
 | 
			
		||||
    {
 | 
			
		||||
      float x, y;
 | 
			
		||||
      gboolean needs_culling;
 | 
			
		||||
 | 
			
		||||
      if (!META_IS_CULLABLE (child))
 | 
			
		||||
        continue;
 | 
			
		||||
 | 
			
		||||
      needs_culling = (unobscured_region != NULL && clip_region != NULL);
 | 
			
		||||
 | 
			
		||||
      if (needs_culling && !CLUTTER_ACTOR_IS_VISIBLE (child))
 | 
			
		||||
        needs_culling = FALSE;
 | 
			
		||||
 | 
			
		||||
      /* If an actor has effects applied, then that can change the area
 | 
			
		||||
       * it paints and the opacity, so we no longer can figure out what
 | 
			
		||||
       * portion of the actor is obscured and what portion of the screen
 | 
			
		||||
       * it obscures, so we skip the actor.
 | 
			
		||||
       *
 | 
			
		||||
       * This has a secondary beneficial effect: if a ClutterOffscreenEffect
 | 
			
		||||
       * is applied to an actor, then our clipped redraws interfere with the
 | 
			
		||||
       * caching of the FBO - even if we only need to draw a small portion
 | 
			
		||||
       * of the window right now, ClutterOffscreenEffect may use other portions
 | 
			
		||||
       * of the FBO later. So, skipping actors with effects applied also
 | 
			
		||||
       * prevents these bugs.
 | 
			
		||||
       *
 | 
			
		||||
       * Theoretically, we should check clutter_actor_get_offscreen_redirect()
 | 
			
		||||
       * as well for the same reason, but omitted for simplicity in the
 | 
			
		||||
       * hopes that no-one will do that.
 | 
			
		||||
       */
 | 
			
		||||
      if (needs_culling && clutter_actor_has_effects (child))
 | 
			
		||||
        needs_culling = FALSE;
 | 
			
		||||
 | 
			
		||||
      if (needs_culling && !meta_actor_is_untransformed (child, NULL, NULL))
 | 
			
		||||
        needs_culling = FALSE;
 | 
			
		||||
 | 
			
		||||
      if (needs_culling)
 | 
			
		||||
        {
 | 
			
		||||
          clutter_actor_get_position (child, &x, &y);
 | 
			
		||||
 | 
			
		||||
          /* Temporarily move to the coordinate system of the actor */
 | 
			
		||||
          cairo_region_translate (unobscured_region, - x, - y);
 | 
			
		||||
          cairo_region_translate (clip_region, - x, - y);
 | 
			
		||||
 | 
			
		||||
          meta_cullable_cull_out (META_CULLABLE (child), unobscured_region, clip_region);
 | 
			
		||||
 | 
			
		||||
          cairo_region_translate (unobscured_region, x, y);
 | 
			
		||||
          cairo_region_translate (clip_region, x, y);
 | 
			
		||||
        }
 | 
			
		||||
      else
 | 
			
		||||
        {
 | 
			
		||||
          meta_cullable_cull_out (META_CULLABLE (child), NULL, NULL);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * meta_cullable_reset_culling_children:
 | 
			
		||||
 * @cullable: The #MetaCullable
 | 
			
		||||
 *
 | 
			
		||||
 * This is a helper method for actors that want to recurse over their
 | 
			
		||||
 * child actors, and cull them out.
 | 
			
		||||
 *
 | 
			
		||||
 * See #MetaCullable and meta_cullable_reset_culling() for more details.
 | 
			
		||||
 */
 | 
			
		||||
void
 | 
			
		||||
meta_cullable_reset_culling_children (MetaCullable *cullable)
 | 
			
		||||
{
 | 
			
		||||
  ClutterActor *actor = CLUTTER_ACTOR (cullable);
 | 
			
		||||
  ClutterActor *child;
 | 
			
		||||
  ClutterActorIter iter;
 | 
			
		||||
 | 
			
		||||
  clutter_actor_iter_init (&iter, actor);
 | 
			
		||||
  while (clutter_actor_iter_next (&iter, &child))
 | 
			
		||||
    {
 | 
			
		||||
      if (!META_IS_CULLABLE (child))
 | 
			
		||||
        continue;
 | 
			
		||||
 | 
			
		||||
      meta_cullable_reset_culling (META_CULLABLE (child));
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_cullable_default_init (MetaCullableInterface *iface)
 | 
			
		||||
{
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * meta_cullable_cull_out:
 | 
			
		||||
 * @cullable: The #MetaCullable
 | 
			
		||||
 * @unobscured_region: The unobscured region, in @cullable's space.
 | 
			
		||||
 * @clip_region: The clip region, in @cullable's space.
 | 
			
		||||
 *
 | 
			
		||||
 * When #MetaWindowGroup is painted, we walk over its direct cullable
 | 
			
		||||
 * children from top to bottom and ask themselves to "cull out". Cullables
 | 
			
		||||
 * can use @unobscured_region and @clip_region to clip their drawing. Actors
 | 
			
		||||
 * interested in eliminating overdraw should copy the @clip_region and only
 | 
			
		||||
 * paint those parts, as everything else has been obscured by actors above it.
 | 
			
		||||
 *
 | 
			
		||||
 * Actors that may have fully opaque parts should also subtract out a region
 | 
			
		||||
 * that is fully opaque from @unobscured_region and @clip_region.
 | 
			
		||||
 *
 | 
			
		||||
 * @unobscured_region and @clip_region are extremely similar. The difference
 | 
			
		||||
 * is that @clip_region starts off with the stage's clip, if Clutter detects
 | 
			
		||||
 * that we're doing a clipped redraw. @unobscured_region, however, starts off
 | 
			
		||||
 * with the full stage size, so actors that may want to record what parts of
 | 
			
		||||
 * their window are unobscured for e.g. scheduling repaints can do so.
 | 
			
		||||
 *
 | 
			
		||||
 * Actors that have children can also use the meta_cullable_cull_out_children()
 | 
			
		||||
 * helper method to do a simple cull across all their children.
 | 
			
		||||
 */
 | 
			
		||||
void
 | 
			
		||||
meta_cullable_cull_out (MetaCullable   *cullable,
 | 
			
		||||
                        cairo_region_t *unobscured_region,
 | 
			
		||||
                        cairo_region_t *clip_region)
 | 
			
		||||
{
 | 
			
		||||
  META_CULLABLE_GET_IFACE (cullable)->cull_out (cullable, unobscured_region, clip_region);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * meta_cullable_reset_culling:
 | 
			
		||||
 * @cullable: The #MetaCullable
 | 
			
		||||
 *
 | 
			
		||||
 * Actors that copied data in their cull_out() implementation can now
 | 
			
		||||
 * reset their data, as the paint is now over. Additional paints may be
 | 
			
		||||
 * done by #ClutterClone or similar, and they should not be affected by
 | 
			
		||||
 * the culling operation.
 | 
			
		||||
 */
 | 
			
		||||
void
 | 
			
		||||
meta_cullable_reset_culling (MetaCullable *cullable)
 | 
			
		||||
{
 | 
			
		||||
  META_CULLABLE_GET_IFACE (cullable)->reset_culling (cullable);
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										66
									
								
								src/compositor/meta-cullable.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								src/compositor/meta-cullable.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,66 @@
 | 
			
		||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright (C) 2013 Red Hat
 | 
			
		||||
 *
 | 
			
		||||
 * 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, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 *
 | 
			
		||||
 * Written by:
 | 
			
		||||
 *     Owen Taylor <otaylor@redhat.com>
 | 
			
		||||
 *     Ray Strode <rstrode@redhat.com>
 | 
			
		||||
 *     Jasper St. Pierre <jstpierre@mecheye.net>
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef __META_CULLABLE_H__
 | 
			
		||||
#define __META_CULLABLE_H__
 | 
			
		||||
 | 
			
		||||
#include <clutter/clutter.h>
 | 
			
		||||
 | 
			
		||||
G_BEGIN_DECLS
 | 
			
		||||
 | 
			
		||||
#define META_TYPE_CULLABLE             (meta_cullable_get_type ())
 | 
			
		||||
#define META_CULLABLE(obj)             (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_CULLABLE, MetaCullable))
 | 
			
		||||
#define META_IS_CULLABLE(obj)          (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_CULLABLE))
 | 
			
		||||
#define META_CULLABLE_GET_IFACE(obj)   (G_TYPE_INSTANCE_GET_INTERFACE ((obj),  META_TYPE_CULLABLE, MetaCullableInterface))
 | 
			
		||||
 | 
			
		||||
typedef struct _MetaCullable MetaCullable;
 | 
			
		||||
typedef struct _MetaCullableInterface MetaCullableInterface;
 | 
			
		||||
 | 
			
		||||
struct _MetaCullableInterface
 | 
			
		||||
{
 | 
			
		||||
  GTypeInterface g_iface;
 | 
			
		||||
 | 
			
		||||
  void (* cull_out)      (MetaCullable   *cullable,
 | 
			
		||||
                          cairo_region_t *unobscured_region,
 | 
			
		||||
                          cairo_region_t *clip_region);
 | 
			
		||||
  void (* reset_culling) (MetaCullable  *cullable);
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
GType meta_cullable_get_type (void);
 | 
			
		||||
 | 
			
		||||
void meta_cullable_cull_out (MetaCullable   *cullable,
 | 
			
		||||
                             cairo_region_t *unobscured_region,
 | 
			
		||||
                             cairo_region_t *clip_region);
 | 
			
		||||
void meta_cullable_reset_culling (MetaCullable *cullable);
 | 
			
		||||
 | 
			
		||||
/* Utility methods for implementations */
 | 
			
		||||
void meta_cullable_cull_out_children (MetaCullable   *cullable,
 | 
			
		||||
                                      cairo_region_t *unobscured_region,
 | 
			
		||||
                                      cairo_region_t *clip_region);
 | 
			
		||||
void meta_cullable_reset_culling_children (MetaCullable *cullable);
 | 
			
		||||
 | 
			
		||||
G_END_DECLS
 | 
			
		||||
 | 
			
		||||
#endif /* __META_CULLABLE_H__ */
 | 
			
		||||
 | 
			
		||||
@@ -16,9 +16,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <meta/meta-plugin.h>
 | 
			
		||||
@@ -192,10 +190,7 @@ meta_module_class_init (MetaModuleClass *klass)
 | 
			
		||||
static void
 | 
			
		||||
meta_module_init (MetaModule *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaModulePrivate *priv;
 | 
			
		||||
 | 
			
		||||
  self->priv = priv = META_MODULE_GET_PRIVATE (self);
 | 
			
		||||
 | 
			
		||||
  self->priv = META_MODULE_GET_PRIVATE (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
GType
 | 
			
		||||
 
 | 
			
		||||
@@ -16,9 +16,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef META_MODULE_H_
 | 
			
		||||
 
 | 
			
		||||
@@ -16,9 +16,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include "config.h"
 | 
			
		||||
@@ -102,7 +100,9 @@ meta_plugin_manager_new (MetaScreen *screen)
 | 
			
		||||
 | 
			
		||||
  plugin_mgr = g_new0 (MetaPluginManager, 1);
 | 
			
		||||
  plugin_mgr->screen = screen;
 | 
			
		||||
  plugin_mgr->plugin = plugin = g_object_new (plugin_type, "screen", screen, NULL);
 | 
			
		||||
  plugin_mgr->plugin = plugin = g_object_new (plugin_type, NULL);
 | 
			
		||||
 | 
			
		||||
  _meta_plugin_set_screen (plugin, screen);
 | 
			
		||||
 | 
			
		||||
  klass = META_PLUGIN_GET_CLASS (plugin);
 | 
			
		||||
 | 
			
		||||
@@ -167,8 +167,6 @@ meta_plugin_manager_event_simple (MetaPluginManager *plugin_mgr,
 | 
			
		||||
          retval = TRUE;
 | 
			
		||||
          meta_plugin_manager_kill_window_effects (plugin_mgr,
 | 
			
		||||
                                                   actor);
 | 
			
		||||
 | 
			
		||||
          _meta_plugin_effect_started (plugin);
 | 
			
		||||
          klass->minimize (plugin, actor);
 | 
			
		||||
        }
 | 
			
		||||
      break;
 | 
			
		||||
@@ -178,8 +176,6 @@ meta_plugin_manager_event_simple (MetaPluginManager *plugin_mgr,
 | 
			
		||||
          retval = TRUE;
 | 
			
		||||
          meta_plugin_manager_kill_window_effects (plugin_mgr,
 | 
			
		||||
                                                   actor);
 | 
			
		||||
 | 
			
		||||
          _meta_plugin_effect_started (plugin);
 | 
			
		||||
          klass->map (plugin, actor);
 | 
			
		||||
        }
 | 
			
		||||
      break;
 | 
			
		||||
@@ -187,7 +183,6 @@ meta_plugin_manager_event_simple (MetaPluginManager *plugin_mgr,
 | 
			
		||||
      if (klass->destroy)
 | 
			
		||||
        {
 | 
			
		||||
          retval = TRUE;
 | 
			
		||||
          _meta_plugin_effect_started (plugin);
 | 
			
		||||
          klass->destroy (plugin, actor);
 | 
			
		||||
        }
 | 
			
		||||
      break;
 | 
			
		||||
@@ -232,8 +227,6 @@ meta_plugin_manager_event_maximize (MetaPluginManager *plugin_mgr,
 | 
			
		||||
          retval = TRUE;
 | 
			
		||||
          meta_plugin_manager_kill_window_effects (plugin_mgr,
 | 
			
		||||
                                                   actor);
 | 
			
		||||
 | 
			
		||||
          _meta_plugin_effect_started (plugin);
 | 
			
		||||
          klass->maximize (plugin, actor,
 | 
			
		||||
                           target_x, target_y,
 | 
			
		||||
                           target_width, target_height);
 | 
			
		||||
@@ -245,8 +238,6 @@ meta_plugin_manager_event_maximize (MetaPluginManager *plugin_mgr,
 | 
			
		||||
          retval = TRUE;
 | 
			
		||||
          meta_plugin_manager_kill_window_effects (plugin_mgr,
 | 
			
		||||
                                                   actor);
 | 
			
		||||
 | 
			
		||||
          _meta_plugin_effect_started (plugin);
 | 
			
		||||
          klass->unmaximize (plugin, actor,
 | 
			
		||||
                             target_x, target_y,
 | 
			
		||||
                             target_width, target_height);
 | 
			
		||||
@@ -285,8 +276,6 @@ meta_plugin_manager_switch_workspace (MetaPluginManager   *plugin_mgr,
 | 
			
		||||
    {
 | 
			
		||||
      retval = TRUE;
 | 
			
		||||
      meta_plugin_manager_kill_switch_workspace (plugin_mgr);
 | 
			
		||||
 | 
			
		||||
      _meta_plugin_effect_started (plugin);
 | 
			
		||||
      klass->switch_workspace (plugin, from, to, direction);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
@@ -306,41 +295,13 @@ meta_plugin_manager_filter_keybinding (MetaPluginManager *plugin_mgr,
 | 
			
		||||
  return FALSE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * The public method that the compositor hooks into for desktop switching.
 | 
			
		||||
 *
 | 
			
		||||
 * Returns TRUE if the plugin handled the event type (i.e.,
 | 
			
		||||
 * if the return value is FALSE, there will be no subsequent call to the
 | 
			
		||||
 * manager completed() callback, and the compositor must ensure that any
 | 
			
		||||
 * appropriate post-effect cleanup is carried out.
 | 
			
		||||
 */
 | 
			
		||||
gboolean
 | 
			
		||||
meta_plugin_manager_xevent_filter (MetaPluginManager *plugin_mgr,
 | 
			
		||||
                                   XEvent            *xev)
 | 
			
		||||
{
 | 
			
		||||
  MetaPlugin *plugin = plugin_mgr->plugin;
 | 
			
		||||
  MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
 | 
			
		||||
 | 
			
		||||
  /* We need to make sure that clutter gets certain events, like
 | 
			
		||||
   * ConfigureNotify on the stage window. If there is a plugin that
 | 
			
		||||
   * provides an xevent_filter function, then it's the responsibility
 | 
			
		||||
   * of that plugin to pass events to Clutter. Otherwise, we send the
 | 
			
		||||
   * event directly to Clutter ourselves.
 | 
			
		||||
   */
 | 
			
		||||
  if (klass->xevent_filter)
 | 
			
		||||
    return klass->xevent_filter (plugin, xev);
 | 
			
		||||
 | 
			
		||||
  /* 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 (meta_is_wayland_compositor ())
 | 
			
		||||
    return FALSE;
 | 
			
		||||
 | 
			
		||||
  return clutter_x11_handle_event (xev) != CLUTTER_X11_FILTER_CONTINUE;
 | 
			
		||||
  return _meta_plugin_xevent_filter (plugin, xev);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
@@ -354,3 +315,44 @@ meta_plugin_manager_confirm_display_change (MetaPluginManager *plugin_mgr)
 | 
			
		||||
  else
 | 
			
		||||
    return meta_plugin_complete_display_change (plugin, TRUE);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
gboolean
 | 
			
		||||
meta_plugin_manager_show_tile_preview (MetaPluginManager *plugin_mgr,
 | 
			
		||||
                                       MetaWindow        *window,
 | 
			
		||||
                                       MetaRectangle     *tile_rect,
 | 
			
		||||
                                       int                tile_monitor_number)
 | 
			
		||||
{
 | 
			
		||||
  MetaPlugin *plugin = plugin_mgr->plugin;
 | 
			
		||||
  MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
 | 
			
		||||
  MetaDisplay *display  = meta_screen_get_display (plugin_mgr->screen);
 | 
			
		||||
 | 
			
		||||
  if (display->display_opening)
 | 
			
		||||
    return FALSE;
 | 
			
		||||
 | 
			
		||||
  if (klass->show_tile_preview)
 | 
			
		||||
    {
 | 
			
		||||
      klass->show_tile_preview (plugin, window, tile_rect, tile_monitor_number);
 | 
			
		||||
      return TRUE;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  return FALSE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
gboolean
 | 
			
		||||
meta_plugin_manager_hide_tile_preview (MetaPluginManager *plugin_mgr)
 | 
			
		||||
{
 | 
			
		||||
  MetaPlugin *plugin = plugin_mgr->plugin;
 | 
			
		||||
  MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
 | 
			
		||||
  MetaDisplay *display  = meta_screen_get_display (plugin_mgr->screen);
 | 
			
		||||
 | 
			
		||||
  if (display->display_opening)
 | 
			
		||||
    return FALSE;
 | 
			
		||||
 | 
			
		||||
  if (klass->hide_tile_preview)
 | 
			
		||||
    {
 | 
			
		||||
      klass->hide_tile_preview (plugin);
 | 
			
		||||
      return TRUE;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  return FALSE;
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -16,9 +16,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef META_PLUGIN_MANAGER_H_
 | 
			
		||||
@@ -72,7 +70,14 @@ gboolean meta_plugin_manager_filter_keybinding (MetaPluginManager  *mgr,
 | 
			
		||||
 | 
			
		||||
gboolean meta_plugin_manager_xevent_filter (MetaPluginManager *mgr,
 | 
			
		||||
                                            XEvent            *xev);
 | 
			
		||||
gboolean _meta_plugin_xevent_filter (MetaPlugin *plugin,
 | 
			
		||||
                                     XEvent     *xev);
 | 
			
		||||
 | 
			
		||||
void     meta_plugin_manager_confirm_display_change (MetaPluginManager *mgr);
 | 
			
		||||
 | 
			
		||||
gboolean meta_plugin_manager_show_tile_preview (MetaPluginManager *mgr,
 | 
			
		||||
                                                MetaWindow        *window,
 | 
			
		||||
                                                MetaRectangle     *tile_rect,
 | 
			
		||||
                                                int                tile_monitor_number);
 | 
			
		||||
gboolean meta_plugin_manager_hide_tile_preview (MetaPluginManager *mgr);
 | 
			
		||||
#endif
 | 
			
		||||
 
 | 
			
		||||
@@ -16,9 +16,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -32,6 +30,7 @@
 | 
			
		||||
#include "meta-plugin-manager.h"
 | 
			
		||||
#include <meta/screen.h>
 | 
			
		||||
#include <meta/display.h>
 | 
			
		||||
#include <meta/util.h>
 | 
			
		||||
 | 
			
		||||
#include <string.h>
 | 
			
		||||
#include <X11/Xlib.h>
 | 
			
		||||
@@ -48,115 +47,21 @@ G_DEFINE_ABSTRACT_TYPE (MetaPlugin, meta_plugin, G_TYPE_OBJECT);
 | 
			
		||||
#define META_PLUGIN_GET_PRIVATE(obj) \
 | 
			
		||||
(G_TYPE_INSTANCE_GET_PRIVATE ((obj), META_TYPE_PLUGIN, MetaPluginPrivate))
 | 
			
		||||
 | 
			
		||||
enum
 | 
			
		||||
{
 | 
			
		||||
  PROP_0,
 | 
			
		||||
  PROP_SCREEN,
 | 
			
		||||
  PROP_DEBUG_MODE,
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
struct _MetaPluginPrivate
 | 
			
		||||
{
 | 
			
		||||
  MetaScreen   *screen;
 | 
			
		||||
 | 
			
		||||
  gint          running;
 | 
			
		||||
  gboolean      debug    : 1;
 | 
			
		||||
  MetaScreen *screen;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_plugin_set_property (GObject      *object,
 | 
			
		||||
                          guint         prop_id,
 | 
			
		||||
                          const GValue *value,
 | 
			
		||||
                          GParamSpec   *pspec)
 | 
			
		||||
{
 | 
			
		||||
  MetaPluginPrivate *priv = META_PLUGIN (object)->priv;
 | 
			
		||||
 | 
			
		||||
  switch (prop_id)
 | 
			
		||||
    {
 | 
			
		||||
    case PROP_SCREEN:
 | 
			
		||||
      priv->screen = g_value_get_object (value);
 | 
			
		||||
      break;
 | 
			
		||||
    case PROP_DEBUG_MODE:
 | 
			
		||||
      priv->debug = g_value_get_boolean (value);
 | 
			
		||||
      break;
 | 
			
		||||
    default:
 | 
			
		||||
      G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
 | 
			
		||||
      break;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_plugin_get_property (GObject    *object,
 | 
			
		||||
                          guint       prop_id,
 | 
			
		||||
                          GValue     *value,
 | 
			
		||||
                          GParamSpec *pspec)
 | 
			
		||||
{
 | 
			
		||||
  MetaPluginPrivate *priv = META_PLUGIN (object)->priv;
 | 
			
		||||
 | 
			
		||||
  switch (prop_id)
 | 
			
		||||
    {
 | 
			
		||||
    case PROP_SCREEN:
 | 
			
		||||
      g_value_set_object (value, priv->screen);
 | 
			
		||||
      break;
 | 
			
		||||
    case PROP_DEBUG_MODE:
 | 
			
		||||
      g_value_set_boolean (value, priv->debug);
 | 
			
		||||
      break;
 | 
			
		||||
    default:
 | 
			
		||||
      G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
 | 
			
		||||
      break;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_plugin_class_init (MetaPluginClass *klass)
 | 
			
		||||
{
 | 
			
		||||
  GObjectClass      *gobject_class = G_OBJECT_CLASS (klass);
 | 
			
		||||
 | 
			
		||||
  gobject_class->set_property    = meta_plugin_set_property;
 | 
			
		||||
  gobject_class->get_property    = meta_plugin_get_property;
 | 
			
		||||
 | 
			
		||||
  g_object_class_install_property (gobject_class,
 | 
			
		||||
                                   PROP_SCREEN,
 | 
			
		||||
                                   g_param_spec_object ("screen",
 | 
			
		||||
                                                        "MetaScreen",
 | 
			
		||||
                                                        "MetaScreen",
 | 
			
		||||
                                                        META_TYPE_SCREEN,
 | 
			
		||||
                                                        G_PARAM_READWRITE));
 | 
			
		||||
 | 
			
		||||
  g_object_class_install_property (gobject_class,
 | 
			
		||||
				   PROP_DEBUG_MODE,
 | 
			
		||||
				   g_param_spec_boolean ("debug-mode",
 | 
			
		||||
                                                      "Debug Mode",
 | 
			
		||||
                                                      "Debug Mode",
 | 
			
		||||
                                                      FALSE,
 | 
			
		||||
                                                      G_PARAM_READABLE));
 | 
			
		||||
 | 
			
		||||
  g_type_class_add_private (gobject_class, sizeof (MetaPluginPrivate));
 | 
			
		||||
  g_type_class_add_private (klass, sizeof (MetaPluginPrivate));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_plugin_init (MetaPlugin *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaPluginPrivate *priv;
 | 
			
		||||
 | 
			
		||||
  self->priv = priv = META_PLUGIN_GET_PRIVATE (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
gboolean
 | 
			
		||||
meta_plugin_running  (MetaPlugin *plugin)
 | 
			
		||||
{
 | 
			
		||||
  MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
 | 
			
		||||
 | 
			
		||||
  return (priv->running > 0);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
gboolean
 | 
			
		||||
meta_plugin_debug_mode (MetaPlugin *plugin)
 | 
			
		||||
{
 | 
			
		||||
  MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
 | 
			
		||||
 | 
			
		||||
  return priv->debug;
 | 
			
		||||
  self->priv = META_PLUGIN_GET_PRIVATE (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
const MetaPluginInfo *
 | 
			
		||||
@@ -170,34 +75,34 @@ meta_plugin_get_info (MetaPlugin *plugin)
 | 
			
		||||
  return NULL;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * _meta_plugin_effect_started:
 | 
			
		||||
 * @plugin: the plugin
 | 
			
		||||
 *
 | 
			
		||||
 * Mark that an effect has started for the plugin. This is called
 | 
			
		||||
 * internally by MetaPluginManager.
 | 
			
		||||
 */
 | 
			
		||||
void
 | 
			
		||||
_meta_plugin_effect_started (MetaPlugin *plugin)
 | 
			
		||||
gboolean
 | 
			
		||||
_meta_plugin_xevent_filter (MetaPlugin *plugin,
 | 
			
		||||
                            XEvent     *xev)
 | 
			
		||||
{
 | 
			
		||||
  MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
 | 
			
		||||
  MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
 | 
			
		||||
 | 
			
		||||
  priv->running++;
 | 
			
		||||
  /* 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 if (!meta_is_wayland_compositor ())
 | 
			
		||||
    return clutter_x11_handle_event (xev) != CLUTTER_X11_FILTER_CONTINUE;
 | 
			
		||||
  else
 | 
			
		||||
    return FALSE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_plugin_switch_workspace_completed (MetaPlugin *plugin)
 | 
			
		||||
{
 | 
			
		||||
  MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
 | 
			
		||||
 | 
			
		||||
  MetaScreen *screen = priv->screen;
 | 
			
		||||
 | 
			
		||||
  if (priv->running-- < 0)
 | 
			
		||||
    {
 | 
			
		||||
      g_warning ("Error in running effect accounting, adjusting.");
 | 
			
		||||
      priv->running = 0;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  meta_switch_workspace_completed (screen);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -206,26 +111,6 @@ meta_plugin_window_effect_completed (MetaPlugin      *plugin,
 | 
			
		||||
                                     MetaWindowActor *actor,
 | 
			
		||||
                                     unsigned long    event)
 | 
			
		||||
{
 | 
			
		||||
  MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
 | 
			
		||||
 | 
			
		||||
  if (priv->running-- < 0)
 | 
			
		||||
    {
 | 
			
		||||
      g_warning ("Error in running effect accounting, adjusting.");
 | 
			
		||||
      priv->running = 0;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  if (!actor)
 | 
			
		||||
    {
 | 
			
		||||
      const MetaPluginInfo *info;
 | 
			
		||||
      const gchar            *name = NULL;
 | 
			
		||||
 | 
			
		||||
      if (plugin && (info = meta_plugin_get_info (plugin)))
 | 
			
		||||
        name = info->name;
 | 
			
		||||
 | 
			
		||||
      g_warning ("Plugin [%s] passed NULL for actor!",
 | 
			
		||||
                 name ? name : "unknown");
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  meta_window_actor_effect_completed (actor, event);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -320,9 +205,7 @@ meta_plugin_end_modal (MetaPlugin *plugin,
 | 
			
		||||
 * meta_plugin_get_screen:
 | 
			
		||||
 * @plugin: a #MetaPlugin
 | 
			
		||||
 *
 | 
			
		||||
 * Gets the #MetaScreen corresponding to a plugin. Each plugin instance
 | 
			
		||||
 * is associated with exactly one screen; if Metacity is managing
 | 
			
		||||
 * multiple screens, multiple plugin instances will be created.
 | 
			
		||||
 * Gets the #MetaScreen corresponding to a plugin.
 | 
			
		||||
 *
 | 
			
		||||
 * Return value: (transfer none): the #MetaScreen for the plugin
 | 
			
		||||
 */
 | 
			
		||||
@@ -334,6 +217,15 @@ meta_plugin_get_screen (MetaPlugin *plugin)
 | 
			
		||||
  return priv->screen;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
_meta_plugin_set_screen (MetaPlugin *plugin,
 | 
			
		||||
                         MetaScreen *screen)
 | 
			
		||||
{
 | 
			
		||||
  MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
 | 
			
		||||
 | 
			
		||||
  priv->screen = screen;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_plugin_complete_display_change (MetaPlugin *plugin,
 | 
			
		||||
                                     gboolean    ok)
 | 
			
		||||
 
 | 
			
		||||
@@ -17,9 +17,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef __META_SHADOW_FACTORY_PRIVATE_H__
 | 
			
		||||
 
 | 
			
		||||
@@ -13,9 +13,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 
 | 
			
		||||
@@ -28,17 +28,12 @@
 | 
			
		||||
#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);
 | 
			
		||||
ClutterActor *meta_shaped_texture_new (void);
 | 
			
		||||
void meta_shaped_texture_set_texture (MetaShapedTexture *stex,
 | 
			
		||||
                                      CoglTexture       *texture);
 | 
			
		||||
gboolean meta_shaped_texture_get_unobscured_bounds (MetaShapedTexture     *stex,
 | 
			
		||||
                                                    cairo_rectangle_int_t *unobscured_bounds);
 | 
			
		||||
gboolean meta_shaped_texture_is_obscured (MetaShapedTexture *self);
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 
 | 
			
		||||
@@ -16,9 +16,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -31,22 +29,20 @@
 | 
			
		||||
 | 
			
		||||
#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 "meta-window-actor-private.h"
 | 
			
		||||
 | 
			
		||||
#include <clutter/clutter.h>
 | 
			
		||||
#include <cogl/cogl.h>
 | 
			
		||||
#include <cogl/cogl-texture-pixmap-x11.h>
 | 
			
		||||
#include <gdk/gdk.h> /* for gdk_rectangle_intersect() */
 | 
			
		||||
#include "meta-cullable.h"
 | 
			
		||||
 | 
			
		||||
static void meta_shaped_texture_dispose  (GObject    *object);
 | 
			
		||||
 | 
			
		||||
static void meta_shaped_texture_paint (ClutterActor       *actor);
 | 
			
		||||
static void meta_shaped_texture_pick  (ClutterActor       *actor,
 | 
			
		||||
				       const ClutterColor *color);
 | 
			
		||||
 | 
			
		||||
static void meta_shaped_texture_get_preferred_width (ClutterActor *self,
 | 
			
		||||
                                                     gfloat        for_height,
 | 
			
		||||
@@ -60,15 +56,10 @@ 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;
 | 
			
		||||
static void cullable_iface_init (MetaCullableInterface *iface);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
G_DEFINE_TYPE (MetaShapedTexture, meta_shaped_texture,
 | 
			
		||||
               CLUTTER_TYPE_ACTOR);
 | 
			
		||||
G_DEFINE_TYPE_WITH_CODE (MetaShapedTexture, meta_shaped_texture, CLUTTER_TYPE_ACTOR,
 | 
			
		||||
                         G_IMPLEMENT_INTERFACE (META_TYPE_CULLABLE, cullable_iface_init));
 | 
			
		||||
 | 
			
		||||
#define META_SHAPED_TEXTURE_GET_PRIVATE(obj) \
 | 
			
		||||
  (G_TYPE_INSTANCE_GET_PRIVATE ((obj), META_TYPE_SHAPED_TEXTURE, \
 | 
			
		||||
@@ -78,24 +69,16 @@ struct _MetaShapedTexturePrivate
 | 
			
		||||
{
 | 
			
		||||
  MetaTextureTower *paint_tower;
 | 
			
		||||
 | 
			
		||||
  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;
 | 
			
		||||
  /* The region containing only fully opaque pixels */
 | 
			
		||||
  cairo_region_t *opaque_region;
 | 
			
		||||
 | 
			
		||||
  /* MetaCullable regions, see that documentation for more details */
 | 
			
		||||
  cairo_region_t *clip_region;
 | 
			
		||||
  cairo_region_t *unobscured_region;
 | 
			
		||||
 | 
			
		||||
  guint tex_width, tex_height;
 | 
			
		||||
 | 
			
		||||
  guint create_mipmaps : 1;
 | 
			
		||||
@@ -112,7 +95,6 @@ meta_shaped_texture_class_init (MetaShapedTextureClass *klass)
 | 
			
		||||
  actor_class->get_preferred_width = meta_shaped_texture_get_preferred_width;
 | 
			
		||||
  actor_class->get_preferred_height = meta_shaped_texture_get_preferred_height;
 | 
			
		||||
  actor_class->paint = meta_shaped_texture_paint;
 | 
			
		||||
  actor_class->pick = meta_shaped_texture_pick;
 | 
			
		||||
  actor_class->get_paint_volume = meta_shaped_texture_get_paint_volume;
 | 
			
		||||
 | 
			
		||||
  g_type_class_add_private (klass, sizeof (MetaShapedTexturePrivate));
 | 
			
		||||
@@ -127,13 +109,37 @@ meta_shaped_texture_init (MetaShapedTexture *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;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
set_unobscured_region (MetaShapedTexture *self,
 | 
			
		||||
                       cairo_region_t    *unobscured_region)
 | 
			
		||||
{
 | 
			
		||||
  MetaShapedTexturePrivate *priv = self->priv;
 | 
			
		||||
 | 
			
		||||
  g_clear_pointer (&priv->unobscured_region, (GDestroyNotify) cairo_region_destroy);
 | 
			
		||||
  if (unobscured_region)
 | 
			
		||||
    {
 | 
			
		||||
      cairo_rectangle_int_t bounds = { 0, 0, priv->tex_width, priv->tex_height };
 | 
			
		||||
      priv->unobscured_region = cairo_region_copy (unobscured_region);
 | 
			
		||||
      cairo_region_intersect_rectangle (priv->unobscured_region, &bounds);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
set_clip_region (MetaShapedTexture *self,
 | 
			
		||||
                 cairo_region_t    *clip_region)
 | 
			
		||||
{
 | 
			
		||||
  MetaShapedTexturePrivate *priv = self->priv;
 | 
			
		||||
 | 
			
		||||
  g_clear_pointer (&priv->clip_region, (GDestroyNotify) cairo_region_destroy);
 | 
			
		||||
  if (clip_region)
 | 
			
		||||
    priv->clip_region = cairo_region_copy (clip_region);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_shaped_texture_dispose (GObject *object)
 | 
			
		||||
{
 | 
			
		||||
@@ -145,9 +151,11 @@ meta_shaped_texture_dispose (GObject *object)
 | 
			
		||||
  priv->paint_tower = NULL;
 | 
			
		||||
 | 
			
		||||
  g_clear_pointer (&priv->texture, cogl_object_unref);
 | 
			
		||||
  g_clear_pointer (&priv->opaque_region, cairo_region_destroy);
 | 
			
		||||
 | 
			
		||||
  meta_shaped_texture_set_mask_texture (self, NULL);
 | 
			
		||||
  meta_shaped_texture_set_clip_region (self, NULL);
 | 
			
		||||
  set_unobscured_region (self, NULL);
 | 
			
		||||
  set_clip_region (self, NULL);
 | 
			
		||||
 | 
			
		||||
  G_OBJECT_CLASS (meta_shaped_texture_parent_class)->dispose (object);
 | 
			
		||||
}
 | 
			
		||||
@@ -218,10 +226,8 @@ paint_clipped_rectangle (CoglFramebuffer       *fb,
 | 
			
		||||
  cogl_framebuffer_draw_multitextured_rectangle (fb, pipeline,
 | 
			
		||||
                                                 x1, y1, x2, y2,
 | 
			
		||||
                                                 &coords[0], 8);
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
set_cogl_texture (MetaShapedTexture *stex,
 | 
			
		||||
                  CoglTexture       *cogl_tex)
 | 
			
		||||
@@ -240,6 +246,7 @@ set_cogl_texture (MetaShapedTexture *stex,
 | 
			
		||||
 | 
			
		||||
  if (cogl_tex != NULL)
 | 
			
		||||
    {
 | 
			
		||||
      cogl_object_ref (cogl_tex);
 | 
			
		||||
      width = cogl_texture_get_width (COGL_TEXTURE (cogl_tex));
 | 
			
		||||
      height = cogl_texture_get_height (COGL_TEXTURE (cogl_tex));
 | 
			
		||||
 | 
			
		||||
@@ -264,6 +271,9 @@ set_cogl_texture (MetaShapedTexture *stex,
 | 
			
		||||
   * know how much of the buffer has changed with respect to the
 | 
			
		||||
   * previous buffer. We only queue a redraw in response to surface
 | 
			
		||||
   * damage. */
 | 
			
		||||
 | 
			
		||||
  if (priv->create_mipmaps)
 | 
			
		||||
    meta_texture_tower_set_base_texture (priv->paint_tower, cogl_tex);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
@@ -279,6 +289,7 @@ meta_shaped_texture_paint (ClutterActor *actor)
 | 
			
		||||
  CoglTexture *paint_tex;
 | 
			
		||||
  ClutterActorBox alloc;
 | 
			
		||||
  cairo_region_t *blended_region = NULL;
 | 
			
		||||
  CoglPipelineFilter filter;
 | 
			
		||||
 | 
			
		||||
  if (priv->clip_region && cairo_region_is_empty (priv->clip_region))
 | 
			
		||||
    return;
 | 
			
		||||
@@ -315,6 +326,15 @@ meta_shaped_texture_paint (ClutterActor *actor)
 | 
			
		||||
  if (tex_width == 0 || tex_height == 0) /* no contents yet */
 | 
			
		||||
    return;
 | 
			
		||||
 | 
			
		||||
  /* Use nearest-pixel interpolation if the texture is unscaled. This
 | 
			
		||||
   * improves performance, especially with software rendering.
 | 
			
		||||
   */
 | 
			
		||||
 | 
			
		||||
  filter = COGL_PIPELINE_FILTER_LINEAR;
 | 
			
		||||
 | 
			
		||||
  if (!clutter_actor_is_in_clone_paint (actor) && meta_actor_is_untransformed (actor, NULL, NULL))
 | 
			
		||||
    filter = COGL_PIPELINE_FILTER_NEAREST;
 | 
			
		||||
 | 
			
		||||
  ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ());
 | 
			
		||||
  fb = cogl_get_draw_framebuffer ();
 | 
			
		||||
 | 
			
		||||
@@ -328,14 +348,22 @@ meta_shaped_texture_paint (ClutterActor *actor)
 | 
			
		||||
      int n_rects;
 | 
			
		||||
      int i;
 | 
			
		||||
 | 
			
		||||
      region = cairo_region_copy (priv->clip_region);
 | 
			
		||||
      cairo_region_intersect (region, priv->opaque_region);
 | 
			
		||||
      if (priv->clip_region != NULL)
 | 
			
		||||
        {
 | 
			
		||||
          region = cairo_region_copy (priv->clip_region);
 | 
			
		||||
          cairo_region_intersect (region, priv->opaque_region);
 | 
			
		||||
        }
 | 
			
		||||
      else
 | 
			
		||||
        {
 | 
			
		||||
          region = cairo_region_reference (priv->opaque_region);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
      if (cairo_region_is_empty (region))
 | 
			
		||||
        goto paint_blended;
 | 
			
		||||
 | 
			
		||||
      opaque_pipeline = get_unblended_pipeline (ctx);
 | 
			
		||||
      cogl_pipeline_set_layer_texture (opaque_pipeline, 0, paint_tex);
 | 
			
		||||
      cogl_pipeline_set_layer_filters (opaque_pipeline, 0, filter, filter);
 | 
			
		||||
 | 
			
		||||
      n_rects = cairo_region_num_rectangles (region);
 | 
			
		||||
      for (i = 0; i < n_rects; i++)
 | 
			
		||||
@@ -377,9 +405,11 @@ meta_shaped_texture_paint (ClutterActor *actor)
 | 
			
		||||
    {
 | 
			
		||||
      pipeline = get_masked_pipeline (ctx);
 | 
			
		||||
      cogl_pipeline_set_layer_texture (pipeline, 1, priv->mask_texture);
 | 
			
		||||
      cogl_pipeline_set_layer_filters (pipeline, 1, filter, filter);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  cogl_pipeline_set_layer_texture (pipeline, 0, paint_tex);
 | 
			
		||||
  cogl_pipeline_set_layer_filters (pipeline, 0, filter, filter);
 | 
			
		||||
 | 
			
		||||
  {
 | 
			
		||||
    CoglColor color;
 | 
			
		||||
@@ -395,7 +425,7 @@ meta_shaped_texture_paint (ClutterActor *actor)
 | 
			
		||||
       * fall back and draw the whole thing */
 | 
			
		||||
#     define MAX_RECTS 16
 | 
			
		||||
 | 
			
		||||
      n_rects = cairo_region_num_rectangles (priv->clip_region);
 | 
			
		||||
      n_rects = cairo_region_num_rectangles (blended_region);
 | 
			
		||||
      if (n_rects <= MAX_RECTS)
 | 
			
		||||
	{
 | 
			
		||||
          int i;
 | 
			
		||||
@@ -405,7 +435,7 @@ meta_shaped_texture_paint (ClutterActor *actor)
 | 
			
		||||
	    {
 | 
			
		||||
	      cairo_rectangle_int_t rect;
 | 
			
		||||
 | 
			
		||||
	      cairo_region_get_rectangle (priv->clip_region, i, &rect);
 | 
			
		||||
	      cairo_region_get_rectangle (blended_region, i, &rect);
 | 
			
		||||
 | 
			
		||||
	      if (!gdk_rectangle_intersect (&tex_rect, &rect, &rect))
 | 
			
		||||
		continue;
 | 
			
		||||
@@ -429,72 +459,6 @@ meta_shaped_texture_paint (ClutterActor *actor)
 | 
			
		||||
    cairo_region_destroy (blended_region);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_shaped_texture_pick (ClutterActor       *actor,
 | 
			
		||||
			  const ClutterColor *color)
 | 
			
		||||
{
 | 
			
		||||
  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->input_shape_region == NULL)
 | 
			
		||||
    CLUTTER_ACTOR_CLASS (meta_shaped_texture_parent_class)->pick (actor, color);
 | 
			
		||||
  else
 | 
			
		||||
    {
 | 
			
		||||
      int n_rects;
 | 
			
		||||
      float *rectangles;
 | 
			
		||||
      int i;
 | 
			
		||||
      ClutterActorBox alloc;
 | 
			
		||||
      CoglPipeline *pipeline;
 | 
			
		||||
      CoglContext *ctx;
 | 
			
		||||
      CoglFramebuffer *fb;
 | 
			
		||||
      CoglColor cogl_color;
 | 
			
		||||
 | 
			
		||||
      /* 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.
 | 
			
		||||
       */
 | 
			
		||||
 | 
			
		||||
      n_rects = cairo_region_num_rectangles (priv->input_shape_region);
 | 
			
		||||
      rectangles = g_alloca (sizeof (float) * 4 * n_rects);
 | 
			
		||||
 | 
			
		||||
      for (i = 0; i < n_rects; i++)
 | 
			
		||||
        {
 | 
			
		||||
          cairo_rectangle_int_t rect;
 | 
			
		||||
          int pos = i * 4;
 | 
			
		||||
 | 
			
		||||
          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 = cogl_pipeline_new (ctx);
 | 
			
		||||
      cogl_pipeline_set_color (pipeline, &cogl_color);
 | 
			
		||||
 | 
			
		||||
      cogl_framebuffer_draw_rectangles (fb, pipeline,
 | 
			
		||||
                                        rectangles, n_rects);
 | 
			
		||||
      cogl_object_unref (pipeline);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_shaped_texture_get_preferred_width (ClutterActor *self,
 | 
			
		||||
                                         gfloat        for_height,
 | 
			
		||||
@@ -534,52 +498,37 @@ meta_shaped_texture_get_preferred_height (ClutterActor *self,
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
meta_shaped_texture_get_paint_volume (ClutterActor *self,
 | 
			
		||||
meta_shaped_texture_get_paint_volume (ClutterActor *actor,
 | 
			
		||||
                                      ClutterPaintVolume *volume)
 | 
			
		||||
{
 | 
			
		||||
  return clutter_paint_volume_set_from_allocation (volume, self);
 | 
			
		||||
}
 | 
			
		||||
  MetaShapedTexture *self = META_SHAPED_TEXTURE (actor);
 | 
			
		||||
  cairo_rectangle_int_t unobscured_bounds;
 | 
			
		||||
 | 
			
		||||
ClutterActor *
 | 
			
		||||
meta_shaped_texture_new_with_wayland_surface (MetaWaylandSurface *surface)
 | 
			
		||||
{
 | 
			
		||||
  ClutterActor *actor = g_object_new (META_TYPE_SHAPED_TEXTURE, NULL);
 | 
			
		||||
  MetaShapedTexturePrivate *priv = META_SHAPED_TEXTURE (actor)->priv;
 | 
			
		||||
  if (!clutter_paint_volume_set_from_allocation (volume, actor))
 | 
			
		||||
    return FALSE;
 | 
			
		||||
 | 
			
		||||
  /* 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;
 | 
			
		||||
  if (meta_shaped_texture_get_unobscured_bounds (self, &unobscured_bounds))
 | 
			
		||||
    {
 | 
			
		||||
      ClutterVertex origin;
 | 
			
		||||
      cairo_rectangle_int_t bounds;
 | 
			
		||||
 | 
			
		||||
  meta_shaped_texture_set_wayland_surface (META_SHAPED_TEXTURE (actor),
 | 
			
		||||
                                           surface);
 | 
			
		||||
      /* I hate ClutterPaintVolume so much... */
 | 
			
		||||
      clutter_paint_volume_get_origin (volume, &origin);
 | 
			
		||||
      bounds.x = origin.x;
 | 
			
		||||
      bounds.y = origin.y;
 | 
			
		||||
      bounds.width = clutter_paint_volume_get_width (volume);
 | 
			
		||||
      bounds.height = clutter_paint_volume_get_height (volume);
 | 
			
		||||
 | 
			
		||||
  return actor;
 | 
			
		||||
}
 | 
			
		||||
      gdk_rectangle_intersect (&bounds, &unobscured_bounds, &bounds);
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_shaped_texture_set_wayland_surface (MetaShapedTexture *stex,
 | 
			
		||||
                                         MetaWaylandSurface *surface)
 | 
			
		||||
{
 | 
			
		||||
  MetaShapedTexturePrivate *priv = stex->priv;
 | 
			
		||||
      origin.x = bounds.x;
 | 
			
		||||
      origin.y = bounds.y;
 | 
			
		||||
      clutter_paint_volume_set_origin (volume, &origin);
 | 
			
		||||
      clutter_paint_volume_set_width (volume, bounds.width);
 | 
			
		||||
      clutter_paint_volume_set_height (volume, bounds.height);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  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);
 | 
			
		||||
  return TRUE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
@@ -624,224 +573,123 @@ 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)
 | 
			
		||||
static cairo_region_t *
 | 
			
		||||
effective_unobscured_region (MetaShapedTexture *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaShapedTexturePrivate *priv;
 | 
			
		||||
  MetaWaylandBuffer *buffer;
 | 
			
		||||
  MetaShapedTexturePrivate *priv = self->priv;
 | 
			
		||||
  ClutterActor *parent = clutter_actor_get_parent (CLUTTER_ACTOR (self));
 | 
			
		||||
 | 
			
		||||
  priv = stex->priv;
 | 
			
		||||
  if (clutter_actor_has_mapped_clones (CLUTTER_ACTOR (self)))
 | 
			
		||||
    return NULL;
 | 
			
		||||
 | 
			
		||||
  g_return_if_fail (priv->type == META_SHAPED_TEXTURE_TYPE_WAYLAND_SURFACE);
 | 
			
		||||
  g_return_if_fail (priv->texture != NULL);
 | 
			
		||||
  while (parent && !META_IS_WINDOW_ACTOR (parent))
 | 
			
		||||
    parent = clutter_actor_get_parent (parent);
 | 
			
		||||
 | 
			
		||||
  buffer = priv->wayland.surface->buffer_ref.buffer;
 | 
			
		||||
  if (parent && clutter_actor_has_mapped_clones (parent))
 | 
			
		||||
    return NULL;
 | 
			
		||||
 | 
			
		||||
  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));
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
  return priv->unobscured_region;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
queue_damage_redraw_with_clip (MetaShapedTexture *stex,
 | 
			
		||||
                               int x,
 | 
			
		||||
                               int y,
 | 
			
		||||
                               int width,
 | 
			
		||||
                               int height)
 | 
			
		||||
gboolean
 | 
			
		||||
meta_shaped_texture_get_unobscured_bounds (MetaShapedTexture     *self,
 | 
			
		||||
                                           cairo_rectangle_int_t *unobscured_bounds)
 | 
			
		||||
{
 | 
			
		||||
  ClutterActor *self = CLUTTER_ACTOR (stex);
 | 
			
		||||
  MetaShapedTexturePrivate *priv;
 | 
			
		||||
  ClutterActorBox allocation;
 | 
			
		||||
  float scale_x;
 | 
			
		||||
  float scale_y;
 | 
			
		||||
  cairo_rectangle_int_t clip;
 | 
			
		||||
  cairo_region_t *unobscured_region = effective_unobscured_region (self);
 | 
			
		||||
 | 
			
		||||
  /* 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))
 | 
			
		||||
  if (unobscured_region)
 | 
			
		||||
    {
 | 
			
		||||
      clutter_actor_queue_redraw (self);
 | 
			
		||||
      return;
 | 
			
		||||
      cairo_region_get_extents (unobscured_region, unobscured_bounds);
 | 
			
		||||
      return TRUE;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  priv = stex->priv;
 | 
			
		||||
 | 
			
		||||
  if (priv->tex_width == 0 || priv->tex_height == 0)
 | 
			
		||||
    return;
 | 
			
		||||
 | 
			
		||||
  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;
 | 
			
		||||
  clutter_actor_queue_redraw_with_clip (self, &clip);
 | 
			
		||||
  else
 | 
			
		||||
    return FALSE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
gboolean
 | 
			
		||||
meta_shaped_texture_is_obscured (MetaShapedTexture *self)
 | 
			
		||||
{
 | 
			
		||||
  cairo_region_t *unobscured_region = effective_unobscured_region (self);
 | 
			
		||||
 | 
			
		||||
  if (unobscured_region)
 | 
			
		||||
    return cairo_region_is_empty (unobscured_region);
 | 
			
		||||
  else
 | 
			
		||||
    return FALSE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * meta_shaped_texture_update_area:
 | 
			
		||||
 * @stex: #MetaShapedTexture
 | 
			
		||||
 * @x: the x coordinate of the damaged area
 | 
			
		||||
 * @y: the y coordinate of the damaged area
 | 
			
		||||
 * @width: the width of the damaged area
 | 
			
		||||
 * @height: the height of the damaged area
 | 
			
		||||
 *
 | 
			
		||||
 * Repairs the damaged area indicated by @x, @y, @width and @height
 | 
			
		||||
 * and potentially queues a redraw.
 | 
			
		||||
 *
 | 
			
		||||
 * Return value: Whether a redraw have been queued or not
 | 
			
		||||
 */
 | 
			
		||||
gboolean
 | 
			
		||||
meta_shaped_texture_update_area (MetaShapedTexture *stex,
 | 
			
		||||
                                 int                x,
 | 
			
		||||
                                 int                y,
 | 
			
		||||
                                 int                width,
 | 
			
		||||
                                 int                height)
 | 
			
		||||
				 int                x,
 | 
			
		||||
				 int                y,
 | 
			
		||||
				 int                width,
 | 
			
		||||
				 int                height)
 | 
			
		||||
{
 | 
			
		||||
  MetaShapedTexturePrivate *priv;
 | 
			
		||||
  cairo_region_t *unobscured_region;
 | 
			
		||||
  const cairo_rectangle_int_t clip = { x, y, width, height };
 | 
			
		||||
 | 
			
		||||
  priv = stex->priv;
 | 
			
		||||
 | 
			
		||||
  if (priv->texture == NULL)
 | 
			
		||||
    return;
 | 
			
		||||
 | 
			
		||||
  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;
 | 
			
		||||
    }
 | 
			
		||||
    return FALSE;
 | 
			
		||||
 | 
			
		||||
  meta_texture_tower_update_area (priv->paint_tower, x, y, width, height);
 | 
			
		||||
 | 
			
		||||
  queue_damage_redraw_with_clip (stex, x, y, width, height);
 | 
			
		||||
  unobscured_region = effective_unobscured_region (stex);
 | 
			
		||||
  if (unobscured_region)
 | 
			
		||||
    {
 | 
			
		||||
      cairo_region_t *intersection;
 | 
			
		||||
 | 
			
		||||
      if (cairo_region_is_empty (unobscured_region))
 | 
			
		||||
        return FALSE;
 | 
			
		||||
 | 
			
		||||
      intersection = cairo_region_copy (unobscured_region);
 | 
			
		||||
      cairo_region_intersect_rectangle (intersection, &clip);
 | 
			
		||||
 | 
			
		||||
      if (!cairo_region_is_empty (intersection))
 | 
			
		||||
        {
 | 
			
		||||
          cairo_rectangle_int_t damage_rect;
 | 
			
		||||
          cairo_region_get_extents (intersection, &damage_rect);
 | 
			
		||||
          clutter_actor_queue_redraw_with_clip (CLUTTER_ACTOR (stex), &damage_rect);
 | 
			
		||||
          cairo_region_destroy (intersection);
 | 
			
		||||
          return TRUE;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
      cairo_region_destroy (intersection);
 | 
			
		||||
      return FALSE;
 | 
			
		||||
    }
 | 
			
		||||
  else
 | 
			
		||||
    {
 | 
			
		||||
      clutter_actor_queue_redraw_with_clip (CLUTTER_ACTOR (stex), &clip);
 | 
			
		||||
      return TRUE;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * meta_shaped_texture_set_pixmap:
 | 
			
		||||
 * meta_shaped_texture_set_texture:
 | 
			
		||||
 * @stex: The #MetaShapedTexture
 | 
			
		||||
 * @pixmap: The pixmap you want the stex to assume
 | 
			
		||||
 * @pixmap: The #CoglTexture to display
 | 
			
		||||
 */
 | 
			
		||||
void
 | 
			
		||||
meta_shaped_texture_set_pixmap (MetaShapedTexture *stex,
 | 
			
		||||
                                Pixmap             pixmap)
 | 
			
		||||
meta_shaped_texture_set_texture (MetaShapedTexture *stex,
 | 
			
		||||
                                 CoglTexture       *texture)
 | 
			
		||||
{
 | 
			
		||||
  MetaShapedTexturePrivate *priv;
 | 
			
		||||
 | 
			
		||||
  g_return_if_fail (META_IS_SHAPED_TEXTURE (stex));
 | 
			
		||||
 | 
			
		||||
  priv = stex->priv;
 | 
			
		||||
 | 
			
		||||
  if (priv->x11.pixmap == pixmap)
 | 
			
		||||
    return;
 | 
			
		||||
 | 
			
		||||
  priv->x11.pixmap = pixmap;
 | 
			
		||||
 | 
			
		||||
  if (pixmap != None)
 | 
			
		||||
    {
 | 
			
		||||
      CoglContext *ctx =
 | 
			
		||||
        clutter_backend_get_cogl_context (clutter_get_default_backend ());
 | 
			
		||||
      CoglTexture *texture =
 | 
			
		||||
        COGL_TEXTURE (cogl_texture_pixmap_x11_new (ctx, pixmap, FALSE, NULL));
 | 
			
		||||
      set_cogl_texture (stex, texture);
 | 
			
		||||
    }
 | 
			
		||||
  else
 | 
			
		||||
    set_cogl_texture (stex, NULL);
 | 
			
		||||
 | 
			
		||||
  if (priv->create_mipmaps)
 | 
			
		||||
    meta_texture_tower_set_base_texture (priv->paint_tower,
 | 
			
		||||
                                         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)
 | 
			
		||||
    {
 | 
			
		||||
      CoglContext *ctx =
 | 
			
		||||
        clutter_backend_get_cogl_context (clutter_get_default_backend ());
 | 
			
		||||
      CoglError *catch_error = NULL;
 | 
			
		||||
      CoglTexture *texture =
 | 
			
		||||
        COGL_TEXTURE (cogl_wayland_texture_2d_new_from_buffer (ctx,
 | 
			
		||||
                                                               buffer->resource,
 | 
			
		||||
                                                               &catch_error));
 | 
			
		||||
      if (!texture)
 | 
			
		||||
        {
 | 
			
		||||
          cogl_error_free (catch_error);
 | 
			
		||||
        }
 | 
			
		||||
      else
 | 
			
		||||
        {
 | 
			
		||||
          buffer->width = cogl_texture_get_width (texture);
 | 
			
		||||
          buffer->height = cogl_texture_get_height (texture);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
      set_cogl_texture (stex, texture);
 | 
			
		||||
    }
 | 
			
		||||
  else
 | 
			
		||||
    set_cogl_texture (stex, NULL);
 | 
			
		||||
 | 
			
		||||
  if (priv->create_mipmaps)
 | 
			
		||||
    meta_texture_tower_set_base_texture (priv->paint_tower,
 | 
			
		||||
                                         COGL_TEXTURE (priv->texture));
 | 
			
		||||
  set_cogl_texture (stex, texture);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
@@ -857,77 +705,6 @@ 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
 | 
			
		||||
 * @clip_region: (transfer full): the region of the texture that
 | 
			
		||||
 *   is visible and should be painted.
 | 
			
		||||
 *
 | 
			
		||||
 * Provides a hint to the texture about what areas of the texture
 | 
			
		||||
 * are not completely obscured and thus need to be painted. This
 | 
			
		||||
 * is an optimization and is not supposed to have any effect on
 | 
			
		||||
 * the output.
 | 
			
		||||
 *
 | 
			
		||||
 * Typically a parent container will set the clip region before
 | 
			
		||||
 * painting its children, and then unset it afterwards.
 | 
			
		||||
 */
 | 
			
		||||
void
 | 
			
		||||
meta_shaped_texture_set_clip_region (MetaShapedTexture *stex,
 | 
			
		||||
				     cairo_region_t    *clip_region)
 | 
			
		||||
{
 | 
			
		||||
  MetaShapedTexturePrivate *priv;
 | 
			
		||||
 | 
			
		||||
  g_return_if_fail (META_IS_SHAPED_TEXTURE (stex));
 | 
			
		||||
 | 
			
		||||
  priv = stex->priv;
 | 
			
		||||
 | 
			
		||||
  if (priv->clip_region)
 | 
			
		||||
    {
 | 
			
		||||
      cairo_region_destroy (priv->clip_region);
 | 
			
		||||
      priv->clip_region = NULL;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  if (clip_region)
 | 
			
		||||
    priv->clip_region = cairo_region_copy (clip_region);
 | 
			
		||||
  else
 | 
			
		||||
    priv->clip_region = NULL;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * meta_shaped_texture_set_opaque_region:
 | 
			
		||||
 * @stex: a #MetaShapedTexture
 | 
			
		||||
@@ -1055,3 +832,46 @@ meta_shaped_texture_get_image (MetaShapedTexture     *stex,
 | 
			
		||||
 | 
			
		||||
  return surface;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_shaped_texture_cull_out (MetaCullable   *cullable,
 | 
			
		||||
                              cairo_region_t *unobscured_region,
 | 
			
		||||
                              cairo_region_t *clip_region)
 | 
			
		||||
{
 | 
			
		||||
  MetaShapedTexture *self = META_SHAPED_TEXTURE (cullable);
 | 
			
		||||
  MetaShapedTexturePrivate *priv = self->priv;
 | 
			
		||||
 | 
			
		||||
  set_unobscured_region (self, unobscured_region);
 | 
			
		||||
  set_clip_region (self, clip_region);
 | 
			
		||||
 | 
			
		||||
  if (clutter_actor_get_paint_opacity (CLUTTER_ACTOR (self)) == 0xff)
 | 
			
		||||
    {
 | 
			
		||||
      if (priv->opaque_region)
 | 
			
		||||
        {
 | 
			
		||||
          if (unobscured_region)
 | 
			
		||||
            cairo_region_subtract (unobscured_region, priv->opaque_region);
 | 
			
		||||
          if (clip_region)
 | 
			
		||||
            cairo_region_subtract (clip_region, priv->opaque_region);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_shaped_texture_reset_culling (MetaCullable *cullable)
 | 
			
		||||
{
 | 
			
		||||
  MetaShapedTexture *self = META_SHAPED_TEXTURE (cullable);
 | 
			
		||||
  set_clip_region (self, NULL);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
cullable_iface_init (MetaCullableInterface *iface)
 | 
			
		||||
{
 | 
			
		||||
  iface->cull_out = meta_shaped_texture_cull_out;
 | 
			
		||||
  iface->reset_culling = meta_shaped_texture_reset_culling;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
ClutterActor *
 | 
			
		||||
meta_shaped_texture_new (void)
 | 
			
		||||
{
 | 
			
		||||
  return g_object_new (META_TYPE_SHAPED_TEXTURE, NULL);
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										165
									
								
								src/compositor/meta-surface-actor-wayland.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										165
									
								
								src/compositor/meta-surface-actor-wayland.c
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,165 @@
 | 
			
		||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright (C) 2013 Red Hat
 | 
			
		||||
 *
 | 
			
		||||
 * 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.
 | 
			
		||||
 *
 | 
			
		||||
 * Written by:
 | 
			
		||||
 *     Jasper St. Pierre <jstpierre@mecheye.net>
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include "config.h"
 | 
			
		||||
 | 
			
		||||
#include "meta-surface-actor-wayland.h"
 | 
			
		||||
 | 
			
		||||
#include <cogl/cogl-wayland-server.h>
 | 
			
		||||
#include "meta-shaped-texture-private.h"
 | 
			
		||||
 | 
			
		||||
#include "wayland/meta-wayland-private.h"
 | 
			
		||||
 | 
			
		||||
struct _MetaSurfaceActorWaylandPrivate
 | 
			
		||||
{
 | 
			
		||||
  MetaWaylandSurface *surface;
 | 
			
		||||
  MetaWaylandBuffer *buffer;
 | 
			
		||||
};
 | 
			
		||||
typedef struct _MetaSurfaceActorWaylandPrivate MetaSurfaceActorWaylandPrivate;
 | 
			
		||||
 | 
			
		||||
G_DEFINE_TYPE_WITH_PRIVATE (MetaSurfaceActorWayland, meta_surface_actor_wayland, META_TYPE_SURFACE_ACTOR)
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_wayland_process_damage (MetaSurfaceActor *actor,
 | 
			
		||||
                                           int x, int y, int width, int height)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorWayland *self = META_SURFACE_ACTOR_WAYLAND (actor);
 | 
			
		||||
  MetaSurfaceActorWaylandPrivate *priv = meta_surface_actor_wayland_get_instance_private (self);
 | 
			
		||||
 | 
			
		||||
  struct wl_resource *resource = priv->buffer->resource;
 | 
			
		||||
  struct wl_shm_buffer *shm_buffer = wl_shm_buffer_get (resource);
 | 
			
		||||
 | 
			
		||||
  if (shm_buffer)
 | 
			
		||||
    {
 | 
			
		||||
      CoglTexture2D *texture = COGL_TEXTURE_2D (priv->buffer->texture);
 | 
			
		||||
      cogl_wayland_texture_set_region_from_shm_buffer (texture, x, y, width, height, shm_buffer, x, y, 0, NULL);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  meta_surface_actor_update_area (META_SURFACE_ACTOR (self), x, y, width, height);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_wayland_pre_paint (MetaSurfaceActor *actor)
 | 
			
		||||
{
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
meta_surface_actor_wayland_is_argb32 (MetaSurfaceActor *actor)
 | 
			
		||||
{
 | 
			
		||||
  /* XXX -- look at the SHM buffer format. */
 | 
			
		||||
  return TRUE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
meta_surface_actor_wayland_is_visible (MetaSurfaceActor *actor)
 | 
			
		||||
{
 | 
			
		||||
  /* TODO: ensure that the buffer isn't NULL, implement
 | 
			
		||||
   * wayland mapping semantics */
 | 
			
		||||
  return TRUE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
meta_surface_actor_wayland_should_unredirect (MetaSurfaceActor *actor)
 | 
			
		||||
{
 | 
			
		||||
  return FALSE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_wayland_set_unredirected (MetaSurfaceActor *actor,
 | 
			
		||||
                                             gboolean          unredirected)
 | 
			
		||||
{
 | 
			
		||||
  /* Do nothing. In the future, we'll use KMS to set this
 | 
			
		||||
   * up as a hardware overlay or something. */
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
meta_surface_actor_wayland_is_unredirected (MetaSurfaceActor *actor)
 | 
			
		||||
{
 | 
			
		||||
  return FALSE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static MetaWindow *
 | 
			
		||||
meta_surface_actor_wayland_get_window (MetaSurfaceActor *actor)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorWaylandPrivate *priv = meta_surface_actor_wayland_get_instance_private (META_SURFACE_ACTOR_WAYLAND (actor));
 | 
			
		||||
 | 
			
		||||
  return priv->surface->window;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_wayland_class_init (MetaSurfaceActorWaylandClass *klass)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorClass *surface_actor_class = META_SURFACE_ACTOR_CLASS (klass);
 | 
			
		||||
 | 
			
		||||
  surface_actor_class->process_damage = meta_surface_actor_wayland_process_damage;
 | 
			
		||||
  surface_actor_class->pre_paint = meta_surface_actor_wayland_pre_paint;
 | 
			
		||||
  surface_actor_class->is_argb32 = meta_surface_actor_wayland_is_argb32;
 | 
			
		||||
  surface_actor_class->is_visible = meta_surface_actor_wayland_is_visible;
 | 
			
		||||
 | 
			
		||||
  surface_actor_class->should_unredirect = meta_surface_actor_wayland_should_unredirect;
 | 
			
		||||
  surface_actor_class->set_unredirected = meta_surface_actor_wayland_set_unredirected;
 | 
			
		||||
  surface_actor_class->is_unredirected = meta_surface_actor_wayland_is_unredirected;
 | 
			
		||||
 | 
			
		||||
  surface_actor_class->get_window = meta_surface_actor_wayland_get_window;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_wayland_init (MetaSurfaceActorWayland *self)
 | 
			
		||||
{
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
MetaSurfaceActor *
 | 
			
		||||
meta_surface_actor_wayland_new (MetaWaylandSurface *surface)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorWayland *self = g_object_new (META_TYPE_SURFACE_ACTOR_WAYLAND, NULL);
 | 
			
		||||
  MetaSurfaceActorWaylandPrivate *priv = meta_surface_actor_wayland_get_instance_private (self);
 | 
			
		||||
 | 
			
		||||
  g_assert (meta_is_wayland_compositor ());
 | 
			
		||||
 | 
			
		||||
  priv->surface = surface;
 | 
			
		||||
 | 
			
		||||
  return META_SURFACE_ACTOR (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_surface_actor_wayland_set_buffer (MetaSurfaceActorWayland *self,
 | 
			
		||||
                                       MetaWaylandBuffer       *buffer)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorWaylandPrivate *priv = meta_surface_actor_wayland_get_instance_private (self);
 | 
			
		||||
  MetaShapedTexture *stex = meta_surface_actor_get_texture (META_SURFACE_ACTOR (self));
 | 
			
		||||
 | 
			
		||||
  priv->buffer = buffer;
 | 
			
		||||
 | 
			
		||||
  if (buffer)
 | 
			
		||||
    meta_shaped_texture_set_texture (stex, buffer->texture);
 | 
			
		||||
  else
 | 
			
		||||
    meta_shaped_texture_set_texture (stex, NULL);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
MetaWaylandSurface *
 | 
			
		||||
meta_surface_actor_wayland_get_surface (MetaSurfaceActorWayland *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorWaylandPrivate *priv = meta_surface_actor_wayland_get_instance_private (self);
 | 
			
		||||
  return priv->surface;
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										66
									
								
								src/compositor/meta-surface-actor-wayland.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								src/compositor/meta-surface-actor-wayland.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,66 @@
 | 
			
		||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright (C) 2013 Red Hat
 | 
			
		||||
 *
 | 
			
		||||
 * 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.
 | 
			
		||||
 *
 | 
			
		||||
 * Written by:
 | 
			
		||||
 *     Jasper St. Pierre <jstpierre@mecheye.net>
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef __META_SURFACE_ACTOR_WAYLAND_H__
 | 
			
		||||
#define __META_SURFACE_ACTOR_WAYLAND_H__
 | 
			
		||||
 | 
			
		||||
#include <glib-object.h>
 | 
			
		||||
 | 
			
		||||
#include "meta-surface-actor.h"
 | 
			
		||||
 | 
			
		||||
#include "wayland/meta-wayland.h"
 | 
			
		||||
 | 
			
		||||
G_BEGIN_DECLS
 | 
			
		||||
 | 
			
		||||
#define META_TYPE_SURFACE_ACTOR_WAYLAND            (meta_surface_actor_wayland_get_type ())
 | 
			
		||||
#define META_SURFACE_ACTOR_WAYLAND(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_SURFACE_ACTOR_WAYLAND, MetaSurfaceActorWayland))
 | 
			
		||||
#define META_SURFACE_ACTOR_WAYLAND_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass),  META_TYPE_SURFACE_ACTOR_WAYLAND, MetaSurfaceActorWaylandClass))
 | 
			
		||||
#define META_IS_SURFACE_ACTOR_WAYLAND(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_SURFACE_ACTOR_WAYLAND))
 | 
			
		||||
#define META_IS_SURFACE_ACTOR_WAYLAND_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass),  META_TYPE_SURFACE_ACTOR_WAYLAND))
 | 
			
		||||
#define META_SURFACE_ACTOR_WAYLAND_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj),  META_TYPE_SURFACE_ACTOR_WAYLAND, MetaSurfaceActorWaylandClass))
 | 
			
		||||
 | 
			
		||||
typedef struct _MetaSurfaceActorWayland      MetaSurfaceActorWayland;
 | 
			
		||||
typedef struct _MetaSurfaceActorWaylandClass MetaSurfaceActorWaylandClass;
 | 
			
		||||
 | 
			
		||||
struct _MetaSurfaceActorWayland
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActor parent;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
struct _MetaSurfaceActorWaylandClass
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorClass parent_class;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
GType meta_surface_actor_wayland_get_type (void);
 | 
			
		||||
 | 
			
		||||
MetaSurfaceActor * meta_surface_actor_wayland_new (MetaWaylandSurface *surface);
 | 
			
		||||
MetaWaylandSurface * meta_surface_actor_wayland_get_surface (MetaSurfaceActorWayland *self);
 | 
			
		||||
 | 
			
		||||
void meta_surface_actor_wayland_set_buffer (MetaSurfaceActorWayland *self,
 | 
			
		||||
                                            MetaWaylandBuffer         *buffer);
 | 
			
		||||
 | 
			
		||||
G_END_DECLS
 | 
			
		||||
 | 
			
		||||
#endif /* __META_SURFACE_ACTOR_WAYLAND_H__ */
 | 
			
		||||
							
								
								
									
										486
									
								
								src/compositor/meta-surface-actor-x11.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										486
									
								
								src/compositor/meta-surface-actor-x11.c
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,486 @@
 | 
			
		||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright (C) 2013 Red Hat
 | 
			
		||||
 *
 | 
			
		||||
 * 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.
 | 
			
		||||
 *
 | 
			
		||||
 * Written by:
 | 
			
		||||
 *     Owen Taylor <otaylor@redhat.com>
 | 
			
		||||
 *     Jasper St. Pierre <jstpierre@mecheye.net>
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include "config.h"
 | 
			
		||||
 | 
			
		||||
#include "meta-surface-actor-x11.h"
 | 
			
		||||
 | 
			
		||||
#include <X11/extensions/Xcomposite.h>
 | 
			
		||||
#include <X11/extensions/Xrender.h>
 | 
			
		||||
#include <cogl/cogl-texture-pixmap-x11.h>
 | 
			
		||||
 | 
			
		||||
#include <meta/errors.h>
 | 
			
		||||
#include "window-private.h"
 | 
			
		||||
#include "meta-shaped-texture-private.h"
 | 
			
		||||
#include "meta-cullable.h"
 | 
			
		||||
 | 
			
		||||
struct _MetaSurfaceActorX11Private
 | 
			
		||||
{
 | 
			
		||||
  MetaWindow *window;
 | 
			
		||||
 | 
			
		||||
  MetaDisplay *display;
 | 
			
		||||
 | 
			
		||||
  CoglTexture *texture;
 | 
			
		||||
  Pixmap pixmap;
 | 
			
		||||
  Damage damage;
 | 
			
		||||
 | 
			
		||||
  int last_width;
 | 
			
		||||
  int last_height;
 | 
			
		||||
 | 
			
		||||
  /* This is used to detect fullscreen windows that need to be unredirected */
 | 
			
		||||
  guint full_damage_frames_count;
 | 
			
		||||
  guint does_full_damage  : 1;
 | 
			
		||||
 | 
			
		||||
  /* Other state... */
 | 
			
		||||
  guint argb32 : 1;
 | 
			
		||||
  guint received_damage : 1;
 | 
			
		||||
  guint size_changed : 1;
 | 
			
		||||
 | 
			
		||||
  guint unredirected   : 1;
 | 
			
		||||
};
 | 
			
		||||
typedef struct _MetaSurfaceActorX11Private MetaSurfaceActorX11Private;
 | 
			
		||||
 | 
			
		||||
G_DEFINE_TYPE_WITH_PRIVATE (MetaSurfaceActorX11, meta_surface_actor_x11, META_TYPE_SURFACE_ACTOR)
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
free_damage (MetaSurfaceActorX11 *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
  MetaDisplay *display = priv->display;
 | 
			
		||||
  Display *xdisplay = meta_display_get_xdisplay (display);
 | 
			
		||||
 | 
			
		||||
  if (priv->damage == None)
 | 
			
		||||
    return;
 | 
			
		||||
 | 
			
		||||
  meta_error_trap_push (display);
 | 
			
		||||
  XDamageDestroy (xdisplay, priv->damage);
 | 
			
		||||
  priv->damage = None;
 | 
			
		||||
  meta_error_trap_pop (display);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
detach_pixmap (MetaSurfaceActorX11 *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
  MetaDisplay *display = priv->display;
 | 
			
		||||
  Display *xdisplay = meta_display_get_xdisplay (display);
 | 
			
		||||
  MetaShapedTexture *stex = meta_surface_actor_get_texture (META_SURFACE_ACTOR (self));
 | 
			
		||||
 | 
			
		||||
  if (priv->pixmap == None)
 | 
			
		||||
    return;
 | 
			
		||||
 | 
			
		||||
  /* Get rid of all references to the pixmap before freeing it; it's unclear whether
 | 
			
		||||
   * you are supposed to be able to free a GLXPixmap after freeing the underlying
 | 
			
		||||
   * pixmap, but it certainly doesn't work with current DRI/Mesa
 | 
			
		||||
   */
 | 
			
		||||
  meta_shaped_texture_set_texture (stex, NULL);
 | 
			
		||||
  cogl_flush ();
 | 
			
		||||
 | 
			
		||||
  meta_error_trap_push (display);
 | 
			
		||||
  XFreePixmap (xdisplay, priv->pixmap);
 | 
			
		||||
  priv->pixmap = None;
 | 
			
		||||
  meta_error_trap_pop (display);
 | 
			
		||||
 | 
			
		||||
  cogl_object_unref (priv->texture);
 | 
			
		||||
  priv->texture = NULL;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
set_pixmap (MetaSurfaceActorX11 *self,
 | 
			
		||||
            Pixmap               pixmap)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
 | 
			
		||||
  CoglContext *ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ());
 | 
			
		||||
  MetaShapedTexture *stex = meta_surface_actor_get_texture (META_SURFACE_ACTOR (self));
 | 
			
		||||
  CoglTexture *texture;
 | 
			
		||||
 | 
			
		||||
  g_assert (priv->pixmap == None);
 | 
			
		||||
  priv->pixmap = pixmap;
 | 
			
		||||
 | 
			
		||||
  texture = COGL_TEXTURE (cogl_texture_pixmap_x11_new (ctx, priv->pixmap, FALSE, NULL));
 | 
			
		||||
 | 
			
		||||
  if (G_UNLIKELY (!cogl_texture_pixmap_x11_is_using_tfp_extension (COGL_TEXTURE_PIXMAP_X11 (texture))))
 | 
			
		||||
    g_warning ("NOTE: Not using GLX TFP!\n");
 | 
			
		||||
 | 
			
		||||
  priv->texture = texture;
 | 
			
		||||
  meta_shaped_texture_set_texture (stex, texture);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
update_pixmap (MetaSurfaceActorX11 *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
  MetaDisplay *display = priv->display;
 | 
			
		||||
  Display *xdisplay = meta_display_get_xdisplay (display);
 | 
			
		||||
 | 
			
		||||
  if (priv->size_changed)
 | 
			
		||||
    {
 | 
			
		||||
      detach_pixmap (self);
 | 
			
		||||
      priv->size_changed = FALSE;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  if (priv->pixmap == None)
 | 
			
		||||
    {
 | 
			
		||||
      Pixmap new_pixmap;
 | 
			
		||||
      Window xwindow = meta_window_get_toplevel_xwindow (priv->window);
 | 
			
		||||
 | 
			
		||||
      meta_error_trap_push (display);
 | 
			
		||||
      new_pixmap = XCompositeNameWindowPixmap (xdisplay, xwindow);
 | 
			
		||||
 | 
			
		||||
      if (meta_error_trap_pop_with_return (display) != Success)
 | 
			
		||||
        {
 | 
			
		||||
          /* Probably a BadMatch if the window isn't viewable; we could
 | 
			
		||||
           * GrabServer/GetWindowAttributes/NameWindowPixmap/UngrabServer/Sync
 | 
			
		||||
           * to avoid this, but there's no reason to take two round trips
 | 
			
		||||
           * when one will do. (We need that Sync if we want to handle failures
 | 
			
		||||
           * for any reason other than !viewable. That's unlikely, but maybe
 | 
			
		||||
           * we'll BadAlloc or something.)
 | 
			
		||||
           */
 | 
			
		||||
          new_pixmap = None;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
      if (new_pixmap == None)
 | 
			
		||||
        {
 | 
			
		||||
          meta_verbose ("Unable to get named pixmap for %s\n",
 | 
			
		||||
                        meta_window_get_description (priv->window));
 | 
			
		||||
          return;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
      set_pixmap (self, new_pixmap);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
is_visible (MetaSurfaceActorX11 *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
  return (priv->pixmap != None) && !priv->unredirected;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
damage_area (MetaSurfaceActorX11 *self,
 | 
			
		||||
             int x, int y, int width, int height)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
 | 
			
		||||
  if (!is_visible (self))
 | 
			
		||||
    return;
 | 
			
		||||
 | 
			
		||||
  cogl_texture_pixmap_x11_update_area (priv->texture, x, y, width, height);
 | 
			
		||||
  meta_surface_actor_update_area (META_SURFACE_ACTOR (self), x, y, width, height);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_x11_process_damage (MetaSurfaceActor *actor,
 | 
			
		||||
                                       int x, int y, int width, int height)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11 *self = META_SURFACE_ACTOR_X11 (actor);
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
 | 
			
		||||
  priv->received_damage = TRUE;
 | 
			
		||||
 | 
			
		||||
  if (meta_window_is_fullscreen (priv->window) && !priv->unredirected && !priv->does_full_damage)
 | 
			
		||||
    {
 | 
			
		||||
      MetaRectangle window_rect;
 | 
			
		||||
      meta_window_get_frame_rect (priv->window, &window_rect);
 | 
			
		||||
 | 
			
		||||
      if (window_rect.x == x &&
 | 
			
		||||
          window_rect.y == y &&
 | 
			
		||||
          window_rect.width == width &&
 | 
			
		||||
          window_rect.height == height)
 | 
			
		||||
        priv->full_damage_frames_count++;
 | 
			
		||||
      else
 | 
			
		||||
        priv->full_damage_frames_count = 0;
 | 
			
		||||
 | 
			
		||||
      if (priv->full_damage_frames_count >= 100)
 | 
			
		||||
        priv->does_full_damage = TRUE;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  /* Drop damage event for unredirected windows */
 | 
			
		||||
  if (priv->unredirected)
 | 
			
		||||
    return;
 | 
			
		||||
 | 
			
		||||
  damage_area (self, x, y, width, height);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_x11_pre_paint (MetaSurfaceActor *actor)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11 *self = META_SURFACE_ACTOR_X11 (actor);
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
  MetaDisplay *display = priv->display;
 | 
			
		||||
  Display *xdisplay = meta_display_get_xdisplay (display);
 | 
			
		||||
 | 
			
		||||
  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;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  update_pixmap (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
update_is_argb32 (MetaSurfaceActorX11 *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
  MetaDisplay *display = priv->display;
 | 
			
		||||
  Display *xdisplay = meta_display_get_xdisplay (display);
 | 
			
		||||
 | 
			
		||||
  XRenderPictFormat *format;
 | 
			
		||||
  format = XRenderFindVisualFormat (xdisplay, priv->window->xvisual);
 | 
			
		||||
 | 
			
		||||
  priv->argb32 = (format && format->type == PictTypeDirect && format->direct.alphaMask);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
meta_surface_actor_x11_is_argb32 (MetaSurfaceActor *actor)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11 *self = META_SURFACE_ACTOR_X11 (actor);
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
 | 
			
		||||
  return priv->argb32;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
meta_surface_actor_x11_is_visible (MetaSurfaceActor *actor)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11 *self = META_SURFACE_ACTOR_X11 (actor);
 | 
			
		||||
  return is_visible (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
meta_surface_actor_x11_should_unredirect (MetaSurfaceActor *actor)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11 *self = META_SURFACE_ACTOR_X11 (actor);
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
 | 
			
		||||
  MetaWindow *window = priv->window;
 | 
			
		||||
 | 
			
		||||
  if (meta_window_requested_dont_bypass_compositor (window))
 | 
			
		||||
    return FALSE;
 | 
			
		||||
 | 
			
		||||
  if (window->opacity != 0xFF)
 | 
			
		||||
    return FALSE;
 | 
			
		||||
 | 
			
		||||
  if (window->shape_region != NULL)
 | 
			
		||||
    return FALSE;
 | 
			
		||||
 | 
			
		||||
  if (priv->argb32 && !meta_window_requested_bypass_compositor (window))
 | 
			
		||||
    return FALSE;
 | 
			
		||||
 | 
			
		||||
  if (!meta_window_is_monitor_sized (window))
 | 
			
		||||
    return FALSE;
 | 
			
		||||
 | 
			
		||||
  if (meta_window_requested_bypass_compositor (window))
 | 
			
		||||
    return TRUE;
 | 
			
		||||
 | 
			
		||||
  if (meta_window_is_override_redirect (window))
 | 
			
		||||
    return TRUE;
 | 
			
		||||
 | 
			
		||||
  if (priv->does_full_damage)
 | 
			
		||||
    return TRUE;
 | 
			
		||||
 | 
			
		||||
  return FALSE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
sync_unredirected (MetaSurfaceActorX11 *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
  MetaDisplay *display = priv->display;
 | 
			
		||||
  Display *xdisplay = meta_display_get_xdisplay (display);
 | 
			
		||||
  Window xwindow = meta_window_get_toplevel_xwindow (priv->window);
 | 
			
		||||
 | 
			
		||||
  meta_error_trap_push (display);
 | 
			
		||||
 | 
			
		||||
  if (priv->unredirected)
 | 
			
		||||
    {
 | 
			
		||||
      detach_pixmap (self);
 | 
			
		||||
      XCompositeUnredirectWindow (xdisplay, xwindow, CompositeRedirectManual);
 | 
			
		||||
    }
 | 
			
		||||
  else
 | 
			
		||||
    {
 | 
			
		||||
      XCompositeRedirectWindow (xdisplay, xwindow, CompositeRedirectManual);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  meta_error_trap_pop (display);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_x11_set_unredirected (MetaSurfaceActor *actor,
 | 
			
		||||
                                         gboolean          unredirected)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11 *self = META_SURFACE_ACTOR_X11 (actor);
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
 | 
			
		||||
  if (priv->unredirected == unredirected)
 | 
			
		||||
    return;
 | 
			
		||||
 | 
			
		||||
  priv->unredirected = unredirected;
 | 
			
		||||
  sync_unredirected (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
meta_surface_actor_x11_is_unredirected (MetaSurfaceActor *actor)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11 *self = META_SURFACE_ACTOR_X11 (actor);
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
 | 
			
		||||
  return priv->unredirected;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_x11_dispose (GObject *object)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11 *self = META_SURFACE_ACTOR_X11 (object);
 | 
			
		||||
 | 
			
		||||
  detach_pixmap (self);
 | 
			
		||||
  free_damage (self);
 | 
			
		||||
 | 
			
		||||
  G_OBJECT_CLASS (meta_surface_actor_x11_parent_class)->dispose (object);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static MetaWindow *
 | 
			
		||||
meta_surface_actor_x11_get_window (MetaSurfaceActor *actor)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (META_SURFACE_ACTOR_X11 (actor));
 | 
			
		||||
 | 
			
		||||
  return priv->window;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_x11_class_init (MetaSurfaceActorX11Class *klass)
 | 
			
		||||
{
 | 
			
		||||
  GObjectClass *object_class = G_OBJECT_CLASS (klass);
 | 
			
		||||
  MetaSurfaceActorClass *surface_actor_class = META_SURFACE_ACTOR_CLASS (klass);
 | 
			
		||||
 | 
			
		||||
  object_class->dispose = meta_surface_actor_x11_dispose;
 | 
			
		||||
 | 
			
		||||
  surface_actor_class->process_damage = meta_surface_actor_x11_process_damage;
 | 
			
		||||
  surface_actor_class->pre_paint = meta_surface_actor_x11_pre_paint;
 | 
			
		||||
  surface_actor_class->is_argb32 = meta_surface_actor_x11_is_argb32;
 | 
			
		||||
  surface_actor_class->is_visible = meta_surface_actor_x11_is_visible;
 | 
			
		||||
 | 
			
		||||
  surface_actor_class->should_unredirect = meta_surface_actor_x11_should_unredirect;
 | 
			
		||||
  surface_actor_class->set_unredirected = meta_surface_actor_x11_set_unredirected;
 | 
			
		||||
  surface_actor_class->is_unredirected = meta_surface_actor_x11_is_unredirected;
 | 
			
		||||
 | 
			
		||||
  surface_actor_class->get_window = meta_surface_actor_x11_get_window;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_x11_init (MetaSurfaceActorX11 *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
 | 
			
		||||
  priv->last_width = -1;
 | 
			
		||||
  priv->last_height = -1;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
create_damage (MetaSurfaceActorX11 *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
  Display *xdisplay = meta_display_get_xdisplay (priv->display);
 | 
			
		||||
  Window xwindow = meta_window_get_toplevel_xwindow (priv->window);
 | 
			
		||||
 | 
			
		||||
  priv->damage = XDamageCreate (xdisplay, xwindow, XDamageReportBoundingBox);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
window_decorated_notify (MetaWindow *window,
 | 
			
		||||
                         GParamSpec *pspec,
 | 
			
		||||
                         gpointer    user_data)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11 *self = META_SURFACE_ACTOR_X11 (user_data);
 | 
			
		||||
 | 
			
		||||
  free_damage (self);
 | 
			
		||||
  create_damage (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
MetaSurfaceActor *
 | 
			
		||||
meta_surface_actor_x11_new (MetaWindow *window)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11 *self = g_object_new (META_TYPE_SURFACE_ACTOR_X11, NULL);
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
  MetaDisplay *display = meta_window_get_display (window);
 | 
			
		||||
 | 
			
		||||
  g_assert (!meta_is_wayland_compositor ());
 | 
			
		||||
 | 
			
		||||
  priv->window = window;
 | 
			
		||||
  priv->display = display;
 | 
			
		||||
 | 
			
		||||
  create_damage (self);
 | 
			
		||||
  g_signal_connect_object (priv->window, "notify::decorated",
 | 
			
		||||
                           G_CALLBACK (window_decorated_notify), self, 0);
 | 
			
		||||
 | 
			
		||||
  update_is_argb32 (self);
 | 
			
		||||
 | 
			
		||||
  priv->unredirected = FALSE;
 | 
			
		||||
  sync_unredirected (self);
 | 
			
		||||
 | 
			
		||||
  clutter_actor_set_reactive (CLUTTER_ACTOR (self), TRUE);
 | 
			
		||||
  return META_SURFACE_ACTOR (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_surface_actor_x11_set_size (MetaSurfaceActorX11 *self,
 | 
			
		||||
                                 int width, int height)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorX11Private *priv = meta_surface_actor_x11_get_instance_private (self);
 | 
			
		||||
 | 
			
		||||
  if (priv->last_width == width &&
 | 
			
		||||
      priv->last_height == height)
 | 
			
		||||
    return;
 | 
			
		||||
 | 
			
		||||
  priv->size_changed = TRUE;
 | 
			
		||||
  priv->last_width = width;
 | 
			
		||||
  priv->last_height = height;
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										69
									
								
								src/compositor/meta-surface-actor-x11.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								src/compositor/meta-surface-actor-x11.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,69 @@
 | 
			
		||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright (C) 2013 Red Hat
 | 
			
		||||
 *
 | 
			
		||||
 * 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.
 | 
			
		||||
 *
 | 
			
		||||
 * Written by:
 | 
			
		||||
 *     Owen Taylor <otaylor@redhat.com>
 | 
			
		||||
 *     Jasper St. Pierre <jstpierre@mecheye.net>
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef __META_SURFACE_ACTOR_X11_H__
 | 
			
		||||
#define __META_SURFACE_ACTOR_X11_H__
 | 
			
		||||
 | 
			
		||||
#include <glib-object.h>
 | 
			
		||||
 | 
			
		||||
#include "meta-surface-actor.h"
 | 
			
		||||
 | 
			
		||||
#include <X11/extensions/Xdamage.h>
 | 
			
		||||
 | 
			
		||||
#include <meta/display.h>
 | 
			
		||||
#include <meta/window.h>
 | 
			
		||||
 | 
			
		||||
G_BEGIN_DECLS
 | 
			
		||||
 | 
			
		||||
#define META_TYPE_SURFACE_ACTOR_X11            (meta_surface_actor_x11_get_type ())
 | 
			
		||||
#define META_SURFACE_ACTOR_X11(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_SURFACE_ACTOR_X11, MetaSurfaceActorX11))
 | 
			
		||||
#define META_SURFACE_ACTOR_X11_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass),  META_TYPE_SURFACE_ACTOR_X11, MetaSurfaceActorX11Class))
 | 
			
		||||
#define META_IS_SURFACE_ACTOR_X11(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_SURFACE_ACTOR_X11))
 | 
			
		||||
#define META_IS_SURFACE_ACTOR_X11_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass),  META_TYPE_SURFACE_ACTOR_X11))
 | 
			
		||||
#define META_SURFACE_ACTOR_X11_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj),  META_TYPE_SURFACE_ACTOR_X11, MetaSurfaceActorX11Class))
 | 
			
		||||
 | 
			
		||||
typedef struct _MetaSurfaceActorX11      MetaSurfaceActorX11;
 | 
			
		||||
typedef struct _MetaSurfaceActorX11Class MetaSurfaceActorX11Class;
 | 
			
		||||
 | 
			
		||||
struct _MetaSurfaceActorX11
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActor parent;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
struct _MetaSurfaceActorX11Class
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorClass parent_class;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
GType meta_surface_actor_x11_get_type (void);
 | 
			
		||||
 | 
			
		||||
MetaSurfaceActor * meta_surface_actor_x11_new (MetaWindow *window);
 | 
			
		||||
 | 
			
		||||
void meta_surface_actor_x11_set_size (MetaSurfaceActorX11 *self,
 | 
			
		||||
                                      int width, int height);
 | 
			
		||||
 | 
			
		||||
G_END_DECLS
 | 
			
		||||
 | 
			
		||||
#endif /* __META_SURFACE_ACTOR_X11_H__ */
 | 
			
		||||
							
								
								
									
										319
									
								
								src/compositor/meta-surface-actor.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										319
									
								
								src/compositor/meta-surface-actor.c
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,319 @@
 | 
			
		||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * SECTION:meta-surface-actor
 | 
			
		||||
 * @title: MetaSurfaceActor
 | 
			
		||||
 * @short_description: An actor representing a surface in the scene graph
 | 
			
		||||
 *
 | 
			
		||||
 * A surface can be either a shaped texture, or a group of shaped texture,
 | 
			
		||||
 * used to draw the content of a window.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <config.h>
 | 
			
		||||
 | 
			
		||||
#include "meta-surface-actor.h"
 | 
			
		||||
 | 
			
		||||
#include <clutter/clutter.h>
 | 
			
		||||
#include <meta/meta-shaped-texture.h>
 | 
			
		||||
#include "meta-cullable.h"
 | 
			
		||||
#include "meta-shaped-texture-private.h"
 | 
			
		||||
 | 
			
		||||
struct _MetaSurfaceActorPrivate
 | 
			
		||||
{
 | 
			
		||||
  MetaShapedTexture *texture;
 | 
			
		||||
 | 
			
		||||
  cairo_region_t *input_region;
 | 
			
		||||
 | 
			
		||||
  /* Freeze/thaw accounting */
 | 
			
		||||
  guint needs_damage_all : 1;
 | 
			
		||||
  guint frozen : 1;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
static void cullable_iface_init (MetaCullableInterface *iface);
 | 
			
		||||
 | 
			
		||||
G_DEFINE_ABSTRACT_TYPE_WITH_CODE (MetaSurfaceActor, meta_surface_actor, CLUTTER_TYPE_ACTOR,
 | 
			
		||||
                                  G_IMPLEMENT_INTERFACE (META_TYPE_CULLABLE, cullable_iface_init));
 | 
			
		||||
 | 
			
		||||
enum {
 | 
			
		||||
  REPAINT_SCHEDULED,
 | 
			
		||||
 | 
			
		||||
  LAST_SIGNAL,
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
static guint signals[LAST_SIGNAL];
 | 
			
		||||
 | 
			
		||||
gboolean
 | 
			
		||||
meta_surface_actor_get_unobscured_bounds (MetaSurfaceActor      *self,
 | 
			
		||||
                                          cairo_rectangle_int_t *unobscured_bounds)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorPrivate *priv = self->priv;
 | 
			
		||||
  return meta_shaped_texture_get_unobscured_bounds (priv->texture, unobscured_bounds);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_pick (ClutterActor       *actor,
 | 
			
		||||
                         const ClutterColor *color)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActor *self = META_SURFACE_ACTOR (actor);
 | 
			
		||||
  MetaSurfaceActorPrivate *priv = self->priv;
 | 
			
		||||
 | 
			
		||||
  if (!clutter_actor_should_pick_paint (actor))
 | 
			
		||||
    return;
 | 
			
		||||
 | 
			
		||||
  /* If there is no region then use the regular pick */
 | 
			
		||||
  if (priv->input_region == NULL)
 | 
			
		||||
    CLUTTER_ACTOR_CLASS (meta_surface_actor_parent_class)->pick (actor, color);
 | 
			
		||||
  else
 | 
			
		||||
    {
 | 
			
		||||
      int n_rects;
 | 
			
		||||
      float *rectangles;
 | 
			
		||||
      int i;
 | 
			
		||||
      CoglPipeline *pipeline;
 | 
			
		||||
      CoglContext *ctx;
 | 
			
		||||
      CoglFramebuffer *fb;
 | 
			
		||||
      CoglColor cogl_color;
 | 
			
		||||
 | 
			
		||||
      n_rects = cairo_region_num_rectangles (priv->input_region);
 | 
			
		||||
      rectangles = g_alloca (sizeof (float) * 4 * n_rects);
 | 
			
		||||
 | 
			
		||||
      for (i = 0; i < n_rects; i++)
 | 
			
		||||
        {
 | 
			
		||||
          cairo_rectangle_int_t rect;
 | 
			
		||||
          int pos = i * 4;
 | 
			
		||||
 | 
			
		||||
          cairo_region_get_rectangle (priv->input_region, i, &rect);
 | 
			
		||||
 | 
			
		||||
          rectangles[pos + 0] = 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 = cogl_pipeline_new (ctx);
 | 
			
		||||
      cogl_pipeline_set_color (pipeline, &cogl_color);
 | 
			
		||||
      cogl_framebuffer_draw_rectangles (fb, pipeline, rectangles, n_rects);
 | 
			
		||||
      cogl_object_unref (pipeline);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_dispose (GObject *object)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActor *self = META_SURFACE_ACTOR (object);
 | 
			
		||||
  MetaSurfaceActorPrivate *priv = self->priv;
 | 
			
		||||
 | 
			
		||||
  g_clear_pointer (&priv->input_region, cairo_region_destroy);
 | 
			
		||||
 | 
			
		||||
  G_OBJECT_CLASS (meta_surface_actor_parent_class)->dispose (object);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_class_init (MetaSurfaceActorClass *klass)
 | 
			
		||||
{
 | 
			
		||||
  GObjectClass *object_class = G_OBJECT_CLASS (klass);
 | 
			
		||||
  ClutterActorClass *actor_class = CLUTTER_ACTOR_CLASS (klass);
 | 
			
		||||
 | 
			
		||||
  object_class->dispose = meta_surface_actor_dispose;
 | 
			
		||||
  actor_class->pick = meta_surface_actor_pick;
 | 
			
		||||
 | 
			
		||||
  signals[REPAINT_SCHEDULED] = g_signal_new ("repaint-scheduled",
 | 
			
		||||
                                             G_TYPE_FROM_CLASS (object_class),
 | 
			
		||||
                                             G_SIGNAL_RUN_LAST,
 | 
			
		||||
                                             0,
 | 
			
		||||
                                             NULL, NULL, NULL,
 | 
			
		||||
                                             G_TYPE_NONE, 0);
 | 
			
		||||
 | 
			
		||||
  g_type_class_add_private (klass, sizeof (MetaSurfaceActorPrivate));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_cull_out (MetaCullable   *cullable,
 | 
			
		||||
                             cairo_region_t *unobscured_region,
 | 
			
		||||
                             cairo_region_t *clip_region)
 | 
			
		||||
{
 | 
			
		||||
  meta_cullable_cull_out_children (cullable, unobscured_region, clip_region);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_reset_culling (MetaCullable *cullable)
 | 
			
		||||
{
 | 
			
		||||
  meta_cullable_reset_culling_children (cullable);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
cullable_iface_init (MetaCullableInterface *iface)
 | 
			
		||||
{
 | 
			
		||||
  iface->cull_out = meta_surface_actor_cull_out;
 | 
			
		||||
  iface->reset_culling = meta_surface_actor_reset_culling;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_surface_actor_init (MetaSurfaceActor *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorPrivate *priv;
 | 
			
		||||
 | 
			
		||||
  priv = self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self,
 | 
			
		||||
                                                   META_TYPE_SURFACE_ACTOR,
 | 
			
		||||
                                                   MetaSurfaceActorPrivate);
 | 
			
		||||
 | 
			
		||||
  priv->texture = META_SHAPED_TEXTURE (meta_shaped_texture_new ());
 | 
			
		||||
  clutter_actor_add_child (CLUTTER_ACTOR (self), CLUTTER_ACTOR (priv->texture));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
cairo_surface_t *
 | 
			
		||||
meta_surface_actor_get_image (MetaSurfaceActor      *self,
 | 
			
		||||
                              cairo_rectangle_int_t *clip)
 | 
			
		||||
{
 | 
			
		||||
  return meta_shaped_texture_get_image (self->priv->texture, clip);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
MetaShapedTexture *
 | 
			
		||||
meta_surface_actor_get_texture (MetaSurfaceActor *self)
 | 
			
		||||
{
 | 
			
		||||
  return self->priv->texture;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_surface_actor_update_area (MetaSurfaceActor *self,
 | 
			
		||||
                                int x, int y, int width, int height)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorPrivate *priv = self->priv;
 | 
			
		||||
 | 
			
		||||
  if (meta_shaped_texture_update_area (priv->texture, x, y, width, height))
 | 
			
		||||
    g_signal_emit (self, signals[REPAINT_SCHEDULED], 0);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
gboolean
 | 
			
		||||
meta_surface_actor_is_obscured (MetaSurfaceActor *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorPrivate *priv = self->priv;
 | 
			
		||||
  return meta_shaped_texture_is_obscured (priv->texture);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_surface_actor_set_input_region (MetaSurfaceActor *self,
 | 
			
		||||
                                     cairo_region_t   *region)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorPrivate *priv = self->priv;
 | 
			
		||||
 | 
			
		||||
  if (priv->input_region)
 | 
			
		||||
    cairo_region_destroy (priv->input_region);
 | 
			
		||||
 | 
			
		||||
  if (region)
 | 
			
		||||
    priv->input_region = cairo_region_reference (region);
 | 
			
		||||
  else
 | 
			
		||||
    priv->input_region = NULL;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_surface_actor_set_opaque_region (MetaSurfaceActor *self,
 | 
			
		||||
                                      cairo_region_t   *region)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorPrivate *priv = self->priv;
 | 
			
		||||
  meta_shaped_texture_set_opaque_region (priv->texture, region);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
is_frozen (MetaSurfaceActor *self)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorPrivate *priv = self->priv;
 | 
			
		||||
  return priv->frozen;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_surface_actor_process_damage (MetaSurfaceActor *self,
 | 
			
		||||
                                   int x, int y, int width, int height)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorPrivate *priv = self->priv;
 | 
			
		||||
 | 
			
		||||
  if (is_frozen (self))
 | 
			
		||||
    {
 | 
			
		||||
      /* The window is frozen due to an effect in progress: we ignore damage
 | 
			
		||||
       * here on the off chance that this will stop the corresponding
 | 
			
		||||
       * texture_from_pixmap from being update.
 | 
			
		||||
       *
 | 
			
		||||
       * needs_damage_all tracks that some unknown damage happened while the
 | 
			
		||||
       * window was frozen so that when the window becomes unfrozen we can
 | 
			
		||||
       * issue a full window update to cover any lost damage.
 | 
			
		||||
       *
 | 
			
		||||
       * It should be noted that this is an unreliable mechanism since it's
 | 
			
		||||
       * quite likely that drivers will aim to provide a zero-copy
 | 
			
		||||
       * implementation of the texture_from_pixmap extension and in those cases
 | 
			
		||||
       * any drawing done to the window is always immediately reflected in the
 | 
			
		||||
       * texture regardless of damage event handling.
 | 
			
		||||
       */
 | 
			
		||||
      priv->needs_damage_all = TRUE;
 | 
			
		||||
      return;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  META_SURFACE_ACTOR_GET_CLASS (self)->process_damage (self, x, y, width, height);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_surface_actor_pre_paint (MetaSurfaceActor *self)
 | 
			
		||||
{
 | 
			
		||||
  META_SURFACE_ACTOR_GET_CLASS (self)->pre_paint (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
gboolean
 | 
			
		||||
meta_surface_actor_is_argb32 (MetaSurfaceActor *self)
 | 
			
		||||
{
 | 
			
		||||
  return META_SURFACE_ACTOR_GET_CLASS (self)->is_argb32 (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
gboolean
 | 
			
		||||
meta_surface_actor_is_visible (MetaSurfaceActor *self)
 | 
			
		||||
{
 | 
			
		||||
  return META_SURFACE_ACTOR_GET_CLASS (self)->is_visible (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_surface_actor_set_frozen (MetaSurfaceActor *self,
 | 
			
		||||
                               gboolean          frozen)
 | 
			
		||||
{
 | 
			
		||||
  MetaSurfaceActorPrivate *priv = self->priv;
 | 
			
		||||
 | 
			
		||||
  priv->frozen = frozen;
 | 
			
		||||
 | 
			
		||||
  if (!frozen && priv->needs_damage_all)
 | 
			
		||||
    {
 | 
			
		||||
      /* 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. */
 | 
			
		||||
 | 
			
		||||
      meta_surface_actor_process_damage (self, 0, 0,
 | 
			
		||||
                                         clutter_actor_get_width (CLUTTER_ACTOR (priv->texture)),
 | 
			
		||||
                                         clutter_actor_get_height (CLUTTER_ACTOR (priv->texture)));
 | 
			
		||||
      priv->needs_damage_all = FALSE;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
gboolean
 | 
			
		||||
meta_surface_actor_should_unredirect (MetaSurfaceActor *self)
 | 
			
		||||
{
 | 
			
		||||
  return META_SURFACE_ACTOR_GET_CLASS (self)->should_unredirect (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_surface_actor_set_unredirected (MetaSurfaceActor *self,
 | 
			
		||||
                                     gboolean          unredirected)
 | 
			
		||||
{
 | 
			
		||||
  META_SURFACE_ACTOR_GET_CLASS (self)->set_unredirected (self, unredirected);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
gboolean
 | 
			
		||||
meta_surface_actor_is_unredirected (MetaSurfaceActor *self)
 | 
			
		||||
{
 | 
			
		||||
  return META_SURFACE_ACTOR_GET_CLASS (self)->is_unredirected (self);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
MetaWindow *
 | 
			
		||||
meta_surface_actor_get_window (MetaSurfaceActor *self)
 | 
			
		||||
{
 | 
			
		||||
  return META_SURFACE_ACTOR_GET_CLASS (self)->get_window (self);
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										86
									
								
								src/compositor/meta-surface-actor.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								src/compositor/meta-surface-actor.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,86 @@
 | 
			
		||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
 | 
			
		||||
 | 
			
		||||
#ifndef META_SURFACE_ACTOR_PRIVATE_H
 | 
			
		||||
#define META_SURFACE_ACTOR_PRIVATE_H
 | 
			
		||||
 | 
			
		||||
#include <config.h>
 | 
			
		||||
 | 
			
		||||
#include <meta/meta-shaped-texture.h>
 | 
			
		||||
#include <meta/window.h>
 | 
			
		||||
 | 
			
		||||
G_BEGIN_DECLS
 | 
			
		||||
 | 
			
		||||
#define META_TYPE_SURFACE_ACTOR            (meta_surface_actor_get_type())
 | 
			
		||||
#define META_SURFACE_ACTOR(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_SURFACE_ACTOR, MetaSurfaceActor))
 | 
			
		||||
#define META_SURFACE_ACTOR_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass), META_TYPE_SURFACE_ACTOR, MetaSurfaceActorClass))
 | 
			
		||||
#define META_IS_SURFACE_ACTOR(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_SURFACE_ACTOR))
 | 
			
		||||
#define META_IS_SURFACE_ACTOR_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), META_TYPE_SURFACE_ACTOR))
 | 
			
		||||
#define META_SURFACE_ACTOR_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj), META_TYPE_SURFACE_ACTOR, MetaSurfaceActorClass))
 | 
			
		||||
 | 
			
		||||
typedef struct _MetaSurfaceActor        MetaSurfaceActor;
 | 
			
		||||
typedef struct _MetaSurfaceActorClass   MetaSurfaceActorClass;
 | 
			
		||||
typedef struct _MetaSurfaceActorPrivate MetaSurfaceActorPrivate;
 | 
			
		||||
 | 
			
		||||
struct _MetaSurfaceActorClass
 | 
			
		||||
{
 | 
			
		||||
  /*< private >*/
 | 
			
		||||
  ClutterActorClass parent_class;
 | 
			
		||||
 | 
			
		||||
  void     (* process_damage)    (MetaSurfaceActor *actor,
 | 
			
		||||
                                  int x, int y, int width, int height);
 | 
			
		||||
  void     (* pre_paint)         (MetaSurfaceActor *actor);
 | 
			
		||||
  gboolean (* is_argb32)         (MetaSurfaceActor *actor);
 | 
			
		||||
  gboolean (* is_visible)        (MetaSurfaceActor *actor);
 | 
			
		||||
 | 
			
		||||
  gboolean (* should_unredirect) (MetaSurfaceActor *actor);
 | 
			
		||||
  void     (* set_unredirected)  (MetaSurfaceActor *actor,
 | 
			
		||||
                                  gboolean          unredirected);
 | 
			
		||||
  gboolean (* is_unredirected)   (MetaSurfaceActor *actor);
 | 
			
		||||
 | 
			
		||||
  MetaWindow *(* get_window)      (MetaSurfaceActor *actor);
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
struct _MetaSurfaceActor
 | 
			
		||||
{
 | 
			
		||||
  ClutterActor            parent;
 | 
			
		||||
 | 
			
		||||
  MetaSurfaceActorPrivate *priv;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
GType meta_surface_actor_get_type (void);
 | 
			
		||||
 | 
			
		||||
cairo_surface_t *meta_surface_actor_get_image (MetaSurfaceActor      *self,
 | 
			
		||||
                                               cairo_rectangle_int_t *clip);
 | 
			
		||||
 | 
			
		||||
MetaShapedTexture *meta_surface_actor_get_texture (MetaSurfaceActor *self);
 | 
			
		||||
MetaWindow        *meta_surface_actor_get_window  (MetaSurfaceActor *self);
 | 
			
		||||
 | 
			
		||||
gboolean meta_surface_actor_is_obscured (MetaSurfaceActor *self);
 | 
			
		||||
gboolean meta_surface_actor_get_unobscured_bounds (MetaSurfaceActor      *self,
 | 
			
		||||
                                                   cairo_rectangle_int_t *unobscured_bounds);
 | 
			
		||||
 | 
			
		||||
void meta_surface_actor_set_input_region (MetaSurfaceActor *self,
 | 
			
		||||
                                          cairo_region_t   *region);
 | 
			
		||||
void meta_surface_actor_set_opaque_region (MetaSurfaceActor *self,
 | 
			
		||||
                                           cairo_region_t   *region);
 | 
			
		||||
 | 
			
		||||
void meta_surface_actor_update_area (MetaSurfaceActor *actor,
 | 
			
		||||
                                     int x, int y, int width, int height);
 | 
			
		||||
 | 
			
		||||
void meta_surface_actor_process_damage (MetaSurfaceActor *actor,
 | 
			
		||||
                                        int x, int y, int width, int height);
 | 
			
		||||
void meta_surface_actor_pre_paint (MetaSurfaceActor *actor);
 | 
			
		||||
gboolean meta_surface_actor_is_argb32 (MetaSurfaceActor *actor);
 | 
			
		||||
gboolean meta_surface_actor_is_visible (MetaSurfaceActor *actor);
 | 
			
		||||
 | 
			
		||||
void meta_surface_actor_set_frozen (MetaSurfaceActor *actor,
 | 
			
		||||
                                    gboolean          frozen);
 | 
			
		||||
 | 
			
		||||
gboolean meta_surface_actor_should_unredirect (MetaSurfaceActor *actor);
 | 
			
		||||
void meta_surface_actor_set_unredirected (MetaSurfaceActor *actor,
 | 
			
		||||
                                          gboolean          unredirected);
 | 
			
		||||
gboolean meta_surface_actor_is_unredirected (MetaSurfaceActor *actor);
 | 
			
		||||
 | 
			
		||||
G_END_DECLS
 | 
			
		||||
 | 
			
		||||
#endif /* META_SURFACE_ACTOR_PRIVATE_H */
 | 
			
		||||
@@ -18,9 +18,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <config.h>
 | 
			
		||||
@@ -28,41 +26,6 @@
 | 
			
		||||
#include <clutter/clutter.h>
 | 
			
		||||
#include "meta-texture-rectangle.h"
 | 
			
		||||
 | 
			
		||||
CoglTexture *
 | 
			
		||||
meta_texture_rectangle_new (unsigned int width,
 | 
			
		||||
                            unsigned int height,
 | 
			
		||||
                            CoglPixelFormat format,
 | 
			
		||||
                            CoglPixelFormat internal_format,
 | 
			
		||||
                            unsigned int rowstride,
 | 
			
		||||
                            const guint8 *data,
 | 
			
		||||
                            GError **error)
 | 
			
		||||
{
 | 
			
		||||
  ClutterBackend *backend =
 | 
			
		||||
    clutter_get_default_backend ();
 | 
			
		||||
  CoglContext *context =
 | 
			
		||||
    clutter_backend_get_cogl_context (backend);
 | 
			
		||||
  CoglTextureRectangle *tex_rect;
 | 
			
		||||
 | 
			
		||||
  tex_rect = cogl_texture_rectangle_new_with_size (context,
 | 
			
		||||
                                                   width, height,
 | 
			
		||||
                                                   internal_format,
 | 
			
		||||
                                                   error);
 | 
			
		||||
  if (tex_rect == NULL)
 | 
			
		||||
    return NULL;
 | 
			
		||||
 | 
			
		||||
  if (data)
 | 
			
		||||
    cogl_texture_set_region (COGL_TEXTURE (tex_rect),
 | 
			
		||||
                             0, 0, /* src_x/y */
 | 
			
		||||
                             0, 0, /* dst_x/y */
 | 
			
		||||
                             width, height, /* dst_width/height */
 | 
			
		||||
                             width, height, /* width/height */
 | 
			
		||||
                             format,
 | 
			
		||||
                             rowstride,
 | 
			
		||||
                             data);
 | 
			
		||||
 | 
			
		||||
  return COGL_TEXTURE (tex_rect);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
texture_rectangle_check_cb (CoglTexture *sub_texture,
 | 
			
		||||
                            const float *sub_texture_coords,
 | 
			
		||||
 
 | 
			
		||||
@@ -18,9 +18,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef __META_TEXTURE_RECTANGLE_H__
 | 
			
		||||
@@ -30,15 +28,6 @@
 | 
			
		||||
 | 
			
		||||
G_BEGIN_DECLS
 | 
			
		||||
 | 
			
		||||
CoglTexture *
 | 
			
		||||
meta_texture_rectangle_new (unsigned int width,
 | 
			
		||||
                            unsigned int height,
 | 
			
		||||
                            CoglPixelFormat format,
 | 
			
		||||
                            CoglPixelFormat internal_format,
 | 
			
		||||
                            unsigned int rowstride,
 | 
			
		||||
                            const guint8 *data,
 | 
			
		||||
                            GError **error);
 | 
			
		||||
 | 
			
		||||
gboolean
 | 
			
		||||
meta_texture_rectangle_check (CoglTexture *texture);
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -17,9 +17,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <math.h>
 | 
			
		||||
@@ -357,18 +355,10 @@ texture_tower_create_texture (MetaTextureTower *tower,
 | 
			
		||||
  if ((!is_power_of_two (width) || !is_power_of_two (height)) &&
 | 
			
		||||
      meta_texture_rectangle_check (tower->textures[level - 1]))
 | 
			
		||||
    {
 | 
			
		||||
      tower->textures[level] =
 | 
			
		||||
        meta_texture_rectangle_new (width, height,
 | 
			
		||||
                                    /* data format */
 | 
			
		||||
                                    TEXTURE_FORMAT,
 | 
			
		||||
                                    /* internal cogl format */
 | 
			
		||||
                                    TEXTURE_FORMAT,
 | 
			
		||||
                                    /* rowstride */
 | 
			
		||||
                                    width * 4,
 | 
			
		||||
                                    /* data */
 | 
			
		||||
                                    NULL,
 | 
			
		||||
                                    /* error */
 | 
			
		||||
                                    NULL);
 | 
			
		||||
      ClutterBackend *backend = clutter_get_default_backend ();
 | 
			
		||||
      CoglContext *context = clutter_backend_get_cogl_context (backend);
 | 
			
		||||
 | 
			
		||||
      tower->textures[level] = cogl_texture_rectangle_new_with_size (context, width, height);
 | 
			
		||||
    }
 | 
			
		||||
  else
 | 
			
		||||
    {
 | 
			
		||||
 
 | 
			
		||||
@@ -17,9 +17,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef __META_TEXTURE_TOWER_H__
 | 
			
		||||
 
 | 
			
		||||
@@ -5,11 +5,9 @@
 | 
			
		||||
 | 
			
		||||
#include <config.h>
 | 
			
		||||
 | 
			
		||||
#include <wayland-server.h>
 | 
			
		||||
#include <meta-wayland-private.h>
 | 
			
		||||
 | 
			
		||||
#include <X11/extensions/Xdamage.h>
 | 
			
		||||
#include <meta/compositor-mutter.h>
 | 
			
		||||
#include "meta-surface-actor.h"
 | 
			
		||||
 | 
			
		||||
MetaWindowActor *meta_window_actor_new (MetaWindow *window);
 | 
			
		||||
 | 
			
		||||
@@ -30,16 +28,6 @@ void meta_window_actor_unmaximize (MetaWindowActor *self,
 | 
			
		||||
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);
 | 
			
		||||
void meta_window_actor_frame_complete (MetaWindowActor    *self,
 | 
			
		||||
@@ -48,13 +36,13 @@ void meta_window_actor_frame_complete (MetaWindowActor    *self,
 | 
			
		||||
 | 
			
		||||
void meta_window_actor_invalidate_shadow (MetaWindowActor *self);
 | 
			
		||||
 | 
			
		||||
void meta_window_actor_set_redirected (MetaWindowActor *self, gboolean state);
 | 
			
		||||
 | 
			
		||||
gboolean meta_window_actor_should_unredirect (MetaWindowActor *self);
 | 
			
		||||
 | 
			
		||||
void meta_window_actor_get_shape_bounds (MetaWindowActor       *self,
 | 
			
		||||
                                          cairo_rectangle_int_t *bounds);
 | 
			
		||||
 | 
			
		||||
gboolean meta_window_actor_should_unredirect   (MetaWindowActor *self);
 | 
			
		||||
void     meta_window_actor_set_unredirected    (MetaWindowActor *self,
 | 
			
		||||
                                                gboolean         unredirected);
 | 
			
		||||
 | 
			
		||||
gboolean meta_window_actor_effect_in_progress  (MetaWindowActor *self);
 | 
			
		||||
void     meta_window_actor_sync_actor_geometry (MetaWindowActor *self,
 | 
			
		||||
                                                gboolean         did_placement);
 | 
			
		||||
@@ -68,15 +56,10 @@ void     meta_window_actor_set_updates_frozen  (MetaWindowActor *self,
 | 
			
		||||
void     meta_window_actor_queue_frame_drawn   (MetaWindowActor *self,
 | 
			
		||||
                                                gboolean         no_delay_frame);
 | 
			
		||||
 | 
			
		||||
cairo_region_t *meta_window_actor_get_obscured_region (MetaWindowActor *self);
 | 
			
		||||
 | 
			
		||||
void meta_window_actor_set_visible_region         (MetaWindowActor *self,
 | 
			
		||||
                                                   cairo_region_t  *visible_region);
 | 
			
		||||
void meta_window_actor_set_visible_region_beneath (MetaWindowActor *self,
 | 
			
		||||
                                                   cairo_region_t  *beneath_region);
 | 
			
		||||
void meta_window_actor_reset_visible_regions      (MetaWindowActor *self);
 | 
			
		||||
 | 
			
		||||
void meta_window_actor_effect_completed (MetaWindowActor *actor,
 | 
			
		||||
                                         gulong           event);
 | 
			
		||||
 | 
			
		||||
MetaSurfaceActor *meta_window_actor_get_surface (MetaWindowActor *self);
 | 
			
		||||
void meta_window_actor_update_surface (MetaWindowActor *self);
 | 
			
		||||
 | 
			
		||||
#endif /* META_WINDOW_ACTOR_PRIVATE_H */
 | 
			
		||||
 
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -11,9 +11,8 @@
 | 
			
		||||
#include "compositor-private.h"
 | 
			
		||||
#include "meta-window-actor-private.h"
 | 
			
		||||
#include "meta-window-group.h"
 | 
			
		||||
#include "meta-background-actor-private.h"
 | 
			
		||||
#include "meta-background-group-private.h"
 | 
			
		||||
#include "window-private.h"
 | 
			
		||||
#include "meta-cullable.h"
 | 
			
		||||
 | 
			
		||||
struct _MetaWindowGroupClass
 | 
			
		||||
{
 | 
			
		||||
@@ -27,7 +26,10 @@ struct _MetaWindowGroup
 | 
			
		||||
  MetaScreen *screen;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
G_DEFINE_TYPE (MetaWindowGroup, meta_window_group, CLUTTER_TYPE_ACTOR);
 | 
			
		||||
static void cullable_iface_init (MetaCullableInterface *iface);
 | 
			
		||||
 | 
			
		||||
G_DEFINE_TYPE_WITH_CODE (MetaWindowGroup, meta_window_group, CLUTTER_TYPE_ACTOR,
 | 
			
		||||
                         G_IMPLEMENT_INTERFACE (META_TYPE_CULLABLE, cullable_iface_init));
 | 
			
		||||
 | 
			
		||||
/* Help macros to scale from OpenGL <-1,1> coordinates system to
 | 
			
		||||
 * window coordinates ranging [0,window-size]. Borrowed from clutter-utils.c
 | 
			
		||||
@@ -87,20 +89,39 @@ painting_untransformed (MetaWindowGroup *window_group,
 | 
			
		||||
  return meta_actor_vertices_are_untransformed (vertices, width, height, x_origin, y_origin);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_window_group_cull_out (MetaCullable   *cullable,
 | 
			
		||||
                            cairo_region_t *unobscured_region,
 | 
			
		||||
                            cairo_region_t *clip_region)
 | 
			
		||||
{
 | 
			
		||||
  meta_cullable_cull_out_children (cullable, unobscured_region, clip_region);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_window_group_reset_culling (MetaCullable *cullable)
 | 
			
		||||
{
 | 
			
		||||
  meta_cullable_reset_culling_children (cullable);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
cullable_iface_init (MetaCullableInterface *iface)
 | 
			
		||||
{
 | 
			
		||||
  iface->cull_out = meta_window_group_cull_out;
 | 
			
		||||
  iface->reset_culling = meta_window_group_reset_culling;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_window_group_paint (ClutterActor *actor)
 | 
			
		||||
{
 | 
			
		||||
  cairo_region_t *visible_region;
 | 
			
		||||
  ClutterActor *stage;
 | 
			
		||||
  ClutterActorIter iter;
 | 
			
		||||
  ClutterActor *child;
 | 
			
		||||
  cairo_rectangle_int_t visible_rect;
 | 
			
		||||
  cairo_region_t *clip_region;
 | 
			
		||||
  cairo_region_t *unobscured_region;
 | 
			
		||||
  cairo_rectangle_int_t visible_rect, clip_rect;
 | 
			
		||||
  int paint_x_offset, paint_y_offset;
 | 
			
		||||
  int paint_x_origin, paint_y_origin;
 | 
			
		||||
  int actor_x_origin, actor_y_origin;
 | 
			
		||||
  int paint_x_offset, paint_y_offset;
 | 
			
		||||
 | 
			
		||||
  MetaWindowGroup *window_group = META_WINDOW_GROUP (actor);
 | 
			
		||||
  MetaCompScreen *info;
 | 
			
		||||
  ClutterActor *stage = clutter_actor_get_stage (actor);
 | 
			
		||||
 | 
			
		||||
  /* Normally we expect an actor to be drawn at it's position on the screen.
 | 
			
		||||
   * However, if we're inside the paint of a ClutterClone, that won't be the
 | 
			
		||||
@@ -122,8 +143,11 @@ meta_window_group_paint (ClutterActor *actor)
 | 
			
		||||
      return;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  paint_x_offset = paint_x_origin - actor_x_origin;
 | 
			
		||||
  paint_y_offset = paint_y_origin - actor_y_origin;
 | 
			
		||||
  visible_rect.x = visible_rect.y = 0;
 | 
			
		||||
  visible_rect.width = clutter_actor_get_width (CLUTTER_ACTOR (stage));
 | 
			
		||||
  visible_rect.height = clutter_actor_get_height (CLUTTER_ACTOR (stage));
 | 
			
		||||
 | 
			
		||||
  unobscured_region = cairo_region_create_rectangle (&visible_rect);
 | 
			
		||||
 | 
			
		||||
  /* Get the clipped redraw bounds from Clutter so that we can avoid
 | 
			
		||||
   * painting shadows on windows that don't need to be painted in this
 | 
			
		||||
@@ -131,134 +155,49 @@ meta_window_group_paint (ClutterActor *actor)
 | 
			
		||||
   * sizes, we could intersect this with an accurate union of the
 | 
			
		||||
   * monitors to avoid painting shadows that are visible only in the
 | 
			
		||||
   * holes. */
 | 
			
		||||
  stage = clutter_actor_get_stage (actor);
 | 
			
		||||
  clutter_stage_get_redraw_clip_bounds (CLUTTER_STAGE (stage),
 | 
			
		||||
                                        &visible_rect);
 | 
			
		||||
                                        &clip_rect);
 | 
			
		||||
 | 
			
		||||
  visible_region = cairo_region_create_rectangle (&visible_rect);
 | 
			
		||||
  clip_region = cairo_region_create_rectangle (&clip_rect);
 | 
			
		||||
 | 
			
		||||
  if (!meta_is_wayland_compositor ())
 | 
			
		||||
    {
 | 
			
		||||
      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);
 | 
			
		||||
  paint_x_offset = paint_x_origin - actor_x_origin;
 | 
			
		||||
  paint_y_offset = paint_y_origin - actor_y_origin;
 | 
			
		||||
  cairo_region_translate (clip_region, -paint_x_offset, -paint_y_offset);
 | 
			
		||||
 | 
			
		||||
          meta_window_get_outer_rect (window, (MetaRectangle *)&unredirected_rect);
 | 
			
		||||
          cairo_region_subtract_rectangle (visible_region, &unredirected_rect);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
  meta_cullable_cull_out (META_CULLABLE (window_group), unobscured_region, clip_region);
 | 
			
		||||
 | 
			
		||||
  /* We walk the list from top to bottom (opposite of painting order),
 | 
			
		||||
   * and subtract the opaque area of each window out of the visible
 | 
			
		||||
   * region that we pass to the windows below.
 | 
			
		||||
   */
 | 
			
		||||
  clutter_actor_iter_init (&iter, actor);
 | 
			
		||||
  while (clutter_actor_iter_prev (&iter, &child))
 | 
			
		||||
    {
 | 
			
		||||
      if (!CLUTTER_ACTOR_IS_VISIBLE (child))
 | 
			
		||||
        continue;
 | 
			
		||||
 | 
			
		||||
      if (!meta_is_wayland_compositor () &&
 | 
			
		||||
          info->unredirected_window != NULL &&
 | 
			
		||||
          child == CLUTTER_ACTOR (info->unredirected_window))
 | 
			
		||||
        continue;
 | 
			
		||||
 | 
			
		||||
      /* If an actor has effects applied, then that can change the area
 | 
			
		||||
       * it paints and the opacity, so we no longer can figure out what
 | 
			
		||||
       * portion of the actor is obscured and what portion of the screen
 | 
			
		||||
       * it obscures, so we skip the actor.
 | 
			
		||||
       *
 | 
			
		||||
       * This has a secondary beneficial effect: if a ClutterOffscreenEffect
 | 
			
		||||
       * is applied to an actor, then our clipped redraws interfere with the
 | 
			
		||||
       * caching of the FBO - even if we only need to draw a small portion
 | 
			
		||||
       * of the window right now, ClutterOffscreenEffect may use other portions
 | 
			
		||||
       * of the FBO later. So, skipping actors with effects applied also
 | 
			
		||||
       * prevents these bugs.
 | 
			
		||||
       *
 | 
			
		||||
       * Theoretically, we should check clutter_actor_get_offscreen_redirect()
 | 
			
		||||
       * as well for the same reason, but omitted for simplicity in the
 | 
			
		||||
       * hopes that no-one will do that.
 | 
			
		||||
       */
 | 
			
		||||
      if (clutter_actor_has_effects (child))
 | 
			
		||||
        continue;
 | 
			
		||||
 | 
			
		||||
      if (META_IS_WINDOW_ACTOR (child))
 | 
			
		||||
        {
 | 
			
		||||
          MetaWindowActor *window_actor = META_WINDOW_ACTOR (child);
 | 
			
		||||
          int x, y;
 | 
			
		||||
 | 
			
		||||
          if (!meta_actor_is_untransformed (CLUTTER_ACTOR (window_actor), &x, &y))
 | 
			
		||||
            continue;
 | 
			
		||||
 | 
			
		||||
          x += paint_x_offset;
 | 
			
		||||
          y += paint_y_offset;
 | 
			
		||||
 | 
			
		||||
          /* Temporarily move to the coordinate system of the actor */
 | 
			
		||||
          cairo_region_translate (visible_region, - x, - y);
 | 
			
		||||
 | 
			
		||||
          meta_window_actor_set_visible_region (window_actor, visible_region);
 | 
			
		||||
 | 
			
		||||
          if (clutter_actor_get_paint_opacity (CLUTTER_ACTOR (window_actor)) == 0xff)
 | 
			
		||||
            {
 | 
			
		||||
              cairo_region_t *obscured_region = meta_window_actor_get_obscured_region (window_actor);
 | 
			
		||||
              if (obscured_region)
 | 
			
		||||
                cairo_region_subtract (visible_region, obscured_region);
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
          meta_window_actor_set_visible_region_beneath (window_actor, visible_region);
 | 
			
		||||
          cairo_region_translate (visible_region, x, y);
 | 
			
		||||
        }
 | 
			
		||||
      else if (META_IS_BACKGROUND_ACTOR (child) ||
 | 
			
		||||
               META_IS_BACKGROUND_GROUP (child))
 | 
			
		||||
        {
 | 
			
		||||
          int x, y;
 | 
			
		||||
 | 
			
		||||
          if (!meta_actor_is_untransformed (child, &x, &y))
 | 
			
		||||
            continue;
 | 
			
		||||
 | 
			
		||||
          x += paint_x_offset;
 | 
			
		||||
          y += paint_y_offset;
 | 
			
		||||
 | 
			
		||||
          cairo_region_translate (visible_region, - x, - y);
 | 
			
		||||
 | 
			
		||||
          if (META_IS_BACKGROUND_GROUP (child))
 | 
			
		||||
            meta_background_group_set_visible_region (META_BACKGROUND_GROUP (child), visible_region);
 | 
			
		||||
          else
 | 
			
		||||
            meta_background_actor_set_visible_region (META_BACKGROUND_ACTOR (child), visible_region);
 | 
			
		||||
          cairo_region_translate (visible_region, x, y);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  cairo_region_destroy (visible_region);
 | 
			
		||||
  cairo_region_destroy (unobscured_region);
 | 
			
		||||
  cairo_region_destroy (clip_region);
 | 
			
		||||
 | 
			
		||||
  CLUTTER_ACTOR_CLASS (meta_window_group_parent_class)->paint (actor);
 | 
			
		||||
 | 
			
		||||
  /* Now that we are done painting, unset the visible regions (they will
 | 
			
		||||
   * mess up painting clones of our actors)
 | 
			
		||||
   */
 | 
			
		||||
  clutter_actor_iter_init (&iter, actor);
 | 
			
		||||
  while (clutter_actor_iter_next (&iter, &child))
 | 
			
		||||
    {
 | 
			
		||||
      if (META_IS_WINDOW_ACTOR (child))
 | 
			
		||||
        {
 | 
			
		||||
          MetaWindowActor *window_actor = META_WINDOW_ACTOR (child);
 | 
			
		||||
          meta_window_actor_reset_visible_regions (window_actor);
 | 
			
		||||
        }
 | 
			
		||||
      else if (META_IS_BACKGROUND_ACTOR (child))
 | 
			
		||||
        {
 | 
			
		||||
          MetaBackgroundActor *background_actor = META_BACKGROUND_ACTOR (child);
 | 
			
		||||
          meta_background_actor_set_visible_region (background_actor, NULL);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
  meta_cullable_reset_culling (META_CULLABLE (window_group));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Adapted from clutter_actor_update_default_paint_volume() */
 | 
			
		||||
static gboolean
 | 
			
		||||
meta_window_group_get_paint_volume (ClutterActor       *actor,
 | 
			
		||||
meta_window_group_get_paint_volume (ClutterActor       *self,
 | 
			
		||||
                                    ClutterPaintVolume *volume)
 | 
			
		||||
{
 | 
			
		||||
  return clutter_paint_volume_set_from_allocation (volume, actor);
 | 
			
		||||
  ClutterActorIter iter;
 | 
			
		||||
  ClutterActor *child;
 | 
			
		||||
 | 
			
		||||
  clutter_actor_iter_init (&iter, self);
 | 
			
		||||
  while (clutter_actor_iter_next (&iter, &child))
 | 
			
		||||
    {
 | 
			
		||||
      const ClutterPaintVolume *child_volume;
 | 
			
		||||
 | 
			
		||||
      if (!CLUTTER_ACTOR_IS_MAPPED (child))
 | 
			
		||||
        continue;
 | 
			
		||||
 | 
			
		||||
      child_volume = clutter_actor_get_transformed_paint_volume (child, self);
 | 
			
		||||
      if (child_volume == NULL)
 | 
			
		||||
        return FALSE;
 | 
			
		||||
 | 
			
		||||
      clutter_paint_volume_union (volume, child_volume);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  return TRUE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
 
 | 
			
		||||
@@ -11,29 +11,9 @@
 | 
			
		||||
 * MetaWindowGroup:
 | 
			
		||||
 *
 | 
			
		||||
 * This class is a subclass of ClutterActor with special handling for
 | 
			
		||||
 * MetaWindowActor/MetaBackgroundActor/MetaBackgroundGroup when painting
 | 
			
		||||
 * children.
 | 
			
		||||
 *
 | 
			
		||||
 * When we are painting a stack of 5-10 maximized windows, the
 | 
			
		||||
 * standard bottom-to-top method of drawing every actor results in a
 | 
			
		||||
 * tremendous amount of overdraw and can easily max out the available
 | 
			
		||||
 * memory bandwidth on a low-end graphics chipset. It's even worse if
 | 
			
		||||
 * window textures are being accessed over the AGP bus.
 | 
			
		||||
 *
 | 
			
		||||
 * The basic technique applied here is to do a pre-pass before painting
 | 
			
		||||
 * where we walk window from top to bottom and compute the visible area
 | 
			
		||||
 * at each step by subtracting out the windows above it. The visible
 | 
			
		||||
 * area is passed to MetaWindowActor which uses it to clip the portion of
 | 
			
		||||
 * the window which drawn and avoid redrawing the shadow if it is completely
 | 
			
		||||
 * obscured.
 | 
			
		||||
 *
 | 
			
		||||
 * A caveat is that this is ineffective if applications are using ARGB
 | 
			
		||||
 * visuals, since we have no way of knowing whether a window obscures
 | 
			
		||||
 * the windows behind it or not. Alternate approaches using the depth
 | 
			
		||||
 * or stencil buffer rather than client side regions might be able to
 | 
			
		||||
 * handle alpha windows, but the combination of glAlphaFunc and stenciling
 | 
			
		||||
 * tends not to be efficient except on newer cards. (And on newer cards
 | 
			
		||||
 * we have lots of memory and bandwidth.)
 | 
			
		||||
 * #MetaCullable when painting children. It uses code similar to
 | 
			
		||||
 * meta_cullable_cull_out_children(), but also has additional special
 | 
			
		||||
 * cases for the undirected window, and similar.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#define META_TYPE_WINDOW_GROUP            (meta_window_group_get_type ())
 | 
			
		||||
 
 | 
			
		||||
@@ -17,9 +17,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
#include <string.h>
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -17,9 +17,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef __META_WINDOW_SHAPE_H__
 | 
			
		||||
 
 | 
			
		||||
@@ -16,32 +16,30 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#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>
 | 
			
		||||
#include <string.h>
 | 
			
		||||
 | 
			
		||||
#define DESTROY_TIMEOUT   250
 | 
			
		||||
#define DESTROY_TIMEOUT   100
 | 
			
		||||
#define MINIMIZE_TIMEOUT  250
 | 
			
		||||
#define MAXIMIZE_TIMEOUT  250
 | 
			
		||||
#define MAP_TIMEOUT       250
 | 
			
		||||
#define SWITCH_TIMEOUT    500
 | 
			
		||||
 | 
			
		||||
#define ACTOR_DATA_KEY "MCCP-Default-actor-data"
 | 
			
		||||
#define SCREEN_TILE_PREVIEW_DATA_KEY "MCCP-Default-screen-tile-preview-data"
 | 
			
		||||
 | 
			
		||||
#define META_TYPE_DEFAULT_PLUGIN            (meta_default_plugin_get_type ())
 | 
			
		||||
#define META_DEFAULT_PLUGIN(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_DEFAULT_PLUGIN, MetaDefaultPlugin))
 | 
			
		||||
@@ -70,6 +68,7 @@ struct _MetaDefaultPluginClass
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
static GQuark actor_data_quark = 0;
 | 
			
		||||
static GQuark screen_tile_preview_data_quark = 0;
 | 
			
		||||
 | 
			
		||||
static void start      (MetaPlugin      *plugin);
 | 
			
		||||
static void minimize   (MetaPlugin      *plugin,
 | 
			
		||||
@@ -100,6 +99,12 @@ static void kill_window_effects   (MetaPlugin      *plugin,
 | 
			
		||||
                                   MetaWindowActor *actor);
 | 
			
		||||
static void kill_switch_workspace (MetaPlugin      *plugin);
 | 
			
		||||
 | 
			
		||||
static void show_tile_preview (MetaPlugin      *plugin,
 | 
			
		||||
                               MetaWindow      *window,
 | 
			
		||||
                               MetaRectangle   *tile_rect,
 | 
			
		||||
                               int              tile_monitor_number);
 | 
			
		||||
static void hide_tile_preview (MetaPlugin      *plugin);
 | 
			
		||||
 | 
			
		||||
static void confirm_display_change (MetaPlugin *plugin);
 | 
			
		||||
 | 
			
		||||
static const MetaPluginInfo * plugin_info (MetaPlugin *plugin);
 | 
			
		||||
@@ -146,6 +151,15 @@ typedef struct
 | 
			
		||||
} EffectCompleteData;
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
typedef struct _ScreenTilePreview
 | 
			
		||||
{
 | 
			
		||||
  ClutterActor   *actor;
 | 
			
		||||
 | 
			
		||||
  GdkRGBA        *preview_color;
 | 
			
		||||
 | 
			
		||||
  MetaRectangle   tile_rect;
 | 
			
		||||
} ScreenTilePreview;
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
meta_default_plugin_dispose (GObject *object)
 | 
			
		||||
{
 | 
			
		||||
@@ -206,6 +220,8 @@ meta_default_plugin_class_init (MetaDefaultPluginClass *klass)
 | 
			
		||||
  plugin_class->unmaximize       = unmaximize;
 | 
			
		||||
  plugin_class->destroy          = destroy;
 | 
			
		||||
  plugin_class->switch_workspace = switch_workspace;
 | 
			
		||||
  plugin_class->show_tile_preview = show_tile_preview;
 | 
			
		||||
  plugin_class->hide_tile_preview = hide_tile_preview;
 | 
			
		||||
  plugin_class->plugin_info      = plugin_info;
 | 
			
		||||
  plugin_class->kill_window_effects   = kill_window_effects;
 | 
			
		||||
  plugin_class->kill_switch_workspace = kill_switch_workspace;
 | 
			
		||||
@@ -292,26 +308,13 @@ on_switch_workspace_effect_complete (ClutterTimeline *timeline, gpointer data)
 | 
			
		||||
  meta_plugin_switch_workspace_completed (plugin);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static gboolean
 | 
			
		||||
show_stage (MetaPlugin *plugin)
 | 
			
		||||
{
 | 
			
		||||
  MetaScreen *screen;
 | 
			
		||||
  ClutterActor *stage;
 | 
			
		||||
 | 
			
		||||
  screen = meta_plugin_get_screen (plugin);
 | 
			
		||||
  stage = meta_get_stage_for_screen (screen);
 | 
			
		||||
 | 
			
		||||
  clutter_actor_show (stage);
 | 
			
		||||
 | 
			
		||||
  return FALSE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
on_monitors_changed (MetaScreen *screen,
 | 
			
		||||
                     MetaPlugin *plugin)
 | 
			
		||||
{
 | 
			
		||||
  MetaDefaultPlugin *self = META_DEFAULT_PLUGIN (plugin);
 | 
			
		||||
  int i, n;
 | 
			
		||||
  GRand *rand = g_rand_new_with_seed (12345);
 | 
			
		||||
 | 
			
		||||
  clutter_actor_destroy_all_children (self->priv->background_group);
 | 
			
		||||
 | 
			
		||||
@@ -334,14 +337,16 @@ on_monitors_changed (MetaScreen *screen,
 | 
			
		||||
         reproducible.
 | 
			
		||||
      */
 | 
			
		||||
      clutter_color_init (&color,
 | 
			
		||||
                          g_random_int () % 255,
 | 
			
		||||
                          g_random_int () % 255,
 | 
			
		||||
                          g_random_int () % 255,
 | 
			
		||||
                          g_rand_int_range (rand, 0, 255),
 | 
			
		||||
                          g_rand_int_range (rand, 0, 255),
 | 
			
		||||
                          g_rand_int_range (rand, 0, 255),
 | 
			
		||||
                          255);
 | 
			
		||||
      clutter_actor_set_background_color (background, &color);
 | 
			
		||||
 | 
			
		||||
      clutter_actor_add_child (self->priv->background_group, background);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  g_rand_free (rand);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
@@ -358,10 +363,7 @@ start (MetaPlugin *plugin)
 | 
			
		||||
                    G_CALLBACK (on_monitors_changed), plugin);
 | 
			
		||||
  on_monitors_changed (screen, plugin);
 | 
			
		||||
 | 
			
		||||
  meta_later_add (META_LATER_BEFORE_REDRAW,
 | 
			
		||||
                  (GSourceFunc) show_stage,
 | 
			
		||||
                  plugin,
 | 
			
		||||
                  NULL);
 | 
			
		||||
  clutter_actor_show (meta_get_stage_for_screen (screen));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
@@ -410,9 +412,11 @@ switch_workspace (MetaPlugin *plugin,
 | 
			
		||||
      MetaWindowActor *window_actor = l->data;
 | 
			
		||||
      ActorPrivate    *apriv	    = get_actor_private (window_actor);
 | 
			
		||||
      ClutterActor    *actor	    = CLUTTER_ACTOR (window_actor);
 | 
			
		||||
      MetaWorkspace   *workspace;
 | 
			
		||||
      gint             win_workspace;
 | 
			
		||||
 | 
			
		||||
      win_workspace = meta_window_actor_get_workspace (window_actor);
 | 
			
		||||
      workspace = meta_window_get_workspace (meta_window_actor_get_meta_window (window_actor));
 | 
			
		||||
      win_workspace = meta_workspace_index (workspace);
 | 
			
		||||
 | 
			
		||||
      if (win_workspace == to || win_workspace == from)
 | 
			
		||||
        {
 | 
			
		||||
@@ -484,8 +488,6 @@ on_minimize_effect_complete (ClutterTimeline *timeline, EffectCompleteData *data
 | 
			
		||||
  /* FIXME - we shouldn't assume the original scale, it should be saved
 | 
			
		||||
   * at the start of the effect */
 | 
			
		||||
  clutter_actor_set_scale (data->actor, 1.0, 1.0);
 | 
			
		||||
  clutter_actor_move_anchor_point_from_gravity (data->actor,
 | 
			
		||||
                                                CLUTTER_GRAVITY_NORTH_WEST);
 | 
			
		||||
 | 
			
		||||
  /* Now notify the manager that we are done with this effect */
 | 
			
		||||
  meta_plugin_minimize_completed (plugin, window_actor);
 | 
			
		||||
@@ -522,9 +524,6 @@ minimize (MetaPlugin *plugin, MetaWindowActor *window_actor)
 | 
			
		||||
 | 
			
		||||
      apriv->is_minimized = TRUE;
 | 
			
		||||
 | 
			
		||||
      clutter_actor_move_anchor_point_from_gravity (actor,
 | 
			
		||||
                                                    CLUTTER_GRAVITY_CENTER);
 | 
			
		||||
 | 
			
		||||
      animation = clutter_actor_animate (actor,
 | 
			
		||||
                                         CLUTTER_EASE_IN_SINE,
 | 
			
		||||
                                         MINIMIZE_TIMEOUT,
 | 
			
		||||
@@ -563,8 +562,6 @@ on_maximize_effect_complete (ClutterTimeline *timeline, EffectCompleteData *data
 | 
			
		||||
 | 
			
		||||
  /* FIXME - don't assume the original scale was 1.0 */
 | 
			
		||||
  clutter_actor_set_scale (data->actor, 1.0, 1.0);
 | 
			
		||||
  clutter_actor_move_anchor_point_from_gravity (data->actor,
 | 
			
		||||
                                                CLUTTER_GRAVITY_NORTH_WEST);
 | 
			
		||||
 | 
			
		||||
  /* Now notify the manager that we are done with this effect */
 | 
			
		||||
  meta_plugin_maximize_completed (plugin, window_actor);
 | 
			
		||||
@@ -589,10 +586,8 @@ maximize (MetaPlugin *plugin,
 | 
			
		||||
  ClutterActor *actor = CLUTTER_ACTOR (window_actor);
 | 
			
		||||
  MetaWindow *meta_window = meta_window_actor_get_meta_window (window_actor);
 | 
			
		||||
 | 
			
		||||
  gdouble  scale_x    = 1.0;
 | 
			
		||||
  gdouble  scale_y    = 1.0;
 | 
			
		||||
  gfloat   anchor_x   = 0;
 | 
			
		||||
  gfloat   anchor_y   = 0;
 | 
			
		||||
  gdouble  scale_x = 1.0;
 | 
			
		||||
  gdouble  scale_y = 1.0;
 | 
			
		||||
 | 
			
		||||
  type = meta_window_get_window_type (meta_window);
 | 
			
		||||
 | 
			
		||||
@@ -616,13 +611,6 @@ maximize (MetaPlugin *plugin,
 | 
			
		||||
      scale_x = (gdouble)end_width / (gdouble) width;
 | 
			
		||||
      scale_y = (gdouble)end_height / (gdouble) height;
 | 
			
		||||
 | 
			
		||||
      anchor_x = (gdouble)(x - end_x)*(gdouble)width /
 | 
			
		||||
        ((gdouble)(end_width - width));
 | 
			
		||||
      anchor_y = (gdouble)(y - end_y)*(gdouble)height /
 | 
			
		||||
        ((gdouble)(end_height - height));
 | 
			
		||||
 | 
			
		||||
      clutter_actor_move_anchor_point (actor, anchor_x, anchor_y);
 | 
			
		||||
 | 
			
		||||
      animation = clutter_actor_animate (actor,
 | 
			
		||||
                                         CLUTTER_EASE_IN_SINE,
 | 
			
		||||
                                         MAXIMIZE_TIMEOUT,
 | 
			
		||||
@@ -677,9 +665,6 @@ on_map_effect_complete (ClutterTimeline *timeline, EffectCompleteData *data)
 | 
			
		||||
 | 
			
		||||
  apriv->tml_map = NULL;
 | 
			
		||||
 | 
			
		||||
  clutter_actor_move_anchor_point_from_gravity (data->actor,
 | 
			
		||||
                                                CLUTTER_GRAVITY_NORTH_WEST);
 | 
			
		||||
 | 
			
		||||
  /* Now notify the manager that we are done with this effect */
 | 
			
		||||
  meta_plugin_map_completed (plugin, window_actor);
 | 
			
		||||
 | 
			
		||||
@@ -705,15 +690,15 @@ map (MetaPlugin *plugin, MetaWindowActor *window_actor)
 | 
			
		||||
      EffectCompleteData *data = g_new0 (EffectCompleteData, 1);
 | 
			
		||||
      ActorPrivate *apriv = get_actor_private (window_actor);
 | 
			
		||||
 | 
			
		||||
      clutter_actor_move_anchor_point_from_gravity (actor,
 | 
			
		||||
                                                    CLUTTER_GRAVITY_CENTER);
 | 
			
		||||
 | 
			
		||||
      clutter_actor_set_scale (actor, 0.0, 0.0);
 | 
			
		||||
      clutter_actor_set_pivot_point (actor, 0.5, 0.5);
 | 
			
		||||
      clutter_actor_set_opacity (actor, 0);
 | 
			
		||||
      clutter_actor_set_scale (actor, 0.5, 0.5);
 | 
			
		||||
      clutter_actor_show (actor);
 | 
			
		||||
 | 
			
		||||
      animation = clutter_actor_animate (actor,
 | 
			
		||||
                                         CLUTTER_EASE_IN_SINE,
 | 
			
		||||
                                         CLUTTER_EASE_OUT_QUAD,
 | 
			
		||||
                                         MAP_TIMEOUT,
 | 
			
		||||
                                         "opacity", 255,
 | 
			
		||||
                                         "scale-x", 1.0,
 | 
			
		||||
                                         "scale-y", 1.0,
 | 
			
		||||
                                         NULL);
 | 
			
		||||
@@ -765,14 +750,12 @@ destroy (MetaPlugin *plugin, MetaWindowActor *window_actor)
 | 
			
		||||
      EffectCompleteData *data = g_new0 (EffectCompleteData, 1);
 | 
			
		||||
      ActorPrivate *apriv = get_actor_private (window_actor);
 | 
			
		||||
 | 
			
		||||
      clutter_actor_move_anchor_point_from_gravity (actor,
 | 
			
		||||
                                                    CLUTTER_GRAVITY_CENTER);
 | 
			
		||||
 | 
			
		||||
      animation = clutter_actor_animate (actor,
 | 
			
		||||
                                         CLUTTER_EASE_IN_SINE,
 | 
			
		||||
                                         CLUTTER_EASE_OUT_QUAD,
 | 
			
		||||
                                         DESTROY_TIMEOUT,
 | 
			
		||||
                                         "scale-x", 0.0,
 | 
			
		||||
                                         "scale-y", 1.0,
 | 
			
		||||
                                         "opacity", 0,
 | 
			
		||||
                                         "scale-x", 0.8,
 | 
			
		||||
                                         "scale-y", 0.8,
 | 
			
		||||
                                         NULL);
 | 
			
		||||
      apriv->tml_destroy = clutter_animation_get_timeline (animation);
 | 
			
		||||
      data->plugin = plugin;
 | 
			
		||||
@@ -785,6 +768,82 @@ destroy (MetaPlugin *plugin, MetaWindowActor *window_actor)
 | 
			
		||||
    meta_plugin_destroy_completed (plugin, window_actor);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Tile preview private data accessor
 | 
			
		||||
 */
 | 
			
		||||
static void
 | 
			
		||||
free_screen_tile_preview (gpointer data)
 | 
			
		||||
{
 | 
			
		||||
  ScreenTilePreview *preview = data;
 | 
			
		||||
 | 
			
		||||
  if (G_LIKELY (preview != NULL)) {
 | 
			
		||||
    clutter_actor_destroy (preview->actor);
 | 
			
		||||
    g_slice_free (ScreenTilePreview, preview);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static ScreenTilePreview *
 | 
			
		||||
get_screen_tile_preview (MetaScreen *screen)
 | 
			
		||||
{
 | 
			
		||||
  ScreenTilePreview *preview = g_object_get_qdata (G_OBJECT (screen), screen_tile_preview_data_quark);
 | 
			
		||||
 | 
			
		||||
  if (G_UNLIKELY (screen_tile_preview_data_quark == 0))
 | 
			
		||||
    screen_tile_preview_data_quark = g_quark_from_static_string (SCREEN_TILE_PREVIEW_DATA_KEY);
 | 
			
		||||
 | 
			
		||||
  if (G_UNLIKELY (!preview))
 | 
			
		||||
    {
 | 
			
		||||
      preview = g_slice_new0 (ScreenTilePreview);
 | 
			
		||||
 | 
			
		||||
      preview->actor = clutter_actor_new ();
 | 
			
		||||
      clutter_actor_set_background_color (preview->actor, CLUTTER_COLOR_Blue);
 | 
			
		||||
      clutter_actor_set_opacity (preview->actor, 100);
 | 
			
		||||
 | 
			
		||||
      clutter_actor_add_child (meta_get_window_group_for_screen (screen), preview->actor);
 | 
			
		||||
      g_object_set_qdata_full (G_OBJECT (screen),
 | 
			
		||||
                               screen_tile_preview_data_quark, preview,
 | 
			
		||||
                               free_screen_tile_preview);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  return preview;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
show_tile_preview (MetaPlugin    *plugin,
 | 
			
		||||
                   MetaWindow    *window,
 | 
			
		||||
                   MetaRectangle *tile_rect,
 | 
			
		||||
                   int            tile_monitor_number)
 | 
			
		||||
{
 | 
			
		||||
  MetaScreen *screen = meta_plugin_get_screen (plugin);
 | 
			
		||||
  ScreenTilePreview *preview = get_screen_tile_preview (screen);
 | 
			
		||||
  ClutterActor *window_actor;
 | 
			
		||||
 | 
			
		||||
  if (CLUTTER_ACTOR_IS_VISIBLE (preview->actor)
 | 
			
		||||
      && preview->tile_rect.x == tile_rect->x
 | 
			
		||||
      && preview->tile_rect.y == tile_rect->y
 | 
			
		||||
      && preview->tile_rect.width == tile_rect->width
 | 
			
		||||
      && preview->tile_rect.height == tile_rect->height)
 | 
			
		||||
    return; /* nothing to do */
 | 
			
		||||
 | 
			
		||||
  clutter_actor_set_position (preview->actor, tile_rect->x, tile_rect->y);
 | 
			
		||||
  clutter_actor_set_size (preview->actor, tile_rect->width, tile_rect->height);
 | 
			
		||||
 | 
			
		||||
  clutter_actor_show (preview->actor);
 | 
			
		||||
 | 
			
		||||
  window_actor = CLUTTER_ACTOR (meta_window_get_compositor_private (window));
 | 
			
		||||
  clutter_actor_lower (preview->actor, window_actor);
 | 
			
		||||
 | 
			
		||||
  preview->tile_rect = *tile_rect;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
hide_tile_preview (MetaPlugin *plugin)
 | 
			
		||||
{
 | 
			
		||||
  MetaScreen *screen = meta_plugin_get_screen (plugin);
 | 
			
		||||
  ScreenTilePreview *preview = get_screen_tile_preview (screen);
 | 
			
		||||
 | 
			
		||||
  clutter_actor_hide (preview->actor);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
kill_switch_workspace (MetaPlugin     *plugin)
 | 
			
		||||
{
 | 
			
		||||
 
 | 
			
		||||
@@ -15,9 +15,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include "region-utils.h"
 | 
			
		||||
 
 | 
			
		||||
@@ -15,9 +15,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef __META_REGION_UTILS_H__
 | 
			
		||||
 
 | 
			
		||||
@@ -15,9 +15,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/* The standard cycle-windows keybinding should be the key above the
 | 
			
		||||
 
 | 
			
		||||
@@ -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)
 | 
			
		||||
    {
 | 
			
		||||
 
 | 
			
		||||
@@ -17,9 +17,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
@@ -53,94 +51,13 @@
 | 
			
		||||
#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
 | 
			
		||||
#include <canberra-gtk.h>
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * bell_flash_screen:
 | 
			
		||||
 * @display:  The display which owns the screen (rather redundant)
 | 
			
		||||
 * @screen:   The screen to flash
 | 
			
		||||
 *
 | 
			
		||||
 * Flashes one entire screen.  This is done by making a window the size of the
 | 
			
		||||
 * whole screen (or reusing the old one, if it's still around), mapping it,
 | 
			
		||||
 * painting it white and then black, and then unmapping it. We set saveunder so
 | 
			
		||||
 * that all the windows behind it come back immediately.
 | 
			
		||||
 *
 | 
			
		||||
 * Unlike frame flashes, we don't do fullscreen flashes with a timeout; rather,
 | 
			
		||||
 * we do them in one go, because we don't have to rely on the theme code
 | 
			
		||||
 * redrawing the frame for us in order to do the flash.
 | 
			
		||||
 */
 | 
			
		||||
/*
 | 
			
		||||
 * Bug: The way I read it, this appears not to do the flash
 | 
			
		||||
 * the first time we flash a particular display. Am I wrong?
 | 
			
		||||
 *
 | 
			
		||||
 * Bug: This appears to destroy our current XSync status.
 | 
			
		||||
 */
 | 
			
		||||
static void
 | 
			
		||||
bell_flash_screen (MetaDisplay *display, 
 | 
			
		||||
			MetaScreen  *screen)
 | 
			
		||||
{
 | 
			
		||||
  Window root = screen->xroot;
 | 
			
		||||
  int width = screen->rect.width;
 | 
			
		||||
  int height = screen->rect.height;
 | 
			
		||||
  
 | 
			
		||||
  if (screen->flash_window == None)
 | 
			
		||||
    {
 | 
			
		||||
      Visual *visual = (Visual *)CopyFromParent;
 | 
			
		||||
      XSetWindowAttributes xswa;
 | 
			
		||||
      int depth = CopyFromParent;
 | 
			
		||||
      xswa.save_under = True;
 | 
			
		||||
      xswa.override_redirect = True;
 | 
			
		||||
      /* 
 | 
			
		||||
       * TODO: use XGetVisualInfo and determine which is an
 | 
			
		||||
       * overlay, if one is present, and use the Overlay visual
 | 
			
		||||
       * for this window (for performance reasons).  
 | 
			
		||||
       * Not sure how to tell this yet... 
 | 
			
		||||
       */
 | 
			
		||||
      screen->flash_window = XCreateWindow (display->xdisplay, root,
 | 
			
		||||
					    0, 0, width, height,
 | 
			
		||||
					    0, depth,
 | 
			
		||||
					    InputOutput,
 | 
			
		||||
					    visual,
 | 
			
		||||
				    /* note: XSun doesn't like SaveUnder here */
 | 
			
		||||
					    CWSaveUnder | CWOverrideRedirect,
 | 
			
		||||
					    &xswa);
 | 
			
		||||
      XSelectInput (display->xdisplay, screen->flash_window, ExposureMask);
 | 
			
		||||
      XMapWindow (display->xdisplay, screen->flash_window);
 | 
			
		||||
      XSync (display->xdisplay, False);
 | 
			
		||||
      XFlush (display->xdisplay);
 | 
			
		||||
      XUnmapWindow (display->xdisplay, screen->flash_window);
 | 
			
		||||
    }
 | 
			
		||||
  else
 | 
			
		||||
    {
 | 
			
		||||
      /* just draw something in the window */
 | 
			
		||||
      GC gc = XCreateGC (display->xdisplay, screen->flash_window, 0, NULL);
 | 
			
		||||
      XMapWindow (display->xdisplay, screen->flash_window);
 | 
			
		||||
      XSetForeground (display->xdisplay, gc,
 | 
			
		||||
		      WhitePixel (display->xdisplay, 
 | 
			
		||||
				  XScreenNumberOfScreen (screen->xscreen)));
 | 
			
		||||
      XFillRectangle (display->xdisplay, screen->flash_window, gc,
 | 
			
		||||
		      0, 0, width, height);
 | 
			
		||||
      XSetForeground (display->xdisplay, gc,
 | 
			
		||||
		      BlackPixel (display->xdisplay, 
 | 
			
		||||
				  XScreenNumberOfScreen (screen->xscreen)));
 | 
			
		||||
      XFillRectangle (display->xdisplay, screen->flash_window, gc,
 | 
			
		||||
		      0, 0, width, height);
 | 
			
		||||
      XFlush (display->xdisplay);
 | 
			
		||||
      XSync (display->xdisplay, False);
 | 
			
		||||
      XUnmapWindow (display->xdisplay, screen->flash_window);
 | 
			
		||||
      XFreeGC (display->xdisplay, gc);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  if (meta_prefs_get_focus_mode () != G_DESKTOP_FOCUS_MODE_CLICK &&
 | 
			
		||||
      !display->mouse_mode)
 | 
			
		||||
    meta_display_increment_focus_sentinel (display);
 | 
			
		||||
  XFlush (display->xdisplay);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * bell_flash_fullscreen:
 | 
			
		||||
 * @display: The display the event came in on
 | 
			
		||||
@@ -165,12 +82,7 @@ bell_flash_fullscreen (MetaDisplay *display,
 | 
			
		||||
    {
 | 
			
		||||
      screen = meta_display_screen_for_xwindow (display, xkb_bell_ev->window);
 | 
			
		||||
      if (screen)
 | 
			
		||||
        {
 | 
			
		||||
          if (display->compositor)
 | 
			
		||||
            meta_compositor_flash_screen (display->compositor, screen);
 | 
			
		||||
          else
 | 
			
		||||
            bell_flash_screen (display, screen);
 | 
			
		||||
        }
 | 
			
		||||
        meta_compositor_flash_screen (display->compositor, screen);
 | 
			
		||||
    }
 | 
			
		||||
  else 
 | 
			
		||||
    {
 | 
			
		||||
@@ -178,10 +90,7 @@ bell_flash_fullscreen (MetaDisplay *display,
 | 
			
		||||
      while (screen_list) 
 | 
			
		||||
	{
 | 
			
		||||
	  screen = (MetaScreen *) screen_list->data;
 | 
			
		||||
          if (display->compositor)
 | 
			
		||||
            meta_compositor_flash_screen (display->compositor, screen);
 | 
			
		||||
          else
 | 
			
		||||
            bell_flash_screen (display, screen);
 | 
			
		||||
          meta_compositor_flash_screen (display->compositor, screen);
 | 
			
		||||
	  screen_list = screen_list->next;
 | 
			
		||||
	}
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
@@ -14,9 +14,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <X11/Xlib.h>
 | 
			
		||||
 
 | 
			
		||||
@@ -16,9 +16,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef META_BOXES_PRIVATE_H
 | 
			
		||||
 
 | 
			
		||||
@@ -25,9 +25,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include "boxes-private.h"
 | 
			
		||||
 
 | 
			
		||||
@@ -18,9 +18,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <config.h>
 | 
			
		||||
@@ -118,8 +116,6 @@ typedef struct
 | 
			
		||||
{
 | 
			
		||||
  MetaRectangle        orig;
 | 
			
		||||
  MetaRectangle        current;
 | 
			
		||||
  MetaFrameBorders    *borders;
 | 
			
		||||
  gboolean             must_free_borders;
 | 
			
		||||
  ActionType           action_type;
 | 
			
		||||
  gboolean             is_user_action;
 | 
			
		||||
 | 
			
		||||
@@ -195,7 +191,6 @@ static gboolean constrain_partially_onscreen (MetaWindow         *window,
 | 
			
		||||
 | 
			
		||||
static void setup_constraint_info        (ConstraintInfo      *info,
 | 
			
		||||
                                          MetaWindow          *window,
 | 
			
		||||
                                          MetaFrameBorders    *orig_borders,
 | 
			
		||||
                                          MetaMoveResizeFlags  flags,
 | 
			
		||||
                                          int                  resize_gravity,
 | 
			
		||||
                                          const MetaRectangle *orig,
 | 
			
		||||
@@ -204,13 +199,12 @@ static void place_window_if_needed       (MetaWindow     *window,
 | 
			
		||||
                                          ConstraintInfo *info);
 | 
			
		||||
static void update_onscreen_requirements (MetaWindow     *window,
 | 
			
		||||
                                          ConstraintInfo *info);
 | 
			
		||||
static void extend_by_frame              (MetaRectangle           *rect,
 | 
			
		||||
                                          const MetaFrameBorders  *borders);
 | 
			
		||||
static void unextend_by_frame            (MetaRectangle           *rect,
 | 
			
		||||
                                          const MetaFrameBorders  *borders);
 | 
			
		||||
static inline void get_size_limits       (const MetaWindow        *window,
 | 
			
		||||
                                          const MetaFrameBorders  *borders,
 | 
			
		||||
                                          gboolean include_frame,
 | 
			
		||||
static void extend_by_frame              (MetaWindow     *window,
 | 
			
		||||
                                          MetaRectangle  *rect);
 | 
			
		||||
static void unextend_by_frame            (MetaWindow     *window,
 | 
			
		||||
                                          MetaRectangle  *rect);
 | 
			
		||||
static inline void get_size_limits       (MetaWindow    *window,
 | 
			
		||||
                                          gboolean       include_frame,
 | 
			
		||||
                                          MetaRectangle *min_size,
 | 
			
		||||
                                          MetaRectangle *max_size);
 | 
			
		||||
 | 
			
		||||
@@ -280,7 +274,6 @@ do_all_constraints (MetaWindow         *window,
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_window_constrain (MetaWindow          *window,
 | 
			
		||||
                       MetaFrameBorders    *orig_borders,
 | 
			
		||||
                       MetaMoveResizeFlags  flags,
 | 
			
		||||
                       int                  resize_gravity,
 | 
			
		||||
                       const MetaRectangle *orig,
 | 
			
		||||
@@ -303,7 +296,6 @@ meta_window_constrain (MetaWindow          *window,
 | 
			
		||||
 | 
			
		||||
  setup_constraint_info (&info,
 | 
			
		||||
                         window, 
 | 
			
		||||
                         orig_borders,
 | 
			
		||||
                         flags,
 | 
			
		||||
                         resize_gravity,
 | 
			
		||||
                         orig,
 | 
			
		||||
@@ -333,19 +325,11 @@ meta_window_constrain (MetaWindow          *window,
 | 
			
		||||
   * if this was a user move or user move-and-resize operation.
 | 
			
		||||
   */
 | 
			
		||||
  update_onscreen_requirements (window, &info);
 | 
			
		||||
 | 
			
		||||
  /* Ew, what an ugly way to do things.  Destructors (in a real OOP language,
 | 
			
		||||
   * not gobject-style--gobject would be more pain than it's worth) or
 | 
			
		||||
   * smart pointers would be so much nicer here.  *shrug*
 | 
			
		||||
   */
 | 
			
		||||
  if (info.must_free_borders)
 | 
			
		||||
    g_free (info.borders);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
setup_constraint_info (ConstraintInfo      *info,
 | 
			
		||||
                       MetaWindow          *window,
 | 
			
		||||
                       MetaFrameBorders    *orig_borders,
 | 
			
		||||
                       MetaMoveResizeFlags  flags,
 | 
			
		||||
                       int                  resize_gravity,
 | 
			
		||||
                       const MetaRectangle *orig,
 | 
			
		||||
@@ -357,18 +341,6 @@ setup_constraint_info (ConstraintInfo      *info,
 | 
			
		||||
  info->orig    = *orig;
 | 
			
		||||
  info->current = *new;
 | 
			
		||||
 | 
			
		||||
  /* Create a fake frame geometry if none really exists */
 | 
			
		||||
  if (orig_borders && !window->fullscreen)
 | 
			
		||||
    {
 | 
			
		||||
      info->borders = orig_borders;
 | 
			
		||||
      info->must_free_borders = FALSE;
 | 
			
		||||
    }
 | 
			
		||||
  else
 | 
			
		||||
    {
 | 
			
		||||
      info->borders = g_new0 (MetaFrameBorders, 1);
 | 
			
		||||
      info->must_free_borders = TRUE;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  if (flags & META_IS_MOVE_ACTION && flags & META_IS_RESIZE_ACTION)
 | 
			
		||||
    info->action_type = ACTION_MOVE_AND_RESIZE;
 | 
			
		||||
  else if (flags & META_IS_RESIZE_ACTION)
 | 
			
		||||
@@ -447,12 +419,15 @@ setup_constraint_info (ConstraintInfo      *info,
 | 
			
		||||
 | 
			
		||||
  /* Workaround braindead legacy apps that don't know how to
 | 
			
		||||
   * fullscreen themselves properly - don't get fooled by
 | 
			
		||||
   * windows which hide their titlebar when maximized; that's
 | 
			
		||||
   * not the same as fullscreen, even if there are no struts
 | 
			
		||||
   * making the workarea smaller than the monitor.
 | 
			
		||||
   * windows which hide their titlebar when maximized or which are
 | 
			
		||||
   * client decorated; that's not the same as fullscreen, even
 | 
			
		||||
   * if there are no struts making the workarea smaller than
 | 
			
		||||
   * the monitor.
 | 
			
		||||
   */
 | 
			
		||||
  if (meta_prefs_get_force_fullscreen() &&
 | 
			
		||||
      window->client_type != META_WINDOW_CLIENT_TYPE_WAYLAND &&
 | 
			
		||||
      !window->hide_titlebar_when_maximized &&
 | 
			
		||||
      (window->decorated || !meta_window_is_client_decorated (window)) &&
 | 
			
		||||
      meta_rectangle_equal (new, &monitor_info->rect) &&
 | 
			
		||||
      window->has_fullscreen_func &&
 | 
			
		||||
      !window->fullscreen)
 | 
			
		||||
@@ -517,11 +492,17 @@ place_window_if_needed(MetaWindow     *window,
 | 
			
		||||
      !window->minimized &&
 | 
			
		||||
      !window->fullscreen)
 | 
			
		||||
    {
 | 
			
		||||
      MetaRectangle placed_rect = info->orig;
 | 
			
		||||
      MetaRectangle orig_rect;
 | 
			
		||||
      MetaRectangle placed_rect;
 | 
			
		||||
      MetaWorkspace *cur_workspace;
 | 
			
		||||
      const MetaMonitorInfo *monitor_info;
 | 
			
		||||
 | 
			
		||||
      meta_window_place (window, info->borders, info->orig.x, info->orig.y,
 | 
			
		||||
      meta_window_get_frame_rect (window, &placed_rect);
 | 
			
		||||
 | 
			
		||||
      orig_rect = info->orig;
 | 
			
		||||
      extend_by_frame (window, &orig_rect);
 | 
			
		||||
 | 
			
		||||
      meta_window_place (window, orig_rect.x, orig_rect.y,
 | 
			
		||||
                         &placed_rect.x, &placed_rect.y);
 | 
			
		||||
      did_placement = TRUE;
 | 
			
		||||
 | 
			
		||||
@@ -539,6 +520,7 @@ place_window_if_needed(MetaWindow     *window,
 | 
			
		||||
        meta_workspace_get_onmonitor_region (cur_workspace, 
 | 
			
		||||
                                             monitor_info->number);
 | 
			
		||||
 | 
			
		||||
      meta_window_frame_rect_to_client_rect (window, &placed_rect, &placed_rect);
 | 
			
		||||
 | 
			
		||||
      info->current.x = placed_rect.x;
 | 
			
		||||
      info->current.y = placed_rect.y;
 | 
			
		||||
@@ -584,10 +566,6 @@ place_window_if_needed(MetaWindow     *window,
 | 
			
		||||
                (window->maximize_vertically_after_placement ?
 | 
			
		||||
                 META_MAXIMIZE_VERTICAL : 0), &info->current);
 | 
			
		||||
 | 
			
		||||
          /* maximization may have changed frame geometry */
 | 
			
		||||
          if (!window->fullscreen)
 | 
			
		||||
            meta_frame_calc_borders (window->frame, info->borders);
 | 
			
		||||
 | 
			
		||||
          if (window->fullscreen_after_placement)
 | 
			
		||||
            {
 | 
			
		||||
              window->saved_rect = info->current;
 | 
			
		||||
@@ -647,7 +625,7 @@ update_onscreen_requirements (MetaWindow     *window,
 | 
			
		||||
  /* The require onscreen/on-single-monitor and titlebar_visible
 | 
			
		||||
   * stuff is relative to the outer window, not the inner
 | 
			
		||||
   */
 | 
			
		||||
  extend_by_frame (&info->current, info->borders);
 | 
			
		||||
  extend_by_frame (window, &info->current);
 | 
			
		||||
 | 
			
		||||
  /* Update whether we want future constraint runs to require the
 | 
			
		||||
   * window to be on fully onscreen.
 | 
			
		||||
@@ -680,10 +658,13 @@ update_onscreen_requirements (MetaWindow     *window,
 | 
			
		||||
   */
 | 
			
		||||
  if (window->frame && window->decorated)
 | 
			
		||||
    {
 | 
			
		||||
      MetaFrameBorders borders;
 | 
			
		||||
      MetaRectangle titlebar_rect;
 | 
			
		||||
 | 
			
		||||
      meta_frame_calc_borders (window->frame, &borders);
 | 
			
		||||
 | 
			
		||||
      titlebar_rect = info->current;
 | 
			
		||||
      titlebar_rect.height = info->borders->visible.top;
 | 
			
		||||
      titlebar_rect.height = borders.visible.top;
 | 
			
		||||
      old = window->require_titlebar_visible;
 | 
			
		||||
      window->require_titlebar_visible =
 | 
			
		||||
        meta_rectangle_overlaps_with_region (info->usable_screen_region,
 | 
			
		||||
@@ -696,39 +677,33 @@ update_onscreen_requirements (MetaWindow     *window,
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
  /* Don't forget to restore the position of the window */
 | 
			
		||||
  unextend_by_frame (&info->current, info->borders);
 | 
			
		||||
  unextend_by_frame (window, &info->current);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
extend_by_frame (MetaRectangle           *rect,
 | 
			
		||||
                 const MetaFrameBorders *borders)
 | 
			
		||||
extend_by_frame (MetaWindow    *window,
 | 
			
		||||
                 MetaRectangle *rect)
 | 
			
		||||
{
 | 
			
		||||
  rect->x -= borders->visible.left;
 | 
			
		||||
  rect->y -= borders->visible.top;
 | 
			
		||||
  rect->width  += borders->visible.left + borders->visible.right;
 | 
			
		||||
  rect->height += borders->visible.top + borders->visible.bottom;
 | 
			
		||||
  meta_window_client_rect_to_frame_rect (window, rect, rect);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
unextend_by_frame (MetaRectangle           *rect,
 | 
			
		||||
                   const MetaFrameBorders *borders)
 | 
			
		||||
unextend_by_frame (MetaWindow    *window,
 | 
			
		||||
                   MetaRectangle *rect)
 | 
			
		||||
{
 | 
			
		||||
  rect->x += borders->visible.left;
 | 
			
		||||
  rect->y += borders->visible.top;
 | 
			
		||||
  rect->width  -= borders->visible.left + borders->visible.right;
 | 
			
		||||
  rect->height -= borders->visible.top + borders->visible.bottom;
 | 
			
		||||
  meta_window_frame_rect_to_client_rect (window, rect, rect);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static inline void
 | 
			
		||||
get_size_limits (const MetaWindow        *window,
 | 
			
		||||
                 const MetaFrameBorders *borders,
 | 
			
		||||
                 gboolean                 include_frame,
 | 
			
		||||
get_size_limits (MetaWindow    *window,
 | 
			
		||||
                 gboolean       include_frame,
 | 
			
		||||
                 MetaRectangle *min_size,
 | 
			
		||||
                 MetaRectangle *max_size)
 | 
			
		||||
{
 | 
			
		||||
  /* We pack the results into MetaRectangle structs just for convienience; we
 | 
			
		||||
   * don't actually use the position of those rects.
 | 
			
		||||
   */
 | 
			
		||||
  min_size->x = min_size->y = max_size->x = max_size->y = 0;
 | 
			
		||||
  min_size->width  = window->size_hints.min_width;
 | 
			
		||||
  min_size->height = window->size_hints.min_height;
 | 
			
		||||
  max_size->width  = window->size_hints.max_width;
 | 
			
		||||
@@ -736,22 +711,8 @@ get_size_limits (const MetaWindow        *window,
 | 
			
		||||
 | 
			
		||||
  if (include_frame)
 | 
			
		||||
    {
 | 
			
		||||
      int fw = borders->visible.left + borders->visible.right;
 | 
			
		||||
      int fh = borders->visible.top + borders->visible.bottom;
 | 
			
		||||
 | 
			
		||||
      min_size->width  += fw;
 | 
			
		||||
      min_size->height += fh;
 | 
			
		||||
      /* Do check to avoid overflow (e.g. max_size->width & max_size->height
 | 
			
		||||
       * may be set to G_MAXINT by meta_set_normal_hints()).
 | 
			
		||||
       */
 | 
			
		||||
      if (max_size->width < (G_MAXINT - fw))
 | 
			
		||||
        max_size->width += fw;
 | 
			
		||||
      else
 | 
			
		||||
        max_size->width = G_MAXINT;
 | 
			
		||||
      if (max_size->height < (G_MAXINT - fh))
 | 
			
		||||
        max_size->height += fh;
 | 
			
		||||
      else
 | 
			
		||||
        max_size->height = G_MAXINT;
 | 
			
		||||
      meta_window_client_rect_to_frame_rect (window, min_size, min_size);
 | 
			
		||||
      meta_window_client_rect_to_frame_rect (window, max_size, max_size);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -763,18 +724,28 @@ constrain_modal_dialog (MetaWindow         *window,
 | 
			
		||||
{
 | 
			
		||||
  int x, y;
 | 
			
		||||
  MetaWindow *parent = meta_window_get_transient_for (window);
 | 
			
		||||
  MetaRectangle child_rect, parent_rect;
 | 
			
		||||
  gboolean constraint_already_satisfied;
 | 
			
		||||
 | 
			
		||||
  if (!meta_window_is_attached_dialog (window))
 | 
			
		||||
    return TRUE;
 | 
			
		||||
 | 
			
		||||
  x = parent->rect.x + (parent->rect.width / 2  - info->current.width / 2);
 | 
			
		||||
  y = parent->rect.y + (parent->rect.height / 2 - info->current.height / 2);
 | 
			
		||||
  if (parent->frame)
 | 
			
		||||
    {
 | 
			
		||||
      x += parent->frame->rect.x;
 | 
			
		||||
      y += parent->frame->rect.y;
 | 
			
		||||
    }
 | 
			
		||||
  /* We want to center the dialog on the parent, including the decorations
 | 
			
		||||
     for both of them. info->current is in client X window coordinates, so we need
 | 
			
		||||
     to convert them to frame coordinates, apply the centering and then
 | 
			
		||||
     convert back to client.
 | 
			
		||||
  */
 | 
			
		||||
 | 
			
		||||
  child_rect = info->current;
 | 
			
		||||
  extend_by_frame (window, &child_rect);
 | 
			
		||||
 | 
			
		||||
  meta_window_get_frame_rect (parent, &parent_rect);
 | 
			
		||||
 | 
			
		||||
  child_rect.x = parent_rect.x + (parent_rect.width / 2  - child_rect.width / 2);
 | 
			
		||||
  child_rect.y = parent_rect.y + (parent_rect.height / 2 - child_rect.height / 2);
 | 
			
		||||
  unextend_by_frame (window, &child_rect);
 | 
			
		||||
  x = child_rect.x;
 | 
			
		||||
  y = child_rect.y;
 | 
			
		||||
 | 
			
		||||
  constraint_already_satisfied = (x == info->current.x) && (y == info->current.y);
 | 
			
		||||
 | 
			
		||||
@@ -839,19 +810,19 @@ constrain_maximization (MetaWindow         *window,
 | 
			
		||||
      active_workspace_struts = window->screen->active_workspace->all_struts;
 | 
			
		||||
 | 
			
		||||
      target_size = info->current;
 | 
			
		||||
      extend_by_frame (&target_size, info->borders);
 | 
			
		||||
      extend_by_frame (window, &target_size);
 | 
			
		||||
      meta_rectangle_expand_to_avoiding_struts (&target_size,
 | 
			
		||||
                                                &info->entire_monitor,
 | 
			
		||||
                                                direction,
 | 
			
		||||
                                                active_workspace_struts);
 | 
			
		||||
   }
 | 
			
		||||
  /* Now make target_size = maximized size of client window */
 | 
			
		||||
  unextend_by_frame (&target_size, info->borders);
 | 
			
		||||
  unextend_by_frame (window, &target_size);
 | 
			
		||||
 | 
			
		||||
  /* Check min size constraints; max size constraints are ignored for maximized
 | 
			
		||||
   * windows, as per bug 327543.
 | 
			
		||||
   */
 | 
			
		||||
  get_size_limits (window, info->borders, FALSE, &min_size, &max_size);
 | 
			
		||||
  get_size_limits (window, FALSE, &min_size, &max_size);
 | 
			
		||||
  hminbad = target_size.width < min_size.width && window->maximized_horizontally;
 | 
			
		||||
  vminbad = target_size.height < min_size.height && window->maximized_vertically;
 | 
			
		||||
  if (hminbad || vminbad)
 | 
			
		||||
@@ -905,12 +876,12 @@ constrain_tiling (MetaWindow         *window,
 | 
			
		||||
   * use an external function for the actual calculation
 | 
			
		||||
   */
 | 
			
		||||
  meta_window_get_current_tile_area (window, &target_size);
 | 
			
		||||
  unextend_by_frame (&target_size, info->borders);
 | 
			
		||||
  unextend_by_frame (window, &target_size);
 | 
			
		||||
 | 
			
		||||
  /* Check min size constraints; max size constraints are ignored as for
 | 
			
		||||
   * maximized windows.
 | 
			
		||||
   */
 | 
			
		||||
  get_size_limits (window, info->borders, FALSE, &min_size, &max_size);
 | 
			
		||||
  get_size_limits (window, FALSE, &min_size, &max_size);
 | 
			
		||||
  hminbad = target_size.width < min_size.width;
 | 
			
		||||
  vminbad = target_size.height < min_size.height;
 | 
			
		||||
  if (hminbad || vminbad)
 | 
			
		||||
@@ -953,7 +924,7 @@ constrain_fullscreen (MetaWindow         *window,
 | 
			
		||||
 | 
			
		||||
  monitor = info->entire_monitor;
 | 
			
		||||
 | 
			
		||||
  get_size_limits (window, info->borders, FALSE, &min_size, &max_size);
 | 
			
		||||
  get_size_limits (window, FALSE, &min_size, &max_size);
 | 
			
		||||
  too_big =   !meta_rectangle_could_fit_rect (&monitor, &min_size);
 | 
			
		||||
  too_small = !meta_rectangle_could_fit_rect (&max_size, &monitor);
 | 
			
		||||
  if (too_big || too_small)
 | 
			
		||||
@@ -1062,7 +1033,7 @@ constrain_size_limits (MetaWindow         *window,
 | 
			
		||||
    return TRUE;
 | 
			
		||||
 | 
			
		||||
  /* Determine whether constraint is already satisfied; exit if it is */
 | 
			
		||||
  get_size_limits (window, info->borders, FALSE, &min_size, &max_size);
 | 
			
		||||
  get_size_limits (window, FALSE, &min_size, &max_size);
 | 
			
		||||
  /* We ignore max-size limits for maximized windows; see #327543 */
 | 
			
		||||
  if (window->maximized_horizontally)
 | 
			
		||||
    max_size.width = MAX (max_size.width, info->current.width);
 | 
			
		||||
@@ -1254,8 +1225,8 @@ do_screen_and_monitor_relative_constraints (
 | 
			
		||||
 | 
			
		||||
  /* Determine whether constraint applies; exit if it doesn't */
 | 
			
		||||
  how_far_it_can_be_smushed = info->current;
 | 
			
		||||
  get_size_limits (window, info->borders, TRUE, &min_size, &max_size);
 | 
			
		||||
  extend_by_frame (&info->current, info->borders);
 | 
			
		||||
  get_size_limits (window, TRUE, &min_size, &max_size);
 | 
			
		||||
  extend_by_frame (window, &info->current);
 | 
			
		||||
 | 
			
		||||
  if (info->action_type != ACTION_MOVE)
 | 
			
		||||
    {
 | 
			
		||||
@@ -1275,7 +1246,7 @@ do_screen_and_monitor_relative_constraints (
 | 
			
		||||
                                        &info->current);
 | 
			
		||||
  if (exit_early || constraint_satisfied || check_only)
 | 
			
		||||
    {
 | 
			
		||||
      unextend_by_frame (&info->current, info->borders);
 | 
			
		||||
      unextend_by_frame (window, &info->current);
 | 
			
		||||
      return constraint_satisfied;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
@@ -1299,7 +1270,7 @@ do_screen_and_monitor_relative_constraints (
 | 
			
		||||
                                      info->fixed_directions,
 | 
			
		||||
                                      &info->current);
 | 
			
		||||
 | 
			
		||||
  unextend_by_frame (&info->current, info->borders);
 | 
			
		||||
  unextend_by_frame (window, &info->current);
 | 
			
		||||
  return TRUE;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -1388,7 +1359,6 @@ constrain_titlebar_visible (MetaWindow         *window,
 | 
			
		||||
      window->type == META_WINDOW_DOCK    ||
 | 
			
		||||
      window->fullscreen                  ||
 | 
			
		||||
      !window->require_titlebar_visible   ||
 | 
			
		||||
      !window->decorated                  ||
 | 
			
		||||
      unconstrained_user_action)
 | 
			
		||||
    return TRUE;
 | 
			
		||||
 | 
			
		||||
@@ -1412,8 +1382,11 @@ constrain_titlebar_visible (MetaWindow         *window,
 | 
			
		||||
   */
 | 
			
		||||
  if (window->frame)
 | 
			
		||||
    {
 | 
			
		||||
      bottom_amount = info->current.height + info->borders->visible.bottom;
 | 
			
		||||
      vert_amount_onscreen = info->borders->visible.top;
 | 
			
		||||
      MetaFrameBorders borders;
 | 
			
		||||
      meta_frame_calc_borders (window->frame, &borders);
 | 
			
		||||
 | 
			
		||||
      bottom_amount = info->current.height + borders.visible.bottom;
 | 
			
		||||
      vert_amount_onscreen = borders.visible.top;
 | 
			
		||||
    }
 | 
			
		||||
  else
 | 
			
		||||
    bottom_amount = vert_amount_offscreen;
 | 
			
		||||
@@ -1487,8 +1460,11 @@ constrain_partially_onscreen (MetaWindow         *window,
 | 
			
		||||
   */
 | 
			
		||||
  if (window->frame)
 | 
			
		||||
    {
 | 
			
		||||
      bottom_amount = info->current.height + info->borders->visible.bottom;
 | 
			
		||||
      vert_amount_onscreen = info->borders->visible.top;
 | 
			
		||||
      MetaFrameBorders borders;
 | 
			
		||||
      meta_frame_calc_borders (window->frame, &borders);
 | 
			
		||||
 | 
			
		||||
      bottom_amount = info->current.height + borders.visible.bottom;
 | 
			
		||||
      vert_amount_onscreen = borders.visible.top;
 | 
			
		||||
    }
 | 
			
		||||
  else
 | 
			
		||||
    bottom_amount = vert_amount_offscreen;
 | 
			
		||||
 
 | 
			
		||||
@@ -17,9 +17,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef META_CONSTRAINTS_H
 | 
			
		||||
@@ -35,11 +33,11 @@ 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,
 | 
			
		||||
                            MetaFrameBorders    *orig_borders,
 | 
			
		||||
                            MetaMoveResizeFlags  flags,
 | 
			
		||||
                            int                  resize_gravity,
 | 
			
		||||
                            const MetaRectangle *orig,
 | 
			
		||||
 
 | 
			
		||||
@@ -18,9 +18,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <config.h>
 | 
			
		||||
@@ -29,6 +27,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.
 | 
			
		||||
@@ -89,7 +88,7 @@ meta_core_get (Display *xdisplay,
 | 
			
		||||
  if (request != META_CORE_WINDOW_HAS_FRAME &&
 | 
			
		||||
      (window == NULL || window->frame == NULL)) {
 | 
			
		||||
    meta_bug ("No such frame window 0x%lx!\n", xwindow);
 | 
			
		||||
    return;
 | 
			
		||||
    goto out;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  while (request != META_CORE_GET_END) {
 | 
			
		||||
@@ -99,7 +98,7 @@ meta_core_get (Display *xdisplay,
 | 
			
		||||
    switch (request) {
 | 
			
		||||
      case META_CORE_WINDOW_HAS_FRAME:
 | 
			
		||||
        *((gboolean*)answer) = window != NULL && window->frame != NULL;
 | 
			
		||||
        if (!*((gboolean*)answer)) return; /* see above */
 | 
			
		||||
        if (!*((gboolean*)answer)) goto out; /* see above */
 | 
			
		||||
        break; 
 | 
			
		||||
      case META_CORE_GET_CLIENT_WIDTH:
 | 
			
		||||
        *((gint*)answer) = window->rect.width;
 | 
			
		||||
@@ -154,12 +153,13 @@ 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);
 | 
			
		||||
  } 
 | 
			
		||||
 | 
			
		||||
 out:
 | 
			
		||||
  va_end (args);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@@ -170,6 +170,7 @@ meta_core_queue_frame_resize (Display *xdisplay,
 | 
			
		||||
  MetaWindow *window = get_window (xdisplay, frame_xwindow);
 | 
			
		||||
 | 
			
		||||
  meta_window_queue (window, META_QUEUE_MOVE_RESIZE);
 | 
			
		||||
  meta_window_frame_size_changed (window);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
@@ -280,8 +281,7 @@ meta_core_lower_beneath_grab_window (Display *xdisplay,
 | 
			
		||||
    return;
 | 
			
		||||
 | 
			
		||||
  changes.stack_mode = Below;
 | 
			
		||||
  changes.sibling = grab_window->frame ? grab_window->frame->xwindow
 | 
			
		||||
                                       : grab_window->xwindow;
 | 
			
		||||
  changes.sibling = meta_window_get_toplevel_xwindow (grab_window);
 | 
			
		||||
 | 
			
		||||
  stack_window.any.type = META_WINDOW_CLIENT_TYPE_X11;
 | 
			
		||||
  stack_window.x11.xwindow = xwindow;
 | 
			
		||||
@@ -328,8 +328,7 @@ meta_core_maximize (Display *xdisplay,
 | 
			
		||||
  if (meta_prefs_get_raise_on_click ())
 | 
			
		||||
    meta_window_raise (window);
 | 
			
		||||
 | 
			
		||||
  meta_window_maximize (window, 
 | 
			
		||||
                        META_MAXIMIZE_HORIZONTAL | META_MAXIMIZE_VERTICAL);
 | 
			
		||||
  meta_window_maximize (window, META_MAXIMIZE_BOTH);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
@@ -342,11 +341,9 @@ meta_core_toggle_maximize_vertically (Display *xdisplay,
 | 
			
		||||
    meta_window_raise (window);
 | 
			
		||||
 | 
			
		||||
  if (META_WINDOW_MAXIMIZED_VERTICALLY (window))
 | 
			
		||||
    meta_window_unmaximize (window, 
 | 
			
		||||
                            META_MAXIMIZE_VERTICAL);
 | 
			
		||||
    meta_window_unmaximize (window, META_MAXIMIZE_VERTICAL);
 | 
			
		||||
  else
 | 
			
		||||
    meta_window_maximize (window,
 | 
			
		||||
    			    META_MAXIMIZE_VERTICAL);
 | 
			
		||||
    meta_window_maximize (window, META_MAXIMIZE_VERTICAL);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
@@ -359,11 +356,9 @@ meta_core_toggle_maximize_horizontally (Display *xdisplay,
 | 
			
		||||
    meta_window_raise (window);
 | 
			
		||||
 | 
			
		||||
  if (META_WINDOW_MAXIMIZED_HORIZONTALLY (window))
 | 
			
		||||
    meta_window_unmaximize (window, 
 | 
			
		||||
                            META_MAXIMIZE_HORIZONTAL);
 | 
			
		||||
    meta_window_unmaximize (window, META_MAXIMIZE_HORIZONTAL);
 | 
			
		||||
  else
 | 
			
		||||
    meta_window_maximize (window,
 | 
			
		||||
    			    META_MAXIMIZE_HORIZONTAL);
 | 
			
		||||
    meta_window_maximize (window, META_MAXIMIZE_HORIZONTAL);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
@@ -376,11 +371,9 @@ meta_core_toggle_maximize (Display *xdisplay,
 | 
			
		||||
    meta_window_raise (window);
 | 
			
		||||
 | 
			
		||||
  if (META_WINDOW_MAXIMIZED (window))
 | 
			
		||||
    meta_window_unmaximize (window, 
 | 
			
		||||
                            META_MAXIMIZE_HORIZONTAL | META_MAXIMIZE_VERTICAL);
 | 
			
		||||
    meta_window_unmaximize (window, META_MAXIMIZE_BOTH);
 | 
			
		||||
  else
 | 
			
		||||
    meta_window_maximize (window,
 | 
			
		||||
                          META_MAXIMIZE_HORIZONTAL | META_MAXIMIZE_VERTICAL);
 | 
			
		||||
    meta_window_maximize (window, META_MAXIMIZE_BOTH);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
@@ -392,8 +385,7 @@ meta_core_unmaximize (Display *xdisplay,
 | 
			
		||||
  if (meta_prefs_get_raise_on_click ())
 | 
			
		||||
    meta_window_raise (window);
 | 
			
		||||
 | 
			
		||||
  meta_window_unmaximize (window,
 | 
			
		||||
                          META_MAXIMIZE_HORIZONTAL | META_MAXIMIZE_VERTICAL);
 | 
			
		||||
  meta_window_unmaximize (window, META_MAXIMIZE_BOTH);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
@@ -474,26 +466,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,
 | 
			
		||||
@@ -746,16 +718,6 @@ meta_core_set_screen_cursor (Display *xdisplay,
 | 
			
		||||
  meta_frame_set_screen_cursor (window->frame, cursor);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_core_increment_event_serial (Display *xdisplay)
 | 
			
		||||
{
 | 
			
		||||
  MetaDisplay *display;
 | 
			
		||||
  
 | 
			
		||||
  display = meta_display_for_x_display (xdisplay);
 | 
			
		||||
 | 
			
		||||
  meta_display_increment_event_serial (display);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_invalidate_default_icons (void)
 | 
			
		||||
{
 | 
			
		||||
 
 | 
			
		||||
@@ -17,9 +17,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef META_CORE_H
 | 
			
		||||
@@ -153,8 +151,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,
 | 
			
		||||
@@ -197,12 +193,6 @@ void       meta_core_set_screen_cursor (Display *xdisplay,
 | 
			
		||||
                                        Window   frame_on_screen,
 | 
			
		||||
                                        MetaCursor cursor);
 | 
			
		||||
 | 
			
		||||
/* Used because we ignore EnterNotify when a window is unmapped that
 | 
			
		||||
 * really shouldn't cause focus changes, by comparing the event serial
 | 
			
		||||
 * of the EnterNotify and the UnmapNotify.
 | 
			
		||||
 */
 | 
			
		||||
void meta_core_increment_event_serial (Display *display);
 | 
			
		||||
 | 
			
		||||
void meta_invalidate_default_icons (void);
 | 
			
		||||
 | 
			
		||||
void meta_core_add_old_event_mask (Display     *xdisplay,
 | 
			
		||||
 
 | 
			
		||||
@@ -17,15 +17,13 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#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,18 +37,17 @@
 | 
			
		||||
#include <stdlib.h>
 | 
			
		||||
#include <stdio.h>
 | 
			
		||||
 | 
			
		||||
#include "wayland/meta-wayland-surface.h"
 | 
			
		||||
 | 
			
		||||
static void meta_window_present_delete_dialog (MetaWindow *window,
 | 
			
		||||
                                               guint32     timestamp);
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
delete_ping_reply_func (MetaDisplay *display,
 | 
			
		||||
                        Window       xwindow,
 | 
			
		||||
delete_ping_reply_func (MetaWindow  *window,
 | 
			
		||||
                        guint32      timestamp,
 | 
			
		||||
                        void        *user_data)
 | 
			
		||||
{
 | 
			
		||||
  meta_topic (META_DEBUG_PING,
 | 
			
		||||
              "Got reply to delete ping for %s\n",
 | 
			
		||||
              ((MetaWindow*)user_data)->desc);
 | 
			
		||||
  meta_topic (META_DEBUG_PING, "Got reply to delete ping for %s\n", window->desc);
 | 
			
		||||
 | 
			
		||||
  /* we do nothing */
 | 
			
		||||
}
 | 
			
		||||
@@ -68,12 +65,10 @@ dialog_exited (GPid pid, int status, gpointer user_data)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static void
 | 
			
		||||
delete_ping_timeout_func (MetaDisplay *display,
 | 
			
		||||
                          Window       xwindow,
 | 
			
		||||
delete_ping_timeout_func (MetaWindow  *window,
 | 
			
		||||
                          guint32      timestamp,
 | 
			
		||||
                          void        *user_data)
 | 
			
		||||
{
 | 
			
		||||
  MetaWindow *window = user_data;
 | 
			
		||||
  char *window_title;
 | 
			
		||||
  gchar *window_content, *tmp;
 | 
			
		||||
  GPid dialog_pid;
 | 
			
		||||
@@ -137,36 +132,42 @@ void
 | 
			
		||||
meta_window_check_alive (MetaWindow *window,
 | 
			
		||||
                         guint32     timestamp)
 | 
			
		||||
{
 | 
			
		||||
  meta_display_ping_window (window->display,
 | 
			
		||||
                            window,
 | 
			
		||||
  meta_display_ping_window (window,
 | 
			
		||||
                            timestamp,
 | 
			
		||||
                            delete_ping_reply_func,
 | 
			
		||||
                            delete_ping_timeout_func,
 | 
			
		||||
                            window);
 | 
			
		||||
                            NULL);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
meta_window_delete (MetaWindow  *window,
 | 
			
		||||
                    guint32      timestamp)
 | 
			
		||||
{
 | 
			
		||||
  meta_error_trap_push (window->display);
 | 
			
		||||
  if (window->delete_window)
 | 
			
		||||
  if (window->client_type == META_WINDOW_CLIENT_TYPE_X11)
 | 
			
		||||
    {
 | 
			
		||||
      meta_topic (META_DEBUG_WINDOW_OPS,
 | 
			
		||||
                  "Deleting %s with delete_window request\n",
 | 
			
		||||
                  window->desc);
 | 
			
		||||
      meta_window_send_icccm_message (window,
 | 
			
		||||
                                      window->display->atom_WM_DELETE_WINDOW,
 | 
			
		||||
                                      timestamp);
 | 
			
		||||
      meta_error_trap_push (window->display);
 | 
			
		||||
      if (window->delete_window)
 | 
			
		||||
        {
 | 
			
		||||
          meta_topic (META_DEBUG_WINDOW_OPS,
 | 
			
		||||
                      "Deleting %s with delete_window request\n",
 | 
			
		||||
                      window->desc);
 | 
			
		||||
          meta_window_send_icccm_message (window,
 | 
			
		||||
                                          window->display->atom_WM_DELETE_WINDOW,
 | 
			
		||||
                                          timestamp);
 | 
			
		||||
        }
 | 
			
		||||
      else
 | 
			
		||||
        {
 | 
			
		||||
          meta_topic (META_DEBUG_WINDOW_OPS,
 | 
			
		||||
                      "Deleting %s with explicit kill\n",
 | 
			
		||||
                      window->desc);
 | 
			
		||||
          XKillClient (window->display->xdisplay, window->xwindow);
 | 
			
		||||
        }
 | 
			
		||||
      meta_error_trap_pop (window->display);
 | 
			
		||||
    }
 | 
			
		||||
  else
 | 
			
		||||
    {
 | 
			
		||||
      meta_topic (META_DEBUG_WINDOW_OPS,
 | 
			
		||||
                  "Deleting %s with explicit kill\n",
 | 
			
		||||
                  window->desc);
 | 
			
		||||
      XKillClient (window->display->xdisplay, window->xwindow);
 | 
			
		||||
      meta_wayland_surface_delete (window->surface);
 | 
			
		||||
    }
 | 
			
		||||
  meta_error_trap_pop (window->display);
 | 
			
		||||
 | 
			
		||||
  meta_window_check_alive (window, timestamp);
 | 
			
		||||
 | 
			
		||||
@@ -260,8 +261,7 @@ meta_window_present_delete_dialog (MetaWindow *window, guint32 timestamp)
 | 
			
		||||
        {
 | 
			
		||||
          MetaWindow *w = tmp->data;
 | 
			
		||||
 | 
			
		||||
          if (w->xtransient_for == window->xwindow &&
 | 
			
		||||
              w->res_class &&
 | 
			
		||||
          if (w->transient_for == window && w->res_class &&
 | 
			
		||||
              g_ascii_strcasecmp (w->res_class, "mutter-dialog") == 0)
 | 
			
		||||
            {
 | 
			
		||||
              meta_window_activate (w, timestamp);
 | 
			
		||||
 
 | 
			
		||||
@@ -19,9 +19,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef META_DISPLAY_PRIVATE_H
 | 
			
		||||
@@ -39,6 +37,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>
 | 
			
		||||
@@ -56,10 +55,9 @@ typedef struct _MetaWindowPropHooks MetaWindowPropHooks;
 | 
			
		||||
 | 
			
		||||
typedef struct MetaEdgeResistanceData MetaEdgeResistanceData;
 | 
			
		||||
 | 
			
		||||
typedef void (* MetaWindowPingFunc) (MetaDisplay *display,
 | 
			
		||||
				     Window       xwindow,
 | 
			
		||||
				     guint32      timestamp,
 | 
			
		||||
				     gpointer     user_data);
 | 
			
		||||
typedef void (* MetaWindowPingFunc) (MetaWindow  *window,
 | 
			
		||||
                                     guint32      timestamp,
 | 
			
		||||
                                     gpointer     user_data);
 | 
			
		||||
 | 
			
		||||
typedef enum {
 | 
			
		||||
  META_LIST_DEFAULT                   = 0,      /* normal windows */
 | 
			
		||||
@@ -86,14 +84,6 @@ 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;
 | 
			
		||||
@@ -101,6 +91,8 @@ struct _MetaDisplay
 | 
			
		||||
  char *name;
 | 
			
		||||
  Display *xdisplay;
 | 
			
		||||
 | 
			
		||||
  int clutter_event_filter;
 | 
			
		||||
 | 
			
		||||
  Window leader_window;
 | 
			
		||||
  Window timestamp_pinging_window;
 | 
			
		||||
 | 
			
		||||
@@ -125,7 +117,6 @@ 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;
 | 
			
		||||
@@ -147,6 +138,14 @@ struct _MetaDisplay
 | 
			
		||||
   */
 | 
			
		||||
  guint allow_terminal_deactivation : 1;
 | 
			
		||||
 | 
			
		||||
  /* If true, server->focus_serial refers to us changing the focus; in
 | 
			
		||||
   * this case, we can ignore focus events that have exactly focus_serial,
 | 
			
		||||
   * since we take care to make another request immediately afterwards.
 | 
			
		||||
   * But if focus is being changed by another client, we have to accept
 | 
			
		||||
   * multiple events with the same serial.
 | 
			
		||||
   */
 | 
			
		||||
  guint focused_by_us : 1;
 | 
			
		||||
 | 
			
		||||
  guint static_gravity_works : 1;
 | 
			
		||||
  
 | 
			
		||||
  /*< private-ish >*/
 | 
			
		||||
@@ -154,6 +153,7 @@ struct _MetaDisplay
 | 
			
		||||
  GSList *screens;
 | 
			
		||||
  MetaScreen *active_screen;
 | 
			
		||||
  GHashTable *xids;
 | 
			
		||||
  GHashTable *wayland_windows;
 | 
			
		||||
  int error_traps;
 | 
			
		||||
  int (* error_trap_handler) (Display     *display,
 | 
			
		||||
                              XErrorEvent *error);  
 | 
			
		||||
@@ -188,7 +188,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;
 | 
			
		||||
@@ -215,7 +215,6 @@ struct _MetaDisplay
 | 
			
		||||
  gboolean    grab_threshold_movement_reached; /* raise_on_click == FALSE.    */
 | 
			
		||||
  MetaResizePopup *grab_resize_popup;
 | 
			
		||||
  GTimeVal    grab_last_moveresize_time;
 | 
			
		||||
  guint32     grab_motion_notify_time;
 | 
			
		||||
  GList*      grab_old_window_stacking;
 | 
			
		||||
  MetaEdgeResistanceData *grab_edge_resistance_data;
 | 
			
		||||
  unsigned int grab_last_user_action_was_snap;
 | 
			
		||||
@@ -233,8 +232,8 @@ struct _MetaDisplay
 | 
			
		||||
  int	      grab_resize_timeout_id;
 | 
			
		||||
 | 
			
		||||
  /* Keybindings stuff */
 | 
			
		||||
  MetaKeyBinding *key_bindings;
 | 
			
		||||
  int             n_key_bindings;
 | 
			
		||||
  GHashTable     *key_bindings;
 | 
			
		||||
  GHashTable     *key_bindings_index;
 | 
			
		||||
  int             min_keycode;
 | 
			
		||||
  int             max_keycode;
 | 
			
		||||
  KeySym *keymap;
 | 
			
		||||
@@ -380,6 +379,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);
 | 
			
		||||
@@ -439,14 +443,13 @@ void meta_display_retheme_all (void);
 | 
			
		||||
void meta_display_set_cursor_theme (const char *theme, 
 | 
			
		||||
				    int         size);
 | 
			
		||||
 | 
			
		||||
void meta_display_ping_window      (MetaDisplay        *display,
 | 
			
		||||
                                    MetaWindow         *window,
 | 
			
		||||
void meta_display_ping_window      (MetaWindow         *window,
 | 
			
		||||
                                    guint32             timestamp,
 | 
			
		||||
                                    MetaWindowPingFunc  ping_reply_func,
 | 
			
		||||
                                    MetaWindowPingFunc  ping_timeout_func,
 | 
			
		||||
                                    void               *user_data);
 | 
			
		||||
gboolean meta_display_window_has_pending_pings (MetaDisplay        *display,
 | 
			
		||||
						MetaWindow         *window);
 | 
			
		||||
void meta_display_pong_for_serial  (MetaDisplay        *display,
 | 
			
		||||
                                    guint32             serial);
 | 
			
		||||
 | 
			
		||||
int meta_resize_gravity_from_grab_op (MetaGrabOp op);
 | 
			
		||||
 | 
			
		||||
@@ -467,27 +470,22 @@ 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_event (MetaDisplay *display,
 | 
			
		||||
                                    XEvent      *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,
 | 
			
		||||
                                           MetaFocusType  type,
 | 
			
		||||
                                           Window         window,
 | 
			
		||||
                                           guint32        timestamp);
 | 
			
		||||
void meta_display_set_input_focus_xwindow (MetaDisplay *display,
 | 
			
		||||
                                           MetaScreen  *screen,
 | 
			
		||||
                                           Window       window,
 | 
			
		||||
                                           guint32      timestamp);
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										2825
									
								
								src/core/display.c
									
									
									
									
									
								
							
							
						
						
									
										2825
									
								
								src/core/display.c
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -16,9 +16,7 @@
 | 
			
		||||
 * 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.
 | 
			
		||||
 * along with this program; if not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include <config.h>
 | 
			
		||||
@@ -985,7 +983,7 @@ compute_resistance_and_snapping_edges (MetaDisplay *display)
 | 
			
		||||
        {
 | 
			
		||||
          MetaRectangle *new_rect;
 | 
			
		||||
          new_rect = g_new (MetaRectangle, 1);
 | 
			
		||||
          meta_window_get_outer_rect (cur_window, new_rect);
 | 
			
		||||
          meta_window_get_frame_rect (cur_window, new_rect);
 | 
			
		||||
          obscuring_windows = g_slist_prepend (obscuring_windows, new_rect);
 | 
			
		||||
          window_stacking = 
 | 
			
		||||
            g_slist_prepend (window_stacking, GINT_TO_POINTER (stack_position));
 | 
			
		||||
@@ -1010,7 +1008,7 @@ compute_resistance_and_snapping_edges (MetaDisplay *display)
 | 
			
		||||
    {
 | 
			
		||||
      MetaRectangle  cur_rect;
 | 
			
		||||
      MetaWindow    *cur_window = cur_window_iter->data;
 | 
			
		||||
      meta_window_get_outer_rect (cur_window, &cur_rect);
 | 
			
		||||
      meta_window_get_frame_rect (cur_window, &cur_rect);
 | 
			
		||||
 | 
			
		||||
      /* Check if we want to use this window's edges for edge
 | 
			
		||||
       * resistance (note that dock edges are considered screen edges
 | 
			
		||||
@@ -1151,7 +1149,7 @@ meta_window_edge_resistance_for_move (MetaWindow  *window,
 | 
			
		||||
  MetaRectangle old_outer, proposed_outer, new_outer;
 | 
			
		||||
  gboolean is_resize;
 | 
			
		||||
 | 
			
		||||
  meta_window_get_outer_rect (window, &old_outer);
 | 
			
		||||
  meta_window_get_frame_rect (window, &old_outer);
 | 
			
		||||
 | 
			
		||||
  proposed_outer = old_outer;
 | 
			
		||||
  proposed_outer.x += (*new_x - old_x);
 | 
			
		||||
@@ -1237,7 +1235,7 @@ meta_window_edge_resistance_for_resize (MetaWindow  *window,
 | 
			
		||||
  int proposed_outer_width, proposed_outer_height;
 | 
			
		||||
  gboolean is_resize;
 | 
			
		||||
 | 
			
		||||
  meta_window_get_outer_rect (window, &old_outer);
 | 
			
		||||
  meta_window_get_frame_rect (window, &old_outer);
 | 
			
		||||
  proposed_outer_width  = old_outer.width  + (*new_width  - old_width);
 | 
			
		||||
  proposed_outer_height = old_outer.height + (*new_height - old_height);
 | 
			
		||||
  meta_rectangle_resize_with_gravity (&old_outer, 
 | 
			
		||||
 
 | 
			
		||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user