Compare commits
860 Commits
gnome-3-10
...
wip/ui-on-
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5bc7ae4095 | ||
|
|
1a78515606 | ||
|
|
4122257bce | ||
|
|
29f6e3bda5 | ||
|
|
bbcbf5820f | ||
|
|
ee7c58984a | ||
|
|
03e5bbf59f | ||
|
|
cc6becb163 | ||
|
|
e3b855a583 | ||
|
|
5d8dd0653e | ||
|
|
abe94827f5 | ||
|
|
72b88c929e | ||
|
|
4752776ebf | ||
|
|
c40868b239 | ||
|
|
a21e7a2188 | ||
|
|
371fba6843 | ||
|
|
be02fa1120 | ||
|
|
43730f1660 | ||
|
|
4f609dbf5e | ||
|
|
2a7d12ba14 | ||
|
|
c4c0b5f0ab | ||
|
|
8373c90cd8 | ||
|
|
eb5b54dd8b | ||
|
|
9653b79a35 | ||
|
|
e07bd15fc2 | ||
|
|
5cf0740b4e | ||
|
|
c540ddf59b | ||
|
|
a44295599c | ||
|
|
af272f2685 | ||
|
|
81d033ec73 | ||
|
|
e9ee984921 | ||
|
|
3c404c5db3 | ||
|
|
e4cd000cef | ||
|
|
6296fefea6 | ||
|
|
c1e3a6b742 | ||
|
|
dcd83b7365 | ||
|
|
617b00dfbd | ||
|
|
94692414cb | ||
|
|
ab6bc76bfd | ||
|
|
57803f1d59 | ||
|
|
67b6737b27 | ||
|
|
29396014fd | ||
|
|
899d4d8477 | ||
|
|
f1c7063ee7 | ||
|
|
216ff7ebe5 | ||
|
|
34cc5efb90 | ||
|
|
bce1d5117b | ||
|
|
d5552cc372 | ||
|
|
fd392cc1e7 | ||
|
|
b641d9d5a8 | ||
|
|
5bcc78498f | ||
|
|
521125b672 | ||
|
|
89b931435d | ||
|
|
e22e9f5df5 | ||
|
|
20547e3b63 | ||
|
|
2cf185b4e4 | ||
|
|
229360b248 | ||
|
|
ccced506ed | ||
|
|
28b9160c01 | ||
|
|
ba6584a0d7 | ||
|
|
2a0289a216 | ||
|
|
f6a73bcf22 | ||
|
|
59e064f610 | ||
|
|
ba131626c2 | ||
|
|
30ebf46aa4 | ||
|
|
da27735265 | ||
|
|
78dbf8cb56 | ||
|
|
f4e299ca46 | ||
|
|
f95f2b0c6d | ||
|
|
fe42a4eb4e | ||
|
|
565883dadb | ||
|
|
be60e4f6e7 | ||
|
|
fa60824096 | ||
|
|
0efb0b47eb | ||
|
|
0f810a4e21 | ||
|
|
383d4c7e4e | ||
|
|
21425b5833 | ||
|
|
863569b702 | ||
|
|
5f52f55916 | ||
|
|
0aec98cf02 | ||
|
|
b64d14ff4a | ||
|
|
08a8254deb | ||
|
|
11de01741c | ||
|
|
a7ea2cd365 | ||
|
|
a15a4faff0 | ||
|
|
b93176d89a | ||
|
|
f842ea6d15 | ||
|
|
422f2e5fe6 | ||
|
|
3961f291e4 | ||
|
|
61d8b35254 | ||
|
|
78457cf7b4 | ||
|
|
1e2bdcc3c5 | ||
|
|
490e1c8c3b | ||
|
|
9a751a95e3 | ||
|
|
afce448281 | ||
|
|
b2405b701a | ||
|
|
390c028da7 | ||
|
|
82e02e39d3 | ||
|
|
0f9b29b140 | ||
|
|
b367965f6c | ||
|
|
ed9dbf6aa2 | ||
|
|
e10fd19d24 | ||
|
|
f4f529385a | ||
|
|
3f70bdd331 | ||
|
|
6eeaf09ab7 | ||
|
|
cd905a34fb | ||
|
|
47aa583625 | ||
|
|
d7519f4ebc | ||
|
|
97ea4e8717 | ||
|
|
208296a619 | ||
|
|
cc0488f1e2 | ||
|
|
e30ed6892c | ||
|
|
d699b2409a | ||
|
|
ef65848d11 | ||
|
|
272676b896 | ||
|
|
44580ddb80 | ||
|
|
456e3e2429 | ||
|
|
eba848e8aa | ||
|
|
71be7e8493 | ||
|
|
7484d540cd | ||
|
|
a55622d924 | ||
|
|
1cfaf45389 | ||
|
|
42491f7724 | ||
|
|
9696e785da | ||
|
|
0de83ebfb5 | ||
|
|
337db2a660 | ||
|
|
054c307353 | ||
|
|
852589897e | ||
|
|
46b4d6c0f0 | ||
|
|
ab2224686a | ||
|
|
24b08d1a36 | ||
|
|
0808adefaf | ||
|
|
14f424cd02 | ||
|
|
9debd2fb0d | ||
|
|
57359da9b4 | ||
|
|
e67abdd3ff | ||
|
|
ca4777f778 | ||
|
|
76dc0ca681 | ||
|
|
8968501031 | ||
|
|
1b29113150 | ||
|
|
15c59f9919 | ||
|
|
a53e094fcd | ||
|
|
a377a1a110 | ||
|
|
74a1e00e30 | ||
|
|
1c41f71eef | ||
|
|
63350c52cc | ||
|
|
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 | ||
|
|
7d9141c56f | ||
|
|
519a06b93d | ||
|
|
0cceddab75 | ||
|
|
c9830c13b4 | ||
|
|
9a4783e364 | ||
|
|
aa15c09d54 | ||
|
|
62d908be42 | ||
|
|
6526e9882b | ||
|
|
ab72352c47 | ||
|
|
f09b9573f0 | ||
|
|
3d3ae40f79 | ||
|
|
ea3d2b4759 | ||
|
|
542a0886cf | ||
|
|
bd3d5df9ce | ||
|
|
91cdfab495 | ||
|
|
1617323dca | ||
|
|
bbf9358eba | ||
|
|
9682a2aea4 | ||
|
|
c9fbb51775 | ||
|
|
aa6d887214 | ||
|
|
13312527de | ||
|
|
9bd366f2a6 | ||
|
|
5de346bfef | ||
|
|
2af20b77b6 | ||
|
|
9affbf10a6 | ||
|
|
c0acf3ae6d | ||
|
|
2c1b20e15f | ||
|
|
77290b6736 | ||
|
|
876f81db12 | ||
|
|
75f3ae14b5 | ||
|
|
d26f248b0f | ||
|
|
eeb3dfc991 | ||
|
|
e66db2eab3 | ||
|
|
2ae7454f36 | ||
|
|
4fd3c63da9 | ||
|
|
bfc87d13cb | ||
|
|
24564c77d6 | ||
|
|
18a21b67c2 | ||
|
|
3803fd9511 | ||
|
|
152d896f75 | ||
|
|
2f3a5f2001 | ||
|
|
0e098249b1 | ||
|
|
9a5f243f73 | ||
|
|
03f55b9485 | ||
|
|
ef9ef87d91 | ||
|
|
0ee2c21da7 | ||
|
|
9b966561c4 | ||
|
|
8c0779a9db | ||
|
|
2c901cc015 | ||
|
|
85e66f69fa | ||
|
|
a5585327dc | ||
|
|
268ebb1b18 | ||
|
|
40e820f551 | ||
|
|
f9a11b3b18 | ||
|
|
bd3c357212 | ||
|
|
b4d108dac6 | ||
|
|
6585a5760b | ||
|
|
531be6c413 | ||
|
|
f0c503b5a9 |
28
.gitignore
vendored
28
.gitignore
vendored
@@ -23,7 +23,7 @@ src/50-mutter-navigation.xml
|
|||||||
src/50-mutter-system.xml
|
src/50-mutter-system.xml
|
||||||
src/50-mutter-windows.xml
|
src/50-mutter-windows.xml
|
||||||
src/mutter-wm.desktop
|
src/mutter-wm.desktop
|
||||||
src/mutter.desktop
|
src/mutter-wayland.desktop
|
||||||
*.o
|
*.o
|
||||||
*.a
|
*.a
|
||||||
*.lo
|
*.lo
|
||||||
@@ -46,16 +46,16 @@ POTFILES
|
|||||||
po/*.pot
|
po/*.pot
|
||||||
50-metacity-desktop-key.xml
|
50-metacity-desktop-key.xml
|
||||||
50-metacity-key.xml
|
50-metacity-key.xml
|
||||||
libmutter.pc
|
libmutter-wayland.pc
|
||||||
mutter
|
mutter-wayland
|
||||||
mutter-theme-viewer
|
mutter-launch
|
||||||
mutter.desktop
|
|
||||||
org.gnome.mutter.gschema.valid
|
org.gnome.mutter.gschema.valid
|
||||||
org.gnome.mutter.gschema.xml
|
org.gnome.mutter.gschema.xml
|
||||||
|
org.gnome.mutter.wayland.gschema.valid
|
||||||
|
org.gnome.mutter.wayland.gschema.xml
|
||||||
testasyncgetprop
|
testasyncgetprop
|
||||||
testboxes
|
testboxes
|
||||||
testgradient
|
testgradient
|
||||||
m4/*
|
|
||||||
mutter-grayscale
|
mutter-grayscale
|
||||||
mutter-mag
|
mutter-mag
|
||||||
mutter-message
|
mutter-message
|
||||||
@@ -75,9 +75,15 @@ src/mutter-enum-types.[ch]
|
|||||||
src/stamp-mutter-enum-types.h
|
src/stamp-mutter-enum-types.h
|
||||||
src/mutter-marshal.[ch]
|
src/mutter-marshal.[ch]
|
||||||
src/stamp-mutter-marshal.h
|
src/stamp-mutter-marshal.h
|
||||||
src/meta-dbus-xrandr.[ch]
|
src/meta-dbus-display-config.[ch]
|
||||||
src/meta-dbus-idle-monitor.[ch]
|
src/meta-dbus-idle-monitor.[ch]
|
||||||
src/mutter-plugins.pc
|
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/*.args
|
||||||
doc/reference/*.bak
|
doc/reference/*.bak
|
||||||
doc/reference/*.hierarchy
|
doc/reference/*.hierarchy
|
||||||
@@ -95,3 +101,11 @@ doc/reference/meta-undocumented.txt
|
|||||||
doc/reference/meta-unused.txt
|
doc/reference/meta-unused.txt
|
||||||
doc/reference/meta-docs.sgml
|
doc/reference/meta-docs.sgml
|
||||||
doc/reference/meta.types
|
doc/reference/meta.types
|
||||||
|
gtk-doc.m4
|
||||||
|
intltool.m4
|
||||||
|
libtool.m4
|
||||||
|
ltoptions.m4
|
||||||
|
ltsugar.m4
|
||||||
|
ltversion.m4
|
||||||
|
lt~obsolete.m4
|
||||||
|
.dirstamp
|
||||||
|
|||||||
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
|
GNU GENERAL PUBLIC LICENSE
|
||||||
Version 2, June 1991
|
Version 2, June 1991
|
||||||
|
|
||||||
Copyright (C) 1989, 1991 Free Software Foundation, Inc.
|
Copyright (C) 1989, 1991 Free Software Foundation, Inc.,
|
||||||
59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
Everyone is permitted to copy and distribute verbatim copies
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
of this license document, but changing it is not allowed.
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
Preamble
|
Preamble
|
||||||
|
|
||||||
The licenses for most software are designed to take away your
|
The licenses for most software are designed to take away your
|
||||||
freedom to share and change it. By contrast, the GNU General Public
|
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
|
General Public License applies to most of the Free Software
|
||||||
Foundation's software and to any other program whose authors commit to
|
Foundation's software and to any other program whose authors commit to
|
||||||
using it. (Some other Free Software Foundation software is covered by
|
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.
|
your programs, too.
|
||||||
|
|
||||||
When we speak of free software, we are referring to freedom, not
|
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
|
The precise terms and conditions for copying, distribution and
|
||||||
modification follow.
|
modification follow.
|
||||||
|
|
||||||
GNU GENERAL PUBLIC LICENSE
|
GNU GENERAL PUBLIC LICENSE
|
||||||
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||||
|
|
||||||
0. This License applies to any program or other work which contains
|
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
|
License. (Exception: if the Program itself is interactive but
|
||||||
does not normally print such an announcement, your work based on
|
does not normally print such an announcement, your work based on
|
||||||
the Program is not required to print an announcement.)
|
the Program is not required to print an announcement.)
|
||||||
|
|
||||||
These requirements apply to the modified work as a whole. If
|
These requirements apply to the modified work as a whole. If
|
||||||
identifiable sections of that work are not derived from the Program,
|
identifiable sections of that work are not derived from the Program,
|
||||||
and can be reasonably considered independent and separate works in
|
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
|
access to copy the source code from the same place counts as
|
||||||
distribution of the source code, even though third parties are not
|
distribution of the source code, even though third parties are not
|
||||||
compelled to copy the source along with the object code.
|
compelled to copy the source along with the object code.
|
||||||
|
|
||||||
4. You may not copy, modify, sublicense, or distribute the Program
|
4. You may not copy, modify, sublicense, or distribute the Program
|
||||||
except as expressly provided under this License. Any attempt
|
except as expressly provided under this License. Any attempt
|
||||||
otherwise to copy, modify, sublicense or distribute the Program is
|
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
|
This section is intended to make thoroughly clear what is believed to
|
||||||
be a consequence of the rest of this License.
|
be a consequence of the rest of this License.
|
||||||
|
|
||||||
8. If the distribution and/or use of the Program is restricted in
|
8. If the distribution and/or use of the Program is restricted in
|
||||||
certain countries either by patents or by copyrighted interfaces, the
|
certain countries either by patents or by copyrighted interfaces, the
|
||||||
original copyright holder who places the Program under this License
|
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 preserving the free status of all derivatives of our free software and
|
||||||
of promoting the sharing and reuse of software generally.
|
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
|
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
|
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
|
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
||||||
POSSIBILITY OF SUCH DAMAGES.
|
POSSIBILITY OF SUCH DAMAGES.
|
||||||
|
|
||||||
END OF TERMS AND CONDITIONS
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
How to Apply These Terms to Your New Programs
|
How to Apply These Terms to Your New Programs
|
||||||
|
|
||||||
If you develop a new program, and you want it to be of the greatest
|
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
|
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
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
GNU General Public License for more details.
|
GNU General Public License for more details.
|
||||||
|
|
||||||
You should have received a copy of the GNU General Public License
|
You should have received a copy of the GNU General Public License along
|
||||||
along with this program; if not, write to the Free Software
|
with this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
|
||||||
|
|
||||||
Also add information on how to contact you by electronic and paper mail.
|
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
|
If the program is interactive, make it output a short notice like this
|
||||||
when it starts in an interactive mode:
|
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'.
|
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||||
This is free software, and you are welcome to redistribute it
|
This is free software, and you are welcome to redistribute it
|
||||||
under certain conditions; type `show c' for details.
|
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
|
This General Public License does not permit incorporating your program into
|
||||||
proprietary programs. If your program is a subroutine library, you may
|
proprietary programs. If your program is a subroutine library, you may
|
||||||
consider it more useful to permit linking proprietary applications with the
|
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.
|
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,10 +1,8 @@
|
|||||||
|
|
||||||
SUBDIRS=src po doc
|
SUBDIRS=src po doc
|
||||||
|
|
||||||
ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS}
|
|
||||||
|
|
||||||
EXTRA_DIST = HACKING MAINTAINERS rationales.txt
|
|
||||||
|
|
||||||
DISTCLEANFILES = intltool-extract intltool-merge intltool-update po/stamp-it po/.intltool-merge-cache
|
DISTCLEANFILES = intltool-extract intltool-merge intltool-update po/stamp-it po/.intltool-merge-cache
|
||||||
|
|
||||||
DISTCHECK_CONFIGURE_FLAGS = --enable-gtk-doc
|
DISTCHECK_CONFIGURE_FLAGS = --enable-gtk-doc
|
||||||
|
|
||||||
|
ACLOCAL_AMFLAGS = -I m4 ${ACLOCAL_FLAGS}
|
||||||
|
|||||||
184
NEWS
184
NEWS
@@ -1,68 +1,127 @@
|
|||||||
3.10.4
|
3.12.0
|
||||||
|
======
|
||||||
|
* Fix grab issue with SSD xwayland windows [Rui; #726123]
|
||||||
|
* Misc. bug fixes [Jasper, Ray, Rui, Florian; #727011]
|
||||||
|
|
||||||
|
Contributors:
|
||||||
|
Rui Matos, Florian Müllner, Jasper St. Pierre, Ray Strode
|
||||||
|
|
||||||
|
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]
|
* Fix CSD titlebars being placed off-screen [Jasper; #719772]
|
||||||
|
* Add support for subsurfaces [Jonas; #705502]
|
||||||
* Expose MetaWindow:skip-taskbar property [Florian; #723307]
|
* Expose MetaWindow:skip-taskbar property [Florian; #723307]
|
||||||
* Fix legacy tray icons showing up blank [Adel; #721596]
|
* Fix legacy tray icons showing up blank [Adel; #721596]
|
||||||
* Fix configuration of cloned monitors [Adel; #710610]
|
* Fix configuration of cloned monitors [Adel; #710610]
|
||||||
* Use correct output property for backlight control [Robert; #723606]
|
* Misc bug fixes and cleanups [Jasper, Adel, Marek, Jonas; #720631, #723468,
|
||||||
* Misc. bug fixes [Jasper, Adel, Giovanni, Ryan; #720630, #723468, #724258,
|
#720818, #723563, #723564]
|
||||||
#724364]
|
|
||||||
|
|
||||||
Contributors:
|
Contributors:
|
||||||
Robert Ancell, Giovanni Campagna, Adel Gadllah, Ryan Lortie, Florian Müllner,
|
Jonas Ådahl, Marek Ch, Adel Gadllah, Florian Müllner, Jasper St. Pierre
|
||||||
Jasper St. Pierre
|
|
||||||
|
|
||||||
Translations:
|
3.11.4
|
||||||
Shankar Prasad [kn], Khaled Hosny [ar]
|
|
||||||
|
|
||||||
3.10.3
|
|
||||||
======
|
======
|
||||||
* xrandr: Use "hotplug_mode_update" property [Marc-André; #711216]
|
|
||||||
* Don't focus the no-focus-window for globally active windows [Jasper; #710296]
|
|
||||||
* Fix window group paint volume [Owen; #719669]
|
|
||||||
* Fix checks for KeyPress/ButtonPress [Jasper; #720545]
|
|
||||||
* Fix problems with focus tracking [Owen; #720558]
|
|
||||||
* Don't leave focus on windows that are being unmanaged [Owen; #711618]
|
* Don't leave focus on windows that are being unmanaged [Owen; #711618]
|
||||||
* Reduce server grabs [Daniel; #721345, #721709]
|
* 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:
|
Contributors:
|
||||||
Daniel Drake, Marc-André Lureau, Jasper St. Pierre, Owen W. Taylor
|
Cosimo Cecchi, Daniel Drake, Florian Müllner, Debarshi Ray, Jasper St. Pierre,
|
||||||
|
Andika Triwidada, Owen W. Taylor
|
||||||
|
|
||||||
Translations:
|
3.11.3
|
||||||
甘露(Gan Lu) [zh_CN]
|
|
||||||
|
|
||||||
3.10.2
|
|
||||||
======
|
======
|
||||||
|
* 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 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:
|
Contributors:
|
||||||
Lionel Landwerlin
|
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
|
||||||
|
|
||||||
Translations:
|
3.11.1
|
||||||
Efstathios Iosifidis [el], Reinout van Schouwen [nl]
|
======
|
||||||
|
* Fix tile previews getting stuck on right click during drags [Lionel; #704759]
|
||||||
3.10.1.1
|
* Use new UPower API [Bastien]
|
||||||
========
|
* Set hot spot when cursor set from wl_buffer [Jonas; #709593]
|
||||||
* Don't assert that at least one output is connected [Giovanni; #709009]
|
* Expose min-backlight-step [Asad; #710380]
|
||||||
|
* Misc. bug fixes and cleanups [Jasper, Olav, Magdalen; #709776]
|
||||||
|
|
||||||
Contributors:
|
Contributors:
|
||||||
Giovanni Campagna
|
Magdalen Berns, Lionel Landwerlin, Asad Mehmood, Bastien Nocera,
|
||||||
|
Jasper St. Pierre, Olav Vitters, Jonas Ådahl
|
||||||
|
|
||||||
3.10.1
|
3.10.1
|
||||||
======
|
======
|
||||||
* Don't apply fullscreen workarounds to CSD windows [Giovanni; #708718]
|
* Don't apply fullscreen workarounds to CSD windows [Giovanni; #708718]
|
||||||
* Fix hangs during DND operations [Adel; #709340]
|
* Fix hangs during DND operations [Adel; #709340]
|
||||||
* Use nearest-pixel interpolation when possible [Hans; #708389]
|
* Misc bug fixes [Dan, Giovanni, Jasper; #708813, #708420]
|
||||||
* Fix tile previews getting stuck on right click during drags [Lionel; #704759]
|
|
||||||
* Misc bug fixes [Giovanni, Jasper; #708420]
|
|
||||||
|
|
||||||
Contributors:
|
Contributors:
|
||||||
Giovanni Campagna, Adel Gadllah, Lionel Landwerlin, Hans Petter Jansson,
|
Giovanni Campagna, Adel Gadllah, Dan Horák, Hans Petter Jansson,
|
||||||
Jasper St. Pierre
|
Jasper St. Pierre
|
||||||
|
|
||||||
Translations:
|
|
||||||
Khaled Hosny [ar], Reinout van Schouwen [nl], Carles Ferrando [ca@valencia]
|
|
||||||
|
|
||||||
3.10.0.1
|
3.10.0.1
|
||||||
========
|
========
|
||||||
* Fix bug when a window changed size twice in a single frame - this
|
* Fix bug when a window changed size twice in a single frame - this
|
||||||
@@ -73,24 +132,32 @@ Contributors:
|
|||||||
|
|
||||||
3.10.0
|
3.10.0
|
||||||
======
|
======
|
||||||
|
* Update dependencies [Giovanni; #708210]
|
||||||
Translations:
|
|
||||||
Ask H. Larsen [da], Gabor Kelemen [hu], Duarte Loreto [pt],
|
|
||||||
Yosef Or Boczko [he]
|
|
||||||
|
|
||||||
3.9.92
|
3.9.92
|
||||||
======
|
======
|
||||||
* Don't create a dummy texture for the texture pipeline template [Neil; #707458]
|
* Constrain the pointer position onto visible monitors [Giovanni; #706655]
|
||||||
* Remove holes generated by disabling the laptop lid [Giovanni; #707473]
|
* Fix keyboard state handling in face of event compression [Giovanni; #706963]
|
||||||
* https://bugzilla.gnome.org/show_bug.cgi?id=707474 [Giovanni; #707474]
|
* 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]
|
* 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]
|
* 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]
|
* Immediately fire idle watches that are already expired [Giovanni; #707302]
|
||||||
* Misc bug fixes [Giovanni, Colin, Pavel; #707649, #707563, #708070]
|
* Remove holes generated by disabling the laptop lid [Giovanni; #707473]
|
||||||
|
* Misc bug fixes [Giovanni, Pavel, Adel; #707649, #706124, #707584, #707851, #707929,
|
||||||
|
#708070]
|
||||||
|
|
||||||
Contributors:
|
Contributors:
|
||||||
Giovanni Campagna, Adel Gadllah, Colin Guthrie, Neil Roberts,
|
Adel Gadllah, Giovanni Campagna, Kalev Lember, Pavel Vasin
|
||||||
Jasper St. Pierre, Ray Strode, Pavel Vasin
|
|
||||||
|
|
||||||
Translations:
|
Translations:
|
||||||
Мирослав Николић po/sr, sr@latin.po, Мирослав Николић [sr, sr@latin],
|
Мирослав Николић po/sr, sr@latin.po, Мирослав Николић [sr, sr@latin],
|
||||||
@@ -103,19 +170,30 @@ Translations:
|
|||||||
3.9.91
|
3.9.91
|
||||||
======
|
======
|
||||||
* Drop man pages for removed utilities [Kalev; #706579]
|
* Drop man pages for removed utilities [Kalev; #706579]
|
||||||
* Add support for idle tracking [Giovanni; #706005]
|
* Add support for idle tracking [Giovanni, Cosimo; #706005, #707250]
|
||||||
* Skip CRTC reconfigurations that have no effect [Giovanni; #706672]
|
* Skip CRTC reconfigurations that have no effect [Giovanni; #706672]
|
||||||
* Ignore skip-taskbar hints on parentless dialogs [Giovanni; #673399]
|
* Ignore skip-taskbar hints on parentless dialogs [Giovanni; #673399]
|
||||||
* Don't save pixbuf data in user data [Tim; #706777]
|
* Don't save pixbuf data in user data [Tim; #706777]
|
||||||
* Don't queue redraws for obscured regions [Adel; #703332]
|
* Don't queue redraws for obscured regions [Adel; #703332]
|
||||||
* Turn blending off when drawing entirely opaque regions [Jasper; #706930]
|
* Suppor the opaque region hints for wayland clients [Jasper; #707019]
|
||||||
|
* Turn blending off when drawing entirely opaque regions [Jasper; #707019]
|
||||||
* Check event timestamps before reconfiguring [Giovanni; #706735]
|
* 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,
|
* Misc bug fixes [Giovanni, Colin, Seán, Jasper, Cosimo; #706582, #706598,
|
||||||
#706787, #706729, #706825, #707081, #707090, #707250, #707267]
|
#706787, #706729, #706825, #707081, #707090, #707267, #706982, #706289]
|
||||||
|
|
||||||
Contributors:
|
Contributors:
|
||||||
Giovanni Campagna, Cosimo Cecchi, Adel Gadllah, Colin Guthrie, Kalev Lember,
|
Giovanni Campagna, Cosimo Cecchi, Adel Gadllah, Colin Guthrie, Kalev Lember,
|
||||||
Tim Lunn, Jasper St. Pierre, Rico Tzschichholz, Seán de Búrca
|
Tim Lunn, Jasper St. Pierre, Neil Roberts, Rico Tzschichholz, Seán de Búrca
|
||||||
|
|
||||||
Translations:
|
Translations:
|
||||||
Piotr Drąg [pl], Alexandre Franke [fr], Kjartan Maraas [nb],
|
Piotr Drąg [pl], Alexandre Franke [fr], Kjartan Maraas [nb],
|
||||||
@@ -124,6 +202,8 @@ Translations:
|
|||||||
|
|
||||||
3.9.90
|
3.9.90
|
||||||
======
|
======
|
||||||
|
* First release from the wayland branch, includes basic support for running
|
||||||
|
as a wayland compositor [Robert, Neil, Giovanni]
|
||||||
* Add support for _GTK_FRAME_EXTENTS [Jasper; #705766]
|
* Add support for _GTK_FRAME_EXTENTS [Jasper; #705766]
|
||||||
* Fix quick consecutive <super> presses breaking keyboard input [Alban; #666101]
|
* Fix quick consecutive <super> presses breaking keyboard input [Alban; #666101]
|
||||||
* Work towards running as wayland compositor [Giovanni]
|
* Work towards running as wayland compositor [Giovanni]
|
||||||
@@ -138,8 +218,8 @@ Translations:
|
|||||||
|
|
||||||
Contributors:
|
Contributors:
|
||||||
Robert Bragg, Giovanni Campagna, Alban Crequy, Adel Gadllah,
|
Robert Bragg, Giovanni Campagna, Alban Crequy, Adel Gadllah,
|
||||||
Alexander Larsson, Florian Müllner, Jasper St. Pierre, Rico Tzschichholz,
|
Alexander Larsson, Florian Müllner, Jasper St. Pierre, Neil Roberts,
|
||||||
Colin Walters
|
Rico Tzschichholz, Colin Walters
|
||||||
|
|
||||||
Translations:
|
Translations:
|
||||||
Jiro Matsuzawa [ja], Kjartan Maraas [nb], Matej Urbančič [sl],
|
Jiro Matsuzawa [ja], Kjartan Maraas [nb], Matej Urbančič [sl],
|
||||||
|
|||||||
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,4 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/sh
|
||||||
# Run this to generate all the initial makefiles, etc.
|
# Run this to generate all the initial makefiles, etc.
|
||||||
|
|
||||||
srcdir=`dirname $0`
|
srcdir=`dirname $0`
|
||||||
|
|||||||
63
configure.ac
63
configure.ac
@@ -1,8 +1,9 @@
|
|||||||
AC_PREREQ(2.50)
|
AC_PREREQ(2.50)
|
||||||
|
AC_CONFIG_MACRO_DIR([m4])
|
||||||
|
|
||||||
m4_define([mutter_major_version], [3])
|
m4_define([mutter_major_version], [3])
|
||||||
m4_define([mutter_minor_version], [10])
|
m4_define([mutter_minor_version], [12])
|
||||||
m4_define([mutter_micro_version], [4])
|
m4_define([mutter_micro_version], [0])
|
||||||
|
|
||||||
m4_define([mutter_version],
|
m4_define([mutter_version],
|
||||||
[mutter_major_version.mutter_minor_version.mutter_micro_version])
|
[mutter_major_version.mutter_minor_version.mutter_micro_version])
|
||||||
@@ -12,14 +13,17 @@ m4_define([mutter_plugin_api_version], [3])
|
|||||||
AC_INIT([mutter], [mutter_version],
|
AC_INIT([mutter], [mutter_version],
|
||||||
[http://bugzilla.gnome.org/enter_bug.cgi?product=mutter])
|
[http://bugzilla.gnome.org/enter_bug.cgi?product=mutter])
|
||||||
|
|
||||||
AC_CONFIG_MACRO_DIR([m4])
|
|
||||||
AC_CONFIG_SRCDIR(src/core/display.c)
|
AC_CONFIG_SRCDIR(src/core/display.c)
|
||||||
AC_CONFIG_HEADERS(config.h)
|
AC_CONFIG_HEADERS(config.h)
|
||||||
|
|
||||||
AM_INIT_AUTOMAKE([1.11 no-dist-gzip dist-xz tar-ustar])
|
AM_INIT_AUTOMAKE([1.11 foreign no-dist-gzip dist-xz tar-ustar subdir-objects])
|
||||||
m4_ifdef([AM_SILENT_RULES],[AM_SILENT_RULES([yes])],)
|
m4_ifdef([AM_SILENT_RULES],[AM_SILENT_RULES([yes])],)
|
||||||
AM_MAINTAINER_MODE([enable])
|
AM_MAINTAINER_MODE([enable])
|
||||||
|
|
||||||
|
# Change pkglibdir and pkgdatadir to mutter-wayland instead of mutter
|
||||||
|
PACKAGE="mutter-wayland"
|
||||||
|
AC_SUBST([PACKAGE], [$PACKAGE])
|
||||||
|
|
||||||
MUTTER_MAJOR_VERSION=mutter_major_version
|
MUTTER_MAJOR_VERSION=mutter_major_version
|
||||||
MUTTER_MINOR_VERSION=mutter_minor_version
|
MUTTER_MINOR_VERSION=mutter_minor_version
|
||||||
MUTTER_MICRO_VERSION=mutter_micro_version
|
MUTTER_MICRO_VERSION=mutter_micro_version
|
||||||
@@ -35,7 +39,7 @@ AC_SUBST(MUTTER_PLUGIN_DIR)
|
|||||||
# Honor aclocal flags
|
# Honor aclocal flags
|
||||||
AC_SUBST(ACLOCAL_AMFLAGS, "\${ACLOCAL_FLAGS}")
|
AC_SUBST(ACLOCAL_AMFLAGS, "\${ACLOCAL_FLAGS}")
|
||||||
|
|
||||||
GETTEXT_PACKAGE=mutter
|
GETTEXT_PACKAGE=mutter-wayland
|
||||||
AC_SUBST(GETTEXT_PACKAGE)
|
AC_SUBST(GETTEXT_PACKAGE)
|
||||||
AC_DEFINE_UNQUOTED(GETTEXT_PACKAGE,"$GETTEXT_PACKAGE",[Name of default gettext domain])
|
AC_DEFINE_UNQUOTED(GETTEXT_PACKAGE,"$GETTEXT_PACKAGE",[Name of default gettext domain])
|
||||||
|
|
||||||
@@ -68,15 +72,15 @@ CANBERRA_GTK_VERSION=0.26
|
|||||||
CLUTTER_PACKAGE=clutter-1.0
|
CLUTTER_PACKAGE=clutter-1.0
|
||||||
|
|
||||||
MUTTER_PC_MODULES="
|
MUTTER_PC_MODULES="
|
||||||
gtk+-3.0 >= 3.9.11
|
gtk+-3.0 >= 3.3.7
|
||||||
gio-2.0 >= 2.25.10
|
gio-2.0 >= 2.25.10
|
||||||
pango >= 1.2.0
|
pango >= 1.2.0
|
||||||
cairo >= 1.10.0
|
cairo >= 1.10.0
|
||||||
gsettings-desktop-schemas >= 3.7.3
|
gsettings-desktop-schemas >= 3.7.3
|
||||||
xcomposite >= 0.2 xfixes xrender xdamage xi >= 1.6.0
|
xcomposite >= 0.2 xfixes xrender xdamage xi >= 1.6.0
|
||||||
$CLUTTER_PACKAGE >= 1.15.90
|
$CLUTTER_PACKAGE >= 1.17.5
|
||||||
cogl-1.0 >= 1.15.6
|
cogl-1.0 >= 1.17.1
|
||||||
upower-glib > 0.9.11
|
upower-glib >= 0.99.0
|
||||||
gnome-desktop-3.0
|
gnome-desktop-3.0
|
||||||
"
|
"
|
||||||
|
|
||||||
@@ -116,11 +120,27 @@ AC_ARG_ENABLE(shape,
|
|||||||
[disable mutter's use of the shaped window extension]),,
|
[disable mutter's use of the shaped window extension]),,
|
||||||
enable_shape=auto)
|
enable_shape=auto)
|
||||||
|
|
||||||
|
## Wayland support requires the xserver.xml protocol extension found in the weston
|
||||||
|
## repository but since there aren't currently established conventions for
|
||||||
|
## installing and discovering these we simply require a location to be given
|
||||||
|
## explicitly...
|
||||||
|
AC_ARG_WITH([wayland-protocols],
|
||||||
|
[AS_HELP_STRING([--with-wayland-protocols], [Location for wayland extension protocol specs])],
|
||||||
|
[
|
||||||
|
],
|
||||||
|
[])
|
||||||
|
|
||||||
|
AC_ARG_WITH([xwayland-path],
|
||||||
|
[AS_HELP_STRING([--with-xwayland-path], [Absolute path for an X Wayland server])],
|
||||||
|
[XWAYLAND_PATH="$withval"],
|
||||||
|
[XWAYLAND_PATH="$bindir/Xwayland"])
|
||||||
|
|
||||||
AM_GLIB_GNU_GETTEXT
|
AM_GLIB_GNU_GETTEXT
|
||||||
|
|
||||||
## here we get the flags we'll actually use
|
## here we get the flags we'll actually use
|
||||||
# GRegex requires Glib-2.14.0
|
# GRegex requires Glib-2.14.0
|
||||||
PKG_CHECK_MODULES(ALL, glib-2.0 >= 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
|
# Unconditionally use this dir to avoid a circular dep with gnomecc
|
||||||
GNOME_KEYBINDINGS_KEYSDIR="${datadir}/gnome-control-center/keybindings"
|
GNOME_KEYBINDINGS_KEYSDIR="${datadir}/gnome-control-center/keybindings"
|
||||||
@@ -185,20 +205,15 @@ if test x$found_introspection != xno; then
|
|||||||
AC_SUBST(META_GIR)
|
AC_SUBST(META_GIR)
|
||||||
fi
|
fi
|
||||||
|
|
||||||
AC_MSG_CHECKING([Xcursor])
|
MUTTER_PC_MODULES="$MUTTER_PC_MODULES 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
|
AC_PATH_PROG([WAYLAND_SCANNER],[wayland-scanner],[no])
|
||||||
echo "Building with Xcursor"
|
AS_IF([test "x$WAYLAND_SCANNER" = "xno"],
|
||||||
MUTTER_PC_MODULES="$MUTTER_PC_MODULES xcursor"
|
AC_MSG_ERROR([Could not find wayland-scanner in your PATH, required for parsing wayland extension protocols]))
|
||||||
AC_DEFINE(HAVE_XCURSOR, , [Building with Xcursor support])
|
AC_SUBST([WAYLAND_SCANNER])
|
||||||
fi
|
AC_SUBST(XWAYLAND_PATH)
|
||||||
|
|
||||||
|
MUTTER_PC_MODULES="$MUTTER_PC_MODULES clutter-wayland-1.0 clutter-wayland-compositor-1.0 clutter-egl-1.0 wayland-server libdrm"
|
||||||
PKG_CHECK_MODULES(MUTTER, $MUTTER_PC_MODULES)
|
PKG_CHECK_MODULES(MUTTER, $MUTTER_PC_MODULES)
|
||||||
|
|
||||||
PKG_CHECK_EXISTS([xi >= 1.6.99.1],
|
PKG_CHECK_EXISTS([xi >= 1.6.99.1],
|
||||||
@@ -436,8 +451,7 @@ doc/man/Makefile
|
|||||||
doc/reference/Makefile
|
doc/reference/Makefile
|
||||||
doc/reference/meta-docs.sgml
|
doc/reference/meta-docs.sgml
|
||||||
src/Makefile
|
src/Makefile
|
||||||
src/libmutter.pc
|
src/libmutter-wayland.pc
|
||||||
src/mutter-plugins.pc
|
|
||||||
src/compositor/plugins/Makefile
|
src/compositor/plugins/Makefile
|
||||||
po/Makefile.in
|
po/Makefile.in
|
||||||
])
|
])
|
||||||
@@ -454,7 +468,7 @@ fi
|
|||||||
|
|
||||||
dnl ==========================================================================
|
dnl ==========================================================================
|
||||||
echo "
|
echo "
|
||||||
mutter-$VERSION
|
mutter-wayland-$VERSION
|
||||||
|
|
||||||
prefix: ${prefix}
|
prefix: ${prefix}
|
||||||
source code location: ${srcdir}
|
source code location: ${srcdir}
|
||||||
@@ -466,7 +480,6 @@ mutter-$VERSION
|
|||||||
Session management: ${found_sm}
|
Session management: ${found_sm}
|
||||||
Shape extension: ${found_shape}
|
Shape extension: ${found_shape}
|
||||||
Xsync: ${found_xsync}
|
Xsync: ${found_xsync}
|
||||||
Xcursor: ${have_xcursor}
|
|
||||||
"
|
"
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
SUBDIRS = man reference
|
SUBDIRS = man reference
|
||||||
|
|
||||||
EXTRA_DIST=theme-format.txt dialogs.txt code-overview.txt \
|
EXTRA_DIST=theme-format.txt dialogs.txt code-overview.txt \
|
||||||
how-to-get-focus-right.txt
|
how-to-get-focus-right.txt rationales.txt
|
||||||
|
|||||||
@@ -49,8 +49,8 @@ FIXXREF_OPTIONS=
|
|||||||
# Used for dependencies. The docs will be rebuilt if any of these change.
|
# Used for dependencies. The docs will be rebuilt if any of these change.
|
||||||
# e.g. HFILE_GLOB=$(top_srcdir)/gtk/*.h
|
# e.g. HFILE_GLOB=$(top_srcdir)/gtk/*.h
|
||||||
# e.g. CFILE_GLOB=$(top_srcdir)/gtk/*.c
|
# e.g. CFILE_GLOB=$(top_srcdir)/gtk/*.c
|
||||||
HFILE_GLOB=$(top_srcdir)/src/*.h
|
HFILE_GLOB=$(top_srcdir)/src/*/*.h
|
||||||
CFILE_GLOB=$(top_srcdir)/src/*.c
|
CFILE_GLOB=$(top_srcdir)/src/*/*.c
|
||||||
|
|
||||||
# Extra header to include when scanning, which are not under DOC_SOURCE_DIR
|
# Extra header to include when scanning, which are not under DOC_SOURCE_DIR
|
||||||
# e.g. EXTRA_HFILES=$(top_srcdir}/contrib/extra.h
|
# e.g. EXTRA_HFILES=$(top_srcdir}/contrib/extra.h
|
||||||
@@ -140,7 +140,7 @@ expand_content_files= \
|
|||||||
# e.g. GTKDOC_CFLAGS=-I$(top_srcdir) -I$(top_builddir) $(GTK_DEBUG_FLAGS)
|
# e.g. GTKDOC_CFLAGS=-I$(top_srcdir) -I$(top_builddir) $(GTK_DEBUG_FLAGS)
|
||||||
# e.g. GTKDOC_LIBS=$(top_builddir)/gtk/$(gtktargetlib)
|
# e.g. GTKDOC_LIBS=$(top_builddir)/gtk/$(gtktargetlib)
|
||||||
GTKDOC_CFLAGS=$(MUTTER_CFLAGS)
|
GTKDOC_CFLAGS=$(MUTTER_CFLAGS)
|
||||||
GTKDOC_LIBS=$(MUTTER_LIBS) $(top_builddir)/src/libmutter.la
|
GTKDOC_LIBS=$(MUTTER_LIBS) $(top_builddir)/src/libmutter-wayland.la
|
||||||
|
|
||||||
# This includes the standard gtk-doc make rules, copied by gtkdocize.
|
# This includes the standard gtk-doc make rules, copied by gtkdocize.
|
||||||
include $(top_srcdir)/gtk-doc.make
|
include $(top_srcdir)/gtk-doc.make
|
||||||
|
|||||||
@@ -96,8 +96,6 @@ meta_compositor_hide_window
|
|||||||
meta_compositor_switch_workspace
|
meta_compositor_switch_workspace
|
||||||
meta_compositor_maximize_window
|
meta_compositor_maximize_window
|
||||||
meta_compositor_unmaximize_window
|
meta_compositor_unmaximize_window
|
||||||
meta_compositor_window_mapped
|
|
||||||
meta_compositor_window_unmapped
|
|
||||||
meta_compositor_sync_window_geometry
|
meta_compositor_sync_window_geometry
|
||||||
meta_compositor_set_updates_frozen
|
meta_compositor_set_updates_frozen
|
||||||
meta_compositor_queue_frame_drawn
|
meta_compositor_queue_frame_drawn
|
||||||
@@ -207,7 +205,6 @@ meta_key_binding_get_modifiers
|
|||||||
meta_key_binding_get_mask
|
meta_key_binding_get_mask
|
||||||
meta_key_binding_is_builtin
|
meta_key_binding_is_builtin
|
||||||
meta_keybindings_set_custom_handler
|
meta_keybindings_set_custom_handler
|
||||||
meta_keybindings_switch_window
|
|
||||||
meta_screen_ungrab_all_keys
|
meta_screen_ungrab_all_keys
|
||||||
meta_screen_grab_all_keys
|
meta_screen_grab_all_keys
|
||||||
</SECTION>
|
</SECTION>
|
||||||
@@ -389,6 +386,23 @@ MetaWindowActorPrivate
|
|||||||
meta_window_actor_get_type
|
meta_window_actor_get_type
|
||||||
</SECTION>
|
</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>
|
<SECTION>
|
||||||
<FILE>prefs</FILE>
|
<FILE>prefs</FILE>
|
||||||
MetaPreference
|
MetaPreference
|
||||||
@@ -542,7 +556,10 @@ meta_window_is_override_redirect
|
|||||||
meta_window_is_skip_taskbar
|
meta_window_is_skip_taskbar
|
||||||
meta_window_get_rect
|
meta_window_get_rect
|
||||||
meta_window_get_input_rect
|
meta_window_get_input_rect
|
||||||
|
meta_window_get_frame_rect
|
||||||
meta_window_get_outer_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_screen
|
||||||
meta_window_get_display
|
meta_window_get_display
|
||||||
meta_window_get_xwindow
|
meta_window_get_xwindow
|
||||||
|
|||||||
@@ -21,6 +21,7 @@ environment.</description>
|
|||||||
-->
|
-->
|
||||||
<mailing-list rdf:resource="http://mail.gnome.org/mailman/listinfo/gnome-shell-list" />
|
<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/" />
|
||||||
|
<download-page rdf:resource="http://download.gnome.org/sources/mutter-wayland/" />
|
||||||
<bug-database rdf:resource="http://bugzilla.gnome.org/browse.cgi?product=mutter" />
|
<bug-database rdf:resource="http://bugzilla.gnome.org/browse.cgi?product=mutter" />
|
||||||
|
|
||||||
<category rdf:resource="http://api.gnome.org/doap-extensions#desktop" />
|
<category rdf:resource="http://api.gnome.org/doap-extensions#desktop" />
|
||||||
|
|||||||
@@ -16,14 +16,14 @@ src/core/monitor.c
|
|||||||
src/core/mutter.c
|
src/core/mutter.c
|
||||||
src/core/prefs.c
|
src/core/prefs.c
|
||||||
src/core/screen.c
|
src/core/screen.c
|
||||||
src/core/session.c
|
src/x11/session.c
|
||||||
src/core/util.c
|
src/core/util.c
|
||||||
src/core/window.c
|
src/core/window.c
|
||||||
src/core/window-props.c
|
src/x11/window-props.c
|
||||||
src/core/xprops.c
|
src/x11/xprops.c
|
||||||
src/mutter.desktop.in
|
src/mutter-wayland.desktop.in
|
||||||
src/mutter-wm.desktop.in
|
|
||||||
src/org.gnome.mutter.gschema.xml.in
|
src/org.gnome.mutter.gschema.xml.in
|
||||||
|
src/org.gnome.mutter.wayland.gschema.xml.in
|
||||||
src/ui/frames.c
|
src/ui/frames.c
|
||||||
src/ui/menu.c
|
src/ui/menu.c
|
||||||
src/ui/metaaccellabel.c
|
src/ui/metaaccellabel.c
|
||||||
|
|||||||
2834
po/ca@valencia.po
2834
po/ca@valencia.po
File diff suppressed because it is too large
Load Diff
353
po/cs.po
353
po/cs.po
@@ -6,23 +6,22 @@
|
|||||||
# Petr Tomeš <ptomes@gmail.com>, 2006.
|
# Petr Tomeš <ptomes@gmail.com>, 2006.
|
||||||
# Jakub Friedl <jfriedl@suse.cz>, 2006, 2007.
|
# Jakub Friedl <jfriedl@suse.cz>, 2006, 2007.
|
||||||
# Petr Kovar <pknbe@volny.cz>, 2007, 2008, 2009, 2010, 2011, 2012, 2013.
|
# Petr Kovar <pknbe@volny.cz>, 2007, 2008, 2009, 2010, 2011, 2012, 2013.
|
||||||
# Marek Černocký <marek@manet.cz>, 2012, 2013.
|
# Marek Černocký <marek@manet.cz>, 2012.
|
||||||
#
|
|
||||||
msgid ""
|
msgid ""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: mutter\n"
|
"Project-Id-Version: mutter\n"
|
||||||
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?"
|
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?product=mutter"
|
||||||
"product=mutter&keywords=I18N+L10N&component=general\n"
|
"&keywords=I18N+L10N&component=general\n"
|
||||||
"POT-Creation-Date: 2013-08-18 20:03+0000\n"
|
"POT-Creation-Date: 2013-03-22 10:02+0000\n"
|
||||||
"PO-Revision-Date: 2013-08-20 08:50+0200\n"
|
"PO-Revision-Date: 2013-03-24 20:55+0200\n"
|
||||||
"Last-Translator: Marek Černocký <marek@manet.cz>\n"
|
"Last-Translator: Petr Kovar <pknbe@volny.cz>\n"
|
||||||
"Language-Team: Czech <gnome-cs-list@gnome.org>\n"
|
"Language-Team: Czech <gnome-cs-list@gnome.org>\n"
|
||||||
"Language: cs\n"
|
"Language: cs\n"
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
"Content-Type: text/plain; charset=UTF-8\n"
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
"Content-Transfer-Encoding: 8bit\n"
|
"Content-Transfer-Encoding: 8bit\n"
|
||||||
"Plural-Forms: nplurals=3; plural=(n==1) ? 0 : (n>=2 && n<=4) ? 1 : 2;\n"
|
"Plural-Forms: nplurals=3; plural=(n==1) ? 0 : (n>=2 && n<=4) ? 1 : 2;\n"
|
||||||
"X-Generator: Gtranslator 2.91.6\n"
|
"X-Generator: Virtaal 0.7.1\n"
|
||||||
"X-Project-Style: gnome\n"
|
"X-Project-Style: gnome\n"
|
||||||
|
|
||||||
#: ../src/50-mutter-navigation.xml.in.h:1
|
#: ../src/50-mutter-navigation.xml.in.h:1
|
||||||
@@ -187,8 +186,7 @@ msgstr "Přepnout výskyt okna na všech plochách nebo jen na jedné"
|
|||||||
|
|
||||||
#: ../src/50-mutter-windows.xml.in.h:13
|
#: ../src/50-mutter-windows.xml.in.h:13
|
||||||
msgid "Raise window if covered, otherwise lower it"
|
msgid "Raise window if covered, otherwise lower it"
|
||||||
msgstr ""
|
msgstr "Přenést okno do popředí, pokud je zakryté, jinak jej odsunout do pozadí"
|
||||||
"Přenést okno do popředí, pokud je zakryté, jinak jej odsunout do pozadí"
|
|
||||||
|
|
||||||
#: ../src/50-mutter-windows.xml.in.h:14
|
#: ../src/50-mutter-windows.xml.in.h:14
|
||||||
msgid "Raise window above other windows"
|
msgid "Raise window above other windows"
|
||||||
@@ -216,14 +214,14 @@ msgstr "Zobrazit rozdělení napravo"
|
|||||||
|
|
||||||
#. This probably means that a non-WM compositor like xcompmgr is running;
|
#. This probably means that a non-WM compositor like xcompmgr is running;
|
||||||
#. * we have no way to get it to exit
|
#. * we have no way to get it to exit
|
||||||
#: ../src/compositor/compositor.c:589
|
#: ../src/compositor/compositor.c:568
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Another compositing manager is already running on screen %i on display \"%s"
|
"Another compositing manager is already running on screen %i on display \"%s"
|
||||||
"\"."
|
"\"."
|
||||||
msgstr "Jiný kompozitní správce již běží na obrazovce %i displeje „%s“."
|
msgstr "Jiný kompozitní správce již běží na obrazovce %i displeje „%s“."
|
||||||
|
|
||||||
#: ../src/compositor/meta-background.c:1076
|
#: ../src/compositor/meta-background.c:1191
|
||||||
msgid "background texture could not be created from file"
|
msgid "background texture could not be created from file"
|
||||||
msgstr "textura pozadí nemohla být ze souboru vytvořena"
|
msgstr "textura pozadí nemohla být ze souboru vytvořena"
|
||||||
|
|
||||||
@@ -261,17 +259,17 @@ msgstr "_Počkat"
|
|||||||
msgid "_Force Quit"
|
msgid "_Force Quit"
|
||||||
msgstr "_Vynutit ukončení"
|
msgstr "_Vynutit ukončení"
|
||||||
|
|
||||||
#: ../src/core/display.c:421
|
#: ../src/core/display.c:401
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Missing %s extension required for compositing"
|
msgid "Missing %s extension required for compositing"
|
||||||
msgstr "Schází rozšíření %s vyžadované funkcemi kompozitoru"
|
msgstr "Schází rozšíření %s vyžadované funkcemi kompozitoru"
|
||||||
|
|
||||||
#: ../src/core/display.c:513
|
#: ../src/core/display.c:493
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open X Window System display '%s'\n"
|
msgid "Failed to open X Window System display '%s'\n"
|
||||||
msgstr "Nelze otevřít displej X Window System „%s“\n"
|
msgstr "Nelze otevřít displej X Window System „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1136
|
#: ../src/core/keybindings.c:935
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Some other program is already using the key %s with modifiers %x as a "
|
"Some other program is already using the key %s with modifiers %x as a "
|
||||||
@@ -279,8 +277,9 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Klávesu %s s modifikátory %x již jako zkratku používá nějaký jiný program\n"
|
"Klávesu %s s modifikátory %x již jako zkratku používá nějaký jiný program\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1333
|
#: ../src/core/keybindings.c:1135
|
||||||
#, c-format
|
#, c-format
|
||||||
|
#| msgid "\"%s\" is not a valid value for focus attribute"
|
||||||
msgid "\"%s\" is not a valid accelerator\n"
|
msgid "\"%s\" is not a valid accelerator\n"
|
||||||
msgstr "„%s“ není platný akcelerátor\n"
|
msgstr "„%s“ není platný akcelerátor\n"
|
||||||
|
|
||||||
@@ -321,19 +320,6 @@ msgstr ""
|
|||||||
"Nelze najít motiv! Ujistěte se prosím, že existuje %s a obsahuje obvyklé "
|
"Nelze najít motiv! Ujistěte se prosím, že existuje %s a obsahuje obvyklé "
|
||||||
"motivy.\n"
|
"motivy.\n"
|
||||||
|
|
||||||
#: ../src/core/monitor.c:711
|
|
||||||
msgid "Built-in display"
|
|
||||||
msgstr "Vestavěný displej"
|
|
||||||
|
|
||||||
#. TRANSLATORS: this is a monitor name (in case we don't know
|
|
||||||
#. the vendor), it's Unknown followed by a size in inches,
|
|
||||||
#. like 'Unknown 15"'
|
|
||||||
#.
|
|
||||||
#: ../src/core/monitor.c:739
|
|
||||||
#, c-format
|
|
||||||
msgid "Unknown %s"
|
|
||||||
msgstr "Neznámý %s"
|
|
||||||
|
|
||||||
#: ../src/core/mutter.c:40
|
#: ../src/core/mutter.c:40
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
@@ -358,7 +344,7 @@ msgstr "Vypíše verzi"
|
|||||||
msgid "Mutter plugin to use"
|
msgid "Mutter plugin to use"
|
||||||
msgstr "Zásuvný modul Mutter, který se má použít"
|
msgstr "Zásuvný modul Mutter, který se má použít"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1202
|
#: ../src/core/prefs.c:1095
|
||||||
msgid ""
|
msgid ""
|
||||||
"Workarounds for broken applications disabled. Some applications may not "
|
"Workarounds for broken applications disabled. Some applications may not "
|
||||||
"behave properly.\n"
|
"behave properly.\n"
|
||||||
@@ -366,12 +352,12 @@ msgstr ""
|
|||||||
"Bylo zakázáno obcházení chyb aplikací. Některé aplikace se možná nebudou "
|
"Bylo zakázáno obcházení chyb aplikací. Některé aplikace se možná nebudou "
|
||||||
"chovat správně.\n"
|
"chovat správně.\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1277
|
#: ../src/core/prefs.c:1170
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
||||||
msgstr "Nelze zpracovat popis písma „%s“ v klíči GSettings %s\n"
|
msgstr "Nelze zpracovat popis písma „%s“ v klíči GSettings %s\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1343
|
#: ../src/core/prefs.c:1236
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for mouse button "
|
"\"%s\" found in configuration database is not a valid value for mouse button "
|
||||||
@@ -380,7 +366,7 @@ msgstr ""
|
|||||||
"„%s“ nalezené v databázi nastavení není platnou hodnotou modifikátoru "
|
"„%s“ nalezené v databázi nastavení není platnou hodnotou modifikátoru "
|
||||||
"tlačítka myši\n"
|
"tlačítka myši\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1909
|
#: ../src/core/prefs.c:1788
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for keybinding "
|
"\"%s\" found in configuration database is not a valid value for keybinding "
|
||||||
@@ -389,17 +375,17 @@ msgstr ""
|
|||||||
"„%s“ nalezené v databázi nastavení není platnou hodnotou klávesové zkratky "
|
"„%s“ nalezené v databázi nastavení není platnou hodnotou klávesové zkratky "
|
||||||
"„%s“\n"
|
"„%s“\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1999
|
#: ../src/core/prefs.c:1887
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d"
|
msgid "Workspace %d"
|
||||||
msgstr "Plocha %d"
|
msgstr "Plocha %d"
|
||||||
|
|
||||||
#: ../src/core/screen.c:534
|
#: ../src/core/screen.c:691
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display '%s' is invalid\n"
|
msgid "Screen %d on display '%s' is invalid\n"
|
||||||
msgstr "Obrazovka %d na displeji „%s“ je neplatná\n"
|
msgstr "Obrazovka %d na displeji „%s“ je neplatná\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:550
|
#: ../src/core/screen.c:707
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
||||||
@@ -408,18 +394,18 @@ msgstr ""
|
|||||||
"Obrazovka %d na displeji „%s“ již správce oken má; zkuste prosím nahradit "
|
"Obrazovka %d na displeji „%s“ již správce oken má; zkuste prosím nahradit "
|
||||||
"aktuálního správce oken pomocí přepínače --replace.\n"
|
"aktuálního správce oken pomocí přepínače --replace.\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:577
|
#: ../src/core/screen.c:734
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
||||||
msgstr "Nelze získat výběr správce oken na obrazovce %d displeje „%s“\n"
|
msgstr "Nelze získat výběr správce oken na obrazovce %d displeje „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:655
|
#: ../src/core/screen.c:812
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
||||||
msgstr "Obrazovka %d na displeji „%s“ již má správce oken\n"
|
msgstr "Obrazovka %d na displeji „%s“ již má správce oken\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:846
|
#: ../src/core/screen.c:998
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not release screen %d on display \"%s\"\n"
|
msgid "Could not release screen %d on display \"%s\"\n"
|
||||||
msgstr "Nelze uvolnit obrazovku %d na displeji „%s“\n"
|
msgstr "Nelze uvolnit obrazovku %d na displeji „%s“\n"
|
||||||
@@ -494,7 +480,8 @@ msgstr "Nelze provést fdopen() soubor záznamu %s: %s\n"
|
|||||||
msgid "Opened log file %s\n"
|
msgid "Opened log file %s\n"
|
||||||
msgstr "Otevřen soubor záznamu %s\n"
|
msgstr "Otevřen soubor záznamu %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:119
|
#: ../src/core/util.c:119 ../src/tools/mutter-message.c:149
|
||||||
|
#, c-format
|
||||||
msgid "Mutter was compiled without support for verbose mode\n"
|
msgid "Mutter was compiled without support for verbose mode\n"
|
||||||
msgstr "Mutter bylo přeloženo bez podpory podrobného režimu\n"
|
msgstr "Mutter bylo přeloženo bez podpory podrobného režimu\n"
|
||||||
|
|
||||||
@@ -502,20 +489,20 @@ msgstr "Mutter bylo přeloženo bez podpory podrobného režimu\n"
|
|||||||
msgid "Window manager: "
|
msgid "Window manager: "
|
||||||
msgstr "Správce oken: "
|
msgstr "Správce oken: "
|
||||||
|
|
||||||
#: ../src/core/util.c:414
|
#: ../src/core/util.c:412
|
||||||
msgid "Bug in window manager: "
|
msgid "Bug in window manager: "
|
||||||
msgstr "Chyba ve správci oken: "
|
msgstr "Chyba ve správci oken: "
|
||||||
|
|
||||||
#: ../src/core/util.c:445
|
#: ../src/core/util.c:443
|
||||||
msgid "Window manager warning: "
|
msgid "Window manager warning: "
|
||||||
msgstr "Varování správce oken: "
|
msgstr "Varování správce oken: "
|
||||||
|
|
||||||
#: ../src/core/util.c:473
|
#: ../src/core/util.c:471
|
||||||
msgid "Window manager error: "
|
msgid "Window manager error: "
|
||||||
msgstr "Chyba správce oken: "
|
msgstr "Chyba správce oken: "
|
||||||
|
|
||||||
#. first time through
|
#. first time through
|
||||||
#: ../src/core/window.c:7533
|
#: ../src/core/window.c:7596
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
||||||
@@ -531,7 +518,7 @@ msgstr ""
|
|||||||
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
||||||
#. * about these apps but make them work.
|
#. * about these apps but make them work.
|
||||||
#.
|
#.
|
||||||
#: ../src/core/window.c:8257
|
#: ../src/core/window.c:8320
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
||||||
@@ -541,22 +528,22 @@ msgstr ""
|
|||||||
"velikost, ale nastavuje min. velikost %d × %d a max. velikost %d × %d; to "
|
"velikost, ale nastavuje min. velikost %d × %d a max. velikost %d × %d; to "
|
||||||
"nedává smysl.\n"
|
"nedává smysl.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:347
|
#: ../src/core/window-props.c:318
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
||||||
msgstr "Aplikace nastavila neplatný _NET_WM_PID %lu\n"
|
msgstr "Aplikace nastavila neplatný _NET_WM_PID %lu\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:463
|
#: ../src/core/window-props.c:434
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s (on %s)"
|
msgid "%s (on %s)"
|
||||||
msgstr "%s (na %s)"
|
msgstr "%s (na %s)"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1546
|
#: ../src/core/window-props.c:1517
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
||||||
msgstr "Neplatné okno WM_TRANSIENT_FOR 0x%lx specifikováno pro %s.\n"
|
msgstr "Neplatné okno WM_TRANSIENT_FOR 0x%lx specifikováno pro %s.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1557
|
#: ../src/core/window-props.c:1528
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
||||||
msgstr "Okno WM_TRANSIENT_FOR 0x%lx by vytvořilo smyčku pro %s.\n"
|
msgstr "Okno WM_TRANSIENT_FOR 0x%lx by vytvořilo smyčku pro %s.\n"
|
||||||
@@ -720,104 +707,109 @@ msgstr "Vybrat okno z překryvné nabídky tabulátoru"
|
|||||||
msgid "Cancel tab popup"
|
msgid "Cancel tab popup"
|
||||||
msgstr "Zrušit překryvné okno tabulátoru"
|
msgstr "Zrušit překryvné okno tabulátoru"
|
||||||
|
|
||||||
|
#: ../src/tools/mutter-message.c:123
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: %s\n"
|
||||||
|
msgstr "Použití: %s\n"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:67
|
#: ../src/ui/menu.c:69
|
||||||
msgid "Mi_nimize"
|
msgid "Mi_nimize"
|
||||||
msgstr "Mi_nimalizovat"
|
msgstr "Mi_nimalizovat"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:69
|
#: ../src/ui/menu.c:71
|
||||||
msgid "Ma_ximize"
|
msgid "Ma_ximize"
|
||||||
msgstr "Ma_ximalizovat"
|
msgstr "Ma_ximalizovat"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:71
|
#: ../src/ui/menu.c:73
|
||||||
msgid "Unma_ximize"
|
msgid "Unma_ximize"
|
||||||
msgstr "Zrušit ma_ximalizaci"
|
msgstr "Zrušit ma_ximalizaci"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:73
|
#: ../src/ui/menu.c:75
|
||||||
msgid "Roll _Up"
|
msgid "Roll _Up"
|
||||||
msgstr "Sv_inout"
|
msgstr "Sv_inout"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:75
|
#: ../src/ui/menu.c:77
|
||||||
msgid "_Unroll"
|
msgid "_Unroll"
|
||||||
msgstr "Rozv_inout"
|
msgstr "Rozv_inout"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:77
|
#: ../src/ui/menu.c:79
|
||||||
msgid "_Move"
|
msgid "_Move"
|
||||||
msgstr "_Přesunout"
|
msgstr "_Přesunout"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:79
|
#: ../src/ui/menu.c:81
|
||||||
msgid "_Resize"
|
msgid "_Resize"
|
||||||
msgstr "Z_měnit velikost"
|
msgstr "Z_měnit velikost"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:81
|
#: ../src/ui/menu.c:83
|
||||||
msgid "Move Titlebar On_screen"
|
msgid "Move Titlebar On_screen"
|
||||||
msgstr "Přesunout záhlaví okna na _obrazovku"
|
msgstr "Přesunout záhlaví okna na _obrazovku"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:84 ../src/ui/menu.c:86
|
#: ../src/ui/menu.c:86 ../src/ui/menu.c:88
|
||||||
msgid "Always on _Top"
|
msgid "Always on _Top"
|
||||||
msgstr "_Vždy navrchu"
|
msgstr "_Vždy navrchu"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:88
|
#: ../src/ui/menu.c:90
|
||||||
msgid "_Always on Visible Workspace"
|
msgid "_Always on Visible Workspace"
|
||||||
msgstr "Vžd_y na viditelné ploše"
|
msgstr "Vžd_y na viditelné ploše"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:90
|
#: ../src/ui/menu.c:92
|
||||||
msgid "_Only on This Workspace"
|
msgid "_Only on This Workspace"
|
||||||
msgstr "_Jen na této ploše"
|
msgstr "_Jen na této ploše"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:92
|
#: ../src/ui/menu.c:94
|
||||||
msgid "Move to Workspace _Left"
|
msgid "Move to Workspace _Left"
|
||||||
msgstr "Přesunout na plochu v_levo"
|
msgstr "Přesunout na plochu v_levo"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:94
|
#: ../src/ui/menu.c:96
|
||||||
msgid "Move to Workspace R_ight"
|
msgid "Move to Workspace R_ight"
|
||||||
msgstr "Přesunout na plochu vp_ravo"
|
msgstr "Přesunout na plochu vp_ravo"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:96
|
#: ../src/ui/menu.c:98
|
||||||
msgid "Move to Workspace _Up"
|
msgid "Move to Workspace _Up"
|
||||||
msgstr "Přesunout na plochu na_hoře"
|
msgstr "Přesunout na plochu na_hoře"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:98
|
#: ../src/ui/menu.c:100
|
||||||
msgid "Move to Workspace _Down"
|
msgid "Move to Workspace _Down"
|
||||||
msgstr "Přesunout na plochu _dole"
|
msgstr "Přesunout na plochu _dole"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:102
|
#: ../src/ui/menu.c:104
|
||||||
msgid "_Close"
|
msgid "_Close"
|
||||||
msgstr "_Zavřít"
|
msgstr "_Zavřít"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:202
|
#: ../src/ui/menu.c:204
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d%n"
|
msgid "Workspace %d%n"
|
||||||
msgstr "Plocha %d%n"
|
msgstr "Plocha %d%n"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:212
|
#: ../src/ui/menu.c:214
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace 1_0"
|
msgid "Workspace 1_0"
|
||||||
msgstr "Plocha 1_0"
|
msgstr "Plocha 1_0"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:214
|
#: ../src/ui/menu.c:216
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %s%d"
|
msgid "Workspace %s%d"
|
||||||
msgstr "Plocha %s%d"
|
msgstr "Plocha %s%d"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:384
|
#: ../src/ui/menu.c:397
|
||||||
msgid "Move to Another _Workspace"
|
msgid "Move to Another _Workspace"
|
||||||
msgstr "Přes_unout na jinou plochu"
|
msgstr "Přes_unout na jinou plochu"
|
||||||
|
|
||||||
@@ -993,8 +985,8 @@ msgid ""
|
|||||||
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
|
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
|
||||||
"where NORMAL is the state; could not parse \"%s\""
|
"where NORMAL is the state; could not parse \"%s\""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Specifikace GTK barvy musí mít stav v hranatých závorkách, např. gtk:"
|
"Specifikace GTK barvy musí mít stav v hranatých závorkách, např. gtk:fg"
|
||||||
"fg[NORMAL], kde NORMAL je stav; nelze analyzovat „%s“"
|
"[NORMAL], kde NORMAL je stav; nelze analyzovat „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1292
|
#: ../src/ui/theme.c:1292
|
||||||
#, c-format
|
#, c-format
|
||||||
@@ -1002,8 +994,8 @@ msgid ""
|
|||||||
"GTK color specification must have a close bracket after the state, e.g. gtk:"
|
"GTK color specification must have a close bracket after the state, e.g. gtk:"
|
||||||
"fg[NORMAL] where NORMAL is the state; could not parse \"%s\""
|
"fg[NORMAL] where NORMAL is the state; could not parse \"%s\""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Specifikace GTK barvy musí mít za stavem hranatou závorku, např. gtk:"
|
"Specifikace GTK barvy musí mít za stavem hranatou závorku, např. gtk:fg"
|
||||||
"fg[NORMAL], kde NORMAL je stav; nelze analyzovat „%s“"
|
"[NORMAL], kde NORMAL je stav; nelze analyzovat „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1303
|
#: ../src/ui/theme.c:1303
|
||||||
#, c-format
|
#, c-format
|
||||||
@@ -1173,18 +1165,18 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Chybí <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"cokoliv\"/>"
|
"Chybí <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"cokoliv\"/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5082
|
#: ../src/ui/theme.c:5084
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to load theme \"%s\": %s\n"
|
msgid "Failed to load theme \"%s\": %s\n"
|
||||||
msgstr "Nelze načíst motiv „%s“: %s\n"
|
msgstr "Nelze načíst motiv „%s“: %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232
|
#: ../src/ui/theme.c:5220 ../src/ui/theme.c:5227 ../src/ui/theme.c:5234
|
||||||
#: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246
|
#: ../src/ui/theme.c:5241 ../src/ui/theme.c:5248
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "No <%s> set for theme \"%s\""
|
msgid "No <%s> set for theme \"%s\""
|
||||||
msgstr "Není nastaveno <%s> motivu „%s“"
|
msgstr "Není nastaveno <%s> motivu „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5254
|
#: ../src/ui/theme.c:5256
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
||||||
@@ -1193,7 +1185,7 @@ msgstr ""
|
|||||||
"U typu okna „%s“ motivu „%s“ není nastaven typ rámu, přidejte prosím prvek "
|
"U typu okna „%s“ motivu „%s“ není nastaven typ rámu, přidejte prosím prvek "
|
||||||
"<window type=\"%s\" style_set=\"cokoliv\"/>"
|
"<window type=\"%s\" style_set=\"cokoliv\"/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786
|
#: ../src/ui/theme.c:5663 ../src/ui/theme.c:5725 ../src/ui/theme.c:5788
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
||||||
@@ -1201,7 +1193,7 @@ msgstr ""
|
|||||||
"Uživatelem definované konstanty musí začínat velkým písmenem; „%s“ toto "
|
"Uživatelem definované konstanty musí začínat velkým písmenem; „%s“ toto "
|
||||||
"nesplňuje"
|
"nesplňuje"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794
|
#: ../src/ui/theme.c:5671 ../src/ui/theme.c:5733 ../src/ui/theme.c:5796
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Constant \"%s\" has already been defined"
|
msgid "Constant \"%s\" has already been defined"
|
||||||
msgstr "Konstanta „%s“ již byla definována"
|
msgstr "Konstanta „%s“ již byla definována"
|
||||||
@@ -1580,4 +1572,205 @@ msgstr "<%s> u tohoto motivu definováno dvakrát"
|
|||||||
#: ../src/ui/theme-parser.c:4336
|
#: ../src/ui/theme-parser.c:4336
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to find a valid file for theme %s\n"
|
msgid "Failed to find a valid file for theme %s\n"
|
||||||
msgstr "Nelze nalézt platný soubor motivu %s\n"
|
msgstr "Nelze nalézt platný soubor motivu %s\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:99
|
||||||
|
msgid "_Windows"
|
||||||
|
msgstr "_Okna"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:100
|
||||||
|
msgid "_Dialog"
|
||||||
|
msgstr "_Dialogové okno"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:101
|
||||||
|
msgid "_Modal dialog"
|
||||||
|
msgstr "_Modální dialogové okno"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:102
|
||||||
|
msgid "_Utility"
|
||||||
|
msgstr "_Nástroje"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:103
|
||||||
|
msgid "_Splashscreen"
|
||||||
|
msgstr "_Spouštěcí obrazovka"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:104
|
||||||
|
msgid "_Top dock"
|
||||||
|
msgstr "_Horní dok"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:105
|
||||||
|
msgid "_Bottom dock"
|
||||||
|
msgstr "Dolní do_k"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:106
|
||||||
|
msgid "_Left dock"
|
||||||
|
msgstr "_Levý dok"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:107
|
||||||
|
msgid "_Right dock"
|
||||||
|
msgstr "P_ravý dok"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:108
|
||||||
|
msgid "_All docks"
|
||||||
|
msgstr "_Všechny doky"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:109
|
||||||
|
msgid "Des_ktop"
|
||||||
|
msgstr "Pra_covní prostředí"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:115
|
||||||
|
msgid "Open another one of these windows"
|
||||||
|
msgstr "Otevřít další takové okno"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:117
|
||||||
|
msgid "This is a demo button with an 'open' icon"
|
||||||
|
msgstr "Toto je demonstrační tlačítko s ikonou „otevřít“"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:119
|
||||||
|
msgid "This is a demo button with a 'quit' icon"
|
||||||
|
msgstr "Toto je demonstrační tlačítko s ikonou „ukončit“"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:248
|
||||||
|
msgid "This is a sample message in a sample dialog"
|
||||||
|
msgstr "Toto je ukázková zpráva v ukázkovém dialogu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:328
|
||||||
|
#, c-format
|
||||||
|
msgid "Fake menu item %d\n"
|
||||||
|
msgstr "Falešná položka nabídky %d\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:363
|
||||||
|
msgid "Border-only window"
|
||||||
|
msgstr "Okno jen s okrajem"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:365
|
||||||
|
msgid "Bar"
|
||||||
|
msgstr "Lišta"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:382
|
||||||
|
msgid "Normal Application Window"
|
||||||
|
msgstr "Normální okno aplikace"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:386
|
||||||
|
msgid "Dialog Box"
|
||||||
|
msgstr "Dialogové okno"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:390
|
||||||
|
msgid "Modal Dialog Box"
|
||||||
|
msgstr "Modální dialogové okno"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:394
|
||||||
|
msgid "Utility Palette"
|
||||||
|
msgstr "Paleta nástrojů"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:398
|
||||||
|
msgid "Torn-off Menu"
|
||||||
|
msgstr "Odtržení nabídky"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:402
|
||||||
|
msgid "Border"
|
||||||
|
msgstr "Okraj"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:406
|
||||||
|
msgid "Attached Modal Dialog"
|
||||||
|
msgstr "Připojené modální dialogové okno"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:737
|
||||||
|
#, c-format
|
||||||
|
msgid "Button layout test %d"
|
||||||
|
msgstr "Test rozložení tlačítek %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:766
|
||||||
|
#, c-format
|
||||||
|
msgid "%g milliseconds to draw one window frame"
|
||||||
|
msgstr "%g milisekund na nakreslení jednoho rámu okna"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:811
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
|
||||||
|
msgstr "Použití: metacity-theme-viewer [NÁZEVMOTIVU]\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:818
|
||||||
|
#, c-format
|
||||||
|
msgid "Error loading theme: %s\n"
|
||||||
|
msgstr "Chyba při načítání motivu: %s\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:824
|
||||||
|
#, c-format
|
||||||
|
msgid "Loaded theme \"%s\" in %g seconds\n"
|
||||||
|
msgstr "Načten motiv „%s“ za %g sekund\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:869
|
||||||
|
msgid "Normal Title Font"
|
||||||
|
msgstr "Normální písmo nadpisu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:875
|
||||||
|
msgid "Small Title Font"
|
||||||
|
msgstr "Malé písmo nadpisu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:881
|
||||||
|
msgid "Large Title Font"
|
||||||
|
msgstr "Velké písmo nadpisu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:886
|
||||||
|
msgid "Button Layouts"
|
||||||
|
msgstr "Rozložení tlačítek"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:891
|
||||||
|
msgid "Benchmark"
|
||||||
|
msgstr "Test výkonnosti"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:947
|
||||||
|
msgid "Window Title Goes Here"
|
||||||
|
msgstr "Sem patří nadpis okna"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1053
|
||||||
|
#, c-format
|
||||||
|
msgid ""
|
||||||
|
"Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g "
|
||||||
|
"seconds wall clock time including X server resources (%g milliseconds per "
|
||||||
|
"frame)\n"
|
||||||
|
msgstr ""
|
||||||
|
"Nakresleno %d rámů za %g sekund na straně klienta (%g milisekund na rám) a "
|
||||||
|
"%g sekund reálného času včetně zdrojů serveru X (%g milisekund na rám)\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1273
|
||||||
|
msgid "position expression test returned TRUE but set error"
|
||||||
|
msgstr "test výrazu umístění vrátil TRUE, ale nastavil chybu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1275
|
||||||
|
msgid "position expression test returned FALSE but didn't set error"
|
||||||
|
msgstr "test výrazu umístění vrátil FALSE, ale nenastavil chybu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1279
|
||||||
|
msgid "Error was expected but none given"
|
||||||
|
msgstr "Byla očekávána chyba, ale nebyla přijata"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1281
|
||||||
|
#, c-format
|
||||||
|
msgid "Error %d was expected but %d given"
|
||||||
|
msgstr "Byla očekávána chyba %d, ale bylo přijato %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1287
|
||||||
|
#, c-format
|
||||||
|
msgid "Error not expected but one was returned: %s"
|
||||||
|
msgstr "Chyba nebyla očekávána, ale byla vrácena: %s"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1291
|
||||||
|
#, c-format
|
||||||
|
msgid "x value was %d, %d was expected"
|
||||||
|
msgstr "Hodnota x byla %d, bylo očekáváno %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1294
|
||||||
|
#, c-format
|
||||||
|
msgid "y value was %d, %d was expected"
|
||||||
|
msgstr "Hodnota y byla %d, bylo očekáváno %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1359
|
||||||
|
#, c-format
|
||||||
|
msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
|
||||||
|
msgstr "Zpracováno %d výrazů souřadnic za %g sekund (průměr %g sekund)\n"
|
||||||
|
|
||||||
|
#, fuzzy
|
||||||
|
#~ msgid "Minimize window"
|
||||||
|
#~ msgstr "Minimalizovat okno"
|
||||||
|
|||||||
398
po/hu.po
398
po/hu.po
@@ -6,21 +6,19 @@
|
|||||||
# Gabor Sari <saga at externet dot hu>, 2003.
|
# Gabor Sari <saga at externet dot hu>, 2003.
|
||||||
# Laszlo Dvornik <dvornik at gnome dot hu>, 2004.
|
# Laszlo Dvornik <dvornik at gnome dot hu>, 2004.
|
||||||
# Gabor Kelemen <kelemeng at gnome dot hu>, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013.
|
# Gabor Kelemen <kelemeng at gnome dot hu>, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012, 2013.
|
||||||
# Balázs Úr <urbalazs at gmail dot com>, 2013.
|
|
||||||
msgid ""
|
msgid ""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: mutter master\n"
|
"Project-Id-Version: mutter master\n"
|
||||||
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"product=mutter&keywords=I18N+L10N&component=general\n"
|
"POT-Creation-Date: 2013-03-21 00:15+0100\n"
|
||||||
"POT-Creation-Date: 2013-08-18 20:03+0000\n"
|
"PO-Revision-Date: 2013-03-21 00:14+0100\n"
|
||||||
"PO-Revision-Date: 2013-08-25 10:26+0200\n"
|
"Last-Translator: Gabor Kelemen <kelemeng at gnome dot hu>\n"
|
||||||
"Last-Translator: Balázs Úr <urbalazs at gmail dot com>\n"
|
|
||||||
"Language-Team: Hungarian <gnome-hu-list at gnome dot org>\n"
|
"Language-Team: Hungarian <gnome-hu-list at gnome dot org>\n"
|
||||||
"Language: hu\n"
|
"Language: hu\n"
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
"Content-Type: text/plain; charset=UTF-8\n"
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
"Content-Transfer-Encoding: 8bit\n"
|
"Content-Transfer-Encoding: 8bit\n"
|
||||||
"X-Generator: Lokalize 1.2\n"
|
"X-Generator: Lokalize 1.4\n"
|
||||||
"Plural-Forms: nplurals=2; plural=(n != 1);\n"
|
"Plural-Forms: nplurals=2; plural=(n != 1);\n"
|
||||||
|
|
||||||
#: ../src/50-mutter-navigation.xml.in.h:1
|
#: ../src/50-mutter-navigation.xml.in.h:1
|
||||||
@@ -213,7 +211,7 @@ msgstr "Jobb oldali felosztás megjelenítése"
|
|||||||
|
|
||||||
#. This probably means that a non-WM compositor like xcompmgr is running;
|
#. This probably means that a non-WM compositor like xcompmgr is running;
|
||||||
#. * we have no way to get it to exit
|
#. * we have no way to get it to exit
|
||||||
#: ../src/compositor/compositor.c:589
|
#: ../src/compositor/compositor.c:568
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Another compositing manager is already running on screen %i on display \"%s"
|
"Another compositing manager is already running on screen %i on display \"%s"
|
||||||
@@ -222,7 +220,7 @@ msgstr ""
|
|||||||
"Már fut egy másik kompozitáláskezelő a(z) %i képernyőn a(z) „%s” "
|
"Már fut egy másik kompozitáláskezelő a(z) %i képernyőn a(z) „%s” "
|
||||||
"megjelenítőn."
|
"megjelenítőn."
|
||||||
|
|
||||||
#: ../src/compositor/meta-background.c:1076
|
#: ../src/compositor/meta-background.c:1191
|
||||||
msgid "background texture could not be created from file"
|
msgid "background texture could not be created from file"
|
||||||
msgstr "nem hozható létre a háttér textúrája fájlból"
|
msgstr "nem hozható létre a háttér textúrája fájlból"
|
||||||
|
|
||||||
@@ -260,17 +258,17 @@ msgstr "Vá_rakozás"
|
|||||||
msgid "_Force Quit"
|
msgid "_Force Quit"
|
||||||
msgstr "_Erőltetett kilépés"
|
msgstr "_Erőltetett kilépés"
|
||||||
|
|
||||||
#: ../src/core/display.c:421
|
#: ../src/core/display.c:401
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Missing %s extension required for compositing"
|
msgid "Missing %s extension required for compositing"
|
||||||
msgstr "Hiányzik a kompozit ablakkezeléshez szükséges %s kiterjesztés"
|
msgstr "Hiányzik a kompozit ablakkezeléshez szükséges %s kiterjesztés"
|
||||||
|
|
||||||
#: ../src/core/display.c:513
|
#: ../src/core/display.c:493
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open X Window System display '%s'\n"
|
msgid "Failed to open X Window System display '%s'\n"
|
||||||
msgstr "Nem sikerült megnyitni a(z) „%s” X Window rendszer képernyőt\n"
|
msgstr "Nem sikerült megnyitni a(z) „%s” X Window rendszer képernyőt\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1136
|
#: ../src/core/keybindings.c:935
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Some other program is already using the key %s with modifiers %x as a "
|
"Some other program is already using the key %s with modifiers %x as a "
|
||||||
@@ -279,7 +277,7 @@ msgstr ""
|
|||||||
"Valamely másik program már használja a(z) %s billentyűt %x módosítókkal "
|
"Valamely másik program már használja a(z) %s billentyűt %x módosítókkal "
|
||||||
"összekötve\n"
|
"összekötve\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1333
|
#: ../src/core/keybindings.c:1135
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "\"%s\" is not a valid accelerator\n"
|
msgid "\"%s\" is not a valid accelerator\n"
|
||||||
msgstr "„%s” érvénytelen hívóbetű\n"
|
msgstr "„%s” érvénytelen hívóbetű\n"
|
||||||
@@ -321,20 +319,6 @@ msgstr ""
|
|||||||
"Nem található téma! Bizonyosodjon meg róla hogy a(z) %s létezik és "
|
"Nem található téma! Bizonyosodjon meg róla hogy a(z) %s létezik és "
|
||||||
"tartalmazza a szokásos témákat.\n"
|
"tartalmazza a szokásos témákat.\n"
|
||||||
|
|
||||||
#: ../src/core/monitor.c:711
|
|
||||||
msgid "Built-in display"
|
|
||||||
msgstr "Beépített kijelző"
|
|
||||||
|
|
||||||
#. TRANSLATORS: this is a monitor name (in case we don't know
|
|
||||||
#. the vendor), it's Unknown followed by a size in inches,
|
|
||||||
#. like 'Unknown 15"'
|
|
||||||
#.
|
|
||||||
#: ../src/core/monitor.c:739
|
|
||||||
#, c-format
|
|
||||||
#| msgid "Unknown element %s"
|
|
||||||
msgid "Unknown %s"
|
|
||||||
msgstr "Ismeretlen %s"
|
|
||||||
|
|
||||||
#: ../src/core/mutter.c:40
|
#: ../src/core/mutter.c:40
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
@@ -358,7 +342,7 @@ msgstr "Verzió kinyomtatása"
|
|||||||
msgid "Mutter plugin to use"
|
msgid "Mutter plugin to use"
|
||||||
msgstr "Használandó Mutter bővítmény"
|
msgstr "Használandó Mutter bővítmény"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1202
|
#: ../src/core/prefs.c:1095
|
||||||
msgid ""
|
msgid ""
|
||||||
"Workarounds for broken applications disabled. Some applications may not "
|
"Workarounds for broken applications disabled. Some applications may not "
|
||||||
"behave properly.\n"
|
"behave properly.\n"
|
||||||
@@ -366,14 +350,14 @@ msgstr ""
|
|||||||
"A hibás alkalmazások hibáinak megkerülése nincs engedélyezve. Néhány "
|
"A hibás alkalmazások hibáinak megkerülése nincs engedélyezve. Néhány "
|
||||||
"alkalmazás lehet, hogy nem fog helyesen működni.\n"
|
"alkalmazás lehet, hogy nem fog helyesen működni.\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1277
|
#: ../src/core/prefs.c:1170
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Nem sikerült feldolgozni a(z) „%s” betűkészlet leírását a(z) „%s” GSettings "
|
"Nem sikerült feldolgozni a(z) „%s” betűkészlet leírását a(z) „%s” GSettings "
|
||||||
"kulcsból\n"
|
"kulcsból\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1343
|
#: ../src/core/prefs.c:1236
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for mouse button "
|
"\"%s\" found in configuration database is not a valid value for mouse button "
|
||||||
@@ -382,7 +366,7 @@ msgstr ""
|
|||||||
"A konfigurációs adatbázisban talált „%s” érvénytelen érték az egérgomb "
|
"A konfigurációs adatbázisban talált „%s” érvénytelen érték az egérgomb "
|
||||||
"módosítóhoz\n"
|
"módosítóhoz\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1909
|
#: ../src/core/prefs.c:1788
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for keybinding "
|
"\"%s\" found in configuration database is not a valid value for keybinding "
|
||||||
@@ -391,17 +375,17 @@ msgstr ""
|
|||||||
"A konfigurációs adatbázisban talált „%s” nem érvényes érték a következő "
|
"A konfigurációs adatbázisban talált „%s” nem érvényes érték a következő "
|
||||||
"billentyűkombinációhoz: „%s”\n"
|
"billentyűkombinációhoz: „%s”\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1999
|
#: ../src/core/prefs.c:1887
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d"
|
msgid "Workspace %d"
|
||||||
msgstr "%d. munkaterület"
|
msgstr "%d. munkaterület"
|
||||||
|
|
||||||
#: ../src/core/screen.c:534
|
#: ../src/core/screen.c:691
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display '%s' is invalid\n"
|
msgid "Screen %d on display '%s' is invalid\n"
|
||||||
msgstr "A(z) %d képernyő a(z) „%s” megjelenítőn érvénytelen\n"
|
msgstr "A(z) %d képernyő a(z) „%s” megjelenítőn érvénytelen\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:550
|
#: ../src/core/screen.c:707
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
||||||
@@ -410,7 +394,7 @@ msgstr ""
|
|||||||
"A(z) %d képernyő a(z) „%s” megjelenítőn már rendelkezik egy ablakkezelővel; "
|
"A(z) %d képernyő a(z) „%s” megjelenítőn már rendelkezik egy ablakkezelővel; "
|
||||||
"próbálja a --replace opcióval helyettesíteni a jelenlegi ablakkezelőt.\n"
|
"próbálja a --replace opcióval helyettesíteni a jelenlegi ablakkezelőt.\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:577
|
#: ../src/core/screen.c:734
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
||||||
@@ -418,12 +402,12 @@ msgstr ""
|
|||||||
"Nem sikerült beolvasni az ablakkezelő kiválasztását a(z) %d képernyőn a(z) "
|
"Nem sikerült beolvasni az ablakkezelő kiválasztását a(z) %d képernyőn a(z) "
|
||||||
"„%s” megjelenítőn\n"
|
"„%s” megjelenítőn\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:655
|
#: ../src/core/screen.c:812
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
||||||
msgstr "A(z) %d képernyőnek a(z) „%s” megjelenítőn már van ablakkezelője\n"
|
msgstr "A(z) %d képernyőnek a(z) „%s” megjelenítőn már van ablakkezelője\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:846
|
#: ../src/core/screen.c:998
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not release screen %d on display \"%s\"\n"
|
msgid "Could not release screen %d on display \"%s\"\n"
|
||||||
msgstr "Nem sikerült elengedni a(z) %d képernyőt a(z) „%s” kijelzőn\n"
|
msgstr "Nem sikerült elengedni a(z) %d képernyőt a(z) „%s” kijelzőn\n"
|
||||||
@@ -500,7 +484,8 @@ msgstr "Nem sikerült megnyitni az fdopen()-nel a(z) „%s” naplófájlt: %s\n
|
|||||||
msgid "Opened log file %s\n"
|
msgid "Opened log file %s\n"
|
||||||
msgstr "%s naplófájl megnyitva\n"
|
msgstr "%s naplófájl megnyitva\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:119
|
#: ../src/core/util.c:119 ../src/tools/mutter-message.c:149
|
||||||
|
#, c-format
|
||||||
msgid "Mutter was compiled without support for verbose mode\n"
|
msgid "Mutter was compiled without support for verbose mode\n"
|
||||||
msgstr "A Mutter ablakkezelőt a részletes mód támogatása nélkül fordították\n"
|
msgstr "A Mutter ablakkezelőt a részletes mód támogatása nélkül fordították\n"
|
||||||
|
|
||||||
@@ -508,20 +493,20 @@ msgstr "A Mutter ablakkezelőt a részletes mód támogatása nélkül fordítot
|
|||||||
msgid "Window manager: "
|
msgid "Window manager: "
|
||||||
msgstr "Ablakkezelő: "
|
msgstr "Ablakkezelő: "
|
||||||
|
|
||||||
#: ../src/core/util.c:414
|
#: ../src/core/util.c:412
|
||||||
msgid "Bug in window manager: "
|
msgid "Bug in window manager: "
|
||||||
msgstr "Hiba az ablakkezelőben: "
|
msgstr "Hiba az ablakkezelőben: "
|
||||||
|
|
||||||
#: ../src/core/util.c:445
|
#: ../src/core/util.c:443
|
||||||
msgid "Window manager warning: "
|
msgid "Window manager warning: "
|
||||||
msgstr "Figyelmeztetés az ablakkezelőtől: "
|
msgstr "Figyelmeztetés az ablakkezelőtől: "
|
||||||
|
|
||||||
#: ../src/core/util.c:473
|
#: ../src/core/util.c:471
|
||||||
msgid "Window manager error: "
|
msgid "Window manager error: "
|
||||||
msgstr "Hibaüzenet az ablakkezelőtől: "
|
msgstr "Hibaüzenet az ablakkezelőtől: "
|
||||||
|
|
||||||
#. first time through
|
#. first time through
|
||||||
#: ../src/core/window.c:7533
|
#: ../src/core/window.c:7596
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
||||||
@@ -537,7 +522,7 @@ msgstr ""
|
|||||||
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
||||||
#. * about these apps but make them work.
|
#. * about these apps but make them work.
|
||||||
#.
|
#.
|
||||||
#: ../src/core/window.c:8257
|
#: ../src/core/window.c:8320
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
||||||
@@ -547,24 +532,24 @@ msgstr ""
|
|||||||
"de mégis %d x %d minimális és %d x %d maximális értéket ad meg, amelynek így "
|
"de mégis %d x %d minimális és %d x %d maximális értéket ad meg, amelynek így "
|
||||||
"nincs értelme.\n"
|
"nincs értelme.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:347
|
#: ../src/core/window-props.c:318
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
||||||
msgstr "Az alkalmazás hibás _NET_WM_PID-értéket állított be: %lu\n"
|
msgstr "Az alkalmazás hibás _NET_WM_PID-értéket állított be: %lu\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:463
|
#: ../src/core/window-props.c:434
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s (on %s)"
|
msgid "%s (on %s)"
|
||||||
msgstr "%s (ezen: %s)"
|
msgstr "%s (ezen: %s)"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1546
|
#: ../src/core/window-props.c:1517
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Érvénytelen WM_TRANSIENT_FOR ablak (0x%lx) került megadásra a következőhöz: "
|
"Érvénytelen WM_TRANSIENT_FOR ablak (0x%lx) került megadásra a következőhöz: "
|
||||||
"%s.\n"
|
"%s.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1557
|
#: ../src/core/window-props.c:1528
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
@@ -662,7 +647,7 @@ msgstr ""
|
|||||||
|
|
||||||
#: ../src/org.gnome.mutter.gschema.xml.in.h:9
|
#: ../src/org.gnome.mutter.gschema.xml.in.h:9
|
||||||
msgid "Workspaces only on primary"
|
msgid "Workspaces only on primary"
|
||||||
msgstr "Munkaterületek csak az elsődlegesen"
|
msgstr "Munkaterületek csak az elsődlegese"
|
||||||
|
|
||||||
#: ../src/org.gnome.mutter.gschema.xml.in.h:10
|
#: ../src/org.gnome.mutter.gschema.xml.in.h:10
|
||||||
msgid ""
|
msgid ""
|
||||||
@@ -731,104 +716,109 @@ msgstr "Ablakok kiválasztása tab billentyűre felugró ablakból"
|
|||||||
msgid "Cancel tab popup"
|
msgid "Cancel tab popup"
|
||||||
msgstr "Tab felugró kikapcsolása"
|
msgstr "Tab felugró kikapcsolása"
|
||||||
|
|
||||||
|
#: ../src/tools/mutter-message.c:123
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: %s\n"
|
||||||
|
msgstr "Használat: %s\n"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:67
|
#: ../src/ui/menu.c:69
|
||||||
msgid "Mi_nimize"
|
msgid "Mi_nimize"
|
||||||
msgstr "Mi_nimalizálás"
|
msgstr "Mi_nimalizálás"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:69
|
#: ../src/ui/menu.c:71
|
||||||
msgid "Ma_ximize"
|
msgid "Ma_ximize"
|
||||||
msgstr "Ma_ximalizálás"
|
msgstr "Ma_ximalizálás"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:71
|
#: ../src/ui/menu.c:73
|
||||||
msgid "Unma_ximize"
|
msgid "Unma_ximize"
|
||||||
msgstr "_Eredeti méret"
|
msgstr "_Eredeti méret"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:73
|
#: ../src/ui/menu.c:75
|
||||||
msgid "Roll _Up"
|
msgid "Roll _Up"
|
||||||
msgstr "_Felgördítés"
|
msgstr "_Felgördítés"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:75
|
#: ../src/ui/menu.c:77
|
||||||
msgid "_Unroll"
|
msgid "_Unroll"
|
||||||
msgstr "_Legördítés"
|
msgstr "_Legördítés"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:77
|
#: ../src/ui/menu.c:79
|
||||||
msgid "_Move"
|
msgid "_Move"
|
||||||
msgstr "Át_helyezés"
|
msgstr "Át_helyezés"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:79
|
#: ../src/ui/menu.c:81
|
||||||
msgid "_Resize"
|
msgid "_Resize"
|
||||||
msgstr "Át_méretezés"
|
msgstr "Át_méretezés"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:81
|
#: ../src/ui/menu.c:83
|
||||||
msgid "Move Titlebar On_screen"
|
msgid "Move Titlebar On_screen"
|
||||||
msgstr "_Címsor mozgatása a képernyőn"
|
msgstr "_Címsor mozgatása a képernyőn"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:84 ../src/ui/menu.c:86
|
#: ../src/ui/menu.c:86 ../src/ui/menu.c:88
|
||||||
msgid "Always on _Top"
|
msgid "Always on _Top"
|
||||||
msgstr "Mindig _felül"
|
msgstr "Mindig _felül"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:88
|
#: ../src/ui/menu.c:90
|
||||||
msgid "_Always on Visible Workspace"
|
msgid "_Always on Visible Workspace"
|
||||||
msgstr "Mindig a látható m_unkaterületen"
|
msgstr "Mindig a látható m_unkaterületen"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:90
|
#: ../src/ui/menu.c:92
|
||||||
msgid "_Only on This Workspace"
|
msgid "_Only on This Workspace"
|
||||||
msgstr "_Csak ezen a munkaterületen"
|
msgstr "_Csak ezen a munkaterületen"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:92
|
#: ../src/ui/menu.c:94
|
||||||
msgid "Move to Workspace _Left"
|
msgid "Move to Workspace _Left"
|
||||||
msgstr "Áthelyezés a bal ol_dali munkaterületre"
|
msgstr "Áthelyezés a bal ol_dali munkaterületre"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:94
|
#: ../src/ui/menu.c:96
|
||||||
msgid "Move to Workspace R_ight"
|
msgid "Move to Workspace R_ight"
|
||||||
msgstr "Áthelyezés a j_obb oldali munkaterületre"
|
msgstr "Áthelyezés a j_obb oldali munkaterületre"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:96
|
#: ../src/ui/menu.c:98
|
||||||
msgid "Move to Workspace _Up"
|
msgid "Move to Workspace _Up"
|
||||||
msgstr "Áthelyezés a fel_ső munkaterületre"
|
msgstr "Áthelyezés a fel_ső munkaterületre"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:98
|
#: ../src/ui/menu.c:100
|
||||||
msgid "Move to Workspace _Down"
|
msgid "Move to Workspace _Down"
|
||||||
msgstr "Áthelyezés az _alsó munkaterületre"
|
msgstr "Áthelyezés az _alsó munkaterületre"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:102
|
#: ../src/ui/menu.c:104
|
||||||
msgid "_Close"
|
msgid "_Close"
|
||||||
msgstr "_Bezárás"
|
msgstr "_Bezárás"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:202
|
#: ../src/ui/menu.c:204
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d%n"
|
msgid "Workspace %d%n"
|
||||||
msgstr "%d%n. munkaterület"
|
msgstr "%d%n. munkaterület"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:212
|
#: ../src/ui/menu.c:214
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace 1_0"
|
msgid "Workspace 1_0"
|
||||||
msgstr "1_0. munkaterület"
|
msgstr "1_0. munkaterület"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:214
|
#: ../src/ui/menu.c:216
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %s%d"
|
msgid "Workspace %s%d"
|
||||||
msgstr "%s%d. munkaterület"
|
msgstr "%s%d. munkaterület"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:384
|
#: ../src/ui/menu.c:397
|
||||||
msgid "Move to Another _Workspace"
|
msgid "Move to Another _Workspace"
|
||||||
msgstr "Áthelyezés mási_k munkaterületre"
|
msgstr "Áthelyezés mási_k munkaterületre"
|
||||||
|
|
||||||
@@ -1189,18 +1179,18 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Hiányzó <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"bármi\"/> elem"
|
"Hiányzó <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"bármi\"/> elem"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5082
|
#: ../src/ui/theme.c:5084
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to load theme \"%s\": %s\n"
|
msgid "Failed to load theme \"%s\": %s\n"
|
||||||
msgstr "Hiba a(z) „%s” téma betöltése közben: %s\n"
|
msgstr "Hiba a(z) „%s” téma betöltése közben: %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232
|
#: ../src/ui/theme.c:5220 ../src/ui/theme.c:5227 ../src/ui/theme.c:5234
|
||||||
#: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246
|
#: ../src/ui/theme.c:5241 ../src/ui/theme.c:5248
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "No <%s> set for theme \"%s\""
|
msgid "No <%s> set for theme \"%s\""
|
||||||
msgstr "Nincs <%s> beállítva a(z) „%s” témához"
|
msgstr "Nincs <%s> beállítva a(z) „%s” témához"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5254
|
#: ../src/ui/theme.c:5256
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
||||||
@@ -1209,7 +1199,7 @@ msgstr ""
|
|||||||
"Nincs keretstílus beállítva a(z) „%s” ablaktípushoz a(z) „%s” témában, adjon "
|
"Nincs keretstílus beállítva a(z) „%s” ablaktípushoz a(z) „%s” témában, adjon "
|
||||||
"hozzá egy <window type=\"%s\" style_set=\"bármi\"/> elemet"
|
"hozzá egy <window type=\"%s\" style_set=\"bármi\"/> elemet"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786
|
#: ../src/ui/theme.c:5663 ../src/ui/theme.c:5725 ../src/ui/theme.c:5788
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
||||||
@@ -1217,7 +1207,7 @@ msgstr ""
|
|||||||
"A felhasználó által meghatározott konstansoknak nagybetűvel kell kezdődniük, "
|
"A felhasználó által meghatározott konstansoknak nagybetűvel kell kezdődniük, "
|
||||||
"a(z) „%s” nem ilyen"
|
"a(z) „%s” nem ilyen"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794
|
#: ../src/ui/theme.c:5671 ../src/ui/theme.c:5733 ../src/ui/theme.c:5796
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Constant \"%s\" has already been defined"
|
msgid "Constant \"%s\" has already been defined"
|
||||||
msgstr "A(z) „%s” konstans már definiálva van"
|
msgstr "A(z) „%s” konstans már definiálva van"
|
||||||
@@ -1610,154 +1600,206 @@ msgstr "<%s> kétszer lett megadva ehhez a témához"
|
|||||||
msgid "Failed to find a valid file for theme %s\n"
|
msgid "Failed to find a valid file for theme %s\n"
|
||||||
msgstr "Nem található érvényes fájl a következő témához: %s\n"
|
msgstr "Nem található érvényes fájl a következő témához: %s\n"
|
||||||
|
|
||||||
#~ msgid "Usage: %s\n"
|
#: ../src/ui/theme-viewer.c:99
|
||||||
#~ msgstr "Használat: %s\n"
|
msgid "_Windows"
|
||||||
|
msgstr "_Ablakok"
|
||||||
|
|
||||||
#~ msgid "_Windows"
|
#: ../src/ui/theme-viewer.c:100
|
||||||
#~ msgstr "_Ablakok"
|
msgid "_Dialog"
|
||||||
|
msgstr "_Párbeszédablak"
|
||||||
|
|
||||||
#~ msgid "_Dialog"
|
#: ../src/ui/theme-viewer.c:101
|
||||||
#~ msgstr "_Párbeszédablak"
|
msgid "_Modal dialog"
|
||||||
|
msgstr "_Kizárólagos párbeszédablak"
|
||||||
|
|
||||||
#~ msgid "_Modal dialog"
|
#: ../src/ui/theme-viewer.c:102
|
||||||
#~ msgstr "_Kizárólagos párbeszédablak"
|
msgid "_Utility"
|
||||||
|
msgstr "_Segédprogram"
|
||||||
|
|
||||||
#~ msgid "_Utility"
|
#: ../src/ui/theme-viewer.c:103
|
||||||
#~ msgstr "_Segédprogram"
|
msgid "_Splashscreen"
|
||||||
|
msgstr "_Indítóképernyő"
|
||||||
|
|
||||||
#~ msgid "_Splashscreen"
|
#: ../src/ui/theme-viewer.c:104
|
||||||
#~ msgstr "_Indítóképernyő"
|
msgid "_Top dock"
|
||||||
|
msgstr "_Felső dokk"
|
||||||
|
|
||||||
#~ msgid "_Top dock"
|
#: ../src/ui/theme-viewer.c:105
|
||||||
#~ msgstr "_Felső dokk"
|
msgid "_Bottom dock"
|
||||||
|
msgstr "_Alsó dokk"
|
||||||
|
|
||||||
#~ msgid "_Bottom dock"
|
#: ../src/ui/theme-viewer.c:106
|
||||||
#~ msgstr "_Alsó dokk"
|
msgid "_Left dock"
|
||||||
|
msgstr "_Bal dokk"
|
||||||
|
|
||||||
#~ msgid "_Left dock"
|
#: ../src/ui/theme-viewer.c:107
|
||||||
#~ msgstr "_Bal dokk"
|
msgid "_Right dock"
|
||||||
|
msgstr "_Jobb dokk"
|
||||||
|
|
||||||
#~ msgid "_Right dock"
|
#: ../src/ui/theme-viewer.c:108
|
||||||
#~ msgstr "_Jobb dokk"
|
msgid "_All docks"
|
||||||
|
msgstr "Össz_es dokk"
|
||||||
|
|
||||||
#~ msgid "_All docks"
|
#: ../src/ui/theme-viewer.c:109
|
||||||
#~ msgstr "Össz_es dokk"
|
msgid "Des_ktop"
|
||||||
|
msgstr "_Asztal"
|
||||||
|
|
||||||
#~ msgid "Des_ktop"
|
#: ../src/ui/theme-viewer.c:115
|
||||||
#~ msgstr "_Asztal"
|
msgid "Open another one of these windows"
|
||||||
|
msgstr "Egy újabb példány megnyitása ezekből az ablakokból"
|
||||||
|
|
||||||
#~ msgid "Open another one of these windows"
|
#: ../src/ui/theme-viewer.c:117
|
||||||
#~ msgstr "Egy újabb példány megnyitása ezekből az ablakokból"
|
msgid "This is a demo button with an 'open' icon"
|
||||||
|
msgstr "Ez egy mintagomb a „Megnyitás” ikonnal"
|
||||||
|
|
||||||
#~ msgid "This is a demo button with an 'open' icon"
|
#: ../src/ui/theme-viewer.c:119
|
||||||
#~ msgstr "Ez egy mintagomb a „Megnyitás” ikonnal"
|
msgid "This is a demo button with a 'quit' icon"
|
||||||
|
msgstr "Ez egy mintagomb a „Kilépés” ikonnal"
|
||||||
|
|
||||||
#~ msgid "This is a demo button with a 'quit' icon"
|
#: ../src/ui/theme-viewer.c:248
|
||||||
#~ msgstr "Ez egy mintagomb a „Kilépés” ikonnal"
|
msgid "This is a sample message in a sample dialog"
|
||||||
|
msgstr "Ez egy mintaüzenet egy minta párbeszédben"
|
||||||
|
|
||||||
#~ msgid "This is a sample message in a sample dialog"
|
#: ../src/ui/theme-viewer.c:328
|
||||||
#~ msgstr "Ez egy mintaüzenet egy minta párbeszédben"
|
#, c-format
|
||||||
|
msgid "Fake menu item %d\n"
|
||||||
|
msgstr "%d. hamis menüelem\n"
|
||||||
|
|
||||||
#~ msgid "Fake menu item %d\n"
|
#: ../src/ui/theme-viewer.c:363
|
||||||
#~ msgstr "%d. hamis menüelem\n"
|
msgid "Border-only window"
|
||||||
|
msgstr "Csak keretes ablak"
|
||||||
|
|
||||||
#~ msgid "Border-only window"
|
#: ../src/ui/theme-viewer.c:365
|
||||||
#~ msgstr "Csak keretes ablak"
|
msgid "Bar"
|
||||||
|
msgstr "Sáv"
|
||||||
|
|
||||||
#~ msgid "Bar"
|
#: ../src/ui/theme-viewer.c:382
|
||||||
#~ msgstr "Sáv"
|
msgid "Normal Application Window"
|
||||||
|
msgstr "Normál alkalmazásablak"
|
||||||
|
|
||||||
#~ msgid "Normal Application Window"
|
#: ../src/ui/theme-viewer.c:386
|
||||||
#~ msgstr "Normál alkalmazásablak"
|
msgid "Dialog Box"
|
||||||
|
msgstr "Párbeszédablak"
|
||||||
|
|
||||||
#~ msgid "Dialog Box"
|
#: ../src/ui/theme-viewer.c:390
|
||||||
#~ msgstr "Párbeszédablak"
|
msgid "Modal Dialog Box"
|
||||||
|
msgstr "Kizárólagos párbeszéd doboz"
|
||||||
|
|
||||||
#~ msgid "Modal Dialog Box"
|
#: ../src/ui/theme-viewer.c:394
|
||||||
#~ msgstr "Kizárólagos párbeszéd doboz"
|
msgid "Utility Palette"
|
||||||
|
msgstr "Eszközpaletta"
|
||||||
|
|
||||||
#~ msgid "Utility Palette"
|
#: ../src/ui/theme-viewer.c:398
|
||||||
#~ msgstr "Eszközpaletta"
|
msgid "Torn-off Menu"
|
||||||
|
msgstr "Leválasztott menü"
|
||||||
|
|
||||||
#~ msgid "Torn-off Menu"
|
#: ../src/ui/theme-viewer.c:402
|
||||||
#~ msgstr "Leválasztott menü"
|
msgid "Border"
|
||||||
|
msgstr "Szegély"
|
||||||
|
|
||||||
#~ msgid "Border"
|
#: ../src/ui/theme-viewer.c:406
|
||||||
#~ msgstr "Szegély"
|
msgid "Attached Modal Dialog"
|
||||||
|
msgstr "Csatolt kizárólagos párbeszédablak"
|
||||||
|
|
||||||
#~ msgid "Attached Modal Dialog"
|
#: ../src/ui/theme-viewer.c:737
|
||||||
#~ msgstr "Csatolt kizárólagos párbeszédablak"
|
#, c-format
|
||||||
|
msgid "Button layout test %d"
|
||||||
|
msgstr "Gombelrendezés teszt %d"
|
||||||
|
|
||||||
#~ msgid "Button layout test %d"
|
#: ../src/ui/theme-viewer.c:766
|
||||||
#~ msgstr "Gombelrendezés teszt %d"
|
#, c-format
|
||||||
|
msgid "%g milliseconds to draw one window frame"
|
||||||
|
msgstr "%g ezredmásodpercig tartott egy ablakkeret kirajzolása"
|
||||||
|
|
||||||
#~ msgid "%g milliseconds to draw one window frame"
|
#: ../src/ui/theme-viewer.c:811
|
||||||
#~ msgstr "%g ezredmásodpercig tartott egy ablakkeret kirajzolása"
|
#, c-format
|
||||||
|
msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
|
||||||
|
msgstr "Használat: metacity-theme-viewer [TÉMANÉV]\n"
|
||||||
|
|
||||||
#~ msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
|
#: ../src/ui/theme-viewer.c:818
|
||||||
#~ msgstr "Használat: metacity-theme-viewer [TÉMANÉV]\n"
|
#, c-format
|
||||||
|
msgid "Error loading theme: %s\n"
|
||||||
|
msgstr "Hiba történt a téma betöltése közben: %s\n"
|
||||||
|
|
||||||
#~ msgid "Error loading theme: %s\n"
|
#: ../src/ui/theme-viewer.c:824
|
||||||
#~ msgstr "Hiba történt a téma betöltése közben: %s\n"
|
#, c-format
|
||||||
|
msgid "Loaded theme \"%s\" in %g seconds\n"
|
||||||
|
msgstr "A(z) „%s” téma %g másodperc alatt betöltve\n"
|
||||||
|
|
||||||
#~ msgid "Loaded theme \"%s\" in %g seconds\n"
|
#: ../src/ui/theme-viewer.c:869
|
||||||
#~ msgstr "A(z) „%s” téma %g másodperc alatt betöltve\n"
|
msgid "Normal Title Font"
|
||||||
|
msgstr "Normál cím betűtípus"
|
||||||
|
|
||||||
#~ msgid "Normal Title Font"
|
#: ../src/ui/theme-viewer.c:875
|
||||||
#~ msgstr "Normál cím betűtípus"
|
msgid "Small Title Font"
|
||||||
|
msgstr "Kicsi cím betűtípus"
|
||||||
|
|
||||||
#~ msgid "Small Title Font"
|
#: ../src/ui/theme-viewer.c:881
|
||||||
#~ msgstr "Kicsi cím betűtípus"
|
msgid "Large Title Font"
|
||||||
|
msgstr "Nagy cím betűtípus"
|
||||||
|
|
||||||
#~ msgid "Large Title Font"
|
#: ../src/ui/theme-viewer.c:886
|
||||||
#~ msgstr "Nagy cím betűtípus"
|
msgid "Button Layouts"
|
||||||
|
msgstr "Gombelrendezések"
|
||||||
|
|
||||||
#~ msgid "Button Layouts"
|
#: ../src/ui/theme-viewer.c:891
|
||||||
#~ msgstr "Gombelrendezések"
|
msgid "Benchmark"
|
||||||
|
msgstr "Teljesítményteszt"
|
||||||
|
|
||||||
#~ msgid "Benchmark"
|
#: ../src/ui/theme-viewer.c:947
|
||||||
#~ msgstr "Teljesítményteszt"
|
msgid "Window Title Goes Here"
|
||||||
|
msgstr "Ide kerül az ablak címe"
|
||||||
|
|
||||||
#~ msgid "Window Title Goes Here"
|
#: ../src/ui/theme-viewer.c:1053
|
||||||
#~ msgstr "Ide kerül az ablak címe"
|
#, c-format
|
||||||
|
msgid ""
|
||||||
|
"Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g "
|
||||||
|
"seconds wall clock time including X server resources (%g milliseconds per "
|
||||||
|
"frame)\n"
|
||||||
|
msgstr ""
|
||||||
|
"%d keret kirajzolása %g kliens-oldali másodperc alatt (%g ezredmásodperc "
|
||||||
|
"képkeretenként) és %g összes idő beleértve az X szerver erőforrásokat (%g "
|
||||||
|
"ezredmásodperc képkeretenként)\n"
|
||||||
|
|
||||||
#~ msgid ""
|
#: ../src/ui/theme-viewer.c:1273
|
||||||
#~ "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and "
|
msgid "position expression test returned TRUE but set error"
|
||||||
#~ "%g seconds wall clock time including X server resources (%g milliseconds "
|
msgstr "a pozíció kifejezés teszt IGAZ értéket adott vissza, de hiba történt"
|
||||||
#~ "per frame)\n"
|
|
||||||
#~ msgstr ""
|
|
||||||
#~ "%d keret kirajzolása %g kliens-oldali másodperc alatt (%g ezredmásodperc "
|
|
||||||
#~ "képkeretenként) és %g összes idő beleértve az X szerver erőforrásokat (%g "
|
|
||||||
#~ "ezredmásodperc képkeretenként)\n"
|
|
||||||
|
|
||||||
#~ msgid "position expression test returned TRUE but set error"
|
#: ../src/ui/theme-viewer.c:1275
|
||||||
#~ msgstr ""
|
msgid "position expression test returned FALSE but didn't set error"
|
||||||
#~ "a pozíció kifejezés teszt IGAZ értéket adott vissza, de hiba történt"
|
msgstr ""
|
||||||
|
"a pozíció kifejezés teszt HAMIS értéket adott vissza, de nem történt hiba"
|
||||||
|
|
||||||
#~ msgid "position expression test returned FALSE but didn't set error"
|
#: ../src/ui/theme-viewer.c:1279
|
||||||
#~ msgstr ""
|
msgid "Error was expected but none given"
|
||||||
#~ "a pozíció kifejezés teszt HAMIS értéket adott vissza, de nem történt hiba"
|
msgstr "Hibát vártunk, de nem történt egy sem"
|
||||||
|
|
||||||
#~ msgid "Error was expected but none given"
|
#: ../src/ui/theme-viewer.c:1281
|
||||||
#~ msgstr "Hibát vártunk, de nem történt egy sem"
|
#, c-format
|
||||||
|
msgid "Error %d was expected but %d given"
|
||||||
|
msgstr "A(z) %d hibát vártuk, de a(z) %d hiba következett be"
|
||||||
|
|
||||||
#~ msgid "Error %d was expected but %d given"
|
#: ../src/ui/theme-viewer.c:1287
|
||||||
#~ msgstr "A(z) %d hibát vártuk, de a(z) %d hiba következett be"
|
#, c-format
|
||||||
|
msgid "Error not expected but one was returned: %s"
|
||||||
|
msgstr "Nem várt hiba következett be: %s"
|
||||||
|
|
||||||
#~ msgid "Error not expected but one was returned: %s"
|
#: ../src/ui/theme-viewer.c:1291
|
||||||
#~ msgstr "Nem várt hiba következett be: %s"
|
#, c-format
|
||||||
|
msgid "x value was %d, %d was expected"
|
||||||
|
msgstr "x értéke %d volt, de a várt érték %d volt"
|
||||||
|
|
||||||
#~ msgid "x value was %d, %d was expected"
|
#: ../src/ui/theme-viewer.c:1294
|
||||||
#~ msgstr "x értéke %d volt, de a várt érték %d volt"
|
#, c-format
|
||||||
|
msgid "y value was %d, %d was expected"
|
||||||
|
msgstr "y értéke %d volt, de a várt érték %d volt"
|
||||||
|
|
||||||
#~ msgid "y value was %d, %d was expected"
|
#: ../src/ui/theme-viewer.c:1359
|
||||||
#~ msgstr "y értéke %d volt, de a várt érték %d volt"
|
#, c-format
|
||||||
|
msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
|
||||||
#~ msgid ""
|
msgstr ""
|
||||||
#~ "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
|
"A %d koordináta kifejezések %g másodperc alatt lettek feldolgozva (átlagosan "
|
||||||
#~ msgstr ""
|
"%g másodperc)\n"
|
||||||
#~ "A %d koordináta kifejezések %g másodperc alatt lettek feldolgozva "
|
|
||||||
#~ "(átlagosan %g másodperc)\n"
|
|
||||||
|
|
||||||
#, fuzzy
|
#, fuzzy
|
||||||
#~ msgid "Minimize window"
|
#~ msgid "Minimize window"
|
||||||
|
|||||||
440
po/it.po
440
po/it.po
@@ -12,8 +12,8 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: mutter\n"
|
"Project-Id-Version: mutter\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2013-08-24 19:11+0200\n"
|
"POT-Creation-Date: 2013-03-12 18:34+0100\n"
|
||||||
"PO-Revision-Date: 2013-08-24 19:11+0200\n"
|
"PO-Revision-Date: 2013-03-12 18:35+0100\n"
|
||||||
"Last-Translator: Milo Casagrande <milo@ubuntu.com>\n"
|
"Last-Translator: Milo Casagrande <milo@ubuntu.com>\n"
|
||||||
"Language-Team: Italian <tp@lists.linux.it>\n"
|
"Language-Team: Italian <tp@lists.linux.it>\n"
|
||||||
"Language: it\n"
|
"Language: it\n"
|
||||||
@@ -21,7 +21,6 @@ msgstr ""
|
|||||||
"Content-Type: text/plain; charset=UTF-8\n"
|
"Content-Type: text/plain; charset=UTF-8\n"
|
||||||
"Content-Transfer-Encoding: 8-bit\n"
|
"Content-Transfer-Encoding: 8-bit\n"
|
||||||
"Plural-Forms: nplurals=2; plural=(n!=1);\n"
|
"Plural-Forms: nplurals=2; plural=(n!=1);\n"
|
||||||
"X-Generator: Gtranslator 2.91.6\n"
|
|
||||||
|
|
||||||
#: ../src/50-mutter-navigation.xml.in.h:1
|
#: ../src/50-mutter-navigation.xml.in.h:1
|
||||||
msgid "Navigation"
|
msgid "Navigation"
|
||||||
@@ -217,7 +216,7 @@ msgstr "Massimizza a destra"
|
|||||||
|
|
||||||
#. This probably means that a non-WM compositor like xcompmgr is running;
|
#. This probably means that a non-WM compositor like xcompmgr is running;
|
||||||
#. * we have no way to get it to exit
|
#. * we have no way to get it to exit
|
||||||
#: ../src/compositor/compositor.c:596
|
#: ../src/compositor/compositor.c:502
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Another compositing manager is already running on screen %i on display \"%s"
|
"Another compositing manager is already running on screen %i on display \"%s"
|
||||||
@@ -226,11 +225,11 @@ msgstr ""
|
|||||||
"Un altro compositing manager è già in esecuzione sullo schermo %i sul "
|
"Un altro compositing manager è già in esecuzione sullo schermo %i sul "
|
||||||
"display «%s»."
|
"display «%s»."
|
||||||
|
|
||||||
#: ../src/compositor/meta-background.c:1076
|
#: ../src/compositor/meta-background.c:1180
|
||||||
msgid "background texture could not be created from file"
|
msgid "background texture could not be created from file"
|
||||||
msgstr "La texture dello sfondo non può essere creata dal file"
|
msgstr "La texture dello sfondo non può essere creata dal file"
|
||||||
|
|
||||||
#: ../src/core/bell.c:322
|
#: ../src/core/bell.c:320
|
||||||
msgid "Bell event"
|
msgid "Bell event"
|
||||||
msgstr "Evento campanella"
|
msgstr "Evento campanella"
|
||||||
|
|
||||||
@@ -266,17 +265,17 @@ msgstr "_Attendi"
|
|||||||
msgid "_Force Quit"
|
msgid "_Force Quit"
|
||||||
msgstr "_Forza uscita"
|
msgstr "_Forza uscita"
|
||||||
|
|
||||||
#: ../src/core/display.c:422
|
#: ../src/core/display.c:402
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Missing %s extension required for compositing"
|
msgid "Missing %s extension required for compositing"
|
||||||
msgstr "Estensione %s richiesta per il compositing mancante"
|
msgstr "Estensione %s richiesta per il compositing mancante"
|
||||||
|
|
||||||
#: ../src/core/display.c:514
|
#: ../src/core/display.c:494
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open X Window System display '%s'\n"
|
msgid "Failed to open X Window System display '%s'\n"
|
||||||
msgstr "Apertura del display «%s» di X Window System non riuscita\n"
|
msgstr "Apertura del display «%s» di X Window System non riuscita\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1136
|
#: ../src/core/keybindings.c:929
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Some other program is already using the key %s with modifiers %x as a "
|
"Some other program is already using the key %s with modifiers %x as a "
|
||||||
@@ -285,41 +284,41 @@ msgstr ""
|
|||||||
"Qualche altro programma sta già usando il tasto %s con i modificatori %x "
|
"Qualche altro programma sta già usando il tasto %s con i modificatori %x "
|
||||||
"come una associazione di tasti\n"
|
"come una associazione di tasti\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1333
|
#: ../src/core/keybindings.c:1129
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "\"%s\" is not a valid accelerator\n"
|
msgid "\"%s\" is not a valid accelerator\n"
|
||||||
msgstr "«%s» non è una scorciatoia valida\n"
|
msgstr "«%s» non è una scorciatoia valida\n"
|
||||||
|
|
||||||
#: ../src/core/main.c:197
|
#: ../src/core/main.c:196
|
||||||
msgid "Disable connection to session manager"
|
msgid "Disable connection to session manager"
|
||||||
msgstr "Disabilita la connessione al gestore di sessione"
|
msgstr "Disabilita la connessione al gestore di sessione"
|
||||||
|
|
||||||
#: ../src/core/main.c:203
|
#: ../src/core/main.c:202
|
||||||
msgid "Replace the running window manager"
|
msgid "Replace the running window manager"
|
||||||
msgstr "Sostituisce il window manager in esecuzione"
|
msgstr "Sostituisce il window manager in esecuzione"
|
||||||
|
|
||||||
#: ../src/core/main.c:209
|
#: ../src/core/main.c:208
|
||||||
msgid "Specify session management ID"
|
msgid "Specify session management ID"
|
||||||
msgstr "Specifica l'ID di gestione sessione"
|
msgstr "Specifica l'ID di gestione sessione"
|
||||||
|
|
||||||
#: ../src/core/main.c:214
|
#: ../src/core/main.c:213
|
||||||
msgid "X Display to use"
|
msgid "X Display to use"
|
||||||
msgstr "Display X da usare"
|
msgstr "Display X da usare"
|
||||||
|
|
||||||
#: ../src/core/main.c:220
|
#: ../src/core/main.c:219
|
||||||
msgid "Initialize session from savefile"
|
msgid "Initialize session from savefile"
|
||||||
msgstr "Inizializza la sessione da file salvato"
|
msgstr "Inizializza la sessione da file salvato"
|
||||||
|
|
||||||
#: ../src/core/main.c:226
|
#: ../src/core/main.c:225
|
||||||
msgid "Make X calls synchronous"
|
msgid "Make X calls synchronous"
|
||||||
msgstr "Rende le chiamate X sincrone"
|
msgstr "Rende le chiamate X sincrone"
|
||||||
|
|
||||||
#: ../src/core/main.c:534
|
#: ../src/core/main.c:533
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to scan themes directory: %s\n"
|
msgid "Failed to scan themes directory: %s\n"
|
||||||
msgstr "Scansione della directory dei temi non riuscita: %s\n"
|
msgstr "Scansione della directory dei temi non riuscita: %s\n"
|
||||||
|
|
||||||
#: ../src/core/main.c:550
|
#: ../src/core/main.c:549
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
|
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
|
||||||
@@ -327,19 +326,6 @@ msgstr ""
|
|||||||
"Non è stato trovato alcun tema. Assicurarsi che %s esista e contenga i temi "
|
"Non è stato trovato alcun tema. Assicurarsi che %s esista e contenga i temi "
|
||||||
"standard.\n"
|
"standard.\n"
|
||||||
|
|
||||||
#: ../src/core/monitor.c:702
|
|
||||||
msgid "Built-in display"
|
|
||||||
msgstr "Display integrato"
|
|
||||||
|
|
||||||
#. TRANSLATORS: this is a monitor name (in case we don't know
|
|
||||||
#. the vendor), it's Unknown followed by a size in inches,
|
|
||||||
#. like 'Unknown 15"'
|
|
||||||
#.
|
|
||||||
#: ../src/core/monitor.c:730
|
|
||||||
#, c-format
|
|
||||||
msgid "Unknown %s"
|
|
||||||
msgstr "Sconosciuto %s"
|
|
||||||
|
|
||||||
#: ../src/core/mutter.c:40
|
#: ../src/core/mutter.c:40
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
@@ -363,7 +349,7 @@ msgstr "Stampa la versione"
|
|||||||
msgid "Mutter plugin to use"
|
msgid "Mutter plugin to use"
|
||||||
msgstr "Plugin Mutter da usare"
|
msgstr "Plugin Mutter da usare"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1202
|
#: ../src/core/prefs.c:1087
|
||||||
msgid ""
|
msgid ""
|
||||||
"Workarounds for broken applications disabled. Some applications may not "
|
"Workarounds for broken applications disabled. Some applications may not "
|
||||||
"behave properly.\n"
|
"behave properly.\n"
|
||||||
@@ -371,14 +357,14 @@ msgstr ""
|
|||||||
"Disabilitate le funzionalità palliative per la applicazioni difettose. "
|
"Disabilitate le funzionalità palliative per la applicazioni difettose. "
|
||||||
"Alcune applicazioni potrebbero avere comportamenti errati.\n"
|
"Alcune applicazioni potrebbero avere comportamenti errati.\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1277
|
#: ../src/core/prefs.c:1162
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Impossibile analizzare la descrizione del tipo di carattere «%s» dalla "
|
"Impossibile analizzare la descrizione del tipo di carattere «%s» dalla "
|
||||||
"chiave GSettings %s\n"
|
"chiave GSettings %s\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1343
|
#: ../src/core/prefs.c:1228
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for mouse button "
|
"\"%s\" found in configuration database is not a valid value for mouse button "
|
||||||
@@ -387,7 +373,7 @@ msgstr ""
|
|||||||
"Il valore «%s» trovato nel database di configurazione non è valido per il "
|
"Il valore «%s» trovato nel database di configurazione non è valido per il "
|
||||||
"modificatore del tasto del mouse\n"
|
"modificatore del tasto del mouse\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1909
|
#: ../src/core/prefs.c:1780
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for keybinding "
|
"\"%s\" found in configuration database is not a valid value for keybinding "
|
||||||
@@ -396,17 +382,17 @@ msgstr ""
|
|||||||
"Il valore «%s» nel database di configurazione non è valido per "
|
"Il valore «%s» nel database di configurazione non è valido per "
|
||||||
"l'associazione di tasti «%s»\n"
|
"l'associazione di tasti «%s»\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1999
|
#: ../src/core/prefs.c:1879
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d"
|
msgid "Workspace %d"
|
||||||
msgstr "Spazio di lavoro %d"
|
msgstr "Spazio di lavoro %d"
|
||||||
|
|
||||||
#: ../src/core/screen.c:537
|
#: ../src/core/screen.c:674
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display '%s' is invalid\n"
|
msgid "Screen %d on display '%s' is invalid\n"
|
||||||
msgstr "Lo schermo %d nel display «%s» non è valido\n"
|
msgstr "Lo schermo %d nel display «%s» non è valido\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:553
|
#: ../src/core/screen.c:690
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
||||||
@@ -415,7 +401,7 @@ msgstr ""
|
|||||||
"Lo schermo %d sul display «%s» ha già un window manager; provare a "
|
"Lo schermo %d sul display «%s» ha già un window manager; provare a "
|
||||||
"utilizzare l'opzione --replace per sostituirlo.\n"
|
"utilizzare l'opzione --replace per sostituirlo.\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:580
|
#: ../src/core/screen.c:717
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
||||||
@@ -423,12 +409,12 @@ msgstr ""
|
|||||||
"Impossibile acquisire la selezione del window manager per lo schermo %d nel "
|
"Impossibile acquisire la selezione del window manager per lo schermo %d nel "
|
||||||
"display «%s»\n"
|
"display «%s»\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:658
|
#: ../src/core/screen.c:795
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
||||||
msgstr "Lo schermo %d sul display «%s» ha già un window manager\n"
|
msgstr "Lo schermo %d sul display «%s» ha già un window manager\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:850
|
#: ../src/core/screen.c:980
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not release screen %d on display \"%s\"\n"
|
msgid "Could not release screen %d on display \"%s\"\n"
|
||||||
msgstr "Impossibile rilasciare lo schermo %d sul display «%s»\n"
|
msgstr "Impossibile rilasciare lo schermo %d sul display «%s»\n"
|
||||||
@@ -490,44 +476,45 @@ msgstr ""
|
|||||||
"Queste finestre non supportano la funzione "salva impostazioni "
|
"Queste finestre non supportano la funzione "salva impostazioni "
|
||||||
"attuali" e dovranno essere riavviate manualmente al prossimo accesso."
|
"attuali" e dovranno essere riavviate manualmente al prossimo accesso."
|
||||||
|
|
||||||
#: ../src/core/util.c:84
|
#: ../src/core/util.c:80
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open debug log: %s\n"
|
msgid "Failed to open debug log: %s\n"
|
||||||
msgstr "Apertura nel file di registro di debug non riuscita: %s\n"
|
msgstr "Apertura nel file di registro di debug non riuscita: %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:94
|
#: ../src/core/util.c:90
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to fdopen() log file %s: %s\n"
|
msgid "Failed to fdopen() log file %s: %s\n"
|
||||||
msgstr "Esecuzione di fdopen() sul file di registro %s non riuscita: %s\n"
|
msgstr "Esecuzione di fdopen() sul file di registro %s non riuscita: %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:100
|
#: ../src/core/util.c:96
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Opened log file %s\n"
|
msgid "Opened log file %s\n"
|
||||||
msgstr "File di registro %s aperto\n"
|
msgstr "File di registro %s aperto\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:119
|
#: ../src/core/util.c:115 ../src/tools/mutter-message.c:149
|
||||||
|
#, c-format
|
||||||
msgid "Mutter was compiled without support for verbose mode\n"
|
msgid "Mutter was compiled without support for verbose mode\n"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Mutter è stato compilato escludendo il supporto per la modalità prolissa\n"
|
"Mutter è stato compilato escludendo il supporto per la modalità prolissa\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:264
|
#: ../src/core/util.c:259
|
||||||
msgid "Window manager: "
|
msgid "Window manager: "
|
||||||
msgstr "Window manager: "
|
msgstr "Window manager: "
|
||||||
|
|
||||||
#: ../src/core/util.c:414
|
#: ../src/core/util.c:407
|
||||||
msgid "Bug in window manager: "
|
msgid "Bug in window manager: "
|
||||||
msgstr "Bug nel window manager: "
|
msgstr "Bug nel window manager: "
|
||||||
|
|
||||||
#: ../src/core/util.c:445
|
#: ../src/core/util.c:438
|
||||||
msgid "Window manager warning: "
|
msgid "Window manager warning: "
|
||||||
msgstr "Avviso del window manager: "
|
msgstr "Avviso del window manager: "
|
||||||
|
|
||||||
#: ../src/core/util.c:473
|
#: ../src/core/util.c:466
|
||||||
msgid "Window manager error: "
|
msgid "Window manager error: "
|
||||||
msgstr "Errore del window manager: "
|
msgstr "Errore del window manager: "
|
||||||
|
|
||||||
#. first time through
|
#. first time through
|
||||||
#: ../src/core/window.c:7533
|
#: ../src/core/window.c:7538
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
||||||
@@ -543,7 +530,7 @@ msgstr ""
|
|||||||
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
||||||
#. * about these apps but make them work.
|
#. * about these apps but make them work.
|
||||||
#.
|
#.
|
||||||
#: ../src/core/window.c:8257
|
#: ../src/core/window.c:8262
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
||||||
@@ -553,26 +540,26 @@ msgstr ""
|
|||||||
"ridimensionabile, ma ha impostato la dimensione minima %d x %d e la "
|
"ridimensionabile, ma ha impostato la dimensione minima %d x %d e la "
|
||||||
"dimensione massima %d x %d; ciò non ha senso.\n"
|
"dimensione massima %d x %d; ciò non ha senso.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:347
|
#: ../src/core/window-props.c:318
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
||||||
msgstr "L'applicazione ha impostato un _NET_WM_PID errato %lu\n"
|
msgstr "L'applicazione ha impostato un _NET_WM_PID errato %lu\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:463
|
#: ../src/core/window-props.c:434
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s (on %s)"
|
msgid "%s (on %s)"
|
||||||
msgstr "%s (su %s)"
|
msgstr "%s (su %s)"
|
||||||
|
|
||||||
# Sì, direi che è oscuro -Luca
|
# Sì, direi che è oscuro -Luca
|
||||||
#
|
#
|
||||||
#: ../src/core/window-props.c:1546
|
#: ../src/core/window-props.c:1517
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
||||||
msgstr "Specificato un WM_TRANSIENT_FOR finestra 0x%lx non valido per %s.\n"
|
msgstr "Specificato un WM_TRANSIENT_FOR finestra 0x%lx non valido per %s.\n"
|
||||||
|
|
||||||
# Sì, direi che è oscuro -Luca
|
# Sì, direi che è oscuro -Luca
|
||||||
#
|
#
|
||||||
#: ../src/core/window-props.c:1557
|
#: ../src/core/window-props.c:1528
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
||||||
msgstr "WM_TRANSIENT_FOR finestra 0x%lx per %s potrebbe creare un loop.\n"
|
msgstr "WM_TRANSIENT_FOR finestra 0x%lx per %s potrebbe creare un loop.\n"
|
||||||
@@ -744,120 +731,125 @@ msgstr "Seleziona finestra dal tab popup"
|
|||||||
msgid "Cancel tab popup"
|
msgid "Cancel tab popup"
|
||||||
msgstr "Annulla tab popup"
|
msgstr "Annulla tab popup"
|
||||||
|
|
||||||
|
#: ../src/tools/mutter-message.c:123
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: %s\n"
|
||||||
|
msgstr "Uso: %s\n"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:67
|
#: ../src/ui/menu.c:69
|
||||||
msgid "Mi_nimize"
|
msgid "Mi_nimize"
|
||||||
msgstr "_Minimizza"
|
msgstr "_Minimizza"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:69
|
#: ../src/ui/menu.c:71
|
||||||
msgid "Ma_ximize"
|
msgid "Ma_ximize"
|
||||||
msgstr "Ma_ssimizza"
|
msgstr "Ma_ssimizza"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:71
|
#: ../src/ui/menu.c:73
|
||||||
msgid "Unma_ximize"
|
msgid "Unma_ximize"
|
||||||
msgstr "Dema_ssimizza"
|
msgstr "Dema_ssimizza"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:73
|
#: ../src/ui/menu.c:75
|
||||||
msgid "Roll _Up"
|
msgid "Roll _Up"
|
||||||
msgstr "Arr_otola"
|
msgstr "Arr_otola"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:75
|
#: ../src/ui/menu.c:77
|
||||||
msgid "_Unroll"
|
msgid "_Unroll"
|
||||||
msgstr "Sr_otola"
|
msgstr "Sr_otola"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:77
|
#: ../src/ui/menu.c:79
|
||||||
msgid "_Move"
|
msgid "_Move"
|
||||||
msgstr "M_uovi"
|
msgstr "M_uovi"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:79
|
#: ../src/ui/menu.c:81
|
||||||
msgid "_Resize"
|
msgid "_Resize"
|
||||||
msgstr "_Ridimensiona"
|
msgstr "_Ridimensiona"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:81
|
#: ../src/ui/menu.c:83
|
||||||
msgid "Move Titlebar On_screen"
|
msgid "Move Titlebar On_screen"
|
||||||
msgstr "Muovi barra del titolo su _schermo"
|
msgstr "Muovi barra del titolo su _schermo"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:84 ../src/ui/menu.c:86
|
#: ../src/ui/menu.c:86 ../src/ui/menu.c:88
|
||||||
msgid "Always on _Top"
|
msgid "Always on _Top"
|
||||||
msgstr "Sempre in _primo piano"
|
msgstr "Sempre in _primo piano"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:88
|
#: ../src/ui/menu.c:90
|
||||||
msgid "_Always on Visible Workspace"
|
msgid "_Always on Visible Workspace"
|
||||||
msgstr "Sempre su spazio di lavoro _visibile"
|
msgstr "Sempre su spazio di lavoro _visibile"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:90
|
#: ../src/ui/menu.c:92
|
||||||
msgid "_Only on This Workspace"
|
msgid "_Only on This Workspace"
|
||||||
msgstr "Solo su _questo spazio di lavoro"
|
msgstr "Solo su _questo spazio di lavoro"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:92
|
#: ../src/ui/menu.c:94
|
||||||
msgid "Move to Workspace _Left"
|
msgid "Move to Workspace _Left"
|
||||||
msgstr "Sposta su spazio di lavoro a s_inistra"
|
msgstr "Sposta su spazio di lavoro a s_inistra"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:94
|
#: ../src/ui/menu.c:96
|
||||||
msgid "Move to Workspace R_ight"
|
msgid "Move to Workspace R_ight"
|
||||||
msgstr "Sposta su spazio di lavoro a d_estra"
|
msgstr "Sposta su spazio di lavoro a d_estra"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:96
|
#: ../src/ui/menu.c:98
|
||||||
msgid "Move to Workspace _Up"
|
msgid "Move to Workspace _Up"
|
||||||
msgstr "Sposta su spazio di lavoro in alt_o"
|
msgstr "Sposta su spazio di lavoro in alt_o"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:98
|
#: ../src/ui/menu.c:100
|
||||||
msgid "Move to Workspace _Down"
|
msgid "Move to Workspace _Down"
|
||||||
msgstr "Sposta su spazio di lavoro in _basso"
|
msgstr "Sposta su spazio di lavoro in _basso"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:102
|
#: ../src/ui/menu.c:104
|
||||||
msgid "_Close"
|
msgid "_Close"
|
||||||
msgstr "_Chiudi"
|
msgstr "_Chiudi"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#: ../src/ui/menu.c:202
|
#: ../src/ui/menu.c:204
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d%n"
|
msgid "Workspace %d%n"
|
||||||
msgstr "Spazio di lavoro %d%n"
|
msgstr "Spazio di lavoro %d%n"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#: ../src/ui/menu.c:212
|
#: ../src/ui/menu.c:214
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace 1_0"
|
msgid "Workspace 1_0"
|
||||||
msgstr "Spazio di lavoro 1_0"
|
msgstr "Spazio di lavoro 1_0"
|
||||||
|
|
||||||
# mantenere in sync con libwnck
|
# mantenere in sync con libwnck
|
||||||
#: ../src/ui/menu.c:214
|
#: ../src/ui/menu.c:216
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %s%d"
|
msgid "Workspace %s%d"
|
||||||
msgstr "Spazio di lavoro %s%d"
|
msgstr "Spazio di lavoro %s%d"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:384
|
#: ../src/ui/menu.c:397
|
||||||
msgid "Move to Another _Workspace"
|
msgid "Move to Another _Workspace"
|
||||||
msgstr "Sposta su _altro spazio di lavoro"
|
msgstr "Sposta su _altro spazio di lavoro"
|
||||||
|
|
||||||
@@ -959,49 +951,49 @@ msgstr "Mod5"
|
|||||||
msgid "%d x %d"
|
msgid "%d x %d"
|
||||||
msgstr "%d × %d"
|
msgstr "%d × %d"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:236
|
#: ../src/ui/theme.c:235
|
||||||
msgid "top"
|
msgid "top"
|
||||||
msgstr "alto"
|
msgstr "alto"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:238
|
#: ../src/ui/theme.c:237
|
||||||
msgid "bottom"
|
msgid "bottom"
|
||||||
msgstr "basso"
|
msgstr "basso"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:240
|
#: ../src/ui/theme.c:239
|
||||||
msgid "left"
|
msgid "left"
|
||||||
msgstr "sinistra"
|
msgstr "sinistra"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:242
|
#: ../src/ui/theme.c:241
|
||||||
msgid "right"
|
msgid "right"
|
||||||
msgstr "destra"
|
msgstr "destra"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:270
|
#: ../src/ui/theme.c:269
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "frame geometry does not specify \"%s\" dimension"
|
msgid "frame geometry does not specify \"%s\" dimension"
|
||||||
msgstr "la geometria della cornice non specifica la dimensione «%s»"
|
msgstr "la geometria della cornice non specifica la dimensione «%s»"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:289
|
#: ../src/ui/theme.c:288
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "frame geometry does not specify dimension \"%s\" for border \"%s\""
|
msgid "frame geometry does not specify dimension \"%s\" for border \"%s\""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"la geometria della cornice non specifica la dimensione «%s» per il bordo «%s»"
|
"la geometria della cornice non specifica la dimensione «%s» per il bordo «%s»"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:326
|
#: ../src/ui/theme.c:325
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Button aspect ratio %g is not reasonable"
|
msgid "Button aspect ratio %g is not reasonable"
|
||||||
msgstr "Le proporzioni %g del pulsante non sono ragionevoli"
|
msgstr "Le proporzioni %g del pulsante non sono ragionevoli"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:338
|
#: ../src/ui/theme.c:337
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Frame geometry does not specify size of buttons"
|
msgid "Frame geometry does not specify size of buttons"
|
||||||
msgstr "La geometria della cornice non specifica la dimensione dei pulsanti"
|
msgstr "La geometria della cornice non specifica la dimensione dei pulsanti"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1051
|
#: ../src/ui/theme.c:1050
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Gradients should have at least two colors"
|
msgid "Gradients should have at least two colors"
|
||||||
msgstr "I gradienti dovrebbero avere almeno due colori"
|
msgstr "I gradienti dovrebbero avere almeno due colori"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1203
|
#: ../src/ui/theme.c:1202
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK custom color specification must have color name and fallback in "
|
"GTK custom color specification must have color name and fallback in "
|
||||||
@@ -1011,7 +1003,7 @@ msgstr ""
|
|||||||
"colore e un ripiego tra parentesi, per es. gtk:custom(foo,bar); impossibile "
|
"colore e un ripiego tra parentesi, per es. gtk:custom(foo,bar); impossibile "
|
||||||
"analizzare \"%s\""
|
"analizzare \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1219
|
#: ../src/ui/theme.c:1218
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
|
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
|
||||||
@@ -1020,7 +1012,7 @@ msgstr ""
|
|||||||
"Carattere \"%c\" non valido nel parametro color_name di gtk:custom, sono "
|
"Carattere \"%c\" non valido nel parametro color_name di gtk:custom, sono "
|
||||||
"validi solo A-Za-z0-9-_"
|
"validi solo A-Za-z0-9-_"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1233
|
#: ../src/ui/theme.c:1232
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
|
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
|
||||||
@@ -1029,7 +1021,7 @@ msgstr ""
|
|||||||
"Il formato per Gtk:custom è \"gtk:custom(color_name,fallback)\", «%s» non è "
|
"Il formato per Gtk:custom è \"gtk:custom(color_name,fallback)\", «%s» non è "
|
||||||
"adatto a tale formato"
|
"adatto a tale formato"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1278
|
#: ../src/ui/theme.c:1277
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
|
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
|
||||||
@@ -1038,7 +1030,7 @@ msgstr ""
|
|||||||
"La specificazione del colore GTK deve avere lo stato fra parentesi, per es. "
|
"La specificazione del colore GTK deve avere lo stato fra parentesi, per es. "
|
||||||
"gtk:fg[NORMAL] dove NORMAL è lo stato; impossibile analizzare \"%s\""
|
"gtk:fg[NORMAL] dove NORMAL è lo stato; impossibile analizzare \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1292
|
#: ../src/ui/theme.c:1291
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK color specification must have a close bracket after the state, e.g. gtk:"
|
"GTK color specification must have a close bracket after the state, e.g. gtk:"
|
||||||
@@ -1048,18 +1040,18 @@ msgstr ""
|
|||||||
"lo stato, per es. gtk:fg[NORMAL] dove NORMAL è lo stato; impossibile "
|
"lo stato, per es. gtk:fg[NORMAL] dove NORMAL è lo stato; impossibile "
|
||||||
"analizzare \"%s\""
|
"analizzare \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1303
|
#: ../src/ui/theme.c:1302
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Did not understand state \"%s\" in color specification"
|
msgid "Did not understand state \"%s\" in color specification"
|
||||||
msgstr "Stato «%s» incomprensibile nella specificazione del colore"
|
msgstr "Stato «%s» incomprensibile nella specificazione del colore"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1316
|
#: ../src/ui/theme.c:1315
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Did not understand color component \"%s\" in color specification"
|
msgid "Did not understand color component \"%s\" in color specification"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Componente di colore «%s» incomprensibile nella specificazione del colore"
|
"Componente di colore «%s» incomprensibile nella specificazione del colore"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1345
|
#: ../src/ui/theme.c:1344
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the "
|
"Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the "
|
||||||
@@ -1068,17 +1060,17 @@ msgstr ""
|
|||||||
"Il formato della sfumature è «blend/bg_color/fg_color/alpha», «%s» non è "
|
"Il formato della sfumature è «blend/bg_color/fg_color/alpha», «%s» non è "
|
||||||
"adatto a tale formato"
|
"adatto a tale formato"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1356
|
#: ../src/ui/theme.c:1355
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse alpha value \"%s\" in blended color"
|
msgid "Could not parse alpha value \"%s\" in blended color"
|
||||||
msgstr "Impossibile analizzare il valore alpha «%s» nel colore sfumato"
|
msgstr "Impossibile analizzare il valore alpha «%s» nel colore sfumato"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1366
|
#: ../src/ui/theme.c:1365
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0"
|
msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0"
|
||||||
msgstr "Il valore alpha «%s» nel colore sfumato non è compreso tra 0.0 e 1.0"
|
msgstr "Il valore alpha «%s» nel colore sfumato non è compreso tra 0.0 e 1.0"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1413
|
#: ../src/ui/theme.c:1412
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format"
|
"Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format"
|
||||||
@@ -1086,31 +1078,31 @@ msgstr ""
|
|||||||
"Il formato dell'ombreggiatura è «shade/base_color/factor», «%s» non è adatto "
|
"Il formato dell'ombreggiatura è «shade/base_color/factor», «%s» non è adatto "
|
||||||
"a tale formato"
|
"a tale formato"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1424
|
#: ../src/ui/theme.c:1423
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse shade factor \"%s\" in shaded color"
|
msgid "Could not parse shade factor \"%s\" in shaded color"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Impossibile analizzare il fattore di ombreggiatura «%s» nel colore "
|
"Impossibile analizzare il fattore di ombreggiatura «%s» nel colore "
|
||||||
"ombreggiato"
|
"ombreggiato"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1434
|
#: ../src/ui/theme.c:1433
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Shade factor \"%s\" in shaded color is negative"
|
msgid "Shade factor \"%s\" in shaded color is negative"
|
||||||
msgstr "Il fattore di ombreggiatura «%s» nel colore ombreggiato è negativo"
|
msgstr "Il fattore di ombreggiatura «%s» nel colore ombreggiato è negativo"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1463
|
#: ../src/ui/theme.c:1462
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse color \"%s\""
|
msgid "Could not parse color \"%s\""
|
||||||
msgstr "Impossibile analizzare il colore «%s»"
|
msgstr "Impossibile analizzare il colore «%s»"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1780
|
#: ../src/ui/theme.c:1779
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression contains character '%s' which is not allowed"
|
msgid "Coordinate expression contains character '%s' which is not allowed"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'espressione delle coordinate contiene il carattere «%s» che non è "
|
"L'espressione delle coordinate contiene il carattere «%s» che non è "
|
||||||
"consentito"
|
"consentito"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1807
|
#: ../src/ui/theme.c:1806
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression contains floating point number '%s' which could not be "
|
"Coordinate expression contains floating point number '%s' which could not be "
|
||||||
@@ -1119,14 +1111,14 @@ msgstr ""
|
|||||||
"L'espressione delle coordinate contiene il numero in virgola mobile «%s» che "
|
"L'espressione delle coordinate contiene il numero in virgola mobile «%s» che "
|
||||||
"non può essere analizzato"
|
"non può essere analizzato"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1821
|
#: ../src/ui/theme.c:1820
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression contains integer '%s' which could not be parsed"
|
msgid "Coordinate expression contains integer '%s' which could not be parsed"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'espressione delle coordinate contiene l'intero «%s» che non può essere "
|
"L'espressione delle coordinate contiene l'intero «%s» che non può essere "
|
||||||
"analizzato"
|
"analizzato"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1942
|
#: ../src/ui/theme.c:1941
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression contained unknown operator at the start of this text: "
|
"Coordinate expression contained unknown operator at the start of this text: "
|
||||||
@@ -1135,18 +1127,18 @@ msgstr ""
|
|||||||
"L'espressione delle coordinate contiene un operatore sconosciuto all'inizio "
|
"L'espressione delle coordinate contiene un operatore sconosciuto all'inizio "
|
||||||
"di questo testo: \"%s\""
|
"di questo testo: \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1999
|
#: ../src/ui/theme.c:1998
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression was empty or not understood"
|
msgid "Coordinate expression was empty or not understood"
|
||||||
msgstr "L'espressione delle coordinate è vuota o incomprensibile"
|
msgstr "L'espressione delle coordinate è vuota o incomprensibile"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2112 ../src/ui/theme.c:2122 ../src/ui/theme.c:2156
|
#: ../src/ui/theme.c:2111 ../src/ui/theme.c:2121 ../src/ui/theme.c:2155
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression results in division by zero"
|
msgid "Coordinate expression results in division by zero"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'espressione delle coordinate ha come risultato una divisione per zero"
|
"L'espressione delle coordinate ha come risultato una divisione per zero"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2164
|
#: ../src/ui/theme.c:2163
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression tries to use mod operator on a floating-point number"
|
"Coordinate expression tries to use mod operator on a floating-point number"
|
||||||
@@ -1154,27 +1146,27 @@ msgstr ""
|
|||||||
"L'espressione delle coordinate tenta di usare un operatore mod su un numero "
|
"L'espressione delle coordinate tenta di usare un operatore mod su un numero "
|
||||||
"in virgola mobile"
|
"in virgola mobile"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2220
|
#: ../src/ui/theme.c:2219
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression has an operator \"%s\" where an operand was expected"
|
"Coordinate expression has an operator \"%s\" where an operand was expected"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'espressione delle coordinate ha un operatore «%s» dove è atteso un operando"
|
"L'espressione delle coordinate ha un operatore «%s» dove è atteso un operando"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2229
|
#: ../src/ui/theme.c:2228
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had an operand where an operator was expected"
|
msgid "Coordinate expression had an operand where an operator was expected"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'espressione delle coordinate ha un operando dove è atteso un operatore"
|
"L'espressione delle coordinate ha un operando dove è atteso un operatore"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2237
|
#: ../src/ui/theme.c:2236
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression ended with an operator instead of an operand"
|
msgid "Coordinate expression ended with an operator instead of an operand"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'espressione delle coordinate finisce con un operatore invece che un "
|
"L'espressione delle coordinate finisce con un operatore invece che un "
|
||||||
"operando"
|
"operando"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2247
|
#: ../src/ui/theme.c:2246
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression has operator \"%c\" following operator \"%c\" with no "
|
"Coordinate expression has operator \"%c\" following operator \"%c\" with no "
|
||||||
@@ -1183,45 +1175,45 @@ msgstr ""
|
|||||||
"L'espressione delle coordinate ha l'operatore «%c» seguito dall'operatore "
|
"L'espressione delle coordinate ha l'operatore «%c» seguito dall'operatore "
|
||||||
"«%c» senza un operando fra i due"
|
"«%c» senza un operando fra i due"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2398 ../src/ui/theme.c:2443
|
#: ../src/ui/theme.c:2397 ../src/ui/theme.c:2442
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had unknown variable or constant \"%s\""
|
msgid "Coordinate expression had unknown variable or constant \"%s\""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'espressione delle coordinate ha la variabile o la costante «%s» sconosciuta"
|
"L'espressione delle coordinate ha la variabile o la costante «%s» sconosciuta"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2497
|
#: ../src/ui/theme.c:2496
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression parser overflowed its buffer."
|
msgid "Coordinate expression parser overflowed its buffer."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'analizzatore dell'espressione delle coordinate ha superato il proprio "
|
"L'analizzatore dell'espressione delle coordinate ha superato il proprio "
|
||||||
"buffer."
|
"buffer."
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2526
|
#: ../src/ui/theme.c:2525
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had a close parenthesis with no open parenthesis"
|
msgid "Coordinate expression had a close parenthesis with no open parenthesis"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'espressione delle coordinate ha una parentesi di chiusura senza la "
|
"L'espressione delle coordinate ha una parentesi di chiusura senza la "
|
||||||
"relativa di apertura"
|
"relativa di apertura"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2590
|
#: ../src/ui/theme.c:2589
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had an open parenthesis with no close parenthesis"
|
msgid "Coordinate expression had an open parenthesis with no close parenthesis"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'espressione delle coordinate ha una parentesi di apertura senza la "
|
"L'espressione delle coordinate ha una parentesi di apertura senza la "
|
||||||
"relativa di chiusura"
|
"relativa di chiusura"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2601
|
#: ../src/ui/theme.c:2600
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression doesn't seem to have any operators or operands"
|
msgid "Coordinate expression doesn't seem to have any operators or operands"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"L'espressione delle coordinate non sembra avere né operatori né operandi"
|
"L'espressione delle coordinate non sembra avere né operatori né operandi"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2814 ../src/ui/theme.c:2834 ../src/ui/theme.c:2854
|
#: ../src/ui/theme.c:2813 ../src/ui/theme.c:2833 ../src/ui/theme.c:2853
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Theme contained an expression that resulted in an error: %s\n"
|
msgid "Theme contained an expression that resulted in an error: %s\n"
|
||||||
msgstr "Il tema contiene un'espressione che ha come risultato un errore: %s\n"
|
msgstr "Il tema contiene un'espressione che ha come risultato un errore: %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:4500
|
#: ../src/ui/theme.c:4499
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be "
|
"<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be "
|
||||||
@@ -1230,7 +1222,7 @@ msgstr ""
|
|||||||
"È necessario specificare <button function=\"%s\" state=\"%s\" draw_ops="
|
"È necessario specificare <button function=\"%s\" state=\"%s\" draw_ops="
|
||||||
"\"whatever\"/> per questo stile di cornice"
|
"\"whatever\"/> per questo stile di cornice"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5011 ../src/ui/theme.c:5036
|
#: ../src/ui/theme.c:5010 ../src/ui/theme.c:5035
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
|
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
|
||||||
@@ -1238,18 +1230,18 @@ msgstr ""
|
|||||||
"Risulta mancante <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style="
|
"Risulta mancante <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style="
|
||||||
"\"whatever\"/>"
|
"\"whatever\"/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5082
|
#: ../src/ui/theme.c:5083
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to load theme \"%s\": %s\n"
|
msgid "Failed to load theme \"%s\": %s\n"
|
||||||
msgstr "Caricamento del tema «%s» non riuscito: %s\n"
|
msgstr "Caricamento del tema «%s» non riuscito: %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232
|
#: ../src/ui/theme.c:5219 ../src/ui/theme.c:5226 ../src/ui/theme.c:5233
|
||||||
#: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246
|
#: ../src/ui/theme.c:5240 ../src/ui/theme.c:5247
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "No <%s> set for theme \"%s\""
|
msgid "No <%s> set for theme \"%s\""
|
||||||
msgstr "Nessun <%s> impostato per il tema «%s»"
|
msgstr "Nessun <%s> impostato per il tema «%s»"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5254
|
#: ../src/ui/theme.c:5255
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
||||||
@@ -1258,7 +1250,7 @@ msgstr ""
|
|||||||
"Nessuno stile di cornice impostato per il tipo di finestra «%s» nel tema "
|
"Nessuno stile di cornice impostato per il tipo di finestra «%s» nel tema "
|
||||||
"«%s», aggiungere un elemento <window type=\"%s\" style_set=\"whatever\"/>"
|
"«%s», aggiungere un elemento <window type=\"%s\" style_set=\"whatever\"/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786
|
#: ../src/ui/theme.c:5662 ../src/ui/theme.c:5724 ../src/ui/theme.c:5787
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
||||||
@@ -1266,7 +1258,7 @@ msgstr ""
|
|||||||
"Le costanti definite dall'utente devono iniziare con una lettera maiuscola, "
|
"Le costanti definite dall'utente devono iniziare con una lettera maiuscola, "
|
||||||
"«%s» non lo fa"
|
"«%s» non lo fa"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794
|
#: ../src/ui/theme.c:5670 ../src/ui/theme.c:5732 ../src/ui/theme.c:5795
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Constant \"%s\" has already been defined"
|
msgid "Constant \"%s\" has already been defined"
|
||||||
msgstr "La costante «%s» è già definita"
|
msgstr "La costante «%s» è già definita"
|
||||||
@@ -1669,7 +1661,207 @@ msgstr "Il testo non è consentito all'interno dell'elemento <%s>"
|
|||||||
msgid "<%s> specified twice for this theme"
|
msgid "<%s> specified twice for this theme"
|
||||||
msgstr "<%s> specificato due volte per questo tema"
|
msgstr "<%s> specificato due volte per questo tema"
|
||||||
|
|
||||||
#: ../src/ui/theme-parser.c:4336
|
#: ../src/ui/theme-parser.c:4334
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to find a valid file for theme %s\n"
|
msgid "Failed to find a valid file for theme %s\n"
|
||||||
msgstr "Ricerca di un file valido per il tema «%s» non riuscita\n"
|
msgstr "Ricerca di un file valido per il tema «%s» non riuscita\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:99
|
||||||
|
msgid "_Windows"
|
||||||
|
msgstr "_Finestre"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:100
|
||||||
|
msgid "_Dialog"
|
||||||
|
msgstr "_Dialogo"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:101
|
||||||
|
msgid "_Modal dialog"
|
||||||
|
msgstr "Dialogo _modale"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:102
|
||||||
|
msgid "_Utility"
|
||||||
|
msgstr "_Utilità"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:103
|
||||||
|
msgid "_Splashscreen"
|
||||||
|
msgstr "_Schermata d'avvio"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:104
|
||||||
|
msgid "_Top dock"
|
||||||
|
msgstr "Dock superi_ore"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:105
|
||||||
|
msgid "_Bottom dock"
|
||||||
|
msgstr "Dock in_feriore"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:106
|
||||||
|
msgid "_Left dock"
|
||||||
|
msgstr "Dock _sinistro"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:107
|
||||||
|
msgid "_Right dock"
|
||||||
|
msgstr "Dock _destro"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:108
|
||||||
|
msgid "_All docks"
|
||||||
|
msgstr "Tutti i doc_k"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:109
|
||||||
|
msgid "Des_ktop"
|
||||||
|
msgstr "Scri_vania"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:115
|
||||||
|
msgid "Open another one of these windows"
|
||||||
|
msgstr "Apre un'altra di queste finestre"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:117
|
||||||
|
msgid "This is a demo button with an 'open' icon"
|
||||||
|
msgstr "Questo è un pulsante di prova con un'icona «Apri»"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:119
|
||||||
|
msgid "This is a demo button with a 'quit' icon"
|
||||||
|
msgstr "Questo è un pulsante di prova con un'icona «Esci»"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:248
|
||||||
|
msgid "This is a sample message in a sample dialog"
|
||||||
|
msgstr "Questo è un messaggio d'esempio in una finestra di dialogo d'esempio"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:328
|
||||||
|
#, c-format
|
||||||
|
msgid "Fake menu item %d\n"
|
||||||
|
msgstr "Voce di menu finta n.%d\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:363
|
||||||
|
msgid "Border-only window"
|
||||||
|
msgstr "Finestra solo-bordo"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:365
|
||||||
|
msgid "Bar"
|
||||||
|
msgstr "Barra"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:382
|
||||||
|
msgid "Normal Application Window"
|
||||||
|
msgstr "Finestra applicazione normale"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:386
|
||||||
|
msgid "Dialog Box"
|
||||||
|
msgstr "Casella di dialogo"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:390
|
||||||
|
msgid "Modal Dialog Box"
|
||||||
|
msgstr "Casella di dialogo modale"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:394
|
||||||
|
msgid "Utility Palette"
|
||||||
|
msgstr "Tavolozza di utilità"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:398
|
||||||
|
msgid "Torn-off Menu"
|
||||||
|
msgstr "Menù staccato"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:402
|
||||||
|
msgid "Border"
|
||||||
|
msgstr "Bordo"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:406
|
||||||
|
msgid "Attached Modal Dialog"
|
||||||
|
msgstr "Dialogo modale attaccato"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:737
|
||||||
|
#, c-format
|
||||||
|
msgid "Button layout test %d"
|
||||||
|
msgstr "Test n.%d disposizione pulsanti"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:766
|
||||||
|
#, c-format
|
||||||
|
msgid "%g milliseconds to draw one window frame"
|
||||||
|
msgstr "%g millisecondi per disegnare una cornice di finestra"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:811
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
|
||||||
|
msgstr "Uso: metacity-theme-viewer [NOME_TEMA]\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:818
|
||||||
|
#, c-format
|
||||||
|
msgid "Error loading theme: %s\n"
|
||||||
|
msgstr "Errore nel caricare il tema: %s\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:824
|
||||||
|
#, c-format
|
||||||
|
msgid "Loaded theme \"%s\" in %g seconds\n"
|
||||||
|
msgstr "Tema «%s» caricato in %g secondi\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:869
|
||||||
|
msgid "Normal Title Font"
|
||||||
|
msgstr "Carattere titolo normale"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:875
|
||||||
|
msgid "Small Title Font"
|
||||||
|
msgstr "Carattere titolo piccolo"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:881
|
||||||
|
msgid "Large Title Font"
|
||||||
|
msgstr "Carattere titolo grande"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:886
|
||||||
|
msgid "Button Layouts"
|
||||||
|
msgstr "Disposizione pulsanti"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:891
|
||||||
|
msgid "Benchmark"
|
||||||
|
msgstr "Prestazioni"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:947
|
||||||
|
msgid "Window Title Goes Here"
|
||||||
|
msgstr "Qui va il titolo della finestra"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1053
|
||||||
|
#, c-format
|
||||||
|
msgid ""
|
||||||
|
"Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g "
|
||||||
|
"seconds wall clock time including X server resources (%g milliseconds per "
|
||||||
|
"frame)\n"
|
||||||
|
msgstr ""
|
||||||
|
"Disegnate %d cornici in %g secondi lato client (%g millisecondi per cornice) "
|
||||||
|
"e %g secondi di wall clock time, incluse le risorse del server X (%g "
|
||||||
|
"millisecondi per cornice)\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1273
|
||||||
|
msgid "position expression test returned TRUE but set error"
|
||||||
|
msgstr "test espressione posizione ha restituito TRUE, ma impostato errore"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1275
|
||||||
|
msgid "position expression test returned FALSE but didn't set error"
|
||||||
|
msgstr ""
|
||||||
|
"test espressione posizione ha restituito FALSE, ma non ha impostato errore"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1279
|
||||||
|
msgid "Error was expected but none given"
|
||||||
|
msgstr "Errore atteso, ma non fornito"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1281
|
||||||
|
#, c-format
|
||||||
|
msgid "Error %d was expected but %d given"
|
||||||
|
msgstr "Atteso errore %d, ma fornito %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1287
|
||||||
|
#, c-format
|
||||||
|
msgid "Error not expected but one was returned: %s"
|
||||||
|
msgstr "Errore non atteso, ma è stato restituito: %s"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1291
|
||||||
|
#, c-format
|
||||||
|
msgid "x value was %d, %d was expected"
|
||||||
|
msgstr "valore x era %d, era atteso %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1294
|
||||||
|
#, c-format
|
||||||
|
msgid "y value was %d, %d was expected"
|
||||||
|
msgstr "valore y era %d, era atteso %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1359
|
||||||
|
#, c-format
|
||||||
|
msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
|
||||||
|
msgstr ""
|
||||||
|
"%d espressioni di coordinate analizzate in %g secondi (%g secondi in media)\n"
|
||||||
|
|||||||
443
po/lt.po
443
po/lt.po
@@ -13,8 +13,8 @@ msgstr ""
|
|||||||
"Project-Id-Version: lt\n"
|
"Project-Id-Version: lt\n"
|
||||||
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?"
|
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?"
|
||||||
"product=mutter&keywords=I18N+L10N&component=general\n"
|
"product=mutter&keywords=I18N+L10N&component=general\n"
|
||||||
"POT-Creation-Date: 2013-08-18 20:03+0000\n"
|
"POT-Creation-Date: 2013-03-01 15:50+0000\n"
|
||||||
"PO-Revision-Date: 2013-08-28 23:06+0300\n"
|
"PO-Revision-Date: 2013-03-02 22:57+0200\n"
|
||||||
"Last-Translator: Aurimas Černius <aurisc4@gmail.com>\n"
|
"Last-Translator: Aurimas Černius <aurisc4@gmail.com>\n"
|
||||||
"Language-Team: Lietuvių <gnome-lt@lists.akl.lt>\n"
|
"Language-Team: Lietuvių <gnome-lt@lists.akl.lt>\n"
|
||||||
"Language: lt\n"
|
"Language: lt\n"
|
||||||
@@ -216,18 +216,18 @@ msgstr "Rodyti skyrimą dešinėje"
|
|||||||
|
|
||||||
#. This probably means that a non-WM compositor like xcompmgr is running;
|
#. This probably means that a non-WM compositor like xcompmgr is running;
|
||||||
#. * we have no way to get it to exit
|
#. * we have no way to get it to exit
|
||||||
#: ../src/compositor/compositor.c:589
|
#: ../src/compositor/compositor.c:507
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Another compositing manager is already running on screen %i on display \"%s"
|
"Another compositing manager is already running on screen %i on display \"%s"
|
||||||
"\"."
|
"\"."
|
||||||
msgstr "Kita kompozicijos valdyklė jau veikia ekrane %i vaizduoklyje „%s“."
|
msgstr "Kita kompozicijos valdyklė jau veikia ekrane %i vaizduoklyje „%s“."
|
||||||
|
|
||||||
#: ../src/compositor/meta-background.c:1076
|
#: ../src/compositor/meta-background.c:1111
|
||||||
msgid "background texture could not be created from file"
|
msgid "background texture could not be created from file"
|
||||||
msgstr "nepavyko sukurti fono tekstūros iš failo"
|
msgstr "nepavyko sukurti fono tekstūros iš failo"
|
||||||
|
|
||||||
#: ../src/core/bell.c:322
|
#: ../src/core/bell.c:320
|
||||||
msgid "Bell event"
|
msgid "Bell event"
|
||||||
msgstr "Skambučio įvykis"
|
msgstr "Skambučio įvykis"
|
||||||
|
|
||||||
@@ -259,17 +259,17 @@ msgstr "_Laukti"
|
|||||||
msgid "_Force Quit"
|
msgid "_Force Quit"
|
||||||
msgstr "_Priverstinai išeiti"
|
msgstr "_Priverstinai išeiti"
|
||||||
|
|
||||||
#: ../src/core/display.c:421
|
#: ../src/core/display.c:401
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Missing %s extension required for compositing"
|
msgid "Missing %s extension required for compositing"
|
||||||
msgstr "Trūksta %s priedo, reikalingo komponavimui"
|
msgstr "Trūksta %s priedo, reikalingo komponavimui"
|
||||||
|
|
||||||
#: ../src/core/display.c:513
|
#: ../src/core/display.c:493
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open X Window System display '%s'\n"
|
msgid "Failed to open X Window System display '%s'\n"
|
||||||
msgstr "Nepavyko atverti X Window sistemos ekrano „%s“\n"
|
msgstr "Nepavyko atverti X Window sistemos ekrano „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1136
|
#: ../src/core/keybindings.c:929
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Some other program is already using the key %s with modifiers %x as a "
|
"Some other program is already using the key %s with modifiers %x as a "
|
||||||
@@ -278,41 +278,42 @@ msgstr ""
|
|||||||
"Kažkokia kita programa jau naudoja %s klavišą su modifikatoriais %x kaip "
|
"Kažkokia kita programa jau naudoja %s klavišą su modifikatoriais %x kaip "
|
||||||
"susiejimą\n"
|
"susiejimą\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1333
|
#: ../src/core/keybindings.c:1129
|
||||||
#, c-format
|
#, c-format
|
||||||
|
#| msgid "\"%s\" is not a valid value for focus attribute"
|
||||||
msgid "\"%s\" is not a valid accelerator\n"
|
msgid "\"%s\" is not a valid accelerator\n"
|
||||||
msgstr "„%s“ yra nepriimtinas spartusis klavišas\n"
|
msgstr "„%s“ yra nepriimtinas spartusis klavišas\n"
|
||||||
|
|
||||||
#: ../src/core/main.c:197
|
#: ../src/core/main.c:196
|
||||||
msgid "Disable connection to session manager"
|
msgid "Disable connection to session manager"
|
||||||
msgstr "Išjungti susijungimą su sesijos valdykle"
|
msgstr "Išjungti susijungimą su sesijos valdykle"
|
||||||
|
|
||||||
#: ../src/core/main.c:203
|
#: ../src/core/main.c:202
|
||||||
msgid "Replace the running window manager"
|
msgid "Replace the running window manager"
|
||||||
msgstr "Pakeisti veikiančią langų valdyklę"
|
msgstr "Pakeisti veikiančią langų valdyklę"
|
||||||
|
|
||||||
#: ../src/core/main.c:209
|
#: ../src/core/main.c:208
|
||||||
msgid "Specify session management ID"
|
msgid "Specify session management ID"
|
||||||
msgstr "Nurodyti sesijos valdymo ID"
|
msgstr "Nurodyti sesijos valdymo ID"
|
||||||
|
|
||||||
#: ../src/core/main.c:214
|
#: ../src/core/main.c:213
|
||||||
msgid "X Display to use"
|
msgid "X Display to use"
|
||||||
msgstr "Naudotinas X ekranas"
|
msgstr "Naudotinas X ekranas"
|
||||||
|
|
||||||
#: ../src/core/main.c:220
|
#: ../src/core/main.c:219
|
||||||
msgid "Initialize session from savefile"
|
msgid "Initialize session from savefile"
|
||||||
msgstr "Inicializuoti sesiją iš išsaugojimo failo"
|
msgstr "Inicializuoti sesiją iš išsaugojimo failo"
|
||||||
|
|
||||||
#: ../src/core/main.c:226
|
#: ../src/core/main.c:225
|
||||||
msgid "Make X calls synchronous"
|
msgid "Make X calls synchronous"
|
||||||
msgstr "Sinchronizuoti X iškvietimus"
|
msgstr "Sinchronizuoti X iškvietimus"
|
||||||
|
|
||||||
#: ../src/core/main.c:534
|
#: ../src/core/main.c:494
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to scan themes directory: %s\n"
|
msgid "Failed to scan themes directory: %s\n"
|
||||||
msgstr "Nepavyko nuskanuoti temų aplanko: %s\n"
|
msgstr "Nepavyko nuskanuoti temų aplanko: %s\n"
|
||||||
|
|
||||||
#: ../src/core/main.c:550
|
#: ../src/core/main.c:510
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
|
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
|
||||||
@@ -320,20 +321,6 @@ msgstr ""
|
|||||||
"Nepavyko rasti temos! Įsitikinkite, kad %s egzistuoja ir kad ten yra "
|
"Nepavyko rasti temos! Įsitikinkite, kad %s egzistuoja ir kad ten yra "
|
||||||
"įprastos temos.\n"
|
"įprastos temos.\n"
|
||||||
|
|
||||||
#: ../src/core/monitor.c:711
|
|
||||||
msgid "Built-in display"
|
|
||||||
msgstr "Integruotas vaizduoklis"
|
|
||||||
|
|
||||||
#. TRANSLATORS: this is a monitor name (in case we don't know
|
|
||||||
#. the vendor), it's Unknown followed by a size in inches,
|
|
||||||
#. like 'Unknown 15"'
|
|
||||||
#.
|
|
||||||
#: ../src/core/monitor.c:739
|
|
||||||
#, c-format
|
|
||||||
#| msgid "Unknown element %s"
|
|
||||||
msgid "Unknown %s"
|
|
||||||
msgstr "Nežinomas %s"
|
|
||||||
|
|
||||||
#: ../src/core/mutter.c:40
|
#: ../src/core/mutter.c:40
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
@@ -359,7 +346,7 @@ msgstr "Parodyti versiją"
|
|||||||
msgid "Mutter plugin to use"
|
msgid "Mutter plugin to use"
|
||||||
msgstr "Naudojamas Mutter įskiepis"
|
msgstr "Naudojamas Mutter įskiepis"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1202
|
#: ../src/core/prefs.c:1087
|
||||||
msgid ""
|
msgid ""
|
||||||
"Workarounds for broken applications disabled. Some applications may not "
|
"Workarounds for broken applications disabled. Some applications may not "
|
||||||
"behave properly.\n"
|
"behave properly.\n"
|
||||||
@@ -367,12 +354,12 @@ msgstr ""
|
|||||||
"Apsauga nuo sugadintų programų atjungta. Kai kurios programos gali pradėti "
|
"Apsauga nuo sugadintų programų atjungta. Kai kurios programos gali pradėti "
|
||||||
"keistai elgtis.\n"
|
"keistai elgtis.\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1277
|
#: ../src/core/prefs.c:1162
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
||||||
msgstr "Nepavyko perskaityti šrifto aprašymo „%s“ saugomo GSettings rakte %s\n"
|
msgstr "Nepavyko perskaityti šrifto aprašymo „%s“ saugomo GSettings rakte %s\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1343
|
#: ../src/core/prefs.c:1228
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for mouse button "
|
"\"%s\" found in configuration database is not a valid value for mouse button "
|
||||||
@@ -381,7 +368,7 @@ msgstr ""
|
|||||||
"„%s“ reikšmė rasta nustatymų duomenų bazėje yra netinkama pelės mygtuko "
|
"„%s“ reikšmė rasta nustatymų duomenų bazėje yra netinkama pelės mygtuko "
|
||||||
"keitiklio aprašymui\n"
|
"keitiklio aprašymui\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1909
|
#: ../src/core/prefs.c:1780
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for keybinding "
|
"\"%s\" found in configuration database is not a valid value for keybinding "
|
||||||
@@ -390,17 +377,17 @@ msgstr ""
|
|||||||
"„%s“ reikšmė rasta konfiguracijos duomenų bazė yra netinkama klavišų "
|
"„%s“ reikšmė rasta konfiguracijos duomenų bazė yra netinkama klavišų "
|
||||||
"kombinacijai „%s“\n"
|
"kombinacijai „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1999
|
#: ../src/core/prefs.c:1879
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d"
|
msgid "Workspace %d"
|
||||||
msgstr "Darbalaukis %d"
|
msgstr "Darbalaukis %d"
|
||||||
|
|
||||||
#: ../src/core/screen.c:534
|
#: ../src/core/screen.c:673
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display '%s' is invalid\n"
|
msgid "Screen %d on display '%s' is invalid\n"
|
||||||
msgstr "Ekranas %d vaizduoklyje „%s“ netinkamas\n"
|
msgstr "Ekranas %d vaizduoklyje „%s“ netinkamas\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:550
|
#: ../src/core/screen.c:689
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
||||||
@@ -409,19 +396,19 @@ msgstr ""
|
|||||||
"Ekranas %d vaizduoklyje „%s“ jau turi langų valdyklę; pabandykite "
|
"Ekranas %d vaizduoklyje „%s“ jau turi langų valdyklę; pabandykite "
|
||||||
"pasinaudoti parinktimi --replace, jei norite pakeisti esamą langų valdyklę.\n"
|
"pasinaudoti parinktimi --replace, jei norite pakeisti esamą langų valdyklę.\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:577
|
#: ../src/core/screen.c:716
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Nepavyko aptikti langų valdyklės pasirinkimo ekrano %d vaizduoklyje „%s“\n"
|
"Nepavyko aptikti langų valdyklės pasirinkimo ekrano %d vaizduoklyje „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:655
|
#: ../src/core/screen.c:794
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
||||||
msgstr "Ekranas %d vaizduoklyje „%s“ jau turi langų valdyklę\n"
|
msgstr "Ekranas %d vaizduoklyje „%s“ jau turi langų valdyklę\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:846
|
#: ../src/core/screen.c:979
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not release screen %d on display \"%s\"\n"
|
msgid "Could not release screen %d on display \"%s\"\n"
|
||||||
msgstr "Nepavyko pasitraukti iš ekrano %d vaizduoklyje „%s“\n"
|
msgstr "Nepavyko pasitraukti iš ekrano %d vaizduoklyje „%s“\n"
|
||||||
@@ -481,43 +468,44 @@ msgstr ""
|
|||||||
"Šie langai nepalaiko "išsaugoti esamus nustatymus" komandos ir "
|
"Šie langai nepalaiko "išsaugoti esamus nustatymus" komandos ir "
|
||||||
"turi būti paleisti rankiniu būdu, kai prisijungsite kitą kartą."
|
"turi būti paleisti rankiniu būdu, kai prisijungsite kitą kartą."
|
||||||
|
|
||||||
#: ../src/core/util.c:84
|
#: ../src/core/util.c:80
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open debug log: %s\n"
|
msgid "Failed to open debug log: %s\n"
|
||||||
msgstr "Nepavyko atverti derinimo žurnalo: %s\n"
|
msgstr "Nepavyko atverti derinimo žurnalo: %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:94
|
#: ../src/core/util.c:90
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to fdopen() log file %s: %s\n"
|
msgid "Failed to fdopen() log file %s: %s\n"
|
||||||
msgstr "Funkcija fdopen() su žurnalo failu %s nesėkminga: %s\n"
|
msgstr "Funkcija fdopen() su žurnalo failu %s nesėkminga: %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:100
|
#: ../src/core/util.c:96
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Opened log file %s\n"
|
msgid "Opened log file %s\n"
|
||||||
msgstr "Atvertas žurnalo failas %s\n"
|
msgstr "Atvertas žurnalo failas %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:119
|
#: ../src/core/util.c:115 ../src/tools/mutter-message.c:149
|
||||||
|
#, c-format
|
||||||
msgid "Mutter was compiled without support for verbose mode\n"
|
msgid "Mutter was compiled without support for verbose mode\n"
|
||||||
msgstr "Mutter buvo sukompiliuota be išsamaus veikimo veiksenos\n"
|
msgstr "Mutter buvo sukompiliuota be išsamaus veikimo veiksenos\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:264
|
#: ../src/core/util.c:259
|
||||||
msgid "Window manager: "
|
msgid "Window manager: "
|
||||||
msgstr "Langų valdyklė:"
|
msgstr "Langų valdyklė:"
|
||||||
|
|
||||||
#: ../src/core/util.c:414
|
#: ../src/core/util.c:407
|
||||||
msgid "Bug in window manager: "
|
msgid "Bug in window manager: "
|
||||||
msgstr "Klaida langų valdyklėje:"
|
msgstr "Klaida langų valdyklėje:"
|
||||||
|
|
||||||
#: ../src/core/util.c:445
|
#: ../src/core/util.c:438
|
||||||
msgid "Window manager warning: "
|
msgid "Window manager warning: "
|
||||||
msgstr "Langų valdyklės perspėjimas:"
|
msgstr "Langų valdyklės perspėjimas:"
|
||||||
|
|
||||||
#: ../src/core/util.c:473
|
#: ../src/core/util.c:466
|
||||||
msgid "Window manager error: "
|
msgid "Window manager error: "
|
||||||
msgstr "Langų valdyklės klaida:"
|
msgstr "Langų valdyklės klaida:"
|
||||||
|
|
||||||
#. first time through
|
#. first time through
|
||||||
#: ../src/core/window.c:7533
|
#: ../src/core/window.c:7539
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
||||||
@@ -533,7 +521,7 @@ msgstr ""
|
|||||||
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
||||||
#. * about these apps but make them work.
|
#. * about these apps but make them work.
|
||||||
#.
|
#.
|
||||||
#: ../src/core/window.c:8257
|
#: ../src/core/window.c:8263
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
||||||
@@ -543,22 +531,22 @@ msgstr ""
|
|||||||
"tuo pat metu nustatė ir leistinas mažiausio dydžio %d x %d bei didžiausio "
|
"tuo pat metu nustatė ir leistinas mažiausio dydžio %d x %d bei didžiausio "
|
||||||
"dydžio %d x %d reikšmes; tai yra beprasmiška.\n"
|
"dydžio %d x %d reikšmes; tai yra beprasmiška.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:347
|
#: ../src/core/window-props.c:318
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
||||||
msgstr "Programa nustatė netinkamą _NET_WM_PID %lu\n"
|
msgstr "Programa nustatė netinkamą _NET_WM_PID %lu\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:463
|
#: ../src/core/window-props.c:434
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s (on %s)"
|
msgid "%s (on %s)"
|
||||||
msgstr "%s (kompiuteryje %s)"
|
msgstr "%s (kompiuteryje %s)"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1546
|
#: ../src/core/window-props.c:1517
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
||||||
msgstr "Nekorektiškas WM_TRANSIENT_FOR langas 0x%lx nurodytas %s.\n"
|
msgstr "Nekorektiškas WM_TRANSIENT_FOR langas 0x%lx nurodytas %s.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1557
|
#: ../src/core/window-props.c:1528
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
||||||
msgstr "WM_TRANSIENT_FOR langas 0x%lx nurodytas %s sukurtų ciklą.\n"
|
msgstr "WM_TRANSIENT_FOR langas 0x%lx nurodytas %s sukurtų ciklą.\n"
|
||||||
@@ -722,104 +710,109 @@ msgstr "Pasirinkti langą iš tab iššokimo"
|
|||||||
msgid "Cancel tab popup"
|
msgid "Cancel tab popup"
|
||||||
msgstr "Atšaukti tab iššokimą"
|
msgstr "Atšaukti tab iššokimą"
|
||||||
|
|
||||||
|
#: ../src/tools/mutter-message.c:123
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: %s\n"
|
||||||
|
msgstr "Naudojimas: %s\n"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:67
|
#: ../src/ui/menu.c:69
|
||||||
msgid "Mi_nimize"
|
msgid "Mi_nimize"
|
||||||
msgstr "Sumaži_nti"
|
msgstr "Sumaži_nti"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:69
|
#: ../src/ui/menu.c:71
|
||||||
msgid "Ma_ximize"
|
msgid "Ma_ximize"
|
||||||
msgstr "Iš_didinti"
|
msgstr "Iš_didinti"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:71
|
#: ../src/ui/menu.c:73
|
||||||
msgid "Unma_ximize"
|
msgid "Unma_ximize"
|
||||||
msgstr "_Grąžinti iš išdidinimo"
|
msgstr "_Grąžinti iš išdidinimo"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:73
|
#: ../src/ui/menu.c:75
|
||||||
msgid "Roll _Up"
|
msgid "Roll _Up"
|
||||||
msgstr "Su_vynioti"
|
msgstr "Su_vynioti"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:75
|
#: ../src/ui/menu.c:77
|
||||||
msgid "_Unroll"
|
msgid "_Unroll"
|
||||||
msgstr "_Išvynioti"
|
msgstr "_Išvynioti"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:77
|
#: ../src/ui/menu.c:79
|
||||||
msgid "_Move"
|
msgid "_Move"
|
||||||
msgstr "Pe_rkelti"
|
msgstr "Pe_rkelti"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:79
|
#: ../src/ui/menu.c:81
|
||||||
msgid "_Resize"
|
msgid "_Resize"
|
||||||
msgstr "_Keisti dydį"
|
msgstr "_Keisti dydį"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:81
|
#: ../src/ui/menu.c:83
|
||||||
msgid "Move Titlebar On_screen"
|
msgid "Move Titlebar On_screen"
|
||||||
msgstr "Perkelti lango juostą ant _ekrano"
|
msgstr "Perkelti lango juostą ant _ekrano"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:84 ../src/ui/menu.c:86
|
#: ../src/ui/menu.c:86 ../src/ui/menu.c:88
|
||||||
msgid "Always on _Top"
|
msgid "Always on _Top"
|
||||||
msgstr "Visada _viršuje"
|
msgstr "Visada _viršuje"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:88
|
#: ../src/ui/menu.c:90
|
||||||
msgid "_Always on Visible Workspace"
|
msgid "_Always on Visible Workspace"
|
||||||
msgstr "_Visada matomame darbalaukyje"
|
msgstr "_Visada matomame darbalaukyje"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:90
|
#: ../src/ui/menu.c:92
|
||||||
msgid "_Only on This Workspace"
|
msgid "_Only on This Workspace"
|
||||||
msgstr "_Tik šiame darbalaukyje"
|
msgstr "_Tik šiame darbalaukyje"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:92
|
#: ../src/ui/menu.c:94
|
||||||
msgid "Move to Workspace _Left"
|
msgid "Move to Workspace _Left"
|
||||||
msgstr "Perkelti _langą į kairįjį darbalaukį"
|
msgstr "Perkelti _langą į kairįjį darbalaukį"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:94
|
#: ../src/ui/menu.c:96
|
||||||
msgid "Move to Workspace R_ight"
|
msgid "Move to Workspace R_ight"
|
||||||
msgstr "Pe_rkelti langą į dešinįjį darbalaukį"
|
msgstr "Pe_rkelti langą į dešinįjį darbalaukį"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:96
|
#: ../src/ui/menu.c:98
|
||||||
msgid "Move to Workspace _Up"
|
msgid "Move to Workspace _Up"
|
||||||
msgstr "Perkelti langą į a_ukštesnįjį darbalaukį"
|
msgstr "Perkelti langą į a_ukštesnįjį darbalaukį"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:98
|
#: ../src/ui/menu.c:100
|
||||||
msgid "Move to Workspace _Down"
|
msgid "Move to Workspace _Down"
|
||||||
msgstr "Perkelti langą į ž_emesnįjį darbalaukį"
|
msgstr "Perkelti langą į ž_emesnįjį darbalaukį"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:102
|
#: ../src/ui/menu.c:104
|
||||||
msgid "_Close"
|
msgid "_Close"
|
||||||
msgstr "_Užverti"
|
msgstr "_Užverti"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:202
|
#: ../src/ui/menu.c:204
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d%n"
|
msgid "Workspace %d%n"
|
||||||
msgstr "Darbalaukis %d%n"
|
msgstr "Darbalaukis %d%n"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:212
|
#: ../src/ui/menu.c:214
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace 1_0"
|
msgid "Workspace 1_0"
|
||||||
msgstr "1_0-tas darbalaukis"
|
msgstr "1_0-tas darbalaukis"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:214
|
#: ../src/ui/menu.c:216
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %s%d"
|
msgid "Workspace %s%d"
|
||||||
msgstr "Darbalaukis %s%d"
|
msgstr "Darbalaukis %s%d"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:384
|
#: ../src/ui/menu.c:397
|
||||||
msgid "Move to Another _Workspace"
|
msgid "Move to Another _Workspace"
|
||||||
msgstr "Perkelti langą į kitą _darbalaukį"
|
msgstr "Perkelti langą į kitą _darbalaukį"
|
||||||
|
|
||||||
@@ -921,48 +914,48 @@ msgstr "Mod5"
|
|||||||
msgid "%d x %d"
|
msgid "%d x %d"
|
||||||
msgstr "%d x %d"
|
msgstr "%d x %d"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:236
|
#: ../src/ui/theme.c:235
|
||||||
msgid "top"
|
msgid "top"
|
||||||
msgstr "viršus"
|
msgstr "viršus"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:238
|
#: ../src/ui/theme.c:237
|
||||||
msgid "bottom"
|
msgid "bottom"
|
||||||
msgstr "apačia"
|
msgstr "apačia"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:240
|
#: ../src/ui/theme.c:239
|
||||||
msgid "left"
|
msgid "left"
|
||||||
msgstr "kairė"
|
msgstr "kairė"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:242
|
#: ../src/ui/theme.c:241
|
||||||
msgid "right"
|
msgid "right"
|
||||||
msgstr "dešinė"
|
msgstr "dešinė"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:270
|
#: ../src/ui/theme.c:269
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "frame geometry does not specify \"%s\" dimension"
|
msgid "frame geometry does not specify \"%s\" dimension"
|
||||||
msgstr "rėmelio aprašyme nenurodytas „%s“ matmuo"
|
msgstr "rėmelio aprašyme nenurodytas „%s“ matmuo"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:289
|
#: ../src/ui/theme.c:288
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "frame geometry does not specify dimension \"%s\" for border \"%s\""
|
msgid "frame geometry does not specify dimension \"%s\" for border \"%s\""
|
||||||
msgstr "rėmelio aprašyme nenurodytas paraštės „%2$s“ „%1$s“ matmuo"
|
msgstr "rėmelio aprašyme nenurodytas paraštės „%2$s“ „%1$s“ matmuo"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:326
|
#: ../src/ui/theme.c:325
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Button aspect ratio %g is not reasonable"
|
msgid "Button aspect ratio %g is not reasonable"
|
||||||
msgstr "Mygtuko dydžio santykis %g yra nenuosaikus"
|
msgstr "Mygtuko dydžio santykis %g yra nenuosaikus"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:338
|
#: ../src/ui/theme.c:337
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Frame geometry does not specify size of buttons"
|
msgid "Frame geometry does not specify size of buttons"
|
||||||
msgstr "Rėmelio aprašyme nenurodytas mygtukų dydis"
|
msgstr "Rėmelio aprašyme nenurodytas mygtukų dydis"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1051
|
#: ../src/ui/theme.c:1050
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Gradients should have at least two colors"
|
msgid "Gradients should have at least two colors"
|
||||||
msgstr "Aprašant persiliejančias spalvas reikia nurodyti bent dvi spalvas"
|
msgstr "Aprašant persiliejančias spalvas reikia nurodyti bent dvi spalvas"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1203
|
#: ../src/ui/theme.c:1202
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK custom color specification must have color name and fallback in "
|
"GTK custom color specification must have color name and fallback in "
|
||||||
@@ -972,7 +965,7 @@ msgstr ""
|
|||||||
"uždarančius laužtinius skliaustus, pvz.: gtk:custom(foo,bar); nepavyko "
|
"uždarančius laužtinius skliaustus, pvz.: gtk:custom(foo,bar); nepavyko "
|
||||||
"perskaityti „%s“"
|
"perskaityti „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1219
|
#: ../src/ui/theme.c:1218
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
|
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
|
||||||
@@ -981,7 +974,7 @@ msgstr ""
|
|||||||
"Netinkamas simbolis „%c“ gtk:custom parametre color_name, leidžiama tik A-Za-"
|
"Netinkamas simbolis „%c“ gtk:custom parametre color_name, leidžiama tik A-Za-"
|
||||||
"z0-9_"
|
"z0-9_"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1233
|
#: ../src/ui/theme.c:1232
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
|
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
|
||||||
@@ -990,7 +983,7 @@ msgstr ""
|
|||||||
"Gtk:custom formatas yra „gtk:custom(color_name,fallback)“, „%s“ neatitinka "
|
"Gtk:custom formatas yra „gtk:custom(color_name,fallback)“, „%s“ neatitinka "
|
||||||
"šio formato"
|
"šio formato"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1278
|
#: ../src/ui/theme.c:1277
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
|
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
|
||||||
@@ -1000,7 +993,7 @@ msgstr ""
|
|||||||
"skliaustų, pvz.: gtk:fg[NORMAL], kur NORMAL yra būsena; nepavyko apdoroti "
|
"skliaustų, pvz.: gtk:fg[NORMAL], kur NORMAL yra būsena; nepavyko apdoroti "
|
||||||
"\"%s\""
|
"\"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1292
|
#: ../src/ui/theme.c:1291
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK color specification must have a close bracket after the state, e.g. gtk:"
|
"GTK color specification must have a close bracket after the state, e.g. gtk:"
|
||||||
@@ -1010,17 +1003,17 @@ msgstr ""
|
|||||||
"skliaustus, pvz.: gtk:fg[NORMAL], kur NORMAL yra būsena; nepavyko apdoroti "
|
"skliaustus, pvz.: gtk:fg[NORMAL], kur NORMAL yra būsena; nepavyko apdoroti "
|
||||||
"\"%s\""
|
"\"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1303
|
#: ../src/ui/theme.c:1302
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Did not understand state \"%s\" in color specification"
|
msgid "Did not understand state \"%s\" in color specification"
|
||||||
msgstr "Nesuprantama spalvų aprašymo būsena \"%s\""
|
msgstr "Nesuprantama spalvų aprašymo būsena \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1316
|
#: ../src/ui/theme.c:1315
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Did not understand color component \"%s\" in color specification"
|
msgid "Did not understand color component \"%s\" in color specification"
|
||||||
msgstr "Spalvų aprašyme nurodytas nesuprantamas spalvos komponentas \"%s\""
|
msgstr "Spalvų aprašyme nurodytas nesuprantamas spalvos komponentas \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1345
|
#: ../src/ui/theme.c:1344
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the "
|
"Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the "
|
||||||
@@ -1029,19 +1022,19 @@ msgstr ""
|
|||||||
"Išplaukimo formatas yra \"blend/bg_color/fg_color/alpha\", \"%s\" neatitinka "
|
"Išplaukimo formatas yra \"blend/bg_color/fg_color/alpha\", \"%s\" neatitinka "
|
||||||
"šio formato"
|
"šio formato"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1356
|
#: ../src/ui/theme.c:1355
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse alpha value \"%s\" in blended color"
|
msgid "Could not parse alpha value \"%s\" in blended color"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Nepavyko aprodoti skaidrumo reikšmės \"%s\" priskirtos išplaukiančiai spalva"
|
"Nepavyko aprodoti skaidrumo reikšmės \"%s\" priskirtos išplaukiančiai spalva"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1366
|
#: ../src/ui/theme.c:1365
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0"
|
msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Skaidrumo reikšmė \"%s\" tarp išplaukiančios spalvos yra ne tarp 0.0 ir 1.0"
|
"Skaidrumo reikšmė \"%s\" tarp išplaukiančios spalvos yra ne tarp 0.0 ir 1.0"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1413
|
#: ../src/ui/theme.c:1412
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format"
|
"Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format"
|
||||||
@@ -1049,27 +1042,27 @@ msgstr ""
|
|||||||
"Šešėlio formatas yra \"shade/base_color/factor\", \"%s\" neatitinka šio "
|
"Šešėlio formatas yra \"shade/base_color/factor\", \"%s\" neatitinka šio "
|
||||||
"formato"
|
"formato"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1424
|
#: ../src/ui/theme.c:1423
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse shade factor \"%s\" in shaded color"
|
msgid "Could not parse shade factor \"%s\" in shaded color"
|
||||||
msgstr "Nepavyko apdoroti šešėlinės spalvos šešėlių rodiklio \"%s\""
|
msgstr "Nepavyko apdoroti šešėlinės spalvos šešėlių rodiklio \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1434
|
#: ../src/ui/theme.c:1433
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Shade factor \"%s\" in shaded color is negative"
|
msgid "Shade factor \"%s\" in shaded color is negative"
|
||||||
msgstr "Šešėlio rodiklis \"%s\" tarp šešėlinės spalvos yra neigiamas"
|
msgstr "Šešėlio rodiklis \"%s\" tarp šešėlinės spalvos yra neigiamas"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1463
|
#: ../src/ui/theme.c:1462
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse color \"%s\""
|
msgid "Could not parse color \"%s\""
|
||||||
msgstr "Nepavyko apdoroti spalvos \"%s\""
|
msgstr "Nepavyko apdoroti spalvos \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1780
|
#: ../src/ui/theme.c:1779
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression contains character '%s' which is not allowed"
|
msgid "Coordinate expression contains character '%s' which is not allowed"
|
||||||
msgstr "Koordinačių išraiška turi neleistiną simbolį '%s'"
|
msgstr "Koordinačių išraiška turi neleistiną simbolį '%s'"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1807
|
#: ../src/ui/theme.c:1806
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression contains floating point number '%s' which could not be "
|
"Coordinate expression contains floating point number '%s' which could not be "
|
||||||
@@ -1078,13 +1071,13 @@ msgstr ""
|
|||||||
"Koordinačių išraiška turi skaičių su slankiu kableliu '%s', kuris negali "
|
"Koordinačių išraiška turi skaičių su slankiu kableliu '%s', kuris negali "
|
||||||
"būti apdorotas"
|
"būti apdorotas"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1821
|
#: ../src/ui/theme.c:1820
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression contains integer '%s' which could not be parsed"
|
msgid "Coordinate expression contains integer '%s' which could not be parsed"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Koordinačių išraiška turi sveiką skaičių '%s', kuris negali būti apdorotas"
|
"Koordinačių išraiška turi sveiką skaičių '%s', kuris negali būti apdorotas"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1942
|
#: ../src/ui/theme.c:1941
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression contained unknown operator at the start of this text: "
|
"Coordinate expression contained unknown operator at the start of this text: "
|
||||||
@@ -1093,17 +1086,17 @@ msgstr ""
|
|||||||
"Koordinačių išraiškoje nurodytas nežinomas operatorius šio teksto pradžioje: "
|
"Koordinačių išraiškoje nurodytas nežinomas operatorius šio teksto pradžioje: "
|
||||||
"\"%s\""
|
"\"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1999
|
#: ../src/ui/theme.c:1998
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression was empty or not understood"
|
msgid "Coordinate expression was empty or not understood"
|
||||||
msgstr "Koordinačių išraiška tuščia arba nesuprantama"
|
msgstr "Koordinačių išraiška tuščia arba nesuprantama"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2112 ../src/ui/theme.c:2122 ../src/ui/theme.c:2156
|
#: ../src/ui/theme.c:2111 ../src/ui/theme.c:2121 ../src/ui/theme.c:2155
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression results in division by zero"
|
msgid "Coordinate expression results in division by zero"
|
||||||
msgstr "Koordinačių išraiška sukelia dalybą iš nulio"
|
msgstr "Koordinačių išraiška sukelia dalybą iš nulio"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2164
|
#: ../src/ui/theme.c:2163
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression tries to use mod operator on a floating-point number"
|
"Coordinate expression tries to use mod operator on a floating-point number"
|
||||||
@@ -1111,7 +1104,7 @@ msgstr ""
|
|||||||
"Koordinačių išraiška bando panaudoti liekanos operatorių (mod) slankaus "
|
"Koordinačių išraiška bando panaudoti liekanos operatorių (mod) slankaus "
|
||||||
"kablelio skaičiui"
|
"kablelio skaičiui"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2220
|
#: ../src/ui/theme.c:2219
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression has an operator \"%s\" where an operand was expected"
|
"Coordinate expression has an operator \"%s\" where an operand was expected"
|
||||||
@@ -1119,17 +1112,17 @@ msgstr ""
|
|||||||
"Koordinačių išraiškoje įvestas operatorius \"%s\" ten, kur turi būti vedamas "
|
"Koordinačių išraiškoje įvestas operatorius \"%s\" ten, kur turi būti vedamas "
|
||||||
"operandas"
|
"operandas"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2229
|
#: ../src/ui/theme.c:2228
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had an operand where an operator was expected"
|
msgid "Coordinate expression had an operand where an operator was expected"
|
||||||
msgstr "Koordinačių išraiškoje operandas įrašytas operatoriaus vietoje"
|
msgstr "Koordinačių išraiškoje operandas įrašytas operatoriaus vietoje"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2237
|
#: ../src/ui/theme.c:2236
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression ended with an operator instead of an operand"
|
msgid "Coordinate expression ended with an operator instead of an operand"
|
||||||
msgstr "Koordinačių išraiška pasibaigė operatoriumi, o ne operandu"
|
msgstr "Koordinačių išraiška pasibaigė operatoriumi, o ne operandu"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2247
|
#: ../src/ui/theme.c:2246
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression has operator \"%c\" following operator \"%c\" with no "
|
"Coordinate expression has operator \"%c\" following operator \"%c\" with no "
|
||||||
@@ -1138,41 +1131,41 @@ msgstr ""
|
|||||||
"Koordinačių išraiškoje operatorius \"%c\" eina po operatoriaus \"%c\" be "
|
"Koordinačių išraiškoje operatorius \"%c\" eina po operatoriaus \"%c\" be "
|
||||||
"tarpinio operando"
|
"tarpinio operando"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2398 ../src/ui/theme.c:2443
|
#: ../src/ui/theme.c:2397 ../src/ui/theme.c:2442
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had unknown variable or constant \"%s\""
|
msgid "Coordinate expression had unknown variable or constant \"%s\""
|
||||||
msgstr "Koordinačių išraiška saugo nežinomą kintamąjį arba konstantą \"%s\""
|
msgstr "Koordinačių išraiška saugo nežinomą kintamąjį arba konstantą \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2497
|
#: ../src/ui/theme.c:2496
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression parser overflowed its buffer."
|
msgid "Coordinate expression parser overflowed its buffer."
|
||||||
msgstr "Koordinačių išraiškų skaitytuvas perpildė buferį."
|
msgstr "Koordinačių išraiškų skaitytuvas perpildė buferį."
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2526
|
#: ../src/ui/theme.c:2525
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had a close parenthesis with no open parenthesis"
|
msgid "Coordinate expression had a close parenthesis with no open parenthesis"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Koordinačių išraiškoje įvesti uždarantys skliaustai, nors atidarančių "
|
"Koordinačių išraiškoje įvesti uždarantys skliaustai, nors atidarančių "
|
||||||
"skliaustų nerasta"
|
"skliaustų nerasta"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2590
|
#: ../src/ui/theme.c:2589
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had an open parenthesis with no close parenthesis"
|
msgid "Coordinate expression had an open parenthesis with no close parenthesis"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Koordinačių išraiškoje po atidarančių skliaustų neįvesti uždarantys "
|
"Koordinačių išraiškoje po atidarančių skliaustų neįvesti uždarantys "
|
||||||
"skliaustai"
|
"skliaustai"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2601
|
#: ../src/ui/theme.c:2600
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression doesn't seem to have any operators or operands"
|
msgid "Coordinate expression doesn't seem to have any operators or operands"
|
||||||
msgstr "Koordinačių išraiška neturi jokių operatorių ar operandų"
|
msgstr "Koordinačių išraiška neturi jokių operatorių ar operandų"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2814 ../src/ui/theme.c:2834 ../src/ui/theme.c:2854
|
#: ../src/ui/theme.c:2813 ../src/ui/theme.c:2833 ../src/ui/theme.c:2853
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Theme contained an expression that resulted in an error: %s\n"
|
msgid "Theme contained an expression that resulted in an error: %s\n"
|
||||||
msgstr "Temoje esanti išraiška sukėlė klaidą: %s\n"
|
msgstr "Temoje esanti išraiška sukėlė klaidą: %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:4500
|
#: ../src/ui/theme.c:4499
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be "
|
"<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be "
|
||||||
@@ -1181,25 +1174,25 @@ msgstr ""
|
|||||||
"Šiam rėmelio stiliui turi būti nurodytas <button function=\"%s\" state=\"%s"
|
"Šiam rėmelio stiliui turi būti nurodytas <button function=\"%s\" state=\"%s"
|
||||||
"\" draw_ops=\"kažkokswhatever\"/> požymis"
|
"\" draw_ops=\"kažkokswhatever\"/> požymis"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5011 ../src/ui/theme.c:5036
|
#: ../src/ui/theme.c:5010 ../src/ui/theme.c:5035
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
|
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Trūksta <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"kažkoks\"/>"
|
"Trūksta <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"kažkoks\"/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5082
|
#: ../src/ui/theme.c:5083
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to load theme \"%s\": %s\n"
|
msgid "Failed to load theme \"%s\": %s\n"
|
||||||
msgstr "Nepavyko paleisti temos \"%s\": %s\n"
|
msgstr "Nepavyko paleisti temos \"%s\": %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232
|
#: ../src/ui/theme.c:5219 ../src/ui/theme.c:5226 ../src/ui/theme.c:5233
|
||||||
#: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246
|
#: ../src/ui/theme.c:5240 ../src/ui/theme.c:5247
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "No <%s> set for theme \"%s\""
|
msgid "No <%s> set for theme \"%s\""
|
||||||
msgstr "Temoje \"%2$s\" trūksta <%1$s> nustatymų"
|
msgstr "Temoje \"%2$s\" trūksta <%1$s> nustatymų"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5254
|
#: ../src/ui/theme.c:5255
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
||||||
@@ -1208,7 +1201,7 @@ msgstr ""
|
|||||||
"Rėmelio stilius nenurodytas lango tipui \"%s\" temoje \"%s\", pridėkite "
|
"Rėmelio stilius nenurodytas lango tipui \"%s\" temoje \"%s\", pridėkite "
|
||||||
"<window type=\"%s\" style_set=\"kažkoks\"/> elementą"
|
"<window type=\"%s\" style_set=\"kažkoks\"/> elementą"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786
|
#: ../src/ui/theme.c:5662 ../src/ui/theme.c:5724 ../src/ui/theme.c:5787
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
||||||
@@ -1216,7 +1209,7 @@ msgstr ""
|
|||||||
"Naudotojo nustatytos konstantos turi prasidėti didžiąja raide; „%s“ nėra "
|
"Naudotojo nustatytos konstantos turi prasidėti didžiąja raide; „%s“ nėra "
|
||||||
"didžioji"
|
"didžioji"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794
|
#: ../src/ui/theme.c:5670 ../src/ui/theme.c:5732 ../src/ui/theme.c:5795
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Constant \"%s\" has already been defined"
|
msgid "Constant \"%s\" has already been defined"
|
||||||
msgstr "Konstanta „%s“ jau aprašyta"
|
msgstr "Konstanta „%s“ jau aprašyta"
|
||||||
@@ -1600,8 +1593,210 @@ msgstr "Elemente <%s> tekstas negalimas"
|
|||||||
msgid "<%s> specified twice for this theme"
|
msgid "<%s> specified twice for this theme"
|
||||||
msgstr "<%s> elementas temos aprašyme nurodytas du kartus"
|
msgstr "<%s> elementas temos aprašyme nurodytas du kartus"
|
||||||
|
|
||||||
#: ../src/ui/theme-parser.c:4336
|
#: ../src/ui/theme-parser.c:4334
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to find a valid file for theme %s\n"
|
msgid "Failed to find a valid file for theme %s\n"
|
||||||
msgstr "Nepavyko rasti tinkamo temos %s failo\n"
|
msgstr "Nepavyko rasti tinkamo temos %s failo\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:99
|
||||||
|
msgid "_Windows"
|
||||||
|
msgstr "_Langai"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:100
|
||||||
|
msgid "_Dialog"
|
||||||
|
msgstr "_Dialogas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:101
|
||||||
|
msgid "_Modal dialog"
|
||||||
|
msgstr "_Modalinis dialogas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:102
|
||||||
|
msgid "_Utility"
|
||||||
|
msgstr "_Įrankis"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:103
|
||||||
|
msgid "_Splashscreen"
|
||||||
|
msgstr "_Pristatymo langas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:104
|
||||||
|
msgid "_Top dock"
|
||||||
|
msgstr "_Viršutinis dokas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:105
|
||||||
|
msgid "_Bottom dock"
|
||||||
|
msgstr "_Apatinis dokas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:106
|
||||||
|
msgid "_Left dock"
|
||||||
|
msgstr "_Kairysis dokas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:107
|
||||||
|
msgid "_Right dock"
|
||||||
|
msgstr "_Kairysis dokas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:108
|
||||||
|
msgid "_All docks"
|
||||||
|
msgstr "Visi dok_ai"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:109
|
||||||
|
msgid "Des_ktop"
|
||||||
|
msgstr "Dar_bastalis"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:115
|
||||||
|
msgid "Open another one of these windows"
|
||||||
|
msgstr "Atverti dar vieną tokį langą"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:117
|
||||||
|
msgid "This is a demo button with an 'open' icon"
|
||||||
|
msgstr "Tai yra bandomasis mygtukas su „atverti“ piktograma"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:119
|
||||||
|
msgid "This is a demo button with a 'quit' icon"
|
||||||
|
msgstr "Tai yra bandomasis mygtukas su „uždaryti“ piktograma"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:248
|
||||||
|
msgid "This is a sample message in a sample dialog"
|
||||||
|
msgstr "Tai yra pavydžio pranešimas pavyzdžio dialoge"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:328
|
||||||
|
#, c-format
|
||||||
|
msgid "Fake menu item %d\n"
|
||||||
|
msgstr "Netikras meniu punktas %d\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:363
|
||||||
|
msgid "Border-only window"
|
||||||
|
msgstr "Tik rėmelį turintis langas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:365
|
||||||
|
msgid "Bar"
|
||||||
|
msgstr "Juosta"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:382
|
||||||
|
msgid "Normal Application Window"
|
||||||
|
msgstr "Normalus programos langas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:386
|
||||||
|
msgid "Dialog Box"
|
||||||
|
msgstr "Dialogo langas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:390
|
||||||
|
msgid "Modal Dialog Box"
|
||||||
|
msgstr "Modalinis dialogo langas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:394
|
||||||
|
msgid "Utility Palette"
|
||||||
|
msgstr "Įrankių paletė"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:398
|
||||||
|
msgid "Torn-off Menu"
|
||||||
|
msgstr "Atkabinamas meniu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:402
|
||||||
|
msgid "Border"
|
||||||
|
msgstr "Paraštė"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:406
|
||||||
|
msgid "Attached Modal Dialog"
|
||||||
|
msgstr "Prikabintas modalinis dialogas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:737
|
||||||
|
#, c-format
|
||||||
|
msgid "Button layout test %d"
|
||||||
|
msgstr "Mygtukų išdėstymo testas %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:766
|
||||||
|
#, c-format
|
||||||
|
msgid "%g milliseconds to draw one window frame"
|
||||||
|
msgstr "vienam lango kadrui išvesti yra skirta %g milisekundžių"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:811
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
|
||||||
|
msgstr "Panaudojimas: metacity-theme-viewer [TEMOS PAVADINIMAS]\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:818
|
||||||
|
#, c-format
|
||||||
|
msgid "Error loading theme: %s\n"
|
||||||
|
msgstr "Klaida įkeliant temą: %s\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:824
|
||||||
|
#, c-format
|
||||||
|
msgid "Loaded theme \"%s\" in %g seconds\n"
|
||||||
|
msgstr "Tema „%s“ įkelta per %g sekundžių\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:869
|
||||||
|
msgid "Normal Title Font"
|
||||||
|
msgstr "Normalus antraštės šriftas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:875
|
||||||
|
msgid "Small Title Font"
|
||||||
|
msgstr "Smulkus antraštės šriftas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:881
|
||||||
|
msgid "Large Title Font"
|
||||||
|
msgstr "Didelis antraštės šriftas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:886
|
||||||
|
msgid "Button Layouts"
|
||||||
|
msgstr "Mygtukų išdėstymai"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:891
|
||||||
|
msgid "Benchmark"
|
||||||
|
msgstr "Greičio testas"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:947
|
||||||
|
msgid "Window Title Goes Here"
|
||||||
|
msgstr "Čia rodomo lango antraštė"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1053
|
||||||
|
#, c-format
|
||||||
|
msgid ""
|
||||||
|
"Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g "
|
||||||
|
"seconds wall clock time including X server resources (%g milliseconds per "
|
||||||
|
"frame)\n"
|
||||||
|
msgstr ""
|
||||||
|
"%d kadrai buvo išvesti per %g klientines sekundes (%g milisekunčių kadrui) "
|
||||||
|
"ir per %g bendrinio laiko sekundes įskaitant X serverio resursus (%g "
|
||||||
|
"milisekundžių kadrui)\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1273
|
||||||
|
msgid "position expression test returned TRUE but set error"
|
||||||
|
msgstr ""
|
||||||
|
"padėties išraiškos testas grąžino teigiamą reikšmę, bet kartu nustatė "
|
||||||
|
"klaidos pranešimą"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1275
|
||||||
|
msgid "position expression test returned FALSE but didn't set error"
|
||||||
|
msgstr ""
|
||||||
|
"padėties išraiškos testas grąžino neigiamą reikšmę, bet nenustatė klaidos "
|
||||||
|
"pranešimo"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1279
|
||||||
|
msgid "Error was expected but none given"
|
||||||
|
msgstr "Tikėtasi sulaukti klaidos pranešimo, tačiau nieko nesulaukta"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1281
|
||||||
|
#, c-format
|
||||||
|
msgid "Error %d was expected but %d given"
|
||||||
|
msgstr "Tikėtasi klaidos %d, tačiau gauta %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1287
|
||||||
|
#, c-format
|
||||||
|
msgid "Error not expected but one was returned: %s"
|
||||||
|
msgstr "Klaidos nesitikėta, tačiau grąžinta klaida: %s"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1291
|
||||||
|
#, c-format
|
||||||
|
msgid "x value was %d, %d was expected"
|
||||||
|
msgstr "x reikšmė buvo %d, tikėtasi %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1294
|
||||||
|
#, c-format
|
||||||
|
msgid "y value was %d, %d was expected"
|
||||||
|
msgstr "y reikšmė buvo %d, tikėtasi %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1359
|
||||||
|
#, c-format
|
||||||
|
msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
|
||||||
|
msgstr ""
|
||||||
|
"Koordinačių %d išraiška apdorota per %g sekundžių (%g sekundžių vidurkis)\n"
|
||||||
|
|||||||
309
po/nb.po
309
po/nb.po
@@ -6,8 +6,8 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: mutter 3.9.x\n"
|
"Project-Id-Version: mutter 3.9.x\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2013-08-22 16:11+0200\n"
|
"POT-Creation-Date: 2013-08-08 22:14+0200\n"
|
||||||
"PO-Revision-Date: 2013-08-22 16:12+0200\n"
|
"PO-Revision-Date: 2013-05-28 09:48+0200\n"
|
||||||
"Last-Translator: Kjartan Maraas <kmaraas@gnome.org>\n"
|
"Last-Translator: Kjartan Maraas <kmaraas@gnome.org>\n"
|
||||||
"Language-Team: Norwegian bokmål <i18n-no@lister.ping.uio.no>\n"
|
"Language-Team: Norwegian bokmål <i18n-no@lister.ping.uio.no>\n"
|
||||||
"Language: \n"
|
"Language: \n"
|
||||||
@@ -205,7 +205,7 @@ msgstr "Visning delt til høyre"
|
|||||||
|
|
||||||
#. This probably means that a non-WM compositor like xcompmgr is running;
|
#. This probably means that a non-WM compositor like xcompmgr is running;
|
||||||
#. * we have no way to get it to exit
|
#. * we have no way to get it to exit
|
||||||
#: ../src/compositor/compositor.c:596
|
#: ../src/compositor/compositor.c:589
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Another compositing manager is already running on screen %i on display \"%s"
|
"Another compositing manager is already running on screen %i on display \"%s"
|
||||||
@@ -260,7 +260,7 @@ msgstr "Mangler utvidelsen %s som kreves for komposittfunksjon"
|
|||||||
msgid "Failed to open X Window System display '%s'\n"
|
msgid "Failed to open X Window System display '%s'\n"
|
||||||
msgstr "Feil under åpning av X Window System skjerm «%s»\n"
|
msgstr "Feil under åpning av X Window System skjerm «%s»\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1136
|
#: ../src/core/keybindings.c:1138
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Some other program is already using the key %s with modifiers %x as a "
|
"Some other program is already using the key %s with modifiers %x as a "
|
||||||
@@ -269,7 +269,7 @@ msgstr ""
|
|||||||
"Et annet program bruker allerede nøkkelen %s med modifikatorer %x som "
|
"Et annet program bruker allerede nøkkelen %s med modifikatorer %x som "
|
||||||
"binding\n"
|
"binding\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1333
|
#: ../src/core/keybindings.c:1335
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "\"%s\" is not a valid accelerator\n"
|
msgid "\"%s\" is not a valid accelerator\n"
|
||||||
msgstr "«%s» er ikke en gyldig aksellerator\n"
|
msgstr "«%s» er ikke en gyldig aksellerator\n"
|
||||||
@@ -311,19 +311,6 @@ msgstr ""
|
|||||||
"Kunne ikke finne et tema! Sjekk at %s eksisterer og inneholder de vanlige "
|
"Kunne ikke finne et tema! Sjekk at %s eksisterer og inneholder de vanlige "
|
||||||
"temaene.\n"
|
"temaene.\n"
|
||||||
|
|
||||||
#: ../src/core/monitor.c:702
|
|
||||||
msgid "Built-in display"
|
|
||||||
msgstr "Innebygget skjerm"
|
|
||||||
|
|
||||||
#. TRANSLATORS: this is a monitor name (in case we don't know
|
|
||||||
#. the vendor), it's Unknown followed by a size in inches,
|
|
||||||
#. like 'Unknown 15"'
|
|
||||||
#.
|
|
||||||
#: ../src/core/monitor.c:730
|
|
||||||
#, c-format
|
|
||||||
msgid "Unknown %s"
|
|
||||||
msgstr "Ukjent %s"
|
|
||||||
|
|
||||||
#: ../src/core/mutter.c:40
|
#: ../src/core/mutter.c:40
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
@@ -382,12 +369,12 @@ msgstr ""
|
|||||||
msgid "Workspace %d"
|
msgid "Workspace %d"
|
||||||
msgstr "Arbeidsområde %d"
|
msgstr "Arbeidsområde %d"
|
||||||
|
|
||||||
#: ../src/core/screen.c:537
|
#: ../src/core/screen.c:691
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display '%s' is invalid\n"
|
msgid "Screen %d on display '%s' is invalid\n"
|
||||||
msgstr "Skjerm %d på display «%s» er ugyldig\n"
|
msgstr "Skjerm %d på display «%s» er ugyldig\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:553
|
#: ../src/core/screen.c:707
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
||||||
@@ -396,19 +383,19 @@ msgstr ""
|
|||||||
"Skjerm %d på display «%s» har allerede en vindushåndterer; prøv å bruke "
|
"Skjerm %d på display «%s» har allerede en vindushåndterer; prøv å bruke "
|
||||||
"flagget --replace for å erstatte aktiv vindushåndterer.\n"
|
"flagget --replace for å erstatte aktiv vindushåndterer.\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:580
|
#: ../src/core/screen.c:734
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Kunne ikke hente utvalg fra vinduhåndterer på skjerm %d, display «%s»\n"
|
"Kunne ikke hente utvalg fra vinduhåndterer på skjerm %d, display «%s»\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:658
|
#: ../src/core/screen.c:812
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
||||||
msgstr "Skjerm %d på display «%s» har allerede en vinduhåndterer\n"
|
msgstr "Skjerm %d på display «%s» har allerede en vinduhåndterer\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:850
|
#: ../src/core/screen.c:998
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not release screen %d on display \"%s\"\n"
|
msgid "Could not release screen %d on display \"%s\"\n"
|
||||||
msgstr "Kunne ikke slippe skjerm %d på display «%s»\n"
|
msgstr "Kunne ikke slippe skjerm %d på display «%s»\n"
|
||||||
@@ -483,7 +470,8 @@ msgstr "Feil under fdopen() av loggfil %s: %s\n"
|
|||||||
msgid "Opened log file %s\n"
|
msgid "Opened log file %s\n"
|
||||||
msgstr "Åpnet loggfil %s\n"
|
msgstr "Åpnet loggfil %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:119
|
#: ../src/core/util.c:119 ../src/tools/mutter-message.c:149
|
||||||
|
#, c-format
|
||||||
msgid "Mutter was compiled without support for verbose mode\n"
|
msgid "Mutter was compiled without support for verbose mode\n"
|
||||||
msgstr "Mutter er kompilert uten støtte for «verbose» modus\n"
|
msgstr "Mutter er kompilert uten støtte for «verbose» modus\n"
|
||||||
|
|
||||||
@@ -491,20 +479,20 @@ msgstr "Mutter er kompilert uten støtte for «verbose» modus\n"
|
|||||||
msgid "Window manager: "
|
msgid "Window manager: "
|
||||||
msgstr "Vindushåndterer: "
|
msgstr "Vindushåndterer: "
|
||||||
|
|
||||||
#: ../src/core/util.c:414
|
#: ../src/core/util.c:412
|
||||||
msgid "Bug in window manager: "
|
msgid "Bug in window manager: "
|
||||||
msgstr "Feil i vindushåndterer: "
|
msgstr "Feil i vindushåndterer: "
|
||||||
|
|
||||||
#: ../src/core/util.c:445
|
#: ../src/core/util.c:443
|
||||||
msgid "Window manager warning: "
|
msgid "Window manager warning: "
|
||||||
msgstr "Advarsel fra vindushåndterer: "
|
msgstr "Advarsel fra vindushåndterer: "
|
||||||
|
|
||||||
#: ../src/core/util.c:473
|
#: ../src/core/util.c:471
|
||||||
msgid "Window manager error: "
|
msgid "Window manager error: "
|
||||||
msgstr "Feil i vindushåndterer: "
|
msgstr "Feil i vindushåndterer: "
|
||||||
|
|
||||||
#. first time through
|
#. first time through
|
||||||
#: ../src/core/window.c:7533
|
#: ../src/core/window.c:7513
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
||||||
@@ -520,7 +508,7 @@ msgstr ""
|
|||||||
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
||||||
#. * about these apps but make them work.
|
#. * about these apps but make them work.
|
||||||
#.
|
#.
|
||||||
#: ../src/core/window.c:8257
|
#: ../src/core/window.c:8237
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
||||||
@@ -530,22 +518,22 @@ msgstr ""
|
|||||||
"men setter minste størrelse %d x %d og maks størrelse %d x %d; dette virker "
|
"men setter minste størrelse %d x %d og maks størrelse %d x %d; dette virker "
|
||||||
"ikke fornuftig.\n"
|
"ikke fornuftig.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:347
|
#: ../src/core/window-props.c:318
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
||||||
msgstr "Programmet satte en feil _NET_WM_PID %lu\n"
|
msgstr "Programmet satte en feil _NET_WM_PID %lu\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:463
|
#: ../src/core/window-props.c:434
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s (on %s)"
|
msgid "%s (on %s)"
|
||||||
msgstr "%s (på %s)"
|
msgstr "%s (på %s)"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1546
|
#: ../src/core/window-props.c:1517
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
||||||
msgstr "Ugyldig WM_TRANSIENT_FOR vindu 0x%lx oppgitt for %s.\n"
|
msgstr "Ugyldig WM_TRANSIENT_FOR vindu 0x%lx oppgitt for %s.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1557
|
#: ../src/core/window-props.c:1528
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
||||||
msgstr "WM_TRANSIENT_FOR vindu 0x%lx for %s ville skapt en løkke.\n"
|
msgstr "WM_TRANSIENT_FOR vindu 0x%lx for %s ville skapt en løkke.\n"
|
||||||
@@ -708,104 +696,109 @@ msgstr "Fjern vindu fra tabulatordialog"
|
|||||||
msgid "Cancel tab popup"
|
msgid "Cancel tab popup"
|
||||||
msgstr "Avbryt tabulatordialog"
|
msgstr "Avbryt tabulatordialog"
|
||||||
|
|
||||||
|
#: ../src/tools/mutter-message.c:123
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: %s\n"
|
||||||
|
msgstr " Bruk: %s\n"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:67
|
#: ../src/ui/menu.c:69
|
||||||
msgid "Mi_nimize"
|
msgid "Mi_nimize"
|
||||||
msgstr "Mi_nimer"
|
msgstr "Mi_nimer"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:69
|
#: ../src/ui/menu.c:71
|
||||||
msgid "Ma_ximize"
|
msgid "Ma_ximize"
|
||||||
msgstr "Ma_ksimer"
|
msgstr "Ma_ksimer"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:71
|
#: ../src/ui/menu.c:73
|
||||||
msgid "Unma_ximize"
|
msgid "Unma_ximize"
|
||||||
msgstr "G_jenopprett"
|
msgstr "G_jenopprett"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:73
|
#: ../src/ui/menu.c:75
|
||||||
msgid "Roll _Up"
|
msgid "Roll _Up"
|
||||||
msgstr "Rull _opp"
|
msgstr "Rull _opp"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:75
|
#: ../src/ui/menu.c:77
|
||||||
msgid "_Unroll"
|
msgid "_Unroll"
|
||||||
msgstr "R_ull ned"
|
msgstr "R_ull ned"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:77
|
#: ../src/ui/menu.c:79
|
||||||
msgid "_Move"
|
msgid "_Move"
|
||||||
msgstr "_Flytt"
|
msgstr "_Flytt"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:79
|
#: ../src/ui/menu.c:81
|
||||||
msgid "_Resize"
|
msgid "_Resize"
|
||||||
msgstr "End_re størrelse"
|
msgstr "End_re størrelse"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:81
|
#: ../src/ui/menu.c:83
|
||||||
msgid "Move Titlebar On_screen"
|
msgid "Move Titlebar On_screen"
|
||||||
msgstr "Flytt tittellinje på _skjermen"
|
msgstr "Flytt tittellinje på _skjermen"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:84 ../src/ui/menu.c:86
|
#: ../src/ui/menu.c:86 ../src/ui/menu.c:88
|
||||||
msgid "Always on _Top"
|
msgid "Always on _Top"
|
||||||
msgstr "All_tid øverst"
|
msgstr "All_tid øverst"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:88
|
#: ../src/ui/menu.c:90
|
||||||
msgid "_Always on Visible Workspace"
|
msgid "_Always on Visible Workspace"
|
||||||
msgstr "_Alltid på synlig arbeidsområde"
|
msgstr "_Alltid på synlig arbeidsområde"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:90
|
#: ../src/ui/menu.c:92
|
||||||
msgid "_Only on This Workspace"
|
msgid "_Only on This Workspace"
|
||||||
msgstr "K_un på dette arbeidsområdet"
|
msgstr "K_un på dette arbeidsområdet"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:92
|
#: ../src/ui/menu.c:94
|
||||||
msgid "Move to Workspace _Left"
|
msgid "Move to Workspace _Left"
|
||||||
msgstr "Flytt til arbeidsområdet ti_l venstre"
|
msgstr "Flytt til arbeidsområdet ti_l venstre"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:94
|
#: ../src/ui/menu.c:96
|
||||||
msgid "Move to Workspace R_ight"
|
msgid "Move to Workspace R_ight"
|
||||||
msgstr "Flytt til a_rbeidsområdet til høyre"
|
msgstr "Flytt til a_rbeidsområdet til høyre"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:96
|
#: ../src/ui/menu.c:98
|
||||||
msgid "Move to Workspace _Up"
|
msgid "Move to Workspace _Up"
|
||||||
msgstr "Flytt til arbeidsområdet _over"
|
msgstr "Flytt til arbeidsområdet _over"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:98
|
#: ../src/ui/menu.c:100
|
||||||
msgid "Move to Workspace _Down"
|
msgid "Move to Workspace _Down"
|
||||||
msgstr "Flytt til arbeidsområdet ne_denfor"
|
msgstr "Flytt til arbeidsområdet ne_denfor"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:102
|
#: ../src/ui/menu.c:104
|
||||||
msgid "_Close"
|
msgid "_Close"
|
||||||
msgstr "_Lukk"
|
msgstr "_Lukk"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:202
|
#: ../src/ui/menu.c:204
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d%n"
|
msgid "Workspace %d%n"
|
||||||
msgstr "Arbeidsområde %d%n"
|
msgstr "Arbeidsområde %d%n"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:212
|
#: ../src/ui/menu.c:214
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace 1_0"
|
msgid "Workspace 1_0"
|
||||||
msgstr "Arbeidsområde 1_0"
|
msgstr "Arbeidsområde 1_0"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:214
|
#: ../src/ui/menu.c:216
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %s%d"
|
msgid "Workspace %s%d"
|
||||||
msgstr "Arbeidsområde %s%d"
|
msgstr "Arbeidsområde %s%d"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:384
|
#: ../src/ui/menu.c:397
|
||||||
msgid "Move to Another _Workspace"
|
msgid "Move to Another _Workspace"
|
||||||
msgstr "Flytt til et annet ar_beidsområde"
|
msgstr "Flytt til et annet ar_beidsområde"
|
||||||
|
|
||||||
@@ -1158,18 +1151,18 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Mangler <frame state=«%s» resize=«%s» focus=«%s» stil=«ett-eller-annet»/>"
|
"Mangler <frame state=«%s» resize=«%s» focus=«%s» stil=«ett-eller-annet»/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5082
|
#: ../src/ui/theme.c:5084
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to load theme \"%s\": %s\n"
|
msgid "Failed to load theme \"%s\": %s\n"
|
||||||
msgstr "Klarte ikke å laste tema «%s»: %s\n"
|
msgstr "Klarte ikke å laste tema «%s»: %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232
|
#: ../src/ui/theme.c:5220 ../src/ui/theme.c:5227 ../src/ui/theme.c:5234
|
||||||
#: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246
|
#: ../src/ui/theme.c:5241 ../src/ui/theme.c:5248
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "No <%s> set for theme \"%s\""
|
msgid "No <%s> set for theme \"%s\""
|
||||||
msgstr "<%s> er ikke satt for tema «%s»"
|
msgstr "<%s> er ikke satt for tema «%s»"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5254
|
#: ../src/ui/theme.c:5256
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
||||||
@@ -1178,14 +1171,14 @@ msgstr ""
|
|||||||
"Ingen rammestil satt for vindutype «%s» i tema «%s», legg til et <window "
|
"Ingen rammestil satt for vindutype «%s» i tema «%s», legg til et <window "
|
||||||
"type=«%s» style_set=«ett-eller-annet»/>-element"
|
"type=«%s» style_set=«ett-eller-annet»/>-element"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786
|
#: ../src/ui/theme.c:5663 ../src/ui/theme.c:5725 ../src/ui/theme.c:5788
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Brukerdefinerte konstanter må begynne med stor bokstav; «%s» gjør ikke det"
|
"Brukerdefinerte konstanter må begynne med stor bokstav; «%s» gjør ikke det"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794
|
#: ../src/ui/theme.c:5671 ../src/ui/theme.c:5733 ../src/ui/theme.c:5796
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Constant \"%s\" has already been defined"
|
msgid "Constant \"%s\" has already been defined"
|
||||||
msgstr "Konstant «%s» er allerede definert"
|
msgstr "Konstant «%s» er allerede definert"
|
||||||
@@ -1570,3 +1563,201 @@ msgstr "<%s> spesifisert to ganger for dette temaet"
|
|||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to find a valid file for theme %s\n"
|
msgid "Failed to find a valid file for theme %s\n"
|
||||||
msgstr "Fant ikke en gyldig fil for tema %s\n"
|
msgstr "Fant ikke en gyldig fil for tema %s\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:99
|
||||||
|
msgid "_Windows"
|
||||||
|
msgstr "_Vinduer"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:100
|
||||||
|
msgid "_Dialog"
|
||||||
|
msgstr "_Dialog"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:101
|
||||||
|
msgid "_Modal dialog"
|
||||||
|
msgstr "_Modal dialog"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:102
|
||||||
|
msgid "_Utility"
|
||||||
|
msgstr "_Verktøy"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:103
|
||||||
|
msgid "_Splashscreen"
|
||||||
|
msgstr "Opp_startskjerm"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:104
|
||||||
|
msgid "_Top dock"
|
||||||
|
msgstr "_Toppdokk"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:105
|
||||||
|
msgid "_Bottom dock"
|
||||||
|
msgstr "_Bunndokk"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:106
|
||||||
|
msgid "_Left dock"
|
||||||
|
msgstr "_Venstre dokk"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:107
|
||||||
|
msgid "_Right dock"
|
||||||
|
msgstr "Høy_re dokk"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:108
|
||||||
|
msgid "_All docks"
|
||||||
|
msgstr "_Alle dokker"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:109
|
||||||
|
msgid "Des_ktop"
|
||||||
|
msgstr "S_krivebord"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:115
|
||||||
|
msgid "Open another one of these windows"
|
||||||
|
msgstr "Åpne et til av disse vinduene"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:117
|
||||||
|
msgid "This is a demo button with an 'open' icon"
|
||||||
|
msgstr "Dette er en demoknapp med et «åpne»-ikon"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:119
|
||||||
|
msgid "This is a demo button with a 'quit' icon"
|
||||||
|
msgstr "Dette er en demoknapp med et «avslutt»-ikon"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:248
|
||||||
|
msgid "This is a sample message in a sample dialog"
|
||||||
|
msgstr "Dette er en eksempelbeskjed i en eksempeldialog"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:328
|
||||||
|
#, c-format
|
||||||
|
msgid "Fake menu item %d\n"
|
||||||
|
msgstr "Falsk menyoppføring %d\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:363
|
||||||
|
msgid "Border-only window"
|
||||||
|
msgstr "Vindu uten innhold"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:365
|
||||||
|
msgid "Bar"
|
||||||
|
msgstr "Linje"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:382
|
||||||
|
msgid "Normal Application Window"
|
||||||
|
msgstr "Normalt programvindu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:386
|
||||||
|
msgid "Dialog Box"
|
||||||
|
msgstr "Dialogboks"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:390
|
||||||
|
msgid "Modal Dialog Box"
|
||||||
|
msgstr "Modal dialogboks"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:394
|
||||||
|
msgid "Utility Palette"
|
||||||
|
msgstr "Verktøypalett"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:398
|
||||||
|
msgid "Torn-off Menu"
|
||||||
|
msgstr "Avrevet meny"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:402
|
||||||
|
msgid "Border"
|
||||||
|
msgstr "Kant"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:406
|
||||||
|
msgid "Attached Modal Dialog"
|
||||||
|
msgstr "Festet modal dialog"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:737
|
||||||
|
#, c-format
|
||||||
|
msgid "Button layout test %d"
|
||||||
|
msgstr "Test av knappeplassering %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:766
|
||||||
|
#, c-format
|
||||||
|
msgid "%g milliseconds to draw one window frame"
|
||||||
|
msgstr "%g millisekunder for å tegne en vindusramme"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:811
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
|
||||||
|
msgstr "Bruk: metacity-theme-viewer [TEMANAVN]\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:818
|
||||||
|
#, c-format
|
||||||
|
msgid "Error loading theme: %s\n"
|
||||||
|
msgstr "Feil under lasting av tema: %s\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:824
|
||||||
|
#, c-format
|
||||||
|
msgid "Loaded theme \"%s\" in %g seconds\n"
|
||||||
|
msgstr "Lastet tema «%s» på %g sekunder\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:869
|
||||||
|
msgid "Normal Title Font"
|
||||||
|
msgstr "Normal tittelskrift"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:875
|
||||||
|
msgid "Small Title Font"
|
||||||
|
msgstr "Liten tittelskrift"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:881
|
||||||
|
msgid "Large Title Font"
|
||||||
|
msgstr "Stor tittelskrift"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:886
|
||||||
|
msgid "Button Layouts"
|
||||||
|
msgstr "Knappeplasseringer"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:891
|
||||||
|
msgid "Benchmark"
|
||||||
|
msgstr "Ytelsestest"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:947
|
||||||
|
msgid "Window Title Goes Here"
|
||||||
|
msgstr "Vindutittel skal her"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1053
|
||||||
|
#, c-format
|
||||||
|
msgid ""
|
||||||
|
"Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g "
|
||||||
|
"seconds wall clock time including X server resources (%g milliseconds per "
|
||||||
|
"frame)\n"
|
||||||
|
msgstr ""
|
||||||
|
"Tegnet %d rammer på %g sekunder hos klienten (%g millisekunder per ramme) og "
|
||||||
|
"%g sekunder på klokken inklusive ressurser på X-tjener (%g millisekunder per "
|
||||||
|
"ramme)\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1273
|
||||||
|
msgid "position expression test returned TRUE but set error"
|
||||||
|
msgstr "test av posisjonsuttrykk returnerte TRUE, men satte en feilkode"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1275
|
||||||
|
msgid "position expression test returned FALSE but didn't set error"
|
||||||
|
msgstr "test av posisjonsuttrykk returnerte FALSE, men satte ikke en feilkode"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1279
|
||||||
|
msgid "Error was expected but none given"
|
||||||
|
msgstr "Feil var ventet men ingen ble gitt"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1281
|
||||||
|
#, c-format
|
||||||
|
msgid "Error %d was expected but %d given"
|
||||||
|
msgstr "Feil %d var ventet men %d ble gitt"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1287
|
||||||
|
#, c-format
|
||||||
|
msgid "Error not expected but one was returned: %s"
|
||||||
|
msgstr "Feil ikke ventet men en ble returnert: %s"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1291
|
||||||
|
#, c-format
|
||||||
|
msgid "x value was %d, %d was expected"
|
||||||
|
msgstr "x-verdi var %d, %d var ventet"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1294
|
||||||
|
#, c-format
|
||||||
|
msgid "y value was %d, %d was expected"
|
||||||
|
msgstr "y-verdi var %d, %d var ventet"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1359
|
||||||
|
#, c-format
|
||||||
|
msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
|
||||||
|
msgstr "%d koordinatuttrykk lest på %g sekunder (%g sekunder i snitt)\n"
|
||||||
|
|||||||
440
po/pl.po
440
po/pl.po
@@ -15,8 +15,8 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: mutter\n"
|
"Project-Id-Version: mutter\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2013-08-22 01:49+0200\n"
|
"POT-Creation-Date: 2013-03-02 01:52+0100\n"
|
||||||
"PO-Revision-Date: 2013-08-22 01:50+0200\n"
|
"PO-Revision-Date: 2013-03-02 01:53+0100\n"
|
||||||
"Last-Translator: Piotr Drąg <piotrdrag@gmail.com>\n"
|
"Last-Translator: Piotr Drąg <piotrdrag@gmail.com>\n"
|
||||||
"Language-Team: Polish <gnomepl@aviary.pl>\n"
|
"Language-Team: Polish <gnomepl@aviary.pl>\n"
|
||||||
"Language: pl\n"
|
"Language: pl\n"
|
||||||
@@ -220,7 +220,7 @@ msgstr "Podział widoku po prawej"
|
|||||||
|
|
||||||
#. This probably means that a non-WM compositor like xcompmgr is running;
|
#. This probably means that a non-WM compositor like xcompmgr is running;
|
||||||
#. * we have no way to get it to exit
|
#. * we have no way to get it to exit
|
||||||
#: ../src/compositor/compositor.c:596
|
#: ../src/compositor/compositor.c:507
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Another compositing manager is already running on screen %i on display \"%s"
|
"Another compositing manager is already running on screen %i on display \"%s"
|
||||||
@@ -228,11 +228,11 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Inny menedżer składania jest już uruchomiony na podekranie %i ekranu \"%s\"."
|
"Inny menedżer składania jest już uruchomiony na podekranie %i ekranu \"%s\"."
|
||||||
|
|
||||||
#: ../src/compositor/meta-background.c:1076
|
#: ../src/compositor/meta-background.c:1111
|
||||||
msgid "background texture could not be created from file"
|
msgid "background texture could not be created from file"
|
||||||
msgstr "nie można utworzyć tekstury tła z pliku"
|
msgstr "nie można utworzyć tekstury tła z pliku"
|
||||||
|
|
||||||
#: ../src/core/bell.c:322
|
#: ../src/core/bell.c:320
|
||||||
msgid "Bell event"
|
msgid "Bell event"
|
||||||
msgstr "Zdarzenie sygnału dźwiękowego"
|
msgstr "Zdarzenie sygnału dźwiękowego"
|
||||||
|
|
||||||
@@ -264,18 +264,18 @@ msgstr "_Czekaj"
|
|||||||
msgid "_Force Quit"
|
msgid "_Force Quit"
|
||||||
msgstr "_Zakończ"
|
msgstr "_Zakończ"
|
||||||
|
|
||||||
#: ../src/core/display.c:421
|
#: ../src/core/display.c:401
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Missing %s extension required for compositing"
|
msgid "Missing %s extension required for compositing"
|
||||||
msgstr "Brak rozszerzenia %s, wymaganego przez składanie"
|
msgstr "Brak rozszerzenia %s, wymaganego przez składanie"
|
||||||
|
|
||||||
#: ../src/core/display.c:513
|
#: ../src/core/display.c:493
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open X Window System display '%s'\n"
|
msgid "Failed to open X Window System display '%s'\n"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Otwarcie połączenia z ekranem \"%s\" systemu X Window się nie powiodło\n"
|
"Otwarcie połączenia z ekranem \"%s\" systemu X Window się nie powiodło\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1136
|
#: ../src/core/keybindings.c:929
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Some other program is already using the key %s with modifiers %x as a "
|
"Some other program is already using the key %s with modifiers %x as a "
|
||||||
@@ -284,41 +284,41 @@ msgstr ""
|
|||||||
"Skrótu klawiszowego z klawiszem %s i modyfikatorami %x używa już inny "
|
"Skrótu klawiszowego z klawiszem %s i modyfikatorami %x używa już inny "
|
||||||
"program\n"
|
"program\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1333
|
#: ../src/core/keybindings.c:1129
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "\"%s\" is not a valid accelerator\n"
|
msgid "\"%s\" is not a valid accelerator\n"
|
||||||
msgstr "\"%s\" nie jest prawidłowym skrótem\n"
|
msgstr "\"%s\" nie jest prawidłowym skrótem\n"
|
||||||
|
|
||||||
#: ../src/core/main.c:197
|
#: ../src/core/main.c:196
|
||||||
msgid "Disable connection to session manager"
|
msgid "Disable connection to session manager"
|
||||||
msgstr "Rozłącza połączenie z menedżerem sesji"
|
msgstr "Rozłącza połączenie z menedżerem sesji"
|
||||||
|
|
||||||
#: ../src/core/main.c:203
|
#: ../src/core/main.c:202
|
||||||
msgid "Replace the running window manager"
|
msgid "Replace the running window manager"
|
||||||
msgstr "Zastępuje uruchomionego menedżera okien"
|
msgstr "Zastępuje uruchomionego menedżera okien"
|
||||||
|
|
||||||
#: ../src/core/main.c:209
|
#: ../src/core/main.c:208
|
||||||
msgid "Specify session management ID"
|
msgid "Specify session management ID"
|
||||||
msgstr "Podaje identyfikator zarządzania sesją"
|
msgstr "Podaje identyfikator zarządzania sesją"
|
||||||
|
|
||||||
#: ../src/core/main.c:214
|
#: ../src/core/main.c:213
|
||||||
msgid "X Display to use"
|
msgid "X Display to use"
|
||||||
msgstr "Używany ekran X"
|
msgstr "Używany ekran X"
|
||||||
|
|
||||||
#: ../src/core/main.c:220
|
#: ../src/core/main.c:219
|
||||||
msgid "Initialize session from savefile"
|
msgid "Initialize session from savefile"
|
||||||
msgstr "Inicjuje sesję z zapisanego pliku"
|
msgstr "Inicjuje sesję z zapisanego pliku"
|
||||||
|
|
||||||
#: ../src/core/main.c:226
|
#: ../src/core/main.c:225
|
||||||
msgid "Make X calls synchronous"
|
msgid "Make X calls synchronous"
|
||||||
msgstr "Synchroniczne wywołania X"
|
msgstr "Synchroniczne wywołania X"
|
||||||
|
|
||||||
#: ../src/core/main.c:534
|
#: ../src/core/main.c:533
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to scan themes directory: %s\n"
|
msgid "Failed to scan themes directory: %s\n"
|
||||||
msgstr "Przejrzenie katalogu z motywami się nie powiodło: %s\n"
|
msgstr "Przejrzenie katalogu z motywami się nie powiodło: %s\n"
|
||||||
|
|
||||||
#: ../src/core/main.c:550
|
#: ../src/core/main.c:549
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
|
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
|
||||||
@@ -326,19 +326,6 @@ msgstr ""
|
|||||||
"Nie można odnaleźć żadnego motywu. Proszę sprawdzić, czy katalog %s istnieje "
|
"Nie można odnaleźć żadnego motywu. Proszę sprawdzić, czy katalog %s istnieje "
|
||||||
"i zawiera standardowe motywy.\n"
|
"i zawiera standardowe motywy.\n"
|
||||||
|
|
||||||
#: ../src/core/monitor.c:702
|
|
||||||
msgid "Built-in display"
|
|
||||||
msgstr "Wbudowany ekran"
|
|
||||||
|
|
||||||
#. TRANSLATORS: this is a monitor name (in case we don't know
|
|
||||||
#. the vendor), it's Unknown followed by a size in inches,
|
|
||||||
#. like 'Unknown 15"'
|
|
||||||
#.
|
|
||||||
#: ../src/core/monitor.c:730
|
|
||||||
#, c-format
|
|
||||||
msgid "Unknown %s"
|
|
||||||
msgstr "Nieznany %s"
|
|
||||||
|
|
||||||
#: ../src/core/mutter.c:40
|
#: ../src/core/mutter.c:40
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
@@ -363,7 +350,7 @@ msgstr "Wyświetla wersję"
|
|||||||
msgid "Mutter plugin to use"
|
msgid "Mutter plugin to use"
|
||||||
msgstr "Używana wtyczka programu Mutter"
|
msgstr "Używana wtyczka programu Mutter"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1202
|
#: ../src/core/prefs.c:1087
|
||||||
msgid ""
|
msgid ""
|
||||||
"Workarounds for broken applications disabled. Some applications may not "
|
"Workarounds for broken applications disabled. Some applications may not "
|
||||||
"behave properly.\n"
|
"behave properly.\n"
|
||||||
@@ -371,14 +358,14 @@ msgstr ""
|
|||||||
"Obejścia dla błędnie działających programów są wyłączone. Niektóre z nich "
|
"Obejścia dla błędnie działających programów są wyłączone. Niektóre z nich "
|
||||||
"mogą się zachowywać w sposób nieprzewidywalny.\n"
|
"mogą się zachowywać w sposób nieprzewidywalny.\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1277
|
#: ../src/core/prefs.c:1162
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Nie można przetworzyć opisu czcionki \"%s\", powiązanego z kluczem GSettings "
|
"Nie można przetworzyć opisu czcionki \"%s\", powiązanego z kluczem GSettings "
|
||||||
"%s\n"
|
"%s\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1343
|
#: ../src/core/prefs.c:1228
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for mouse button "
|
"\"%s\" found in configuration database is not a valid value for mouse button "
|
||||||
@@ -387,7 +374,7 @@ msgstr ""
|
|||||||
"Wartość \"%s\", odnaleziona w bazie danych konfiguracji nie opisuje "
|
"Wartość \"%s\", odnaleziona w bazie danych konfiguracji nie opisuje "
|
||||||
"prawidłowo modyfikatora przycisku myszy\n"
|
"prawidłowo modyfikatora przycisku myszy\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1909
|
#: ../src/core/prefs.c:1780
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for keybinding "
|
"\"%s\" found in configuration database is not a valid value for keybinding "
|
||||||
@@ -396,17 +383,17 @@ msgstr ""
|
|||||||
"Wartość \"%s\", odnaleziona w bazie danych konfiguracji nie opisuje "
|
"Wartość \"%s\", odnaleziona w bazie danych konfiguracji nie opisuje "
|
||||||
"prawidłowo skrótu klawiszowego \"%s\"\n"
|
"prawidłowo skrótu klawiszowego \"%s\"\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1999
|
#: ../src/core/prefs.c:1879
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d"
|
msgid "Workspace %d"
|
||||||
msgstr "Obszar roboczy %d"
|
msgstr "Obszar roboczy %d"
|
||||||
|
|
||||||
#: ../src/core/screen.c:537
|
#: ../src/core/screen.c:673
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display '%s' is invalid\n"
|
msgid "Screen %d on display '%s' is invalid\n"
|
||||||
msgstr "Podekran %d ekranu \"%s\" jest nieprawidłowy\n"
|
msgstr "Podekran %d ekranu \"%s\" jest nieprawidłowy\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:553
|
#: ../src/core/screen.c:689
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
||||||
@@ -415,7 +402,7 @@ msgstr ""
|
|||||||
"Na podekranie %d ekranu \"%s\" działa już menedżer okien. Aby zastąpić "
|
"Na podekranie %d ekranu \"%s\" działa już menedżer okien. Aby zastąpić "
|
||||||
"działającego menedżera okien, proszę spróbować użyć opcji --replace.\n"
|
"działającego menedżera okien, proszę spróbować użyć opcji --replace.\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:580
|
#: ../src/core/screen.c:716
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
||||||
@@ -423,12 +410,12 @@ msgstr ""
|
|||||||
"Nie można uzyskać zaznaczenia menedżera okien na podekranie %d ekranu \"%s"
|
"Nie można uzyskać zaznaczenia menedżera okien na podekranie %d ekranu \"%s"
|
||||||
"\"\n"
|
"\"\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:658
|
#: ../src/core/screen.c:794
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
||||||
msgstr "Na podekranie %d ekranu \"%s\" działa już menedżer okien\n"
|
msgstr "Na podekranie %d ekranu \"%s\" działa już menedżer okien\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:850
|
#: ../src/core/screen.c:979
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not release screen %d on display \"%s\"\n"
|
msgid "Could not release screen %d on display \"%s\"\n"
|
||||||
msgstr "Nie można zwolnić podekranu %d ekranu \"%s\"\n"
|
msgstr "Nie można zwolnić podekranu %d ekranu \"%s\"\n"
|
||||||
@@ -490,44 +477,45 @@ msgstr ""
|
|||||||
"Te okna nie obsługują opcji zapisu aktualnego stanu (\"save current setup"
|
"Te okna nie obsługują opcji zapisu aktualnego stanu (\"save current setup"
|
||||||
"\"), więc przy następnym zalogowaniu będą musiały zostać uruchomione ręcznie."
|
"\"), więc przy następnym zalogowaniu będą musiały zostać uruchomione ręcznie."
|
||||||
|
|
||||||
#: ../src/core/util.c:84
|
#: ../src/core/util.c:80
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open debug log: %s\n"
|
msgid "Failed to open debug log: %s\n"
|
||||||
msgstr "Otwarcie dziennika z zapisem wykonania się nie powiodło: %s\n"
|
msgstr "Otwarcie dziennika z zapisem wykonania się nie powiodło: %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:94
|
#: ../src/core/util.c:90
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to fdopen() log file %s: %s\n"
|
msgid "Failed to fdopen() log file %s: %s\n"
|
||||||
msgstr "Wykonać fdopen() na pliku dziennika %s się nie powiodło: %s\n"
|
msgstr "Wykonać fdopen() na pliku dziennika %s się nie powiodło: %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:100
|
#: ../src/core/util.c:96
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Opened log file %s\n"
|
msgid "Opened log file %s\n"
|
||||||
msgstr "Otwarty plik dziennika %s\n"
|
msgstr "Otwarty plik dziennika %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:119
|
#: ../src/core/util.c:115 ../src/tools/mutter-message.c:149
|
||||||
|
#, c-format
|
||||||
msgid "Mutter was compiled without support for verbose mode\n"
|
msgid "Mutter was compiled without support for verbose mode\n"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Program Mutter został skompilowany bez obsługi trybu z obszerną informacją\n"
|
"Program Mutter został skompilowany bez obsługi trybu z obszerną informacją\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:264
|
#: ../src/core/util.c:259
|
||||||
msgid "Window manager: "
|
msgid "Window manager: "
|
||||||
msgstr "Menedżer okien: "
|
msgstr "Menedżer okien: "
|
||||||
|
|
||||||
#: ../src/core/util.c:414
|
#: ../src/core/util.c:407
|
||||||
msgid "Bug in window manager: "
|
msgid "Bug in window manager: "
|
||||||
msgstr "Błąd w programie menedżera okien: "
|
msgstr "Błąd w programie menedżera okien: "
|
||||||
|
|
||||||
#: ../src/core/util.c:445
|
#: ../src/core/util.c:438
|
||||||
msgid "Window manager warning: "
|
msgid "Window manager warning: "
|
||||||
msgstr "Ostrzeżenie menedżera okien: "
|
msgstr "Ostrzeżenie menedżera okien: "
|
||||||
|
|
||||||
#: ../src/core/util.c:473
|
#: ../src/core/util.c:466
|
||||||
msgid "Window manager error: "
|
msgid "Window manager error: "
|
||||||
msgstr "Błąd menedżera okien: "
|
msgstr "Błąd menedżera okien: "
|
||||||
|
|
||||||
#. first time through
|
#. first time through
|
||||||
#: ../src/core/window.c:7533
|
#: ../src/core/window.c:7539
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
||||||
@@ -543,7 +531,7 @@ msgstr ""
|
|||||||
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
||||||
#. * about these apps but make them work.
|
#. * about these apps but make them work.
|
||||||
#.
|
#.
|
||||||
#: ../src/core/window.c:8257
|
#: ../src/core/window.c:8263
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
||||||
@@ -553,23 +541,23 @@ msgstr ""
|
|||||||
"niezmienny, lecz jednocześnie ustawia minimalny rozmiar na %d x %d, a "
|
"niezmienny, lecz jednocześnie ustawia minimalny rozmiar na %d x %d, a "
|
||||||
"maksymalny rozmiar na %d x %d. To nie ma żadnego sensu.\n"
|
"maksymalny rozmiar na %d x %d. To nie ma żadnego sensu.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:347
|
#: ../src/core/window-props.c:318
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
||||||
msgstr "Program ustawił błędną wartość _NET_WM_PID %lu\n"
|
msgstr "Program ustawił błędną wartość _NET_WM_PID %lu\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:463
|
#: ../src/core/window-props.c:434
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s (on %s)"
|
msgid "%s (on %s)"
|
||||||
msgstr "%s (na %s)"
|
msgstr "%s (na %s)"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1546
|
#: ../src/core/window-props.c:1517
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Nieprawidłowa wartość WM_TRANSIENT_FOR dla okna 0x%lx określona w %s.\n"
|
"Nieprawidłowa wartość WM_TRANSIENT_FOR dla okna 0x%lx określona w %s.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1557
|
#: ../src/core/window-props.c:1528
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
||||||
msgstr "WM_TRANSIENT_FOR okna 0x%lx dla %s utworzyłoby pętlę.\n"
|
msgstr "WM_TRANSIENT_FOR okna 0x%lx dla %s utworzyłoby pętlę.\n"
|
||||||
@@ -742,104 +730,109 @@ msgstr "Wybór okna z wyskakującego okna dla tabulacji"
|
|||||||
msgid "Cancel tab popup"
|
msgid "Cancel tab popup"
|
||||||
msgstr "Anulowanie wyskakującego okna dla tabulacji"
|
msgstr "Anulowanie wyskakującego okna dla tabulacji"
|
||||||
|
|
||||||
|
#: ../src/tools/mutter-message.c:123
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: %s\n"
|
||||||
|
msgstr "Użycie: %s\n"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:67
|
#: ../src/ui/menu.c:69
|
||||||
msgid "Mi_nimize"
|
msgid "Mi_nimize"
|
||||||
msgstr "Zm_inimalizuj"
|
msgstr "Zm_inimalizuj"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:69
|
#: ../src/ui/menu.c:71
|
||||||
msgid "Ma_ximize"
|
msgid "Ma_ximize"
|
||||||
msgstr "Zm_aksymalizuj"
|
msgstr "Zm_aksymalizuj"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:71
|
#: ../src/ui/menu.c:73
|
||||||
msgid "Unma_ximize"
|
msgid "Unma_ximize"
|
||||||
msgstr "Cofnij m_aksymalizację"
|
msgstr "Cofnij m_aksymalizację"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:73
|
#: ../src/ui/menu.c:75
|
||||||
msgid "Roll _Up"
|
msgid "Roll _Up"
|
||||||
msgstr "_Zwiń"
|
msgstr "_Zwiń"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:75
|
#: ../src/ui/menu.c:77
|
||||||
msgid "_Unroll"
|
msgid "_Unroll"
|
||||||
msgstr "Ro_zwiń"
|
msgstr "Ro_zwiń"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:77
|
#: ../src/ui/menu.c:79
|
||||||
msgid "_Move"
|
msgid "_Move"
|
||||||
msgstr "Prz_esuń"
|
msgstr "Prz_esuń"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:79
|
#: ../src/ui/menu.c:81
|
||||||
msgid "_Resize"
|
msgid "_Resize"
|
||||||
msgstr "Zmień _rozmiar"
|
msgstr "Zmień _rozmiar"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:81
|
#: ../src/ui/menu.c:83
|
||||||
msgid "Move Titlebar On_screen"
|
msgid "Move Titlebar On_screen"
|
||||||
msgstr "Przeno_szenie paska tytułowego na ekranie"
|
msgstr "Przeno_szenie paska tytułowego na ekranie"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:84 ../src/ui/menu.c:86
|
#: ../src/ui/menu.c:86 ../src/ui/menu.c:88
|
||||||
msgid "Always on _Top"
|
msgid "Always on _Top"
|
||||||
msgstr "Zawsze na _wierzchu"
|
msgstr "Zawsze na _wierzchu"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:88
|
#: ../src/ui/menu.c:90
|
||||||
msgid "_Always on Visible Workspace"
|
msgid "_Always on Visible Workspace"
|
||||||
msgstr "_Zawsze na widocznym obszarze roboczym"
|
msgstr "_Zawsze na widocznym obszarze roboczym"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:90
|
#: ../src/ui/menu.c:92
|
||||||
msgid "_Only on This Workspace"
|
msgid "_Only on This Workspace"
|
||||||
msgstr "_Tylko na tym obszarze roboczym"
|
msgstr "_Tylko na tym obszarze roboczym"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:92
|
#: ../src/ui/menu.c:94
|
||||||
msgid "Move to Workspace _Left"
|
msgid "Move to Workspace _Left"
|
||||||
msgstr "Przenieś na _lewy obszar roboczy"
|
msgstr "Przenieś na _lewy obszar roboczy"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:94
|
#: ../src/ui/menu.c:96
|
||||||
msgid "Move to Workspace R_ight"
|
msgid "Move to Workspace R_ight"
|
||||||
msgstr "Przen_ieś na prawy obszar roboczy"
|
msgstr "Przen_ieś na prawy obszar roboczy"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:96
|
#: ../src/ui/menu.c:98
|
||||||
msgid "Move to Workspace _Up"
|
msgid "Move to Workspace _Up"
|
||||||
msgstr "_Przenieś na górny obszar roboczy"
|
msgstr "_Przenieś na górny obszar roboczy"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:98
|
#: ../src/ui/menu.c:100
|
||||||
msgid "Move to Workspace _Down"
|
msgid "Move to Workspace _Down"
|
||||||
msgstr "Przenieś na _dolny obszar roboczy"
|
msgstr "Przenieś na _dolny obszar roboczy"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:102
|
#: ../src/ui/menu.c:104
|
||||||
msgid "_Close"
|
msgid "_Close"
|
||||||
msgstr "Za_mknij"
|
msgstr "Za_mknij"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:202
|
#: ../src/ui/menu.c:204
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d%n"
|
msgid "Workspace %d%n"
|
||||||
msgstr "Obszar roboczy %d%n"
|
msgstr "Obszar roboczy %d%n"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:212
|
#: ../src/ui/menu.c:214
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace 1_0"
|
msgid "Workspace 1_0"
|
||||||
msgstr "Obszar roboczy 1_0"
|
msgstr "Obszar roboczy 1_0"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:214
|
#: ../src/ui/menu.c:216
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %s%d"
|
msgid "Workspace %s%d"
|
||||||
msgstr "Obszar roboczy %s%d"
|
msgstr "Obszar roboczy %s%d"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:384
|
#: ../src/ui/menu.c:397
|
||||||
msgid "Move to Another _Workspace"
|
msgid "Move to Another _Workspace"
|
||||||
msgstr "Przeniesienie na inny _obszar roboczy"
|
msgstr "Przeniesienie na inny _obszar roboczy"
|
||||||
|
|
||||||
@@ -941,49 +934,49 @@ msgstr "Mod5"
|
|||||||
msgid "%d x %d"
|
msgid "%d x %d"
|
||||||
msgstr "%d x %d"
|
msgstr "%d x %d"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:236
|
#: ../src/ui/theme.c:235
|
||||||
msgid "top"
|
msgid "top"
|
||||||
msgstr "góra"
|
msgstr "góra"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:238
|
#: ../src/ui/theme.c:237
|
||||||
msgid "bottom"
|
msgid "bottom"
|
||||||
msgstr "dół"
|
msgstr "dół"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:240
|
#: ../src/ui/theme.c:239
|
||||||
msgid "left"
|
msgid "left"
|
||||||
msgstr "lewa"
|
msgstr "lewa"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:242
|
#: ../src/ui/theme.c:241
|
||||||
msgid "right"
|
msgid "right"
|
||||||
msgstr "prawa"
|
msgstr "prawa"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:270
|
#: ../src/ui/theme.c:269
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "frame geometry does not specify \"%s\" dimension"
|
msgid "frame geometry does not specify \"%s\" dimension"
|
||||||
msgstr "Rozmiar ramki nie określa wymiaru \"%s\""
|
msgstr "Rozmiar ramki nie określa wymiaru \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:289
|
#: ../src/ui/theme.c:288
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "frame geometry does not specify dimension \"%s\" for border \"%s\""
|
msgid "frame geometry does not specify dimension \"%s\" for border \"%s\""
|
||||||
msgstr "Rozmiar ramki nie określa wymiaru \"%s\" dla krawędzi \"%s\""
|
msgstr "Rozmiar ramki nie określa wymiaru \"%s\" dla krawędzi \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:326
|
#: ../src/ui/theme.c:325
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Button aspect ratio %g is not reasonable"
|
msgid "Button aspect ratio %g is not reasonable"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Współczynnik proporcji przycisku %g nie mieści się w rozsądnych granicach"
|
"Współczynnik proporcji przycisku %g nie mieści się w rozsądnych granicach"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:338
|
#: ../src/ui/theme.c:337
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Frame geometry does not specify size of buttons"
|
msgid "Frame geometry does not specify size of buttons"
|
||||||
msgstr "Rozmiar ramki nie określa liczby przycisków"
|
msgstr "Rozmiar ramki nie określa liczby przycisków"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1051
|
#: ../src/ui/theme.c:1050
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Gradients should have at least two colors"
|
msgid "Gradients should have at least two colors"
|
||||||
msgstr "Gradienty powinny się składać co najmniej z dwóch kolorów"
|
msgstr "Gradienty powinny się składać co najmniej z dwóch kolorów"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1203
|
#: ../src/ui/theme.c:1202
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK custom color specification must have color name and fallback in "
|
"GTK custom color specification must have color name and fallback in "
|
||||||
@@ -993,7 +986,7 @@ msgstr ""
|
|||||||
"kolor zastępczy w nawiasach, np. gtk:custom(foo,bar); nie można przetworzyć "
|
"kolor zastępczy w nawiasach, np. gtk:custom(foo,bar); nie można przetworzyć "
|
||||||
"\"%s\""
|
"\"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1219
|
#: ../src/ui/theme.c:1218
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
|
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
|
||||||
@@ -1002,7 +995,7 @@ msgstr ""
|
|||||||
"Nieprawidłowy znak \"%c\" w parametrze nazwa_koloru opcji gtk:custom, tylko "
|
"Nieprawidłowy znak \"%c\" w parametrze nazwa_koloru opcji gtk:custom, tylko "
|
||||||
"znaki A-Za-z0-9-_ są prawidłowe"
|
"znaki A-Za-z0-9-_ są prawidłowe"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1233
|
#: ../src/ui/theme.c:1232
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
|
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
|
||||||
@@ -1011,7 +1004,7 @@ msgstr ""
|
|||||||
"Formatem Gtk:custom jest \"gtk:custom(nazwa_koloru,kolor_zastępczy)\", \"%s"
|
"Formatem Gtk:custom jest \"gtk:custom(nazwa_koloru,kolor_zastępczy)\", \"%s"
|
||||||
"\" nie pasuje do formatu"
|
"\" nie pasuje do formatu"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1278
|
#: ../src/ui/theme.c:1277
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
|
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
|
||||||
@@ -1021,7 +1014,7 @@ msgstr ""
|
|||||||
"kwadratowych, np. gtk:fg[NORMAL], gdzie NORMAL jest nazwą stanu; nie można "
|
"kwadratowych, np. gtk:fg[NORMAL], gdzie NORMAL jest nazwą stanu; nie można "
|
||||||
"przetworzyć \"%s\""
|
"przetworzyć \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1292
|
#: ../src/ui/theme.c:1291
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK color specification must have a close bracket after the state, e.g. gtk:"
|
"GTK color specification must have a close bracket after the state, e.g. gtk:"
|
||||||
@@ -1031,17 +1024,17 @@ msgstr ""
|
|||||||
"nawias kwadratowy, np. gtk:fg[NORMAL], gdzie NORMAL jest nazwą stanu; nie "
|
"nawias kwadratowy, np. gtk:fg[NORMAL], gdzie NORMAL jest nazwą stanu; nie "
|
||||||
"można przetworzyć \"%s\""
|
"można przetworzyć \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1303
|
#: ../src/ui/theme.c:1302
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Did not understand state \"%s\" in color specification"
|
msgid "Did not understand state \"%s\" in color specification"
|
||||||
msgstr "Niezrozumiały stan \"%s\" w specyfikacji koloru"
|
msgstr "Niezrozumiały stan \"%s\" w specyfikacji koloru"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1316
|
#: ../src/ui/theme.c:1315
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Did not understand color component \"%s\" in color specification"
|
msgid "Did not understand color component \"%s\" in color specification"
|
||||||
msgstr "Niezrozumiała definicja koloru \"%s\" w specyfikacji koloru"
|
msgstr "Niezrozumiała definicja koloru \"%s\" w specyfikacji koloru"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1345
|
#: ../src/ui/theme.c:1344
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the "
|
"Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the "
|
||||||
@@ -1050,19 +1043,19 @@ msgstr ""
|
|||||||
"Formatem przenikania jest \"blend/bg_color/fg_color/alpha\", \"%s\" nie "
|
"Formatem przenikania jest \"blend/bg_color/fg_color/alpha\", \"%s\" nie "
|
||||||
"pasuje do formatu"
|
"pasuje do formatu"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1356
|
#: ../src/ui/theme.c:1355
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse alpha value \"%s\" in blended color"
|
msgid "Could not parse alpha value \"%s\" in blended color"
|
||||||
msgstr "Nie można przetworzyć wartości alfa \"%s\" w przenikającym kolorze"
|
msgstr "Nie można przetworzyć wartości alfa \"%s\" w przenikającym kolorze"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1366
|
#: ../src/ui/theme.c:1365
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0"
|
msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Wartość alfa \"%s\" w przenikającym kolorze nie zawiera się pomiędzy 0,0 i "
|
"Wartość alfa \"%s\" w przenikającym kolorze nie zawiera się pomiędzy 0,0 i "
|
||||||
"1,0"
|
"1,0"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1413
|
#: ../src/ui/theme.c:1412
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format"
|
"Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format"
|
||||||
@@ -1070,29 +1063,29 @@ msgstr ""
|
|||||||
"Formatem przenikania jest \"shade/base_color/factor\", \"%s\" nie pasuje do "
|
"Formatem przenikania jest \"shade/base_color/factor\", \"%s\" nie pasuje do "
|
||||||
"formatu"
|
"formatu"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1424
|
#: ../src/ui/theme.c:1423
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse shade factor \"%s\" in shaded color"
|
msgid "Could not parse shade factor \"%s\" in shaded color"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Nie można przetworzyć współczynnika przenikania \"%s\" w przenikającym "
|
"Nie można przetworzyć współczynnika przenikania \"%s\" w przenikającym "
|
||||||
"kolorze"
|
"kolorze"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1434
|
#: ../src/ui/theme.c:1433
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Shade factor \"%s\" in shaded color is negative"
|
msgid "Shade factor \"%s\" in shaded color is negative"
|
||||||
msgstr "Współczynnik przenikania \"%s\" w przenikającym kolorze jest ujemny"
|
msgstr "Współczynnik przenikania \"%s\" w przenikającym kolorze jest ujemny"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1463
|
#: ../src/ui/theme.c:1462
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse color \"%s\""
|
msgid "Could not parse color \"%s\""
|
||||||
msgstr "Nie można przetworzyć koloru \"%s\""
|
msgstr "Nie można przetworzyć koloru \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1780
|
#: ../src/ui/theme.c:1779
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression contains character '%s' which is not allowed"
|
msgid "Coordinate expression contains character '%s' which is not allowed"
|
||||||
msgstr "Wyrażenie określające współrzędne zawiera niedozwolony znak \"%s\""
|
msgstr "Wyrażenie określające współrzędne zawiera niedozwolony znak \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1807
|
#: ../src/ui/theme.c:1806
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression contains floating point number '%s' which could not be "
|
"Coordinate expression contains floating point number '%s' which could not be "
|
||||||
@@ -1101,14 +1094,14 @@ msgstr ""
|
|||||||
"Wyrażenie określające współrzędne zawiera liczbę zmiennoprzecinkową \"%s\", "
|
"Wyrażenie określające współrzędne zawiera liczbę zmiennoprzecinkową \"%s\", "
|
||||||
"której nie można przetworzyć"
|
"której nie można przetworzyć"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1821
|
#: ../src/ui/theme.c:1820
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression contains integer '%s' which could not be parsed"
|
msgid "Coordinate expression contains integer '%s' which could not be parsed"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Wyrażenie określające współrzędne zawiera liczbę całkowitą \"%s\", której "
|
"Wyrażenie określające współrzędne zawiera liczbę całkowitą \"%s\", której "
|
||||||
"nie można przetworzyć"
|
"nie można przetworzyć"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1942
|
#: ../src/ui/theme.c:1941
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression contained unknown operator at the start of this text: "
|
"Coordinate expression contained unknown operator at the start of this text: "
|
||||||
@@ -1117,18 +1110,18 @@ msgstr ""
|
|||||||
"Wyrażenie określające współrzędne zawiera nieznany operator na początku "
|
"Wyrażenie określające współrzędne zawiera nieznany operator na początku "
|
||||||
"tekstu: \"%s\""
|
"tekstu: \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1999
|
#: ../src/ui/theme.c:1998
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression was empty or not understood"
|
msgid "Coordinate expression was empty or not understood"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Wyrażenie określające współrzędne jest puste lub nie można go rozpoznać"
|
"Wyrażenie określające współrzędne jest puste lub nie można go rozpoznać"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2112 ../src/ui/theme.c:2122 ../src/ui/theme.c:2156
|
#: ../src/ui/theme.c:2111 ../src/ui/theme.c:2121 ../src/ui/theme.c:2155
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression results in division by zero"
|
msgid "Coordinate expression results in division by zero"
|
||||||
msgstr "Wyrażenie opisujące położenie zawiera dzielenie przez zero"
|
msgstr "Wyrażenie opisujące położenie zawiera dzielenie przez zero"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2164
|
#: ../src/ui/theme.c:2163
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression tries to use mod operator on a floating-point number"
|
"Coordinate expression tries to use mod operator on a floating-point number"
|
||||||
@@ -1136,7 +1129,7 @@ msgstr ""
|
|||||||
"Wyrażenie opisujące położenie używa operatora dzielenia modulo z liczbą "
|
"Wyrażenie opisujące położenie używa operatora dzielenia modulo z liczbą "
|
||||||
"zmiennoprzecinkową"
|
"zmiennoprzecinkową"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2220
|
#: ../src/ui/theme.c:2219
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression has an operator \"%s\" where an operand was expected"
|
"Coordinate expression has an operator \"%s\" where an operand was expected"
|
||||||
@@ -1144,19 +1137,19 @@ msgstr ""
|
|||||||
"Wyrażenie opisujące położenie zawiera operator \"%s\" w miejscu, w którym "
|
"Wyrażenie opisujące położenie zawiera operator \"%s\" w miejscu, w którym "
|
||||||
"oczekiwano operandu"
|
"oczekiwano operandu"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2229
|
#: ../src/ui/theme.c:2228
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had an operand where an operator was expected"
|
msgid "Coordinate expression had an operand where an operator was expected"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Wyrażenie opisujące położenie zawiera operand w miejscu, w którym oczekiwano "
|
"Wyrażenie opisujące położenie zawiera operand w miejscu, w którym oczekiwano "
|
||||||
"operatora"
|
"operatora"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2237
|
#: ../src/ui/theme.c:2236
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression ended with an operator instead of an operand"
|
msgid "Coordinate expression ended with an operator instead of an operand"
|
||||||
msgstr "Wyrażenie opisujące położenie kończy się operatorem zamiast operandem"
|
msgstr "Wyrażenie opisujące położenie kończy się operatorem zamiast operandem"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2247
|
#: ../src/ui/theme.c:2246
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression has operator \"%c\" following operator \"%c\" with no "
|
"Coordinate expression has operator \"%c\" following operator \"%c\" with no "
|
||||||
@@ -1165,43 +1158,43 @@ msgstr ""
|
|||||||
"Wyrażenie opisujące położenie zawiera operator \"%c\" bezpośrednio po "
|
"Wyrażenie opisujące położenie zawiera operator \"%c\" bezpośrednio po "
|
||||||
"operatorze \"%c\" bez rozdzielającego ich operandu"
|
"operatorze \"%c\" bez rozdzielającego ich operandu"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2398 ../src/ui/theme.c:2443
|
#: ../src/ui/theme.c:2397 ../src/ui/theme.c:2442
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had unknown variable or constant \"%s\""
|
msgid "Coordinate expression had unknown variable or constant \"%s\""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Wyrażenie opisujące położenie zawiera nieznaną zmienną lub stałą \"%s\""
|
"Wyrażenie opisujące położenie zawiera nieznaną zmienną lub stałą \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2497
|
#: ../src/ui/theme.c:2496
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression parser overflowed its buffer."
|
msgid "Coordinate expression parser overflowed its buffer."
|
||||||
msgstr "Parser wyrażeń określających współrzędne przepełnił swój bufor."
|
msgstr "Parser wyrażeń określających współrzędne przepełnił swój bufor."
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2526
|
#: ../src/ui/theme.c:2525
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had a close parenthesis with no open parenthesis"
|
msgid "Coordinate expression had a close parenthesis with no open parenthesis"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Wyrażenie opisujące położenie zawiera nawias zamykający bez odpowiadającego "
|
"Wyrażenie opisujące położenie zawiera nawias zamykający bez odpowiadającego "
|
||||||
"mu nawiasu otwierającego"
|
"mu nawiasu otwierającego"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2590
|
#: ../src/ui/theme.c:2589
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had an open parenthesis with no close parenthesis"
|
msgid "Coordinate expression had an open parenthesis with no close parenthesis"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Wyrażenie opisujące położenie zawiera nawias otwierający bez odpowiadającego "
|
"Wyrażenie opisujące położenie zawiera nawias otwierający bez odpowiadającego "
|
||||||
"mu nawiasu zamykającego"
|
"mu nawiasu zamykającego"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2601
|
#: ../src/ui/theme.c:2600
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression doesn't seem to have any operators or operands"
|
msgid "Coordinate expression doesn't seem to have any operators or operands"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Wyrażenie opisujące położenie nie zawiera żadnych operatorów ani operandów"
|
"Wyrażenie opisujące położenie nie zawiera żadnych operatorów ani operandów"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2814 ../src/ui/theme.c:2834 ../src/ui/theme.c:2854
|
#: ../src/ui/theme.c:2813 ../src/ui/theme.c:2833 ../src/ui/theme.c:2853
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Theme contained an expression that resulted in an error: %s\n"
|
msgid "Theme contained an expression that resulted in an error: %s\n"
|
||||||
msgstr "Motyw zawiera wyrażenie, przy którego obliczaniu wystąpił błąd: %s\n"
|
msgstr "Motyw zawiera wyrażenie, przy którego obliczaniu wystąpił błąd: %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:4500
|
#: ../src/ui/theme.c:4499
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be "
|
"<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be "
|
||||||
@@ -1210,25 +1203,25 @@ msgstr ""
|
|||||||
"Przy tym stylu ramki należy podać <button function=\"%s\" state=\"%s\" "
|
"Przy tym stylu ramki należy podać <button function=\"%s\" state=\"%s\" "
|
||||||
"draw_ops=\"cokolwiek\"/>"
|
"draw_ops=\"cokolwiek\"/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5011 ../src/ui/theme.c:5036
|
#: ../src/ui/theme.c:5010 ../src/ui/theme.c:5035
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
|
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Brak <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"cokolwiek\"/>"
|
"Brak <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"cokolwiek\"/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5082
|
#: ../src/ui/theme.c:5083
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to load theme \"%s\": %s\n"
|
msgid "Failed to load theme \"%s\": %s\n"
|
||||||
msgstr "Wczytanie motywu \"%s\" się nie powiodło: %s\n"
|
msgstr "Wczytanie motywu \"%s\" się nie powiodło: %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232
|
#: ../src/ui/theme.c:5219 ../src/ui/theme.c:5226 ../src/ui/theme.c:5233
|
||||||
#: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246
|
#: ../src/ui/theme.c:5240 ../src/ui/theme.c:5247
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "No <%s> set for theme \"%s\""
|
msgid "No <%s> set for theme \"%s\""
|
||||||
msgstr "Nie określono elementu <%s> dla motywu \"%s\""
|
msgstr "Nie określono elementu <%s> dla motywu \"%s\""
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5254
|
#: ../src/ui/theme.c:5255
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
||||||
@@ -1237,7 +1230,7 @@ msgstr ""
|
|||||||
"Przy typie okna \"%s\" w motywie \"%s\" nie ustawiono stylu ramki. Należy "
|
"Przy typie okna \"%s\" w motywie \"%s\" nie ustawiono stylu ramki. Należy "
|
||||||
"dodać element <window type=\"%s\" style_set=\"cokolwiek\"/>"
|
"dodać element <window type=\"%s\" style_set=\"cokolwiek\"/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786
|
#: ../src/ui/theme.c:5662 ../src/ui/theme.c:5724 ../src/ui/theme.c:5787
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
||||||
@@ -1245,7 +1238,7 @@ msgstr ""
|
|||||||
"Stałe definiowane przez użytkownika powinny rozpoczynać się wielką literą, "
|
"Stałe definiowane przez użytkownika powinny rozpoczynać się wielką literą, "
|
||||||
"natomiast \"%s\" nie spełnia tego warunku"
|
"natomiast \"%s\" nie spełnia tego warunku"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794
|
#: ../src/ui/theme.c:5670 ../src/ui/theme.c:5732 ../src/ui/theme.c:5795
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Constant \"%s\" has already been defined"
|
msgid "Constant \"%s\" has already been defined"
|
||||||
msgstr "Stała \"%s\" została już określona"
|
msgstr "Stała \"%s\" została już określona"
|
||||||
@@ -1633,7 +1626,208 @@ msgstr "Wewnątrz elementu <%s> nie jest dopuszczalny tekst"
|
|||||||
msgid "<%s> specified twice for this theme"
|
msgid "<%s> specified twice for this theme"
|
||||||
msgstr "<%s> określono dwukrotnie dla tego motywu"
|
msgstr "<%s> określono dwukrotnie dla tego motywu"
|
||||||
|
|
||||||
#: ../src/ui/theme-parser.c:4336
|
#: ../src/ui/theme-parser.c:4334
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to find a valid file for theme %s\n"
|
msgid "Failed to find a valid file for theme %s\n"
|
||||||
msgstr "Odnalezienie prawidłowego pliku dla motywu %s się nie powiodło\n"
|
msgstr "Odnalezienie prawidłowego pliku dla motywu %s się nie powiodło\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:99
|
||||||
|
msgid "_Windows"
|
||||||
|
msgstr "_Okna"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:100
|
||||||
|
msgid "_Dialog"
|
||||||
|
msgstr "Okno _dialogowe"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:101
|
||||||
|
msgid "_Modal dialog"
|
||||||
|
msgstr "_Modalne okno dialogowe"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:102
|
||||||
|
msgid "_Utility"
|
||||||
|
msgstr "_Narzędzie"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:103
|
||||||
|
msgid "_Splashscreen"
|
||||||
|
msgstr "_Ekran powitalny"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:104
|
||||||
|
msgid "_Top dock"
|
||||||
|
msgstr "_Górny dok"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:105
|
||||||
|
msgid "_Bottom dock"
|
||||||
|
msgstr "_Dolny dok"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:106
|
||||||
|
msgid "_Left dock"
|
||||||
|
msgstr "_Lewy dok"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:107
|
||||||
|
msgid "_Right dock"
|
||||||
|
msgstr "_Prawy dok"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:108
|
||||||
|
msgid "_All docks"
|
||||||
|
msgstr "_Wszystkie doki"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:109
|
||||||
|
msgid "Des_ktop"
|
||||||
|
msgstr "Pu_lpit"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:115
|
||||||
|
msgid "Open another one of these windows"
|
||||||
|
msgstr "Otwiera kolejne okno tego typu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:117
|
||||||
|
msgid "This is a demo button with an 'open' icon"
|
||||||
|
msgstr "To jest przycisk demonstracyjny z ikoną \"otwórz\""
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:119
|
||||||
|
msgid "This is a demo button with a 'quit' icon"
|
||||||
|
msgstr "To jest przycisk demonstracyjny z ikoną \"zakończ\""
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:248
|
||||||
|
msgid "This is a sample message in a sample dialog"
|
||||||
|
msgstr "To jest przykładowy komunikat w prostym oknie dialogowym"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:328
|
||||||
|
#, c-format
|
||||||
|
msgid "Fake menu item %d\n"
|
||||||
|
msgstr "Imitacja elementu menu %d\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:363
|
||||||
|
msgid "Border-only window"
|
||||||
|
msgstr "Okno zawierające tylko krawędzie"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:365
|
||||||
|
msgid "Bar"
|
||||||
|
msgstr "Pasek"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:382
|
||||||
|
msgid "Normal Application Window"
|
||||||
|
msgstr "Zwykłe okno programu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:386
|
||||||
|
msgid "Dialog Box"
|
||||||
|
msgstr "Okno dialogowe"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:390
|
||||||
|
msgid "Modal Dialog Box"
|
||||||
|
msgstr "Modalne okno dialogowe"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:394
|
||||||
|
msgid "Utility Palette"
|
||||||
|
msgstr "Paleta narzędziowa"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:398
|
||||||
|
msgid "Torn-off Menu"
|
||||||
|
msgstr "Menu oderwane"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:402
|
||||||
|
msgid "Border"
|
||||||
|
msgstr "Krawędź"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:406
|
||||||
|
msgid "Attached Modal Dialog"
|
||||||
|
msgstr "Dołączone modalne okno dialogowe"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:737
|
||||||
|
#, c-format
|
||||||
|
msgid "Button layout test %d"
|
||||||
|
msgstr "Test układu przycisków %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:766
|
||||||
|
#, c-format
|
||||||
|
msgid "%g milliseconds to draw one window frame"
|
||||||
|
msgstr "%g milisekundy do narysowania jednej ramki okna"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:811
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
|
||||||
|
msgstr "Użycie: metacity-theme-viewer [NAZWA_MOTYWU]\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:818
|
||||||
|
#, c-format
|
||||||
|
msgid "Error loading theme: %s\n"
|
||||||
|
msgstr "Błąd podczas wczytywania motywu: %s\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:824
|
||||||
|
#, c-format
|
||||||
|
msgid "Loaded theme \"%s\" in %g seconds\n"
|
||||||
|
msgstr "Wczytano motyw \"%s\" w ciągu %g sekund\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:869
|
||||||
|
msgid "Normal Title Font"
|
||||||
|
msgstr "Zwykła czcionka tytułu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:875
|
||||||
|
msgid "Small Title Font"
|
||||||
|
msgstr "Mała czcionka tytułu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:881
|
||||||
|
msgid "Large Title Font"
|
||||||
|
msgstr "Duża czcionka tytułu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:886
|
||||||
|
msgid "Button Layouts"
|
||||||
|
msgstr "Układy przycisków"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:891
|
||||||
|
msgid "Benchmark"
|
||||||
|
msgstr "Test wydajności"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:947
|
||||||
|
msgid "Window Title Goes Here"
|
||||||
|
msgstr "Tutaj znajduje się tytuł okna"
|
||||||
|
|
||||||
|
# FIXME - bełkot
|
||||||
|
#: ../src/ui/theme-viewer.c:1053
|
||||||
|
#, c-format
|
||||||
|
msgid ""
|
||||||
|
"Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g "
|
||||||
|
"seconds wall clock time including X server resources (%g milliseconds per "
|
||||||
|
"frame)\n"
|
||||||
|
msgstr ""
|
||||||
|
"Narysowano %d ramek w ciągu %g sekund klienta (%g milisekund na ramkę) oraz "
|
||||||
|
"%g sekund rzeczywistych, włączając w to zasoby serwera X (%g milisekund na "
|
||||||
|
"ramkę)\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1273
|
||||||
|
msgid "position expression test returned TRUE but set error"
|
||||||
|
msgstr "Test wyrażenia pozycji zwrócił wartość PRAWDA, lecz ustawił błąd"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1275
|
||||||
|
msgid "position expression test returned FALSE but didn't set error"
|
||||||
|
msgstr "Test wyrażenia pozycji zwrócił wartość FAŁSZ, lecz nie ustawił błędu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1279
|
||||||
|
msgid "Error was expected but none given"
|
||||||
|
msgstr "Oczekiwano błędu, lecz nie otrzymano żadnego"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1281
|
||||||
|
#, c-format
|
||||||
|
msgid "Error %d was expected but %d given"
|
||||||
|
msgstr "Oczekiwano błędu %d, lecz otrzymano %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1287
|
||||||
|
#, c-format
|
||||||
|
msgid "Error not expected but one was returned: %s"
|
||||||
|
msgstr "Nie oczekiwano błędu, lecz został on zwrócony: %s"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1291
|
||||||
|
#, c-format
|
||||||
|
msgid "x value was %d, %d was expected"
|
||||||
|
msgstr "Wartością X było %d, oczekiwano wartości %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1294
|
||||||
|
#, c-format
|
||||||
|
msgid "y value was %d, %d was expected"
|
||||||
|
msgstr "Wartością Y było %d, oczekiwano wartości %d"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1359
|
||||||
|
#, c-format
|
||||||
|
msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
|
||||||
|
msgstr ""
|
||||||
|
"Wyrażenia współrzędnych %d zostało przetworzone w %g sekund (średnio %g "
|
||||||
|
"sekund)\n"
|
||||||
|
|||||||
498
po/pt_BR.po
498
po/pt_BR.po
File diff suppressed because it is too large
Load Diff
417
po/sk.po
417
po/sk.po
@@ -13,9 +13,9 @@ msgstr ""
|
|||||||
"Project-Id-Version: mutter\n"
|
"Project-Id-Version: mutter\n"
|
||||||
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?"
|
"Report-Msgid-Bugs-To: http://bugzilla.gnome.org/enter_bug.cgi?"
|
||||||
"product=mutter&keywords=I18N+L10N&component=general\n"
|
"product=mutter&keywords=I18N+L10N&component=general\n"
|
||||||
"POT-Creation-Date: 2013-08-21 17:41+0000\n"
|
"POT-Creation-Date: 2013-05-24 21:44+0000\n"
|
||||||
"PO-Revision-Date: 2013-08-02 14:46+0200\n"
|
"PO-Revision-Date: 2013-05-18 16:53+0100\n"
|
||||||
"Last-Translator: Ján Kyselica <kyselica.jan@gmail.com>\n"
|
"Last-Translator: Jan Kyselica <kyselica.jan@gmail.com>\n"
|
||||||
"Language-Team: Slovak <gnome-sk-list@gnome.org>\n"
|
"Language-Team: Slovak <gnome-sk-list@gnome.org>\n"
|
||||||
"Language: sk\n"
|
"Language: sk\n"
|
||||||
"MIME-Version: 1.0\n"
|
"MIME-Version: 1.0\n"
|
||||||
@@ -87,8 +87,9 @@ msgstr "Prepnúť okná aplikácie"
|
|||||||
# PK: zisti co to robi
|
# PK: zisti co to robi
|
||||||
# description
|
# description
|
||||||
#: ../src/50-mutter-navigation.xml.in.h:13
|
#: ../src/50-mutter-navigation.xml.in.h:13
|
||||||
|
#, fuzzy
|
||||||
msgid "Switch system controls"
|
msgid "Switch system controls"
|
||||||
msgstr "Prepnúť medzi ovládacími prvkami systému"
|
msgstr "Prepnúť medzi systémovými ovládacími prvkami"
|
||||||
|
|
||||||
# description
|
# description
|
||||||
#: ../src/50-mutter-navigation.xml.in.h:14
|
#: ../src/50-mutter-navigation.xml.in.h:14
|
||||||
@@ -103,8 +104,9 @@ msgstr "Prepnúť okná aplikácie priamo"
|
|||||||
# MČ: podobne ako vyššie: „cycle-panels“
|
# MČ: podobne ako vyššie: „cycle-panels“
|
||||||
# description
|
# description
|
||||||
#: ../src/50-mutter-navigation.xml.in.h:16
|
#: ../src/50-mutter-navigation.xml.in.h:16
|
||||||
|
#, fuzzy
|
||||||
msgid "Switch system controls directly"
|
msgid "Switch system controls directly"
|
||||||
msgstr "Prepnúť medzi ovládacími prvkami systému priamo"
|
msgstr "Prepnúť medzi systémovými ovládacími prvkami priamo"
|
||||||
|
|
||||||
# description
|
# description
|
||||||
#: ../src/50-mutter-navigation.xml.in.h:17
|
#: ../src/50-mutter-navigation.xml.in.h:17
|
||||||
@@ -265,13 +267,13 @@ msgstr "Zobraziť rozdelenie napravo"
|
|||||||
# PK: je %i cislo obrazovky? ak ano tak "č. %i"
|
# PK: je %i cislo obrazovky? ak ano tak "č. %i"
|
||||||
#. This probably means that a non-WM compositor like xcompmgr is running;
|
#. This probably means that a non-WM compositor like xcompmgr is running;
|
||||||
#. * we have no way to get it to exit
|
#. * we have no way to get it to exit
|
||||||
#: ../src/compositor/compositor.c:596
|
#: ../src/compositor/compositor.c:571
|
||||||
#, c-format
|
#, fuzzy, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Another compositing manager is already running on screen %i on display \"%s"
|
"Another compositing manager is already running on screen %i on display \"%s"
|
||||||
"\"."
|
"\"."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Pre obrazovku č. %i na displeji „%s“ je spustený už iný správca rozloženia."
|
"Pre obrazovku %i na displeji „%s“ je spustený už iný správca rozloženia."
|
||||||
|
|
||||||
#: ../src/compositor/meta-background.c:1076
|
#: ../src/compositor/meta-background.c:1076
|
||||||
msgid "background texture could not be created from file"
|
msgid "background texture could not be created from file"
|
||||||
@@ -311,18 +313,18 @@ msgstr "_Počkať"
|
|||||||
msgid "_Force Quit"
|
msgid "_Force Quit"
|
||||||
msgstr "_Vynútiť ukončenie"
|
msgstr "_Vynútiť ukončenie"
|
||||||
|
|
||||||
#: ../src/core/display.c:421
|
#: ../src/core/display.c:401
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Missing %s extension required for compositing"
|
msgid "Missing %s extension required for compositing"
|
||||||
msgstr "Rozšírenie %s, potrebné pre kompozitné prostredie, chýba"
|
msgstr "Rozšírenie %s, potrebné pre kompozitné prostredie, chýba"
|
||||||
|
|
||||||
# X window system preloz, napr. system na spravu okien X
|
# X window system preloz, napr. system na spravu okien X
|
||||||
#: ../src/core/display.c:513
|
#: ../src/core/display.c:493
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open X Window System display '%s'\n"
|
msgid "Failed to open X Window System display '%s'\n"
|
||||||
msgstr "Zlyhalo otvorenie displeja systému na správu okien X „%s“\n"
|
msgstr "Zlyhalo otvorenie displeja systému na správu okien X „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1136
|
#: ../src/core/keybindings.c:970
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Some other program is already using the key %s with modifiers %x as a "
|
"Some other program is already using the key %s with modifiers %x as a "
|
||||||
@@ -330,7 +332,7 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Iný program už používa kláves %s s modifikátormi %x ako klávesovú skratku\n"
|
"Iný program už používa kláves %s s modifikátormi %x ako klávesovú skratku\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1333
|
#: ../src/core/keybindings.c:1151
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "\"%s\" is not a valid accelerator\n"
|
msgid "\"%s\" is not a valid accelerator\n"
|
||||||
msgstr "„%s“ nie je platný akcelerátor\n"
|
msgstr "„%s“ nie je platný akcelerátor\n"
|
||||||
@@ -376,20 +378,6 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Nepodarilo sa nájsť tému! Overte, že %s existuje a obsahuje obvyklé témy.\n"
|
"Nepodarilo sa nájsť tému! Overte, že %s existuje a obsahuje obvyklé témy.\n"
|
||||||
|
|
||||||
#: ../src/core/monitor.c:702
|
|
||||||
msgid "Built-in display"
|
|
||||||
msgstr "Vstavaný displej"
|
|
||||||
|
|
||||||
#. TRANSLATORS: this is a monitor name (in case we don't know
|
|
||||||
#. the vendor), it's Unknown followed by a size in inches,
|
|
||||||
#. like 'Unknown 15"'
|
|
||||||
#.
|
|
||||||
#: ../src/core/monitor.c:730
|
|
||||||
#, c-format
|
|
||||||
#| msgid "Unknown element %s"
|
|
||||||
msgid "Unknown %s"
|
|
||||||
msgstr "Neznámy %s"
|
|
||||||
|
|
||||||
#: ../src/core/mutter.c:40
|
#: ../src/core/mutter.c:40
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
@@ -415,7 +403,7 @@ msgstr "Zobrazí verziu"
|
|||||||
msgid "Mutter plugin to use"
|
msgid "Mutter plugin to use"
|
||||||
msgstr "Použije zásuvný modul Mutter"
|
msgstr "Použije zásuvný modul Mutter"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1202
|
#: ../src/core/prefs.c:1193
|
||||||
msgid ""
|
msgid ""
|
||||||
"Workarounds for broken applications disabled. Some applications may not "
|
"Workarounds for broken applications disabled. Some applications may not "
|
||||||
"behave properly.\n"
|
"behave properly.\n"
|
||||||
@@ -423,12 +411,12 @@ msgstr ""
|
|||||||
"Náhradné riešenia pre chybné aplikácie nie sú povolené. Niektoré aplikácie "
|
"Náhradné riešenia pre chybné aplikácie nie sú povolené. Niektoré aplikácie "
|
||||||
"sa nemusia správať správne.\n"
|
"sa nemusia správať správne.\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1277
|
#: ../src/core/prefs.c:1268
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
||||||
msgstr "Nepodarilo sa spracovať popis písma „%s“ z kľúča GSettings %s\n"
|
msgstr "Nepodarilo sa spracovať popis písma „%s“ z kľúča GSettings %s\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1343
|
#: ../src/core/prefs.c:1334
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for mouse button "
|
"\"%s\" found in configuration database is not a valid value for mouse button "
|
||||||
@@ -437,7 +425,7 @@ msgstr ""
|
|||||||
"V konfiguračnej databáze sa našlo „%s“, čo nie je platná hodnota pre "
|
"V konfiguračnej databáze sa našlo „%s“, čo nie je platná hodnota pre "
|
||||||
"modifikátor tlačidla myši\n"
|
"modifikátor tlačidla myši\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1909
|
#: ../src/core/prefs.c:1881
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for keybinding "
|
"\"%s\" found in configuration database is not a valid value for keybinding "
|
||||||
@@ -446,17 +434,17 @@ msgstr ""
|
|||||||
"V konfiguračnej databáze sa našlo „%s“, čo nie je platná hodnota pre "
|
"V konfiguračnej databáze sa našlo „%s“, čo nie je platná hodnota pre "
|
||||||
"klávesovú skratku „%s“\n"
|
"klávesovú skratku „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1999
|
#: ../src/core/prefs.c:1945
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d"
|
msgid "Workspace %d"
|
||||||
msgstr "Pracovný priestor č. %d"
|
msgstr "Pracovný priestor č. %d"
|
||||||
|
|
||||||
#: ../src/core/screen.c:537
|
#: ../src/core/screen.c:691
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display '%s' is invalid\n"
|
msgid "Screen %d on display '%s' is invalid\n"
|
||||||
msgstr "Obrazovka č. %d na displeji „%s“ nie je platná\n"
|
msgstr "Obrazovka č. %d na displeji „%s“ nie je platná\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:553
|
#: ../src/core/screen.c:707
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
||||||
@@ -465,7 +453,7 @@ msgstr ""
|
|||||||
"Obrazovka č. %d na displeji „%s“ už má správcu okien. Skúste použiť prepínač "
|
"Obrazovka č. %d na displeji „%s“ už má správcu okien. Skúste použiť prepínač "
|
||||||
"--replace, aby sa aktuálny správca nahradil.\n"
|
"--replace, aby sa aktuálny správca nahradil.\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:580
|
#: ../src/core/screen.c:734
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
||||||
@@ -473,12 +461,12 @@ msgstr ""
|
|||||||
"Nepodarilo sa získať výber správcu okien pre obrazovku č. %d na displeji "
|
"Nepodarilo sa získať výber správcu okien pre obrazovku č. %d na displeji "
|
||||||
"„%s“\n"
|
"„%s“\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:658
|
#: ../src/core/screen.c:812
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
||||||
msgstr "Obrazovka č. %d na displeji „%s“ už má správcu okien\n"
|
msgstr "Obrazovka č. %d na displeji „%s“ už má správcu okien\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:850
|
#: ../src/core/screen.c:998
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not release screen %d on display \"%s\"\n"
|
msgid "Could not release screen %d on display \"%s\"\n"
|
||||||
msgstr "Nepodarilo sa uvoľniť obrazovku č. %d na displeji „%s“\n"
|
msgstr "Nepodarilo sa uvoľniť obrazovku č. %d na displeji „%s“\n"
|
||||||
@@ -554,7 +542,8 @@ msgstr "Zlyhalo otvorenie súboru so záznamom pomocou fdopen() %s: %s\n"
|
|||||||
msgid "Opened log file %s\n"
|
msgid "Opened log file %s\n"
|
||||||
msgstr "Otvorený súbor so záznamom %s\n"
|
msgstr "Otvorený súbor so záznamom %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:119
|
#: ../src/core/util.c:119 ../src/tools/mutter-message.c:149
|
||||||
|
#, c-format
|
||||||
msgid "Mutter was compiled without support for verbose mode\n"
|
msgid "Mutter was compiled without support for verbose mode\n"
|
||||||
msgstr "Mutter bol skompilovaný bez výpisu podrobností pri behu\n"
|
msgstr "Mutter bol skompilovaný bez výpisu podrobností pri behu\n"
|
||||||
|
|
||||||
@@ -562,20 +551,20 @@ msgstr "Mutter bol skompilovaný bez výpisu podrobností pri behu\n"
|
|||||||
msgid "Window manager: "
|
msgid "Window manager: "
|
||||||
msgstr "Správca okien: "
|
msgstr "Správca okien: "
|
||||||
|
|
||||||
#: ../src/core/util.c:414
|
#: ../src/core/util.c:412
|
||||||
msgid "Bug in window manager: "
|
msgid "Bug in window manager: "
|
||||||
msgstr "Chyba v správcovi okien: "
|
msgstr "Chyba v správcovi okien: "
|
||||||
|
|
||||||
#: ../src/core/util.c:445
|
#: ../src/core/util.c:443
|
||||||
msgid "Window manager warning: "
|
msgid "Window manager warning: "
|
||||||
msgstr "Varovanie správcu okien: "
|
msgstr "Varovanie správcu okien: "
|
||||||
|
|
||||||
#: ../src/core/util.c:473
|
#: ../src/core/util.c:471
|
||||||
msgid "Window manager error: "
|
msgid "Window manager error: "
|
||||||
msgstr "Chyba správcu okien: "
|
msgstr "Chyba správcu okien: "
|
||||||
|
|
||||||
#. first time through
|
#. first time through
|
||||||
#: ../src/core/window.c:7533
|
#: ../src/core/window.c:7505
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
||||||
@@ -591,7 +580,7 @@ msgstr ""
|
|||||||
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
||||||
#. * about these apps but make them work.
|
#. * about these apps but make them work.
|
||||||
#.
|
#.
|
||||||
#: ../src/core/window.c:8257
|
#: ../src/core/window.c:8229
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
||||||
@@ -601,7 +590,7 @@ msgstr ""
|
|||||||
"nastavuje minimálnu veľkosť %d x %d a maximálnu veľkosť %d x %d. To nedáva "
|
"nastavuje minimálnu veľkosť %d x %d a maximálnu veľkosť %d x %d. To nedáva "
|
||||||
"zmysel.\n"
|
"zmysel.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:347
|
#: ../src/core/window-props.c:318
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
||||||
msgstr "Aplikácia nastavila neplatné _NET_WM_PID %lu\n"
|
msgstr "Aplikácia nastavila neplatné _NET_WM_PID %lu\n"
|
||||||
@@ -609,18 +598,18 @@ msgstr "Aplikácia nastavila neplatné _NET_WM_PID %lu\n"
|
|||||||
# PK: co je toto?
|
# PK: co je toto?
|
||||||
# JK: nedokazem zistit
|
# JK: nedokazem zistit
|
||||||
# PM: vyžiadaj komentár od vývojárov, pomožeme aj ostatným prekladateľom
|
# PM: vyžiadaj komentár od vývojárov, pomožeme aj ostatným prekladateľom
|
||||||
#: ../src/core/window-props.c:463
|
#: ../src/core/window-props.c:434
|
||||||
#, fuzzy, c-format
|
#, fuzzy, c-format
|
||||||
msgid "%s (on %s)"
|
msgid "%s (on %s)"
|
||||||
msgstr "%s (na %s)"
|
msgstr "%s (na %s)"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1546
|
#: ../src/core/window-props.c:1517
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
||||||
msgstr "Neplatné WM_TRANSIENT_FOR okno 0x%lx nastavené pre %s.\n"
|
msgstr "Neplatné WM_TRANSIENT_FOR okno 0x%lx nastavené pre %s.\n"
|
||||||
|
|
||||||
# MČ: zacykliť sa, alebo vytvoriť slučku.
|
# MČ: zacykliť sa, alebo vytvoriť slučku.
|
||||||
#: ../src/core/window-props.c:1557
|
#: ../src/core/window-props.c:1528
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
||||||
msgstr "WM_TRANSIENT_FOR okno 0x%lx pre %s môže vytvoriť slučku.\n"
|
msgstr "WM_TRANSIENT_FOR okno 0x%lx pre %s môže vytvoriť slučku.\n"
|
||||||
@@ -708,9 +697,9 @@ msgid ""
|
|||||||
"vertically and resizes them horizontally to cover half of the available "
|
"vertically and resizes them horizontally to cover half of the available "
|
||||||
"area. Dropping windows on the top screen edge maximizes them completely."
|
"area. Dropping windows on the top screen edge maximizes them completely."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Ak je povolené, upustenie okien pri zvislých okrajoch obrazovky ich zvislo "
|
"Ak je povolené, upustenie okien pri zvislých okrajoch obrazovky ich "
|
||||||
"maximalizuje a vodorovná veľkosť sa zmení na polovicu dostupnej plochy. "
|
"zvislo maximalizuje a vodorovná veľkosť sa zmení na polovicu dostupnej "
|
||||||
"Upustenie okien pri vrchnom okraji obrazovky ich maximalizuje úplne."
|
"plochy. Upustenie okien pri vrchnom okraji obrazovky ich maximalizuje úplne."
|
||||||
|
|
||||||
# summary
|
# summary
|
||||||
#: ../src/org.gnome.mutter.gschema.xml.in.h:7
|
#: ../src/org.gnome.mutter.gschema.xml.in.h:7
|
||||||
@@ -746,8 +735,9 @@ msgstr ""
|
|||||||
# PM: ja by som dal Bez vyvovlávania tabulátorom
|
# PM: ja by som dal Bez vyvovlávania tabulátorom
|
||||||
# summary
|
# summary
|
||||||
#: ../src/org.gnome.mutter.gschema.xml.in.h:11
|
#: ../src/org.gnome.mutter.gschema.xml.in.h:11
|
||||||
|
#, fuzzy
|
||||||
msgid "No tab popup"
|
msgid "No tab popup"
|
||||||
msgstr "Bez vyvolávania tabulátorom"
|
msgstr "Nepoužívať prekryvnú ponuku tabulátora"
|
||||||
|
|
||||||
# MČ: Neviem, čo to presne má robiť, ale popis som pochopil inak. „…či sa má používať rozbaľovacia ponuka a zvýraznenie rámikom sa má vypnúť…“
|
# MČ: Neviem, čo to presne má robiť, ale popis som pochopil inak. „…či sa má používať rozbaľovacia ponuka a zvýraznenie rámikom sa má vypnúť…“
|
||||||
# description
|
# description
|
||||||
@@ -816,104 +806,109 @@ msgstr "Vybrať okno z rozbaľovacej ponuky tabulátoru"
|
|||||||
msgid "Cancel tab popup"
|
msgid "Cancel tab popup"
|
||||||
msgstr "Zrušit rozbaľovaciu ponuku tabulátoru"
|
msgstr "Zrušit rozbaľovaciu ponuku tabulátoru"
|
||||||
|
|
||||||
|
#: ../src/tools/mutter-message.c:123
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: %s\n"
|
||||||
|
msgstr "Použitie: %s\n"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:67
|
#: ../src/ui/menu.c:69
|
||||||
msgid "Mi_nimize"
|
msgid "Mi_nimize"
|
||||||
msgstr "Mi_nimalizovať"
|
msgstr "Mi_nimalizovať"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:69
|
#: ../src/ui/menu.c:71
|
||||||
msgid "Ma_ximize"
|
msgid "Ma_ximize"
|
||||||
msgstr "Ma_ximalizovať"
|
msgstr "Ma_ximalizovať"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:71
|
#: ../src/ui/menu.c:73
|
||||||
msgid "Unma_ximize"
|
msgid "Unma_ximize"
|
||||||
msgstr "Zrušiť ma_ximalizáciu"
|
msgstr "Zrušiť ma_ximalizáciu"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:73
|
#: ../src/ui/menu.c:75
|
||||||
msgid "Roll _Up"
|
msgid "Roll _Up"
|
||||||
msgstr "_Zabaliť"
|
msgstr "_Zabaliť"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:75
|
#: ../src/ui/menu.c:77
|
||||||
msgid "_Unroll"
|
msgid "_Unroll"
|
||||||
msgstr "_Rozbaliť"
|
msgstr "_Rozbaliť"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:77
|
#: ../src/ui/menu.c:79
|
||||||
msgid "_Move"
|
msgid "_Move"
|
||||||
msgstr "Pre_miestniť"
|
msgstr "Pre_miestniť"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:79
|
#: ../src/ui/menu.c:81
|
||||||
msgid "_Resize"
|
msgid "_Resize"
|
||||||
msgstr "Zmeniť veľko_sť"
|
msgstr "Zmeniť veľko_sť"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:81
|
#: ../src/ui/menu.c:83
|
||||||
msgid "Move Titlebar On_screen"
|
msgid "Move Titlebar On_screen"
|
||||||
msgstr "Presunúť titulok na _obrazovku"
|
msgstr "Presunúť titulok na _obrazovku"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:84 ../src/ui/menu.c:86
|
#: ../src/ui/menu.c:86 ../src/ui/menu.c:88
|
||||||
msgid "Always on _Top"
|
msgid "Always on _Top"
|
||||||
msgstr "Vždy na_vrchu"
|
msgstr "Vždy na_vrchu"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:88
|
#: ../src/ui/menu.c:90
|
||||||
msgid "_Always on Visible Workspace"
|
msgid "_Always on Visible Workspace"
|
||||||
msgstr "Vž_dy na viditeľnom pracovnom priestore"
|
msgstr "Vž_dy na viditeľnom pracovnom priestore"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:90
|
#: ../src/ui/menu.c:92
|
||||||
msgid "_Only on This Workspace"
|
msgid "_Only on This Workspace"
|
||||||
msgstr "_Len na tomto pracovnom priestore"
|
msgstr "_Len na tomto pracovnom priestore"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:92
|
#: ../src/ui/menu.c:94
|
||||||
msgid "Move to Workspace _Left"
|
msgid "Move to Workspace _Left"
|
||||||
msgstr "Presunúť na pracovný priestor vľav_o"
|
msgstr "Presunúť na pracovný priestor vľav_o"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:94
|
#: ../src/ui/menu.c:96
|
||||||
msgid "Move to Workspace R_ight"
|
msgid "Move to Workspace R_ight"
|
||||||
msgstr "Presunúť na pracovný priestor v_pravo"
|
msgstr "Presunúť na pracovný priestor v_pravo"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:96
|
#: ../src/ui/menu.c:98
|
||||||
msgid "Move to Workspace _Up"
|
msgid "Move to Workspace _Up"
|
||||||
msgstr "Presunúť na pracovný priestor _hore"
|
msgstr "Presunúť na pracovný priestor _hore"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:98
|
#: ../src/ui/menu.c:100
|
||||||
msgid "Move to Workspace _Down"
|
msgid "Move to Workspace _Down"
|
||||||
msgstr "Presunúť na pracovný priestor _dole"
|
msgstr "Presunúť na pracovný priestor _dole"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:102
|
#: ../src/ui/menu.c:104
|
||||||
msgid "_Close"
|
msgid "_Close"
|
||||||
msgstr "_Zavrieť"
|
msgstr "_Zavrieť"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:202
|
#: ../src/ui/menu.c:204
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d%n"
|
msgid "Workspace %d%n"
|
||||||
msgstr "Pracovná priestor %d%n"
|
msgstr "Pracovná priestor %d%n"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:212
|
#: ../src/ui/menu.c:214
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace 1_0"
|
msgid "Workspace 1_0"
|
||||||
msgstr "Pracovný priestor 1_0"
|
msgstr "Pracovný priestor 1_0"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:214
|
#: ../src/ui/menu.c:216
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %s%d"
|
msgid "Workspace %s%d"
|
||||||
msgstr "Pracovný priestor %s%d"
|
msgstr "Pracovný priestor %s%d"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:384
|
#: ../src/ui/menu.c:397
|
||||||
msgid "Move to Another _Workspace"
|
msgid "Move to Another _Workspace"
|
||||||
msgstr "P_resunúť na iný pracovný priestor"
|
msgstr "P_resunúť na iný pracovný priestor"
|
||||||
|
|
||||||
@@ -1071,21 +1066,21 @@ msgstr ""
|
|||||||
# MČ: Preformuloval by som koniec: „platné sú len znaky A-Za-z0-9-_“
|
# MČ: Preformuloval by som koniec: „platné sú len znaky A-Za-z0-9-_“
|
||||||
# PK: color_name je asi nejaky atribut, to sa nepreklada, ked tak do zatvorky
|
# PK: color_name je asi nejaky atribut, to sa nepreklada, ked tak do zatvorky
|
||||||
#: ../src/ui/theme.c:1219
|
#: ../src/ui/theme.c:1219
|
||||||
#, c-format
|
#, fuzzy, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
|
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
|
||||||
"_ are valid"
|
"_ are valid"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"V parametri color_name (názov farby) pre gtk:custom je neplatný znak „%c“, platné sú len "
|
"V parametri názov_farby pre gtk:custom je neplatný znak „%c“, platné sú len "
|
||||||
"znaky A-Za-z0-9-_"
|
"znaky A-Za-z0-9-_"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1233
|
#: ../src/ui/theme.c:1233
|
||||||
#, c-format
|
#, fuzzy, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
|
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
|
||||||
"fit the format"
|
"fit the format"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Formát Gtk:custom je „gtk:custom(color_name,fallback)“, „%s“ tomu "
|
"Formát Gtk:custom je „gtk:custom(názov_farby,fallback)“, „%s“ tomu "
|
||||||
"nezodpovedá"
|
"nezodpovedá"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1278
|
#: ../src/ui/theme.c:1278
|
||||||
@@ -1271,20 +1266,20 @@ msgid ""
|
|||||||
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
|
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
|
||||||
msgstr "Chýbajúce <frame state=„%s“ resize=„%s“ focus=„%s“ style=„whatever“/>"
|
msgstr "Chýbajúce <frame state=„%s“ resize=„%s“ focus=„%s“ style=„whatever“/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5082
|
#: ../src/ui/theme.c:5084
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to load theme \"%s\": %s\n"
|
msgid "Failed to load theme \"%s\": %s\n"
|
||||||
msgstr "Zlyhalo načítanie témy „%s“: %s\n"
|
msgstr "Zlyhalo načítanie témy „%s“: %s\n"
|
||||||
|
|
||||||
# PK: prvok?
|
# PK: prvok?
|
||||||
# JK: XML značka (XML tag)
|
# JK: XML značka (XML tag)
|
||||||
#: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232
|
#: ../src/ui/theme.c:5220 ../src/ui/theme.c:5227 ../src/ui/theme.c:5234
|
||||||
#: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246
|
#: ../src/ui/theme.c:5241 ../src/ui/theme.c:5248
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "No <%s> set for theme \"%s\""
|
msgid "No <%s> set for theme \"%s\""
|
||||||
msgstr "Pre tému „%s“ nie je nastavená <%s>"
|
msgstr "Pre tému „%s“ nie je nastavená <%s>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5254
|
#: ../src/ui/theme.c:5256
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
||||||
@@ -1293,13 +1288,13 @@ msgstr ""
|
|||||||
"Pre typ okna „%s“ nie je sada štýlov v téme „%s“, pridajte prvok <window "
|
"Pre typ okna „%s“ nie je sada štýlov v téme „%s“, pridajte prvok <window "
|
||||||
"type=„%s“ style_set=„whatever“/>"
|
"type=„%s“ style_set=„whatever“/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786
|
#: ../src/ui/theme.c:5663 ../src/ui/theme.c:5725 ../src/ui/theme.c:5788
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
||||||
msgstr "Používateľské konštanty musia začínať veľkým písmenom, „%s“ nezačína"
|
msgstr "Používateľské konštanty musia začínať veľkým písmenom, „%s“ nezačína"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794
|
#: ../src/ui/theme.c:5671 ../src/ui/theme.c:5733 ../src/ui/theme.c:5796
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Constant \"%s\" has already been defined"
|
msgid "Constant \"%s\" has already been defined"
|
||||||
msgstr "Konštanta „%s“ už je definovaná"
|
msgstr "Konštanta „%s“ už je definovaná"
|
||||||
@@ -1402,7 +1397,7 @@ msgstr "<%s> musí uvádzať buď geometriu alebo rodiča, ktorý má geometriu"
|
|||||||
msgid "You must specify a background for an alpha value to be meaningful"
|
msgid "You must specify a background for an alpha value to be meaningful"
|
||||||
msgstr "Ak má byť hodnota alpha zmysluplná, tak musíte vybrať nejaké pozadie"
|
msgstr "Ak má byť hodnota alpha zmysluplná, tak musíte vybrať nejaké pozadie"
|
||||||
|
|
||||||
# PM: asi atribút type
|
# PM: asi atribút type
|
||||||
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=698123
|
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=698123
|
||||||
#: ../src/ui/theme-parser.c:1264
|
#: ../src/ui/theme-parser.c:1264
|
||||||
#, fuzzy, c-format
|
#, fuzzy, c-format
|
||||||
@@ -1564,7 +1559,6 @@ msgid "\"%s\" is not a valid value for resize attribute"
|
|||||||
msgstr "„%s“ nie je platná hodnota pre atribút zmeny veľkosti"
|
msgstr "„%s“ nie je platná hodnota pre atribút zmeny veľkosti"
|
||||||
|
|
||||||
# PK: shaded states? to zatvorky daj popis co je resize
|
# PK: shaded states? to zatvorky daj popis co je resize
|
||||||
# PM: skôr "pre stavy maximized (maximalizovaný)/shaded (zatienený)"
|
|
||||||
#: ../src/ui/theme-parser.c:3147
|
#: ../src/ui/theme-parser.c:3147
|
||||||
#, fuzzy, c-format
|
#, fuzzy, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
@@ -1706,172 +1700,221 @@ msgstr "<%s> uvedený dvakrát pre túto tému"
|
|||||||
msgid "Failed to find a valid file for theme %s\n"
|
msgid "Failed to find a valid file for theme %s\n"
|
||||||
msgstr "Zlyhalo nájdenie platného súboru pre tému%s\n"
|
msgstr "Zlyhalo nájdenie platného súboru pre tému%s\n"
|
||||||
|
|
||||||
#~ msgid "Usage: %s\n"
|
#: ../src/ui/theme-viewer.c:99
|
||||||
#~ msgstr "Použitie: %s\n"
|
msgid "_Windows"
|
||||||
|
msgstr "_Okná"
|
||||||
|
|
||||||
#~ msgid "_Windows"
|
#: ../src/ui/theme-viewer.c:100
|
||||||
#~ msgstr "_Okná"
|
msgid "_Dialog"
|
||||||
|
msgstr "_Dialógové okno"
|
||||||
|
|
||||||
#~ msgid "_Dialog"
|
#: ../src/ui/theme-viewer.c:101
|
||||||
#~ msgstr "_Dialógové okno"
|
msgid "_Modal dialog"
|
||||||
|
msgstr "_Modálne dialógové okno"
|
||||||
|
|
||||||
#~ msgid "_Modal dialog"
|
#: ../src/ui/theme-viewer.c:102
|
||||||
#~ msgstr "_Modálne dialógové okno"
|
msgid "_Utility"
|
||||||
|
msgstr "_Nástroje"
|
||||||
|
|
||||||
#~ msgid "_Utility"
|
#: ../src/ui/theme-viewer.c:103
|
||||||
#~ msgstr "_Nástroje"
|
msgid "_Splashscreen"
|
||||||
|
msgstr "Ú_vodná obrazovka"
|
||||||
#~ msgid "_Splashscreen"
|
|
||||||
#~ msgstr "Ú_vodná obrazovka"
|
|
||||||
|
|
||||||
# MČ: nie som si istý prekladom „dok“, nemal by to byť „panel“?
|
# MČ: nie som si istý prekladom „dok“, nemal by to byť „panel“?
|
||||||
#~ msgid "_Top dock"
|
#: ../src/ui/theme-viewer.c:104
|
||||||
#~ msgstr "_Horný panel"
|
msgid "_Top dock"
|
||||||
|
msgstr "_Horný panel"
|
||||||
|
|
||||||
#~ msgid "_Bottom dock"
|
#: ../src/ui/theme-viewer.c:105
|
||||||
#~ msgstr "_Spodný panel"
|
msgid "_Bottom dock"
|
||||||
|
msgstr "_Spodný panel"
|
||||||
|
|
||||||
#~ msgid "_Left dock"
|
#: ../src/ui/theme-viewer.c:106
|
||||||
#~ msgstr "Ľ_avý panel"
|
msgid "_Left dock"
|
||||||
|
msgstr "Ľ_avý panel"
|
||||||
|
|
||||||
#~ msgid "_Right dock"
|
#: ../src/ui/theme-viewer.c:107
|
||||||
#~ msgstr "_Pravý panel"
|
msgid "_Right dock"
|
||||||
|
msgstr "_Pravý panel"
|
||||||
|
|
||||||
#~ msgid "_All docks"
|
#: ../src/ui/theme-viewer.c:108
|
||||||
#~ msgstr "_Všetky panely"
|
msgid "_All docks"
|
||||||
|
msgstr "_Všetky panely"
|
||||||
|
|
||||||
#~ msgid "Des_ktop"
|
#: ../src/ui/theme-viewer.c:109
|
||||||
#~ msgstr "P_racovná plocha"
|
msgid "Des_ktop"
|
||||||
|
msgstr "P_racovná plocha"
|
||||||
|
|
||||||
# tooltip
|
# tooltip
|
||||||
#~ msgid "Open another one of these windows"
|
#: ../src/ui/theme-viewer.c:115
|
||||||
#~ msgstr "Otvorí ďalšie z týchto okien"
|
msgid "Open another one of these windows"
|
||||||
|
msgstr "Otvorí ďalšie z týchto okien"
|
||||||
|
|
||||||
# PK: prekladat to v uvodzovkach? nahlas bug
|
# PK: prekladat to v uvodzovkach? nahlas bug
|
||||||
# tooltip
|
# tooltip
|
||||||
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=698123
|
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=698123
|
||||||
|
#: ../src/ui/theme-viewer.c:117
|
||||||
#, fuzzy
|
#, fuzzy
|
||||||
#~ msgid "This is a demo button with an 'open' icon"
|
msgid "This is a demo button with an 'open' icon"
|
||||||
#~ msgstr "Toto je ukážkové tlačidlo s ikonou „open“"
|
msgstr "Toto je ukážkové tlačidlo s ikonou „open“"
|
||||||
|
|
||||||
# tooltip
|
# tooltip
|
||||||
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=698123
|
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=698123
|
||||||
|
#: ../src/ui/theme-viewer.c:119
|
||||||
#, fuzzy
|
#, fuzzy
|
||||||
#~ msgid "This is a demo button with a 'quit' icon"
|
msgid "This is a demo button with a 'quit' icon"
|
||||||
#~ msgstr "Toto je ukážkové tlačidlo s ikonou „quit“"
|
msgstr "Toto je ukážkové tlačidlo s ikonou „quit“"
|
||||||
|
|
||||||
# label
|
# label
|
||||||
#~ msgid "This is a sample message in a sample dialog"
|
#: ../src/ui/theme-viewer.c:248
|
||||||
#~ msgstr "Toto je ukážková správa v ukážkovom dialógovom okne"
|
msgid "This is a sample message in a sample dialog"
|
||||||
|
msgstr "Toto je ukážková správa v ukážkovom dialógovom okne"
|
||||||
|
|
||||||
# PK: falosna
|
# PK: falosna
|
||||||
#~ msgid "Fake menu item %d\n"
|
#: ../src/ui/theme-viewer.c:328
|
||||||
#~ msgstr "Falošná položka ponuky č. %d\n"
|
#, c-format
|
||||||
|
msgid "Fake menu item %d\n"
|
||||||
|
msgstr "Falošná položka ponuky č. %d\n"
|
||||||
|
|
||||||
#~ msgid "Border-only window"
|
#: ../src/ui/theme-viewer.c:363
|
||||||
#~ msgstr "Okno len s okrajom"
|
msgid "Border-only window"
|
||||||
|
msgstr "Okno len s okrajom"
|
||||||
|
|
||||||
#~ msgid "Bar"
|
#: ../src/ui/theme-viewer.c:365
|
||||||
#~ msgstr "Lišta"
|
msgid "Bar"
|
||||||
|
msgstr "Lišta"
|
||||||
|
|
||||||
#~ msgid "Normal Application Window"
|
#: ../src/ui/theme-viewer.c:382
|
||||||
#~ msgstr "Normálne aplikačné okno"
|
msgid "Normal Application Window"
|
||||||
|
msgstr "Normálne aplikačné okno"
|
||||||
|
|
||||||
#~ msgid "Dialog Box"
|
#: ../src/ui/theme-viewer.c:386
|
||||||
#~ msgstr "Dialógové okno"
|
msgid "Dialog Box"
|
||||||
|
msgstr "Dialógové okno"
|
||||||
|
|
||||||
#~ msgid "Modal Dialog Box"
|
#: ../src/ui/theme-viewer.c:390
|
||||||
#~ msgstr "Modálne dialógové okno"
|
msgid "Modal Dialog Box"
|
||||||
|
msgstr "Modálne dialógové okno"
|
||||||
|
|
||||||
#~ msgid "Utility Palette"
|
#: ../src/ui/theme-viewer.c:394
|
||||||
#~ msgstr "Paleta nástrojov"
|
msgid "Utility Palette"
|
||||||
|
msgstr "Paleta nástrojov"
|
||||||
|
|
||||||
#~ msgid "Torn-off Menu"
|
#: ../src/ui/theme-viewer.c:398
|
||||||
#~ msgstr "Vypnúť ponuku"
|
msgid "Torn-off Menu"
|
||||||
|
msgstr "Vypnúť ponuku"
|
||||||
|
|
||||||
#~ msgid "Border"
|
#: ../src/ui/theme-viewer.c:402
|
||||||
#~ msgstr "Okraj"
|
msgid "Border"
|
||||||
|
msgstr "Okraj"
|
||||||
|
|
||||||
#~ msgid "Attached Modal Dialog"
|
#: ../src/ui/theme-viewer.c:406
|
||||||
#~ msgstr "Pričlenené modálne okno"
|
msgid "Attached Modal Dialog"
|
||||||
|
msgstr "Pričlenené modálne okno"
|
||||||
|
|
||||||
#~ msgid "Button layout test %d"
|
#: ../src/ui/theme-viewer.c:737
|
||||||
#~ msgstr "Test rozloženia tlačidiel č. %d"
|
#, c-format
|
||||||
|
msgid "Button layout test %d"
|
||||||
|
msgstr "Test rozloženia tlačidiel č. %d"
|
||||||
|
|
||||||
# PK: plural forms
|
# PK: plural forms
|
||||||
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=697987
|
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=697987
|
||||||
#, fuzzy
|
#: ../src/ui/theme-viewer.c:766
|
||||||
#~ msgid "%g milliseconds to draw one window frame"
|
#, fuzzy, c-format
|
||||||
#~ msgstr "%g milisekúnd pre vykreslenie jedného rámca okna"
|
msgid "%g milliseconds to draw one window frame"
|
||||||
|
msgstr "%g milisekúnd pre vykreslenie jedného rámca okna"
|
||||||
|
|
||||||
#~ msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
|
#: ../src/ui/theme-viewer.c:811
|
||||||
#~ msgstr "Použitie: metacity-theme-viewer [NÁZOVTÉMY]\n"
|
#, c-format
|
||||||
|
msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
|
||||||
|
msgstr "Použitie: metacity-theme-viewer [NÁZOVTÉMY]\n"
|
||||||
|
|
||||||
#~ msgid "Error loading theme: %s\n"
|
#: ../src/ui/theme-viewer.c:818
|
||||||
#~ msgstr "Chyba pri načítavaní témy: %s\n"
|
#, c-format
|
||||||
|
msgid "Error loading theme: %s\n"
|
||||||
|
msgstr "Chyba pri načítavaní témy: %s\n"
|
||||||
|
|
||||||
# PK: plural forms
|
# PK: plural forms
|
||||||
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=697987
|
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=697987
|
||||||
#, fuzzy
|
#: ../src/ui/theme-viewer.c:824
|
||||||
#~ msgid "Loaded theme \"%s\" in %g seconds\n"
|
#, fuzzy, c-format
|
||||||
#~ msgstr "Téma „%s“ načítaná za %g sekúnd\n"
|
msgid "Loaded theme \"%s\" in %g seconds\n"
|
||||||
|
msgstr "Téma „%s“ načítaná za %g sekúnd\n"
|
||||||
|
|
||||||
# PK: inde titulku, aky je rozdiel
|
# PK: inde titulku, aky je rozdiel
|
||||||
#~ msgid "Normal Title Font"
|
#: ../src/ui/theme-viewer.c:869
|
||||||
#~ msgstr "Obyčajné písmo titulku"
|
msgid "Normal Title Font"
|
||||||
|
msgstr "Obyčajné písmo titulku"
|
||||||
|
|
||||||
#~ msgid "Small Title Font"
|
#: ../src/ui/theme-viewer.c:875
|
||||||
#~ msgstr "Malé písmo titulku"
|
msgid "Small Title Font"
|
||||||
|
msgstr "Malé písmo titulku"
|
||||||
|
|
||||||
#~ msgid "Large Title Font"
|
#: ../src/ui/theme-viewer.c:881
|
||||||
#~ msgstr "Veľké písmo titulku"
|
msgid "Large Title Font"
|
||||||
|
msgstr "Veľké písmo titulku"
|
||||||
|
|
||||||
#~ msgid "Button Layouts"
|
#: ../src/ui/theme-viewer.c:886
|
||||||
#~ msgstr "Rozloženia tlačidiel"
|
msgid "Button Layouts"
|
||||||
|
msgstr "Rozloženia tlačidiel"
|
||||||
|
|
||||||
#~ msgid "Benchmark"
|
#: ../src/ui/theme-viewer.c:891
|
||||||
#~ msgstr "Test rýchlosti"
|
msgid "Benchmark"
|
||||||
|
msgstr "Test rýchlosti"
|
||||||
|
|
||||||
#~ msgid "Window Title Goes Here"
|
#: ../src/ui/theme-viewer.c:947
|
||||||
#~ msgstr "Sem príde názov okna"
|
msgid "Window Title Goes Here"
|
||||||
|
msgstr "Sem príde názov okna"
|
||||||
|
|
||||||
# PK: plural forms
|
# PK: plural forms
|
||||||
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=697987
|
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=697987
|
||||||
#, fuzzy
|
#: ../src/ui/theme-viewer.c:1053
|
||||||
#~ msgid ""
|
#, fuzzy, c-format
|
||||||
#~ "Drew %d frames in %g client-side seconds (%g milliseconds per frame) and "
|
msgid ""
|
||||||
#~ "%g seconds wall clock time including X server resources (%g milliseconds "
|
"Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g "
|
||||||
#~ "per frame)\n"
|
"seconds wall clock time including X server resources (%g milliseconds per "
|
||||||
#~ msgstr ""
|
"frame)\n"
|
||||||
#~ "Vykreslených %d rámcov za %g sekúnd na strane klienta (%g milisekúnd na "
|
msgstr ""
|
||||||
#~ "rámec) a %g sekúnd celkového času vrátane zdrojov servera X (%g "
|
"Vykreslených %d rámcov za %g sekúnd na strane klienta (%g milisekúnd na "
|
||||||
#~ "milisekúnd na rámec)\n"
|
"rámec) a %g sekúnd celkového času vrátane zdrojov servera X (%g milisekúnd "
|
||||||
|
"na rámec)\n"
|
||||||
|
|
||||||
#~ msgid "position expression test returned TRUE but set error"
|
#: ../src/ui/theme-viewer.c:1273
|
||||||
#~ msgstr "test výrazu polohy vrátil TRUE, ale nastavil chybu"
|
msgid "position expression test returned TRUE but set error"
|
||||||
|
msgstr "test výrazu polohy vrátil TRUE, ale nastavil chybu"
|
||||||
|
|
||||||
#~ msgid "position expression test returned FALSE but didn't set error"
|
#: ../src/ui/theme-viewer.c:1275
|
||||||
#~ msgstr "test výrazu polohy vrátil FALSE, ale nenastavil chybu"
|
msgid "position expression test returned FALSE but didn't set error"
|
||||||
|
msgstr "test výrazu polohy vrátil FALSE, ale nenastavil chybu"
|
||||||
|
|
||||||
#~ msgid "Error was expected but none given"
|
#: ../src/ui/theme-viewer.c:1279
|
||||||
#~ msgstr "Bola očakávaná chyba, ale žiadna nenastala"
|
msgid "Error was expected but none given"
|
||||||
|
msgstr "Bola očakávaná chyba, ale žiadna nenastala"
|
||||||
|
|
||||||
#~ msgid "Error %d was expected but %d given"
|
#: ../src/ui/theme-viewer.c:1281
|
||||||
#~ msgstr "Bola očakávaná chyba %d, ale nastala %d"
|
#, c-format
|
||||||
|
msgid "Error %d was expected but %d given"
|
||||||
|
msgstr "Bola očakávaná chyba %d, ale nastala %d"
|
||||||
|
|
||||||
#~ msgid "Error not expected but one was returned: %s"
|
#: ../src/ui/theme-viewer.c:1287
|
||||||
#~ msgstr "Chyba nebola očakávaná, ale bola vrátená: %s"
|
#, c-format
|
||||||
|
msgid "Error not expected but one was returned: %s"
|
||||||
|
msgstr "Chyba nebola očakávaná, ale bola vrátená: %s"
|
||||||
|
|
||||||
#~ msgid "x value was %d, %d was expected"
|
#: ../src/ui/theme-viewer.c:1291
|
||||||
#~ msgstr "hodnota x bola %d, očakávaná bola %d"
|
#, c-format
|
||||||
|
msgid "x value was %d, %d was expected"
|
||||||
|
msgstr "hodnota x bola %d, očakávaná bola %d"
|
||||||
|
|
||||||
#~ msgid "y value was %d, %d was expected"
|
#: ../src/ui/theme-viewer.c:1294
|
||||||
#~ msgstr "hodnota y bola %d, očakávaná bola %d"
|
#, c-format
|
||||||
|
msgid "y value was %d, %d was expected"
|
||||||
|
msgstr "hodnota y bola %d, očakávaná bola %d"
|
||||||
|
|
||||||
# PK: plural forms
|
# PK: plural forms
|
||||||
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=697987
|
# JK: https://bugzilla.gnome.org/show_bug.cgi?id=697987
|
||||||
#, fuzzy
|
#: ../src/ui/theme-viewer.c:1359
|
||||||
#~ msgid ""
|
#, fuzzy, c-format
|
||||||
#~ "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
|
msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
|
||||||
#~ msgstr ""
|
msgstr ""
|
||||||
#~ "%d výrazov pre súradnice analyzovaných za %g sekúnd (priemer %g sekúnd)\n"
|
"%d výrazov pre súradnice analyzovaných za %g sekúnd (priemer %g sekúnd)\n"
|
||||||
|
|||||||
425
po/sr.po
425
po/sr.po
@@ -212,7 +212,7 @@ msgstr "Прикажите поделу на десно"
|
|||||||
|
|
||||||
#. This probably means that a non-WM compositor like xcompmgr is running;
|
#. This probably means that a non-WM compositor like xcompmgr is running;
|
||||||
#. * we have no way to get it to exit
|
#. * we have no way to get it to exit
|
||||||
#: ../src/compositor/compositor.c:589
|
#: ../src/compositor/compositor.c:507
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Another compositing manager is already running on screen %i on display \"%s"
|
"Another compositing manager is already running on screen %i on display \"%s"
|
||||||
@@ -220,11 +220,11 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Неки други композитни управник је већ покренут на приказу %i еркана „%s“."
|
"Неки други композитни управник је већ покренут на приказу %i еркана „%s“."
|
||||||
|
|
||||||
#: ../src/compositor/meta-background.c:1076
|
#: ../src/compositor/meta-background.c:1111
|
||||||
msgid "background texture could not be created from file"
|
msgid "background texture could not be created from file"
|
||||||
msgstr "склоп позадине не може бити створен из датотеке"
|
msgstr "склоп позадине не може бити створен из датотеке"
|
||||||
|
|
||||||
#: ../src/core/bell.c:322
|
#: ../src/core/bell.c:320
|
||||||
msgid "Bell event"
|
msgid "Bell event"
|
||||||
msgstr "Звонца"
|
msgstr "Звонца"
|
||||||
|
|
||||||
@@ -258,17 +258,17 @@ msgstr "_Сачекај"
|
|||||||
msgid "_Force Quit"
|
msgid "_Force Quit"
|
||||||
msgstr "_Приморај излаз"
|
msgstr "_Приморај излаз"
|
||||||
|
|
||||||
#: ../src/core/display.c:421
|
#: ../src/core/display.c:401
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Missing %s extension required for compositing"
|
msgid "Missing %s extension required for compositing"
|
||||||
msgstr "Недостаје потребан композитни додатак %s"
|
msgstr "Недостаје потребан композитни додатак %s"
|
||||||
|
|
||||||
#: ../src/core/display.c:513
|
#: ../src/core/display.c:493
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open X Window System display '%s'\n"
|
msgid "Failed to open X Window System display '%s'\n"
|
||||||
msgstr "Нисам успео да отворим екран „%s“ Икс система прозора\n"
|
msgstr "Нисам успео да отворим екран „%s“ Икс система прозора\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1136
|
#: ../src/core/keybindings.c:929
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Some other program is already using the key %s with modifiers %x as a "
|
"Some other program is already using the key %s with modifiers %x as a "
|
||||||
@@ -277,41 +277,42 @@ msgstr ""
|
|||||||
"Неки други програм већ користи тастер %s са измењивачима %x за неку "
|
"Неки други програм већ користи тастер %s са измењивачима %x за неку "
|
||||||
"функцију\n"
|
"функцију\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1333
|
#: ../src/core/keybindings.c:1129
|
||||||
#, c-format
|
#, c-format
|
||||||
|
#| msgid "\"%s\" is not a valid value for focus attribute"
|
||||||
msgid "\"%s\" is not a valid accelerator\n"
|
msgid "\"%s\" is not a valid accelerator\n"
|
||||||
msgstr "„%s“ није исправна пречица\n"
|
msgstr "„%s“ није исправна пречица\n"
|
||||||
|
|
||||||
#: ../src/core/main.c:197
|
#: ../src/core/main.c:196
|
||||||
msgid "Disable connection to session manager"
|
msgid "Disable connection to session manager"
|
||||||
msgstr "Искључује везу са управником сесије"
|
msgstr "Искључује везу са управником сесије"
|
||||||
|
|
||||||
#: ../src/core/main.c:203
|
#: ../src/core/main.c:202
|
||||||
msgid "Replace the running window manager"
|
msgid "Replace the running window manager"
|
||||||
msgstr "Мења текућег управника прозорима"
|
msgstr "Мења текућег управника прозорима"
|
||||||
|
|
||||||
#: ../src/core/main.c:209
|
#: ../src/core/main.c:208
|
||||||
msgid "Specify session management ID"
|
msgid "Specify session management ID"
|
||||||
msgstr "Наводи ИБ управника сесије"
|
msgstr "Наводи ИБ управника сесије"
|
||||||
|
|
||||||
#: ../src/core/main.c:214
|
#: ../src/core/main.c:213
|
||||||
msgid "X Display to use"
|
msgid "X Display to use"
|
||||||
msgstr "Икс екран који ће бити коришћен"
|
msgstr "Икс екран који ће бити коришћен"
|
||||||
|
|
||||||
#: ../src/core/main.c:220
|
#: ../src/core/main.c:219
|
||||||
msgid "Initialize session from savefile"
|
msgid "Initialize session from savefile"
|
||||||
msgstr "Покреће сесију из датотеке чувања"
|
msgstr "Покреће сесију из датотеке чувања"
|
||||||
|
|
||||||
#: ../src/core/main.c:226
|
#: ../src/core/main.c:225
|
||||||
msgid "Make X calls synchronous"
|
msgid "Make X calls synchronous"
|
||||||
msgstr "Чини Икс позиве усклађеним"
|
msgstr "Чини Икс позиве усклађеним"
|
||||||
|
|
||||||
#: ../src/core/main.c:534
|
#: ../src/core/main.c:494
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to scan themes directory: %s\n"
|
msgid "Failed to scan themes directory: %s\n"
|
||||||
msgstr "Нисам успео да прочитам директоријум тема: %s\n"
|
msgstr "Нисам успео да прочитам директоријум тема: %s\n"
|
||||||
|
|
||||||
#: ../src/core/main.c:550
|
#: ../src/core/main.c:510
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
|
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
|
||||||
@@ -356,7 +357,7 @@ msgstr "Исписује издање"
|
|||||||
msgid "Mutter plugin to use"
|
msgid "Mutter plugin to use"
|
||||||
msgstr "Прикључци Матера за коришћење"
|
msgstr "Прикључци Матера за коришћење"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1202
|
#: ../src/core/prefs.c:1087
|
||||||
msgid ""
|
msgid ""
|
||||||
"Workarounds for broken applications disabled. Some applications may not "
|
"Workarounds for broken applications disabled. Some applications may not "
|
||||||
"behave properly.\n"
|
"behave properly.\n"
|
||||||
@@ -364,12 +365,12 @@ msgstr ""
|
|||||||
"Решења за оштећене програме су искључена. Неке апликације се могу понашати "
|
"Решења за оштећене програме су искључена. Неке апликације се могу понашати "
|
||||||
"чудно.\n"
|
"чудно.\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1277
|
#: ../src/core/prefs.c:1162
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
||||||
msgstr "Не могу да обрадим опис „%s“ из кључа „%s“ у Гномовим подешавањима\n"
|
msgstr "Не могу да обрадим опис „%s“ из кључа „%s“ у Гномовим подешавањима\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1343
|
#: ../src/core/prefs.c:1228
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for mouse button "
|
"\"%s\" found in configuration database is not a valid value for mouse button "
|
||||||
@@ -378,24 +379,24 @@ msgstr ""
|
|||||||
"„%s“ је пронађен у бази подешавања што није исправна вредност која мења "
|
"„%s“ је пронађен у бази подешавања што није исправна вредност која мења "
|
||||||
"понашање тастера миша\n"
|
"понашање тастера миша\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1909
|
#: ../src/core/prefs.c:1780
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for keybinding "
|
"\"%s\" found in configuration database is not a valid value for keybinding "
|
||||||
"\"%s\"\n"
|
"\"%s\"\n"
|
||||||
msgstr "„%s“ из базе са подешавањима није исправна комбинација тастера „%s“\n"
|
msgstr "„%s“ из базе са подешавањима није исправна комбинација тастера „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1999
|
#: ../src/core/prefs.c:1879
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d"
|
msgid "Workspace %d"
|
||||||
msgstr "%d. радни простор"
|
msgstr "%d. радни простор"
|
||||||
|
|
||||||
#: ../src/core/screen.c:534
|
#: ../src/core/screen.c:673
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display '%s' is invalid\n"
|
msgid "Screen %d on display '%s' is invalid\n"
|
||||||
msgstr "Приказ „%d“ на екрану „%s“ није исправан\n"
|
msgstr "Приказ „%d“ на екрану „%s“ није исправан\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:550
|
#: ../src/core/screen.c:689
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
||||||
@@ -404,18 +405,18 @@ msgstr ""
|
|||||||
"Приказ „%d“ на екрану „%s“ већ има управника прозора; покушајте да користите "
|
"Приказ „%d“ на екрану „%s“ већ има управника прозора; покушајте да користите "
|
||||||
"опцију „--replace“ да замените тренутног управника прозора.\n"
|
"опцију „--replace“ да замените тренутног управника прозора.\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:577
|
#: ../src/core/screen.c:716
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
||||||
msgstr "Не могу да добијем избор управника прозора на приказу %d еркана „%s“\n"
|
msgstr "Не могу да добијем избор управника прозора на приказу %d еркана „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:655
|
#: ../src/core/screen.c:794
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
||||||
msgstr "Приказ %d на екрану „%s“ већ има управника прозора\n"
|
msgstr "Приказ %d на екрану „%s“ већ има управника прозора\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:846
|
#: ../src/core/screen.c:979
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not release screen %d on display \"%s\"\n"
|
msgid "Could not release screen %d on display \"%s\"\n"
|
||||||
msgstr "Не могу да отпустим приказ %d на екрану „%s“\n"
|
msgstr "Не могу да отпустим приказ %d на екрану „%s“\n"
|
||||||
@@ -475,43 +476,44 @@ msgstr ""
|
|||||||
"Ови прозори не подржавају могућност „сачувај тренутна подешавања“ па ћете "
|
"Ови прозори не подржавају могућност „сачувај тренутна подешавања“ па ћете "
|
||||||
"морати ручно да их поново покренете када се следећи пут пријавите."
|
"морати ручно да их поново покренете када се следећи пут пријавите."
|
||||||
|
|
||||||
#: ../src/core/util.c:84
|
#: ../src/core/util.c:80
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open debug log: %s\n"
|
msgid "Failed to open debug log: %s\n"
|
||||||
msgstr "Нисам успео да отворим дневник грешака: %s\n"
|
msgstr "Нисам успео да отворим дневник грешака: %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:94
|
#: ../src/core/util.c:90
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to fdopen() log file %s: %s\n"
|
msgid "Failed to fdopen() log file %s: %s\n"
|
||||||
msgstr "Нисам успео да „fdopen()“ датотеку дневника „%s“: %s\n"
|
msgstr "Нисам успео да „fdopen()“ датотеку дневника „%s“: %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:100
|
#: ../src/core/util.c:96
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Opened log file %s\n"
|
msgid "Opened log file %s\n"
|
||||||
msgstr "Отворена је датотека дневника „%s“\n"
|
msgstr "Отворена је датотека дневника „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:119
|
#: ../src/core/util.c:115 ../src/tools/mutter-message.c:149
|
||||||
|
#, c-format
|
||||||
msgid "Mutter was compiled without support for verbose mode\n"
|
msgid "Mutter was compiled without support for verbose mode\n"
|
||||||
msgstr "Матер је преведен без подршке за опширан режим\n"
|
msgstr "Матер је преведен без подршке за опширан режим\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:264
|
#: ../src/core/util.c:259
|
||||||
msgid "Window manager: "
|
msgid "Window manager: "
|
||||||
msgstr "Управник прозора: "
|
msgstr "Управник прозора: "
|
||||||
|
|
||||||
#: ../src/core/util.c:414
|
#: ../src/core/util.c:407
|
||||||
msgid "Bug in window manager: "
|
msgid "Bug in window manager: "
|
||||||
msgstr "Грешка у управнику прозора: "
|
msgstr "Грешка у управнику прозора: "
|
||||||
|
|
||||||
#: ../src/core/util.c:445
|
#: ../src/core/util.c:438
|
||||||
msgid "Window manager warning: "
|
msgid "Window manager warning: "
|
||||||
msgstr "Упозорење управника прозора: "
|
msgstr "Упозорење управника прозора: "
|
||||||
|
|
||||||
#: ../src/core/util.c:473
|
#: ../src/core/util.c:466
|
||||||
msgid "Window manager error: "
|
msgid "Window manager error: "
|
||||||
msgstr "Грешка управника прозора: "
|
msgstr "Грешка управника прозора: "
|
||||||
|
|
||||||
#. first time through
|
#. first time through
|
||||||
#: ../src/core/window.c:7533
|
#: ../src/core/window.c:7539
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
||||||
@@ -527,7 +529,7 @@ msgstr ""
|
|||||||
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
||||||
#. * about these apps but make them work.
|
#. * about these apps but make them work.
|
||||||
#.
|
#.
|
||||||
#: ../src/core/window.c:8257
|
#: ../src/core/window.c:8263
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
||||||
@@ -537,22 +539,22 @@ msgstr ""
|
|||||||
"али је поставио најмању величину %d x %d и највећу величину %d x %d што нема "
|
"али је поставио најмању величину %d x %d и највећу величину %d x %d што нема "
|
||||||
"много смисла.\n"
|
"много смисла.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:347
|
#: ../src/core/window-props.c:318
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
||||||
msgstr "Програм је поставио нетачан _NET_WM_PID %lu\n"
|
msgstr "Програм је поставио нетачан _NET_WM_PID %lu\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:463
|
#: ../src/core/window-props.c:434
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s (on %s)"
|
msgid "%s (on %s)"
|
||||||
msgstr "%s (на %s)"
|
msgstr "%s (на %s)"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1546
|
#: ../src/core/window-props.c:1517
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
||||||
msgstr "Неисправан прозор 0x%lx наведен као WM_TRANSIENT_FOR за %s.\n"
|
msgstr "Неисправан прозор 0x%lx наведен као WM_TRANSIENT_FOR за %s.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1557
|
#: ../src/core/window-props.c:1528
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
||||||
msgstr "WM_TRANSIENT_FOR прозор 0x%lx за %s ће направити петљу.\n"
|
msgstr "WM_TRANSIENT_FOR прозор 0x%lx за %s ће направити петљу.\n"
|
||||||
@@ -717,104 +719,109 @@ msgstr "Бира прозор из језичка искакања"
|
|||||||
msgid "Cancel tab popup"
|
msgid "Cancel tab popup"
|
||||||
msgstr "Отказивање језичка искакања"
|
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!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:67
|
#: ../src/ui/menu.c:69
|
||||||
msgid "Mi_nimize"
|
msgid "Mi_nimize"
|
||||||
msgstr "У_мањи"
|
msgstr "У_мањи"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:69
|
#: ../src/ui/menu.c:71
|
||||||
msgid "Ma_ximize"
|
msgid "Ma_ximize"
|
||||||
msgstr "У_већај"
|
msgstr "У_већај"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:71
|
#: ../src/ui/menu.c:73
|
||||||
msgid "Unma_ximize"
|
msgid "Unma_ximize"
|
||||||
msgstr "Поништи у_већање"
|
msgstr "Поништи у_већање"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:73
|
#: ../src/ui/menu.c:75
|
||||||
msgid "Roll _Up"
|
msgid "Roll _Up"
|
||||||
msgstr "_Замотај"
|
msgstr "_Замотај"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:75
|
#: ../src/ui/menu.c:77
|
||||||
msgid "_Unroll"
|
msgid "_Unroll"
|
||||||
msgstr "_Одмотај"
|
msgstr "_Одмотај"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:77
|
#: ../src/ui/menu.c:79
|
||||||
msgid "_Move"
|
msgid "_Move"
|
||||||
msgstr "_Премести"
|
msgstr "_Премести"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:79
|
#: ../src/ui/menu.c:81
|
||||||
msgid "_Resize"
|
msgid "_Resize"
|
||||||
msgstr "П_ромени величину"
|
msgstr "П_ромени величину"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:81
|
#: ../src/ui/menu.c:83
|
||||||
msgid "Move Titlebar On_screen"
|
msgid "Move Titlebar On_screen"
|
||||||
msgstr "Премести траку _наслова на екран"
|
msgstr "Премести траку _наслова на екран"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:84 ../src/ui/menu.c:86
|
#: ../src/ui/menu.c:86 ../src/ui/menu.c:88
|
||||||
msgid "Always on _Top"
|
msgid "Always on _Top"
|
||||||
msgstr "Увек _изнад осталих"
|
msgstr "Увек _изнад осталих"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:88
|
#: ../src/ui/menu.c:90
|
||||||
msgid "_Always on Visible Workspace"
|
msgid "_Always on Visible Workspace"
|
||||||
msgstr "_Увек на видљивом радном простору"
|
msgstr "_Увек на видљивом радном простору"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:90
|
#: ../src/ui/menu.c:92
|
||||||
msgid "_Only on This Workspace"
|
msgid "_Only on This Workspace"
|
||||||
msgstr "Само на _овом радном простору"
|
msgstr "Само на _овом радном простору"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:92
|
#: ../src/ui/menu.c:94
|
||||||
msgid "Move to Workspace _Left"
|
msgid "Move to Workspace _Left"
|
||||||
msgstr "Премести на радни простор ле_во"
|
msgstr "Премести на радни простор ле_во"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:94
|
#: ../src/ui/menu.c:96
|
||||||
msgid "Move to Workspace R_ight"
|
msgid "Move to Workspace R_ight"
|
||||||
msgstr "Премести на радни простор де_сно"
|
msgstr "Премести на радни простор де_сно"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:96
|
#: ../src/ui/menu.c:98
|
||||||
msgid "Move to Workspace _Up"
|
msgid "Move to Workspace _Up"
|
||||||
msgstr "Премести на радни простор го_ре"
|
msgstr "Премести на радни простор го_ре"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:98
|
#: ../src/ui/menu.c:100
|
||||||
msgid "Move to Workspace _Down"
|
msgid "Move to Workspace _Down"
|
||||||
msgstr "Премести на радни простор до_ле"
|
msgstr "Премести на радни простор до_ле"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:102
|
#: ../src/ui/menu.c:104
|
||||||
msgid "_Close"
|
msgid "_Close"
|
||||||
msgstr "_Затвори"
|
msgstr "_Затвори"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:202
|
#: ../src/ui/menu.c:204
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d%n"
|
msgid "Workspace %d%n"
|
||||||
msgstr "Радни простор %d%n"
|
msgstr "Радни простор %d%n"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:212
|
#: ../src/ui/menu.c:214
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace 1_0"
|
msgid "Workspace 1_0"
|
||||||
msgstr "1_0. радни простор"
|
msgstr "1_0. радни простор"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:214
|
#: ../src/ui/menu.c:216
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %s%d"
|
msgid "Workspace %s%d"
|
||||||
msgstr "%s%d. радни простор"
|
msgstr "%s%d. радни простор"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:384
|
#: ../src/ui/menu.c:397
|
||||||
msgid "Move to Another _Workspace"
|
msgid "Move to Another _Workspace"
|
||||||
msgstr "Премести на други _радни простор"
|
msgstr "Премести на други _радни простор"
|
||||||
|
|
||||||
@@ -916,48 +923,48 @@ msgstr "Мод5"
|
|||||||
msgid "%d x %d"
|
msgid "%d x %d"
|
||||||
msgstr "%d x %d"
|
msgstr "%d x %d"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:236
|
#: ../src/ui/theme.c:235
|
||||||
msgid "top"
|
msgid "top"
|
||||||
msgstr "горњу"
|
msgstr "горњу"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:238
|
#: ../src/ui/theme.c:237
|
||||||
msgid "bottom"
|
msgid "bottom"
|
||||||
msgstr "доњу"
|
msgstr "доњу"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:240
|
#: ../src/ui/theme.c:239
|
||||||
msgid "left"
|
msgid "left"
|
||||||
msgstr "леву"
|
msgstr "леву"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:242
|
#: ../src/ui/theme.c:241
|
||||||
msgid "right"
|
msgid "right"
|
||||||
msgstr "десну"
|
msgstr "десну"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:270
|
#: ../src/ui/theme.c:269
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "frame geometry does not specify \"%s\" dimension"
|
msgid "frame geometry does not specify \"%s\" dimension"
|
||||||
msgstr "геометрија оквира не подешава „%s“ димензију"
|
msgstr "геометрија оквира не подешава „%s“ димензију"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:289
|
#: ../src/ui/theme.c:288
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "frame geometry does not specify dimension \"%s\" for border \"%s\""
|
msgid "frame geometry does not specify dimension \"%s\" for border \"%s\""
|
||||||
msgstr "геометрија оквира не подешава „%s“ димензију за ивицу „%s“"
|
msgstr "геометрија оквира не подешава „%s“ димензију за ивицу „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:326
|
#: ../src/ui/theme.c:325
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Button aspect ratio %g is not reasonable"
|
msgid "Button aspect ratio %g is not reasonable"
|
||||||
msgstr "Однос размере дугмета %g није разуман"
|
msgstr "Однос размере дугмета %g није разуман"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:338
|
#: ../src/ui/theme.c:337
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Frame geometry does not specify size of buttons"
|
msgid "Frame geometry does not specify size of buttons"
|
||||||
msgstr "Геометрија оквира не подешава величину дугмића"
|
msgstr "Геометрија оквира не подешава величину дугмића"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1051
|
#: ../src/ui/theme.c:1050
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Gradients should have at least two colors"
|
msgid "Gradients should have at least two colors"
|
||||||
msgstr "Преливи морају имати најмање две боје"
|
msgstr "Преливи морају имати најмање две боје"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1203
|
#: ../src/ui/theme.c:1202
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK custom color specification must have color name and fallback in "
|
"GTK custom color specification must have color name and fallback in "
|
||||||
@@ -966,7 +973,7 @@ msgstr ""
|
|||||||
"Спецификација произвољне ГТК боје мора имати назив боје и пребацивање у "
|
"Спецификација произвољне ГТК боје мора имати назив боје и пребацивање у "
|
||||||
"загради, на пример gtk:custom(foo,bar); не могу да обрадим „%s“"
|
"загради, на пример gtk:custom(foo,bar); не могу да обрадим „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1219
|
#: ../src/ui/theme.c:1218
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
|
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
|
||||||
@@ -975,7 +982,7 @@ msgstr ""
|
|||||||
"Неисправан знак „%c“ параметра назив_боје у gtk:custom, иасправни су само A-"
|
"Неисправан знак „%c“ параметра назив_боје у gtk:custom, иасправни су само A-"
|
||||||
"Za-z0-9-_"
|
"Za-z0-9-_"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1233
|
#: ../src/ui/theme.c:1232
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
|
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
|
||||||
@@ -984,7 +991,7 @@ msgstr ""
|
|||||||
"Гтк:произвољни формат је „gtk:custom(назив_боје,пребацивање)“, „%s“ се не "
|
"Гтк:произвољни формат је „gtk:custom(назив_боје,пребацивање)“, „%s“ се не "
|
||||||
"уклапа у формат"
|
"уклапа у формат"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1278
|
#: ../src/ui/theme.c:1277
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
|
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
|
||||||
@@ -993,7 +1000,7 @@ msgstr ""
|
|||||||
"Спецификација ГТК боје мора имати наведено стање у загради, на пример „gtk:fg"
|
"Спецификација ГТК боје мора имати наведено стање у загради, на пример „gtk:fg"
|
||||||
"[NORMAL]“ где је „NORMAL“ стање; не могу да обрадим „%s“"
|
"[NORMAL]“ где је „NORMAL“ стање; не могу да обрадим „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1292
|
#: ../src/ui/theme.c:1291
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK color specification must have a close bracket after the state, e.g. gtk:"
|
"GTK color specification must have a close bracket after the state, e.g. gtk:"
|
||||||
@@ -1002,17 +1009,17 @@ msgstr ""
|
|||||||
"Спецификација ГТК боје мора имати наведено стање у загради, на пример „gtk:fg"
|
"Спецификација ГТК боје мора имати наведено стање у загради, на пример „gtk:fg"
|
||||||
"[NORMAL]“ где је „NORMAL“ стање; не могу да обрадим „%s“"
|
"[NORMAL]“ где је „NORMAL“ стање; не могу да обрадим „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1303
|
#: ../src/ui/theme.c:1302
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Did not understand state \"%s\" in color specification"
|
msgid "Did not understand state \"%s\" in color specification"
|
||||||
msgstr "Нисам разумео стање „%s“ у спецификацији боје"
|
msgstr "Нисам разумео стање „%s“ у спецификацији боје"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1316
|
#: ../src/ui/theme.c:1315
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Did not understand color component \"%s\" in color specification"
|
msgid "Did not understand color component \"%s\" in color specification"
|
||||||
msgstr "Нисам разумео део боје „%s“ у спецификацији боје"
|
msgstr "Нисам разумео део боје „%s“ у спецификацији боје"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1345
|
#: ../src/ui/theme.c:1344
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the "
|
"Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the "
|
||||||
@@ -1021,55 +1028,55 @@ msgstr ""
|
|||||||
"Формат смеше је „blend/bg_color/fg_color/alpha“, „%s“ се не уклапа у тражени "
|
"Формат смеше је „blend/bg_color/fg_color/alpha“, „%s“ се не уклапа у тражени "
|
||||||
"формат записа"
|
"формат записа"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1356
|
#: ../src/ui/theme.c:1355
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse alpha value \"%s\" in blended color"
|
msgid "Could not parse alpha value \"%s\" in blended color"
|
||||||
msgstr "Не могу да обрадим алфа вредност „%s“ у смешаној боји"
|
msgstr "Не могу да обрадим алфа вредност „%s“ у смешаној боји"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1366
|
#: ../src/ui/theme.c:1365
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0"
|
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:1413
|
#: ../src/ui/theme.c:1412
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format"
|
"Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format"
|
||||||
msgstr "Формат сенке је „shade/base_color/factor“, „%s“ се не уклапа у формат"
|
msgstr "Формат сенке је „shade/base_color/factor“, „%s“ се не уклапа у формат"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1424
|
#: ../src/ui/theme.c:1423
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse shade factor \"%s\" in shaded color"
|
msgid "Could not parse shade factor \"%s\" in shaded color"
|
||||||
msgstr "Не могу да обрадим фактор сенке „%s“ у осенченој боји"
|
msgstr "Не могу да обрадим фактор сенке „%s“ у осенченој боји"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1434
|
#: ../src/ui/theme.c:1433
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Shade factor \"%s\" in shaded color is negative"
|
msgid "Shade factor \"%s\" in shaded color is negative"
|
||||||
msgstr "Фактор сенке „%s“ у осенченој боји је негативан"
|
msgstr "Фактор сенке „%s“ у осенченој боји је негативан"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1463
|
#: ../src/ui/theme.c:1462
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse color \"%s\""
|
msgid "Could not parse color \"%s\""
|
||||||
msgstr "Не могу да обрадим боју „%s“"
|
msgstr "Не могу да обрадим боју „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1780
|
#: ../src/ui/theme.c:1779
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression contains character '%s' which is not allowed"
|
msgid "Coordinate expression contains character '%s' which is not allowed"
|
||||||
msgstr "Израз координата садржи знак „%s“ који није дозвољен"
|
msgstr "Израз координата садржи знак „%s“ који није дозвољен"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1807
|
#: ../src/ui/theme.c:1806
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression contains floating point number '%s' which could not be "
|
"Coordinate expression contains floating point number '%s' which could not be "
|
||||||
"parsed"
|
"parsed"
|
||||||
msgstr "Израз координата садржи децимални број „%s“ који не може бити обрађен"
|
msgstr "Израз координата садржи децимални број „%s“ који не може бити обрађен"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1821
|
#: ../src/ui/theme.c:1820
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression contains integer '%s' which could not be parsed"
|
msgid "Coordinate expression contains integer '%s' which could not be parsed"
|
||||||
msgstr "Израз координата садржи цели број „%s“ који не може бити обрађен"
|
msgstr "Израз координата садржи цели број „%s“ који не може бити обрађен"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1942
|
#: ../src/ui/theme.c:1941
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression contained unknown operator at the start of this text: "
|
"Coordinate expression contained unknown operator at the start of this text: "
|
||||||
@@ -1077,17 +1084,17 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Израз са координатама садржи непознати оператор на почетку овог текста: „%s“"
|
"Израз са координатама садржи непознати оператор на почетку овог текста: „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1999
|
#: ../src/ui/theme.c:1998
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression was empty or not understood"
|
msgid "Coordinate expression was empty or not understood"
|
||||||
msgstr "Израз са координатама је био празан или неразумљив"
|
msgstr "Израз са координатама је био празан или неразумљив"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2112 ../src/ui/theme.c:2122 ../src/ui/theme.c:2156
|
#: ../src/ui/theme.c:2111 ../src/ui/theme.c:2121 ../src/ui/theme.c:2155
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression results in division by zero"
|
msgid "Coordinate expression results in division by zero"
|
||||||
msgstr "Израз са координатама резултира у дељењу нулом"
|
msgstr "Израз са координатама резултира у дељењу нулом"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2164
|
#: ../src/ui/theme.c:2163
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression tries to use mod operator on a floating-point number"
|
"Coordinate expression tries to use mod operator on a floating-point number"
|
||||||
@@ -1095,23 +1102,23 @@ msgstr ""
|
|||||||
"Израз са координатам покушава да користи оператор остатка при дељењу за "
|
"Израз са координатам покушава да користи оператор остатка при дељењу за "
|
||||||
"децимални број"
|
"децимални број"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2220
|
#: ../src/ui/theme.c:2219
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression has an operator \"%s\" where an operand was expected"
|
"Coordinate expression has an operator \"%s\" where an operand was expected"
|
||||||
msgstr "Израз са координатама има оператор „%s“ где је очекиван операнд"
|
msgstr "Израз са координатама има оператор „%s“ где је очекиван операнд"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2229
|
#: ../src/ui/theme.c:2228
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had an operand where an operator was expected"
|
msgid "Coordinate expression had an operand where an operator was expected"
|
||||||
msgstr "Израз са координатама имаше операнд где је очекиван оператор"
|
msgstr "Израз са координатама имаше операнд где је очекиван оператор"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2237
|
#: ../src/ui/theme.c:2236
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression ended with an operator instead of an operand"
|
msgid "Coordinate expression ended with an operator instead of an operand"
|
||||||
msgstr "Израз са координарама је завршио са оператором уместо са операндом"
|
msgstr "Израз са координарама је завршио са оператором уместо са операндом"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2247
|
#: ../src/ui/theme.c:2246
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression has operator \"%c\" following operator \"%c\" with no "
|
"Coordinate expression has operator \"%c\" following operator \"%c\" with no "
|
||||||
@@ -1120,37 +1127,37 @@ msgstr ""
|
|||||||
"Израз са координатама има оператор „%c“, а затим оператор „%c“ без операнда "
|
"Израз са координатама има оператор „%c“, а затим оператор „%c“ без операнда "
|
||||||
"између"
|
"између"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2398 ../src/ui/theme.c:2443
|
#: ../src/ui/theme.c:2397 ../src/ui/theme.c:2442
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had unknown variable or constant \"%s\""
|
msgid "Coordinate expression had unknown variable or constant \"%s\""
|
||||||
msgstr "Израз са координатама има непознату променљиву или константи „%s“"
|
msgstr "Израз са координатама има непознату променљиву или константи „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2497
|
#: ../src/ui/theme.c:2496
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression parser overflowed its buffer."
|
msgid "Coordinate expression parser overflowed its buffer."
|
||||||
msgstr "Израз са координатама је био превелики за смештај и обраду."
|
msgstr "Израз са координатама је био превелики за смештај и обраду."
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2526
|
#: ../src/ui/theme.c:2525
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had a close parenthesis with no open parenthesis"
|
msgid "Coordinate expression had a close parenthesis with no open parenthesis"
|
||||||
msgstr "Израз са координатама има затворене заграде без отворених заграда"
|
msgstr "Израз са координатама има затворене заграде без отворених заграда"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2590
|
#: ../src/ui/theme.c:2589
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had an open parenthesis with no close parenthesis"
|
msgid "Coordinate expression had an open parenthesis with no close parenthesis"
|
||||||
msgstr "Израз са координатама има отворену заграду без затворене заграде"
|
msgstr "Израз са координатама има отворену заграду без затворене заграде"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2601
|
#: ../src/ui/theme.c:2600
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression doesn't seem to have any operators or operands"
|
msgid "Coordinate expression doesn't seem to have any operators or operands"
|
||||||
msgstr "Израз са координатама изгледа да нема ни један оператор или операнд"
|
msgstr "Израз са координатама изгледа да нема ни један оператор или операнд"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2814 ../src/ui/theme.c:2834 ../src/ui/theme.c:2854
|
#: ../src/ui/theme.c:2813 ../src/ui/theme.c:2833 ../src/ui/theme.c:2853
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Theme contained an expression that resulted in an error: %s\n"
|
msgid "Theme contained an expression that resulted in an error: %s\n"
|
||||||
msgstr "Тема садржи израз који резултира грешком: %s\n"
|
msgstr "Тема садржи израз који резултира грешком: %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:4500
|
#: ../src/ui/theme.c:4499
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be "
|
"<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be "
|
||||||
@@ -1159,25 +1166,25 @@ msgstr ""
|
|||||||
"<button function=„%s“ state=„%s“ draw_ops=\"whatever\"/> мора бити наведен "
|
"<button function=„%s“ state=„%s“ draw_ops=\"whatever\"/> мора бити наведен "
|
||||||
"за овај стил оквира"
|
"за овај стил оквира"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5011 ../src/ui/theme.c:5036
|
#: ../src/ui/theme.c:5010 ../src/ui/theme.c:5035
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
|
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Недостаје <frame state=„%s“ resize=„%s“ focus=„%s“ style=\"whatever\"/>"
|
"Недостаје <frame state=„%s“ resize=„%s“ focus=„%s“ style=\"whatever\"/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5082
|
#: ../src/ui/theme.c:5083
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to load theme \"%s\": %s\n"
|
msgid "Failed to load theme \"%s\": %s\n"
|
||||||
msgstr "Нисам успео да учитам тему „%s“: %s\n"
|
msgstr "Нисам успео да учитам тему „%s“: %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232
|
#: ../src/ui/theme.c:5219 ../src/ui/theme.c:5226 ../src/ui/theme.c:5233
|
||||||
#: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246
|
#: ../src/ui/theme.c:5240 ../src/ui/theme.c:5247
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "No <%s> set for theme \"%s\""
|
msgid "No <%s> set for theme \"%s\""
|
||||||
msgstr "Није дефинисан елемент <%s> за тему „%s“"
|
msgstr "Није дефинисан елемент <%s> за тему „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5254
|
#: ../src/ui/theme.c:5255
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
||||||
@@ -1186,14 +1193,14 @@ msgstr ""
|
|||||||
"Није подешен стил оквира за прозор типа „%s“ у теми „%s“. Додајте <window "
|
"Није подешен стил оквира за прозор типа „%s“ у теми „%s“. Додајте <window "
|
||||||
"type=„%s“ style_set=\"whatever\"/> елемент"
|
"type=„%s“ style_set=\"whatever\"/> елемент"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786
|
#: ../src/ui/theme.c:5662 ../src/ui/theme.c:5724 ../src/ui/theme.c:5787
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Кориснички дефинисане константе морају почети великим словом; „%s“ не почиње"
|
"Кориснички дефинисане константе морају почети великим словом; „%s“ не почиње"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794
|
#: ../src/ui/theme.c:5670 ../src/ui/theme.c:5732 ../src/ui/theme.c:5795
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Constant \"%s\" has already been defined"
|
msgid "Constant \"%s\" has already been defined"
|
||||||
msgstr "Константа „%s“ је већ дефинисана"
|
msgstr "Константа „%s“ је већ дефинисана"
|
||||||
@@ -1576,7 +1583,209 @@ msgstr "Није дозвољен текст унутар елемента <%s>"
|
|||||||
msgid "<%s> specified twice for this theme"
|
msgid "<%s> specified twice for this theme"
|
||||||
msgstr "<%s> је наведен два пута у овој теми"
|
msgstr "<%s> је наведен два пута у овој теми"
|
||||||
|
|
||||||
#: ../src/ui/theme-parser.c:4336
|
#: ../src/ui/theme-parser.c:4334
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to find a valid file for theme %s\n"
|
msgid "Failed to find a valid file for theme %s\n"
|
||||||
msgstr "Нисам успео да пронађем исправну датотеку за тему „%s“\n"
|
msgstr "Нисам успео да пронађем исправну датотеку за тему „%s“\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:99
|
||||||
|
msgid "_Windows"
|
||||||
|
msgstr "_Прозори"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:100
|
||||||
|
msgid "_Dialog"
|
||||||
|
msgstr "_Прозорче"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:101
|
||||||
|
msgid "_Modal dialog"
|
||||||
|
msgstr "_Важно прозорче"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:102
|
||||||
|
msgid "_Utility"
|
||||||
|
msgstr "_Алатка"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:103
|
||||||
|
msgid "_Splashscreen"
|
||||||
|
msgstr "_Уводни екран"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:104
|
||||||
|
msgid "_Top dock"
|
||||||
|
msgstr "_Горње припајање"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:105
|
||||||
|
msgid "_Bottom dock"
|
||||||
|
msgstr "_Доње припајање"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:106
|
||||||
|
msgid "_Left dock"
|
||||||
|
msgstr "_Лево припајање"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:107
|
||||||
|
msgid "_Right dock"
|
||||||
|
msgstr "Д_есно припајање"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:108
|
||||||
|
msgid "_All docks"
|
||||||
|
msgstr "_Сва припајања"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:109
|
||||||
|
msgid "Des_ktop"
|
||||||
|
msgstr "_Радна површ"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:115
|
||||||
|
msgid "Open another one of these windows"
|
||||||
|
msgstr "Отвори неки други од ових прозора"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:117
|
||||||
|
msgid "This is a demo button with an 'open' icon"
|
||||||
|
msgstr "Ово је пробно дугме са „отвори“ иконом"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:119
|
||||||
|
msgid "This is a demo button with a 'quit' icon"
|
||||||
|
msgstr "Ово је пробно дугме са „изађи“ иконицом"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:248
|
||||||
|
msgid "This is a sample message in a sample dialog"
|
||||||
|
msgstr "Ово је пример поруке у пробном прозорчету"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:328
|
||||||
|
#, c-format
|
||||||
|
msgid "Fake menu item %d\n"
|
||||||
|
msgstr "Лажна ставка изборника %d\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:363
|
||||||
|
msgid "Border-only window"
|
||||||
|
msgstr "Прозор само са ивицом"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:365
|
||||||
|
msgid "Bar"
|
||||||
|
msgstr "Трака"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:382
|
||||||
|
msgid "Normal Application Window"
|
||||||
|
msgstr "Обичан прозор програма"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:386
|
||||||
|
msgid "Dialog Box"
|
||||||
|
msgstr "Прозорче"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:390
|
||||||
|
msgid "Modal Dialog Box"
|
||||||
|
msgstr "Важно прозорче"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:394
|
||||||
|
msgid "Utility Palette"
|
||||||
|
msgstr "Палета алата"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:398
|
||||||
|
msgid "Torn-off Menu"
|
||||||
|
msgstr "Откинути изборник"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:402
|
||||||
|
msgid "Border"
|
||||||
|
msgstr "Ивица"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:406
|
||||||
|
msgid "Attached Modal Dialog"
|
||||||
|
msgstr "Приложено важно прозорче"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:737
|
||||||
|
#, c-format
|
||||||
|
msgid "Button layout test %d"
|
||||||
|
msgstr "Проба распореда дугмића %d"
|
||||||
|
|
||||||
|
# bug: plural-forms
|
||||||
|
#: ../src/ui/theme-viewer.c:766
|
||||||
|
#, c-format
|
||||||
|
msgid "%g milliseconds to draw one window frame"
|
||||||
|
msgstr "%g милисекунди за исцртавање оквира једног прозора"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:811
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
|
||||||
|
msgstr "Употреба: metacity-theme-viewer [НАЗИВ_ТЕМЕ]\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:818
|
||||||
|
#, c-format
|
||||||
|
msgid "Error loading theme: %s\n"
|
||||||
|
msgstr "Грешка приликом учитавања теме: %s\n"
|
||||||
|
|
||||||
|
# bug: plural-forms
|
||||||
|
#: ../src/ui/theme-viewer.c:824
|
||||||
|
#, c-format
|
||||||
|
msgid "Loaded theme \"%s\" in %g seconds\n"
|
||||||
|
msgstr "Учитана је тема „%s“ за %g секунде\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:869
|
||||||
|
msgid "Normal Title Font"
|
||||||
|
msgstr "Обичан словни лик наслова"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:875
|
||||||
|
msgid "Small Title Font"
|
||||||
|
msgstr "Мали словни лик наслова"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:881
|
||||||
|
msgid "Large Title Font"
|
||||||
|
msgstr "Велики словни лик наслова"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:886
|
||||||
|
msgid "Button Layouts"
|
||||||
|
msgstr "Распоред дугмића"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:891
|
||||||
|
msgid "Benchmark"
|
||||||
|
msgstr "Провера брзине"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:947
|
||||||
|
msgid "Window Title Goes Here"
|
||||||
|
msgstr "Овде иде наслов прозора"
|
||||||
|
|
||||||
|
# bug: plural-forms
|
||||||
|
#: ../src/ui/theme-viewer.c:1053
|
||||||
|
#, c-format
|
||||||
|
msgid ""
|
||||||
|
"Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g "
|
||||||
|
"seconds wall clock time including X server resources (%g milliseconds per "
|
||||||
|
"frame)\n"
|
||||||
|
msgstr ""
|
||||||
|
"Нацртао је %d оквира за %g клијентских секунди (%g милисекунди по оквиру) и "
|
||||||
|
"%g секунди времена на зидном часовнику укључујући и ресурсе Икс сервера (%g "
|
||||||
|
"милисекунди по оквиру)\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1273
|
||||||
|
msgid "position expression test returned TRUE but set error"
|
||||||
|
msgstr "провера израза положаја је вратила тачно, али је поставила грешку"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1275
|
||||||
|
msgid "position expression test returned FALSE but didn't set error"
|
||||||
|
msgstr "провера израза положаја је вратила нетачно, али није поставила грешку"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1279
|
||||||
|
msgid "Error was expected but none given"
|
||||||
|
msgstr "Очекивана је грешка, али није дата"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1281
|
||||||
|
#, c-format
|
||||||
|
msgid "Error %d was expected but %d given"
|
||||||
|
msgstr "Очекивана је грешка „%d“, али је дата „%d“"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1287
|
||||||
|
#, c-format
|
||||||
|
msgid "Error not expected but one was returned: %s"
|
||||||
|
msgstr "Грешка није очекивана, али је враћена једна: %s"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1291
|
||||||
|
#, c-format
|
||||||
|
msgid "x value was %d, %d was expected"
|
||||||
|
msgstr "x вредност је била „%d“, а очекивана је „%d“"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1294
|
||||||
|
#, c-format
|
||||||
|
msgid "y value was %d, %d was expected"
|
||||||
|
msgstr "y вредност је била „%d“, а очекивана је „%d“"
|
||||||
|
|
||||||
|
# bug: plural-forms
|
||||||
|
#: ../src/ui/theme-viewer.c:1359
|
||||||
|
#, c-format
|
||||||
|
msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
|
||||||
|
msgstr "%d израза координата је обрађено за %g секунде (просек %g секунде)\n"
|
||||||
|
|||||||
425
po/sr@latin.po
425
po/sr@latin.po
@@ -212,7 +212,7 @@ msgstr "Prikažite podelu na desno"
|
|||||||
|
|
||||||
#. This probably means that a non-WM compositor like xcompmgr is running;
|
#. This probably means that a non-WM compositor like xcompmgr is running;
|
||||||
#. * we have no way to get it to exit
|
#. * we have no way to get it to exit
|
||||||
#: ../src/compositor/compositor.c:589
|
#: ../src/compositor/compositor.c:507
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Another compositing manager is already running on screen %i on display \"%s"
|
"Another compositing manager is already running on screen %i on display \"%s"
|
||||||
@@ -220,11 +220,11 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Neki drugi kompozitni upravnik je već pokrenut na prikazu %i erkana „%s“."
|
"Neki drugi kompozitni upravnik je već pokrenut na prikazu %i erkana „%s“."
|
||||||
|
|
||||||
#: ../src/compositor/meta-background.c:1076
|
#: ../src/compositor/meta-background.c:1111
|
||||||
msgid "background texture could not be created from file"
|
msgid "background texture could not be created from file"
|
||||||
msgstr "sklop pozadine ne može biti stvoren iz datoteke"
|
msgstr "sklop pozadine ne može biti stvoren iz datoteke"
|
||||||
|
|
||||||
#: ../src/core/bell.c:322
|
#: ../src/core/bell.c:320
|
||||||
msgid "Bell event"
|
msgid "Bell event"
|
||||||
msgstr "Zvonca"
|
msgstr "Zvonca"
|
||||||
|
|
||||||
@@ -258,17 +258,17 @@ msgstr "_Sačekaj"
|
|||||||
msgid "_Force Quit"
|
msgid "_Force Quit"
|
||||||
msgstr "_Primoraj izlaz"
|
msgstr "_Primoraj izlaz"
|
||||||
|
|
||||||
#: ../src/core/display.c:421
|
#: ../src/core/display.c:401
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Missing %s extension required for compositing"
|
msgid "Missing %s extension required for compositing"
|
||||||
msgstr "Nedostaje potreban kompozitni dodatak %s"
|
msgstr "Nedostaje potreban kompozitni dodatak %s"
|
||||||
|
|
||||||
#: ../src/core/display.c:513
|
#: ../src/core/display.c:493
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open X Window System display '%s'\n"
|
msgid "Failed to open X Window System display '%s'\n"
|
||||||
msgstr "Nisam uspeo da otvorim ekran „%s“ Iks sistema prozora\n"
|
msgstr "Nisam uspeo da otvorim ekran „%s“ Iks sistema prozora\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1136
|
#: ../src/core/keybindings.c:929
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Some other program is already using the key %s with modifiers %x as a "
|
"Some other program is already using the key %s with modifiers %x as a "
|
||||||
@@ -277,41 +277,42 @@ msgstr ""
|
|||||||
"Neki drugi program već koristi taster %s sa izmenjivačima %x za neku "
|
"Neki drugi program već koristi taster %s sa izmenjivačima %x za neku "
|
||||||
"funkciju\n"
|
"funkciju\n"
|
||||||
|
|
||||||
#: ../src/core/keybindings.c:1333
|
#: ../src/core/keybindings.c:1129
|
||||||
#, c-format
|
#, c-format
|
||||||
|
#| msgid "\"%s\" is not a valid value for focus attribute"
|
||||||
msgid "\"%s\" is not a valid accelerator\n"
|
msgid "\"%s\" is not a valid accelerator\n"
|
||||||
msgstr "„%s“ nije ispravna prečica\n"
|
msgstr "„%s“ nije ispravna prečica\n"
|
||||||
|
|
||||||
#: ../src/core/main.c:197
|
#: ../src/core/main.c:196
|
||||||
msgid "Disable connection to session manager"
|
msgid "Disable connection to session manager"
|
||||||
msgstr "Isključuje vezu sa upravnikom sesije"
|
msgstr "Isključuje vezu sa upravnikom sesije"
|
||||||
|
|
||||||
#: ../src/core/main.c:203
|
#: ../src/core/main.c:202
|
||||||
msgid "Replace the running window manager"
|
msgid "Replace the running window manager"
|
||||||
msgstr "Menja tekućeg upravnika prozorima"
|
msgstr "Menja tekućeg upravnika prozorima"
|
||||||
|
|
||||||
#: ../src/core/main.c:209
|
#: ../src/core/main.c:208
|
||||||
msgid "Specify session management ID"
|
msgid "Specify session management ID"
|
||||||
msgstr "Navodi IB upravnika sesije"
|
msgstr "Navodi IB upravnika sesije"
|
||||||
|
|
||||||
#: ../src/core/main.c:214
|
#: ../src/core/main.c:213
|
||||||
msgid "X Display to use"
|
msgid "X Display to use"
|
||||||
msgstr "Iks ekran koji će biti korišćen"
|
msgstr "Iks ekran koji će biti korišćen"
|
||||||
|
|
||||||
#: ../src/core/main.c:220
|
#: ../src/core/main.c:219
|
||||||
msgid "Initialize session from savefile"
|
msgid "Initialize session from savefile"
|
||||||
msgstr "Pokreće sesiju iz datoteke čuvanja"
|
msgstr "Pokreće sesiju iz datoteke čuvanja"
|
||||||
|
|
||||||
#: ../src/core/main.c:226
|
#: ../src/core/main.c:225
|
||||||
msgid "Make X calls synchronous"
|
msgid "Make X calls synchronous"
|
||||||
msgstr "Čini Iks pozive usklađenim"
|
msgstr "Čini Iks pozive usklađenim"
|
||||||
|
|
||||||
#: ../src/core/main.c:534
|
#: ../src/core/main.c:494
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to scan themes directory: %s\n"
|
msgid "Failed to scan themes directory: %s\n"
|
||||||
msgstr "Nisam uspeo da pročitam direktorijum tema: %s\n"
|
msgstr "Nisam uspeo da pročitam direktorijum tema: %s\n"
|
||||||
|
|
||||||
#: ../src/core/main.c:550
|
#: ../src/core/main.c:510
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
|
"Could not find a theme! Be sure %s exists and contains the usual themes.\n"
|
||||||
@@ -356,7 +357,7 @@ msgstr "Ispisuje izdanje"
|
|||||||
msgid "Mutter plugin to use"
|
msgid "Mutter plugin to use"
|
||||||
msgstr "Priključci Matera za korišćenje"
|
msgstr "Priključci Matera za korišćenje"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1202
|
#: ../src/core/prefs.c:1087
|
||||||
msgid ""
|
msgid ""
|
||||||
"Workarounds for broken applications disabled. Some applications may not "
|
"Workarounds for broken applications disabled. Some applications may not "
|
||||||
"behave properly.\n"
|
"behave properly.\n"
|
||||||
@@ -364,12 +365,12 @@ msgstr ""
|
|||||||
"Rešenja za oštećene programe su isključena. Neke aplikacije se mogu ponašati "
|
"Rešenja za oštećene programe su isključena. Neke aplikacije se mogu ponašati "
|
||||||
"čudno.\n"
|
"čudno.\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1277
|
#: ../src/core/prefs.c:1162
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
msgid "Could not parse font description \"%s\" from GSettings key %s\n"
|
||||||
msgstr "Ne mogu da obradim opis „%s“ iz ključa „%s“ u Gnomovim podešavanjima\n"
|
msgstr "Ne mogu da obradim opis „%s“ iz ključa „%s“ u Gnomovim podešavanjima\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1343
|
#: ../src/core/prefs.c:1228
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for mouse button "
|
"\"%s\" found in configuration database is not a valid value for mouse button "
|
||||||
@@ -378,24 +379,24 @@ msgstr ""
|
|||||||
"„%s“ je pronađen u bazi podešavanja što nije ispravna vrednost koja menja "
|
"„%s“ je pronađen u bazi podešavanja što nije ispravna vrednost koja menja "
|
||||||
"ponašanje tastera miša\n"
|
"ponašanje tastera miša\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1909
|
#: ../src/core/prefs.c:1780
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"\"%s\" found in configuration database is not a valid value for keybinding "
|
"\"%s\" found in configuration database is not a valid value for keybinding "
|
||||||
"\"%s\"\n"
|
"\"%s\"\n"
|
||||||
msgstr "„%s“ iz baze sa podešavanjima nije ispravna kombinacija tastera „%s“\n"
|
msgstr "„%s“ iz baze sa podešavanjima nije ispravna kombinacija tastera „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/prefs.c:1999
|
#: ../src/core/prefs.c:1879
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d"
|
msgid "Workspace %d"
|
||||||
msgstr "%d. radni prostor"
|
msgstr "%d. radni prostor"
|
||||||
|
|
||||||
#: ../src/core/screen.c:534
|
#: ../src/core/screen.c:673
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display '%s' is invalid\n"
|
msgid "Screen %d on display '%s' is invalid\n"
|
||||||
msgstr "Prikaz „%d“ na ekranu „%s“ nije ispravan\n"
|
msgstr "Prikaz „%d“ na ekranu „%s“ nije ispravan\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:550
|
#: ../src/core/screen.c:689
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
"Screen %d on display \"%s\" already has a window manager; try using the --"
|
||||||
@@ -404,18 +405,18 @@ msgstr ""
|
|||||||
"Prikaz „%d“ na ekranu „%s“ već ima upravnika prozora; pokušajte da koristite "
|
"Prikaz „%d“ na ekranu „%s“ već ima upravnika prozora; pokušajte da koristite "
|
||||||
"opciju „--replace“ da zamenite trenutnog upravnika prozora.\n"
|
"opciju „--replace“ da zamenite trenutnog upravnika prozora.\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:577
|
#: ../src/core/screen.c:716
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
"Could not acquire window manager selection on screen %d display \"%s\"\n"
|
||||||
msgstr "Ne mogu da dobijem izbor upravnika prozora na prikazu %d erkana „%s“\n"
|
msgstr "Ne mogu da dobijem izbor upravnika prozora na prikazu %d erkana „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:655
|
#: ../src/core/screen.c:794
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
msgid "Screen %d on display \"%s\" already has a window manager\n"
|
||||||
msgstr "Prikaz %d na ekranu „%s“ već ima upravnika prozora\n"
|
msgstr "Prikaz %d na ekranu „%s“ već ima upravnika prozora\n"
|
||||||
|
|
||||||
#: ../src/core/screen.c:846
|
#: ../src/core/screen.c:979
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not release screen %d on display \"%s\"\n"
|
msgid "Could not release screen %d on display \"%s\"\n"
|
||||||
msgstr "Ne mogu da otpustim prikaz %d na ekranu „%s“\n"
|
msgstr "Ne mogu da otpustim prikaz %d na ekranu „%s“\n"
|
||||||
@@ -475,43 +476,44 @@ msgstr ""
|
|||||||
"Ovi prozori ne podržavaju mogućnost „sačuvaj trenutna podešavanja“ pa ćete "
|
"Ovi prozori ne podržavaju mogućnost „sačuvaj trenutna podešavanja“ pa ćete "
|
||||||
"morati ručno da ih ponovo pokrenete kada se sledeći put prijavite."
|
"morati ručno da ih ponovo pokrenete kada se sledeći put prijavite."
|
||||||
|
|
||||||
#: ../src/core/util.c:84
|
#: ../src/core/util.c:80
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to open debug log: %s\n"
|
msgid "Failed to open debug log: %s\n"
|
||||||
msgstr "Nisam uspeo da otvorim dnevnik grešaka: %s\n"
|
msgstr "Nisam uspeo da otvorim dnevnik grešaka: %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:94
|
#: ../src/core/util.c:90
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to fdopen() log file %s: %s\n"
|
msgid "Failed to fdopen() log file %s: %s\n"
|
||||||
msgstr "Nisam uspeo da „fdopen()“ datoteku dnevnika „%s“: %s\n"
|
msgstr "Nisam uspeo da „fdopen()“ datoteku dnevnika „%s“: %s\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:100
|
#: ../src/core/util.c:96
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Opened log file %s\n"
|
msgid "Opened log file %s\n"
|
||||||
msgstr "Otvorena je datoteka dnevnika „%s“\n"
|
msgstr "Otvorena je datoteka dnevnika „%s“\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:119
|
#: ../src/core/util.c:115 ../src/tools/mutter-message.c:149
|
||||||
|
#, c-format
|
||||||
msgid "Mutter was compiled without support for verbose mode\n"
|
msgid "Mutter was compiled without support for verbose mode\n"
|
||||||
msgstr "Mater je preveden bez podrške za opširan režim\n"
|
msgstr "Mater je preveden bez podrške za opširan režim\n"
|
||||||
|
|
||||||
#: ../src/core/util.c:264
|
#: ../src/core/util.c:259
|
||||||
msgid "Window manager: "
|
msgid "Window manager: "
|
||||||
msgstr "Upravnik prozora: "
|
msgstr "Upravnik prozora: "
|
||||||
|
|
||||||
#: ../src/core/util.c:414
|
#: ../src/core/util.c:407
|
||||||
msgid "Bug in window manager: "
|
msgid "Bug in window manager: "
|
||||||
msgstr "Greška u upravniku prozora: "
|
msgstr "Greška u upravniku prozora: "
|
||||||
|
|
||||||
#: ../src/core/util.c:445
|
#: ../src/core/util.c:438
|
||||||
msgid "Window manager warning: "
|
msgid "Window manager warning: "
|
||||||
msgstr "Upozorenje upravnika prozora: "
|
msgstr "Upozorenje upravnika prozora: "
|
||||||
|
|
||||||
#: ../src/core/util.c:473
|
#: ../src/core/util.c:466
|
||||||
msgid "Window manager error: "
|
msgid "Window manager error: "
|
||||||
msgstr "Greška upravnika prozora: "
|
msgstr "Greška upravnika prozora: "
|
||||||
|
|
||||||
#. first time through
|
#. first time through
|
||||||
#: ../src/core/window.c:7533
|
#: ../src/core/window.c:7539
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
"Window %s sets SM_CLIENT_ID on itself, instead of on the WM_CLIENT_LEADER "
|
||||||
@@ -527,7 +529,7 @@ msgstr ""
|
|||||||
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
#. * MWM but not WM_NORMAL_HINTS are basically broken. We complain
|
||||||
#. * about these apps but make them work.
|
#. * about these apps but make them work.
|
||||||
#.
|
#.
|
||||||
#: ../src/core/window.c:8257
|
#: ../src/core/window.c:8263
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
"Window %s sets an MWM hint indicating it isn't resizable, but sets min size "
|
||||||
@@ -537,22 +539,22 @@ msgstr ""
|
|||||||
"ali je postavio najmanju veličinu %d x %d i najveću veličinu %d x %d što nema "
|
"ali je postavio najmanju veličinu %d x %d i najveću veličinu %d x %d što nema "
|
||||||
"mnogo smisla.\n"
|
"mnogo smisla.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:347
|
#: ../src/core/window-props.c:318
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
msgid "Application set a bogus _NET_WM_PID %lu\n"
|
||||||
msgstr "Program je postavio netačan _NET_WM_PID %lu\n"
|
msgstr "Program je postavio netačan _NET_WM_PID %lu\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:463
|
#: ../src/core/window-props.c:434
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "%s (on %s)"
|
msgid "%s (on %s)"
|
||||||
msgstr "%s (na %s)"
|
msgstr "%s (na %s)"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1546
|
#: ../src/core/window-props.c:1517
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
msgid "Invalid WM_TRANSIENT_FOR window 0x%lx specified for %s.\n"
|
||||||
msgstr "Neispravan prozor 0x%lx naveden kao WM_TRANSIENT_FOR za %s.\n"
|
msgstr "Neispravan prozor 0x%lx naveden kao WM_TRANSIENT_FOR za %s.\n"
|
||||||
|
|
||||||
#: ../src/core/window-props.c:1557
|
#: ../src/core/window-props.c:1528
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
msgid "WM_TRANSIENT_FOR window 0x%lx for %s would create loop.\n"
|
||||||
msgstr "WM_TRANSIENT_FOR prozor 0x%lx za %s će napraviti petlju.\n"
|
msgstr "WM_TRANSIENT_FOR prozor 0x%lx za %s će napraviti petlju.\n"
|
||||||
@@ -717,104 +719,109 @@ msgstr "Bira prozor iz jezička iskakanja"
|
|||||||
msgid "Cancel tab popup"
|
msgid "Cancel tab popup"
|
||||||
msgstr "Otkazivanje jezička iskakanja"
|
msgstr "Otkazivanje jezička iskakanja"
|
||||||
|
|
||||||
|
#: ../src/tools/mutter-message.c:123
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: %s\n"
|
||||||
|
msgstr "Upotreba: %s\n"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:67
|
#: ../src/ui/menu.c:69
|
||||||
msgid "Mi_nimize"
|
msgid "Mi_nimize"
|
||||||
msgstr "U_manji"
|
msgstr "U_manji"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:69
|
#: ../src/ui/menu.c:71
|
||||||
msgid "Ma_ximize"
|
msgid "Ma_ximize"
|
||||||
msgstr "U_većaj"
|
msgstr "U_većaj"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:71
|
#: ../src/ui/menu.c:73
|
||||||
msgid "Unma_ximize"
|
msgid "Unma_ximize"
|
||||||
msgstr "Poništi u_većanje"
|
msgstr "Poništi u_većanje"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:73
|
#: ../src/ui/menu.c:75
|
||||||
msgid "Roll _Up"
|
msgid "Roll _Up"
|
||||||
msgstr "_Zamotaj"
|
msgstr "_Zamotaj"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:75
|
#: ../src/ui/menu.c:77
|
||||||
msgid "_Unroll"
|
msgid "_Unroll"
|
||||||
msgstr "_Odmotaj"
|
msgstr "_Odmotaj"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:77
|
#: ../src/ui/menu.c:79
|
||||||
msgid "_Move"
|
msgid "_Move"
|
||||||
msgstr "_Premesti"
|
msgstr "_Premesti"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:79
|
#: ../src/ui/menu.c:81
|
||||||
msgid "_Resize"
|
msgid "_Resize"
|
||||||
msgstr "P_romeni veličinu"
|
msgstr "P_romeni veličinu"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:81
|
#: ../src/ui/menu.c:83
|
||||||
msgid "Move Titlebar On_screen"
|
msgid "Move Titlebar On_screen"
|
||||||
msgstr "Premesti traku _naslova na ekran"
|
msgstr "Premesti traku _naslova na ekran"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:84 ../src/ui/menu.c:86
|
#: ../src/ui/menu.c:86 ../src/ui/menu.c:88
|
||||||
msgid "Always on _Top"
|
msgid "Always on _Top"
|
||||||
msgstr "Uvek _iznad ostalih"
|
msgstr "Uvek _iznad ostalih"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:88
|
#: ../src/ui/menu.c:90
|
||||||
msgid "_Always on Visible Workspace"
|
msgid "_Always on Visible Workspace"
|
||||||
msgstr "_Uvek na vidljivom radnom prostoru"
|
msgstr "_Uvek na vidljivom radnom prostoru"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:90
|
#: ../src/ui/menu.c:92
|
||||||
msgid "_Only on This Workspace"
|
msgid "_Only on This Workspace"
|
||||||
msgstr "Samo na _ovom radnom prostoru"
|
msgstr "Samo na _ovom radnom prostoru"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:92
|
#: ../src/ui/menu.c:94
|
||||||
msgid "Move to Workspace _Left"
|
msgid "Move to Workspace _Left"
|
||||||
msgstr "Premesti na radni prostor le_vo"
|
msgstr "Premesti na radni prostor le_vo"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:94
|
#: ../src/ui/menu.c:96
|
||||||
msgid "Move to Workspace R_ight"
|
msgid "Move to Workspace R_ight"
|
||||||
msgstr "Premesti na radni prostor de_sno"
|
msgstr "Premesti na radni prostor de_sno"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:96
|
#: ../src/ui/menu.c:98
|
||||||
msgid "Move to Workspace _Up"
|
msgid "Move to Workspace _Up"
|
||||||
msgstr "Premesti na radni prostor go_re"
|
msgstr "Premesti na radni prostor go_re"
|
||||||
|
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:98
|
#: ../src/ui/menu.c:100
|
||||||
msgid "Move to Workspace _Down"
|
msgid "Move to Workspace _Down"
|
||||||
msgstr "Premesti na radni prostor do_le"
|
msgstr "Premesti na radni prostor do_le"
|
||||||
|
|
||||||
#. separator
|
#. separator
|
||||||
#. Translators: Translate this string the same way as you do in libwnck!
|
#. Translators: Translate this string the same way as you do in libwnck!
|
||||||
#: ../src/ui/menu.c:102
|
#: ../src/ui/menu.c:104
|
||||||
msgid "_Close"
|
msgid "_Close"
|
||||||
msgstr "_Zatvori"
|
msgstr "_Zatvori"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:202
|
#: ../src/ui/menu.c:204
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %d%n"
|
msgid "Workspace %d%n"
|
||||||
msgstr "Radni prostor %d%n"
|
msgstr "Radni prostor %d%n"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:212
|
#: ../src/ui/menu.c:214
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace 1_0"
|
msgid "Workspace 1_0"
|
||||||
msgstr "1_0. radni prostor"
|
msgstr "1_0. radni prostor"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:214
|
#: ../src/ui/menu.c:216
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Workspace %s%d"
|
msgid "Workspace %s%d"
|
||||||
msgstr "%s%d. radni prostor"
|
msgstr "%s%d. radni prostor"
|
||||||
|
|
||||||
#: ../src/ui/menu.c:384
|
#: ../src/ui/menu.c:397
|
||||||
msgid "Move to Another _Workspace"
|
msgid "Move to Another _Workspace"
|
||||||
msgstr "Premesti na drugi _radni prostor"
|
msgstr "Premesti na drugi _radni prostor"
|
||||||
|
|
||||||
@@ -916,48 +923,48 @@ msgstr "Mod5"
|
|||||||
msgid "%d x %d"
|
msgid "%d x %d"
|
||||||
msgstr "%d x %d"
|
msgstr "%d x %d"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:236
|
#: ../src/ui/theme.c:235
|
||||||
msgid "top"
|
msgid "top"
|
||||||
msgstr "gornju"
|
msgstr "gornju"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:238
|
#: ../src/ui/theme.c:237
|
||||||
msgid "bottom"
|
msgid "bottom"
|
||||||
msgstr "donju"
|
msgstr "donju"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:240
|
#: ../src/ui/theme.c:239
|
||||||
msgid "left"
|
msgid "left"
|
||||||
msgstr "levu"
|
msgstr "levu"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:242
|
#: ../src/ui/theme.c:241
|
||||||
msgid "right"
|
msgid "right"
|
||||||
msgstr "desnu"
|
msgstr "desnu"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:270
|
#: ../src/ui/theme.c:269
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "frame geometry does not specify \"%s\" dimension"
|
msgid "frame geometry does not specify \"%s\" dimension"
|
||||||
msgstr "geometrija okvira ne podešava „%s“ dimenziju"
|
msgstr "geometrija okvira ne podešava „%s“ dimenziju"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:289
|
#: ../src/ui/theme.c:288
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "frame geometry does not specify dimension \"%s\" for border \"%s\""
|
msgid "frame geometry does not specify dimension \"%s\" for border \"%s\""
|
||||||
msgstr "geometrija okvira ne podešava „%s“ dimenziju za ivicu „%s“"
|
msgstr "geometrija okvira ne podešava „%s“ dimenziju za ivicu „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:326
|
#: ../src/ui/theme.c:325
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Button aspect ratio %g is not reasonable"
|
msgid "Button aspect ratio %g is not reasonable"
|
||||||
msgstr "Odnos razmere dugmeta %g nije razuman"
|
msgstr "Odnos razmere dugmeta %g nije razuman"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:338
|
#: ../src/ui/theme.c:337
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Frame geometry does not specify size of buttons"
|
msgid "Frame geometry does not specify size of buttons"
|
||||||
msgstr "Geometrija okvira ne podešava veličinu dugmića"
|
msgstr "Geometrija okvira ne podešava veličinu dugmića"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1051
|
#: ../src/ui/theme.c:1050
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Gradients should have at least two colors"
|
msgid "Gradients should have at least two colors"
|
||||||
msgstr "Prelivi moraju imati najmanje dve boje"
|
msgstr "Prelivi moraju imati najmanje dve boje"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1203
|
#: ../src/ui/theme.c:1202
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK custom color specification must have color name and fallback in "
|
"GTK custom color specification must have color name and fallback in "
|
||||||
@@ -966,7 +973,7 @@ msgstr ""
|
|||||||
"Specifikacija proizvoljne GTK boje mora imati naziv boje i prebacivanje u "
|
"Specifikacija proizvoljne GTK boje mora imati naziv boje i prebacivanje u "
|
||||||
"zagradi, na primer gtk:custom(foo,bar); ne mogu da obradim „%s“"
|
"zagradi, na primer gtk:custom(foo,bar); ne mogu da obradim „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1219
|
#: ../src/ui/theme.c:1218
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
|
"Invalid character '%c' in color_name parameter of gtk:custom, only A-Za-z0-9-"
|
||||||
@@ -975,7 +982,7 @@ msgstr ""
|
|||||||
"Neispravan znak „%c“ parametra naziv_boje u gtk:custom, iaspravni su samo A-"
|
"Neispravan znak „%c“ parametra naziv_boje u gtk:custom, iaspravni su samo A-"
|
||||||
"Za-z0-9-_"
|
"Za-z0-9-_"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1233
|
#: ../src/ui/theme.c:1232
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
|
"Gtk:custom format is \"gtk:custom(color_name,fallback)\", \"%s\" does not "
|
||||||
@@ -984,7 +991,7 @@ msgstr ""
|
|||||||
"Gtk:proizvoljni format je „gtk:custom(naziv_boje,prebacivanje)“, „%s“ se ne "
|
"Gtk:proizvoljni format je „gtk:custom(naziv_boje,prebacivanje)“, „%s“ se ne "
|
||||||
"uklapa u format"
|
"uklapa u format"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1278
|
#: ../src/ui/theme.c:1277
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
|
"GTK color specification must have the state in brackets, e.g. gtk:fg[NORMAL] "
|
||||||
@@ -993,7 +1000,7 @@ msgstr ""
|
|||||||
"Specifikacija GTK boje mora imati navedeno stanje u zagradi, na primer „gtk:fg"
|
"Specifikacija GTK boje mora imati navedeno stanje u zagradi, na primer „gtk:fg"
|
||||||
"[NORMAL]“ gde je „NORMAL“ stanje; ne mogu da obradim „%s“"
|
"[NORMAL]“ gde je „NORMAL“ stanje; ne mogu da obradim „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1292
|
#: ../src/ui/theme.c:1291
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"GTK color specification must have a close bracket after the state, e.g. gtk:"
|
"GTK color specification must have a close bracket after the state, e.g. gtk:"
|
||||||
@@ -1002,17 +1009,17 @@ msgstr ""
|
|||||||
"Specifikacija GTK boje mora imati navedeno stanje u zagradi, na primer „gtk:fg"
|
"Specifikacija GTK boje mora imati navedeno stanje u zagradi, na primer „gtk:fg"
|
||||||
"[NORMAL]“ gde je „NORMAL“ stanje; ne mogu da obradim „%s“"
|
"[NORMAL]“ gde je „NORMAL“ stanje; ne mogu da obradim „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1303
|
#: ../src/ui/theme.c:1302
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Did not understand state \"%s\" in color specification"
|
msgid "Did not understand state \"%s\" in color specification"
|
||||||
msgstr "Nisam razumeo stanje „%s“ u specifikaciji boje"
|
msgstr "Nisam razumeo stanje „%s“ u specifikaciji boje"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1316
|
#: ../src/ui/theme.c:1315
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Did not understand color component \"%s\" in color specification"
|
msgid "Did not understand color component \"%s\" in color specification"
|
||||||
msgstr "Nisam razumeo deo boje „%s“ u specifikaciji boje"
|
msgstr "Nisam razumeo deo boje „%s“ u specifikaciji boje"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1345
|
#: ../src/ui/theme.c:1344
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the "
|
"Blend format is \"blend/bg_color/fg_color/alpha\", \"%s\" does not fit the "
|
||||||
@@ -1021,55 +1028,55 @@ msgstr ""
|
|||||||
"Format smeše je „blend/bg_color/fg_color/alpha“, „%s“ se ne uklapa u traženi "
|
"Format smeše je „blend/bg_color/fg_color/alpha“, „%s“ se ne uklapa u traženi "
|
||||||
"format zapisa"
|
"format zapisa"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1356
|
#: ../src/ui/theme.c:1355
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse alpha value \"%s\" in blended color"
|
msgid "Could not parse alpha value \"%s\" in blended color"
|
||||||
msgstr "Ne mogu da obradim alfa vrednost „%s“ u smešanoj boji"
|
msgstr "Ne mogu da obradim alfa vrednost „%s“ u smešanoj boji"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1366
|
#: ../src/ui/theme.c:1365
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0"
|
msgid "Alpha value \"%s\" in blended color is not between 0.0 and 1.0"
|
||||||
msgstr "Alfa vrednost „%s“ u smešanoj boji nije između 0.0 i 1.0"
|
msgstr "Alfa vrednost „%s“ u smešanoj boji nije između 0.0 i 1.0"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1413
|
#: ../src/ui/theme.c:1412
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format"
|
"Shade format is \"shade/base_color/factor\", \"%s\" does not fit the format"
|
||||||
msgstr "Format senke je „shade/base_color/factor“, „%s“ se ne uklapa u format"
|
msgstr "Format senke je „shade/base_color/factor“, „%s“ se ne uklapa u format"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1424
|
#: ../src/ui/theme.c:1423
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse shade factor \"%s\" in shaded color"
|
msgid "Could not parse shade factor \"%s\" in shaded color"
|
||||||
msgstr "Ne mogu da obradim faktor senke „%s“ u osenčenoj boji"
|
msgstr "Ne mogu da obradim faktor senke „%s“ u osenčenoj boji"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1434
|
#: ../src/ui/theme.c:1433
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Shade factor \"%s\" in shaded color is negative"
|
msgid "Shade factor \"%s\" in shaded color is negative"
|
||||||
msgstr "Faktor senke „%s“ u osenčenoj boji je negativan"
|
msgstr "Faktor senke „%s“ u osenčenoj boji je negativan"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1463
|
#: ../src/ui/theme.c:1462
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Could not parse color \"%s\""
|
msgid "Could not parse color \"%s\""
|
||||||
msgstr "Ne mogu da obradim boju „%s“"
|
msgstr "Ne mogu da obradim boju „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1780
|
#: ../src/ui/theme.c:1779
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression contains character '%s' which is not allowed"
|
msgid "Coordinate expression contains character '%s' which is not allowed"
|
||||||
msgstr "Izraz koordinata sadrži znak „%s“ koji nije dozvoljen"
|
msgstr "Izraz koordinata sadrži znak „%s“ koji nije dozvoljen"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1807
|
#: ../src/ui/theme.c:1806
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression contains floating point number '%s' which could not be "
|
"Coordinate expression contains floating point number '%s' which could not be "
|
||||||
"parsed"
|
"parsed"
|
||||||
msgstr "Izraz koordinata sadrži decimalni broj „%s“ koji ne može biti obrađen"
|
msgstr "Izraz koordinata sadrži decimalni broj „%s“ koji ne može biti obrađen"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1821
|
#: ../src/ui/theme.c:1820
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression contains integer '%s' which could not be parsed"
|
msgid "Coordinate expression contains integer '%s' which could not be parsed"
|
||||||
msgstr "Izraz koordinata sadrži celi broj „%s“ koji ne može biti obrađen"
|
msgstr "Izraz koordinata sadrži celi broj „%s“ koji ne može biti obrađen"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1942
|
#: ../src/ui/theme.c:1941
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression contained unknown operator at the start of this text: "
|
"Coordinate expression contained unknown operator at the start of this text: "
|
||||||
@@ -1077,17 +1084,17 @@ msgid ""
|
|||||||
msgstr ""
|
msgstr ""
|
||||||
"Izraz sa koordinatama sadrži nepoznati operator na početku ovog teksta: „%s“"
|
"Izraz sa koordinatama sadrži nepoznati operator na početku ovog teksta: „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:1999
|
#: ../src/ui/theme.c:1998
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression was empty or not understood"
|
msgid "Coordinate expression was empty or not understood"
|
||||||
msgstr "Izraz sa koordinatama je bio prazan ili nerazumljiv"
|
msgstr "Izraz sa koordinatama je bio prazan ili nerazumljiv"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2112 ../src/ui/theme.c:2122 ../src/ui/theme.c:2156
|
#: ../src/ui/theme.c:2111 ../src/ui/theme.c:2121 ../src/ui/theme.c:2155
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression results in division by zero"
|
msgid "Coordinate expression results in division by zero"
|
||||||
msgstr "Izraz sa koordinatama rezultira u deljenju nulom"
|
msgstr "Izraz sa koordinatama rezultira u deljenju nulom"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2164
|
#: ../src/ui/theme.c:2163
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression tries to use mod operator on a floating-point number"
|
"Coordinate expression tries to use mod operator on a floating-point number"
|
||||||
@@ -1095,23 +1102,23 @@ msgstr ""
|
|||||||
"Izraz sa koordinatam pokušava da koristi operator ostatka pri deljenju za "
|
"Izraz sa koordinatam pokušava da koristi operator ostatka pri deljenju za "
|
||||||
"decimalni broj"
|
"decimalni broj"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2220
|
#: ../src/ui/theme.c:2219
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression has an operator \"%s\" where an operand was expected"
|
"Coordinate expression has an operator \"%s\" where an operand was expected"
|
||||||
msgstr "Izraz sa koordinatama ima operator „%s“ gde je očekivan operand"
|
msgstr "Izraz sa koordinatama ima operator „%s“ gde je očekivan operand"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2229
|
#: ../src/ui/theme.c:2228
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had an operand where an operator was expected"
|
msgid "Coordinate expression had an operand where an operator was expected"
|
||||||
msgstr "Izraz sa koordinatama imaše operand gde je očekivan operator"
|
msgstr "Izraz sa koordinatama imaše operand gde je očekivan operator"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2237
|
#: ../src/ui/theme.c:2236
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression ended with an operator instead of an operand"
|
msgid "Coordinate expression ended with an operator instead of an operand"
|
||||||
msgstr "Izraz sa koordinarama je završio sa operatorom umesto sa operandom"
|
msgstr "Izraz sa koordinarama je završio sa operatorom umesto sa operandom"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2247
|
#: ../src/ui/theme.c:2246
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Coordinate expression has operator \"%c\" following operator \"%c\" with no "
|
"Coordinate expression has operator \"%c\" following operator \"%c\" with no "
|
||||||
@@ -1120,37 +1127,37 @@ msgstr ""
|
|||||||
"Izraz sa koordinatama ima operator „%c“, a zatim operator „%c“ bez operanda "
|
"Izraz sa koordinatama ima operator „%c“, a zatim operator „%c“ bez operanda "
|
||||||
"između"
|
"između"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2398 ../src/ui/theme.c:2443
|
#: ../src/ui/theme.c:2397 ../src/ui/theme.c:2442
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had unknown variable or constant \"%s\""
|
msgid "Coordinate expression had unknown variable or constant \"%s\""
|
||||||
msgstr "Izraz sa koordinatama ima nepoznatu promenljivu ili konstanti „%s“"
|
msgstr "Izraz sa koordinatama ima nepoznatu promenljivu ili konstanti „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2497
|
#: ../src/ui/theme.c:2496
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression parser overflowed its buffer."
|
msgid "Coordinate expression parser overflowed its buffer."
|
||||||
msgstr "Izraz sa koordinatama je bio preveliki za smeštaj i obradu."
|
msgstr "Izraz sa koordinatama je bio preveliki za smeštaj i obradu."
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2526
|
#: ../src/ui/theme.c:2525
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had a close parenthesis with no open parenthesis"
|
msgid "Coordinate expression had a close parenthesis with no open parenthesis"
|
||||||
msgstr "Izraz sa koordinatama ima zatvorene zagrade bez otvorenih zagrada"
|
msgstr "Izraz sa koordinatama ima zatvorene zagrade bez otvorenih zagrada"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2590
|
#: ../src/ui/theme.c:2589
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression had an open parenthesis with no close parenthesis"
|
msgid "Coordinate expression had an open parenthesis with no close parenthesis"
|
||||||
msgstr "Izraz sa koordinatama ima otvorenu zagradu bez zatvorene zagrade"
|
msgstr "Izraz sa koordinatama ima otvorenu zagradu bez zatvorene zagrade"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2601
|
#: ../src/ui/theme.c:2600
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Coordinate expression doesn't seem to have any operators or operands"
|
msgid "Coordinate expression doesn't seem to have any operators or operands"
|
||||||
msgstr "Izraz sa koordinatama izgleda da nema ni jedan operator ili operand"
|
msgstr "Izraz sa koordinatama izgleda da nema ni jedan operator ili operand"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:2814 ../src/ui/theme.c:2834 ../src/ui/theme.c:2854
|
#: ../src/ui/theme.c:2813 ../src/ui/theme.c:2833 ../src/ui/theme.c:2853
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Theme contained an expression that resulted in an error: %s\n"
|
msgid "Theme contained an expression that resulted in an error: %s\n"
|
||||||
msgstr "Tema sadrži izraz koji rezultira greškom: %s\n"
|
msgstr "Tema sadrži izraz koji rezultira greškom: %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:4500
|
#: ../src/ui/theme.c:4499
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be "
|
"<button function=\"%s\" state=\"%s\" draw_ops=\"whatever\"/> must be "
|
||||||
@@ -1159,25 +1166,25 @@ msgstr ""
|
|||||||
"<button function=„%s“ state=„%s“ draw_ops=\"whatever\"/> mora biti naveden "
|
"<button function=„%s“ state=„%s“ draw_ops=\"whatever\"/> mora biti naveden "
|
||||||
"za ovaj stil okvira"
|
"za ovaj stil okvira"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5011 ../src/ui/theme.c:5036
|
#: ../src/ui/theme.c:5010 ../src/ui/theme.c:5035
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
|
"Missing <frame state=\"%s\" resize=\"%s\" focus=\"%s\" style=\"whatever\"/>"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Nedostaje <frame state=„%s“ resize=„%s“ focus=„%s“ style=\"whatever\"/>"
|
"Nedostaje <frame state=„%s“ resize=„%s“ focus=„%s“ style=\"whatever\"/>"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5082
|
#: ../src/ui/theme.c:5083
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to load theme \"%s\": %s\n"
|
msgid "Failed to load theme \"%s\": %s\n"
|
||||||
msgstr "Nisam uspeo da učitam temu „%s“: %s\n"
|
msgstr "Nisam uspeo da učitam temu „%s“: %s\n"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5218 ../src/ui/theme.c:5225 ../src/ui/theme.c:5232
|
#: ../src/ui/theme.c:5219 ../src/ui/theme.c:5226 ../src/ui/theme.c:5233
|
||||||
#: ../src/ui/theme.c:5239 ../src/ui/theme.c:5246
|
#: ../src/ui/theme.c:5240 ../src/ui/theme.c:5247
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "No <%s> set for theme \"%s\""
|
msgid "No <%s> set for theme \"%s\""
|
||||||
msgstr "Nije definisan element <%s> za temu „%s“"
|
msgstr "Nije definisan element <%s> za temu „%s“"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5254
|
#: ../src/ui/theme.c:5255
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
"No frame style set for window type \"%s\" in theme \"%s\", add a <window "
|
||||||
@@ -1186,14 +1193,14 @@ msgstr ""
|
|||||||
"Nije podešen stil okvira za prozor tipa „%s“ u temi „%s“. Dodajte <window "
|
"Nije podešen stil okvira za prozor tipa „%s“ u temi „%s“. Dodajte <window "
|
||||||
"type=„%s“ style_set=\"whatever\"/> element"
|
"type=„%s“ style_set=\"whatever\"/> element"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5661 ../src/ui/theme.c:5723 ../src/ui/theme.c:5786
|
#: ../src/ui/theme.c:5662 ../src/ui/theme.c:5724 ../src/ui/theme.c:5787
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid ""
|
msgid ""
|
||||||
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
"User-defined constants must begin with a capital letter; \"%s\" does not"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Korisnički definisane konstante moraju početi velikim slovom; „%s“ ne počinje"
|
"Korisnički definisane konstante moraju početi velikim slovom; „%s“ ne počinje"
|
||||||
|
|
||||||
#: ../src/ui/theme.c:5669 ../src/ui/theme.c:5731 ../src/ui/theme.c:5794
|
#: ../src/ui/theme.c:5670 ../src/ui/theme.c:5732 ../src/ui/theme.c:5795
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Constant \"%s\" has already been defined"
|
msgid "Constant \"%s\" has already been defined"
|
||||||
msgstr "Konstanta „%s“ je već definisana"
|
msgstr "Konstanta „%s“ je već definisana"
|
||||||
@@ -1576,7 +1583,209 @@ msgstr "Nije dozvoljen tekst unutar elementa <%s>"
|
|||||||
msgid "<%s> specified twice for this theme"
|
msgid "<%s> specified twice for this theme"
|
||||||
msgstr "<%s> je naveden dva puta u ovoj temi"
|
msgstr "<%s> je naveden dva puta u ovoj temi"
|
||||||
|
|
||||||
#: ../src/ui/theme-parser.c:4336
|
#: ../src/ui/theme-parser.c:4334
|
||||||
#, c-format
|
#, c-format
|
||||||
msgid "Failed to find a valid file for theme %s\n"
|
msgid "Failed to find a valid file for theme %s\n"
|
||||||
msgstr "Nisam uspeo da pronađem ispravnu datoteku za temu „%s“\n"
|
msgstr "Nisam uspeo da pronađem ispravnu datoteku za temu „%s“\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:99
|
||||||
|
msgid "_Windows"
|
||||||
|
msgstr "_Prozori"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:100
|
||||||
|
msgid "_Dialog"
|
||||||
|
msgstr "_Prozorče"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:101
|
||||||
|
msgid "_Modal dialog"
|
||||||
|
msgstr "_Važno prozorče"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:102
|
||||||
|
msgid "_Utility"
|
||||||
|
msgstr "_Alatka"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:103
|
||||||
|
msgid "_Splashscreen"
|
||||||
|
msgstr "_Uvodni ekran"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:104
|
||||||
|
msgid "_Top dock"
|
||||||
|
msgstr "_Gornje pripajanje"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:105
|
||||||
|
msgid "_Bottom dock"
|
||||||
|
msgstr "_Donje pripajanje"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:106
|
||||||
|
msgid "_Left dock"
|
||||||
|
msgstr "_Levo pripajanje"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:107
|
||||||
|
msgid "_Right dock"
|
||||||
|
msgstr "D_esno pripajanje"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:108
|
||||||
|
msgid "_All docks"
|
||||||
|
msgstr "_Sva pripajanja"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:109
|
||||||
|
msgid "Des_ktop"
|
||||||
|
msgstr "_Radna površ"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:115
|
||||||
|
msgid "Open another one of these windows"
|
||||||
|
msgstr "Otvori neki drugi od ovih prozora"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:117
|
||||||
|
msgid "This is a demo button with an 'open' icon"
|
||||||
|
msgstr "Ovo je probno dugme sa „otvori“ ikonom"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:119
|
||||||
|
msgid "This is a demo button with a 'quit' icon"
|
||||||
|
msgstr "Ovo je probno dugme sa „izađi“ ikonicom"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:248
|
||||||
|
msgid "This is a sample message in a sample dialog"
|
||||||
|
msgstr "Ovo je primer poruke u probnom prozorčetu"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:328
|
||||||
|
#, c-format
|
||||||
|
msgid "Fake menu item %d\n"
|
||||||
|
msgstr "Lažna stavka izbornika %d\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:363
|
||||||
|
msgid "Border-only window"
|
||||||
|
msgstr "Prozor samo sa ivicom"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:365
|
||||||
|
msgid "Bar"
|
||||||
|
msgstr "Traka"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:382
|
||||||
|
msgid "Normal Application Window"
|
||||||
|
msgstr "Običan prozor programa"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:386
|
||||||
|
msgid "Dialog Box"
|
||||||
|
msgstr "Prozorče"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:390
|
||||||
|
msgid "Modal Dialog Box"
|
||||||
|
msgstr "Važno prozorče"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:394
|
||||||
|
msgid "Utility Palette"
|
||||||
|
msgstr "Paleta alata"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:398
|
||||||
|
msgid "Torn-off Menu"
|
||||||
|
msgstr "Otkinuti izbornik"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:402
|
||||||
|
msgid "Border"
|
||||||
|
msgstr "Ivica"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:406
|
||||||
|
msgid "Attached Modal Dialog"
|
||||||
|
msgstr "Priloženo važno prozorče"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:737
|
||||||
|
#, c-format
|
||||||
|
msgid "Button layout test %d"
|
||||||
|
msgstr "Proba rasporeda dugmića %d"
|
||||||
|
|
||||||
|
# bug: plural-forms
|
||||||
|
#: ../src/ui/theme-viewer.c:766
|
||||||
|
#, c-format
|
||||||
|
msgid "%g milliseconds to draw one window frame"
|
||||||
|
msgstr "%g milisekundi za iscrtavanje okvira jednog prozora"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:811
|
||||||
|
#, c-format
|
||||||
|
msgid "Usage: metacity-theme-viewer [THEMENAME]\n"
|
||||||
|
msgstr "Upotreba: metacity-theme-viewer [NAZIV_TEME]\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:818
|
||||||
|
#, c-format
|
||||||
|
msgid "Error loading theme: %s\n"
|
||||||
|
msgstr "Greška prilikom učitavanja teme: %s\n"
|
||||||
|
|
||||||
|
# bug: plural-forms
|
||||||
|
#: ../src/ui/theme-viewer.c:824
|
||||||
|
#, c-format
|
||||||
|
msgid "Loaded theme \"%s\" in %g seconds\n"
|
||||||
|
msgstr "Učitana je tema „%s“ za %g sekunde\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:869
|
||||||
|
msgid "Normal Title Font"
|
||||||
|
msgstr "Običan slovni lik naslova"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:875
|
||||||
|
msgid "Small Title Font"
|
||||||
|
msgstr "Mali slovni lik naslova"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:881
|
||||||
|
msgid "Large Title Font"
|
||||||
|
msgstr "Veliki slovni lik naslova"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:886
|
||||||
|
msgid "Button Layouts"
|
||||||
|
msgstr "Raspored dugmića"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:891
|
||||||
|
msgid "Benchmark"
|
||||||
|
msgstr "Provera brzine"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:947
|
||||||
|
msgid "Window Title Goes Here"
|
||||||
|
msgstr "Ovde ide naslov prozora"
|
||||||
|
|
||||||
|
# bug: plural-forms
|
||||||
|
#: ../src/ui/theme-viewer.c:1053
|
||||||
|
#, c-format
|
||||||
|
msgid ""
|
||||||
|
"Drew %d frames in %g client-side seconds (%g milliseconds per frame) and %g "
|
||||||
|
"seconds wall clock time including X server resources (%g milliseconds per "
|
||||||
|
"frame)\n"
|
||||||
|
msgstr ""
|
||||||
|
"Nacrtao je %d okvira za %g klijentskih sekundi (%g milisekundi po okviru) i "
|
||||||
|
"%g sekundi vremena na zidnom časovniku uključujući i resurse Iks servera (%g "
|
||||||
|
"milisekundi po okviru)\n"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1273
|
||||||
|
msgid "position expression test returned TRUE but set error"
|
||||||
|
msgstr "provera izraza položaja je vratila tačno, ali je postavila grešku"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1275
|
||||||
|
msgid "position expression test returned FALSE but didn't set error"
|
||||||
|
msgstr "provera izraza položaja je vratila netačno, ali nije postavila grešku"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1279
|
||||||
|
msgid "Error was expected but none given"
|
||||||
|
msgstr "Očekivana je greška, ali nije data"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1281
|
||||||
|
#, c-format
|
||||||
|
msgid "Error %d was expected but %d given"
|
||||||
|
msgstr "Očekivana je greška „%d“, ali je data „%d“"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1287
|
||||||
|
#, c-format
|
||||||
|
msgid "Error not expected but one was returned: %s"
|
||||||
|
msgstr "Greška nije očekivana, ali je vraćena jedna: %s"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1291
|
||||||
|
#, c-format
|
||||||
|
msgid "x value was %d, %d was expected"
|
||||||
|
msgstr "x vrednost je bila „%d“, a očekivana je „%d“"
|
||||||
|
|
||||||
|
#: ../src/ui/theme-viewer.c:1294
|
||||||
|
#, c-format
|
||||||
|
msgid "y value was %d, %d was expected"
|
||||||
|
msgstr "y vrednost je bila „%d“, a očekivana je „%d“"
|
||||||
|
|
||||||
|
# bug: plural-forms
|
||||||
|
#: ../src/ui/theme-viewer.c:1359
|
||||||
|
#, c-format
|
||||||
|
msgid "%d coordinate expressions parsed in %g seconds (%g seconds average)\n"
|
||||||
|
msgstr "%d izraza koordinata je obrađeno za %g sekunde (prosek %g sekunde)\n"
|
||||||
|
|||||||
1135
po/zh_CN.po
1135
po/zh_CN.po
File diff suppressed because it is too large
Load Diff
@@ -29,6 +29,18 @@
|
|||||||
<KeyListEntry name="move-to-workspace-down"
|
<KeyListEntry name="move-to-workspace-down"
|
||||||
_description="Move window one 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"
|
<KeyListEntry name="switch-applications"
|
||||||
_description="Switch applications"/>
|
_description="Switch applications"/>
|
||||||
|
|
||||||
|
|||||||
234
src/Makefile.am
234
src/Makefile.am
@@ -1,16 +1,19 @@
|
|||||||
# Flag build for parallelism; see https://savannah.gnu.org/patch/?6905
|
# Flag build for parallelism; see https://savannah.gnu.org/patch/?6905
|
||||||
.AUTOPARALLEL:
|
.AUTOPARALLEL:
|
||||||
|
|
||||||
lib_LTLIBRARIES = libmutter.la
|
lib_LTLIBRARIES = libmutter-wayland.la
|
||||||
|
|
||||||
SUBDIRS=compositor/plugins
|
SUBDIRS=compositor/plugins
|
||||||
|
|
||||||
INCLUDES= \
|
INCLUDES= \
|
||||||
|
-DCLUTTER_ENABLE_COMPOSITOR_API \
|
||||||
-DCLUTTER_ENABLE_EXPERIMENTAL_API \
|
-DCLUTTER_ENABLE_EXPERIMENTAL_API \
|
||||||
-DCOGL_ENABLE_EXPERIMENTAL_API \
|
-DCOGL_ENABLE_EXPERIMENTAL_API \
|
||||||
-DCOGL_ENABLE_EXPERIMENTAL_2_0_API \
|
-DCOGL_ENABLE_EXPERIMENTAL_2_0_API \
|
||||||
$(MUTTER_CFLAGS) \
|
$(MUTTER_CFLAGS) \
|
||||||
|
-I$(top_builddir) \
|
||||||
-I$(srcdir) \
|
-I$(srcdir) \
|
||||||
|
-I$(srcdir)/backends \
|
||||||
-I$(srcdir)/core \
|
-I$(srcdir)/core \
|
||||||
-I$(srcdir)/ui \
|
-I$(srcdir)/ui \
|
||||||
-I$(srcdir)/compositor \
|
-I$(srcdir)/compositor \
|
||||||
@@ -27,17 +30,55 @@ INCLUDES= \
|
|||||||
-DMUTTER_PLUGIN_API_VERSION=$(MUTTER_PLUGIN_API_VERSION) \
|
-DMUTTER_PLUGIN_API_VERSION=$(MUTTER_PLUGIN_API_VERSION) \
|
||||||
-DMUTTER_PKGLIBDIR=\"$(pkglibdir)\" \
|
-DMUTTER_PKGLIBDIR=\"$(pkglibdir)\" \
|
||||||
-DMUTTER_PLUGIN_DIR=\"@MUTTER_PLUGIN_DIR@\" \
|
-DMUTTER_PLUGIN_DIR=\"@MUTTER_PLUGIN_DIR@\" \
|
||||||
-DGETTEXT_PACKAGE=\"$(GETTEXT_PACKAGE)\"
|
-DGETTEXT_PACKAGE=\"$(GETTEXT_PACKAGE)\" \
|
||||||
|
-DXWAYLAND_PATH='"@XWAYLAND_PATH@"'
|
||||||
|
|
||||||
mutter_built_sources = \
|
mutter_built_sources = \
|
||||||
$(dbus_idle_built_sources) \
|
$(dbus_idle_built_sources) \
|
||||||
$(dbus_xrandr_built_sources) \
|
$(dbus_display_config_built_sources) \
|
||||||
mutter-enum-types.h \
|
mutter-enum-types.h \
|
||||||
mutter-enum-types.c
|
mutter-enum-types.c \
|
||||||
|
gtk-shell-protocol.c \
|
||||||
|
gtk-shell-server-protocol.h \
|
||||||
|
xdg-shell-protocol.c \
|
||||||
|
xdg-shell-server-protocol.h
|
||||||
|
|
||||||
libmutter_la_SOURCES = \
|
wayland_protocols = \
|
||||||
core/async-getprop.c \
|
wayland/protocol/gtk-shell.xml \
|
||||||
core/async-getprop.h \
|
wayland/protocol/xdg-shell.xml
|
||||||
|
|
||||||
|
libmutter_wayland_la_SOURCES = \
|
||||||
|
backends/meta-backend.c \
|
||||||
|
backends/meta-backend.h \
|
||||||
|
backends/meta-cursor.c \
|
||||||
|
backends/meta-cursor.h \
|
||||||
|
backends/meta-cursor-private.h \
|
||||||
|
backends/meta-cursor-tracker.c \
|
||||||
|
backends/meta-cursor-tracker-private.h \
|
||||||
|
backends/meta-idle-monitor.c \
|
||||||
|
backends/meta-idle-monitor-private.h \
|
||||||
|
backends/meta-idle-monitor-dbus.c \
|
||||||
|
backends/meta-idle-monitor-dbus.h \
|
||||||
|
backends/meta-monitor-config.c \
|
||||||
|
backends/meta-monitor-config.h \
|
||||||
|
backends/meta-monitor-manager.c \
|
||||||
|
backends/meta-monitor-manager.h \
|
||||||
|
backends/meta-monitor-manager-dummy.c \
|
||||||
|
backends/meta-monitor-manager-dummy.h \
|
||||||
|
backends/edid-parse.c \
|
||||||
|
backends/edid.h \
|
||||||
|
backends/native/meta-idle-monitor-native.c \
|
||||||
|
backends/native/meta-idle-monitor-native.h \
|
||||||
|
backends/native/meta-monitor-manager-kms.c \
|
||||||
|
backends/native/meta-monitor-manager-kms.h \
|
||||||
|
backends/native/meta-weston-launch.c \
|
||||||
|
backends/native/meta-weston-launch.h \
|
||||||
|
backends/x11/meta-idle-monitor-xsync.c \
|
||||||
|
backends/x11/meta-idle-monitor-xsync.h \
|
||||||
|
backends/x11/meta-monitor-manager-xrandr.c \
|
||||||
|
backends/x11/meta-monitor-manager-xrandr.h \
|
||||||
|
backends/x11/meta-xrandr-shared.h \
|
||||||
|
core/above-tab-keycode.c \
|
||||||
core/barrier.c \
|
core/barrier.c \
|
||||||
meta/barrier.h \
|
meta/barrier.h \
|
||||||
core/bell.c \
|
core/bell.c \
|
||||||
@@ -55,7 +96,8 @@ libmutter_la_SOURCES = \
|
|||||||
compositor/meta-background-actor.c \
|
compositor/meta-background-actor.c \
|
||||||
compositor/meta-background-actor-private.h \
|
compositor/meta-background-actor-private.h \
|
||||||
compositor/meta-background-group.c \
|
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.c \
|
||||||
compositor/meta-module.h \
|
compositor/meta-module.h \
|
||||||
compositor/meta-plugin.c \
|
compositor/meta-plugin.c \
|
||||||
@@ -64,6 +106,13 @@ libmutter_la_SOURCES = \
|
|||||||
compositor/meta-shadow-factory.c \
|
compositor/meta-shadow-factory.c \
|
||||||
compositor/meta-shadow-factory-private.h \
|
compositor/meta-shadow-factory-private.h \
|
||||||
compositor/meta-shaped-texture.c \
|
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.c \
|
||||||
compositor/meta-texture-rectangle.h \
|
compositor/meta-texture-rectangle.h \
|
||||||
compositor/meta-texture-tower.c \
|
compositor/meta-texture-tower.c \
|
||||||
@@ -84,7 +133,6 @@ libmutter_la_SOURCES = \
|
|||||||
meta/meta-shadow-factory.h \
|
meta/meta-shadow-factory.h \
|
||||||
meta/meta-window-actor.h \
|
meta/meta-window-actor.h \
|
||||||
meta/compositor-mutter.h \
|
meta/compositor-mutter.h \
|
||||||
core/above-tab-keycode.c \
|
|
||||||
core/constraints.c \
|
core/constraints.c \
|
||||||
core/constraints.h \
|
core/constraints.h \
|
||||||
core/core.c \
|
core/core.c \
|
||||||
@@ -92,38 +140,19 @@ libmutter_la_SOURCES = \
|
|||||||
core/display.c \
|
core/display.c \
|
||||||
core/display-private.h \
|
core/display-private.h \
|
||||||
meta/display.h \
|
meta/display.h \
|
||||||
ui/draw-workspace.c \
|
|
||||||
ui/draw-workspace.h \
|
|
||||||
core/edge-resistance.c \
|
core/edge-resistance.c \
|
||||||
core/edge-resistance.h \
|
core/edge-resistance.h \
|
||||||
core/edid-parse.c \
|
core/events.c \
|
||||||
core/edid.h \
|
core/events.h \
|
||||||
core/errors.c \
|
core/errors.c \
|
||||||
meta/errors.h \
|
meta/errors.h \
|
||||||
core/frame.c \
|
core/frame.c \
|
||||||
core/frame.h \
|
core/frame.h \
|
||||||
ui/gradient.c \
|
ui/gradient.c \
|
||||||
meta/gradient.h \
|
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.c \
|
||||||
core/keybindings-private.h \
|
core/keybindings-private.h \
|
||||||
core/main.c \
|
core/main.c \
|
||||||
core/meta-cursor-tracker.c \
|
|
||||||
core/meta-cursor-tracker-private.h \
|
|
||||||
core/meta-idle-monitor.c \
|
|
||||||
core/meta-idle-monitor-private.h \
|
|
||||||
core/meta-xrandr-shared.h \
|
|
||||||
core/monitor.c \
|
|
||||||
core/monitor-config.c \
|
|
||||||
core/monitor-private.h \
|
|
||||||
core/monitor-xrandr.c \
|
|
||||||
core/mutter-Xatomtype.h \
|
|
||||||
core/place.c \
|
core/place.c \
|
||||||
core/place.h \
|
core/place.h \
|
||||||
core/prefs.c \
|
core/prefs.c \
|
||||||
@@ -132,23 +161,18 @@ libmutter_la_SOURCES = \
|
|||||||
core/screen-private.h \
|
core/screen-private.h \
|
||||||
meta/screen.h \
|
meta/screen.h \
|
||||||
meta/types.h \
|
meta/types.h \
|
||||||
core/session.c \
|
|
||||||
core/session.h \
|
|
||||||
core/stack.c \
|
core/stack.c \
|
||||||
core/stack.h \
|
core/stack.h \
|
||||||
core/stack-tracker.c \
|
core/stack-tracker.c \
|
||||||
core/stack-tracker.h \
|
core/stack-tracker.h \
|
||||||
core/util.c \
|
core/util.c \
|
||||||
meta/util.h \
|
meta/util.h \
|
||||||
core/window-props.c \
|
core/util-private.h \
|
||||||
core/window-props.h \
|
|
||||||
core/window.c \
|
core/window.c \
|
||||||
core/window-private.h \
|
core/window-private.h \
|
||||||
meta/window.h \
|
meta/window.h \
|
||||||
core/workspace.c \
|
core/workspace.c \
|
||||||
core/workspace-private.h \
|
core/workspace-private.h \
|
||||||
core/xprops.c \
|
|
||||||
core/xprops.h \
|
|
||||||
meta/common.h \
|
meta/common.h \
|
||||||
core/core.h \
|
core/core.h \
|
||||||
ui/ui.h \
|
ui/ui.h \
|
||||||
@@ -160,19 +184,58 @@ libmutter_la_SOURCES = \
|
|||||||
ui/metaaccellabel.h \
|
ui/metaaccellabel.h \
|
||||||
ui/resizepopup.c \
|
ui/resizepopup.c \
|
||||||
ui/resizepopup.h \
|
ui/resizepopup.h \
|
||||||
ui/tabpopup.c \
|
|
||||||
ui/tabpopup.h \
|
|
||||||
ui/tile-preview.c \
|
|
||||||
ui/tile-preview.h \
|
|
||||||
ui/theme-parser.c \
|
ui/theme-parser.c \
|
||||||
ui/theme.c \
|
ui/theme.c \
|
||||||
meta/theme.h \
|
meta/theme.h \
|
||||||
ui/theme-private.h \
|
ui/theme-private.h \
|
||||||
ui/ui.c \
|
ui/ui.c \
|
||||||
|
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 \
|
||||||
|
x11/mutter-Xatomtype.h \
|
||||||
|
wayland/meta-wayland.c \
|
||||||
|
wayland/meta-wayland.h \
|
||||||
|
wayland/meta-wayland-private.h \
|
||||||
|
wayland/meta-xwayland.c \
|
||||||
|
wayland/meta-xwayland.h \
|
||||||
|
wayland/meta-xwayland-private.h \
|
||||||
|
wayland/meta-wayland-data-device.c \
|
||||||
|
wayland/meta-wayland-data-device.h \
|
||||||
|
wayland/meta-wayland-keyboard.c \
|
||||||
|
wayland/meta-wayland-keyboard.h \
|
||||||
|
wayland/meta-wayland-pointer.c \
|
||||||
|
wayland/meta-wayland-pointer.h \
|
||||||
|
wayland/meta-wayland-seat.c \
|
||||||
|
wayland/meta-wayland-seat.h \
|
||||||
|
wayland/meta-wayland-stage.h \
|
||||||
|
wayland/meta-wayland-stage.c \
|
||||||
|
wayland/meta-wayland-surface.c \
|
||||||
|
wayland/meta-wayland-surface.h \
|
||||||
|
wayland/meta-wayland-types.h \
|
||||||
|
wayland/meta-wayland-versions.h \
|
||||||
|
wayland/window-wayland.c \
|
||||||
|
wayland/window-wayland.h
|
||||||
|
|
||||||
|
nodist_libmutter_wayland_la_SOURCES = \
|
||||||
$(mutter_built_sources)
|
$(mutter_built_sources)
|
||||||
|
|
||||||
libmutter_la_LDFLAGS = -no-undefined
|
libmutter_wayland_la_LDFLAGS = -no-undefined
|
||||||
libmutter_la_LIBADD = $(MUTTER_LIBS)
|
libmutter_wayland_la_LIBADD = $(MUTTER_LIBS)
|
||||||
|
|
||||||
# Headers installed for plugins; introspected information will
|
# Headers installed for plugins; introspected information will
|
||||||
# be extracted into Mutter-<version>.gir
|
# be extracted into Mutter-<version>.gir
|
||||||
@@ -210,16 +273,29 @@ libmutterinclude_base_headers = \
|
|||||||
libmutterinclude_extra_headers = \
|
libmutterinclude_extra_headers = \
|
||||||
meta/atomnames.h
|
meta/atomnames.h
|
||||||
|
|
||||||
libmutterincludedir = $(includedir)/mutter/meta
|
libmutterincludedir = $(includedir)/mutter-wayland/meta
|
||||||
|
|
||||||
libmutterinclude_HEADERS = \
|
libmutterinclude_HEADERS = \
|
||||||
$(libmutterinclude_base_headers) \
|
$(libmutterinclude_base_headers) \
|
||||||
$(libmutterinclude_extra_headers)
|
$(libmutterinclude_extra_headers)
|
||||||
|
|
||||||
bin_PROGRAMS=mutter
|
bin_PROGRAMS=mutter-wayland
|
||||||
|
|
||||||
mutter_SOURCES = core/mutter.c
|
mutter_wayland_SOURCES = core/mutter.c
|
||||||
mutter_LDADD = $(MUTTER_LIBS) libmutter.la
|
mutter_wayland_LDADD = $(MUTTER_LIBS) libmutter-wayland.la
|
||||||
|
|
||||||
|
bin_PROGRAMS+=mutter-launch
|
||||||
|
|
||||||
|
mutter_launch_SOURCES = \
|
||||||
|
backends/native/weston-launch.c \
|
||||||
|
backends/native/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
|
if HAVE_INTROSPECTION
|
||||||
include $(INTROSPECTION_MAKEFILE)
|
include $(INTROSPECTION_MAKEFILE)
|
||||||
@@ -241,41 +317,36 @@ typelib_DATA = Meta-$(api_version).typelib
|
|||||||
|
|
||||||
INTROSPECTION_GIRS = Meta-$(api_version).gir
|
INTROSPECTION_GIRS = Meta-$(api_version).gir
|
||||||
|
|
||||||
Meta-$(api_version).gir: libmutter.la
|
Meta-$(api_version).gir: libmutter-wayland.la
|
||||||
@META_GIR@_INCLUDES = GObject-2.0 GDesktopEnums-3.0 Gdk-3.0 Gtk-3.0 Clutter-1.0 xlib-2.0 xfixes-4.0 Cogl-1.0
|
@META_GIR@_INCLUDES = GObject-2.0 GDesktopEnums-3.0 Gdk-3.0 Gtk-3.0 Clutter-1.0 xlib-2.0 xfixes-4.0 Cogl-1.0
|
||||||
@META_GIR@_EXPORT_PACKAGES = libmutter
|
@META_GIR@_EXPORT_PACKAGES = libmutter-wayland
|
||||||
@META_GIR@_CFLAGS = $(INCLUDES)
|
@META_GIR@_CFLAGS = $(INCLUDES)
|
||||||
@META_GIR@_LIBS = libmutter.la
|
@META_GIR@_LIBS = libmutter-wayland.la
|
||||||
@META_GIR@_FILES = \
|
@META_GIR@_FILES = \
|
||||||
mutter-enum-types.h \
|
mutter-enum-types.h \
|
||||||
$(libmutterinclude_base_headers) \
|
$(libmutterinclude_base_headers) \
|
||||||
$(filter %.c,$(libmutter_la_SOURCES))
|
$(filter %.c,$(libmutter_wayland_la_SOURCES) $(nodist_libmutter_wayland_la_SOURCES))
|
||||||
@META_GIR@_SCANNERFLAGS = --warn-all --warn-error
|
@META_GIR@_SCANNERFLAGS = --warn-all --warn-error
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
testboxes_SOURCES = core/testboxes.c
|
testboxes_SOURCES = core/testboxes.c
|
||||||
testgradient_SOURCES = ui/testgradient.c
|
testgradient_SOURCES = ui/testgradient.c
|
||||||
testasyncgetprop_SOURCES = core/testasyncgetprop.c
|
testasyncgetprop_SOURCES = x11/testasyncgetprop.c
|
||||||
|
|
||||||
noinst_PROGRAMS=testboxes testgradient testasyncgetprop
|
noinst_PROGRAMS=testboxes testgradient testasyncgetprop
|
||||||
|
|
||||||
testboxes_LDADD = $(MUTTER_LIBS) libmutter.la
|
testboxes_LDADD = $(MUTTER_LIBS) libmutter-wayland.la
|
||||||
testgradient_LDADD = $(MUTTER_LIBS) libmutter.la
|
testgradient_LDADD = $(MUTTER_LIBS) libmutter-wayland.la
|
||||||
testasyncgetprop_LDADD = $(MUTTER_LIBS) libmutter.la
|
testasyncgetprop_LDADD = $(MUTTER_LIBS) libmutter-wayland.la
|
||||||
|
|
||||||
@INTLTOOL_DESKTOP_RULE@
|
@INTLTOOL_DESKTOP_RULE@
|
||||||
|
|
||||||
desktopfilesdir=$(datadir)/applications
|
desktopfilesdir=$(datadir)/applications
|
||||||
desktopfiles_in_files=mutter.desktop.in
|
desktopfiles_in_files=mutter-wayland.desktop.in
|
||||||
desktopfiles_files=$(desktopfiles_in_files:.desktop.in=.desktop)
|
desktopfiles_files=$(desktopfiles_in_files:.desktop.in=.desktop)
|
||||||
desktopfiles_DATA = $(desktopfiles_files)
|
desktopfiles_DATA = $(desktopfiles_files)
|
||||||
|
|
||||||
wmpropertiesdir=$(datadir)/gnome/wm-properties
|
|
||||||
wmproperties_in_files=mutter-wm.desktop.in
|
|
||||||
wmproperties_files=$(wmproperties_in_files:.desktop.in=.desktop)
|
|
||||||
wmproperties_DATA = $(wmproperties_files)
|
|
||||||
|
|
||||||
xmldir = @GNOME_KEYBINDINGS_KEYSDIR@
|
xmldir = @GNOME_KEYBINDINGS_KEYSDIR@
|
||||||
xml_in_files = \
|
xml_in_files = \
|
||||||
50-mutter-navigation.xml.in \
|
50-mutter-navigation.xml.in \
|
||||||
@@ -283,7 +354,9 @@ xml_in_files = \
|
|||||||
50-mutter-windows.xml.in
|
50-mutter-windows.xml.in
|
||||||
xml_DATA = $(xml_in_files:.xml.in=.xml)
|
xml_DATA = $(xml_in_files:.xml.in=.xml)
|
||||||
|
|
||||||
gsettings_SCHEMAS = org.gnome.mutter.gschema.xml
|
dbus_idle_built_sources = meta-dbus-idle-monitor.c meta-dbus-idle-monitor.h
|
||||||
|
|
||||||
|
gsettings_SCHEMAS = org.gnome.mutter.gschema.xml org.gnome.mutter.wayland.gschema.xml
|
||||||
@INTLTOOL_XML_NOMERGE_RULE@
|
@INTLTOOL_XML_NOMERGE_RULE@
|
||||||
@GSETTINGS_RULES@
|
@GSETTINGS_RULES@
|
||||||
|
|
||||||
@@ -291,9 +364,10 @@ convertdir = $(datadir)/GConf/gsettings
|
|||||||
convert_DATA = mutter-schemas.convert
|
convert_DATA = mutter-schemas.convert
|
||||||
|
|
||||||
CLEANFILES = \
|
CLEANFILES = \
|
||||||
mutter.desktop \
|
mutter-wayland.desktop \
|
||||||
mutter-wm.desktop \
|
mutter-wm.desktop \
|
||||||
org.gnome.mutter.gschema.xml \
|
org.gnome.mutter.gschema.xml \
|
||||||
|
org.gnome.mutter.wayland.gschema.xml \
|
||||||
$(xml_DATA) \
|
$(xml_DATA) \
|
||||||
$(mutter_built_sources) \
|
$(mutter_built_sources) \
|
||||||
$(typelib_DATA) \
|
$(typelib_DATA) \
|
||||||
@@ -301,7 +375,7 @@ CLEANFILES = \
|
|||||||
|
|
||||||
pkgconfigdir = $(libdir)/pkgconfig
|
pkgconfigdir = $(libdir)/pkgconfig
|
||||||
|
|
||||||
pkgconfig_DATA = libmutter.pc mutter-plugins.pc
|
pkgconfig_DATA = libmutter-wayland.pc
|
||||||
|
|
||||||
EXTRA_DIST=$(desktopfiles_files) \
|
EXTRA_DIST=$(desktopfiles_files) \
|
||||||
$(wmproperties_files) \
|
$(wmproperties_files) \
|
||||||
@@ -309,14 +383,15 @@ EXTRA_DIST=$(desktopfiles_files) \
|
|||||||
$(desktopfiles_in_files) \
|
$(desktopfiles_in_files) \
|
||||||
$(wmproperties_in_files) \
|
$(wmproperties_in_files) \
|
||||||
$(xml_in_files) \
|
$(xml_in_files) \
|
||||||
|
$(wayland_protocols) \
|
||||||
org.gnome.mutter.gschema.xml.in \
|
org.gnome.mutter.gschema.xml.in \
|
||||||
idle-monitor.xml \
|
org.gnome.mutter.wayland.gschema.xml.in \
|
||||||
xrandr.xml \
|
|
||||||
mutter-schemas.convert \
|
mutter-schemas.convert \
|
||||||
libmutter.pc.in \
|
libmutter-wayland.pc.in \
|
||||||
mutter-plugins.pc.in \
|
|
||||||
mutter-enum-types.h.in \
|
mutter-enum-types.h.in \
|
||||||
mutter-enum-types.c.in
|
mutter-enum-types.c.in \
|
||||||
|
org.gnome.Mutter.DisplayConfig.xml \
|
||||||
|
org.gnome.Mutter.IdleMonitor.xml
|
||||||
|
|
||||||
BUILT_SOURCES = $(mutter_built_sources)
|
BUILT_SOURCES = $(mutter_built_sources)
|
||||||
MUTTER_STAMP_FILES = stamp-mutter-enum-types.h
|
MUTTER_STAMP_FILES = stamp-mutter-enum-types.h
|
||||||
@@ -341,21 +416,24 @@ mutter-enum-types.c: stamp-mutter-enum-types.h mutter-enum-types.c.in
|
|||||||
cp xgen-tetc mutter-enum-types.c && \
|
cp xgen-tetc mutter-enum-types.c && \
|
||||||
rm -f xgen-tetc
|
rm -f xgen-tetc
|
||||||
|
|
||||||
dbus_xrandr_built_sources = meta-dbus-xrandr.c meta-dbus-xrandr.h
|
dbus_display_config_built_sources = meta-dbus-display-config.c meta-dbus-display-config.h
|
||||||
|
|
||||||
$(dbus_xrandr_built_sources) : Makefile.am xrandr.xml
|
$(dbus_display_config_built_sources) : Makefile.am org.gnome.Mutter.DisplayConfig.xml
|
||||||
$(AM_V_GEN)gdbus-codegen \
|
$(AM_V_GEN)gdbus-codegen \
|
||||||
--interface-prefix org.gnome.Mutter \
|
--interface-prefix org.gnome.Mutter \
|
||||||
--c-namespace MetaDBus \
|
--c-namespace MetaDBus \
|
||||||
--generate-c-code meta-dbus-xrandr \
|
--generate-c-code meta-dbus-display-config \
|
||||||
$(srcdir)/xrandr.xml
|
$(srcdir)/org.gnome.Mutter.DisplayConfig.xml
|
||||||
|
|
||||||
dbus_idle_built_sources = meta-dbus-idle-monitor.c meta-dbus-idle-monitor.h
|
$(dbus_idle_built_sources) : Makefile.am org.gnome.Mutter.IdleMonitor.xml
|
||||||
|
|
||||||
$(dbus_idle_built_sources) : Makefile.am idle-monitor.xml
|
|
||||||
$(AM_V_GEN)gdbus-codegen \
|
$(AM_V_GEN)gdbus-codegen \
|
||||||
--interface-prefix org.gnome.Mutter \
|
--interface-prefix org.gnome.Mutter \
|
||||||
--c-namespace MetaDBus \
|
--c-namespace MetaDBus \
|
||||||
--generate-c-code meta-dbus-idle-monitor \
|
--generate-c-code meta-dbus-idle-monitor \
|
||||||
--c-generate-object-manager \
|
--c-generate-object-manager \
|
||||||
$(srcdir)/idle-monitor.xml
|
$(srcdir)/org.gnome.Mutter.IdleMonitor.xml
|
||||||
|
|
||||||
|
%-protocol.c : $(srcdir)/wayland/protocol/%.xml
|
||||||
|
$(AM_V_GEN)$(WAYLAND_SCANNER) code < $< > $@
|
||||||
|
%-server-protocol.h : $(srcdir)/wayland/protocol/%.xml
|
||||||
|
$(AM_V_GEN)$(WAYLAND_SCANNER) server-header < $< > $@
|
||||||
|
|||||||
157
src/backends/meta-backend.c
Normal file
157
src/backends/meta-backend.c
Normal file
@@ -0,0 +1,157 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2014 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-backend.h"
|
||||||
|
#include <meta/main.h>
|
||||||
|
|
||||||
|
#include <gdk/gdkx.h>
|
||||||
|
#include <clutter/clutter.h>
|
||||||
|
#include <clutter/x11/clutter-x11.h>
|
||||||
|
|
||||||
|
#include "backends/native/meta-weston-launch.h"
|
||||||
|
#include <meta/util.h>
|
||||||
|
|
||||||
|
/* Mutter is responsible for pulling events off the X queue, so Clutter
|
||||||
|
* doesn't need (and shouldn't) run its normal event source which polls
|
||||||
|
* the X fd, but we do have to deal with dispatching events that accumulate
|
||||||
|
* in the clutter queue. This happens, for example, when clutter generate
|
||||||
|
* enter/leave events on mouse motion - several events are queued in the
|
||||||
|
* clutter queue but only one dispatched. It could also happen because of
|
||||||
|
* explicit calls to clutter_event_put(). We add a very simple custom
|
||||||
|
* event loop source which is simply responsible for pulling events off
|
||||||
|
* of the queue and dispatching them before we block for new events.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
event_prepare (GSource *source,
|
||||||
|
gint *timeout_)
|
||||||
|
{
|
||||||
|
*timeout_ = -1;
|
||||||
|
|
||||||
|
return clutter_events_pending ();
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
event_check (GSource *source)
|
||||||
|
{
|
||||||
|
return clutter_events_pending ();
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
event_dispatch (GSource *source,
|
||||||
|
GSourceFunc callback,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
ClutterEvent *event = clutter_event_get ();
|
||||||
|
|
||||||
|
if (event)
|
||||||
|
{
|
||||||
|
clutter_do_event (event);
|
||||||
|
clutter_event_free (event);
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static GSourceFuncs event_funcs = {
|
||||||
|
event_prepare,
|
||||||
|
event_check,
|
||||||
|
event_dispatch
|
||||||
|
};
|
||||||
|
|
||||||
|
static MetaLauncher *launcher;
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_clutter_init (void)
|
||||||
|
{
|
||||||
|
GSource *source;
|
||||||
|
|
||||||
|
/* When running as an X11 compositor, we install our own event filter and
|
||||||
|
* pass events to Clutter explicitly, so we need to prevent Clutter from
|
||||||
|
* handling our events.
|
||||||
|
*
|
||||||
|
* However, when running as a Wayland compostior under X11 nested, Clutter
|
||||||
|
* Clutter needs to see events related to its own window. We need to
|
||||||
|
* eventually replace this with a proper frontend / backend split: Clutter
|
||||||
|
* under nested is connecting to the "host X server" to get its events it
|
||||||
|
* needs to put up a window, and GTK+ is connecting to the "inner X server".
|
||||||
|
* The two would the same in the X11 compositor case, but not when running
|
||||||
|
* XWayland as a Wayland compositor.
|
||||||
|
*/
|
||||||
|
if (!meta_is_wayland_compositor ())
|
||||||
|
{
|
||||||
|
clutter_x11_set_display (GDK_DISPLAY_XDISPLAY (gdk_display_get_default ()));
|
||||||
|
clutter_x11_disable_event_retrieval ();
|
||||||
|
}
|
||||||
|
|
||||||
|
/* If we're running on bare metal, we're a display server,
|
||||||
|
* so start talking to weston-launch. */
|
||||||
|
#if defined(CLUTTER_WINDOWING_EGL)
|
||||||
|
if (clutter_check_windowing_backend (CLUTTER_WINDOWING_EGL))
|
||||||
|
launcher = meta_launcher_new ();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (clutter_init (NULL, NULL) != CLUTTER_INIT_SUCCESS)
|
||||||
|
g_error ("Unable to initialize Clutter.\n");
|
||||||
|
|
||||||
|
source = g_source_new (&event_funcs, sizeof (GSource));
|
||||||
|
g_source_attach (source, NULL);
|
||||||
|
g_source_unref (source);
|
||||||
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
meta_activate_vt (int vt, GError **error)
|
||||||
|
{
|
||||||
|
if (launcher)
|
||||||
|
return meta_launcher_activate_vt (launcher, vt, error);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
g_debug ("Ignoring VT switch keybinding, not running as display server");
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* meta_activate_session:
|
||||||
|
*
|
||||||
|
* Tells mutter to activate the session. When mutter is a
|
||||||
|
* Wayland compositor, this tells logind to switch over to
|
||||||
|
* the new session.
|
||||||
|
*/
|
||||||
|
gboolean
|
||||||
|
meta_activate_session (void)
|
||||||
|
{
|
||||||
|
GError *error = NULL;
|
||||||
|
|
||||||
|
if (!meta_launcher_activate_vt (launcher, -1, &error))
|
||||||
|
{
|
||||||
|
g_warning ("Could not activate session: %s\n", error->message);
|
||||||
|
g_error_free (error);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2013 Red Hat, Inc.
|
* Copyright (C) 2014 Red Hat
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or
|
* This program is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License as
|
* modify it under the terms of the GNU General Public License as
|
||||||
@@ -18,17 +18,17 @@
|
|||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
||||||
* 02111-1307, USA.
|
* 02111-1307, USA.
|
||||||
*
|
*
|
||||||
* Author: Giovanni Campagna <gcampagn@redhat.com>
|
* Written by:
|
||||||
|
* Jasper St. Pierre <jstpierre@mecheye.net>
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef META_CURSOR_TRACKER_PRIVATE_H
|
#ifndef META_BACKEND_H
|
||||||
#define META_CURSOR_TRACKER_PRIVATE_H
|
#define META_BACKEND_H
|
||||||
|
|
||||||
#include <meta/meta-cursor-tracker.h>
|
#include <glib-object.h>
|
||||||
|
|
||||||
gboolean meta_cursor_tracker_handle_xevent (MetaCursorTracker *tracker,
|
void meta_clutter_init (void);
|
||||||
XEvent *xevent);
|
|
||||||
|
|
||||||
void meta_cursor_tracker_set_root_cursor (MetaCursorTracker *tracker,
|
gboolean meta_activate_vt (int vt, GError **error);
|
||||||
MetaCursor cursor);
|
|
||||||
#endif
|
#endif /* META_BACKEND_H */
|
||||||
50
src/backends/meta-cursor-private.h
Normal file
50
src/backends/meta-cursor-private.h
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* 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/>.
|
||||||
|
*
|
||||||
|
* Author: Giovanni Campagna <gcampagn@redhat.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef META_CURSOR_PRIVATE_H
|
||||||
|
#define META_CURSOR_PRIVATE_H
|
||||||
|
|
||||||
|
#include "meta-cursor.h"
|
||||||
|
|
||||||
|
#include <cogl/cogl.h>
|
||||||
|
#include <gbm.h>
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
CoglTexture2D *texture;
|
||||||
|
struct gbm_bo *bo;
|
||||||
|
int hot_x, hot_y;
|
||||||
|
} MetaCursorImage;
|
||||||
|
|
||||||
|
struct _MetaCursorReference {
|
||||||
|
int ref_count;
|
||||||
|
|
||||||
|
MetaCursorImage image;
|
||||||
|
};
|
||||||
|
|
||||||
|
CoglTexture *meta_cursor_reference_get_cogl_texture (MetaCursorReference *cursor,
|
||||||
|
int *hot_x,
|
||||||
|
int *hot_y);
|
||||||
|
|
||||||
|
struct gbm_bo *meta_cursor_reference_get_gbm_bo (MetaCursorReference *cursor,
|
||||||
|
int *hot_x,
|
||||||
|
int *hot_y);
|
||||||
|
|
||||||
|
#endif /* META_CURSOR_PRIVATE_H */
|
||||||
98
src/backends/meta-cursor-tracker-private.h
Normal file
98
src/backends/meta-cursor-tracker-private.h
Normal file
@@ -0,0 +1,98 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* 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/>.
|
||||||
|
*
|
||||||
|
* Author: Giovanni Campagna <gcampagn@redhat.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef META_CURSOR_TRACKER_PRIVATE_H
|
||||||
|
#define META_CURSOR_TRACKER_PRIVATE_H
|
||||||
|
|
||||||
|
#include <meta/meta-cursor-tracker.h>
|
||||||
|
#include <wayland-server.h>
|
||||||
|
|
||||||
|
#include "meta-cursor.h"
|
||||||
|
|
||||||
|
struct _MetaCursorTracker {
|
||||||
|
GObject parent_instance;
|
||||||
|
|
||||||
|
MetaScreen *screen;
|
||||||
|
|
||||||
|
gboolean is_showing;
|
||||||
|
gboolean has_hw_cursor;
|
||||||
|
|
||||||
|
/* The cursor tracker stores the cursor for the current grab
|
||||||
|
* operation, the cursor for the window with pointer focus, and
|
||||||
|
* the cursor for the root window, which contains either the
|
||||||
|
* default arrow cursor or the 'busy' hourglass if we're launching
|
||||||
|
* an app.
|
||||||
|
*
|
||||||
|
* We choose the first one available -- if there's a grab cursor,
|
||||||
|
* we choose that cursor, if there's window cursor, we choose that,
|
||||||
|
* otherwise we choose the root cursor.
|
||||||
|
*
|
||||||
|
* The displayed_cursor contains the chosen cursor.
|
||||||
|
*/
|
||||||
|
MetaCursorReference *displayed_cursor;
|
||||||
|
|
||||||
|
MetaCursorReference *grab_cursor;
|
||||||
|
|
||||||
|
/* Wayland clients can set a NULL buffer as their cursor
|
||||||
|
* explicitly, which means that we shouldn't display anything.
|
||||||
|
* So, we can't simply store a NULL in window_cursor to
|
||||||
|
* determine an unset window cursor; we need an extra boolean.
|
||||||
|
*/
|
||||||
|
gboolean has_window_cursor;
|
||||||
|
MetaCursorReference *window_cursor;
|
||||||
|
|
||||||
|
MetaCursorReference *root_cursor;
|
||||||
|
|
||||||
|
MetaCursorReference *theme_cursors[META_CURSOR_LAST];
|
||||||
|
|
||||||
|
int current_x, current_y;
|
||||||
|
MetaRectangle current_rect;
|
||||||
|
MetaRectangle previous_rect;
|
||||||
|
gboolean previous_is_valid;
|
||||||
|
|
||||||
|
CoglPipeline *pipeline;
|
||||||
|
int drm_fd;
|
||||||
|
struct gbm_device *gbm;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _MetaCursorTrackerClass {
|
||||||
|
GObjectClass parent_class;
|
||||||
|
};
|
||||||
|
|
||||||
|
gboolean meta_cursor_tracker_handle_xevent (MetaCursorTracker *tracker,
|
||||||
|
XEvent *xevent);
|
||||||
|
|
||||||
|
void meta_cursor_tracker_set_grab_cursor (MetaCursorTracker *tracker,
|
||||||
|
MetaCursorReference *cursor);
|
||||||
|
void meta_cursor_tracker_set_window_cursor (MetaCursorTracker *tracker,
|
||||||
|
MetaCursorReference *cursor);
|
||||||
|
void meta_cursor_tracker_unset_window_cursor (MetaCursorTracker *tracker);
|
||||||
|
void meta_cursor_tracker_set_root_cursor (MetaCursorTracker *tracker,
|
||||||
|
MetaCursorReference *cursor);
|
||||||
|
|
||||||
|
void meta_cursor_tracker_update_position (MetaCursorTracker *tracker,
|
||||||
|
int new_x,
|
||||||
|
int new_y);
|
||||||
|
void meta_cursor_tracker_paint (MetaCursorTracker *tracker);
|
||||||
|
|
||||||
|
void meta_cursor_tracker_force_update (MetaCursorTracker *tracker);
|
||||||
|
|
||||||
|
#endif
|
||||||
738
src/backends/meta-cursor-tracker.c
Normal file
738
src/backends/meta-cursor-tracker.c
Normal file
@@ -0,0 +1,738 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* 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/>.
|
||||||
|
*
|
||||||
|
* Author: Giovanni Campagna <gcampagn@redhat.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SECTION:cursor-tracker
|
||||||
|
* @title: MetaCursorTracker
|
||||||
|
* @short_description: Mutter cursor tracking helper. Originally only
|
||||||
|
* tracking the cursor image, now more of a "core
|
||||||
|
* pointer abstraction"
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <meta/main.h>
|
||||||
|
#include <meta/util.h>
|
||||||
|
#include <meta/errors.h>
|
||||||
|
|
||||||
|
#include <cogl/cogl.h>
|
||||||
|
#include <cogl/cogl-wayland-server.h>
|
||||||
|
#include <clutter/clutter.h>
|
||||||
|
#include <gbm.h>
|
||||||
|
|
||||||
|
#include <gdk/gdk.h>
|
||||||
|
#include <gdk/gdkx.h>
|
||||||
|
|
||||||
|
#include "meta-cursor-private.h"
|
||||||
|
#include "meta-cursor-tracker-private.h"
|
||||||
|
#include "screen-private.h"
|
||||||
|
#include "meta-monitor-manager.h"
|
||||||
|
|
||||||
|
#include "wayland/meta-wayland-private.h"
|
||||||
|
|
||||||
|
G_DEFINE_TYPE (MetaCursorTracker, meta_cursor_tracker, G_TYPE_OBJECT);
|
||||||
|
|
||||||
|
enum {
|
||||||
|
CURSOR_CHANGED,
|
||||||
|
LAST_SIGNAL
|
||||||
|
};
|
||||||
|
|
||||||
|
static guint signals[LAST_SIGNAL];
|
||||||
|
|
||||||
|
static void meta_cursor_tracker_set_crtc_has_hw_cursor (MetaCursorTracker *tracker,
|
||||||
|
MetaCRTC *crtc,
|
||||||
|
gboolean has_hw_cursor);
|
||||||
|
static void sync_cursor (MetaCursorTracker *tracker);
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_cursor_tracker_init (MetaCursorTracker *self)
|
||||||
|
{
|
||||||
|
/* (JS) Best (?) that can be assumed since XFixes doesn't provide a way of
|
||||||
|
detecting if the system mouse cursor is showing or not.
|
||||||
|
|
||||||
|
On wayland we start with the cursor showing
|
||||||
|
*/
|
||||||
|
self->is_showing = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_cursor_tracker_finalize (GObject *object)
|
||||||
|
{
|
||||||
|
MetaCursorTracker *self = META_CURSOR_TRACKER (object);
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (self->displayed_cursor)
|
||||||
|
meta_cursor_reference_unref (self->displayed_cursor);
|
||||||
|
if (self->root_cursor)
|
||||||
|
meta_cursor_reference_unref (self->root_cursor);
|
||||||
|
|
||||||
|
for (i = 0; i < META_CURSOR_LAST; i++)
|
||||||
|
if (self->theme_cursors[i])
|
||||||
|
meta_cursor_reference_unref (self->theme_cursors[i]);
|
||||||
|
|
||||||
|
if (self->pipeline)
|
||||||
|
cogl_object_unref (self->pipeline);
|
||||||
|
if (self->gbm)
|
||||||
|
gbm_device_destroy (self->gbm);
|
||||||
|
|
||||||
|
G_OBJECT_CLASS (meta_cursor_tracker_parent_class)->finalize (object);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_cursor_tracker_class_init (MetaCursorTrackerClass *klass)
|
||||||
|
{
|
||||||
|
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
||||||
|
|
||||||
|
object_class->finalize = meta_cursor_tracker_finalize;
|
||||||
|
|
||||||
|
signals[CURSOR_CHANGED] = g_signal_new ("cursor-changed",
|
||||||
|
G_TYPE_FROM_CLASS (klass),
|
||||||
|
G_SIGNAL_RUN_LAST,
|
||||||
|
0,
|
||||||
|
NULL, NULL, NULL,
|
||||||
|
G_TYPE_NONE, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_monitors_changed (MetaMonitorManager *monitors,
|
||||||
|
MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
MetaCRTC *crtcs;
|
||||||
|
unsigned int i, n_crtcs;
|
||||||
|
|
||||||
|
if (!tracker->has_hw_cursor)
|
||||||
|
return;
|
||||||
|
|
||||||
|
/* Go through the new list of monitors, find out where the cursor is */
|
||||||
|
meta_monitor_manager_get_resources (monitors, NULL, NULL, &crtcs, &n_crtcs, NULL, NULL);
|
||||||
|
|
||||||
|
for (i = 0; i < n_crtcs; i++)
|
||||||
|
{
|
||||||
|
MetaRectangle *rect = &crtcs[i].rect;
|
||||||
|
gboolean has;
|
||||||
|
|
||||||
|
has = meta_rectangle_overlap (&tracker->current_rect, rect);
|
||||||
|
|
||||||
|
/* Need to do it unconditionally here, our tracking is
|
||||||
|
wrong because we reloaded the CRTCs */
|
||||||
|
meta_cursor_tracker_set_crtc_has_hw_cursor (tracker, &crtcs[i], has);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static MetaCursorTracker *
|
||||||
|
make_wayland_cursor_tracker (MetaScreen *screen)
|
||||||
|
{
|
||||||
|
MetaWaylandCompositor *compositor;
|
||||||
|
CoglContext *ctx;
|
||||||
|
MetaMonitorManager *monitors;
|
||||||
|
MetaCursorTracker *self;
|
||||||
|
|
||||||
|
self = g_object_new (META_TYPE_CURSOR_TRACKER, NULL);
|
||||||
|
self->screen = screen;
|
||||||
|
|
||||||
|
ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ());
|
||||||
|
self->pipeline = cogl_pipeline_new (ctx);
|
||||||
|
|
||||||
|
compositor = meta_wayland_compositor_get_default ();
|
||||||
|
compositor->seat->cursor_tracker = self;
|
||||||
|
meta_cursor_tracker_update_position (self,
|
||||||
|
wl_fixed_to_int (compositor->seat->pointer.x),
|
||||||
|
wl_fixed_to_int (compositor->seat->pointer.y));
|
||||||
|
|
||||||
|
#if defined(CLUTTER_WINDOWING_EGL)
|
||||||
|
if (clutter_check_windowing_backend (CLUTTER_WINDOWING_EGL))
|
||||||
|
{
|
||||||
|
CoglRenderer *cogl_renderer = cogl_display_get_renderer (cogl_context_get_display (ctx));
|
||||||
|
self->drm_fd = cogl_kms_renderer_get_kms_fd (cogl_renderer);
|
||||||
|
self->gbm = gbm_create_device (self->drm_fd);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
monitors = meta_monitor_manager_get ();
|
||||||
|
g_signal_connect_object (monitors, "monitors-changed",
|
||||||
|
G_CALLBACK (on_monitors_changed), self, 0);
|
||||||
|
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
static MetaCursorTracker *
|
||||||
|
make_x11_cursor_tracker (MetaScreen *screen)
|
||||||
|
{
|
||||||
|
MetaCursorTracker *self = g_object_new (META_TYPE_CURSOR_TRACKER, NULL);
|
||||||
|
self->screen = screen;
|
||||||
|
|
||||||
|
XFixesSelectCursorInput (screen->display->xdisplay,
|
||||||
|
screen->xroot,
|
||||||
|
XFixesDisplayCursorNotifyMask);
|
||||||
|
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* meta_cursor_tracker_get_for_screen:
|
||||||
|
* @screen: the #MetaScreen
|
||||||
|
*
|
||||||
|
* Retrieves the cursor tracker object for @screen.
|
||||||
|
*
|
||||||
|
* Returns: (transfer none):
|
||||||
|
*/
|
||||||
|
MetaCursorTracker *
|
||||||
|
meta_cursor_tracker_get_for_screen (MetaScreen *screen)
|
||||||
|
{
|
||||||
|
MetaCursorTracker *self;
|
||||||
|
|
||||||
|
if (screen->cursor_tracker)
|
||||||
|
return screen->cursor_tracker;
|
||||||
|
|
||||||
|
if (meta_is_wayland_compositor ())
|
||||||
|
self = make_wayland_cursor_tracker (screen);
|
||||||
|
else
|
||||||
|
self = make_x11_cursor_tracker (screen);
|
||||||
|
|
||||||
|
screen->cursor_tracker = self;
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
set_window_cursor (MetaCursorTracker *tracker,
|
||||||
|
gboolean has_cursor,
|
||||||
|
MetaCursorReference *cursor)
|
||||||
|
{
|
||||||
|
g_clear_pointer (&tracker->window_cursor, meta_cursor_reference_unref);
|
||||||
|
if (cursor)
|
||||||
|
tracker->window_cursor = meta_cursor_reference_ref (cursor);
|
||||||
|
tracker->has_window_cursor = has_cursor;
|
||||||
|
sync_cursor (tracker);
|
||||||
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
meta_cursor_tracker_handle_xevent (MetaCursorTracker *tracker,
|
||||||
|
XEvent *xevent)
|
||||||
|
{
|
||||||
|
XFixesCursorNotifyEvent *notify_event;
|
||||||
|
|
||||||
|
if (meta_is_wayland_compositor ())
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
if (xevent->xany.type != tracker->screen->display->xfixes_event_base + XFixesCursorNotify)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
notify_event = (XFixesCursorNotifyEvent *)xevent;
|
||||||
|
if (notify_event->subtype != XFixesDisplayCursorNotify)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
set_window_cursor (tracker, FALSE, NULL);
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static MetaCursorReference *
|
||||||
|
meta_cursor_reference_take_texture (CoglTexture2D *texture,
|
||||||
|
int hot_x,
|
||||||
|
int hot_y)
|
||||||
|
{
|
||||||
|
MetaCursorReference *self;
|
||||||
|
|
||||||
|
self = g_slice_new0 (MetaCursorReference);
|
||||||
|
self->ref_count = 1;
|
||||||
|
self->image.texture = texture;
|
||||||
|
self->image.hot_x = hot_x;
|
||||||
|
self->image.hot_y = hot_y;
|
||||||
|
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
ensure_xfixes_cursor (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
XFixesCursorImage *cursor_image;
|
||||||
|
CoglTexture2D *sprite;
|
||||||
|
guint8 *cursor_data;
|
||||||
|
gboolean free_cursor_data;
|
||||||
|
CoglContext *ctx;
|
||||||
|
|
||||||
|
if (tracker->has_window_cursor)
|
||||||
|
return;
|
||||||
|
|
||||||
|
cursor_image = XFixesGetCursorImage (tracker->screen->display->xdisplay);
|
||||||
|
if (!cursor_image)
|
||||||
|
return;
|
||||||
|
|
||||||
|
/* Like all X APIs, XFixesGetCursorImage() returns arrays of 32-bit
|
||||||
|
* quantities as arrays of long; we need to convert on 64 bit */
|
||||||
|
if (sizeof(long) == 4)
|
||||||
|
{
|
||||||
|
cursor_data = (guint8 *)cursor_image->pixels;
|
||||||
|
free_cursor_data = FALSE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
int i, j;
|
||||||
|
guint32 *cursor_words;
|
||||||
|
gulong *p;
|
||||||
|
guint32 *q;
|
||||||
|
|
||||||
|
cursor_words = g_new (guint32, cursor_image->width * cursor_image->height);
|
||||||
|
cursor_data = (guint8 *)cursor_words;
|
||||||
|
|
||||||
|
p = cursor_image->pixels;
|
||||||
|
q = cursor_words;
|
||||||
|
for (j = 0; j < cursor_image->height; j++)
|
||||||
|
for (i = 0; i < cursor_image->width; i++)
|
||||||
|
*(q++) = *(p++);
|
||||||
|
|
||||||
|
free_cursor_data = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
ctx = clutter_backend_get_cogl_context (clutter_get_default_backend ());
|
||||||
|
sprite = cogl_texture_2d_new_from_data (ctx,
|
||||||
|
cursor_image->width,
|
||||||
|
cursor_image->height,
|
||||||
|
CLUTTER_CAIRO_FORMAT_ARGB32,
|
||||||
|
cursor_image->width * 4, /* stride */
|
||||||
|
cursor_data,
|
||||||
|
NULL);
|
||||||
|
|
||||||
|
if (free_cursor_data)
|
||||||
|
g_free (cursor_data);
|
||||||
|
|
||||||
|
if (sprite != NULL)
|
||||||
|
{
|
||||||
|
MetaCursorReference *cursor = meta_cursor_reference_take_texture (sprite,
|
||||||
|
cursor_image->xhot,
|
||||||
|
cursor_image->yhot);
|
||||||
|
set_window_cursor (tracker, TRUE, cursor);
|
||||||
|
}
|
||||||
|
XFree (cursor_image);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* meta_cursor_tracker_get_sprite:
|
||||||
|
*
|
||||||
|
* Returns: (transfer none):
|
||||||
|
*/
|
||||||
|
CoglTexture *
|
||||||
|
meta_cursor_tracker_get_sprite (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
g_return_val_if_fail (META_IS_CURSOR_TRACKER (tracker), NULL);
|
||||||
|
|
||||||
|
if (!meta_is_wayland_compositor ())
|
||||||
|
ensure_xfixes_cursor (tracker);
|
||||||
|
|
||||||
|
if (tracker->displayed_cursor)
|
||||||
|
return meta_cursor_reference_get_cogl_texture (tracker->displayed_cursor, NULL, NULL);
|
||||||
|
else
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* meta_cursor_tracker_get_hot:
|
||||||
|
* @tracker:
|
||||||
|
* @x: (out):
|
||||||
|
* @y: (out):
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
meta_cursor_tracker_get_hot (MetaCursorTracker *tracker,
|
||||||
|
int *x,
|
||||||
|
int *y)
|
||||||
|
{
|
||||||
|
g_return_if_fail (META_IS_CURSOR_TRACKER (tracker));
|
||||||
|
|
||||||
|
if (!meta_is_wayland_compositor ())
|
||||||
|
ensure_xfixes_cursor (tracker);
|
||||||
|
|
||||||
|
if (tracker->displayed_cursor)
|
||||||
|
meta_cursor_reference_get_cogl_texture (tracker->displayed_cursor, x, y);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (x)
|
||||||
|
*x = 0;
|
||||||
|
if (y)
|
||||||
|
*y = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_cursor_tracker_set_grab_cursor (MetaCursorTracker *tracker,
|
||||||
|
MetaCursorReference *cursor)
|
||||||
|
{
|
||||||
|
g_clear_pointer (&tracker->grab_cursor, meta_cursor_reference_unref);
|
||||||
|
if (cursor)
|
||||||
|
tracker->grab_cursor = meta_cursor_reference_ref (cursor);
|
||||||
|
|
||||||
|
sync_cursor (tracker);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_cursor_tracker_set_window_cursor (MetaCursorTracker *tracker,
|
||||||
|
MetaCursorReference *cursor)
|
||||||
|
{
|
||||||
|
set_window_cursor (tracker, TRUE, cursor);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_cursor_tracker_unset_window_cursor (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
set_window_cursor (tracker, FALSE, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_cursor_tracker_set_root_cursor (MetaCursorTracker *tracker,
|
||||||
|
MetaCursorReference *cursor)
|
||||||
|
{
|
||||||
|
g_clear_pointer (&tracker->root_cursor, meta_cursor_reference_unref);
|
||||||
|
if (cursor)
|
||||||
|
tracker->root_cursor = meta_cursor_reference_ref (cursor);
|
||||||
|
|
||||||
|
sync_cursor (tracker);
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
should_have_hw_cursor (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
if (tracker->displayed_cursor)
|
||||||
|
return (meta_cursor_reference_get_gbm_bo (tracker->displayed_cursor, NULL, NULL) != NULL);
|
||||||
|
else
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
update_hw_cursor (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
MetaMonitorManager *monitors;
|
||||||
|
MetaCRTC *crtcs;
|
||||||
|
unsigned int i, n_crtcs;
|
||||||
|
gboolean enabled;
|
||||||
|
|
||||||
|
enabled = should_have_hw_cursor (tracker);
|
||||||
|
tracker->has_hw_cursor = enabled;
|
||||||
|
|
||||||
|
monitors = meta_monitor_manager_get ();
|
||||||
|
meta_monitor_manager_get_resources (monitors, NULL, NULL, &crtcs, &n_crtcs, NULL, NULL);
|
||||||
|
|
||||||
|
for (i = 0; i < n_crtcs; i++)
|
||||||
|
{
|
||||||
|
MetaRectangle *rect = &crtcs[i].rect;
|
||||||
|
gboolean has;
|
||||||
|
|
||||||
|
has = enabled && meta_rectangle_overlap (&tracker->current_rect, rect);
|
||||||
|
|
||||||
|
if (has || crtcs[i].has_hw_cursor)
|
||||||
|
meta_cursor_tracker_set_crtc_has_hw_cursor (tracker, &crtcs[i], has);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
move_hw_cursor (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
MetaMonitorManager *monitors;
|
||||||
|
MetaCRTC *crtcs;
|
||||||
|
unsigned int i, n_crtcs;
|
||||||
|
|
||||||
|
monitors = meta_monitor_manager_get ();
|
||||||
|
meta_monitor_manager_get_resources (monitors, NULL, NULL, &crtcs, &n_crtcs, NULL, NULL);
|
||||||
|
|
||||||
|
g_assert (tracker->has_hw_cursor);
|
||||||
|
|
||||||
|
for (i = 0; i < n_crtcs; i++)
|
||||||
|
{
|
||||||
|
MetaRectangle *rect = &crtcs[i].rect;
|
||||||
|
gboolean has;
|
||||||
|
|
||||||
|
has = meta_rectangle_overlap (&tracker->current_rect, rect);
|
||||||
|
|
||||||
|
if (has != crtcs[i].has_hw_cursor)
|
||||||
|
meta_cursor_tracker_set_crtc_has_hw_cursor (tracker, &crtcs[i], has);
|
||||||
|
if (has)
|
||||||
|
drmModeMoveCursor (tracker->drm_fd, crtcs[i].crtc_id,
|
||||||
|
tracker->current_rect.x - rect->x,
|
||||||
|
tracker->current_rect.y - rect->y);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static MetaCursorReference *
|
||||||
|
get_displayed_cursor (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
if (!tracker->is_showing)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
if (tracker->grab_cursor)
|
||||||
|
return tracker->grab_cursor;
|
||||||
|
|
||||||
|
if (tracker->has_window_cursor)
|
||||||
|
return tracker->window_cursor;
|
||||||
|
|
||||||
|
return tracker->root_cursor;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
update_displayed_cursor (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
if (meta_is_wayland_compositor ())
|
||||||
|
{
|
||||||
|
if (tracker->displayed_cursor)
|
||||||
|
{
|
||||||
|
CoglTexture *texture = meta_cursor_reference_get_cogl_texture (tracker->displayed_cursor, NULL, NULL);
|
||||||
|
cogl_pipeline_set_layer_texture (tracker->pipeline, 0, texture);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
cogl_pipeline_set_layer_texture (tracker->pipeline, 0, NULL);
|
||||||
|
|
||||||
|
update_hw_cursor (tracker);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
sync_displayed_cursor (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
MetaCursorReference *displayed_cursor = get_displayed_cursor (tracker);
|
||||||
|
|
||||||
|
if (tracker->displayed_cursor == displayed_cursor)
|
||||||
|
return;
|
||||||
|
|
||||||
|
g_clear_pointer (&tracker->displayed_cursor, meta_cursor_reference_unref);
|
||||||
|
if (displayed_cursor)
|
||||||
|
tracker->displayed_cursor = meta_cursor_reference_ref (displayed_cursor);
|
||||||
|
|
||||||
|
update_displayed_cursor (tracker);
|
||||||
|
g_signal_emit (tracker, signals[CURSOR_CHANGED], 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_cursor_tracker_queue_redraw (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
MetaWaylandCompositor *compositor = meta_wayland_compositor_get_default ();
|
||||||
|
ClutterActor *stage = compositor->stage;
|
||||||
|
cairo_rectangle_int_t clip;
|
||||||
|
|
||||||
|
g_assert (meta_is_wayland_compositor ());
|
||||||
|
|
||||||
|
/* Clear the location the cursor was at before, if we need to. */
|
||||||
|
if (tracker->previous_is_valid)
|
||||||
|
{
|
||||||
|
clip.x = tracker->previous_rect.x;
|
||||||
|
clip.y = tracker->previous_rect.y;
|
||||||
|
clip.width = tracker->previous_rect.width;
|
||||||
|
clip.height = tracker->previous_rect.height;
|
||||||
|
clutter_actor_queue_redraw_with_clip (stage, &clip);
|
||||||
|
tracker->previous_is_valid = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tracker->has_hw_cursor || !tracker->displayed_cursor)
|
||||||
|
return;
|
||||||
|
|
||||||
|
clip.x = tracker->current_rect.x;
|
||||||
|
clip.y = tracker->current_rect.y;
|
||||||
|
clip.width = tracker->current_rect.width;
|
||||||
|
clip.height = tracker->current_rect.height;
|
||||||
|
clutter_actor_queue_redraw_with_clip (stage, &clip);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
sync_cursor (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
MetaCursorReference *displayed_cursor;
|
||||||
|
|
||||||
|
sync_displayed_cursor (tracker);
|
||||||
|
displayed_cursor = tracker->displayed_cursor;
|
||||||
|
|
||||||
|
if (displayed_cursor)
|
||||||
|
{
|
||||||
|
CoglTexture *texture;
|
||||||
|
int hot_x, hot_y;
|
||||||
|
|
||||||
|
texture = meta_cursor_reference_get_cogl_texture (displayed_cursor, &hot_x, &hot_y);
|
||||||
|
|
||||||
|
tracker->current_rect.x = tracker->current_x - hot_x;
|
||||||
|
tracker->current_rect.y = tracker->current_y - hot_y;
|
||||||
|
tracker->current_rect.width = cogl_texture_get_width (COGL_TEXTURE (texture));
|
||||||
|
tracker->current_rect.height = cogl_texture_get_height (COGL_TEXTURE (texture));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
tracker->current_rect.x = 0;
|
||||||
|
tracker->current_rect.y = 0;
|
||||||
|
tracker->current_rect.width = 0;
|
||||||
|
tracker->current_rect.height = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (meta_is_wayland_compositor ())
|
||||||
|
{
|
||||||
|
if (tracker->has_hw_cursor)
|
||||||
|
move_hw_cursor (tracker);
|
||||||
|
else
|
||||||
|
meta_cursor_tracker_queue_redraw (tracker);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_cursor_tracker_update_position (MetaCursorTracker *tracker,
|
||||||
|
int new_x,
|
||||||
|
int new_y)
|
||||||
|
{
|
||||||
|
g_assert (meta_is_wayland_compositor ());
|
||||||
|
|
||||||
|
tracker->current_x = new_x;
|
||||||
|
tracker->current_y = new_y;
|
||||||
|
|
||||||
|
sync_cursor (tracker);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_cursor_tracker_paint (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
g_assert (meta_is_wayland_compositor ());
|
||||||
|
|
||||||
|
if (tracker->has_hw_cursor || !tracker->displayed_cursor)
|
||||||
|
return;
|
||||||
|
|
||||||
|
cogl_framebuffer_draw_rectangle (cogl_get_draw_framebuffer (),
|
||||||
|
tracker->pipeline,
|
||||||
|
tracker->current_rect.x,
|
||||||
|
tracker->current_rect.y,
|
||||||
|
tracker->current_rect.x +
|
||||||
|
tracker->current_rect.width,
|
||||||
|
tracker->current_rect.y +
|
||||||
|
tracker->current_rect.height);
|
||||||
|
|
||||||
|
tracker->previous_rect = tracker->current_rect;
|
||||||
|
tracker->previous_is_valid = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_cursor_tracker_set_crtc_has_hw_cursor (MetaCursorTracker *tracker,
|
||||||
|
MetaCRTC *crtc,
|
||||||
|
gboolean has)
|
||||||
|
{
|
||||||
|
if (has)
|
||||||
|
{
|
||||||
|
MetaCursorReference *displayed_cursor = tracker->displayed_cursor;
|
||||||
|
struct gbm_bo *bo;
|
||||||
|
union gbm_bo_handle handle;
|
||||||
|
int width, height;
|
||||||
|
int hot_x, hot_y;
|
||||||
|
|
||||||
|
bo = meta_cursor_reference_get_gbm_bo (displayed_cursor, &hot_x, &hot_y);
|
||||||
|
|
||||||
|
handle = gbm_bo_get_handle (bo);
|
||||||
|
width = gbm_bo_get_width (bo);
|
||||||
|
height = gbm_bo_get_height (bo);
|
||||||
|
|
||||||
|
drmModeSetCursor2 (tracker->drm_fd, crtc->crtc_id, handle.u32,
|
||||||
|
width, height, hot_x, hot_y);
|
||||||
|
crtc->has_hw_cursor = TRUE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
drmModeSetCursor2 (tracker->drm_fd, crtc->crtc_id, 0, 0, 0, 0, 0);
|
||||||
|
crtc->has_hw_cursor = FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
get_pointer_position_gdk (int *x,
|
||||||
|
int *y,
|
||||||
|
int *mods)
|
||||||
|
{
|
||||||
|
GdkDeviceManager *gmanager;
|
||||||
|
GdkDevice *gdevice;
|
||||||
|
GdkScreen *gscreen;
|
||||||
|
|
||||||
|
gmanager = gdk_display_get_device_manager (gdk_display_get_default ());
|
||||||
|
gdevice = gdk_x11_device_manager_lookup (gmanager, META_VIRTUAL_CORE_POINTER_ID);
|
||||||
|
|
||||||
|
gdk_device_get_position (gdevice, &gscreen, x, y);
|
||||||
|
if (mods)
|
||||||
|
gdk_device_get_state (gdevice,
|
||||||
|
gdk_screen_get_root_window (gscreen),
|
||||||
|
NULL, (GdkModifierType*)mods);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
get_pointer_position_clutter (int *x,
|
||||||
|
int *y,
|
||||||
|
int *mods)
|
||||||
|
{
|
||||||
|
ClutterDeviceManager *cmanager;
|
||||||
|
ClutterInputDevice *cdevice;
|
||||||
|
ClutterPoint point;
|
||||||
|
|
||||||
|
cmanager = clutter_device_manager_get_default ();
|
||||||
|
cdevice = clutter_device_manager_get_core_device (cmanager, CLUTTER_POINTER_DEVICE);
|
||||||
|
|
||||||
|
clutter_input_device_get_coords (cdevice, NULL, &point);
|
||||||
|
if (x)
|
||||||
|
*x = point.x;
|
||||||
|
if (y)
|
||||||
|
*y = point.y;
|
||||||
|
if (mods)
|
||||||
|
*mods = clutter_input_device_get_modifier_state (cdevice);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_cursor_tracker_get_pointer (MetaCursorTracker *tracker,
|
||||||
|
int *x,
|
||||||
|
int *y,
|
||||||
|
ClutterModifierType *mods)
|
||||||
|
{
|
||||||
|
/* We can't use the clutter interface when not running as a wayland compositor,
|
||||||
|
because we need to query the server, rather than using the last cached value.
|
||||||
|
OTOH, on wayland we can't use GDK, because that only sees the events
|
||||||
|
we forward to xwayland.
|
||||||
|
*/
|
||||||
|
if (meta_is_wayland_compositor ())
|
||||||
|
get_pointer_position_clutter (x, y, (int*)mods);
|
||||||
|
else
|
||||||
|
get_pointer_position_gdk (x, y, (int*)mods);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_cursor_tracker_set_pointer_visible (MetaCursorTracker *tracker,
|
||||||
|
gboolean visible)
|
||||||
|
{
|
||||||
|
if (visible == tracker->is_showing)
|
||||||
|
return;
|
||||||
|
tracker->is_showing = visible;
|
||||||
|
|
||||||
|
if (meta_is_wayland_compositor ())
|
||||||
|
{
|
||||||
|
sync_cursor (tracker);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (visible)
|
||||||
|
XFixesShowCursor (tracker->screen->display->xdisplay,
|
||||||
|
tracker->screen->xroot);
|
||||||
|
else
|
||||||
|
XFixesHideCursor (tracker->screen->display->xdisplay,
|
||||||
|
tracker->screen->xroot);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_cursor_tracker_force_update (MetaCursorTracker *tracker)
|
||||||
|
{
|
||||||
|
g_assert (meta_is_wayland_compositor ());
|
||||||
|
|
||||||
|
update_hw_cursor (tracker);
|
||||||
|
sync_cursor (tracker);
|
||||||
|
}
|
||||||
412
src/backends/meta-cursor.c
Normal file
412
src/backends/meta-cursor.c
Normal file
@@ -0,0 +1,412 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* 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/>.
|
||||||
|
*
|
||||||
|
* Author: Giovanni Campagna <gcampagn@redhat.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include "meta-cursor-private.h"
|
||||||
|
|
||||||
|
#include <meta/errors.h>
|
||||||
|
|
||||||
|
#include "display-private.h"
|
||||||
|
#include "screen-private.h"
|
||||||
|
#include "meta-cursor-tracker-private.h" /* for tracker->gbm */
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
#include <X11/cursorfont.h>
|
||||||
|
#include <X11/extensions/Xfixes.h>
|
||||||
|
#include <X11/Xcursor/Xcursor.h>
|
||||||
|
|
||||||
|
#include <cogl/cogl-wayland-server.h>
|
||||||
|
|
||||||
|
MetaCursorReference *
|
||||||
|
meta_cursor_reference_ref (MetaCursorReference *self)
|
||||||
|
{
|
||||||
|
g_assert (self->ref_count > 0);
|
||||||
|
self->ref_count++;
|
||||||
|
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_cursor_image_free (MetaCursorImage *image)
|
||||||
|
{
|
||||||
|
cogl_object_unref (image->texture);
|
||||||
|
if (image->bo)
|
||||||
|
gbm_bo_destroy (image->bo);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_cursor_reference_free (MetaCursorReference *self)
|
||||||
|
{
|
||||||
|
meta_cursor_image_free (&self->image);
|
||||||
|
g_slice_free (MetaCursorReference, self);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_cursor_reference_unref (MetaCursorReference *self)
|
||||||
|
{
|
||||||
|
self->ref_count--;
|
||||||
|
|
||||||
|
if (self->ref_count == 0)
|
||||||
|
meta_cursor_reference_free (self);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
translate_meta_cursor (MetaCursor cursor,
|
||||||
|
guint *glyph_out,
|
||||||
|
const char **name_out)
|
||||||
|
{
|
||||||
|
guint glyph = XC_num_glyphs;
|
||||||
|
const char *name = NULL;
|
||||||
|
|
||||||
|
switch (cursor)
|
||||||
|
{
|
||||||
|
case META_CURSOR_DEFAULT:
|
||||||
|
glyph = XC_left_ptr;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_NORTH_RESIZE:
|
||||||
|
glyph = XC_top_side;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_SOUTH_RESIZE:
|
||||||
|
glyph = XC_bottom_side;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_WEST_RESIZE:
|
||||||
|
glyph = XC_left_side;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_EAST_RESIZE:
|
||||||
|
glyph = XC_right_side;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_SE_RESIZE:
|
||||||
|
glyph = XC_bottom_right_corner;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_SW_RESIZE:
|
||||||
|
glyph = XC_bottom_left_corner;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_NE_RESIZE:
|
||||||
|
glyph = XC_top_right_corner;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_NW_RESIZE:
|
||||||
|
glyph = XC_top_left_corner;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_MOVE_OR_RESIZE_WINDOW:
|
||||||
|
glyph = XC_fleur;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_BUSY:
|
||||||
|
glyph = XC_watch;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_DND_IN_DRAG:
|
||||||
|
name = "dnd-none";
|
||||||
|
break;
|
||||||
|
case META_CURSOR_DND_MOVE:
|
||||||
|
name = "dnd-move";
|
||||||
|
break;
|
||||||
|
case META_CURSOR_DND_COPY:
|
||||||
|
name = "dnd-copy";
|
||||||
|
break;
|
||||||
|
case META_CURSOR_DND_UNSUPPORTED_TARGET:
|
||||||
|
name = "dnd-none";
|
||||||
|
break;
|
||||||
|
case META_CURSOR_POINTING_HAND:
|
||||||
|
glyph = XC_hand2;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_CROSSHAIR:
|
||||||
|
glyph = XC_crosshair;
|
||||||
|
break;
|
||||||
|
case META_CURSOR_IBEAM:
|
||||||
|
glyph = XC_xterm;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
g_assert_not_reached ();
|
||||||
|
glyph = 0; /* silence compiler */
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
*glyph_out = glyph;
|
||||||
|
*name_out = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
static Cursor
|
||||||
|
load_cursor_on_server (MetaDisplay *display,
|
||||||
|
MetaCursor cursor)
|
||||||
|
{
|
||||||
|
Cursor xcursor;
|
||||||
|
guint glyph;
|
||||||
|
const char *name;
|
||||||
|
|
||||||
|
translate_meta_cursor (cursor, &glyph, &name);
|
||||||
|
|
||||||
|
if (name != NULL)
|
||||||
|
xcursor = XcursorLibraryLoadCursor (display->xdisplay, name);
|
||||||
|
else
|
||||||
|
xcursor = XCreateFontCursor (display->xdisplay, glyph);
|
||||||
|
|
||||||
|
return xcursor;
|
||||||
|
}
|
||||||
|
|
||||||
|
Cursor
|
||||||
|
meta_display_create_x_cursor (MetaDisplay *display,
|
||||||
|
MetaCursor cursor)
|
||||||
|
{
|
||||||
|
return load_cursor_on_server (display, cursor);
|
||||||
|
}
|
||||||
|
|
||||||
|
static XcursorImage *
|
||||||
|
load_cursor_on_client (MetaDisplay *display,
|
||||||
|
MetaCursor cursor)
|
||||||
|
{
|
||||||
|
XcursorImage *image;
|
||||||
|
guint glyph;
|
||||||
|
const char *name;
|
||||||
|
const char *theme = XcursorGetTheme (display->xdisplay);
|
||||||
|
int size = XcursorGetDefaultSize (display->xdisplay);
|
||||||
|
|
||||||
|
translate_meta_cursor (cursor, &glyph, &name);
|
||||||
|
|
||||||
|
if (name != NULL)
|
||||||
|
image = XcursorLibraryLoadImage (name, theme, size);
|
||||||
|
else
|
||||||
|
image = XcursorShapeLoadImage (glyph, theme, size);
|
||||||
|
|
||||||
|
return image;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_cursor_image_load_gbm_buffer (struct gbm_device *gbm,
|
||||||
|
MetaCursorImage *image,
|
||||||
|
uint8_t *pixels,
|
||||||
|
int width,
|
||||||
|
int height,
|
||||||
|
int rowstride,
|
||||||
|
uint32_t gbm_format)
|
||||||
|
{
|
||||||
|
if (width > 64 || height > 64)
|
||||||
|
{
|
||||||
|
meta_warning ("Invalid theme cursor size (must be at most 64x64)\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gbm_device_is_format_supported (gbm, gbm_format,
|
||||||
|
GBM_BO_USE_CURSOR_64X64 | GBM_BO_USE_WRITE))
|
||||||
|
{
|
||||||
|
uint8_t buf[4 * 64 * 64];
|
||||||
|
int i;
|
||||||
|
|
||||||
|
image->bo = gbm_bo_create (gbm, 64, 64,
|
||||||
|
gbm_format, GBM_BO_USE_CURSOR_64X64 | GBM_BO_USE_WRITE);
|
||||||
|
|
||||||
|
memset (buf, 0, sizeof(buf));
|
||||||
|
for (i = 0; i < height; i++)
|
||||||
|
memcpy (buf + i * 4 * 64, pixels + i * rowstride, width * 4);
|
||||||
|
|
||||||
|
gbm_bo_write (image->bo, buf, 64 * 64 * 4);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
meta_warning ("HW cursor for format %d not supported\n", gbm_format);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_cursor_image_load_from_xcursor_image (MetaCursorTracker *tracker,
|
||||||
|
MetaCursorImage *image,
|
||||||
|
XcursorImage *xc_image)
|
||||||
|
{
|
||||||
|
int width, height, rowstride;
|
||||||
|
CoglPixelFormat cogl_format;
|
||||||
|
uint32_t gbm_format;
|
||||||
|
ClutterBackend *clutter_backend;
|
||||||
|
CoglContext *cogl_context;
|
||||||
|
|
||||||
|
width = xc_image->width;
|
||||||
|
height = xc_image->height;
|
||||||
|
rowstride = width * 4;
|
||||||
|
|
||||||
|
gbm_format = GBM_FORMAT_ARGB8888;
|
||||||
|
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
|
||||||
|
cogl_format = COGL_PIXEL_FORMAT_BGRA_8888;
|
||||||
|
#else
|
||||||
|
cogl_format = COGL_PIXEL_FORMAT_ARGB_8888;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
image->hot_x = xc_image->xhot;
|
||||||
|
image->hot_y = xc_image->yhot;
|
||||||
|
|
||||||
|
clutter_backend = clutter_get_default_backend ();
|
||||||
|
cogl_context = clutter_backend_get_cogl_context (clutter_backend);
|
||||||
|
image->texture = cogl_texture_2d_new_from_data (cogl_context,
|
||||||
|
width, height,
|
||||||
|
cogl_format,
|
||||||
|
rowstride,
|
||||||
|
(uint8_t *) xc_image->pixels,
|
||||||
|
NULL);
|
||||||
|
|
||||||
|
if (tracker->gbm)
|
||||||
|
meta_cursor_image_load_gbm_buffer (tracker->gbm,
|
||||||
|
image,
|
||||||
|
(uint8_t *) xc_image->pixels,
|
||||||
|
width, height, rowstride,
|
||||||
|
gbm_format);
|
||||||
|
}
|
||||||
|
|
||||||
|
MetaCursorReference *
|
||||||
|
meta_cursor_reference_from_theme (MetaCursorTracker *tracker,
|
||||||
|
MetaCursor cursor)
|
||||||
|
{
|
||||||
|
MetaCursorReference *self;
|
||||||
|
XcursorImage *image;
|
||||||
|
|
||||||
|
if (tracker->theme_cursors[cursor])
|
||||||
|
return meta_cursor_reference_ref (tracker->theme_cursors[cursor]);
|
||||||
|
|
||||||
|
image = load_cursor_on_client (tracker->screen->display, cursor);
|
||||||
|
if (!image)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
self = g_slice_new0 (MetaCursorReference);
|
||||||
|
self->ref_count = 1;
|
||||||
|
meta_cursor_image_load_from_xcursor_image (tracker, &self->image, image);
|
||||||
|
|
||||||
|
XcursorImageDestroy (image);
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_cursor_image_load_from_buffer (MetaCursorTracker *tracker,
|
||||||
|
MetaCursorImage *image,
|
||||||
|
struct wl_resource *buffer,
|
||||||
|
int hot_x,
|
||||||
|
int hot_y)
|
||||||
|
{
|
||||||
|
ClutterBackend *backend;
|
||||||
|
CoglContext *cogl_context;
|
||||||
|
struct wl_shm_buffer *shm_buffer;
|
||||||
|
uint32_t gbm_format;
|
||||||
|
int width, height;
|
||||||
|
|
||||||
|
image->hot_x = hot_x;
|
||||||
|
image->hot_y = hot_y;
|
||||||
|
|
||||||
|
backend = clutter_get_default_backend ();
|
||||||
|
cogl_context = clutter_backend_get_cogl_context (backend);
|
||||||
|
|
||||||
|
image->texture = cogl_wayland_texture_2d_new_from_buffer (cogl_context, buffer, NULL);
|
||||||
|
|
||||||
|
width = cogl_texture_get_width (COGL_TEXTURE (image->texture));
|
||||||
|
height = cogl_texture_get_height (COGL_TEXTURE (image->texture));
|
||||||
|
|
||||||
|
shm_buffer = wl_shm_buffer_get (buffer);
|
||||||
|
if (shm_buffer)
|
||||||
|
{
|
||||||
|
if (tracker->gbm)
|
||||||
|
{
|
||||||
|
int rowstride = wl_shm_buffer_get_stride (shm_buffer);
|
||||||
|
|
||||||
|
switch (wl_shm_buffer_get_format (shm_buffer))
|
||||||
|
{
|
||||||
|
#if G_BYTE_ORDER == G_BIG_ENDIAN
|
||||||
|
case WL_SHM_FORMAT_ARGB8888:
|
||||||
|
gbm_format = GBM_FORMAT_ARGB8888;
|
||||||
|
break;
|
||||||
|
case WL_SHM_FORMAT_XRGB8888:
|
||||||
|
gbm_format = GBM_FORMAT_XRGB8888;
|
||||||
|
break;
|
||||||
|
#else
|
||||||
|
case WL_SHM_FORMAT_ARGB8888:
|
||||||
|
gbm_format = GBM_FORMAT_ARGB8888;
|
||||||
|
break;
|
||||||
|
case WL_SHM_FORMAT_XRGB8888:
|
||||||
|
gbm_format = GBM_FORMAT_XRGB8888;
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
default:
|
||||||
|
g_warn_if_reached ();
|
||||||
|
gbm_format = GBM_FORMAT_ARGB8888;
|
||||||
|
}
|
||||||
|
|
||||||
|
meta_cursor_image_load_gbm_buffer (tracker->gbm,
|
||||||
|
image,
|
||||||
|
(uint8_t *) wl_shm_buffer_get_data (shm_buffer),
|
||||||
|
width, height, rowstride,
|
||||||
|
gbm_format);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* HW cursors must be 64x64, but 64x64 is huge, and no cursor theme actually uses
|
||||||
|
that, so themed cursors must be padded with transparent pixels to fill the
|
||||||
|
overlay. This is trivial if we have CPU access to the data, but it's not
|
||||||
|
possible if the buffer is in GPU memory (and possibly tiled too), so if we
|
||||||
|
don't get the right size, we fallback to GL.
|
||||||
|
*/
|
||||||
|
if (width != 64 || height != 64)
|
||||||
|
{
|
||||||
|
meta_warning ("Invalid cursor size (must be 64x64), falling back to software (GL) cursors\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tracker->gbm)
|
||||||
|
{
|
||||||
|
image->bo = gbm_bo_import (tracker->gbm, GBM_BO_IMPORT_WL_BUFFER,
|
||||||
|
buffer, GBM_BO_USE_CURSOR_64X64);
|
||||||
|
if (!image->bo)
|
||||||
|
meta_warning ("Importing HW cursor from wl_buffer failed\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
MetaCursorReference *
|
||||||
|
meta_cursor_reference_from_buffer (MetaCursorTracker *tracker,
|
||||||
|
struct wl_resource *buffer,
|
||||||
|
int hot_x,
|
||||||
|
int hot_y)
|
||||||
|
{
|
||||||
|
MetaCursorReference *self;
|
||||||
|
|
||||||
|
self = g_slice_new0 (MetaCursorReference);
|
||||||
|
self->ref_count = 1;
|
||||||
|
meta_cursor_image_load_from_buffer (tracker, &self->image, buffer, hot_x, hot_y);
|
||||||
|
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
CoglTexture *
|
||||||
|
meta_cursor_reference_get_cogl_texture (MetaCursorReference *cursor,
|
||||||
|
int *hot_x,
|
||||||
|
int *hot_y)
|
||||||
|
{
|
||||||
|
if (hot_x)
|
||||||
|
*hot_x = cursor->image.hot_x;
|
||||||
|
if (hot_y)
|
||||||
|
*hot_y = cursor->image.hot_y;
|
||||||
|
return COGL_TEXTURE (cursor->image.texture);
|
||||||
|
}
|
||||||
|
|
||||||
|
struct gbm_bo *
|
||||||
|
meta_cursor_reference_get_gbm_bo (MetaCursorReference *cursor,
|
||||||
|
int *hot_x,
|
||||||
|
int *hot_y)
|
||||||
|
{
|
||||||
|
if (hot_x)
|
||||||
|
*hot_x = cursor->image.hot_x;
|
||||||
|
if (hot_y)
|
||||||
|
*hot_y = cursor->image.hot_y;
|
||||||
|
return cursor->image.bo;
|
||||||
|
}
|
||||||
42
src/backends/meta-cursor.h
Normal file
42
src/backends/meta-cursor.h
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* 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/>.
|
||||||
|
*
|
||||||
|
* Author: Giovanni Campagna <gcampagn@redhat.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef META_CURSOR_H
|
||||||
|
#define META_CURSOR_H
|
||||||
|
|
||||||
|
typedef struct _MetaCursorReference MetaCursorReference;
|
||||||
|
|
||||||
|
MetaCursorReference * meta_cursor_reference_ref (MetaCursorReference *cursor);
|
||||||
|
void meta_cursor_reference_unref (MetaCursorReference *cursor);
|
||||||
|
|
||||||
|
#include <meta/meta-cursor-tracker.h>
|
||||||
|
#include <meta/common.h>
|
||||||
|
#include <wayland-server.h>
|
||||||
|
|
||||||
|
MetaCursorReference * meta_cursor_reference_from_theme (MetaCursorTracker *tracker,
|
||||||
|
MetaCursor cursor);
|
||||||
|
|
||||||
|
MetaCursorReference * meta_cursor_reference_from_buffer (MetaCursorTracker *tracker,
|
||||||
|
struct wl_resource *buffer,
|
||||||
|
int hot_x,
|
||||||
|
int hot_y);
|
||||||
|
|
||||||
|
#endif /* META_CURSOR_H */
|
||||||
@@ -13,12 +13,10 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* This file is shared between mutter (src/core/meta-xrandr-shared.h)
|
/* This file is shared between mutter (src/core/meta-display-config-shared.h)
|
||||||
and gnome-desktop (libgnome-desktop/meta-xrandr-shared.h).
|
and gnome-desktop (libgnome-desktop/meta-xrandr-shared.h).
|
||||||
|
|
||||||
The canonical place for all changes is mutter.
|
The canonical place for all changes is mutter.
|
||||||
@@ -26,8 +24,8 @@
|
|||||||
There should be no includes in this file.
|
There should be no includes in this file.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef META_XRANDR_SHARED_H
|
#ifndef META_DISPLAY_CONFIG_SHARED_H
|
||||||
#define META_XRANDR_SHARED_H
|
#define META_DISPLAY_CONFIG_SHARED_H
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
META_POWER_SAVE_UNSUPPORTED = -1,
|
META_POWER_SAVE_UNSUPPORTED = -1,
|
||||||
@@ -37,4 +35,4 @@ typedef enum {
|
|||||||
META_POWER_SAVE_OFF,
|
META_POWER_SAVE_OFF,
|
||||||
} MetaPowerSave;
|
} MetaPowerSave;
|
||||||
|
|
||||||
#endif
|
#endif /* META_DISPLAY_CONFIG_SHARED_H */
|
||||||
286
src/backends/meta-idle-monitor-dbus.c
Normal file
286
src/backends/meta-idle-monitor-dbus.c
Normal file
@@ -0,0 +1,286 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* 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/>.
|
||||||
|
*
|
||||||
|
* Adapted from gnome-session/gnome-session/gs-idle-monitor.c and
|
||||||
|
* from gnome-desktop/libgnome-desktop/gnome-idle-monitor.c
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include "meta-idle-monitor-dbus.h"
|
||||||
|
#include <meta/meta-idle-monitor.h>
|
||||||
|
#include "meta-dbus-idle-monitor.h"
|
||||||
|
|
||||||
|
#include <clutter/clutter.h>
|
||||||
|
#include <meta/util.h>
|
||||||
|
#include <meta/main.h> /* for meta_get_replace_current_wm () */
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
handle_get_idletime (MetaDBusIdleMonitor *skeleton,
|
||||||
|
GDBusMethodInvocation *invocation,
|
||||||
|
MetaIdleMonitor *monitor)
|
||||||
|
{
|
||||||
|
guint64 idletime;
|
||||||
|
|
||||||
|
idletime = meta_idle_monitor_get_idletime (monitor);
|
||||||
|
meta_dbus_idle_monitor_complete_get_idletime (skeleton, invocation, idletime);
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
MetaDBusIdleMonitor *dbus_monitor;
|
||||||
|
MetaIdleMonitor *monitor;
|
||||||
|
char *dbus_name;
|
||||||
|
guint watch_id;
|
||||||
|
guint name_watcher_id;
|
||||||
|
} DBusWatch;
|
||||||
|
|
||||||
|
static void
|
||||||
|
destroy_dbus_watch (gpointer data)
|
||||||
|
{
|
||||||
|
DBusWatch *watch = data;
|
||||||
|
|
||||||
|
g_object_unref (watch->dbus_monitor);
|
||||||
|
g_object_unref (watch->monitor);
|
||||||
|
g_free (watch->dbus_name);
|
||||||
|
g_bus_unwatch_name (watch->name_watcher_id);
|
||||||
|
|
||||||
|
g_slice_free (DBusWatch, watch);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
dbus_idle_callback (MetaIdleMonitor *monitor,
|
||||||
|
guint watch_id,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
DBusWatch *watch = user_data;
|
||||||
|
GDBusInterfaceSkeleton *skeleton = G_DBUS_INTERFACE_SKELETON (watch->dbus_monitor);
|
||||||
|
|
||||||
|
g_dbus_connection_emit_signal (g_dbus_interface_skeleton_get_connection (skeleton),
|
||||||
|
watch->dbus_name,
|
||||||
|
g_dbus_interface_skeleton_get_object_path (skeleton),
|
||||||
|
"org.gnome.Mutter.IdleMonitor",
|
||||||
|
"WatchFired",
|
||||||
|
g_variant_new ("(u)", watch_id),
|
||||||
|
NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
name_vanished_callback (GDBusConnection *connection,
|
||||||
|
const char *name,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
DBusWatch *watch = user_data;
|
||||||
|
|
||||||
|
meta_idle_monitor_remove_watch (watch->monitor, watch->watch_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
static DBusWatch *
|
||||||
|
make_dbus_watch (MetaDBusIdleMonitor *skeleton,
|
||||||
|
GDBusMethodInvocation *invocation,
|
||||||
|
MetaIdleMonitor *monitor)
|
||||||
|
{
|
||||||
|
DBusWatch *watch;
|
||||||
|
|
||||||
|
watch = g_slice_new (DBusWatch);
|
||||||
|
watch->dbus_monitor = g_object_ref (skeleton);
|
||||||
|
watch->monitor = g_object_ref (monitor);
|
||||||
|
watch->dbus_name = g_strdup (g_dbus_method_invocation_get_sender (invocation));
|
||||||
|
watch->name_watcher_id = g_bus_watch_name_on_connection (g_dbus_method_invocation_get_connection (invocation),
|
||||||
|
watch->dbus_name,
|
||||||
|
G_BUS_NAME_WATCHER_FLAGS_NONE,
|
||||||
|
NULL, /* appeared */
|
||||||
|
name_vanished_callback,
|
||||||
|
watch, NULL);
|
||||||
|
|
||||||
|
return watch;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
handle_add_idle_watch (MetaDBusIdleMonitor *skeleton,
|
||||||
|
GDBusMethodInvocation *invocation,
|
||||||
|
guint64 interval,
|
||||||
|
MetaIdleMonitor *monitor)
|
||||||
|
{
|
||||||
|
DBusWatch *watch;
|
||||||
|
|
||||||
|
watch = make_dbus_watch (skeleton, invocation, monitor);
|
||||||
|
watch->watch_id = meta_idle_monitor_add_idle_watch (monitor, interval,
|
||||||
|
dbus_idle_callback, watch, destroy_dbus_watch);
|
||||||
|
|
||||||
|
meta_dbus_idle_monitor_complete_add_idle_watch (skeleton, invocation, watch->watch_id);
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
handle_add_user_active_watch (MetaDBusIdleMonitor *skeleton,
|
||||||
|
GDBusMethodInvocation *invocation,
|
||||||
|
MetaIdleMonitor *monitor)
|
||||||
|
{
|
||||||
|
DBusWatch *watch;
|
||||||
|
|
||||||
|
watch = make_dbus_watch (skeleton, invocation, monitor);
|
||||||
|
watch->watch_id = meta_idle_monitor_add_user_active_watch (monitor,
|
||||||
|
dbus_idle_callback, watch,
|
||||||
|
destroy_dbus_watch);
|
||||||
|
|
||||||
|
meta_dbus_idle_monitor_complete_add_user_active_watch (skeleton, invocation, watch->watch_id);
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
handle_remove_watch (MetaDBusIdleMonitor *skeleton,
|
||||||
|
GDBusMethodInvocation *invocation,
|
||||||
|
guint id,
|
||||||
|
MetaIdleMonitor *monitor)
|
||||||
|
{
|
||||||
|
meta_idle_monitor_remove_watch (monitor, id);
|
||||||
|
meta_dbus_idle_monitor_complete_remove_watch (skeleton, invocation);
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
create_monitor_skeleton (GDBusObjectManagerServer *manager,
|
||||||
|
MetaIdleMonitor *monitor,
|
||||||
|
const char *path)
|
||||||
|
{
|
||||||
|
MetaDBusIdleMonitor *skeleton;
|
||||||
|
MetaDBusObjectSkeleton *object;
|
||||||
|
|
||||||
|
skeleton = meta_dbus_idle_monitor_skeleton_new ();
|
||||||
|
g_signal_connect_object (skeleton, "handle-add-idle-watch",
|
||||||
|
G_CALLBACK (handle_add_idle_watch), monitor, 0);
|
||||||
|
g_signal_connect_object (skeleton, "handle-add-user-active-watch",
|
||||||
|
G_CALLBACK (handle_add_user_active_watch), monitor, 0);
|
||||||
|
g_signal_connect_object (skeleton, "handle-remove-watch",
|
||||||
|
G_CALLBACK (handle_remove_watch), monitor, 0);
|
||||||
|
g_signal_connect_object (skeleton, "handle-get-idletime",
|
||||||
|
G_CALLBACK (handle_get_idletime), monitor, 0);
|
||||||
|
|
||||||
|
object = meta_dbus_object_skeleton_new (path);
|
||||||
|
meta_dbus_object_skeleton_set_idle_monitor (object, skeleton);
|
||||||
|
|
||||||
|
g_dbus_object_manager_server_export (manager, G_DBUS_OBJECT_SKELETON (object));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_device_added (ClutterDeviceManager *device_manager,
|
||||||
|
ClutterInputDevice *device,
|
||||||
|
GDBusObjectManagerServer *manager)
|
||||||
|
{
|
||||||
|
|
||||||
|
MetaIdleMonitor *monitor;
|
||||||
|
int device_id;
|
||||||
|
char *path;
|
||||||
|
|
||||||
|
device_id = clutter_input_device_get_device_id (device);
|
||||||
|
monitor = meta_idle_monitor_get_for_device (device_id);
|
||||||
|
path = g_strdup_printf ("/org/gnome/Mutter/IdleMonitor/Device%d", device_id);
|
||||||
|
|
||||||
|
create_monitor_skeleton (manager, monitor, path);
|
||||||
|
g_free (path);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_device_removed (ClutterDeviceManager *device_manager,
|
||||||
|
ClutterInputDevice *device,
|
||||||
|
GDBusObjectManagerServer *manager)
|
||||||
|
{
|
||||||
|
int device_id;
|
||||||
|
char *path;
|
||||||
|
|
||||||
|
device_id = clutter_input_device_get_device_id (device);
|
||||||
|
path = g_strdup_printf ("/org/gnome/Mutter/IdleMonitor/Device%d", device_id);
|
||||||
|
g_dbus_object_manager_server_unexport (manager, path);
|
||||||
|
g_free (path);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_bus_acquired (GDBusConnection *connection,
|
||||||
|
const char *name,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
GDBusObjectManagerServer *manager;
|
||||||
|
ClutterDeviceManager *device_manager;
|
||||||
|
MetaIdleMonitor *monitor;
|
||||||
|
GSList *devices, *iter;
|
||||||
|
char *path;
|
||||||
|
|
||||||
|
manager = g_dbus_object_manager_server_new ("/org/gnome/Mutter/IdleMonitor");
|
||||||
|
|
||||||
|
/* We never clear the core monitor, as that's supposed to cumulate idle times from
|
||||||
|
all devices */
|
||||||
|
monitor = meta_idle_monitor_get_core ();
|
||||||
|
path = g_strdup ("/org/gnome/Mutter/IdleMonitor/Core");
|
||||||
|
create_monitor_skeleton (manager, monitor, path);
|
||||||
|
g_free (path);
|
||||||
|
|
||||||
|
device_manager = clutter_device_manager_get_default ();
|
||||||
|
devices = clutter_device_manager_list_devices (device_manager);
|
||||||
|
|
||||||
|
for (iter = devices; iter; iter = iter->next)
|
||||||
|
on_device_added (device_manager, iter->data, manager);
|
||||||
|
|
||||||
|
g_slist_free (devices);
|
||||||
|
|
||||||
|
g_signal_connect_object (device_manager, "device-added",
|
||||||
|
G_CALLBACK (on_device_added), manager, 0);
|
||||||
|
g_signal_connect_object (device_manager, "device-removed",
|
||||||
|
G_CALLBACK (on_device_removed), manager, 0);
|
||||||
|
|
||||||
|
g_dbus_object_manager_server_set_connection (manager, connection);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_name_acquired (GDBusConnection *connection,
|
||||||
|
const char *name,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
meta_verbose ("Acquired name %s\n", name);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_name_lost (GDBusConnection *connection,
|
||||||
|
const char *name,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
meta_verbose ("Lost or failed to acquire name %s\n", name);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_idle_monitor_init_dbus (void)
|
||||||
|
{
|
||||||
|
static int dbus_name_id;
|
||||||
|
|
||||||
|
if (dbus_name_id > 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
dbus_name_id = g_bus_own_name (G_BUS_TYPE_SESSION,
|
||||||
|
"org.gnome.Mutter.IdleMonitor",
|
||||||
|
G_BUS_NAME_OWNER_FLAGS_ALLOW_REPLACEMENT |
|
||||||
|
(meta_get_replace_current_wm () ?
|
||||||
|
G_BUS_NAME_OWNER_FLAGS_REPLACE : 0),
|
||||||
|
on_bus_acquired,
|
||||||
|
on_name_acquired,
|
||||||
|
on_name_lost,
|
||||||
|
NULL, NULL);
|
||||||
|
}
|
||||||
@@ -1,8 +1,8 @@
|
|||||||
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright 2013 Red Hat, Inc.
|
* Copyright 2013 Red Hat, Inc.
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or
|
* This program is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License as
|
* modify it under the terms of the GNU General Public License as
|
||||||
* published by the Free Software Foundation; either version 2 of the
|
* published by the Free Software Foundation; either version 2 of the
|
||||||
@@ -12,19 +12,17 @@
|
|||||||
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*
|
*
|
||||||
* Adapted from gnome-session/gnome-session/gs-idle-monitor.c and
|
* Adapted from gnome-session/gnome-session/gs-idle-monitor.c and
|
||||||
* from gnome-desktop/libgnome-desktop/gnome-idle-monitor.c
|
* from gnome-desktop/libgnome-desktop/gnome-idle-monitor.c
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <meta/meta-idle-monitor.h>
|
#ifndef META_IDLE_MONITOR_DBUS_H
|
||||||
|
#define META_IDLE_MONITOR_DBUS_H
|
||||||
void meta_idle_monitor_handle_xevent_all (XEvent *xevent);
|
|
||||||
|
|
||||||
|
|
||||||
void meta_idle_monitor_init_dbus (void);
|
void meta_idle_monitor_init_dbus (void);
|
||||||
|
|
||||||
|
#endif
|
||||||
65
src/backends/meta-idle-monitor-private.h
Normal file
65
src/backends/meta-idle-monitor-private.h
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* 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/>.
|
||||||
|
*
|
||||||
|
* Adapted from gnome-session/gnome-session/gs-idle-monitor.c and
|
||||||
|
* from gnome-desktop/libgnome-desktop/gnome-idle-monitor.c
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef META_IDLE_MONITOR_PRIVATE_H
|
||||||
|
#define META_IDLE_MONITOR_PRIVATE_H
|
||||||
|
|
||||||
|
#include <meta/meta-idle-monitor.h>
|
||||||
|
#include "display-private.h"
|
||||||
|
|
||||||
|
#include <X11/Xlib.h>
|
||||||
|
#include <X11/extensions/sync.h>
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
MetaIdleMonitor *monitor;
|
||||||
|
guint id;
|
||||||
|
MetaIdleMonitorWatchFunc callback;
|
||||||
|
gpointer user_data;
|
||||||
|
GDestroyNotify notify;
|
||||||
|
guint64 timeout_msec;
|
||||||
|
int idle_source_id;
|
||||||
|
} MetaIdleMonitorWatch;
|
||||||
|
|
||||||
|
struct _MetaIdleMonitor
|
||||||
|
{
|
||||||
|
GObject parent_instance;
|
||||||
|
|
||||||
|
GHashTable *watches;
|
||||||
|
int device_id;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _MetaIdleMonitorClass
|
||||||
|
{
|
||||||
|
GObjectClass parent_class;
|
||||||
|
|
||||||
|
gint64 (*get_idletime) (MetaIdleMonitor *monitor);
|
||||||
|
MetaIdleMonitorWatch * (*make_watch) (MetaIdleMonitor *monitor,
|
||||||
|
guint64 timeout_msec,
|
||||||
|
MetaIdleMonitorWatchFunc callback,
|
||||||
|
gpointer user_data,
|
||||||
|
GDestroyNotify notify);
|
||||||
|
};
|
||||||
|
|
||||||
|
void _meta_idle_monitor_watch_fire (MetaIdleMonitorWatch *watch);
|
||||||
|
|
||||||
|
#endif /* META_IDLE_MONITOR_PRIVATE_H */
|
||||||
367
src/backends/meta-idle-monitor.c
Normal file
367
src/backends/meta-idle-monitor.c
Normal file
@@ -0,0 +1,367 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* 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/>.
|
||||||
|
*
|
||||||
|
* Adapted from gnome-session/gnome-session/gs-idle-monitor.c and
|
||||||
|
* from gnome-desktop/libgnome-desktop/gnome-idle-monitor.c
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SECTION:idle-monitor
|
||||||
|
* @title: MetaIdleMonitor
|
||||||
|
* @short_description: Mutter idle counter (similar to X's IDLETIME)
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
#include <clutter/clutter.h>
|
||||||
|
#include <X11/Xlib.h>
|
||||||
|
#include <X11/extensions/sync.h>
|
||||||
|
|
||||||
|
#include <meta/util.h>
|
||||||
|
#include <meta/main.h>
|
||||||
|
#include <meta/meta-idle-monitor.h>
|
||||||
|
#include "meta-idle-monitor-private.h"
|
||||||
|
#include "meta-idle-monitor-dbus.h"
|
||||||
|
#include "backends/x11/meta-idle-monitor-xsync.h"
|
||||||
|
#include "backends/native/meta-idle-monitor-native.h"
|
||||||
|
|
||||||
|
G_STATIC_ASSERT(sizeof(unsigned long) == sizeof(gpointer));
|
||||||
|
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
PROP_0,
|
||||||
|
PROP_DEVICE_ID,
|
||||||
|
PROP_LAST,
|
||||||
|
};
|
||||||
|
|
||||||
|
static GParamSpec *obj_props[PROP_LAST];
|
||||||
|
|
||||||
|
G_DEFINE_TYPE (MetaIdleMonitor, meta_idle_monitor, G_TYPE_OBJECT)
|
||||||
|
|
||||||
|
static MetaIdleMonitor *device_monitors[256];
|
||||||
|
static int device_id_max;
|
||||||
|
|
||||||
|
void
|
||||||
|
_meta_idle_monitor_watch_fire (MetaIdleMonitorWatch *watch)
|
||||||
|
{
|
||||||
|
MetaIdleMonitor *monitor;
|
||||||
|
guint id;
|
||||||
|
gboolean is_user_active_watch;
|
||||||
|
|
||||||
|
monitor = watch->monitor;
|
||||||
|
g_object_ref (monitor);
|
||||||
|
|
||||||
|
if (watch->idle_source_id)
|
||||||
|
{
|
||||||
|
g_source_remove (watch->idle_source_id);
|
||||||
|
watch->idle_source_id = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
id = watch->id;
|
||||||
|
is_user_active_watch = (watch->timeout_msec == 0);
|
||||||
|
|
||||||
|
if (watch->callback)
|
||||||
|
watch->callback (monitor, id, watch->user_data);
|
||||||
|
|
||||||
|
if (is_user_active_watch)
|
||||||
|
meta_idle_monitor_remove_watch (monitor, id);
|
||||||
|
|
||||||
|
g_object_unref (monitor);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_idle_monitor_dispose (GObject *object)
|
||||||
|
{
|
||||||
|
MetaIdleMonitor *monitor = META_IDLE_MONITOR (object);
|
||||||
|
|
||||||
|
g_clear_pointer (&monitor->watches, g_hash_table_destroy);
|
||||||
|
|
||||||
|
G_OBJECT_CLASS (meta_idle_monitor_parent_class)->dispose (object);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_idle_monitor_get_property (GObject *object,
|
||||||
|
guint prop_id,
|
||||||
|
GValue *value,
|
||||||
|
GParamSpec *pspec)
|
||||||
|
{
|
||||||
|
MetaIdleMonitor *monitor = META_IDLE_MONITOR (object);
|
||||||
|
|
||||||
|
switch (prop_id)
|
||||||
|
{
|
||||||
|
case PROP_DEVICE_ID:
|
||||||
|
g_value_set_int (value, monitor->device_id);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_idle_monitor_set_property (GObject *object,
|
||||||
|
guint prop_id,
|
||||||
|
const GValue *value,
|
||||||
|
GParamSpec *pspec)
|
||||||
|
{
|
||||||
|
MetaIdleMonitor *monitor = META_IDLE_MONITOR (object);
|
||||||
|
switch (prop_id)
|
||||||
|
{
|
||||||
|
case PROP_DEVICE_ID:
|
||||||
|
monitor->device_id = g_value_get_int (value);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_idle_monitor_class_init (MetaIdleMonitorClass *klass)
|
||||||
|
{
|
||||||
|
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
||||||
|
|
||||||
|
object_class->dispose = meta_idle_monitor_dispose;
|
||||||
|
object_class->get_property = meta_idle_monitor_get_property;
|
||||||
|
object_class->set_property = meta_idle_monitor_set_property;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* MetaIdleMonitor:device_id:
|
||||||
|
*
|
||||||
|
* The device to listen to idletime on.
|
||||||
|
*/
|
||||||
|
obj_props[PROP_DEVICE_ID] =
|
||||||
|
g_param_spec_int ("device-id",
|
||||||
|
"Device ID",
|
||||||
|
"The device to listen to idletime on",
|
||||||
|
0, 255, 0,
|
||||||
|
G_PARAM_STATIC_STRINGS | G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY);
|
||||||
|
g_object_class_install_property (object_class, PROP_DEVICE_ID, obj_props[PROP_DEVICE_ID]);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_idle_monitor_init (MetaIdleMonitor *monitor)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
static GType
|
||||||
|
get_idle_monitor_type (void)
|
||||||
|
{
|
||||||
|
if (meta_is_wayland_compositor ())
|
||||||
|
return META_TYPE_IDLE_MONITOR_NATIVE;
|
||||||
|
else
|
||||||
|
return META_TYPE_IDLE_MONITOR_XSYNC;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
ensure_device_monitor (int device_id)
|
||||||
|
{
|
||||||
|
if (device_monitors[device_id])
|
||||||
|
return;
|
||||||
|
|
||||||
|
device_monitors[device_id] = g_object_new (get_idle_monitor_type (),
|
||||||
|
"device-id", device_id,
|
||||||
|
NULL);
|
||||||
|
device_id_max = MAX (device_id_max, device_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* FIXME -- destroy device monitors at some point */
|
||||||
|
G_GNUC_UNUSED static void
|
||||||
|
destroy_device_monitor (int device_id)
|
||||||
|
{
|
||||||
|
g_clear_object (&device_monitors[device_id]);
|
||||||
|
if (device_id == device_id_max)
|
||||||
|
device_id_max--;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* meta_idle_monitor_get_core:
|
||||||
|
*
|
||||||
|
* Returns: (transfer none): the #MetaIdleMonitor that tracks the server-global
|
||||||
|
* idletime for all devices. To track device-specific idletime,
|
||||||
|
* use meta_idle_monitor_get_for_device().
|
||||||
|
*/
|
||||||
|
MetaIdleMonitor *
|
||||||
|
meta_idle_monitor_get_core (void)
|
||||||
|
{
|
||||||
|
ensure_device_monitor (0);
|
||||||
|
return device_monitors[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* meta_idle_monitor_get_for_device:
|
||||||
|
* @device_id: the device to get the idle time for.
|
||||||
|
*
|
||||||
|
* Returns: (transfer none): a new #MetaIdleMonitor that tracks the
|
||||||
|
* device-specific idletime for @device. To track server-global idletime
|
||||||
|
* for all devices, use meta_idle_monitor_get_core().
|
||||||
|
*/
|
||||||
|
MetaIdleMonitor *
|
||||||
|
meta_idle_monitor_get_for_device (int device_id)
|
||||||
|
{
|
||||||
|
g_return_val_if_fail (device_id > 0 && device_id < 256, NULL);
|
||||||
|
|
||||||
|
ensure_device_monitor (device_id);
|
||||||
|
return device_monitors[device_id];
|
||||||
|
}
|
||||||
|
|
||||||
|
static MetaIdleMonitorWatch *
|
||||||
|
make_watch (MetaIdleMonitor *monitor,
|
||||||
|
guint64 timeout_msec,
|
||||||
|
MetaIdleMonitorWatchFunc callback,
|
||||||
|
gpointer user_data,
|
||||||
|
GDestroyNotify notify)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorWatch *watch;
|
||||||
|
|
||||||
|
watch = META_IDLE_MONITOR_GET_CLASS (monitor)->make_watch (monitor,
|
||||||
|
timeout_msec,
|
||||||
|
callback,
|
||||||
|
user_data,
|
||||||
|
notify);
|
||||||
|
|
||||||
|
g_hash_table_insert (monitor->watches,
|
||||||
|
GUINT_TO_POINTER (watch->id),
|
||||||
|
watch);
|
||||||
|
return watch;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* meta_idle_monitor_add_idle_watch:
|
||||||
|
* @monitor: A #MetaIdleMonitor
|
||||||
|
* @interval_msec: The idletime interval, in milliseconds
|
||||||
|
* @callback: (allow-none): The callback to call when the user has
|
||||||
|
* accumulated @interval_msec milliseconds of idle time.
|
||||||
|
* @user_data: (allow-none): The user data to pass to the callback
|
||||||
|
* @notify: A #GDestroyNotify
|
||||||
|
*
|
||||||
|
* Returns: a watch id
|
||||||
|
*
|
||||||
|
* Adds a watch for a specific idle time. The callback will be called
|
||||||
|
* when the user has accumulated @interval_msec milliseconds of idle time.
|
||||||
|
* This function will return an ID that can either be passed to
|
||||||
|
* meta_idle_monitor_remove_watch(), or can be used to tell idle time
|
||||||
|
* watches apart if you have more than one.
|
||||||
|
*
|
||||||
|
* Also note that this function will only care about positive transitions
|
||||||
|
* (user's idle time exceeding a certain time). If you want to know about
|
||||||
|
* when the user has become active, use
|
||||||
|
* meta_idle_monitor_add_user_active_watch().
|
||||||
|
*/
|
||||||
|
guint
|
||||||
|
meta_idle_monitor_add_idle_watch (MetaIdleMonitor *monitor,
|
||||||
|
guint64 interval_msec,
|
||||||
|
MetaIdleMonitorWatchFunc callback,
|
||||||
|
gpointer user_data,
|
||||||
|
GDestroyNotify notify)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorWatch *watch;
|
||||||
|
|
||||||
|
g_return_val_if_fail (META_IS_IDLE_MONITOR (monitor), 0);
|
||||||
|
g_return_val_if_fail (interval_msec > 0, 0);
|
||||||
|
|
||||||
|
watch = make_watch (monitor,
|
||||||
|
interval_msec,
|
||||||
|
callback,
|
||||||
|
user_data,
|
||||||
|
notify);
|
||||||
|
|
||||||
|
return watch->id;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* meta_idle_monitor_add_user_active_watch:
|
||||||
|
* @monitor: A #MetaIdleMonitor
|
||||||
|
* @callback: (allow-none): The callback to call when the user is
|
||||||
|
* active again.
|
||||||
|
* @user_data: (allow-none): The user data to pass to the callback
|
||||||
|
* @notify: A #GDestroyNotify
|
||||||
|
*
|
||||||
|
* Returns: a watch id
|
||||||
|
*
|
||||||
|
* Add a one-time watch to know when the user is active again.
|
||||||
|
* Note that this watch is one-time and will de-activate after the
|
||||||
|
* function is called, for efficiency purposes. It's most convenient
|
||||||
|
* to call this when an idle watch, as added by
|
||||||
|
* meta_idle_monitor_add_idle_watch(), has triggered.
|
||||||
|
*/
|
||||||
|
guint
|
||||||
|
meta_idle_monitor_add_user_active_watch (MetaIdleMonitor *monitor,
|
||||||
|
MetaIdleMonitorWatchFunc callback,
|
||||||
|
gpointer user_data,
|
||||||
|
GDestroyNotify notify)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorWatch *watch;
|
||||||
|
|
||||||
|
g_return_val_if_fail (META_IS_IDLE_MONITOR (monitor), 0);
|
||||||
|
|
||||||
|
watch = make_watch (monitor,
|
||||||
|
0,
|
||||||
|
callback,
|
||||||
|
user_data,
|
||||||
|
notify);
|
||||||
|
|
||||||
|
return watch->id;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* meta_idle_monitor_remove_watch:
|
||||||
|
* @monitor: A #MetaIdleMonitor
|
||||||
|
* @id: A watch ID
|
||||||
|
*
|
||||||
|
* Removes an idle time watcher, previously added by
|
||||||
|
* meta_idle_monitor_add_idle_watch() or
|
||||||
|
* meta_idle_monitor_add_user_active_watch().
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
meta_idle_monitor_remove_watch (MetaIdleMonitor *monitor,
|
||||||
|
guint id)
|
||||||
|
{
|
||||||
|
g_return_if_fail (META_IS_IDLE_MONITOR (monitor));
|
||||||
|
|
||||||
|
g_object_ref (monitor);
|
||||||
|
g_hash_table_remove (monitor->watches,
|
||||||
|
GUINT_TO_POINTER (id));
|
||||||
|
g_object_unref (monitor);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* meta_idle_monitor_get_idletime:
|
||||||
|
* @monitor: A #MetaIdleMonitor
|
||||||
|
*
|
||||||
|
* Returns: The current idle time, in milliseconds, or -1 for not supported
|
||||||
|
*/
|
||||||
|
gint64
|
||||||
|
meta_idle_monitor_get_idletime (MetaIdleMonitor *monitor)
|
||||||
|
{
|
||||||
|
return META_IDLE_MONITOR_GET_CLASS (monitor)->get_idletime (monitor);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_idle_monitor_xsync_handle_xevent_all (XEvent *xevent)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (meta_is_wayland_compositor ())
|
||||||
|
return;
|
||||||
|
|
||||||
|
for (i = 0; i <= device_id_max; i++)
|
||||||
|
if (device_monitors[i])
|
||||||
|
meta_idle_monitor_xsync_handle_xevent (device_monitors[i], (XSyncAlarmNotifyEvent*)xevent);
|
||||||
|
}
|
||||||
@@ -20,9 +20,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -36,13 +34,14 @@
|
|||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
|
#include "meta-monitor-config.h"
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <clutter/clutter.h>
|
#include <clutter/clutter.h>
|
||||||
#include <libupower-glib/upower.h>
|
#include <libupower-glib/upower.h>
|
||||||
|
|
||||||
#include <meta/main.h>
|
#include <meta/main.h>
|
||||||
#include <meta/errors.h>
|
#include <meta/errors.h>
|
||||||
#include "monitor-private.h"
|
|
||||||
|
|
||||||
/* These structures represent the intended/persistent configuration,
|
/* These structures represent the intended/persistent configuration,
|
||||||
as stored in the monitors.xml file.
|
as stored in the monitors.xml file.
|
||||||
@@ -99,8 +98,9 @@ static gboolean meta_monitor_config_assign_crtcs (MetaConfiguration *config,
|
|||||||
GPtrArray *crtcs,
|
GPtrArray *crtcs,
|
||||||
GPtrArray *outputs);
|
GPtrArray *outputs);
|
||||||
|
|
||||||
static void power_client_changed_cb (UpClient *client,
|
static void power_client_changed_cb (UpClient *client,
|
||||||
gpointer user_data);
|
GParamSpec *pspec,
|
||||||
|
gpointer user_data);
|
||||||
|
|
||||||
static void
|
static void
|
||||||
free_output_key (MetaOutputKey *key)
|
free_output_key (MetaOutputKey *key)
|
||||||
@@ -232,7 +232,7 @@ meta_monitor_config_init (MetaMonitorConfig *self)
|
|||||||
self->up_client = up_client_new ();
|
self->up_client = up_client_new ();
|
||||||
self->lid_is_closed = up_client_get_lid_is_closed (self->up_client);
|
self->lid_is_closed = up_client_get_lid_is_closed (self->up_client);
|
||||||
|
|
||||||
g_signal_connect_object (self->up_client, "changed",
|
g_signal_connect_object (self->up_client, "notify::lid-is-closed",
|
||||||
G_CALLBACK (power_client_changed_cb), self, 0);
|
G_CALLBACK (power_client_changed_cb), self, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -840,9 +840,6 @@ meta_monitor_config_get_stored (MetaMonitorConfig *self,
|
|||||||
MetaConfiguration key;
|
MetaConfiguration key;
|
||||||
MetaConfiguration *stored;
|
MetaConfiguration *stored;
|
||||||
|
|
||||||
if (n_outputs == 0)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
make_config_key (&key, outputs, n_outputs, -1);
|
make_config_key (&key, outputs, n_outputs, -1);
|
||||||
stored = g_hash_table_lookup (self->configs, &key);
|
stored = g_hash_table_lookup (self->configs, &key);
|
||||||
|
|
||||||
@@ -1250,12 +1247,6 @@ meta_monitor_config_make_default (MetaMonitorConfig *self,
|
|||||||
outputs = meta_monitor_manager_get_outputs (manager, &n_outputs);
|
outputs = meta_monitor_manager_get_outputs (manager, &n_outputs);
|
||||||
meta_monitor_manager_get_screen_limits (manager, &max_width, &max_height);
|
meta_monitor_manager_get_screen_limits (manager, &max_width, &max_height);
|
||||||
|
|
||||||
if (n_outputs == 0)
|
|
||||||
{
|
|
||||||
meta_verbose ("No output connected, not applying configuration\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
default_config = make_default_config (self, outputs, n_outputs, max_width, max_height);
|
default_config = make_default_config (self, outputs, n_outputs, max_width, max_height);
|
||||||
|
|
||||||
if (default_config != NULL)
|
if (default_config != NULL)
|
||||||
@@ -1360,8 +1351,9 @@ turn_off_laptop_display (MetaMonitorConfig *self,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
power_client_changed_cb (UpClient *client,
|
power_client_changed_cb (UpClient *client,
|
||||||
gpointer user_data)
|
GParamSpec *pspec,
|
||||||
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
MetaMonitorManager *manager = meta_monitor_manager_get ();
|
MetaMonitorManager *manager = meta_monitor_manager_get ();
|
||||||
MetaMonitorConfig *self = user_data;
|
MetaMonitorConfig *self = user_data;
|
||||||
55
src/backends/meta-monitor-config.h
Normal file
55
src/backends/meta-monitor-config.h
Normal file
@@ -0,0 +1,55 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2001 Havoc Pennington
|
||||||
|
* Copyright (C) 2003 Rob Adams
|
||||||
|
* Copyright (C) 2004-2006 Elijah Newren
|
||||||
|
* Copyright (C) 2013 Red Hat Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation; either version 2 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef META_MONITOR_CONFIG_H
|
||||||
|
#define META_MONITOR_CONFIG_H
|
||||||
|
|
||||||
|
#include "meta-monitor-manager.h"
|
||||||
|
|
||||||
|
#define META_TYPE_MONITOR_CONFIG (meta_monitor_config_get_type ())
|
||||||
|
#define META_MONITOR_CONFIG(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_MONITOR_CONFIG, MetaMonitorConfig))
|
||||||
|
#define META_MONITOR_CONFIG_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), META_TYPE_MONITOR_CONFIG, MetaMonitorConfigClass))
|
||||||
|
#define META_IS_MONITOR_CONFIG(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_MONITOR_CONFIG))
|
||||||
|
#define META_IS_MONITOR_CONFIG_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), META_TYPE_MONITOR_CONFIG))
|
||||||
|
#define META_MONITOR_CONFIG_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), META_TYPE_MONITOR_CONFIG, MetaMonitorConfigClass))
|
||||||
|
|
||||||
|
GType meta_monitor_config_get_type (void) G_GNUC_CONST;
|
||||||
|
|
||||||
|
MetaMonitorConfig *meta_monitor_config_new (void);
|
||||||
|
|
||||||
|
gboolean meta_monitor_config_match_current (MetaMonitorConfig *config,
|
||||||
|
MetaMonitorManager *manager);
|
||||||
|
|
||||||
|
gboolean meta_monitor_config_apply_stored (MetaMonitorConfig *config,
|
||||||
|
MetaMonitorManager *manager);
|
||||||
|
|
||||||
|
void meta_monitor_config_make_default (MetaMonitorConfig *config,
|
||||||
|
MetaMonitorManager *manager);
|
||||||
|
|
||||||
|
void meta_monitor_config_update_current (MetaMonitorConfig *config,
|
||||||
|
MetaMonitorManager *manager);
|
||||||
|
void meta_monitor_config_make_persistent (MetaMonitorConfig *config);
|
||||||
|
|
||||||
|
void meta_monitor_config_restore_previous (MetaMonitorConfig *config,
|
||||||
|
MetaMonitorManager *manager);
|
||||||
|
|
||||||
|
#endif /* META_MONITOR_CONFIG_H */
|
||||||
227
src/backends/meta-monitor-manager-dummy.c
Normal file
227
src/backends/meta-monitor-manager-dummy.c
Normal file
@@ -0,0 +1,227 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2001, 2002 Havoc Pennington
|
||||||
|
* Copyright (C) 2002, 2003 Red Hat Inc.
|
||||||
|
* Some ICCCM manager selection code derived from fvwm2,
|
||||||
|
* Copyright (C) 2001 Dominik Vogt, Matthias Clasen, and fvwm2 team
|
||||||
|
* Copyright (C) 2003 Rob Adams
|
||||||
|
* Copyright (C) 2004-2006 Elijah Newren
|
||||||
|
* Copyright (C) 2013 Red Hat Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation; either version 2 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include "meta-monitor-manager-dummy.h"
|
||||||
|
|
||||||
|
#define ALL_WL_TRANSFORMS ((1 << (WL_OUTPUT_TRANSFORM_FLIPPED_270 + 1)) - 1)
|
||||||
|
|
||||||
|
struct _MetaMonitorManagerDummy
|
||||||
|
{
|
||||||
|
MetaMonitorManager parent_instance;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _MetaMonitorManagerDummyClass
|
||||||
|
{
|
||||||
|
MetaMonitorManagerClass parent_class;
|
||||||
|
};
|
||||||
|
|
||||||
|
G_DEFINE_TYPE (MetaMonitorManagerDummy, meta_monitor_manager_dummy, META_TYPE_MONITOR_MANAGER);
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_manager_dummy_read_current (MetaMonitorManager *manager)
|
||||||
|
{
|
||||||
|
manager->max_screen_width = 65535;
|
||||||
|
manager->max_screen_height = 65535;
|
||||||
|
manager->screen_width = 1024;
|
||||||
|
manager->screen_height = 768;
|
||||||
|
|
||||||
|
manager->modes = g_new0 (MetaMonitorMode, 1);
|
||||||
|
manager->n_modes = 1;
|
||||||
|
|
||||||
|
manager->modes[0].mode_id = 0;
|
||||||
|
manager->modes[0].width = 1024;
|
||||||
|
manager->modes[0].height = 768;
|
||||||
|
manager->modes[0].refresh_rate = 60.0;
|
||||||
|
|
||||||
|
manager->crtcs = g_new0 (MetaCRTC, 1);
|
||||||
|
manager->n_crtcs = 1;
|
||||||
|
|
||||||
|
manager->crtcs[0].crtc_id = 1;
|
||||||
|
manager->crtcs[0].rect.x = 0;
|
||||||
|
manager->crtcs[0].rect.y = 0;
|
||||||
|
manager->crtcs[0].rect.width = manager->modes[0].width;
|
||||||
|
manager->crtcs[0].rect.height = manager->modes[0].height;
|
||||||
|
manager->crtcs[0].current_mode = &manager->modes[0];
|
||||||
|
manager->crtcs[0].transform = WL_OUTPUT_TRANSFORM_NORMAL;
|
||||||
|
manager->crtcs[0].all_transforms = ALL_WL_TRANSFORMS;
|
||||||
|
manager->crtcs[0].is_dirty = FALSE;
|
||||||
|
manager->crtcs[0].logical_monitor = NULL;
|
||||||
|
|
||||||
|
manager->outputs = g_new0 (MetaOutput, 1);
|
||||||
|
manager->n_outputs = 1;
|
||||||
|
|
||||||
|
manager->outputs[0].crtc = &manager->crtcs[0];
|
||||||
|
manager->outputs[0].output_id = 1;
|
||||||
|
manager->outputs[0].name = g_strdup ("LVDS");
|
||||||
|
manager->outputs[0].vendor = g_strdup ("MetaProducts Inc.");
|
||||||
|
manager->outputs[0].product = g_strdup ("unknown");
|
||||||
|
manager->outputs[0].serial = g_strdup ("0xC0FFEE");
|
||||||
|
manager->outputs[0].width_mm = 222;
|
||||||
|
manager->outputs[0].height_mm = 125;
|
||||||
|
manager->outputs[0].subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN;
|
||||||
|
manager->outputs[0].preferred_mode = &manager->modes[0];
|
||||||
|
manager->outputs[0].n_modes = 1;
|
||||||
|
manager->outputs[0].modes = g_new0 (MetaMonitorMode *, 1);
|
||||||
|
manager->outputs[0].modes[0] = &manager->modes[0];
|
||||||
|
manager->outputs[0].n_possible_crtcs = 1;
|
||||||
|
manager->outputs[0].possible_crtcs = g_new0 (MetaCRTC *, 1);
|
||||||
|
manager->outputs[0].possible_crtcs[0] = &manager->crtcs[0];
|
||||||
|
manager->outputs[0].n_possible_clones = 0;
|
||||||
|
manager->outputs[0].possible_clones = g_new0 (MetaOutput *, 0);
|
||||||
|
manager->outputs[0].backlight = -1;
|
||||||
|
manager->outputs[0].backlight_min = 0;
|
||||||
|
manager->outputs[0].backlight_max = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_manager_dummy_apply_config (MetaMonitorManager *manager,
|
||||||
|
MetaCRTCInfo **crtcs,
|
||||||
|
unsigned int n_crtcs,
|
||||||
|
MetaOutputInfo **outputs,
|
||||||
|
unsigned int n_outputs)
|
||||||
|
{
|
||||||
|
unsigned i;
|
||||||
|
int screen_width = 0, screen_height = 0;
|
||||||
|
|
||||||
|
for (i = 0; i < n_crtcs; i++)
|
||||||
|
{
|
||||||
|
MetaCRTCInfo *crtc_info = crtcs[i];
|
||||||
|
MetaCRTC *crtc = crtc_info->crtc;
|
||||||
|
crtc->is_dirty = TRUE;
|
||||||
|
|
||||||
|
if (crtc_info->mode == NULL)
|
||||||
|
{
|
||||||
|
crtc->rect.x = 0;
|
||||||
|
crtc->rect.y = 0;
|
||||||
|
crtc->rect.width = 0;
|
||||||
|
crtc->rect.height = 0;
|
||||||
|
crtc->current_mode = NULL;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
MetaMonitorMode *mode;
|
||||||
|
MetaOutput *output;
|
||||||
|
int i, n_outputs;
|
||||||
|
int width, height;
|
||||||
|
|
||||||
|
mode = crtc_info->mode;
|
||||||
|
|
||||||
|
if (meta_monitor_transform_is_rotated (crtc_info->transform))
|
||||||
|
{
|
||||||
|
width = mode->height;
|
||||||
|
height = mode->width;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
width = mode->width;
|
||||||
|
height = mode->height;
|
||||||
|
}
|
||||||
|
|
||||||
|
crtc->rect.x = crtc_info->x;
|
||||||
|
crtc->rect.y = crtc_info->y;
|
||||||
|
crtc->rect.width = width;
|
||||||
|
crtc->rect.height = height;
|
||||||
|
crtc->current_mode = mode;
|
||||||
|
crtc->transform = crtc_info->transform;
|
||||||
|
|
||||||
|
screen_width = MAX (screen_width, crtc_info->x + width);
|
||||||
|
screen_height = MAX (screen_height, crtc_info->y + height);
|
||||||
|
|
||||||
|
n_outputs = crtc_info->outputs->len;
|
||||||
|
for (i = 0; i < n_outputs; i++)
|
||||||
|
{
|
||||||
|
output = ((MetaOutput**)crtc_info->outputs->pdata)[i];
|
||||||
|
|
||||||
|
output->is_dirty = TRUE;
|
||||||
|
output->crtc = crtc;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < n_outputs; i++)
|
||||||
|
{
|
||||||
|
MetaOutputInfo *output_info = outputs[i];
|
||||||
|
MetaOutput *output = output_info->output;
|
||||||
|
|
||||||
|
output->is_primary = output_info->is_primary;
|
||||||
|
output->is_presentation = output_info->is_presentation;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Disable CRTCs not mentioned in the list */
|
||||||
|
for (i = 0; i < manager->n_crtcs; i++)
|
||||||
|
{
|
||||||
|
MetaCRTC *crtc = &manager->crtcs[i];
|
||||||
|
|
||||||
|
crtc->logical_monitor = NULL;
|
||||||
|
|
||||||
|
if (crtc->is_dirty)
|
||||||
|
{
|
||||||
|
crtc->is_dirty = FALSE;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
crtc->rect.x = 0;
|
||||||
|
crtc->rect.y = 0;
|
||||||
|
crtc->rect.width = 0;
|
||||||
|
crtc->rect.height = 0;
|
||||||
|
crtc->current_mode = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Disable outputs not mentioned in the list */
|
||||||
|
for (i = 0; i < manager->n_outputs; i++)
|
||||||
|
{
|
||||||
|
MetaOutput *output = &manager->outputs[i];
|
||||||
|
|
||||||
|
if (output->is_dirty)
|
||||||
|
{
|
||||||
|
output->is_dirty = FALSE;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
output->crtc = NULL;
|
||||||
|
output->is_primary = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
manager->screen_width = screen_width;
|
||||||
|
manager->screen_height = screen_height;
|
||||||
|
|
||||||
|
meta_monitor_manager_rebuild_derived (manager);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_manager_dummy_class_init (MetaMonitorManagerDummyClass *klass)
|
||||||
|
{
|
||||||
|
MetaMonitorManagerClass *manager_class = META_MONITOR_MANAGER_CLASS (klass);
|
||||||
|
|
||||||
|
manager_class->read_current = meta_monitor_manager_dummy_read_current;
|
||||||
|
manager_class->apply_configuration = meta_monitor_manager_dummy_apply_config;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_manager_dummy_init (MetaMonitorManagerDummy *manager)
|
||||||
|
{
|
||||||
|
}
|
||||||
40
src/backends/meta-monitor-manager-dummy.h
Normal file
40
src/backends/meta-monitor-manager-dummy.h
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2001 Havoc Pennington
|
||||||
|
* Copyright (C) 2003 Rob Adams
|
||||||
|
* Copyright (C) 2004-2006 Elijah Newren
|
||||||
|
* Copyright (C) 2013 Red Hat Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation; either version 2 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef META_MONITOR_MANAGER_DUMMY_H
|
||||||
|
#define META_MONITOR_MANAGER_DUMMY_H
|
||||||
|
|
||||||
|
#include "meta-monitor-manager.h"
|
||||||
|
|
||||||
|
#define META_TYPE_MONITOR_MANAGER_DUMMY (meta_monitor_manager_dummy_get_type ())
|
||||||
|
#define META_MONITOR_MANAGER_DUMMY(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_MONITOR_MANAGER_DUMMY, MetaMonitorManagerDummy))
|
||||||
|
#define META_MONITOR_MANAGER_DUMMY_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), META_TYPE_MONITOR_MANAGER_DUMMY, MetaMonitorManagerDummyClass))
|
||||||
|
#define META_IS_MONITOR_MANAGER_DUMMY(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_MONITOR_MANAGER_DUMMY))
|
||||||
|
#define META_IS_MONITOR_MANAGER_DUMMY_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), META_TYPE_MONITOR_MANAGER_DUMMY))
|
||||||
|
#define META_MONITOR_MANAGER_DUMMY_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), META_TYPE_MONITOR_MANAGER_DUMMY, MetaMonitorManagerDummyClass))
|
||||||
|
|
||||||
|
typedef struct _MetaMonitorManagerDummyClass MetaMonitorManagerDummyClass;
|
||||||
|
typedef struct _MetaMonitorManagerDummy MetaMonitorManagerDummy;
|
||||||
|
|
||||||
|
GType meta_monitor_manager_dummy_get_type (void);
|
||||||
|
|
||||||
|
#endif /* META_MONITOR_MANAGER_DUMMY_H */
|
||||||
@@ -20,26 +20,25 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
|
#include "meta-monitor-manager.h"
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <clutter/clutter.h>
|
#include <clutter/clutter.h>
|
||||||
|
|
||||||
#include <meta/main.h>
|
#include <meta/main.h>
|
||||||
#include <meta/util.h>
|
#include "util-private.h"
|
||||||
#include <meta/errors.h>
|
#include <meta/errors.h>
|
||||||
#include "monitor-private.h"
|
#include "meta-monitor-config.h"
|
||||||
|
#include "backends/native/meta-monitor-manager-kms.h"
|
||||||
#include "meta-dbus-xrandr.h"
|
#include "backends/x11/meta-monitor-manager-xrandr.h"
|
||||||
|
#include "meta-monitor-manager-dummy.h"
|
||||||
#define ALL_WL_TRANSFORMS ((1 << (WL_OUTPUT_TRANSFORM_FLIPPED_270 + 1)) - 1)
|
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
CONFIRM_DISPLAY_CHANGE,
|
CONFIRM_DISPLAY_CHANGE,
|
||||||
@@ -56,313 +55,11 @@ static int signals[SIGNALS_LAST];
|
|||||||
|
|
||||||
static void meta_monitor_manager_display_config_init (MetaDBusDisplayConfigIface *iface);
|
static void meta_monitor_manager_display_config_init (MetaDBusDisplayConfigIface *iface);
|
||||||
|
|
||||||
G_DEFINE_TYPE_WITH_CODE (MetaMonitorManager, meta_monitor_manager, META_DBUS_TYPE_DISPLAY_CONFIG_SKELETON,
|
G_DEFINE_ABSTRACT_TYPE_WITH_CODE (MetaMonitorManager, meta_monitor_manager, META_DBUS_TYPE_DISPLAY_CONFIG_SKELETON,
|
||||||
G_IMPLEMENT_INTERFACE (META_DBUS_TYPE_DISPLAY_CONFIG, meta_monitor_manager_display_config_init));
|
G_IMPLEMENT_INTERFACE (META_DBUS_TYPE_DISPLAY_CONFIG, meta_monitor_manager_display_config_init));
|
||||||
|
|
||||||
static void initialize_dbus_interface (MetaMonitorManager *manager);
|
static void initialize_dbus_interface (MetaMonitorManager *manager);
|
||||||
|
|
||||||
static void
|
|
||||||
read_current_dummy (MetaMonitorManager *manager)
|
|
||||||
{
|
|
||||||
/* The dummy monitor config has:
|
|
||||||
- one enabled output, LVDS, primary, at 0x0 and 1024x768
|
|
||||||
- one free CRTC
|
|
||||||
- two disabled outputs
|
|
||||||
- three modes, 1024x768, 800x600 and 640x480
|
|
||||||
- no clones are possible (use different CRTCs)
|
|
||||||
|
|
||||||
Low-level IDs should be assigned sequentially, to
|
|
||||||
mimick what XRandR and KMS do
|
|
||||||
*/
|
|
||||||
|
|
||||||
manager->max_screen_width = 65535;
|
|
||||||
manager->max_screen_height = 65535;
|
|
||||||
manager->screen_width = 1024;
|
|
||||||
manager->screen_height = 768;
|
|
||||||
|
|
||||||
manager->modes = g_new0 (MetaMonitorMode, 6);
|
|
||||||
manager->n_modes = 6;
|
|
||||||
|
|
||||||
manager->modes[0].mode_id = 1;
|
|
||||||
manager->modes[0].width = 1024;
|
|
||||||
manager->modes[0].height = 768;
|
|
||||||
manager->modes[0].refresh_rate = 60.0;
|
|
||||||
|
|
||||||
manager->modes[1].mode_id = 2;
|
|
||||||
manager->modes[1].width = 800;
|
|
||||||
manager->modes[1].height = 600;
|
|
||||||
manager->modes[1].refresh_rate = 60.0;
|
|
||||||
|
|
||||||
manager->modes[2].mode_id = 3;
|
|
||||||
manager->modes[2].width = 640;
|
|
||||||
manager->modes[2].height = 480;
|
|
||||||
manager->modes[2].refresh_rate = 60.0;
|
|
||||||
|
|
||||||
manager->modes[3].mode_id = 4;
|
|
||||||
manager->modes[3].width = 1920;
|
|
||||||
manager->modes[3].height = 1080;
|
|
||||||
manager->modes[3].refresh_rate = 60.0;
|
|
||||||
|
|
||||||
manager->modes[4].mode_id = 5;
|
|
||||||
manager->modes[4].width = 1920;
|
|
||||||
manager->modes[4].height = 1080;
|
|
||||||
manager->modes[4].refresh_rate = 55.0;
|
|
||||||
|
|
||||||
manager->modes[5].mode_id = 6;
|
|
||||||
manager->modes[5].width = 1600;
|
|
||||||
manager->modes[5].height = 900;
|
|
||||||
manager->modes[5].refresh_rate = 60.0;
|
|
||||||
|
|
||||||
manager->crtcs = g_new0 (MetaCRTC, 3);
|
|
||||||
manager->n_crtcs = 3;
|
|
||||||
|
|
||||||
manager->crtcs[0].crtc_id = 4;
|
|
||||||
manager->crtcs[0].rect.x = 0;
|
|
||||||
manager->crtcs[0].rect.y = 0;
|
|
||||||
manager->crtcs[0].rect.width = manager->modes[0].width;
|
|
||||||
manager->crtcs[0].rect.height = manager->modes[0].height;
|
|
||||||
manager->crtcs[0].current_mode = &manager->modes[0];
|
|
||||||
manager->crtcs[0].transform = WL_OUTPUT_TRANSFORM_NORMAL;
|
|
||||||
manager->crtcs[0].all_transforms = ALL_WL_TRANSFORMS;
|
|
||||||
manager->crtcs[0].is_dirty = FALSE;
|
|
||||||
manager->crtcs[0].logical_monitor = NULL;
|
|
||||||
|
|
||||||
manager->crtcs[1].crtc_id = 5;
|
|
||||||
manager->crtcs[1].rect.x = 0;
|
|
||||||
manager->crtcs[1].rect.y = 0;
|
|
||||||
manager->crtcs[1].rect.width = 0;
|
|
||||||
manager->crtcs[1].rect.height = 0;
|
|
||||||
manager->crtcs[1].current_mode = NULL;
|
|
||||||
manager->crtcs[1].transform = WL_OUTPUT_TRANSFORM_NORMAL;
|
|
||||||
manager->crtcs[1].all_transforms = ALL_WL_TRANSFORMS;
|
|
||||||
manager->crtcs[1].is_dirty = FALSE;
|
|
||||||
manager->crtcs[1].logical_monitor = NULL;
|
|
||||||
|
|
||||||
manager->crtcs[2].crtc_id = 5;
|
|
||||||
manager->crtcs[2].rect.x = 0;
|
|
||||||
manager->crtcs[2].rect.y = 0;
|
|
||||||
manager->crtcs[2].rect.width = 0;
|
|
||||||
manager->crtcs[2].rect.height = 0;
|
|
||||||
manager->crtcs[2].current_mode = NULL;
|
|
||||||
manager->crtcs[2].transform = WL_OUTPUT_TRANSFORM_NORMAL;
|
|
||||||
manager->crtcs[2].all_transforms = ALL_WL_TRANSFORMS;
|
|
||||||
manager->crtcs[2].is_dirty = FALSE;
|
|
||||||
manager->crtcs[2].logical_monitor = NULL;
|
|
||||||
|
|
||||||
manager->outputs = g_new0 (MetaOutput, 3);
|
|
||||||
manager->n_outputs = 3;
|
|
||||||
|
|
||||||
manager->outputs[0].crtc = NULL;
|
|
||||||
manager->outputs[0].output_id = 6;
|
|
||||||
manager->outputs[0].name = g_strdup ("HDMI");
|
|
||||||
manager->outputs[0].vendor = g_strdup ("MetaProducts Inc.");
|
|
||||||
manager->outputs[0].product = g_strdup ("unknown");
|
|
||||||
manager->outputs[0].serial = g_strdup ("0xC0F01A");
|
|
||||||
manager->outputs[0].width_mm = 510;
|
|
||||||
manager->outputs[0].height_mm = 287;
|
|
||||||
manager->outputs[0].subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN;
|
|
||||||
manager->outputs[0].preferred_mode = &manager->modes[3];
|
|
||||||
manager->outputs[0].n_modes = 5;
|
|
||||||
manager->outputs[0].modes = g_new0 (MetaMonitorMode *, 5);
|
|
||||||
manager->outputs[0].modes[0] = &manager->modes[0];
|
|
||||||
manager->outputs[0].modes[1] = &manager->modes[1];
|
|
||||||
manager->outputs[0].modes[2] = &manager->modes[2];
|
|
||||||
manager->outputs[0].modes[3] = &manager->modes[3];
|
|
||||||
manager->outputs[0].modes[4] = &manager->modes[4];
|
|
||||||
manager->outputs[0].n_possible_crtcs = 3;
|
|
||||||
manager->outputs[0].possible_crtcs = g_new0 (MetaCRTC *, 3);
|
|
||||||
manager->outputs[0].possible_crtcs[0] = &manager->crtcs[0];
|
|
||||||
manager->outputs[0].possible_crtcs[1] = &manager->crtcs[1];
|
|
||||||
manager->outputs[0].possible_crtcs[2] = &manager->crtcs[2];
|
|
||||||
manager->outputs[0].n_possible_clones = 0;
|
|
||||||
manager->outputs[0].possible_clones = g_new0 (MetaOutput *, 0);
|
|
||||||
manager->outputs[0].backlight = -1;
|
|
||||||
manager->outputs[0].backlight_min = 0;
|
|
||||||
manager->outputs[0].backlight_max = 0;
|
|
||||||
|
|
||||||
manager->outputs[1].crtc = &manager->crtcs[0];
|
|
||||||
manager->outputs[1].output_id = 7;
|
|
||||||
manager->outputs[1].name = g_strdup ("LVDS");
|
|
||||||
manager->outputs[1].vendor = g_strdup ("MetaProducts Inc.");
|
|
||||||
manager->outputs[1].product = g_strdup ("unknown");
|
|
||||||
manager->outputs[1].serial = g_strdup ("0xC0FFEE");
|
|
||||||
manager->outputs[1].width_mm = 222;
|
|
||||||
manager->outputs[1].height_mm = 125;
|
|
||||||
manager->outputs[1].subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN;
|
|
||||||
manager->outputs[1].preferred_mode = &manager->modes[5];
|
|
||||||
manager->outputs[1].n_modes = 4;
|
|
||||||
manager->outputs[1].modes = g_new0 (MetaMonitorMode *, 4);
|
|
||||||
manager->outputs[1].modes[0] = &manager->modes[0];
|
|
||||||
manager->outputs[1].modes[1] = &manager->modes[1];
|
|
||||||
manager->outputs[1].modes[2] = &manager->modes[2];
|
|
||||||
manager->outputs[1].modes[3] = &manager->modes[5];
|
|
||||||
manager->outputs[1].n_possible_crtcs = 3;
|
|
||||||
manager->outputs[1].possible_crtcs = g_new0 (MetaCRTC *, 3);
|
|
||||||
manager->outputs[1].possible_crtcs[0] = &manager->crtcs[0];
|
|
||||||
manager->outputs[1].possible_crtcs[1] = &manager->crtcs[1];
|
|
||||||
manager->outputs[1].possible_crtcs[2] = &manager->crtcs[2];
|
|
||||||
manager->outputs[1].n_possible_clones = 0;
|
|
||||||
manager->outputs[1].possible_clones = g_new0 (MetaOutput *, 0);
|
|
||||||
manager->outputs[1].backlight = -1;
|
|
||||||
manager->outputs[1].backlight_min = 0;
|
|
||||||
manager->outputs[1].backlight_max = 0;
|
|
||||||
|
|
||||||
manager->outputs[2].crtc = NULL;
|
|
||||||
manager->outputs[2].output_id = 8;
|
|
||||||
manager->outputs[2].name = g_strdup ("VGA");
|
|
||||||
manager->outputs[2].vendor = g_strdup ("MetaProducts Inc.");
|
|
||||||
manager->outputs[2].product = g_strdup ("unknown");
|
|
||||||
manager->outputs[2].serial = g_strdup ("0xC4FE");
|
|
||||||
manager->outputs[2].width_mm = 309;
|
|
||||||
manager->outputs[2].height_mm = 174;
|
|
||||||
manager->outputs[2].subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN;
|
|
||||||
manager->outputs[2].preferred_mode = &manager->modes[0];
|
|
||||||
manager->outputs[2].n_modes = 3;
|
|
||||||
manager->outputs[2].modes = g_new0 (MetaMonitorMode *, 3);
|
|
||||||
manager->outputs[2].modes[0] = &manager->modes[0];
|
|
||||||
manager->outputs[2].modes[1] = &manager->modes[1];
|
|
||||||
manager->outputs[2].modes[2] = &manager->modes[2];
|
|
||||||
manager->outputs[2].n_possible_crtcs = 3;
|
|
||||||
manager->outputs[2].possible_crtcs = g_new0 (MetaCRTC *, 3);
|
|
||||||
manager->outputs[2].possible_crtcs[0] = &manager->crtcs[0];
|
|
||||||
manager->outputs[2].possible_crtcs[1] = &manager->crtcs[1];
|
|
||||||
manager->outputs[2].possible_crtcs[2] = &manager->crtcs[2];
|
|
||||||
manager->outputs[2].n_possible_clones = 0;
|
|
||||||
manager->outputs[2].possible_clones = g_new0 (MetaOutput *, 0);
|
|
||||||
manager->outputs[2].backlight = -1;
|
|
||||||
manager->outputs[2].backlight_min = 0;
|
|
||||||
manager->outputs[2].backlight_max = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
apply_config_dummy (MetaMonitorManager *manager,
|
|
||||||
MetaCRTCInfo **crtcs,
|
|
||||||
unsigned int n_crtcs,
|
|
||||||
MetaOutputInfo **outputs,
|
|
||||||
unsigned int n_outputs)
|
|
||||||
{
|
|
||||||
unsigned i;
|
|
||||||
int screen_width = 0, screen_height = 0;
|
|
||||||
|
|
||||||
for (i = 0; i < n_crtcs; i++)
|
|
||||||
{
|
|
||||||
MetaCRTCInfo *crtc_info = crtcs[i];
|
|
||||||
MetaCRTC *crtc = crtc_info->crtc;
|
|
||||||
crtc->is_dirty = TRUE;
|
|
||||||
|
|
||||||
if (crtc_info->mode == NULL)
|
|
||||||
{
|
|
||||||
crtc->rect.x = 0;
|
|
||||||
crtc->rect.y = 0;
|
|
||||||
crtc->rect.width = 0;
|
|
||||||
crtc->rect.height = 0;
|
|
||||||
crtc->current_mode = NULL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
MetaMonitorMode *mode;
|
|
||||||
MetaOutput *output;
|
|
||||||
int i, n_outputs;
|
|
||||||
int width, height;
|
|
||||||
|
|
||||||
mode = crtc_info->mode;
|
|
||||||
|
|
||||||
if (meta_monitor_transform_is_rotated (crtc_info->transform))
|
|
||||||
{
|
|
||||||
width = mode->height;
|
|
||||||
height = mode->width;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
width = mode->width;
|
|
||||||
height = mode->height;
|
|
||||||
}
|
|
||||||
|
|
||||||
crtc->rect.x = crtc_info->x;
|
|
||||||
crtc->rect.y = crtc_info->y;
|
|
||||||
crtc->rect.width = width;
|
|
||||||
crtc->rect.height = height;
|
|
||||||
crtc->current_mode = mode;
|
|
||||||
crtc->transform = crtc_info->transform;
|
|
||||||
|
|
||||||
screen_width = MAX (screen_width, crtc_info->x + width);
|
|
||||||
screen_height = MAX (screen_height, crtc_info->y + height);
|
|
||||||
|
|
||||||
n_outputs = crtc_info->outputs->len;
|
|
||||||
for (i = 0; i < n_outputs; i++)
|
|
||||||
{
|
|
||||||
output = ((MetaOutput**)crtc_info->outputs->pdata)[i];
|
|
||||||
|
|
||||||
output->is_dirty = TRUE;
|
|
||||||
output->crtc = crtc;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i = 0; i < n_outputs; i++)
|
|
||||||
{
|
|
||||||
MetaOutputInfo *output_info = outputs[i];
|
|
||||||
MetaOutput *output = output_info->output;
|
|
||||||
|
|
||||||
output->is_primary = output_info->is_primary;
|
|
||||||
output->is_presentation = output_info->is_presentation;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Disable CRTCs not mentioned in the list */
|
|
||||||
for (i = 0; i < manager->n_crtcs; i++)
|
|
||||||
{
|
|
||||||
MetaCRTC *crtc = &manager->crtcs[i];
|
|
||||||
|
|
||||||
crtc->logical_monitor = NULL;
|
|
||||||
|
|
||||||
if (crtc->is_dirty)
|
|
||||||
{
|
|
||||||
crtc->is_dirty = FALSE;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
crtc->rect.x = 0;
|
|
||||||
crtc->rect.y = 0;
|
|
||||||
crtc->rect.width = 0;
|
|
||||||
crtc->rect.height = 0;
|
|
||||||
crtc->current_mode = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Disable outputs not mentioned in the list */
|
|
||||||
for (i = 0; i < manager->n_outputs; i++)
|
|
||||||
{
|
|
||||||
MetaOutput *output = &manager->outputs[i];
|
|
||||||
|
|
||||||
if (output->is_dirty)
|
|
||||||
{
|
|
||||||
output->is_dirty = FALSE;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
output->crtc = NULL;
|
|
||||||
output->is_primary = FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
manager->screen_width = screen_width;
|
|
||||||
manager->screen_height = screen_height;
|
|
||||||
|
|
||||||
meta_monitor_manager_rebuild_derived (manager);
|
|
||||||
}
|
|
||||||
|
|
||||||
static GBytes *
|
|
||||||
read_edid_dummy (MetaMonitorManager *manager,
|
|
||||||
MetaOutput *output)
|
|
||||||
{
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
static char *
|
|
||||||
get_edid_file_dummy (MetaMonitorManager *manager,
|
|
||||||
MetaOutput *output)
|
|
||||||
{
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
meta_monitor_manager_init (MetaMonitorManager *manager)
|
meta_monitor_manager_init (MetaMonitorManager *manager)
|
||||||
{
|
{
|
||||||
@@ -471,6 +168,40 @@ make_logical_config (MetaMonitorManager *manager)
|
|||||||
manager->monitor_infos = (void*)g_array_free (monitor_infos, FALSE);
|
manager->monitor_infos = (void*)g_array_free (monitor_infos, FALSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GType
|
||||||
|
get_default_backend (void)
|
||||||
|
{
|
||||||
|
#if defined(CLUTTER_WINDOWING_EGL)
|
||||||
|
if (clutter_check_windowing_backend (CLUTTER_WINDOWING_EGL))
|
||||||
|
return META_TYPE_MONITOR_MANAGER_KMS;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CLUTTER_WINDOWING_X11)
|
||||||
|
if (clutter_check_windowing_backend (CLUTTER_WINDOWING_X11))
|
||||||
|
{
|
||||||
|
/* If we're a Wayland compositor using the X11 backend,
|
||||||
|
* we're a nested configuration, so return the dummy
|
||||||
|
* monitor setup. */
|
||||||
|
if (meta_is_wayland_compositor ())
|
||||||
|
return META_TYPE_MONITOR_MANAGER_DUMMY;
|
||||||
|
else
|
||||||
|
return META_TYPE_MONITOR_MANAGER_XRANDR;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CLUTTER_WINDOWING_WAYLAND)
|
||||||
|
if (clutter_check_windowing_backend (CLUTTER_WINDOWING_WAYLAND))
|
||||||
|
{
|
||||||
|
/* Use the dummy implementation on Wayland for now.
|
||||||
|
* In the future, we should support wl_fullscreen_output
|
||||||
|
* which will have CRTC management in the protocol. */
|
||||||
|
return META_TYPE_MONITOR_MANAGER_DUMMY;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
g_assert_not_reached ();
|
||||||
|
}
|
||||||
|
|
||||||
static MetaMonitorManager *
|
static MetaMonitorManager *
|
||||||
meta_monitor_manager_new (void)
|
meta_monitor_manager_new (void)
|
||||||
{
|
{
|
||||||
@@ -480,7 +211,7 @@ meta_monitor_manager_new (void)
|
|||||||
env = g_getenv ("META_DEBUG_MULTIMONITOR");
|
env = g_getenv ("META_DEBUG_MULTIMONITOR");
|
||||||
|
|
||||||
if (env == NULL)
|
if (env == NULL)
|
||||||
type = META_TYPE_MONITOR_MANAGER_XRANDR;
|
type = get_default_backend ();
|
||||||
else if (strcmp (env, "xrandr") == 0)
|
else if (strcmp (env, "xrandr") == 0)
|
||||||
type = META_TYPE_MONITOR_MANAGER_XRANDR;
|
type = META_TYPE_MONITOR_MANAGER_XRANDR;
|
||||||
else
|
else
|
||||||
@@ -515,17 +246,18 @@ meta_monitor_manager_constructed (GObject *object)
|
|||||||
MetaOutput *old_outputs;
|
MetaOutput *old_outputs;
|
||||||
MetaCRTC *old_crtcs;
|
MetaCRTC *old_crtcs;
|
||||||
MetaMonitorMode *old_modes;
|
MetaMonitorMode *old_modes;
|
||||||
int n_old_outputs;
|
unsigned int n_old_outputs, n_old_modes;
|
||||||
|
|
||||||
old_outputs = manager->outputs;
|
old_outputs = manager->outputs;
|
||||||
n_old_outputs = manager->n_outputs;
|
n_old_outputs = manager->n_outputs;
|
||||||
old_modes = manager->modes;
|
old_modes = manager->modes;
|
||||||
|
n_old_modes = manager->n_modes;
|
||||||
old_crtcs = manager->crtcs;
|
old_crtcs = manager->crtcs;
|
||||||
|
|
||||||
read_current_config (manager);
|
read_current_config (manager);
|
||||||
|
|
||||||
meta_monitor_manager_free_output_array (old_outputs, n_old_outputs);
|
meta_monitor_manager_free_output_array (old_outputs, n_old_outputs);
|
||||||
g_free (old_modes);
|
meta_monitor_manager_free_mode_array (old_modes, n_old_modes);
|
||||||
g_free (old_crtcs);
|
g_free (old_crtcs);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -567,19 +299,39 @@ meta_monitor_manager_free_output_array (MetaOutput *old_outputs,
|
|||||||
g_free (old_outputs[i].modes);
|
g_free (old_outputs[i].modes);
|
||||||
g_free (old_outputs[i].possible_crtcs);
|
g_free (old_outputs[i].possible_crtcs);
|
||||||
g_free (old_outputs[i].possible_clones);
|
g_free (old_outputs[i].possible_clones);
|
||||||
|
|
||||||
|
if (old_outputs[i].driver_notify)
|
||||||
|
old_outputs[i].driver_notify (&old_outputs[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
g_free (old_outputs);
|
g_free (old_outputs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_monitor_manager_free_mode_array (MetaMonitorMode *old_modes,
|
||||||
|
int n_old_modes)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < n_old_modes; i++)
|
||||||
|
{
|
||||||
|
g_free (old_modes[i].name);
|
||||||
|
|
||||||
|
if (old_modes[i].driver_notify)
|
||||||
|
old_modes[i].driver_notify (&old_modes[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
g_free (old_modes);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
meta_monitor_manager_finalize (GObject *object)
|
meta_monitor_manager_finalize (GObject *object)
|
||||||
{
|
{
|
||||||
MetaMonitorManager *manager = META_MONITOR_MANAGER (object);
|
MetaMonitorManager *manager = META_MONITOR_MANAGER (object);
|
||||||
|
|
||||||
meta_monitor_manager_free_output_array (manager->outputs, manager->n_outputs);
|
meta_monitor_manager_free_output_array (manager->outputs, manager->n_outputs);
|
||||||
|
meta_monitor_manager_free_mode_array (manager->modes, manager->n_modes);
|
||||||
g_free (manager->monitor_infos);
|
g_free (manager->monitor_infos);
|
||||||
g_free (manager->modes);
|
|
||||||
g_free (manager->crtcs);
|
g_free (manager->crtcs);
|
||||||
|
|
||||||
G_OBJECT_CLASS (meta_monitor_manager_parent_class)->finalize (object);
|
G_OBJECT_CLASS (meta_monitor_manager_parent_class)->finalize (object);
|
||||||
@@ -637,6 +389,20 @@ meta_monitor_manager_get_property (GObject *object,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GBytes *
|
||||||
|
meta_monitor_manager_real_read_edid (MetaMonitorManager *manager,
|
||||||
|
MetaOutput *output)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *
|
||||||
|
meta_monitor_manager_real_get_edid_file (MetaMonitorManager *manager,
|
||||||
|
MetaOutput *output)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
meta_monitor_manager_class_init (MetaMonitorManagerClass *klass)
|
meta_monitor_manager_class_init (MetaMonitorManagerClass *klass)
|
||||||
{
|
{
|
||||||
@@ -648,10 +414,8 @@ meta_monitor_manager_class_init (MetaMonitorManagerClass *klass)
|
|||||||
object_class->dispose = meta_monitor_manager_dispose;
|
object_class->dispose = meta_monitor_manager_dispose;
|
||||||
object_class->finalize = meta_monitor_manager_finalize;
|
object_class->finalize = meta_monitor_manager_finalize;
|
||||||
|
|
||||||
klass->read_current = read_current_dummy;
|
klass->get_edid_file = meta_monitor_manager_real_get_edid_file;
|
||||||
klass->apply_configuration = apply_config_dummy;
|
klass->read_edid = meta_monitor_manager_real_read_edid;
|
||||||
klass->get_edid_file = get_edid_file_dummy;
|
|
||||||
klass->read_edid = read_edid_dummy;
|
|
||||||
|
|
||||||
signals[CONFIRM_DISPLAY_CHANGE] =
|
signals[CONFIRM_DISPLAY_CHANGE] =
|
||||||
g_signal_new ("confirm-display-change",
|
g_signal_new ("confirm-display-change",
|
||||||
@@ -691,46 +455,60 @@ static char *
|
|||||||
make_display_name (MetaMonitorManager *manager,
|
make_display_name (MetaMonitorManager *manager,
|
||||||
MetaOutput *output)
|
MetaOutput *output)
|
||||||
{
|
{
|
||||||
|
char *inches = NULL;
|
||||||
|
char *vendor_name = NULL;
|
||||||
|
char *ret;
|
||||||
|
|
||||||
if (g_str_has_prefix (output->name, "LVDS") ||
|
if (g_str_has_prefix (output->name, "LVDS") ||
|
||||||
g_str_has_prefix (output->name, "eDP"))
|
g_str_has_prefix (output->name, "eDP"))
|
||||||
return g_strdup (_("Built-in display"));
|
{
|
||||||
|
ret = g_strdup (_("Built-in display"));
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
if (output->width_mm != -1 && output->height_mm != -1)
|
if (output->width_mm > 0 && output->height_mm > 0)
|
||||||
{
|
{
|
||||||
double d = sqrt (output->width_mm * output->width_mm +
|
double d = sqrt (output->width_mm * output->width_mm +
|
||||||
output->height_mm * output->height_mm);
|
output->height_mm * output->height_mm);
|
||||||
char *inches = diagonal_to_str (d / 25.4);
|
inches = diagonal_to_str (d / 25.4);
|
||||||
char *vendor_name;
|
}
|
||||||
char *ret;
|
|
||||||
|
|
||||||
if (g_strcmp0 (output->vendor, "unknown") != 0)
|
if (g_strcmp0 (output->vendor, "unknown") != 0)
|
||||||
{
|
{
|
||||||
if (!manager->pnp_ids)
|
if (!manager->pnp_ids)
|
||||||
manager->pnp_ids = gnome_pnp_ids_new ();
|
manager->pnp_ids = gnome_pnp_ids_new ();
|
||||||
|
|
||||||
vendor_name = gnome_pnp_ids_get_pnp_id (manager->pnp_ids,
|
vendor_name = gnome_pnp_ids_get_pnp_id (manager->pnp_ids,
|
||||||
output->vendor);
|
output->vendor);
|
||||||
|
|
||||||
ret = g_strdup_printf ("%s %s", vendor_name, inches);
|
if (!vendor_name)
|
||||||
|
vendor_name = g_strdup (output->vendor);
|
||||||
g_free (vendor_name);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
/* 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"'
|
|
||||||
*/
|
|
||||||
ret = g_strdup_printf (_("Unknown %s"), inches);
|
|
||||||
}
|
|
||||||
|
|
||||||
g_free (inches);
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return g_strdup (output->vendor);
|
if (inches != NULL)
|
||||||
|
vendor_name = g_strdup (_("Unknown"));
|
||||||
|
else
|
||||||
|
vendor_name = g_strdup (_("Unknown Display"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (inches != NULL)
|
||||||
|
{
|
||||||
|
/* TRANSLATORS: this is a monitor vendor name, followed by a
|
||||||
|
* size in inches, like 'Dell 15"'
|
||||||
|
*/
|
||||||
|
ret = g_strdup_printf (_("%s %s"), vendor_name, inches);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
ret = g_strdup (vendor_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
out:
|
||||||
|
g_free (inches);
|
||||||
|
g_free (vendor_name);
|
||||||
|
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
@@ -758,13 +536,13 @@ meta_monitor_manager_handle_get_resources (MetaDBusDisplayConfig *skeleton,
|
|||||||
|
|
||||||
g_variant_builder_add (&crtc_builder, "(uxiiiiiuaua{sv})",
|
g_variant_builder_add (&crtc_builder, "(uxiiiiiuaua{sv})",
|
||||||
i, /* ID */
|
i, /* ID */
|
||||||
(gint64)crtc->crtc_id,
|
crtc->crtc_id,
|
||||||
(int)crtc->rect.x,
|
(int)crtc->rect.x,
|
||||||
(int)crtc->rect.y,
|
(int)crtc->rect.y,
|
||||||
(int)crtc->rect.width,
|
(int)crtc->rect.width,
|
||||||
(int)crtc->rect.height,
|
(int)crtc->rect.height,
|
||||||
(int)(crtc->current_mode ? crtc->current_mode - manager->modes : -1),
|
(int)(crtc->current_mode ? crtc->current_mode - manager->modes : -1),
|
||||||
(guint32)crtc->transform,
|
crtc->transform,
|
||||||
&transforms,
|
&transforms,
|
||||||
NULL /* properties */);
|
NULL /* properties */);
|
||||||
}
|
}
|
||||||
@@ -806,6 +584,9 @@ meta_monitor_manager_handle_get_resources (MetaDBusDisplayConfig *skeleton,
|
|||||||
g_variant_new_take_string (make_display_name (manager, output)));
|
g_variant_new_take_string (make_display_name (manager, output)));
|
||||||
g_variant_builder_add (&properties, "{sv}", "backlight",
|
g_variant_builder_add (&properties, "{sv}", "backlight",
|
||||||
g_variant_new_int32 (output->backlight));
|
g_variant_new_int32 (output->backlight));
|
||||||
|
g_variant_builder_add (&properties, "{sv}", "min-backlight-step",
|
||||||
|
g_variant_new_int32 ((output->backlight_max - output->backlight_min) ?
|
||||||
|
100 / (output->backlight_max - output->backlight_min) : -1));
|
||||||
g_variant_builder_add (&properties, "{sv}", "primary",
|
g_variant_builder_add (&properties, "{sv}", "primary",
|
||||||
g_variant_new_boolean (output->is_primary));
|
g_variant_new_boolean (output->is_primary));
|
||||||
g_variant_builder_add (&properties, "{sv}", "presentation",
|
g_variant_builder_add (&properties, "{sv}", "presentation",
|
||||||
@@ -832,7 +613,7 @@ meta_monitor_manager_handle_get_resources (MetaDBusDisplayConfig *skeleton,
|
|||||||
|
|
||||||
g_variant_builder_add (&output_builder, "(uxiausauaua{sv})",
|
g_variant_builder_add (&output_builder, "(uxiausauaua{sv})",
|
||||||
i, /* ID */
|
i, /* ID */
|
||||||
(gint64)output->output_id,
|
output->output_id,
|
||||||
(int)(output->crtc ? output->crtc - manager->crtcs : -1),
|
(int)(output->crtc ? output->crtc - manager->crtcs : -1),
|
||||||
&crtcs,
|
&crtcs,
|
||||||
output->name,
|
output->name,
|
||||||
@@ -847,9 +628,9 @@ meta_monitor_manager_handle_get_resources (MetaDBusDisplayConfig *skeleton,
|
|||||||
|
|
||||||
g_variant_builder_add (&mode_builder, "(uxuud)",
|
g_variant_builder_add (&mode_builder, "(uxuud)",
|
||||||
i, /* ID */
|
i, /* ID */
|
||||||
(gint64)mode->mode_id,
|
mode->mode_id,
|
||||||
(guint32)mode->width,
|
mode->width,
|
||||||
(guint32)mode->height,
|
mode->height,
|
||||||
(double)mode->refresh_rate);
|
(double)mode->refresh_rate);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1438,12 +1219,21 @@ meta_monitor_manager_get_resources (MetaMonitorManager *manager,
|
|||||||
MetaOutput **outputs,
|
MetaOutput **outputs,
|
||||||
unsigned int *n_outputs)
|
unsigned int *n_outputs)
|
||||||
{
|
{
|
||||||
*modes = manager->modes;
|
if (modes)
|
||||||
*n_modes = manager->n_modes;
|
{
|
||||||
*crtcs = manager->crtcs;
|
*modes = manager->modes;
|
||||||
*n_crtcs = manager->n_crtcs;
|
*n_modes = manager->n_modes;
|
||||||
*outputs = manager->outputs;
|
}
|
||||||
*n_outputs = manager->n_outputs;
|
if (crtcs)
|
||||||
|
{
|
||||||
|
*crtcs = manager->crtcs;
|
||||||
|
*n_crtcs = manager->n_crtcs;
|
||||||
|
}
|
||||||
|
if (outputs)
|
||||||
|
{
|
||||||
|
*outputs = manager->outputs;
|
||||||
|
*n_outputs = manager->n_outputs;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
@@ -29,9 +29,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef META_MONITOR_PRIVATE_H
|
#ifndef META_MONITOR_PRIVATE_H
|
||||||
@@ -44,31 +42,16 @@
|
|||||||
#include <meta/screen.h>
|
#include <meta/screen.h>
|
||||||
#include "stack-tracker.h"
|
#include "stack-tracker.h"
|
||||||
#include "ui.h"
|
#include "ui.h"
|
||||||
#ifdef HAVE_WAYLAND
|
|
||||||
#include <wayland-server.h>
|
#include <wayland-server.h>
|
||||||
#endif
|
|
||||||
#include "meta-xrandr-shared.h"
|
|
||||||
|
|
||||||
#include "meta-dbus-xrandr.h"
|
#include "meta-display-config-shared.h"
|
||||||
|
#include "meta-dbus-display-config.h"
|
||||||
|
|
||||||
typedef struct _MetaMonitorManagerClass MetaMonitorManagerClass;
|
typedef struct _MetaMonitorManagerClass MetaMonitorManagerClass;
|
||||||
typedef struct _MetaMonitorManager MetaMonitorManager;
|
typedef struct _MetaMonitorManager MetaMonitorManager;
|
||||||
typedef struct _MetaMonitorConfigClass MetaMonitorConfigClass;
|
typedef struct _MetaMonitorConfigClass MetaMonitorConfigClass;
|
||||||
typedef struct _MetaMonitorConfig MetaMonitorConfig;
|
typedef struct _MetaMonitorConfig MetaMonitorConfig;
|
||||||
|
|
||||||
#ifndef HAVE_WAYLAND
|
|
||||||
enum wl_output_transform {
|
|
||||||
WL_OUTPUT_TRANSFORM_NORMAL,
|
|
||||||
WL_OUTPUT_TRANSFORM_90,
|
|
||||||
WL_OUTPUT_TRANSFORM_180,
|
|
||||||
WL_OUTPUT_TRANSFORM_270,
|
|
||||||
WL_OUTPUT_TRANSFORM_FLIPPED,
|
|
||||||
WL_OUTPUT_TRANSFORM_FLIPPED_90,
|
|
||||||
WL_OUTPUT_TRANSFORM_FLIPPED_180,
|
|
||||||
WL_OUTPUT_TRANSFORM_FLIPPED_270
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
typedef struct _MetaOutput MetaOutput;
|
typedef struct _MetaOutput MetaOutput;
|
||||||
typedef struct _MetaCRTC MetaCRTC;
|
typedef struct _MetaCRTC MetaCRTC;
|
||||||
typedef struct _MetaMonitorMode MetaMonitorMode;
|
typedef struct _MetaMonitorMode MetaMonitorMode;
|
||||||
@@ -117,6 +100,9 @@ struct _MetaOutput
|
|||||||
gboolean is_primary;
|
gboolean is_primary;
|
||||||
gboolean is_presentation;
|
gboolean is_presentation;
|
||||||
|
|
||||||
|
gpointer driver_private;
|
||||||
|
GDestroyNotify driver_notify;
|
||||||
|
|
||||||
/* get a new preferred mode on hotplug events, to handle dynamic guest resizing */
|
/* get a new preferred mode on hotplug events, to handle dynamic guest resizing */
|
||||||
gboolean hotplug_mode_update;
|
gboolean hotplug_mode_update;
|
||||||
};
|
};
|
||||||
@@ -136,16 +122,23 @@ struct _MetaCRTC
|
|||||||
|
|
||||||
/* Used when changing configuration */
|
/* Used when changing configuration */
|
||||||
gboolean is_dirty;
|
gboolean is_dirty;
|
||||||
|
|
||||||
|
/* Updated by MetaCursorTracker */
|
||||||
|
gboolean has_hw_cursor;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct _MetaMonitorMode
|
struct _MetaMonitorMode
|
||||||
{
|
{
|
||||||
/* The low-level ID of this mode, used to apply back configuration */
|
/* The low-level ID of this mode, used to apply back configuration */
|
||||||
glong mode_id;
|
glong mode_id;
|
||||||
|
char *name;
|
||||||
|
|
||||||
int width;
|
int width;
|
||||||
int height;
|
int height;
|
||||||
float refresh_rate;
|
float refresh_rate;
|
||||||
|
|
||||||
|
gpointer driver_private;
|
||||||
|
GDestroyNotify driver_notify;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -234,8 +227,6 @@ struct _MetaMonitorManager
|
|||||||
CRTCs refer to stuff that can drive outputs
|
CRTCs refer to stuff that can drive outputs
|
||||||
(like encoders, but less tied to the HW),
|
(like encoders, but less tied to the HW),
|
||||||
while monitor_infos refer to logical ones.
|
while monitor_infos refer to logical ones.
|
||||||
|
|
||||||
See also the comment in monitor-private.h
|
|
||||||
*/
|
*/
|
||||||
MetaOutput *outputs;
|
MetaOutput *outputs;
|
||||||
unsigned int n_outputs;
|
unsigned int n_outputs;
|
||||||
@@ -342,50 +333,13 @@ void meta_monitor_manager_apply_configuration (MetaMonitorManager
|
|||||||
void meta_monitor_manager_confirm_configuration (MetaMonitorManager *manager,
|
void meta_monitor_manager_confirm_configuration (MetaMonitorManager *manager,
|
||||||
gboolean ok);
|
gboolean ok);
|
||||||
|
|
||||||
#define META_TYPE_MONITOR_MANAGER_XRANDR (meta_monitor_manager_xrandr_get_type ())
|
|
||||||
#define META_MONITOR_MANAGER_XRANDR(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_MONITOR_MANAGER_XRANDR, MetaMonitorManagerXrandr))
|
|
||||||
#define META_MONITOR_MANAGER_XRANDR_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), META_TYPE_MONITOR_MANAGER_XRANDR, MetaMonitorManagerXrandrClass))
|
|
||||||
#define META_IS_MONITOR_MANAGER_XRANDR(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_MONITOR_MANAGER_XRANDR))
|
|
||||||
#define META_IS_MONITOR_MANAGER_XRANDR_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), META_TYPE_MONITOR_MANAGER_XRANDR))
|
|
||||||
#define META_MONITOR_MANAGER_XRANDR_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), META_TYPE_MONITOR_MANAGER_XRANDR, MetaMonitorManagerXrandrClass))
|
|
||||||
|
|
||||||
typedef struct _MetaMonitorManagerXrandrClass MetaMonitorManagerXrandrClass;
|
|
||||||
typedef struct _MetaMonitorManagerXrandr MetaMonitorManagerXrandr;
|
|
||||||
|
|
||||||
GType meta_monitor_manager_xrandr_get_type (void);
|
|
||||||
|
|
||||||
#define META_TYPE_MONITOR_CONFIG (meta_monitor_config_get_type ())
|
|
||||||
#define META_MONITOR_CONFIG(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_MONITOR_CONFIG, MetaMonitorConfig))
|
|
||||||
#define META_MONITOR_CONFIG_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), META_TYPE_MONITOR_CONFIG, MetaMonitorConfigClass))
|
|
||||||
#define META_IS_MONITOR_CONFIG(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_MONITOR_CONFIG))
|
|
||||||
#define META_IS_MONITOR_CONFIG_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), META_TYPE_MONITOR_CONFIG))
|
|
||||||
#define META_MONITOR_CONFIG_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), META_TYPE_MONITOR_CONFIG, MetaMonitorConfigClass))
|
|
||||||
|
|
||||||
GType meta_monitor_config_get_type (void) G_GNUC_CONST;
|
|
||||||
|
|
||||||
MetaMonitorConfig *meta_monitor_config_new (void);
|
|
||||||
|
|
||||||
gboolean meta_monitor_config_match_current (MetaMonitorConfig *config,
|
|
||||||
MetaMonitorManager *manager);
|
|
||||||
|
|
||||||
gboolean meta_monitor_config_apply_stored (MetaMonitorConfig *config,
|
|
||||||
MetaMonitorManager *manager);
|
|
||||||
|
|
||||||
void meta_monitor_config_make_default (MetaMonitorConfig *config,
|
|
||||||
MetaMonitorManager *manager);
|
|
||||||
|
|
||||||
void meta_monitor_config_update_current (MetaMonitorConfig *config,
|
|
||||||
MetaMonitorManager *manager);
|
|
||||||
void meta_monitor_config_make_persistent (MetaMonitorConfig *config);
|
|
||||||
|
|
||||||
void meta_monitor_config_restore_previous (MetaMonitorConfig *config,
|
|
||||||
MetaMonitorManager *manager);
|
|
||||||
|
|
||||||
void meta_crtc_info_free (MetaCRTCInfo *info);
|
void meta_crtc_info_free (MetaCRTCInfo *info);
|
||||||
void meta_output_info_free (MetaOutputInfo *info);
|
void meta_output_info_free (MetaOutputInfo *info);
|
||||||
|
|
||||||
void meta_monitor_manager_free_output_array (MetaOutput *old_outputs,
|
void meta_monitor_manager_free_output_array (MetaOutput *old_outputs,
|
||||||
int n_old_outputs);
|
int n_old_outputs);
|
||||||
|
void meta_monitor_manager_free_mode_array (MetaMonitorMode *old_modes,
|
||||||
|
int n_old_modes);
|
||||||
gboolean meta_monitor_manager_has_hotplug_mode_update (MetaMonitorManager *manager);
|
gboolean meta_monitor_manager_has_hotplug_mode_update (MetaMonitorManager *manager);
|
||||||
|
|
||||||
/* Returns true if transform causes width and height to be inverted
|
/* Returns true if transform causes width and height to be inverted
|
||||||
219
src/backends/native/meta-idle-monitor-native.c
Normal file
219
src/backends/native/meta-idle-monitor-native.c
Normal file
@@ -0,0 +1,219 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* 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/>.
|
||||||
|
*
|
||||||
|
* Adapted from gnome-session/gnome-session/gs-idle-monitor.c and
|
||||||
|
* from gnome-desktop/libgnome-desktop/gnome-idle-monitor.c
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include "meta-idle-monitor-native.h"
|
||||||
|
#include "meta-idle-monitor-private.h"
|
||||||
|
|
||||||
|
#include <meta/util.h>
|
||||||
|
#include "display-private.h"
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
struct _MetaIdleMonitorNative
|
||||||
|
{
|
||||||
|
MetaIdleMonitor parent;
|
||||||
|
|
||||||
|
guint64 last_event_time;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _MetaIdleMonitorNativeClass
|
||||||
|
{
|
||||||
|
MetaIdleMonitorClass parent_class;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
MetaIdleMonitorWatch base;
|
||||||
|
|
||||||
|
GSource *timeout_source;
|
||||||
|
} MetaIdleMonitorWatchNative;
|
||||||
|
|
||||||
|
G_DEFINE_TYPE (MetaIdleMonitorNative, meta_idle_monitor_native, META_TYPE_IDLE_MONITOR)
|
||||||
|
|
||||||
|
static gint64
|
||||||
|
meta_idle_monitor_native_get_idletime (MetaIdleMonitor *monitor)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorNative *monitor_native = META_IDLE_MONITOR_NATIVE (monitor);
|
||||||
|
|
||||||
|
return (g_get_monotonic_time () - monitor_native->last_event_time) / 1000;
|
||||||
|
}
|
||||||
|
|
||||||
|
static guint32
|
||||||
|
get_next_watch_serial (void)
|
||||||
|
{
|
||||||
|
static guint32 serial = 0;
|
||||||
|
g_atomic_int_inc (&serial);
|
||||||
|
return serial;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
native_dispatch_timeout (GSource *source,
|
||||||
|
GSourceFunc callback,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorWatchNative *watch_native = user_data;
|
||||||
|
MetaIdleMonitorWatch *watch = (MetaIdleMonitorWatch *) watch_native;
|
||||||
|
|
||||||
|
_meta_idle_monitor_watch_fire (watch);
|
||||||
|
g_source_set_ready_time (watch_native->timeout_source, -1);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static GSourceFuncs native_source_funcs = {
|
||||||
|
NULL, /* prepare */
|
||||||
|
NULL, /* check */
|
||||||
|
native_dispatch_timeout,
|
||||||
|
NULL, /* finalize */
|
||||||
|
};
|
||||||
|
|
||||||
|
static void
|
||||||
|
free_watch (gpointer data)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorWatchNative *watch_native = data;
|
||||||
|
MetaIdleMonitorWatch *watch = (MetaIdleMonitorWatch *) watch_native;
|
||||||
|
MetaIdleMonitor *monitor = watch->monitor;
|
||||||
|
|
||||||
|
g_object_ref (monitor);
|
||||||
|
|
||||||
|
if (watch->idle_source_id)
|
||||||
|
{
|
||||||
|
g_source_remove (watch->idle_source_id);
|
||||||
|
watch->idle_source_id = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (watch->notify != NULL)
|
||||||
|
watch->notify (watch->user_data);
|
||||||
|
|
||||||
|
if (watch_native->timeout_source != NULL)
|
||||||
|
g_source_destroy (watch_native->timeout_source);
|
||||||
|
|
||||||
|
g_object_unref (monitor);
|
||||||
|
g_slice_free (MetaIdleMonitorWatchNative, watch_native);
|
||||||
|
}
|
||||||
|
|
||||||
|
static MetaIdleMonitorWatch *
|
||||||
|
meta_idle_monitor_native_make_watch (MetaIdleMonitor *monitor,
|
||||||
|
guint64 timeout_msec,
|
||||||
|
MetaIdleMonitorWatchFunc callback,
|
||||||
|
gpointer user_data,
|
||||||
|
GDestroyNotify notify)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorWatchNative *watch_native;
|
||||||
|
MetaIdleMonitorWatch *watch;
|
||||||
|
MetaIdleMonitorNative *monitor_native = META_IDLE_MONITOR_NATIVE (monitor);
|
||||||
|
|
||||||
|
watch_native = g_slice_new0 (MetaIdleMonitorWatchNative);
|
||||||
|
watch = (MetaIdleMonitorWatch *) watch_native;
|
||||||
|
|
||||||
|
watch->monitor = monitor;
|
||||||
|
watch->id = get_next_watch_serial ();
|
||||||
|
watch->callback = callback;
|
||||||
|
watch->user_data = user_data;
|
||||||
|
watch->notify = notify;
|
||||||
|
watch->timeout_msec = timeout_msec;
|
||||||
|
|
||||||
|
if (timeout_msec != 0)
|
||||||
|
{
|
||||||
|
GSource *source = g_source_new (&native_source_funcs, sizeof (GSource));
|
||||||
|
|
||||||
|
g_source_set_callback (source, NULL, watch, NULL);
|
||||||
|
g_source_set_ready_time (source, monitor_native->last_event_time + timeout_msec * 1000);
|
||||||
|
g_source_attach (source, NULL);
|
||||||
|
g_source_unref (source);
|
||||||
|
|
||||||
|
watch_native->timeout_source = source;
|
||||||
|
}
|
||||||
|
|
||||||
|
return watch;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_idle_monitor_native_class_init (MetaIdleMonitorNativeClass *klass)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorClass *idle_monitor_class = META_IDLE_MONITOR_CLASS (klass);
|
||||||
|
|
||||||
|
idle_monitor_class->get_idletime = meta_idle_monitor_native_get_idletime;
|
||||||
|
idle_monitor_class->make_watch = meta_idle_monitor_native_make_watch;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_idle_monitor_native_init (MetaIdleMonitorNative *monitor_native)
|
||||||
|
{
|
||||||
|
MetaIdleMonitor *monitor = META_IDLE_MONITOR (monitor_native);
|
||||||
|
|
||||||
|
monitor->watches = g_hash_table_new_full (NULL, NULL, NULL, free_watch);
|
||||||
|
}
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
MetaIdleMonitorNative *monitor_native;
|
||||||
|
GList *fired_watches;
|
||||||
|
} CheckNativeClosure;
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
check_native_watch (gpointer key,
|
||||||
|
gpointer value,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorWatchNative *watch_native = value;
|
||||||
|
MetaIdleMonitorWatch *watch = (MetaIdleMonitorWatch *) watch_native;
|
||||||
|
CheckNativeClosure *closure = user_data;
|
||||||
|
gboolean steal;
|
||||||
|
|
||||||
|
if (watch->timeout_msec == 0)
|
||||||
|
{
|
||||||
|
closure->fired_watches = g_list_prepend (closure->fired_watches, watch);
|
||||||
|
steal = TRUE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
g_source_set_ready_time (watch_native->timeout_source,
|
||||||
|
closure->monitor_native->last_event_time +
|
||||||
|
watch->timeout_msec * 1000);
|
||||||
|
steal = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return steal;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
fire_native_watch (gpointer watch,
|
||||||
|
gpointer data)
|
||||||
|
{
|
||||||
|
_meta_idle_monitor_watch_fire (watch);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_idle_monitor_native_reset_idletime (MetaIdleMonitor *monitor)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorNative *monitor_native = META_IDLE_MONITOR_NATIVE (monitor);
|
||||||
|
CheckNativeClosure closure;
|
||||||
|
|
||||||
|
monitor_native->last_event_time = g_get_monotonic_time ();
|
||||||
|
|
||||||
|
closure.monitor_native = monitor_native;
|
||||||
|
closure.fired_watches = NULL;
|
||||||
|
g_hash_table_foreach_steal (monitor->watches, check_native_watch, &closure);
|
||||||
|
|
||||||
|
g_list_foreach (closure.fired_watches, fire_native_watch, NULL);
|
||||||
|
g_list_free (closure.fired_watches);
|
||||||
|
}
|
||||||
43
src/backends/native/meta-idle-monitor-native.h
Normal file
43
src/backends/native/meta-idle-monitor-native.h
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* 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/>.
|
||||||
|
*
|
||||||
|
* Adapted from gnome-session/gnome-session/gs-idle-monitor.c and
|
||||||
|
* from gnome-desktop/libgnome-desktop/gnome-idle-monitor.c
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef META_IDLE_MONITOR_NATIVE_H
|
||||||
|
#define META_IDLE_MONITOR_NATIVE_H
|
||||||
|
|
||||||
|
#include <glib-object.h>
|
||||||
|
#include <meta/meta-idle-monitor.h>
|
||||||
|
|
||||||
|
#define META_TYPE_IDLE_MONITOR_NATIVE (meta_idle_monitor_native_get_type ())
|
||||||
|
#define META_IDLE_MONITOR_NATIVE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_IDLE_MONITOR_NATIVE, MetaIdleMonitorNative))
|
||||||
|
#define META_IDLE_MONITOR_NATIVE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), META_TYPE_IDLE_MONITOR_NATIVE, MetaIdleMonitorNativeClass))
|
||||||
|
#define META_IS_IDLE_MONITOR_NATIVE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_IDLE_MONITOR_NATIVE))
|
||||||
|
#define META_IS_IDLE_MONITOR_NATIVE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), META_TYPE_IDLE_MONITOR_NATIVE))
|
||||||
|
#define META_IDLE_MONITOR_NATIVE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), META_TYPE_IDLE_MONITOR_NATIVE, MetaIdleMonitorNativeClass))
|
||||||
|
|
||||||
|
typedef struct _MetaIdleMonitorNative MetaIdleMonitorNative;
|
||||||
|
typedef struct _MetaIdleMonitorNativeClass MetaIdleMonitorNativeClass;
|
||||||
|
|
||||||
|
GType meta_idle_monitor_native_get_type (void);
|
||||||
|
|
||||||
|
void meta_idle_monitor_native_reset_idletime (MetaIdleMonitor *monitor);
|
||||||
|
|
||||||
|
#endif /* META_IDLE_MONITOR_NATIVE_H */
|
||||||
939
src/backends/native/meta-monitor-manager-kms.c
Normal file
939
src/backends/native/meta-monitor-manager-kms.c
Normal file
@@ -0,0 +1,939 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2013 Red Hat Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation; either version 2 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
||||||
|
* 02111-1307, USA.
|
||||||
|
*
|
||||||
|
* Author: Giovanni Campagna <gcampagn@redhat.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include "meta-monitor-manager-kms.h"
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <clutter/clutter.h>
|
||||||
|
|
||||||
|
#include <errno.h>
|
||||||
|
#include <sys/ioctl.h>
|
||||||
|
#include <sys/mman.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <xf86drm.h>
|
||||||
|
#include <xf86drmMode.h>
|
||||||
|
|
||||||
|
#include <meta/main.h>
|
||||||
|
#include <meta/errors.h>
|
||||||
|
#include "edid.h"
|
||||||
|
|
||||||
|
#define ALL_WL_TRANSFORMS ((1 << (WL_OUTPUT_TRANSFORM_FLIPPED_270 + 1)) - 1)
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
drmModeConnector *connector;
|
||||||
|
|
||||||
|
unsigned n_encoders;
|
||||||
|
drmModeEncoderPtr *encoders;
|
||||||
|
drmModeEncoderPtr current_encoder;
|
||||||
|
|
||||||
|
/* bitmasks of encoder position in the resources array */
|
||||||
|
uint32_t encoder_mask;
|
||||||
|
uint32_t enc_clone_mask;
|
||||||
|
|
||||||
|
uint32_t dpms_prop_id;
|
||||||
|
uint32_t edid_blob_id;
|
||||||
|
} MetaOutputKms;
|
||||||
|
|
||||||
|
struct _MetaMonitorManagerKms
|
||||||
|
{
|
||||||
|
MetaMonitorManager parent_instance;
|
||||||
|
|
||||||
|
int fd;
|
||||||
|
|
||||||
|
drmModeConnector **connectors;
|
||||||
|
unsigned int n_connectors;
|
||||||
|
|
||||||
|
drmModeEncoder **encoders;
|
||||||
|
unsigned int n_encoders;
|
||||||
|
|
||||||
|
drmModeEncoder *current_encoder;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _MetaMonitorManagerKmsClass
|
||||||
|
{
|
||||||
|
MetaMonitorManagerClass parent_class;
|
||||||
|
};
|
||||||
|
|
||||||
|
G_DEFINE_TYPE (MetaMonitorManagerKms, meta_monitor_manager_kms, META_TYPE_MONITOR_MANAGER);
|
||||||
|
|
||||||
|
static void
|
||||||
|
free_resources (MetaMonitorManagerKms *manager_kms)
|
||||||
|
{
|
||||||
|
unsigned i;
|
||||||
|
|
||||||
|
for (i = 0; i < manager_kms->n_encoders; i++)
|
||||||
|
drmModeFreeEncoder (manager_kms->encoders[i]);
|
||||||
|
for (i = 0; i < manager_kms->n_connectors; i++)
|
||||||
|
drmModeFreeConnector (manager_kms->connectors[i]);
|
||||||
|
|
||||||
|
g_free (manager_kms->encoders);
|
||||||
|
g_free (manager_kms->connectors);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
compare_outputs (const void *one,
|
||||||
|
const void *two)
|
||||||
|
{
|
||||||
|
const MetaOutput *o_one = one, *o_two = two;
|
||||||
|
|
||||||
|
return strcmp (o_one->name, o_two->name);
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *
|
||||||
|
make_output_name (drmModeConnector *connector)
|
||||||
|
{
|
||||||
|
static const char * const connector_type_names[] = {
|
||||||
|
"unknown", "VGA", "DVII", "DVID", "DVID", "Composite",
|
||||||
|
"SVIDEO", "LVDS", "Component", "9PinDIN", "DisplayPort",
|
||||||
|
"HDMIA", "HDMIB", "TV", "eDP"
|
||||||
|
};
|
||||||
|
const char *connector_type_name;
|
||||||
|
|
||||||
|
if (connector->connector_type < G_N_ELEMENTS (connector_type_names))
|
||||||
|
connector_type_name = connector_type_names[connector->connector_type];
|
||||||
|
else
|
||||||
|
connector_type_name = "unknown";
|
||||||
|
|
||||||
|
return g_strdup_printf ("%s%d", connector_type_name, connector->connector_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_output_destroy_notify (MetaOutput *output)
|
||||||
|
{
|
||||||
|
MetaOutputKms *output_kms;
|
||||||
|
unsigned i;
|
||||||
|
|
||||||
|
output_kms = output->driver_private;
|
||||||
|
|
||||||
|
for (i = 0; i < output_kms->n_encoders; i++)
|
||||||
|
drmModeFreeEncoder (output_kms->encoders[i]);
|
||||||
|
g_free (output_kms->encoders);
|
||||||
|
|
||||||
|
g_slice_free (MetaOutputKms, output_kms);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_mode_destroy_notify (MetaMonitorMode *output)
|
||||||
|
{
|
||||||
|
g_slice_free (drmModeModeInfo, output->driver_private);
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
drm_mode_equal (gconstpointer one,
|
||||||
|
gconstpointer two)
|
||||||
|
{
|
||||||
|
const drmModeModeInfo *m_one = one;
|
||||||
|
const drmModeModeInfo *m_two = two;
|
||||||
|
|
||||||
|
return m_one->clock == m_two->clock &&
|
||||||
|
m_one->hdisplay == m_two->hdisplay &&
|
||||||
|
m_one->hsync_start == m_two->hsync_start &&
|
||||||
|
m_one->hsync_end == m_two->hsync_end &&
|
||||||
|
m_one->htotal == m_two->htotal &&
|
||||||
|
m_one->hskew == m_two->hskew &&
|
||||||
|
m_one->vdisplay == m_two->vdisplay &&
|
||||||
|
m_one->vsync_start == m_two->vsync_start &&
|
||||||
|
m_one->vsync_end == m_two->vsync_end &&
|
||||||
|
m_one->vtotal == m_two->vtotal &&
|
||||||
|
m_one->vscan == m_two->vscan &&
|
||||||
|
m_one->vrefresh == m_two->vrefresh &&
|
||||||
|
m_one->flags == m_two->flags &&
|
||||||
|
m_one->type == m_two->type &&
|
||||||
|
strncmp (m_one->name, m_two->name, DRM_DISPLAY_MODE_LEN) == 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static guint
|
||||||
|
drm_mode_hash (gconstpointer ptr)
|
||||||
|
{
|
||||||
|
const drmModeModeInfo *mode = ptr;
|
||||||
|
guint hash = 0;
|
||||||
|
|
||||||
|
/* We don't include the name in the hash because it's generally
|
||||||
|
derived from the other fields (hdisplay, vdisplay and flags)
|
||||||
|
*/
|
||||||
|
|
||||||
|
hash ^= mode->clock;
|
||||||
|
hash ^= mode->hdisplay ^ mode->hsync_start ^ mode->hsync_end;
|
||||||
|
hash ^= mode->vdisplay ^ mode->vsync_start ^ mode->vsync_end;
|
||||||
|
hash ^= mode->vrefresh;
|
||||||
|
hash ^= mode->flags ^ mode->type;
|
||||||
|
|
||||||
|
return hash;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
find_properties (MetaMonitorManagerKms *manager_kms,
|
||||||
|
MetaOutputKms *output_kms)
|
||||||
|
{
|
||||||
|
drmModePropertyPtr prop;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < output_kms->connector->count_props; i++)
|
||||||
|
{
|
||||||
|
prop = drmModeGetProperty (manager_kms->fd, output_kms->connector->props[i]);
|
||||||
|
if (!prop)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if ((prop->flags & DRM_MODE_PROP_ENUM) &&
|
||||||
|
strcmp(prop->name, "DPMS") == 0)
|
||||||
|
output_kms->dpms_prop_id = prop->prop_id;
|
||||||
|
else if ((prop->flags & DRM_MODE_PROP_BLOB) &&
|
||||||
|
strcmp (prop->name, "EDID") == 0)
|
||||||
|
output_kms->edid_blob_id = output_kms->connector->prop_values[i];
|
||||||
|
|
||||||
|
drmModeFreeProperty(prop);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static GBytes *
|
||||||
|
read_output_edid (MetaMonitorManagerKms *manager_kms,
|
||||||
|
MetaOutput *output)
|
||||||
|
{
|
||||||
|
MetaOutputKms *output_kms = output->driver_private;
|
||||||
|
drmModePropertyBlobPtr edid_blob = NULL;
|
||||||
|
|
||||||
|
if (output_kms->edid_blob_id == 0)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
edid_blob = drmModeGetPropertyBlob (manager_kms->fd, output_kms->edid_blob_id);
|
||||||
|
if (!edid_blob)
|
||||||
|
{
|
||||||
|
meta_warning ("Failed to read EDID of output %s: %s\n", output->name, strerror(errno));
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (edid_blob->length > 0)
|
||||||
|
return g_bytes_new_with_free_func (edid_blob->data, edid_blob->length,
|
||||||
|
(GDestroyNotify)drmModeFreePropertyBlob, edid_blob);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
drmModeFreePropertyBlob (edid_blob);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static MetaMonitorMode *
|
||||||
|
find_meta_mode (MetaMonitorManager *manager,
|
||||||
|
const drmModeModeInfo *drm_mode)
|
||||||
|
{
|
||||||
|
unsigned k;
|
||||||
|
|
||||||
|
for (k = 0; k < manager->n_modes; k++)
|
||||||
|
{
|
||||||
|
if (drm_mode_equal (drm_mode, manager->modes[k].driver_private))
|
||||||
|
return &manager->modes[k];
|
||||||
|
}
|
||||||
|
|
||||||
|
g_assert_not_reached ();
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static MetaOutput *
|
||||||
|
find_output_by_id (MetaOutput *outputs,
|
||||||
|
unsigned n_outputs,
|
||||||
|
glong id)
|
||||||
|
{
|
||||||
|
unsigned i;
|
||||||
|
|
||||||
|
for (i = 0; i < n_outputs; i++)
|
||||||
|
if (outputs[i].output_id == id)
|
||||||
|
return &outputs[i];
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_manager_kms_read_current (MetaMonitorManager *manager)
|
||||||
|
{
|
||||||
|
MetaMonitorManagerKms *manager_kms = META_MONITOR_MANAGER_KMS (manager);
|
||||||
|
drmModeRes *resources;
|
||||||
|
GHashTable *modes;
|
||||||
|
GHashTableIter iter;
|
||||||
|
drmModeModeInfo *mode;
|
||||||
|
unsigned int i, j, k;
|
||||||
|
unsigned int n_actual_outputs;
|
||||||
|
int width, height;
|
||||||
|
MetaOutput *old_outputs;
|
||||||
|
unsigned int n_old_outputs;
|
||||||
|
|
||||||
|
resources = drmModeGetResources(manager_kms->fd);
|
||||||
|
modes = g_hash_table_new (drm_mode_hash, drm_mode_equal);
|
||||||
|
|
||||||
|
manager->max_screen_width = resources->max_width;
|
||||||
|
manager->max_screen_height = resources->max_height;
|
||||||
|
|
||||||
|
manager->power_save_mode = META_POWER_SAVE_ON;
|
||||||
|
|
||||||
|
old_outputs = manager->outputs;
|
||||||
|
n_old_outputs = manager->n_outputs;
|
||||||
|
|
||||||
|
/* Note: we must not free the public structures (output, crtc, monitor
|
||||||
|
mode and monitor info) here, they must be kept alive until the API
|
||||||
|
users are done with them after we emit monitors-changed, and thus
|
||||||
|
are freed by the platform-independent layer. */
|
||||||
|
free_resources (manager_kms);
|
||||||
|
|
||||||
|
manager_kms->n_connectors = resources->count_connectors;
|
||||||
|
manager_kms->connectors = g_new (drmModeConnector *, manager_kms->n_connectors);
|
||||||
|
for (i = 0; i < manager_kms->n_connectors; i++)
|
||||||
|
{
|
||||||
|
drmModeConnector *connector;
|
||||||
|
|
||||||
|
connector = drmModeGetConnector (manager_kms->fd, resources->connectors[i]);
|
||||||
|
manager_kms->connectors[i] = connector;
|
||||||
|
|
||||||
|
if (connector->connection == DRM_MODE_CONNECTED)
|
||||||
|
{
|
||||||
|
/* Collect all modes for this connector */
|
||||||
|
for (j = 0; j < (unsigned)connector->count_modes; j++)
|
||||||
|
g_hash_table_add (modes, &connector->modes[j]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
manager_kms->n_encoders = resources->count_encoders;
|
||||||
|
manager_kms->encoders = g_new (drmModeEncoder *, manager_kms->n_encoders);
|
||||||
|
for (i = 0; i < manager_kms->n_encoders; i++)
|
||||||
|
{
|
||||||
|
manager_kms->encoders[i] = drmModeGetEncoder (manager_kms->fd,
|
||||||
|
resources->encoders[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
manager->n_modes = g_hash_table_size (modes);
|
||||||
|
manager->modes = g_new0 (MetaMonitorMode, manager->n_modes);
|
||||||
|
g_hash_table_iter_init (&iter, modes);
|
||||||
|
i = 0;
|
||||||
|
while (g_hash_table_iter_next (&iter, NULL, (gpointer)&mode))
|
||||||
|
{
|
||||||
|
MetaMonitorMode *meta_mode;
|
||||||
|
|
||||||
|
meta_mode = &manager->modes[i];
|
||||||
|
|
||||||
|
meta_mode->mode_id = i;
|
||||||
|
meta_mode->name = g_strndup (mode->name, DRM_DISPLAY_MODE_LEN);
|
||||||
|
meta_mode->width = mode->hdisplay;
|
||||||
|
meta_mode->height = mode->vdisplay;
|
||||||
|
meta_mode->refresh_rate = (1000 * mode->clock /
|
||||||
|
((float)mode->htotal * mode->vtotal));
|
||||||
|
|
||||||
|
meta_mode->driver_private = g_slice_dup (drmModeModeInfo, mode);
|
||||||
|
meta_mode->driver_notify = (GDestroyNotify)meta_monitor_mode_destroy_notify;
|
||||||
|
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
g_hash_table_destroy (modes);
|
||||||
|
|
||||||
|
manager->n_crtcs = resources->count_crtcs;
|
||||||
|
manager->crtcs = g_new0 (MetaCRTC, manager->n_crtcs);
|
||||||
|
width = 0; height = 0;
|
||||||
|
for (i = 0; i < (unsigned)resources->count_crtcs; i++)
|
||||||
|
{
|
||||||
|
drmModeCrtc *crtc;
|
||||||
|
MetaCRTC *meta_crtc;
|
||||||
|
|
||||||
|
crtc = drmModeGetCrtc (manager_kms->fd, resources->crtcs[i]);
|
||||||
|
|
||||||
|
meta_crtc = &manager->crtcs[i];
|
||||||
|
|
||||||
|
meta_crtc->crtc_id = crtc->crtc_id;
|
||||||
|
meta_crtc->rect.x = crtc->x;
|
||||||
|
meta_crtc->rect.y = crtc->y;
|
||||||
|
meta_crtc->rect.width = crtc->width;
|
||||||
|
meta_crtc->rect.height = crtc->height;
|
||||||
|
meta_crtc->is_dirty = FALSE;
|
||||||
|
meta_crtc->transform = WL_OUTPUT_TRANSFORM_NORMAL;
|
||||||
|
/* FIXME: implement! */
|
||||||
|
meta_crtc->all_transforms = 1 << WL_OUTPUT_TRANSFORM_NORMAL;
|
||||||
|
|
||||||
|
if (crtc->mode_valid)
|
||||||
|
{
|
||||||
|
for (j = 0; j < manager->n_modes; j++)
|
||||||
|
{
|
||||||
|
if (drm_mode_equal (&crtc->mode, manager->modes[j].driver_private))
|
||||||
|
{
|
||||||
|
meta_crtc->current_mode = &manager->modes[j];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
width = MAX (width, meta_crtc->rect.x + meta_crtc->rect.width);
|
||||||
|
height = MAX (height, meta_crtc->rect.y + meta_crtc->rect.height);
|
||||||
|
}
|
||||||
|
|
||||||
|
drmModeFreeCrtc (crtc);
|
||||||
|
}
|
||||||
|
|
||||||
|
manager->screen_width = width;
|
||||||
|
manager->screen_height = height;
|
||||||
|
|
||||||
|
manager->outputs = g_new0 (MetaOutput, manager_kms->n_connectors);
|
||||||
|
n_actual_outputs = 0;
|
||||||
|
|
||||||
|
for (i = 0; i < manager_kms->n_connectors; i++)
|
||||||
|
{
|
||||||
|
MetaOutput *meta_output, *old_output;
|
||||||
|
MetaOutputKms *output_kms;
|
||||||
|
drmModeConnector *connector;
|
||||||
|
GArray *crtcs;
|
||||||
|
unsigned int crtc_mask;
|
||||||
|
GBytes *edid;
|
||||||
|
|
||||||
|
connector = manager_kms->connectors[i];
|
||||||
|
meta_output = &manager->outputs[n_actual_outputs];
|
||||||
|
|
||||||
|
if (connector->connection == DRM_MODE_CONNECTED)
|
||||||
|
{
|
||||||
|
meta_output->driver_private = output_kms = g_slice_new0 (MetaOutputKms);
|
||||||
|
meta_output->driver_notify = (GDestroyNotify)meta_output_destroy_notify;
|
||||||
|
|
||||||
|
meta_output->output_id = connector->connector_id;
|
||||||
|
meta_output->name = make_output_name (connector);
|
||||||
|
meta_output->width_mm = connector->mmWidth;
|
||||||
|
meta_output->height_mm = connector->mmHeight;
|
||||||
|
|
||||||
|
switch (connector->subpixel)
|
||||||
|
{
|
||||||
|
case DRM_MODE_SUBPIXEL_NONE:
|
||||||
|
meta_output->subpixel_order = COGL_SUBPIXEL_ORDER_NONE;
|
||||||
|
break;
|
||||||
|
case DRM_MODE_SUBPIXEL_HORIZONTAL_RGB:
|
||||||
|
meta_output->subpixel_order = COGL_SUBPIXEL_ORDER_HORIZONTAL_RGB;
|
||||||
|
break;
|
||||||
|
case DRM_MODE_SUBPIXEL_HORIZONTAL_BGR:
|
||||||
|
meta_output->subpixel_order = COGL_SUBPIXEL_ORDER_HORIZONTAL_BGR;
|
||||||
|
break;
|
||||||
|
case DRM_MODE_SUBPIXEL_VERTICAL_RGB:
|
||||||
|
meta_output->subpixel_order = COGL_SUBPIXEL_ORDER_VERTICAL_RGB;
|
||||||
|
break;
|
||||||
|
case DRM_MODE_SUBPIXEL_VERTICAL_BGR:
|
||||||
|
meta_output->subpixel_order = COGL_SUBPIXEL_ORDER_VERTICAL_BGR;
|
||||||
|
break;
|
||||||
|
case DRM_MODE_SUBPIXEL_UNKNOWN:
|
||||||
|
default:
|
||||||
|
meta_output->subpixel_order = COGL_SUBPIXEL_ORDER_UNKNOWN;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
meta_output->n_modes = connector->count_modes;
|
||||||
|
meta_output->modes = g_new0 (MetaMonitorMode *, meta_output->n_modes);
|
||||||
|
for (j = 0; j < meta_output->n_modes; j++)
|
||||||
|
meta_output->modes[j] = find_meta_mode (manager, &connector->modes[j]);
|
||||||
|
meta_output->preferred_mode = meta_output->modes[0];
|
||||||
|
|
||||||
|
output_kms->connector = connector;
|
||||||
|
output_kms->n_encoders = connector->count_encoders;
|
||||||
|
output_kms->encoders = g_new0 (drmModeEncoderPtr, output_kms->n_encoders);
|
||||||
|
|
||||||
|
crtc_mask = ~(unsigned int)0;
|
||||||
|
for (j = 0; j < output_kms->n_encoders; j++)
|
||||||
|
{
|
||||||
|
output_kms->encoders[j] = drmModeGetEncoder (manager_kms->fd, connector->encoders[j]);
|
||||||
|
|
||||||
|
/* We only list CRTCs as supported if they are supported by all encoders
|
||||||
|
for this connectors.
|
||||||
|
|
||||||
|
This is what xf86-video-modesetting does (see drmmode_output_init())
|
||||||
|
*/
|
||||||
|
crtc_mask &= output_kms->encoders[j]->possible_crtcs;
|
||||||
|
|
||||||
|
if (output_kms->encoders[j]->encoder_id == connector->encoder_id)
|
||||||
|
output_kms->current_encoder = output_kms->encoders[j];
|
||||||
|
}
|
||||||
|
|
||||||
|
crtcs = g_array_new (FALSE, FALSE, sizeof (MetaCRTC*));
|
||||||
|
|
||||||
|
for (j = 0; j < manager->n_crtcs; j++)
|
||||||
|
{
|
||||||
|
if (crtc_mask & (1 << j))
|
||||||
|
{
|
||||||
|
MetaCRTC *crtc = &manager->crtcs[j];
|
||||||
|
g_array_append_val (crtcs, crtc);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
meta_output->n_possible_crtcs = crtcs->len;
|
||||||
|
meta_output->possible_crtcs = (void*)g_array_free (crtcs, FALSE);
|
||||||
|
|
||||||
|
if (output_kms->current_encoder && output_kms->current_encoder->crtc_id != 0)
|
||||||
|
{
|
||||||
|
for (j = 0; j < manager->n_crtcs; j++)
|
||||||
|
{
|
||||||
|
if (manager->crtcs[j].crtc_id == output_kms->current_encoder->crtc_id)
|
||||||
|
{
|
||||||
|
meta_output->crtc = &manager->crtcs[j];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
meta_output->crtc = NULL;
|
||||||
|
|
||||||
|
old_output = find_output_by_id (old_outputs, n_old_outputs,
|
||||||
|
meta_output->output_id);
|
||||||
|
if (old_output)
|
||||||
|
{
|
||||||
|
meta_output->is_primary = old_output->is_primary;
|
||||||
|
meta_output->is_presentation = old_output->is_presentation;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
meta_output->is_primary = FALSE;
|
||||||
|
meta_output->is_presentation = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
find_properties (manager_kms, output_kms);
|
||||||
|
|
||||||
|
edid = read_output_edid (manager_kms, meta_output);
|
||||||
|
if (edid)
|
||||||
|
{
|
||||||
|
MonitorInfo *parsed_edid;
|
||||||
|
gsize len;
|
||||||
|
|
||||||
|
parsed_edid = decode_edid (g_bytes_get_data (edid, &len));
|
||||||
|
if (parsed_edid)
|
||||||
|
{
|
||||||
|
meta_output->vendor = g_strndup (parsed_edid->manufacturer_code, 4);
|
||||||
|
meta_output->product = g_strndup (parsed_edid->dsc_product_name, 14);
|
||||||
|
meta_output->serial = g_strndup (parsed_edid->dsc_serial_number, 14);
|
||||||
|
|
||||||
|
g_free (parsed_edid);
|
||||||
|
}
|
||||||
|
|
||||||
|
g_bytes_unref (edid);
|
||||||
|
}
|
||||||
|
if (!meta_output->vendor)
|
||||||
|
{
|
||||||
|
meta_output->vendor = g_strdup ("unknown");
|
||||||
|
meta_output->product = g_strdup ("unknown");
|
||||||
|
meta_output->serial = g_strdup ("unknown");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* FIXME: backlight is a very driver specific thing unfortunately,
|
||||||
|
every DDX does its own thing, and the dumb KMS API does not include it.
|
||||||
|
|
||||||
|
For example, xf86-video-intel has a list of paths to probe in /sys/class/backlight
|
||||||
|
(one for each major HW maker, and then some).
|
||||||
|
We can't do the same because we're not root.
|
||||||
|
It might be best to leave backlight out of the story and rely on the setuid
|
||||||
|
helper in gnome-settings-daemon.
|
||||||
|
*/
|
||||||
|
meta_output->backlight_min = 0;
|
||||||
|
meta_output->backlight_max = 0;
|
||||||
|
meta_output->backlight = -1;
|
||||||
|
|
||||||
|
n_actual_outputs++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
manager->n_outputs = n_actual_outputs;
|
||||||
|
manager->outputs = g_renew (MetaOutput, manager->outputs, manager->n_outputs);
|
||||||
|
|
||||||
|
/* Sort the outputs for easier handling in MetaMonitorConfig */
|
||||||
|
qsort (manager->outputs, manager->n_outputs, sizeof (MetaOutput), compare_outputs);
|
||||||
|
|
||||||
|
/* Now fix the clones.
|
||||||
|
Code mostly inspired by xf86-video-modesetting. */
|
||||||
|
|
||||||
|
/* XXX: intel hardware doesn't usually have clones, but I only have laptops with
|
||||||
|
intel cards, so this code was never tested! */
|
||||||
|
for (i = 0; i < manager->n_outputs; i++)
|
||||||
|
{
|
||||||
|
MetaOutput *meta_output;
|
||||||
|
MetaOutputKms *output_kms;
|
||||||
|
|
||||||
|
meta_output = &manager->outputs[i];
|
||||||
|
output_kms = meta_output->driver_private;
|
||||||
|
|
||||||
|
output_kms->enc_clone_mask = 0xff;
|
||||||
|
output_kms->encoder_mask = 0;
|
||||||
|
|
||||||
|
for (j = 0; j < output_kms->n_encoders; j++)
|
||||||
|
{
|
||||||
|
for (k = 0; k < manager_kms->n_encoders; k++)
|
||||||
|
{
|
||||||
|
if (output_kms->encoders[j]->encoder_id == manager_kms->encoders[k]->encoder_id)
|
||||||
|
{
|
||||||
|
output_kms->encoder_mask |= (1 << k);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
output_kms->enc_clone_mask &= output_kms->encoders[j]->possible_clones;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < manager->n_outputs; i++)
|
||||||
|
{
|
||||||
|
MetaOutput *meta_output;
|
||||||
|
MetaOutputKms *output_kms;
|
||||||
|
|
||||||
|
meta_output = &manager->outputs[i];
|
||||||
|
output_kms = meta_output->driver_private;
|
||||||
|
|
||||||
|
if (output_kms->enc_clone_mask == 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
for (j = 0; j < manager->n_outputs; j++)
|
||||||
|
{
|
||||||
|
MetaOutput *meta_clone;
|
||||||
|
MetaOutputKms *clone_kms;
|
||||||
|
|
||||||
|
meta_clone = &manager->outputs[i];
|
||||||
|
clone_kms = meta_clone->driver_private;
|
||||||
|
|
||||||
|
if (meta_clone == meta_output)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (clone_kms->encoder_mask == 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (clone_kms->encoder_mask == output_kms->enc_clone_mask)
|
||||||
|
{
|
||||||
|
meta_output->n_possible_clones++;
|
||||||
|
meta_output->possible_clones = g_renew (MetaOutput *,
|
||||||
|
meta_output->possible_clones,
|
||||||
|
meta_output->n_possible_clones);
|
||||||
|
meta_output->possible_clones[meta_output->n_possible_clones - 1] = meta_clone;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
drmModeFreeResources (resources);
|
||||||
|
}
|
||||||
|
|
||||||
|
static GBytes *
|
||||||
|
meta_monitor_manager_kms_read_edid (MetaMonitorManager *manager,
|
||||||
|
MetaOutput *output)
|
||||||
|
{
|
||||||
|
MetaMonitorManagerKms *manager_kms = META_MONITOR_MANAGER_KMS (manager);
|
||||||
|
|
||||||
|
return read_output_edid (manager_kms, output);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_manager_kms_set_power_save_mode (MetaMonitorManager *manager,
|
||||||
|
MetaPowerSave mode)
|
||||||
|
{
|
||||||
|
MetaMonitorManagerKms *manager_kms = META_MONITOR_MANAGER_KMS (manager);
|
||||||
|
uint64_t state;
|
||||||
|
unsigned i;
|
||||||
|
|
||||||
|
switch (mode) {
|
||||||
|
case META_POWER_SAVE_ON:
|
||||||
|
state = DRM_MODE_DPMS_ON;
|
||||||
|
break;
|
||||||
|
case META_POWER_SAVE_STANDBY:
|
||||||
|
state = DRM_MODE_DPMS_STANDBY;
|
||||||
|
break;
|
||||||
|
case META_POWER_SAVE_SUSPEND:
|
||||||
|
state = DRM_MODE_DPMS_SUSPEND;
|
||||||
|
break;
|
||||||
|
case META_POWER_SAVE_OFF:
|
||||||
|
state = DRM_MODE_DPMS_OFF;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < manager->n_outputs; i++)
|
||||||
|
{
|
||||||
|
MetaOutput *meta_output;
|
||||||
|
MetaOutputKms *output_kms;
|
||||||
|
|
||||||
|
meta_output = &manager->outputs[i];
|
||||||
|
output_kms = meta_output->driver_private;
|
||||||
|
|
||||||
|
if (output_kms->dpms_prop_id != 0)
|
||||||
|
{
|
||||||
|
int ok = drmModeConnectorSetProperty(manager_kms->fd, meta_output->output_id,
|
||||||
|
output_kms->dpms_prop_id, state);
|
||||||
|
|
||||||
|
if (ok < 0)
|
||||||
|
meta_warning ("Failed to set power save mode for output %s: %s\n",
|
||||||
|
meta_output->name, strerror (errno));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
crtc_free (CoglKmsCrtc *crtc)
|
||||||
|
{
|
||||||
|
g_free (crtc->connectors);
|
||||||
|
g_slice_free (CoglKmsCrtc, crtc);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_manager_kms_apply_configuration (MetaMonitorManager *manager,
|
||||||
|
MetaCRTCInfo **crtcs,
|
||||||
|
unsigned int n_crtcs,
|
||||||
|
MetaOutputInfo **outputs,
|
||||||
|
unsigned int n_outputs)
|
||||||
|
{
|
||||||
|
ClutterBackend *backend;
|
||||||
|
CoglContext *cogl_context;
|
||||||
|
CoglDisplay *cogl_display;
|
||||||
|
unsigned i;
|
||||||
|
GPtrArray *cogl_crtcs;
|
||||||
|
int screen_width, screen_height;
|
||||||
|
gboolean ok;
|
||||||
|
GError *error;
|
||||||
|
|
||||||
|
cogl_crtcs = g_ptr_array_new_full (manager->n_crtcs, (GDestroyNotify)crtc_free);
|
||||||
|
screen_width = 0; screen_height = 0;
|
||||||
|
for (i = 0; i < n_crtcs; i++)
|
||||||
|
{
|
||||||
|
MetaCRTCInfo *crtc_info = crtcs[i];
|
||||||
|
MetaCRTC *crtc = crtc_info->crtc;
|
||||||
|
CoglKmsCrtc *cogl_crtc;
|
||||||
|
|
||||||
|
crtc->is_dirty = TRUE;
|
||||||
|
|
||||||
|
cogl_crtc = g_slice_new0 (CoglKmsCrtc);
|
||||||
|
g_ptr_array_add (cogl_crtcs, cogl_crtc);
|
||||||
|
|
||||||
|
if (crtc_info->mode == NULL)
|
||||||
|
{
|
||||||
|
cogl_crtc->id = crtc->crtc_id;
|
||||||
|
cogl_crtc->x = 0;
|
||||||
|
cogl_crtc->y = 0;
|
||||||
|
cogl_crtc->count = 0;
|
||||||
|
memset (&cogl_crtc->mode, 0, sizeof (drmModeModeInfo));
|
||||||
|
cogl_crtc->connectors = NULL;
|
||||||
|
cogl_crtc->count = 0;
|
||||||
|
|
||||||
|
crtc->rect.x = 0;
|
||||||
|
crtc->rect.y = 0;
|
||||||
|
crtc->rect.width = 0;
|
||||||
|
crtc->rect.height = 0;
|
||||||
|
crtc->current_mode = NULL;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
MetaMonitorMode *mode;
|
||||||
|
uint32_t *connectors;
|
||||||
|
unsigned int j, n_connectors;
|
||||||
|
int width, height;
|
||||||
|
|
||||||
|
mode = crtc_info->mode;
|
||||||
|
|
||||||
|
cogl_crtc->id = crtc->crtc_id;
|
||||||
|
cogl_crtc->x = crtc_info->x;
|
||||||
|
cogl_crtc->y = crtc_info->y;
|
||||||
|
cogl_crtc->count = n_connectors = crtc_info->outputs->len;
|
||||||
|
cogl_crtc->connectors = connectors = g_new (uint32_t, n_connectors);
|
||||||
|
|
||||||
|
for (j = 0; j < n_connectors; j++)
|
||||||
|
{
|
||||||
|
MetaOutput *output = g_ptr_array_index (crtc_info->outputs, j);
|
||||||
|
|
||||||
|
connectors[j] = output->output_id;
|
||||||
|
|
||||||
|
output->is_dirty = TRUE;
|
||||||
|
output->crtc = crtc;
|
||||||
|
}
|
||||||
|
|
||||||
|
memcpy (&cogl_crtc->mode, crtc_info->mode->driver_private,
|
||||||
|
sizeof (drmModeModeInfo));
|
||||||
|
|
||||||
|
if (meta_monitor_transform_is_rotated (crtc_info->transform))
|
||||||
|
{
|
||||||
|
width = mode->height;
|
||||||
|
height = mode->width;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
width = mode->width;
|
||||||
|
height = mode->height;
|
||||||
|
}
|
||||||
|
|
||||||
|
screen_width = MAX (screen_width, crtc_info->x + width);
|
||||||
|
screen_height = MAX (screen_height, crtc_info->y + height);
|
||||||
|
|
||||||
|
crtc->rect.x = crtc_info->x;
|
||||||
|
crtc->rect.y = crtc_info->y;
|
||||||
|
crtc->rect.width = width;
|
||||||
|
crtc->rect.height = height;
|
||||||
|
crtc->current_mode = mode;
|
||||||
|
crtc->transform = crtc_info->transform;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Disable CRTCs not mentioned in the list (they have is_dirty == FALSE,
|
||||||
|
because they weren't seen in the first loop) */
|
||||||
|
for (i = 0; i < manager->n_crtcs; i++)
|
||||||
|
{
|
||||||
|
MetaCRTC *crtc = &manager->crtcs[i];
|
||||||
|
CoglKmsCrtc *cogl_crtc;
|
||||||
|
|
||||||
|
crtc->logical_monitor = NULL;
|
||||||
|
|
||||||
|
if (crtc->is_dirty)
|
||||||
|
{
|
||||||
|
crtc->is_dirty = FALSE;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
cogl_crtc = g_slice_new0 (CoglKmsCrtc);
|
||||||
|
g_ptr_array_add (cogl_crtcs, cogl_crtc);
|
||||||
|
|
||||||
|
cogl_crtc->id = crtc->crtc_id;
|
||||||
|
cogl_crtc->x = 0;
|
||||||
|
cogl_crtc->y = 0;
|
||||||
|
cogl_crtc->count = 0;
|
||||||
|
memset (&cogl_crtc->mode, 0, sizeof (drmModeModeInfo));
|
||||||
|
cogl_crtc->connectors = NULL;
|
||||||
|
cogl_crtc->count = 0;
|
||||||
|
|
||||||
|
crtc->rect.x = 0;
|
||||||
|
crtc->rect.y = 0;
|
||||||
|
crtc->rect.width = 0;
|
||||||
|
crtc->rect.height = 0;
|
||||||
|
crtc->current_mode = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
backend = clutter_get_default_backend ();
|
||||||
|
cogl_context = clutter_backend_get_cogl_context (backend);
|
||||||
|
cogl_display = cogl_context_get_display (cogl_context);
|
||||||
|
|
||||||
|
error = NULL;
|
||||||
|
ok = cogl_kms_display_set_layout (cogl_display, screen_width, screen_height,
|
||||||
|
(CoglKmsCrtc**)cogl_crtcs->pdata, cogl_crtcs->len, &error);
|
||||||
|
g_ptr_array_unref (cogl_crtcs);
|
||||||
|
|
||||||
|
if (!ok)
|
||||||
|
{
|
||||||
|
meta_warning ("Applying display configuration failed: %s\n", error->message);
|
||||||
|
g_error_free (error);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < n_outputs; i++)
|
||||||
|
{
|
||||||
|
MetaOutputInfo *output_info = outputs[i];
|
||||||
|
MetaOutput *output = output_info->output;
|
||||||
|
|
||||||
|
output->is_primary = output_info->is_primary;
|
||||||
|
output->is_presentation = output_info->is_presentation;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Disable outputs not mentioned in the list */
|
||||||
|
for (i = 0; i < manager->n_outputs; i++)
|
||||||
|
{
|
||||||
|
MetaOutput *output = &manager->outputs[i];
|
||||||
|
|
||||||
|
if (output->is_dirty)
|
||||||
|
{
|
||||||
|
output->is_dirty = FALSE;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
output->crtc = NULL;
|
||||||
|
output->is_primary = FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
manager->screen_width = screen_width;
|
||||||
|
manager->screen_height = screen_height;
|
||||||
|
|
||||||
|
meta_monitor_manager_rebuild_derived (manager);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_manager_kms_get_crtc_gamma (MetaMonitorManager *manager,
|
||||||
|
MetaCRTC *crtc,
|
||||||
|
gsize *size,
|
||||||
|
unsigned short **red,
|
||||||
|
unsigned short **green,
|
||||||
|
unsigned short **blue)
|
||||||
|
{
|
||||||
|
MetaMonitorManagerKms *manager_kms = META_MONITOR_MANAGER_KMS (manager);
|
||||||
|
drmModeCrtc *kms_crtc;
|
||||||
|
|
||||||
|
kms_crtc = drmModeGetCrtc (manager_kms->fd, crtc->crtc_id);
|
||||||
|
|
||||||
|
*size = kms_crtc->gamma_size;
|
||||||
|
*red = g_new (unsigned short, *size);
|
||||||
|
*green = g_new (unsigned short, *size);
|
||||||
|
*blue = g_new (unsigned short, *size);
|
||||||
|
|
||||||
|
drmModeCrtcGetGamma (manager_kms->fd, crtc->crtc_id, *size, *red, *green, *blue);
|
||||||
|
|
||||||
|
drmModeFreeCrtc (kms_crtc);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_manager_kms_set_crtc_gamma (MetaMonitorManager *manager,
|
||||||
|
MetaCRTC *crtc,
|
||||||
|
gsize size,
|
||||||
|
unsigned short *red,
|
||||||
|
unsigned short *green,
|
||||||
|
unsigned short *blue)
|
||||||
|
{
|
||||||
|
MetaMonitorManagerKms *manager_kms = META_MONITOR_MANAGER_KMS (manager);
|
||||||
|
|
||||||
|
drmModeCrtcSetGamma (manager_kms->fd, crtc->crtc_id, size, red, green, blue);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_manager_kms_init (MetaMonitorManagerKms *manager_kms)
|
||||||
|
{
|
||||||
|
ClutterBackend *backend;
|
||||||
|
CoglContext *cogl_context;
|
||||||
|
CoglDisplay *cogl_display;
|
||||||
|
CoglRenderer *cogl_renderer;
|
||||||
|
|
||||||
|
backend = clutter_get_default_backend ();
|
||||||
|
cogl_context = clutter_backend_get_cogl_context (backend);
|
||||||
|
cogl_display = cogl_context_get_display (cogl_context);
|
||||||
|
cogl_renderer = cogl_display_get_renderer (cogl_display);
|
||||||
|
|
||||||
|
manager_kms->fd = cogl_kms_renderer_get_kms_fd (cogl_renderer);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_manager_kms_finalize (GObject *object)
|
||||||
|
{
|
||||||
|
MetaMonitorManagerKms *manager_kms = META_MONITOR_MANAGER_KMS (object);
|
||||||
|
|
||||||
|
free_resources (manager_kms);
|
||||||
|
|
||||||
|
G_OBJECT_CLASS (meta_monitor_manager_kms_parent_class)->finalize (object);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_monitor_manager_kms_class_init (MetaMonitorManagerKmsClass *klass)
|
||||||
|
{
|
||||||
|
MetaMonitorManagerClass *manager_class = META_MONITOR_MANAGER_CLASS (klass);
|
||||||
|
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
||||||
|
|
||||||
|
object_class->finalize = meta_monitor_manager_kms_finalize;
|
||||||
|
|
||||||
|
manager_class->read_current = meta_monitor_manager_kms_read_current;
|
||||||
|
manager_class->read_edid = meta_monitor_manager_kms_read_edid;
|
||||||
|
manager_class->apply_configuration = meta_monitor_manager_kms_apply_configuration;
|
||||||
|
manager_class->set_power_save_mode = meta_monitor_manager_kms_set_power_save_mode;
|
||||||
|
manager_class->get_crtc_gamma = meta_monitor_manager_kms_get_crtc_gamma;
|
||||||
|
manager_class->set_crtc_gamma = meta_monitor_manager_kms_set_crtc_gamma;
|
||||||
|
}
|
||||||
|
|
||||||
40
src/backends/native/meta-monitor-manager-kms.h
Normal file
40
src/backends/native/meta-monitor-manager-kms.h
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2001 Havoc Pennington
|
||||||
|
* Copyright (C) 2003 Rob Adams
|
||||||
|
* Copyright (C) 2004-2006 Elijah Newren
|
||||||
|
* Copyright (C) 2013 Red Hat Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation; either version 2 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef META_MONITOR_MANAGER_KMS_H
|
||||||
|
#define META_MONITOR_MANAGER_KMS_H
|
||||||
|
|
||||||
|
#include "meta-monitor-manager.h"
|
||||||
|
|
||||||
|
#define META_TYPE_MONITOR_MANAGER_KMS (meta_monitor_manager_kms_get_type ())
|
||||||
|
#define META_MONITOR_MANAGER_KMS(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_MONITOR_MANAGER_KMS, MetaMonitorManagerKms))
|
||||||
|
#define META_MONITOR_MANAGER_KMS_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), META_TYPE_MONITOR_MANAGER_KMS, MetaMonitorManagerKmsClass))
|
||||||
|
#define META_IS_MONITOR_MANAGER_KMS(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_MONITOR_MANAGER_KMS))
|
||||||
|
#define META_IS_MONITOR_MANAGER_KMS_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), META_TYPE_MONITOR_MANAGER_KMS))
|
||||||
|
#define META_MONITOR_MANAGER_KMS_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), META_TYPE_MONITOR_MANAGER_KMS, MetaMonitorManagerKmsClass))
|
||||||
|
|
||||||
|
typedef struct _MetaMonitorManagerKmsClass MetaMonitorManagerKmsClass;
|
||||||
|
typedef struct _MetaMonitorManagerKms MetaMonitorManagerKms;
|
||||||
|
|
||||||
|
GType meta_monitor_manager_kms_get_type (void);
|
||||||
|
|
||||||
|
#endif /* META_MONITOR_MANAGER_KMS_H */
|
||||||
411
src/backends/native/meta-weston-launch.c
Normal file
411
src/backends/native/meta-weston-launch.c
Normal file
@@ -0,0 +1,411 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation; either version 2 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
||||||
|
* 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <config.h>
|
||||||
|
|
||||||
|
#include <gio/gio.h>
|
||||||
|
#include <gio/gunixfdmessage.h>
|
||||||
|
|
||||||
|
#include <clutter/clutter.h>
|
||||||
|
#include <clutter/egl/clutter-egl.h>
|
||||||
|
#include <clutter/evdev/clutter-evdev.h>
|
||||||
|
|
||||||
|
#include <glib.h>
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <errno.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
#include <sys/un.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <sys/wait.h>
|
||||||
|
|
||||||
|
#include <drm.h>
|
||||||
|
#include <xf86drm.h>
|
||||||
|
#include <xf86drmMode.h>
|
||||||
|
|
||||||
|
#include "wayland/meta-wayland-private.h"
|
||||||
|
#include "meta-cursor-tracker-private.h"
|
||||||
|
#include "meta-weston-launch.h"
|
||||||
|
|
||||||
|
struct _MetaLauncher
|
||||||
|
{
|
||||||
|
GSocket *weston_launch;
|
||||||
|
|
||||||
|
gboolean vt_switched;
|
||||||
|
|
||||||
|
GMainContext *nested_context;
|
||||||
|
GMainLoop *nested_loop;
|
||||||
|
|
||||||
|
GSource *inner_source;
|
||||||
|
GSource *outer_source;
|
||||||
|
};
|
||||||
|
|
||||||
|
static void handle_request_vt_switch (MetaLauncher *self);
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
request_vt_switch_idle (gpointer user_data)
|
||||||
|
{
|
||||||
|
handle_request_vt_switch (user_data);
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
send_message_to_wl (MetaLauncher *self,
|
||||||
|
void *message,
|
||||||
|
gsize size,
|
||||||
|
GSocketControlMessage *out_cmsg,
|
||||||
|
GSocketControlMessage **in_cmsg,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
struct weston_launcher_reply reply;
|
||||||
|
GInputVector in_iov = { &reply, sizeof (reply) };
|
||||||
|
GOutputVector out_iov = { message, size };
|
||||||
|
GSocketControlMessage *out_all_cmsg[2];
|
||||||
|
GSocketControlMessage **in_all_cmsg;
|
||||||
|
int flags = 0;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
out_all_cmsg[0] = out_cmsg;
|
||||||
|
out_all_cmsg[1] = NULL;
|
||||||
|
if (g_socket_send_message (self->weston_launch, NULL,
|
||||||
|
&out_iov, 1,
|
||||||
|
out_all_cmsg, -1,
|
||||||
|
flags, NULL, error) != (gssize)size)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
if (g_socket_receive_message (self->weston_launch, NULL,
|
||||||
|
&in_iov, 1,
|
||||||
|
&in_all_cmsg, NULL,
|
||||||
|
&flags, NULL, error) != sizeof (reply))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
while (reply.header.opcode != ((struct weston_launcher_message*)message)->opcode)
|
||||||
|
{
|
||||||
|
/* There were events queued */
|
||||||
|
g_assert ((reply.header.opcode & WESTON_LAUNCHER_EVENT) == WESTON_LAUNCHER_EVENT);
|
||||||
|
|
||||||
|
/* This can never happen, because the only time mutter-launch can queue
|
||||||
|
this event is after confirming a VT switch, and we don't make requests
|
||||||
|
during that time.
|
||||||
|
|
||||||
|
Note that getting this event would be really bad, because we would be
|
||||||
|
in the wrong loop/context.
|
||||||
|
*/
|
||||||
|
g_assert (reply.header.opcode != WESTON_LAUNCHER_SERVER_VT_ENTER);
|
||||||
|
|
||||||
|
switch (reply.header.opcode)
|
||||||
|
{
|
||||||
|
case WESTON_LAUNCHER_SERVER_REQUEST_VT_SWITCH:
|
||||||
|
g_idle_add (request_vt_switch_idle, self);
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
g_assert_not_reached ();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (g_socket_receive_message (self->weston_launch, NULL,
|
||||||
|
&in_iov, 1,
|
||||||
|
NULL, NULL,
|
||||||
|
&flags, NULL, error) != sizeof (reply))
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (reply.ret != 0)
|
||||||
|
{
|
||||||
|
if (reply.ret == -1)
|
||||||
|
g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
|
||||||
|
"Got failure from weston-launch");
|
||||||
|
else
|
||||||
|
g_set_error (error, G_IO_ERROR, g_io_error_from_errno (-reply.ret),
|
||||||
|
"Got failure from weston-launch: %s", strerror (-reply.ret));
|
||||||
|
|
||||||
|
for (i = 0; in_all_cmsg && in_all_cmsg[i]; i++)
|
||||||
|
g_object_unref (in_all_cmsg[i]);
|
||||||
|
g_free (in_all_cmsg);
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (in_all_cmsg && in_all_cmsg[0])
|
||||||
|
{
|
||||||
|
for (i = 1; in_all_cmsg[i]; i++)
|
||||||
|
g_object_unref (in_all_cmsg[i]);
|
||||||
|
*in_cmsg = in_all_cmsg[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
g_free (in_all_cmsg);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
meta_launcher_open_device (MetaLauncher *self,
|
||||||
|
const char *name,
|
||||||
|
int flags,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
struct weston_launcher_open *message;
|
||||||
|
GSocketControlMessage *cmsg;
|
||||||
|
gboolean ok;
|
||||||
|
gsize size;
|
||||||
|
int *fds, n_fd;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
size = sizeof (struct weston_launcher_open) + strlen (name) + 1;
|
||||||
|
message = g_malloc (size);
|
||||||
|
message->header.opcode = WESTON_LAUNCHER_OPEN;
|
||||||
|
message->flags = flags;
|
||||||
|
strcpy (message->path, name);
|
||||||
|
message->path[strlen(name)] = 0;
|
||||||
|
|
||||||
|
ok = send_message_to_wl (self, message, size, NULL, &cmsg, error);
|
||||||
|
|
||||||
|
if (ok)
|
||||||
|
{
|
||||||
|
g_assert (G_IS_UNIX_FD_MESSAGE (cmsg));
|
||||||
|
|
||||||
|
fds = g_unix_fd_message_steal_fds (G_UNIX_FD_MESSAGE (cmsg), &n_fd);
|
||||||
|
g_assert (n_fd == 1);
|
||||||
|
|
||||||
|
ret = fds[0];
|
||||||
|
g_free (fds);
|
||||||
|
g_object_unref (cmsg);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
ret = -1;
|
||||||
|
|
||||||
|
g_free (message);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_launcher_enter (MetaLauncher *launcher)
|
||||||
|
{
|
||||||
|
ClutterBackend *backend;
|
||||||
|
CoglContext *cogl_context;
|
||||||
|
CoglDisplay *cogl_display;
|
||||||
|
|
||||||
|
backend = clutter_get_default_backend ();
|
||||||
|
cogl_context = clutter_backend_get_cogl_context (backend);
|
||||||
|
cogl_display = cogl_context_get_display (cogl_context);
|
||||||
|
cogl_kms_display_queue_modes_reset (cogl_display);
|
||||||
|
|
||||||
|
clutter_evdev_reclaim_devices ();
|
||||||
|
|
||||||
|
{
|
||||||
|
MetaWaylandCompositor *compositor = meta_wayland_compositor_get_default ();
|
||||||
|
|
||||||
|
/* When we mode-switch back, we need to immediately queue a redraw
|
||||||
|
* in case nothing else queued one for us, and force the cursor to
|
||||||
|
* update. */
|
||||||
|
|
||||||
|
clutter_actor_queue_redraw (compositor->stage);
|
||||||
|
meta_cursor_tracker_force_update (compositor->seat->cursor_tracker);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_launcher_leave (MetaLauncher *launcher)
|
||||||
|
{
|
||||||
|
clutter_evdev_release_devices ();
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
on_evdev_device_open (const char *path,
|
||||||
|
int flags,
|
||||||
|
gpointer user_data,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
MetaLauncher *launcher = user_data;
|
||||||
|
|
||||||
|
return meta_launcher_open_device (launcher, path, flags, error);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
on_evdev_device_close (int fd,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
close (fd);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
handle_vt_enter (MetaLauncher *launcher)
|
||||||
|
{
|
||||||
|
g_assert (launcher->vt_switched);
|
||||||
|
|
||||||
|
g_main_loop_quit (launcher->nested_loop);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
handle_request_vt_switch (MetaLauncher *launcher)
|
||||||
|
{
|
||||||
|
struct weston_launcher_message message;
|
||||||
|
GError *error;
|
||||||
|
gboolean ok;
|
||||||
|
|
||||||
|
meta_launcher_leave (launcher);
|
||||||
|
|
||||||
|
message.opcode = WESTON_LAUNCHER_CONFIRM_VT_SWITCH;
|
||||||
|
|
||||||
|
error = NULL;
|
||||||
|
ok = send_message_to_wl (launcher, &message, sizeof (message), NULL, NULL, &error);
|
||||||
|
if (!ok) {
|
||||||
|
g_warning ("Failed to acknowledge VT switch: %s", error->message);
|
||||||
|
g_error_free (error);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_assert (!launcher->vt_switched);
|
||||||
|
launcher->vt_switched = TRUE;
|
||||||
|
|
||||||
|
/* We can't do anything at this point, because we don't
|
||||||
|
have input devices and we don't have the DRM master,
|
||||||
|
so let's run a nested busy loop until the VT is reentered */
|
||||||
|
g_main_loop_run (launcher->nested_loop);
|
||||||
|
|
||||||
|
g_assert (launcher->vt_switched);
|
||||||
|
launcher->vt_switched = FALSE;
|
||||||
|
|
||||||
|
meta_launcher_enter (launcher);
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
on_socket_readable (GSocket *socket,
|
||||||
|
GIOCondition condition,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
MetaLauncher *launcher = user_data;
|
||||||
|
struct weston_launcher_event event;
|
||||||
|
gssize read;
|
||||||
|
GError *error;
|
||||||
|
|
||||||
|
if ((condition & G_IO_IN) == 0)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
error = NULL;
|
||||||
|
read = g_socket_receive (socket, (char*)&event, sizeof(event), NULL, &error);
|
||||||
|
if (read < (gssize)sizeof(event))
|
||||||
|
{
|
||||||
|
g_warning ("Error reading from weston-launcher socket: %s", error->message);
|
||||||
|
g_error_free (error);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (event.header.opcode)
|
||||||
|
{
|
||||||
|
case WESTON_LAUNCHER_SERVER_REQUEST_VT_SWITCH:
|
||||||
|
handle_request_vt_switch (launcher);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case WESTON_LAUNCHER_SERVER_VT_ENTER:
|
||||||
|
handle_vt_enter (launcher);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
env_get_fd (const char *env)
|
||||||
|
{
|
||||||
|
const char *value;
|
||||||
|
|
||||||
|
value = g_getenv (env);
|
||||||
|
|
||||||
|
if (value == NULL)
|
||||||
|
return -1;
|
||||||
|
else
|
||||||
|
return g_ascii_strtoll (value, NULL, 10);
|
||||||
|
}
|
||||||
|
|
||||||
|
MetaLauncher *
|
||||||
|
meta_launcher_new (void)
|
||||||
|
{
|
||||||
|
MetaLauncher *self = g_slice_new0 (MetaLauncher);
|
||||||
|
int launch_fd;
|
||||||
|
|
||||||
|
launch_fd = env_get_fd ("WESTON_LAUNCHER_SOCK");
|
||||||
|
if (launch_fd < 0)
|
||||||
|
g_error ("Invalid mutter-launch socket");
|
||||||
|
|
||||||
|
self->weston_launch = g_socket_new_from_fd (launch_fd, NULL);
|
||||||
|
|
||||||
|
self->nested_context = g_main_context_new ();
|
||||||
|
self->nested_loop = g_main_loop_new (self->nested_context, FALSE);
|
||||||
|
|
||||||
|
self->outer_source = g_socket_create_source (self->weston_launch, G_IO_IN, NULL);
|
||||||
|
g_source_set_callback (self->outer_source, (GSourceFunc)on_socket_readable, self, NULL);
|
||||||
|
g_source_attach (self->outer_source, NULL);
|
||||||
|
g_source_unref (self->outer_source);
|
||||||
|
|
||||||
|
self->inner_source = g_socket_create_source (self->weston_launch, G_IO_IN, NULL);
|
||||||
|
g_source_set_callback (self->inner_source, (GSourceFunc)on_socket_readable, self, NULL);
|
||||||
|
g_source_attach (self->inner_source, self->nested_context);
|
||||||
|
g_source_unref (self->inner_source);
|
||||||
|
|
||||||
|
clutter_evdev_set_device_callbacks (on_evdev_device_open,
|
||||||
|
on_evdev_device_close,
|
||||||
|
self);
|
||||||
|
|
||||||
|
#if defined(CLUTTER_WINDOWING_EGL)
|
||||||
|
if (clutter_check_windowing_backend (CLUTTER_WINDOWING_EGL))
|
||||||
|
{
|
||||||
|
GError *error = NULL;
|
||||||
|
int fd = meta_launcher_open_device (self, "/dev/dri/card0", O_RDWR, &error);
|
||||||
|
if (error)
|
||||||
|
g_error ("Failed to open /dev/dri/card0: %s", error->message);
|
||||||
|
|
||||||
|
clutter_egl_set_kms_fd (fd);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_launcher_free (MetaLauncher *launcher)
|
||||||
|
{
|
||||||
|
g_source_destroy (launcher->outer_source);
|
||||||
|
g_source_destroy (launcher->inner_source);
|
||||||
|
|
||||||
|
g_main_loop_unref (launcher->nested_loop);
|
||||||
|
g_main_context_unref (launcher->nested_context);
|
||||||
|
|
||||||
|
g_object_unref (launcher->weston_launch);
|
||||||
|
|
||||||
|
g_slice_free (MetaLauncher, launcher);
|
||||||
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
meta_launcher_activate_vt (MetaLauncher *launcher,
|
||||||
|
signed char vt,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
struct weston_launcher_activate_vt message;
|
||||||
|
|
||||||
|
message.header.opcode = WESTON_LAUNCHER_ACTIVATE_VT;
|
||||||
|
message.vt = vt;
|
||||||
|
|
||||||
|
return send_message_to_wl (launcher, &message, sizeof (message), NULL, NULL, error);
|
||||||
|
}
|
||||||
|
|
||||||
34
src/backends/native/meta-weston-launch.h
Normal file
34
src/backends/native/meta-weston-launch.h
Normal file
@@ -0,0 +1,34 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation; either version 2 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
||||||
|
* 02111-1307, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef META_WESTON_LAUNCH_H
|
||||||
|
#define META_WESTON_LAUNCH_H
|
||||||
|
|
||||||
|
#include <glib-object.h>
|
||||||
|
#include "weston-launch.h"
|
||||||
|
|
||||||
|
typedef struct _MetaLauncher MetaLauncher;
|
||||||
|
|
||||||
|
MetaLauncher *meta_launcher_new (void);
|
||||||
|
void meta_launcher_free (MetaLauncher *self);
|
||||||
|
|
||||||
|
gboolean meta_launcher_activate_vt (MetaLauncher *self,
|
||||||
|
signed char vt,
|
||||||
|
GError **error);
|
||||||
|
#endif
|
||||||
711
src/backends/native/weston-launch.c
Normal file
711
src/backends/native/weston-launch.c
Normal file
@@ -0,0 +1,711 @@
|
|||||||
|
/*
|
||||||
|
* Copyright © 2012 Benjamin Franzke
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, distribute, and sell this software and
|
||||||
|
* its documentation for any purpose is hereby granted without fee, provided
|
||||||
|
* that the above copyright notice appear in all copies and that both that
|
||||||
|
* copyright notice and this permission notice appear in supporting
|
||||||
|
* documentation, and that the name of the copyright holders not be used in
|
||||||
|
* advertising or publicity pertaining to distribution of the software
|
||||||
|
* without specific, written prior permission. The copyright holders make
|
||||||
|
* no representations about the suitability of this software for any
|
||||||
|
* purpose. It is provided "as is" without express or implied warranty.
|
||||||
|
*
|
||||||
|
* THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
|
||||||
|
* SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||||
|
* FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||||||
|
* SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
|
||||||
|
* RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
|
||||||
|
* CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
||||||
|
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <assert.h>
|
||||||
|
#include <poll.h>
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
|
#include <error.h>
|
||||||
|
#include <getopt.h>
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <sys/ioctl.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <sys/wait.h>
|
||||||
|
#include <sys/socket.h>
|
||||||
|
#include <sys/signalfd.h>
|
||||||
|
#include <signal.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <limits.h>
|
||||||
|
|
||||||
|
#include <termios.h>
|
||||||
|
#include <linux/vt.h>
|
||||||
|
#include <linux/major.h>
|
||||||
|
#include <linux/kd.h>
|
||||||
|
|
||||||
|
#include <pwd.h>
|
||||||
|
#include <grp.h>
|
||||||
|
|
||||||
|
#include <xf86drm.h>
|
||||||
|
|
||||||
|
#include <systemd/sd-login.h>
|
||||||
|
|
||||||
|
#include "weston-launch.h"
|
||||||
|
|
||||||
|
#define MAX_ARGV_SIZE 256
|
||||||
|
#define DRM_MAJOR 226
|
||||||
|
|
||||||
|
enum vt_state {
|
||||||
|
VT_HAS_VT,
|
||||||
|
VT_PENDING_CONFIRM,
|
||||||
|
VT_NOT_HAVE_VT,
|
||||||
|
};
|
||||||
|
|
||||||
|
struct weston_launch {
|
||||||
|
int tty;
|
||||||
|
int ttynr;
|
||||||
|
int sock[2];
|
||||||
|
struct passwd *pw;
|
||||||
|
|
||||||
|
int signalfd;
|
||||||
|
|
||||||
|
pid_t child;
|
||||||
|
int verbose;
|
||||||
|
|
||||||
|
struct termios terminal_attributes;
|
||||||
|
int kb_mode;
|
||||||
|
enum vt_state vt_state;
|
||||||
|
unsigned vt;
|
||||||
|
|
||||||
|
int drm_fd;
|
||||||
|
};
|
||||||
|
|
||||||
|
union cmsg_data { unsigned char b[4]; int fd; };
|
||||||
|
|
||||||
|
static void quit (struct weston_launch *wl, int status);
|
||||||
|
|
||||||
|
static int
|
||||||
|
weston_launch_allowed(struct weston_launch *wl)
|
||||||
|
{
|
||||||
|
char *session, *seat;
|
||||||
|
int err;
|
||||||
|
|
||||||
|
if (getuid() == 0)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
err = sd_pid_get_session(getpid(), &session);
|
||||||
|
if (err == 0 && session) {
|
||||||
|
if (sd_session_is_active(session) &&
|
||||||
|
sd_session_get_seat(session, &seat) == 0) {
|
||||||
|
free(seat);
|
||||||
|
free(session);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
free(session);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
setup_launcher_socket(struct weston_launch *wl)
|
||||||
|
{
|
||||||
|
if (socketpair(AF_LOCAL, SOCK_DGRAM, 0, wl->sock) < 0)
|
||||||
|
error(1, errno, "socketpair failed");
|
||||||
|
|
||||||
|
fcntl(wl->sock[0], F_SETFD, O_CLOEXEC);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
setup_signals(struct weston_launch *wl)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
sigset_t mask;
|
||||||
|
struct sigaction sa;
|
||||||
|
|
||||||
|
memset(&sa, 0, sizeof sa);
|
||||||
|
sa.sa_handler = SIG_DFL;
|
||||||
|
sa.sa_flags = SA_NOCLDSTOP | SA_RESTART;
|
||||||
|
ret = sigaction(SIGCHLD, &sa, NULL);
|
||||||
|
assert(ret == 0);
|
||||||
|
|
||||||
|
sa.sa_handler = SIG_IGN;
|
||||||
|
sa.sa_flags = 0;
|
||||||
|
sigaction(SIGHUP, &sa, NULL);
|
||||||
|
|
||||||
|
ret = sigemptyset(&mask);
|
||||||
|
assert(ret == 0);
|
||||||
|
sigaddset(&mask, SIGCHLD);
|
||||||
|
sigaddset(&mask, SIGINT);
|
||||||
|
sigaddset(&mask, SIGTERM);
|
||||||
|
sigaddset(&mask, SIGUSR1);
|
||||||
|
ret = sigprocmask(SIG_BLOCK, &mask, NULL);
|
||||||
|
assert(ret == 0);
|
||||||
|
|
||||||
|
wl->signalfd = signalfd(-1, &mask, SFD_NONBLOCK | SFD_CLOEXEC);
|
||||||
|
if (wl->signalfd < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
setenv_fd(const char *env, int fd)
|
||||||
|
{
|
||||||
|
char buf[32];
|
||||||
|
|
||||||
|
snprintf(buf, sizeof buf, "%d", fd);
|
||||||
|
setenv(env, buf, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
handle_confirm_vt_switch(struct weston_launch *wl, struct msghdr *msg, ssize_t len)
|
||||||
|
{
|
||||||
|
struct weston_launcher_reply reply;
|
||||||
|
|
||||||
|
reply.header.opcode = WESTON_LAUNCHER_CONFIRM_VT_SWITCH;
|
||||||
|
reply.ret = -1;
|
||||||
|
|
||||||
|
if (wl->vt_state != VT_PENDING_CONFIRM) {
|
||||||
|
error(0, 0, "unexpected CONFIRM_VT_SWITCH");
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (wl->drm_fd != -1) {
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = drmDropMaster(wl->drm_fd);
|
||||||
|
if (ret < 0) {
|
||||||
|
fprintf(stderr, "failed to drop DRM master: %m\n");
|
||||||
|
} else if (wl->verbose) {
|
||||||
|
fprintf(stderr, "dropped DRM master for VT switch\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
wl->vt_state = VT_NOT_HAVE_VT;
|
||||||
|
ioctl(wl->tty, VT_RELDISP, 1);
|
||||||
|
|
||||||
|
if (wl->verbose)
|
||||||
|
fprintf(stderr, "mutter-launcher: confirmed VT switch\n");
|
||||||
|
|
||||||
|
reply.ret = 0;
|
||||||
|
|
||||||
|
out:
|
||||||
|
do {
|
||||||
|
len = send(wl->sock[0], &reply, sizeof reply, 0);
|
||||||
|
} while (len < 0 && errno == EINTR);
|
||||||
|
if (len < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
handle_activate_vt(struct weston_launch *wl, struct msghdr *msg, ssize_t len)
|
||||||
|
{
|
||||||
|
struct weston_launcher_reply reply;
|
||||||
|
struct weston_launcher_activate_vt *message;
|
||||||
|
unsigned vt;
|
||||||
|
|
||||||
|
reply.header.opcode = WESTON_LAUNCHER_ACTIVATE_VT;
|
||||||
|
reply.ret = -1;
|
||||||
|
|
||||||
|
if (len != sizeof(*message)) {
|
||||||
|
error(0, 0, "missing value in activate_vt request");
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
|
message = msg->msg_iov->iov_base;
|
||||||
|
|
||||||
|
/* Negative values mean that we're activating our own VT */
|
||||||
|
if (message->vt > 0)
|
||||||
|
vt = message->vt;
|
||||||
|
else
|
||||||
|
vt = wl->vt;
|
||||||
|
|
||||||
|
reply.ret = ioctl(wl->tty, VT_ACTIVATE, vt);
|
||||||
|
if (reply.ret < 0)
|
||||||
|
reply.ret = -errno;
|
||||||
|
|
||||||
|
if (wl->verbose)
|
||||||
|
fprintf(stderr, "mutter-launch: activate VT, ret: %d\n", reply.ret);
|
||||||
|
|
||||||
|
out:
|
||||||
|
do {
|
||||||
|
len = send(wl->sock[0], &reply, sizeof reply, 0);
|
||||||
|
} while (len < 0 && errno == EINTR);
|
||||||
|
if (len < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int
|
||||||
|
handle_open(struct weston_launch *wl, struct msghdr *msg, ssize_t len)
|
||||||
|
{
|
||||||
|
struct weston_launcher_reply reply;
|
||||||
|
int fd = -1;
|
||||||
|
char control[CMSG_SPACE(sizeof(fd))];
|
||||||
|
struct cmsghdr *cmsg;
|
||||||
|
struct stat s;
|
||||||
|
struct msghdr nmsg;
|
||||||
|
struct iovec iov;
|
||||||
|
struct weston_launcher_open *message;
|
||||||
|
union cmsg_data *data;
|
||||||
|
int dev_major;
|
||||||
|
|
||||||
|
reply.header.opcode = WESTON_LAUNCHER_OPEN;
|
||||||
|
reply.ret = -1;
|
||||||
|
|
||||||
|
message = msg->msg_iov->iov_base;
|
||||||
|
if ((size_t)len < sizeof(*message))
|
||||||
|
goto err0;
|
||||||
|
|
||||||
|
/* Ensure path is null-terminated */
|
||||||
|
((char *) message)[len-1] = '\0';
|
||||||
|
|
||||||
|
if (stat(message->path, &s) < 0) {
|
||||||
|
reply.ret = -errno;
|
||||||
|
goto err0;
|
||||||
|
}
|
||||||
|
|
||||||
|
dev_major = major(s.st_rdev);
|
||||||
|
|
||||||
|
if (dev_major != INPUT_MAJOR &&
|
||||||
|
dev_major != DRM_MAJOR) {
|
||||||
|
fprintf(stderr, "Device %s is not an input or DRM device\n",
|
||||||
|
message->path);
|
||||||
|
reply.ret = -EPERM;
|
||||||
|
goto err0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dev_major == DRM_MAJOR && wl->drm_fd != -1) {
|
||||||
|
fprintf(stderr, "Already have a DRM device open\n");
|
||||||
|
reply.ret = -EPERM;
|
||||||
|
goto err0;
|
||||||
|
}
|
||||||
|
|
||||||
|
fd = open(message->path, message->flags);
|
||||||
|
if (fd < 0) {
|
||||||
|
fprintf(stderr, "Error opening device %s: %m\n",
|
||||||
|
message->path);
|
||||||
|
reply.ret = -errno;
|
||||||
|
goto err0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dev_major == DRM_MAJOR) {
|
||||||
|
wl->drm_fd = fd;
|
||||||
|
}
|
||||||
|
|
||||||
|
err0:
|
||||||
|
memset(&nmsg, 0, sizeof nmsg);
|
||||||
|
nmsg.msg_iov = &iov;
|
||||||
|
nmsg.msg_iovlen = 1;
|
||||||
|
if (fd != -1) {
|
||||||
|
nmsg.msg_control = control;
|
||||||
|
nmsg.msg_controllen = sizeof control;
|
||||||
|
cmsg = CMSG_FIRSTHDR(&nmsg);
|
||||||
|
cmsg->cmsg_level = SOL_SOCKET;
|
||||||
|
cmsg->cmsg_type = SCM_RIGHTS;
|
||||||
|
cmsg->cmsg_len = CMSG_LEN(sizeof(fd));
|
||||||
|
data = (union cmsg_data *) CMSG_DATA(cmsg);
|
||||||
|
data->fd = fd;
|
||||||
|
nmsg.msg_controllen = cmsg->cmsg_len;
|
||||||
|
reply.ret = 0;
|
||||||
|
}
|
||||||
|
iov.iov_base = &reply;
|
||||||
|
iov.iov_len = sizeof reply;
|
||||||
|
|
||||||
|
if (wl->verbose)
|
||||||
|
fprintf(stderr, "mutter-launch: opened %s: ret: %d, fd: %d\n",
|
||||||
|
message->path, reply.ret, fd);
|
||||||
|
do {
|
||||||
|
len = sendmsg(wl->sock[0], &nmsg, 0);
|
||||||
|
} while (len < 0 && errno == EINTR);
|
||||||
|
|
||||||
|
close(fd);
|
||||||
|
|
||||||
|
if (len < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
handle_socket_msg(struct weston_launch *wl)
|
||||||
|
{
|
||||||
|
char control[CMSG_SPACE(sizeof(int))];
|
||||||
|
char buf[BUFSIZ];
|
||||||
|
struct msghdr msg;
|
||||||
|
struct iovec iov;
|
||||||
|
int ret = -1;
|
||||||
|
ssize_t len;
|
||||||
|
struct weston_launcher_message *message;
|
||||||
|
|
||||||
|
memset(&msg, 0, sizeof(msg));
|
||||||
|
iov.iov_base = buf;
|
||||||
|
iov.iov_len = sizeof buf;
|
||||||
|
msg.msg_iov = &iov;
|
||||||
|
msg.msg_iovlen = 1;
|
||||||
|
msg.msg_control = control;
|
||||||
|
msg.msg_controllen = sizeof control;
|
||||||
|
|
||||||
|
do {
|
||||||
|
len = recvmsg(wl->sock[0], &msg, 0);
|
||||||
|
} while (len < 0 && errno == EINTR);
|
||||||
|
|
||||||
|
if (len < 1)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
message = (void *) buf;
|
||||||
|
switch (message->opcode) {
|
||||||
|
case WESTON_LAUNCHER_OPEN:
|
||||||
|
ret = handle_open(wl, &msg, len);
|
||||||
|
break;
|
||||||
|
case WESTON_LAUNCHER_CONFIRM_VT_SWITCH:
|
||||||
|
ret = handle_confirm_vt_switch(wl, &msg, len);
|
||||||
|
break;
|
||||||
|
case WESTON_LAUNCHER_ACTIVATE_VT:
|
||||||
|
ret = handle_activate_vt(wl, &msg, len);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
tty_reset(struct weston_launch *wl)
|
||||||
|
{
|
||||||
|
struct vt_mode mode = { 0 };
|
||||||
|
|
||||||
|
if (ioctl(wl->tty, KDSKBMODE, wl->kb_mode))
|
||||||
|
fprintf(stderr, "failed to restore keyboard mode: %m\n");
|
||||||
|
|
||||||
|
if (ioctl(wl->tty, KDSETMODE, KD_TEXT))
|
||||||
|
fprintf(stderr, "failed to set KD_TEXT mode on tty: %m\n");
|
||||||
|
|
||||||
|
if (tcsetattr(wl->tty, TCSANOW, &wl->terminal_attributes) < 0)
|
||||||
|
fprintf(stderr, "could not restore terminal to canonical mode\n");
|
||||||
|
|
||||||
|
mode.mode = VT_AUTO;
|
||||||
|
if (ioctl(wl->tty, VT_SETMODE, &mode) < 0)
|
||||||
|
fprintf(stderr, "could not reset vt handling\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
quit(struct weston_launch *wl, int status)
|
||||||
|
{
|
||||||
|
if (wl->child > 0)
|
||||||
|
kill(wl->child, SIGKILL);
|
||||||
|
|
||||||
|
close(wl->signalfd);
|
||||||
|
close(wl->sock[0]);
|
||||||
|
|
||||||
|
if (wl->drm_fd > 0)
|
||||||
|
close(wl->drm_fd);
|
||||||
|
|
||||||
|
tty_reset(wl);
|
||||||
|
|
||||||
|
exit(status);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
handle_vt_switch(struct weston_launch *wl)
|
||||||
|
{
|
||||||
|
struct weston_launcher_event message;
|
||||||
|
ssize_t len;
|
||||||
|
|
||||||
|
if (wl->vt_state == VT_HAS_VT) {
|
||||||
|
wl->vt_state = VT_PENDING_CONFIRM;
|
||||||
|
message.header.opcode = WESTON_LAUNCHER_SERVER_REQUEST_VT_SWITCH;
|
||||||
|
} else if (wl->vt_state == VT_NOT_HAVE_VT) {
|
||||||
|
wl->vt_state = VT_HAS_VT;
|
||||||
|
ioctl(wl->tty, VT_RELDISP, VT_ACKACQ);
|
||||||
|
|
||||||
|
if (wl->drm_fd != -1) {
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = drmSetMaster(wl->drm_fd);
|
||||||
|
if (ret < 0) {
|
||||||
|
fprintf(stderr, "failed to become DRM master: %m\n");
|
||||||
|
/* This is very, very bad, and the compositor will crash soon,
|
||||||
|
but oh well... */
|
||||||
|
} else if (wl->verbose) {
|
||||||
|
fprintf(stderr, "became DRM master after VT switch\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
message.header.opcode = WESTON_LAUNCHER_SERVER_VT_ENTER;
|
||||||
|
} else
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
message.detail = 0;
|
||||||
|
|
||||||
|
do {
|
||||||
|
len = send(wl->sock[0], &message, sizeof(message), 0);
|
||||||
|
} while (len < 0 && errno == EINTR);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int
|
||||||
|
handle_signal(struct weston_launch *wl)
|
||||||
|
{
|
||||||
|
struct signalfd_siginfo sig;
|
||||||
|
int pid, status, ret;
|
||||||
|
|
||||||
|
if (read(wl->signalfd, &sig, sizeof sig) != sizeof sig) {
|
||||||
|
error(0, errno, "reading signalfd failed");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (sig.ssi_signo) {
|
||||||
|
case SIGCHLD:
|
||||||
|
pid = waitpid(-1, &status, 0);
|
||||||
|
if (pid == wl->child) {
|
||||||
|
wl->child = 0;
|
||||||
|
if (WIFEXITED(status))
|
||||||
|
ret = WEXITSTATUS(status);
|
||||||
|
else if (WIFSIGNALED(status))
|
||||||
|
/*
|
||||||
|
* If weston dies because of signal N, we
|
||||||
|
* return 10+N. This is distinct from
|
||||||
|
* weston-launch dying because of a signal
|
||||||
|
* (128+N).
|
||||||
|
*/
|
||||||
|
ret = 10 + WTERMSIG(status);
|
||||||
|
else
|
||||||
|
ret = 0;
|
||||||
|
quit(wl, ret);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case SIGTERM:
|
||||||
|
case SIGINT:
|
||||||
|
if (wl->child)
|
||||||
|
kill(wl->child, sig.ssi_signo);
|
||||||
|
break;
|
||||||
|
case SIGUSR1:
|
||||||
|
return handle_vt_switch(wl);
|
||||||
|
default:
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
setup_tty(struct weston_launch *wl)
|
||||||
|
{
|
||||||
|
struct stat buf;
|
||||||
|
struct termios raw_attributes;
|
||||||
|
struct vt_mode mode = { 0 };
|
||||||
|
char *session;
|
||||||
|
char path[PATH_MAX];
|
||||||
|
int ok;
|
||||||
|
|
||||||
|
ok = sd_pid_get_session(getpid(), &session);
|
||||||
|
if (ok < 0)
|
||||||
|
error(1, -ok, "could not determine current session");
|
||||||
|
|
||||||
|
ok = sd_session_get_vt(session, &wl->vt);
|
||||||
|
if (ok < 0)
|
||||||
|
error(1, -ok, "could not determine current TTY");
|
||||||
|
|
||||||
|
snprintf(path, PATH_MAX, "/dev/tty%u", wl->vt);
|
||||||
|
wl->tty = open(path, O_RDWR | O_NOCTTY | O_CLOEXEC);
|
||||||
|
|
||||||
|
if (wl->tty < 0)
|
||||||
|
error(1, errno, "failed to open tty");
|
||||||
|
|
||||||
|
if (fstat(wl->tty, &buf) < 0)
|
||||||
|
error(1, errno, "stat %s failed", path);
|
||||||
|
|
||||||
|
if (major(buf.st_rdev) != TTY_MAJOR)
|
||||||
|
error(1, 0, "invalid tty device: %s", path);
|
||||||
|
|
||||||
|
wl->ttynr = minor(buf.st_rdev);
|
||||||
|
|
||||||
|
if (tcgetattr(wl->tty, &wl->terminal_attributes) < 0)
|
||||||
|
error(1, errno, "could not get terminal attributes");
|
||||||
|
|
||||||
|
/* Ignore control characters and disable echo */
|
||||||
|
raw_attributes = wl->terminal_attributes;
|
||||||
|
cfmakeraw(&raw_attributes);
|
||||||
|
|
||||||
|
/* Fix up line endings to be normal (cfmakeraw hoses them) */
|
||||||
|
raw_attributes.c_oflag |= OPOST | OCRNL;
|
||||||
|
/* Don't generate ttou signals */
|
||||||
|
raw_attributes.c_oflag &= ~TOSTOP;
|
||||||
|
|
||||||
|
if (tcsetattr(wl->tty, TCSANOW, &raw_attributes) < 0)
|
||||||
|
error(1, errno, "could not put terminal into raw mode");
|
||||||
|
|
||||||
|
ioctl(wl->tty, KDGKBMODE, &wl->kb_mode);
|
||||||
|
ok = ioctl(wl->tty, KDSKBMODE, K_OFF);
|
||||||
|
if (ok < 0) {
|
||||||
|
ok = ioctl(wl->tty, KDSKBMODE, K_RAW);
|
||||||
|
if (ok < 0)
|
||||||
|
error(1, errno, "failed to set keyboard mode on tty");
|
||||||
|
}
|
||||||
|
|
||||||
|
ok = ioctl(wl->tty, KDSETMODE, KD_GRAPHICS);
|
||||||
|
if (ok < 0)
|
||||||
|
error(1, errno, "failed to set KD_GRAPHICS mode on tty");
|
||||||
|
|
||||||
|
wl->vt_state = VT_HAS_VT;
|
||||||
|
mode.mode = VT_PROCESS;
|
||||||
|
mode.relsig = SIGUSR1;
|
||||||
|
mode.acqsig = SIGUSR1;
|
||||||
|
ok = ioctl(wl->tty, VT_SETMODE, &mode);
|
||||||
|
if (ok < 0)
|
||||||
|
error(1, errno, "failed to take control of vt handling");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
drop_privileges(struct weston_launch *wl)
|
||||||
|
{
|
||||||
|
if (setgid(wl->pw->pw_gid) < 0 ||
|
||||||
|
#ifdef HAVE_INITGROUPS
|
||||||
|
initgroups(wl->pw->pw_name, wl->pw->pw_gid) < 0 ||
|
||||||
|
#endif
|
||||||
|
setuid(wl->pw->pw_uid) < 0)
|
||||||
|
error(1, errno, "dropping privileges failed");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
launch_compositor(struct weston_launch *wl, int argc, char *argv[])
|
||||||
|
{
|
||||||
|
char command[PATH_MAX];
|
||||||
|
char *child_argv[MAX_ARGV_SIZE];
|
||||||
|
sigset_t mask;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (wl->verbose)
|
||||||
|
printf("weston-launch: spawned weston with pid: %d\n", getpid());
|
||||||
|
|
||||||
|
drop_privileges(wl);
|
||||||
|
|
||||||
|
setenv_fd("WESTON_LAUNCHER_SOCK", wl->sock[1]);
|
||||||
|
setenv("LD_LIBRARY_PATH", LIBDIR, 1);
|
||||||
|
unsetenv("DISPLAY");
|
||||||
|
|
||||||
|
/* Do not give our signal mask to the new process. */
|
||||||
|
sigemptyset(&mask);
|
||||||
|
sigaddset(&mask, SIGTERM);
|
||||||
|
sigaddset(&mask, SIGCHLD);
|
||||||
|
sigaddset(&mask, SIGINT);
|
||||||
|
sigaddset(&mask, SIGUSR1);
|
||||||
|
sigprocmask(SIG_UNBLOCK, &mask, NULL);
|
||||||
|
|
||||||
|
snprintf (command, PATH_MAX, "%s \"$@\"", argv[0]);
|
||||||
|
|
||||||
|
child_argv[0] = wl->pw->pw_shell;
|
||||||
|
child_argv[1] = "-l";
|
||||||
|
child_argv[2] = "-c";
|
||||||
|
child_argv[3] = command;
|
||||||
|
for (i = 0; i < argc; ++i)
|
||||||
|
child_argv[4 + i] = argv[i];
|
||||||
|
child_argv[4 + i] = NULL;
|
||||||
|
|
||||||
|
execv(child_argv[0], child_argv);
|
||||||
|
error(1, errno, "exec failed");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
help(const char *name)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "Usage: %s [args...] [-- [weston args..]]\n", name);
|
||||||
|
fprintf(stderr, " -u, --user Start session as specified username\n");
|
||||||
|
fprintf(stderr, " -v, --verbose Be verbose\n");
|
||||||
|
fprintf(stderr, " -h, --help Display this help message\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
struct weston_launch wl;
|
||||||
|
int i, c;
|
||||||
|
struct option opts[] = {
|
||||||
|
{ "verbose", no_argument, NULL, 'v' },
|
||||||
|
{ "help", no_argument, NULL, 'h' },
|
||||||
|
{ 0, 0, NULL, 0 }
|
||||||
|
};
|
||||||
|
|
||||||
|
memset(&wl, 0, sizeof wl);
|
||||||
|
wl.drm_fd = -1;
|
||||||
|
|
||||||
|
while ((c = getopt_long(argc, argv, "u:t::vh", opts, &i)) != -1) {
|
||||||
|
switch (c) {
|
||||||
|
case 'v':
|
||||||
|
wl.verbose = 1;
|
||||||
|
break;
|
||||||
|
case 'h':
|
||||||
|
help("mutter-launch");
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((argc - optind) > (MAX_ARGV_SIZE - 6))
|
||||||
|
error(1, E2BIG, "Too many arguments to pass to weston");
|
||||||
|
|
||||||
|
if (optind >= argc)
|
||||||
|
error(1, 0, "Expected program argument");
|
||||||
|
|
||||||
|
wl.pw = getpwuid(getuid());
|
||||||
|
if (wl.pw == NULL)
|
||||||
|
error(1, errno, "failed to get username");
|
||||||
|
|
||||||
|
if (!weston_launch_allowed(&wl))
|
||||||
|
error(1, 0, "Permission denied. You must run from an active and local (systemd) session.");
|
||||||
|
|
||||||
|
if (setup_tty(&wl) < 0)
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
|
||||||
|
if (setup_launcher_socket(&wl) < 0)
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
|
||||||
|
if (setup_signals(&wl) < 0)
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
|
||||||
|
wl.child = fork();
|
||||||
|
if (wl.child == -1) {
|
||||||
|
error(1, errno, "fork failed");
|
||||||
|
exit(EXIT_FAILURE);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (wl.child == 0)
|
||||||
|
launch_compositor(&wl, argc - optind, argv + optind);
|
||||||
|
|
||||||
|
close(wl.sock[1]);
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
struct pollfd fds[2];
|
||||||
|
int n;
|
||||||
|
|
||||||
|
fds[0].fd = wl.sock[0];
|
||||||
|
fds[0].events = POLLIN;
|
||||||
|
fds[1].fd = wl.signalfd;
|
||||||
|
fds[1].events = POLLIN;
|
||||||
|
|
||||||
|
n = poll(fds, 2, -1);
|
||||||
|
if (n < 0)
|
||||||
|
error(0, errno, "poll failed");
|
||||||
|
if (fds[0].revents & POLLIN)
|
||||||
|
handle_socket_msg(&wl);
|
||||||
|
if (fds[1].revents)
|
||||||
|
handle_signal(&wl);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
68
src/backends/native/weston-launch.h
Normal file
68
src/backends/native/weston-launch.h
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
/*
|
||||||
|
* Copyright © 2012 Benjamin Franzke
|
||||||
|
* 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, distribute, and sell this software and
|
||||||
|
* its documentation for any purpose is hereby granted without fee, provided
|
||||||
|
* that the above copyright notice appear in all copies and that both that
|
||||||
|
* copyright notice and this permission notice appear in supporting
|
||||||
|
* documentation, and that the name of the copyright holders not be used in
|
||||||
|
* advertising or publicity pertaining to distribution of the software
|
||||||
|
* without specific, written prior permission. The copyright holders make
|
||||||
|
* no representations about the suitability of this software for any
|
||||||
|
* purpose. It is provided "as is" without express or implied warranty.
|
||||||
|
*
|
||||||
|
* THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
|
||||||
|
* SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||||
|
* FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
||||||
|
* SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
|
||||||
|
* RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF
|
||||||
|
* CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
|
||||||
|
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _WESTON_LAUNCH_H_
|
||||||
|
#define _WESTON_LAUNCH_H_
|
||||||
|
|
||||||
|
enum weston_launcher_message_type {
|
||||||
|
WESTON_LAUNCHER_REQUEST,
|
||||||
|
WESTON_LAUNCHER_EVENT,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum weston_launcher_opcode {
|
||||||
|
WESTON_LAUNCHER_OPEN = (1 << 1 | WESTON_LAUNCHER_REQUEST),
|
||||||
|
WESTON_LAUNCHER_ACTIVATE_VT = (2 << 1 | WESTON_LAUNCHER_REQUEST),
|
||||||
|
WESTON_LAUNCHER_CONFIRM_VT_SWITCH = (3 << 1 | WESTON_LAUNCHER_REQUEST),
|
||||||
|
};
|
||||||
|
|
||||||
|
enum weston_launcher_server_opcode {
|
||||||
|
WESTON_LAUNCHER_SERVER_REQUEST_VT_SWITCH = (1 << 1 | WESTON_LAUNCHER_EVENT),
|
||||||
|
WESTON_LAUNCHER_SERVER_VT_ENTER = (2 << 1 | WESTON_LAUNCHER_EVENT),
|
||||||
|
};
|
||||||
|
|
||||||
|
struct weston_launcher_message {
|
||||||
|
int opcode;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct weston_launcher_open {
|
||||||
|
struct weston_launcher_message header;
|
||||||
|
int flags;
|
||||||
|
char path[0];
|
||||||
|
};
|
||||||
|
|
||||||
|
struct weston_launcher_activate_vt {
|
||||||
|
struct weston_launcher_message header;
|
||||||
|
signed char vt;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct weston_launcher_reply {
|
||||||
|
struct weston_launcher_message header;
|
||||||
|
int ret;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct weston_launcher_event {
|
||||||
|
struct weston_launcher_message header;
|
||||||
|
int detail; /* unused, but makes sure replies and events are serialized the same */
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
366
src/backends/x11/meta-idle-monitor-xsync.c
Normal file
366
src/backends/x11/meta-idle-monitor-xsync.c
Normal file
@@ -0,0 +1,366 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* 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/>.
|
||||||
|
*
|
||||||
|
* Adapted from gnome-session/gnome-session/gs-idle-monitor.c and
|
||||||
|
* from gnome-desktop/libgnome-desktop/gnome-idle-monitor.c
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
|
||||||
|
#include "meta-idle-monitor-xsync.h"
|
||||||
|
#include "meta-idle-monitor-private.h"
|
||||||
|
|
||||||
|
#include <meta/util.h>
|
||||||
|
#include "display-private.h"
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
struct _MetaIdleMonitorXSync
|
||||||
|
{
|
||||||
|
MetaIdleMonitor parent;
|
||||||
|
|
||||||
|
GHashTable *alarms;
|
||||||
|
Display *display;
|
||||||
|
XSyncCounter counter;
|
||||||
|
XSyncAlarm user_active_alarm;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct _MetaIdleMonitorXSyncClass
|
||||||
|
{
|
||||||
|
MetaIdleMonitorClass parent_class;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
MetaIdleMonitorWatch base;
|
||||||
|
|
||||||
|
XSyncAlarm xalarm;
|
||||||
|
} MetaIdleMonitorWatchXSync;
|
||||||
|
|
||||||
|
G_DEFINE_TYPE (MetaIdleMonitorXSync, meta_idle_monitor_xsync, META_TYPE_IDLE_MONITOR)
|
||||||
|
|
||||||
|
static gint64
|
||||||
|
_xsyncvalue_to_int64 (XSyncValue value)
|
||||||
|
{
|
||||||
|
return ((guint64) XSyncValueHigh32 (value)) << 32
|
||||||
|
| (guint64) XSyncValueLow32 (value);
|
||||||
|
}
|
||||||
|
|
||||||
|
#define GUINT64_TO_XSYNCVALUE(value, ret) XSyncIntsToValue (ret, (value) & 0xFFFFFFFF, ((guint64)(value)) >> 32)
|
||||||
|
|
||||||
|
static XSyncAlarm
|
||||||
|
_xsync_alarm_set (MetaIdleMonitorXSync *monitor_xsync,
|
||||||
|
XSyncTestType test_type,
|
||||||
|
guint64 interval,
|
||||||
|
gboolean want_events)
|
||||||
|
{
|
||||||
|
XSyncAlarmAttributes attr;
|
||||||
|
XSyncValue delta;
|
||||||
|
guint flags;
|
||||||
|
|
||||||
|
flags = XSyncCACounter | XSyncCAValueType | XSyncCATestType |
|
||||||
|
XSyncCAValue | XSyncCADelta | XSyncCAEvents;
|
||||||
|
|
||||||
|
XSyncIntToValue (&delta, 0);
|
||||||
|
attr.trigger.counter = monitor_xsync->counter;
|
||||||
|
attr.trigger.value_type = XSyncAbsolute;
|
||||||
|
attr.delta = delta;
|
||||||
|
attr.events = want_events;
|
||||||
|
|
||||||
|
GUINT64_TO_XSYNCVALUE (interval, &attr.trigger.wait_value);
|
||||||
|
attr.trigger.test_type = test_type;
|
||||||
|
return XSyncCreateAlarm (monitor_xsync->display, flags, &attr);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
ensure_alarm_rescheduled (Display *dpy,
|
||||||
|
XSyncAlarm alarm)
|
||||||
|
{
|
||||||
|
XSyncAlarmAttributes attr;
|
||||||
|
|
||||||
|
/* Some versions of Xorg have an issue where alarms aren't
|
||||||
|
* always rescheduled. Calling XSyncChangeAlarm, even
|
||||||
|
* without any attributes, will reschedule the alarm. */
|
||||||
|
XSyncChangeAlarm (dpy, alarm, 0, &attr);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
set_alarm_enabled (Display *dpy,
|
||||||
|
XSyncAlarm alarm,
|
||||||
|
gboolean enabled)
|
||||||
|
{
|
||||||
|
XSyncAlarmAttributes attr;
|
||||||
|
attr.events = enabled;
|
||||||
|
XSyncChangeAlarm (dpy, alarm, XSyncCAEvents, &attr);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
check_x11_watch (gpointer data,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorWatchXSync *watch_xsync = data;
|
||||||
|
MetaIdleMonitorWatch *watch = (MetaIdleMonitorWatch *) watch_xsync;
|
||||||
|
XSyncAlarm alarm = (XSyncAlarm) user_data;
|
||||||
|
|
||||||
|
if (watch_xsync->xalarm != alarm)
|
||||||
|
return;
|
||||||
|
|
||||||
|
_meta_idle_monitor_watch_fire (watch);
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *
|
||||||
|
counter_name_for_device (int device_id)
|
||||||
|
{
|
||||||
|
if (device_id > 0)
|
||||||
|
return g_strdup_printf ("DEVICEIDLETIME %d", device_id);
|
||||||
|
|
||||||
|
return g_strdup ("IDLETIME");
|
||||||
|
}
|
||||||
|
|
||||||
|
static XSyncCounter
|
||||||
|
find_idletime_counter (MetaIdleMonitorXSync *monitor_xsync)
|
||||||
|
{
|
||||||
|
MetaIdleMonitor *monitor = META_IDLE_MONITOR (monitor_xsync);
|
||||||
|
int i;
|
||||||
|
int ncounters;
|
||||||
|
XSyncSystemCounter *counters;
|
||||||
|
XSyncCounter counter = None;
|
||||||
|
char *counter_name;
|
||||||
|
|
||||||
|
counter_name = counter_name_for_device (monitor->device_id);
|
||||||
|
counters = XSyncListSystemCounters (monitor_xsync->display, &ncounters);
|
||||||
|
for (i = 0; i < ncounters; i++)
|
||||||
|
{
|
||||||
|
if (counters[i].name != NULL && strcmp (counters[i].name, counter_name) == 0)
|
||||||
|
{
|
||||||
|
counter = counters[i].counter;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
XSyncFreeSystemCounterList (counters);
|
||||||
|
g_free (counter_name);
|
||||||
|
|
||||||
|
return counter;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
init_xsync (MetaIdleMonitorXSync *monitor_xsync)
|
||||||
|
{
|
||||||
|
monitor_xsync->counter = find_idletime_counter (monitor_xsync);
|
||||||
|
/* IDLETIME counter not found? */
|
||||||
|
if (monitor_xsync->counter == None)
|
||||||
|
{
|
||||||
|
g_warning ("IDLETIME counter not found\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
monitor_xsync->user_active_alarm = _xsync_alarm_set (monitor_xsync, XSyncNegativeTransition, 1, FALSE);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_idle_monitor_xsync_dispose (GObject *object)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorXSync *monitor_xsync = META_IDLE_MONITOR_XSYNC (object);
|
||||||
|
|
||||||
|
if (monitor_xsync->user_active_alarm != None)
|
||||||
|
{
|
||||||
|
XSyncDestroyAlarm (monitor_xsync->display, monitor_xsync->user_active_alarm);
|
||||||
|
monitor_xsync->user_active_alarm = None;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_clear_pointer (&monitor_xsync->alarms, g_hash_table_destroy);
|
||||||
|
|
||||||
|
G_OBJECT_CLASS (meta_idle_monitor_xsync_parent_class)->dispose (object);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_idle_monitor_xsync_constructed (GObject *object)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorXSync *monitor_xsync = META_IDLE_MONITOR_XSYNC (object);
|
||||||
|
|
||||||
|
g_assert (!meta_is_wayland_compositor ());
|
||||||
|
|
||||||
|
monitor_xsync->display = meta_get_display ()->xdisplay;
|
||||||
|
init_xsync (monitor_xsync);
|
||||||
|
|
||||||
|
G_OBJECT_CLASS (meta_idle_monitor_xsync_parent_class)->constructed (object);
|
||||||
|
}
|
||||||
|
|
||||||
|
static gint64
|
||||||
|
meta_idle_monitor_xsync_get_idletime (MetaIdleMonitor *monitor)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorXSync *monitor_xsync = META_IDLE_MONITOR_XSYNC (monitor);
|
||||||
|
XSyncValue value;
|
||||||
|
|
||||||
|
if (!XSyncQueryCounter (monitor_xsync->display, monitor_xsync->counter, &value))
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
return _xsyncvalue_to_int64 (value);
|
||||||
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
fire_watch_idle (gpointer data)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorWatch *watch = data;
|
||||||
|
|
||||||
|
watch->idle_source_id = 0;
|
||||||
|
_meta_idle_monitor_watch_fire (watch);
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static guint32
|
||||||
|
get_next_watch_serial (void)
|
||||||
|
{
|
||||||
|
static guint32 serial = 0;
|
||||||
|
g_atomic_int_inc (&serial);
|
||||||
|
return serial;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
free_watch (gpointer data)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorWatchXSync *watch_xsync = data;
|
||||||
|
MetaIdleMonitorWatch *watch = (MetaIdleMonitorWatch *) watch_xsync;
|
||||||
|
MetaIdleMonitor *monitor = watch->monitor;
|
||||||
|
MetaIdleMonitorXSync *monitor_xsync = META_IDLE_MONITOR_XSYNC (monitor);
|
||||||
|
|
||||||
|
g_object_ref (monitor);
|
||||||
|
|
||||||
|
if (watch->idle_source_id)
|
||||||
|
{
|
||||||
|
g_source_remove (watch->idle_source_id);
|
||||||
|
watch->idle_source_id = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (watch->notify != NULL)
|
||||||
|
watch->notify (watch->user_data);
|
||||||
|
|
||||||
|
if (watch_xsync->xalarm != monitor_xsync->user_active_alarm &&
|
||||||
|
watch_xsync->xalarm != None)
|
||||||
|
{
|
||||||
|
XSyncDestroyAlarm (monitor_xsync->display, watch_xsync->xalarm);
|
||||||
|
g_hash_table_remove (monitor_xsync->alarms, (gpointer) watch_xsync->xalarm);
|
||||||
|
}
|
||||||
|
|
||||||
|
g_object_unref (monitor);
|
||||||
|
g_slice_free (MetaIdleMonitorWatchXSync, watch_xsync);
|
||||||
|
}
|
||||||
|
|
||||||
|
static MetaIdleMonitorWatch *
|
||||||
|
meta_idle_monitor_xsync_make_watch (MetaIdleMonitor *monitor,
|
||||||
|
guint64 timeout_msec,
|
||||||
|
MetaIdleMonitorWatchFunc callback,
|
||||||
|
gpointer user_data,
|
||||||
|
GDestroyNotify notify)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorXSync *monitor_xsync = META_IDLE_MONITOR_XSYNC (monitor);
|
||||||
|
MetaIdleMonitorWatchXSync *watch_xsync;
|
||||||
|
MetaIdleMonitorWatch *watch;
|
||||||
|
|
||||||
|
watch_xsync = g_slice_new0 (MetaIdleMonitorWatchXSync);
|
||||||
|
watch = (MetaIdleMonitorWatch *) watch_xsync;
|
||||||
|
|
||||||
|
watch->monitor = monitor;
|
||||||
|
watch->id = get_next_watch_serial ();
|
||||||
|
watch->callback = callback;
|
||||||
|
watch->user_data = user_data;
|
||||||
|
watch->notify = notify;
|
||||||
|
watch->timeout_msec = timeout_msec;
|
||||||
|
|
||||||
|
if (monitor_xsync->user_active_alarm != None)
|
||||||
|
{
|
||||||
|
if (timeout_msec != 0)
|
||||||
|
{
|
||||||
|
watch_xsync->xalarm = _xsync_alarm_set (monitor_xsync, XSyncPositiveTransition, timeout_msec, TRUE);
|
||||||
|
|
||||||
|
g_hash_table_add (monitor_xsync->alarms, (gpointer) watch_xsync->xalarm);
|
||||||
|
|
||||||
|
if (meta_idle_monitor_get_idletime (monitor) > (gint64)timeout_msec)
|
||||||
|
watch->idle_source_id = g_idle_add (fire_watch_idle, watch);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
watch_xsync->xalarm = monitor_xsync->user_active_alarm;
|
||||||
|
|
||||||
|
set_alarm_enabled (monitor_xsync->display, monitor_xsync->user_active_alarm, TRUE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return watch;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_idle_monitor_xsync_class_init (MetaIdleMonitorXSyncClass *klass)
|
||||||
|
{
|
||||||
|
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
||||||
|
MetaIdleMonitorClass *idle_monitor_class = META_IDLE_MONITOR_CLASS (klass);
|
||||||
|
|
||||||
|
object_class->dispose = meta_idle_monitor_xsync_dispose;
|
||||||
|
object_class->constructed = meta_idle_monitor_xsync_constructed;
|
||||||
|
|
||||||
|
idle_monitor_class->get_idletime = meta_idle_monitor_xsync_get_idletime;
|
||||||
|
idle_monitor_class->make_watch = meta_idle_monitor_xsync_make_watch;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
meta_idle_monitor_xsync_init (MetaIdleMonitorXSync *monitor_xsync)
|
||||||
|
{
|
||||||
|
MetaIdleMonitor *monitor = META_IDLE_MONITOR (monitor_xsync);
|
||||||
|
|
||||||
|
monitor->watches = g_hash_table_new_full (NULL, NULL, NULL, free_watch);
|
||||||
|
monitor_xsync->alarms = g_hash_table_new (NULL, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
meta_idle_monitor_xsync_handle_xevent (MetaIdleMonitor *monitor,
|
||||||
|
XSyncAlarmNotifyEvent *alarm_event)
|
||||||
|
{
|
||||||
|
MetaIdleMonitorXSync *monitor_xsync = META_IDLE_MONITOR_XSYNC (monitor);
|
||||||
|
XSyncAlarm alarm;
|
||||||
|
GList *watches;
|
||||||
|
gboolean has_alarm;
|
||||||
|
|
||||||
|
if (alarm_event->state != XSyncAlarmActive)
|
||||||
|
return;
|
||||||
|
|
||||||
|
alarm = alarm_event->alarm;
|
||||||
|
|
||||||
|
has_alarm = FALSE;
|
||||||
|
|
||||||
|
if (alarm == monitor_xsync->user_active_alarm)
|
||||||
|
{
|
||||||
|
set_alarm_enabled (monitor_xsync->display,
|
||||||
|
alarm,
|
||||||
|
FALSE);
|
||||||
|
has_alarm = TRUE;
|
||||||
|
}
|
||||||
|
else if (g_hash_table_contains (monitor_xsync->alarms, (gpointer) alarm))
|
||||||
|
{
|
||||||
|
ensure_alarm_rescheduled (monitor_xsync->display,
|
||||||
|
alarm);
|
||||||
|
has_alarm = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (has_alarm)
|
||||||
|
{
|
||||||
|
watches = g_hash_table_get_values (monitor->watches);
|
||||||
|
|
||||||
|
g_list_foreach (watches, check_x11_watch, (gpointer) alarm);
|
||||||
|
g_list_free (watches);
|
||||||
|
}
|
||||||
|
}
|
||||||
49
src/backends/x11/meta-idle-monitor-xsync.h
Normal file
49
src/backends/x11/meta-idle-monitor-xsync.h
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2013 Red Hat, Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* 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/>.
|
||||||
|
*
|
||||||
|
* Adapted from gnome-session/gnome-session/gs-idle-monitor.c and
|
||||||
|
* from gnome-desktop/libgnome-desktop/gnome-idle-monitor.c
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef META_IDLE_MONITOR_XSYNC_H
|
||||||
|
#define META_IDLE_MONITOR_XSYNC_H
|
||||||
|
|
||||||
|
#include <glib-object.h>
|
||||||
|
#include <meta/meta-idle-monitor.h>
|
||||||
|
|
||||||
|
#include <X11/Xlib.h>
|
||||||
|
#include <X11/extensions/sync.h>
|
||||||
|
|
||||||
|
#define META_TYPE_IDLE_MONITOR_XSYNC (meta_idle_monitor_xsync_get_type ())
|
||||||
|
#define META_IDLE_MONITOR_XSYNC(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_IDLE_MONITOR_XSYNC, MetaIdleMonitorXSync))
|
||||||
|
#define META_IDLE_MONITOR_XSYNC_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), META_TYPE_IDLE_MONITOR_XSYNC, MetaIdleMonitorXSyncClass))
|
||||||
|
#define META_IS_IDLE_MONITOR_XSYNC(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_IDLE_MONITOR_XSYNC))
|
||||||
|
#define META_IS_IDLE_MONITOR_XSYNC_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), META_TYPE_IDLE_MONITOR_XSYNC))
|
||||||
|
#define META_IDLE_MONITOR_XSYNC_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), META_TYPE_IDLE_MONITOR_XSYNC, MetaIdleMonitorXSyncClass))
|
||||||
|
|
||||||
|
typedef struct _MetaIdleMonitorXSync MetaIdleMonitorXSync;
|
||||||
|
typedef struct _MetaIdleMonitorXSyncClass MetaIdleMonitorXSyncClass;
|
||||||
|
|
||||||
|
GType meta_idle_monitor_xsync_get_type (void);
|
||||||
|
|
||||||
|
void meta_idle_monitor_xsync_handle_xevent (MetaIdleMonitor *monitor,
|
||||||
|
XSyncAlarmNotifyEvent *xevent);
|
||||||
|
|
||||||
|
void meta_idle_monitor_xsync_handle_xevent_all (XEvent *xevent);
|
||||||
|
|
||||||
|
#endif /* META_IDLE_MONITOR_XSYNC_H */
|
||||||
@@ -20,13 +20,13 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
|
#include "meta-monitor-manager-xrandr.h"
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
@@ -38,9 +38,8 @@
|
|||||||
|
|
||||||
#include <meta/main.h>
|
#include <meta/main.h>
|
||||||
#include <meta/errors.h>
|
#include <meta/errors.h>
|
||||||
#include "monitor-private.h"
|
|
||||||
|
|
||||||
#include "edid.h"
|
#include "edid.h"
|
||||||
|
#include "meta-monitor-config.h"
|
||||||
|
|
||||||
#define ALL_WL_TRANSFORMS ((1 << (WL_OUTPUT_TRANSFORM_FLIPPED_270 + 1)) - 1)
|
#define ALL_WL_TRANSFORMS ((1 << (WL_OUTPUT_TRANSFORM_FLIPPED_270 + 1)) - 1)
|
||||||
|
|
||||||
@@ -187,7 +186,7 @@ output_get_backlight_xrandr (MetaMonitorManagerXrandr *manager_xrandr,
|
|||||||
|
|
||||||
XRRGetOutputProperty (manager_xrandr->xdisplay,
|
XRRGetOutputProperty (manager_xrandr->xdisplay,
|
||||||
(XID)output->output_id,
|
(XID)output->output_id,
|
||||||
display->atom_Backlight,
|
display->atom_BACKLIGHT,
|
||||||
0, G_MAXLONG, False, False, XA_INTEGER,
|
0, G_MAXLONG, False, False, XA_INTEGER,
|
||||||
&actual_type, &actual_format,
|
&actual_type, &actual_format,
|
||||||
&nitems, &bytes_after, &buffer);
|
&nitems, &bytes_after, &buffer);
|
||||||
@@ -212,7 +211,7 @@ output_get_backlight_limits_xrandr (MetaMonitorManagerXrandr *manager_xrandr,
|
|||||||
meta_error_trap_push (display);
|
meta_error_trap_push (display);
|
||||||
info = XRRQueryOutputProperty (manager_xrandr->xdisplay,
|
info = XRRQueryOutputProperty (manager_xrandr->xdisplay,
|
||||||
(XID)output->output_id,
|
(XID)output->output_id,
|
||||||
display->atom_Backlight);
|
display->atom_BACKLIGHT);
|
||||||
meta_error_trap_pop (display);
|
meta_error_trap_pop (display);
|
||||||
|
|
||||||
if (info == NULL)
|
if (info == NULL)
|
||||||
@@ -678,13 +677,11 @@ output_set_presentation_xrandr (MetaMonitorManagerXrandr *manager_xrandr,
|
|||||||
MetaDisplay *display = meta_get_display ();
|
MetaDisplay *display = meta_get_display ();
|
||||||
int value = presentation;
|
int value = presentation;
|
||||||
|
|
||||||
meta_error_trap_push (display);
|
|
||||||
XRRChangeOutputProperty (manager_xrandr->xdisplay,
|
XRRChangeOutputProperty (manager_xrandr->xdisplay,
|
||||||
(XID)output->output_id,
|
(XID)output->output_id,
|
||||||
display->atom__MUTTER_PRESENTATION_OUTPUT,
|
display->atom__MUTTER_PRESENTATION_OUTPUT,
|
||||||
XA_CARDINAL, 32, PropModeReplace,
|
XA_CARDINAL, 32, PropModeReplace,
|
||||||
(unsigned char*) &value, 1);
|
(unsigned char*) &value, 1);
|
||||||
meta_error_trap_pop (display);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@@ -950,7 +947,7 @@ meta_monitor_manager_xrandr_change_backlight (MetaMonitorManager *manager,
|
|||||||
meta_error_trap_push (display);
|
meta_error_trap_push (display);
|
||||||
XRRChangeOutputProperty (manager_xrandr->xdisplay,
|
XRRChangeOutputProperty (manager_xrandr->xdisplay,
|
||||||
(XID)output->output_id,
|
(XID)output->output_id,
|
||||||
display->atom_Backlight,
|
display->atom_BACKLIGHT,
|
||||||
XA_INTEGER, 32, PropModeReplace,
|
XA_INTEGER, 32, PropModeReplace,
|
||||||
(unsigned char *) &hw_value, 1);
|
(unsigned char *) &hw_value, 1);
|
||||||
meta_error_trap_pop (display);
|
meta_error_trap_pop (display);
|
||||||
@@ -1019,7 +1016,7 @@ meta_monitor_manager_xrandr_handle_xevent (MetaMonitorManager *manager,
|
|||||||
MetaOutput *old_outputs;
|
MetaOutput *old_outputs;
|
||||||
MetaCRTC *old_crtcs;
|
MetaCRTC *old_crtcs;
|
||||||
MetaMonitorMode *old_modes;
|
MetaMonitorMode *old_modes;
|
||||||
int n_old_outputs;
|
unsigned int n_old_outputs, n_old_modes;
|
||||||
gboolean new_config;
|
gboolean new_config;
|
||||||
|
|
||||||
if ((event->type - manager_xrandr->rr_event_base) != RRScreenChangeNotify)
|
if ((event->type - manager_xrandr->rr_event_base) != RRScreenChangeNotify)
|
||||||
@@ -1031,6 +1028,7 @@ meta_monitor_manager_xrandr_handle_xevent (MetaMonitorManager *manager,
|
|||||||
old_outputs = manager->outputs;
|
old_outputs = manager->outputs;
|
||||||
n_old_outputs = manager->n_outputs;
|
n_old_outputs = manager->n_outputs;
|
||||||
old_modes = manager->modes;
|
old_modes = manager->modes;
|
||||||
|
n_old_modes = manager->n_modes;
|
||||||
old_crtcs = manager->crtcs;
|
old_crtcs = manager->crtcs;
|
||||||
|
|
||||||
manager->serial++;
|
manager->serial++;
|
||||||
@@ -1070,7 +1068,7 @@ meta_monitor_manager_xrandr_handle_xevent (MetaMonitorManager *manager,
|
|||||||
}
|
}
|
||||||
|
|
||||||
meta_monitor_manager_free_output_array (old_outputs, n_old_outputs);
|
meta_monitor_manager_free_output_array (old_outputs, n_old_outputs);
|
||||||
g_free (old_modes);
|
meta_monitor_manager_free_mode_array (old_modes, n_old_modes);
|
||||||
g_free (old_crtcs);
|
g_free (old_crtcs);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
40
src/backends/x11/meta-monitor-manager-xrandr.h
Normal file
40
src/backends/x11/meta-monitor-manager-xrandr.h
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2001 Havoc Pennington
|
||||||
|
* Copyright (C) 2003 Rob Adams
|
||||||
|
* Copyright (C) 2004-2006 Elijah Newren
|
||||||
|
* Copyright (C) 2013 Red Hat Inc.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation; either version 2 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
* General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef META_MONITOR_MANAGER_XRANDR_H
|
||||||
|
#define META_MONITOR_MANAGER_XRANDR_H
|
||||||
|
|
||||||
|
#include "meta-monitor-manager.h"
|
||||||
|
|
||||||
|
#define META_TYPE_MONITOR_MANAGER_XRANDR (meta_monitor_manager_xrandr_get_type ())
|
||||||
|
#define META_MONITOR_MANAGER_XRANDR(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), META_TYPE_MONITOR_MANAGER_XRANDR, MetaMonitorManagerXrandr))
|
||||||
|
#define META_MONITOR_MANAGER_XRANDR_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), META_TYPE_MONITOR_MANAGER_XRANDR, MetaMonitorManagerXrandrClass))
|
||||||
|
#define META_IS_MONITOR_MANAGER_XRANDR(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), META_TYPE_MONITOR_MANAGER_XRANDR))
|
||||||
|
#define META_IS_MONITOR_MANAGER_XRANDR_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), META_TYPE_MONITOR_MANAGER_XRANDR))
|
||||||
|
#define META_MONITOR_MANAGER_XRANDR_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), META_TYPE_MONITOR_MANAGER_XRANDR, MetaMonitorManagerXrandrClass))
|
||||||
|
|
||||||
|
typedef struct _MetaMonitorManagerXrandrClass MetaMonitorManagerXrandrClass;
|
||||||
|
typedef struct _MetaMonitorManagerXrandr MetaMonitorManagerXrandr;
|
||||||
|
|
||||||
|
GType meta_monitor_manager_xrandr_get_type (void);
|
||||||
|
|
||||||
|
#endif /* META_MONITOR_MANAGER_XRANDR_H */
|
||||||
@@ -16,9 +16,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "clutter-utils.h"
|
#include "clutter-utils.h"
|
||||||
@@ -95,8 +93,10 @@ meta_actor_vertices_are_untransformed (ClutterVertex *verts,
|
|||||||
v3x != v1x || v3y != v2y)
|
v3x != v1x || v3y != v2y)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
*x_origin = x;
|
if (x_origin)
|
||||||
*y_origin = y;
|
*x_origin = x;
|
||||||
|
if (y_origin)
|
||||||
|
*y_origin = y;
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,9 +15,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __META_CLUTTER_UTILS_H__
|
#ifndef __META_CLUTTER_UTILS_H__
|
||||||
|
|||||||
@@ -16,9 +16,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <clutter/clutter.h>
|
#include <clutter/clutter.h>
|
||||||
|
|||||||
@@ -15,9 +15,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __META_COGL_UTILS_H__
|
#ifndef __META_COGL_UTILS_H__
|
||||||
|
|||||||
@@ -11,48 +11,29 @@
|
|||||||
#include "meta-window-actor-private.h"
|
#include "meta-window-actor-private.h"
|
||||||
#include <clutter/clutter.h>
|
#include <clutter/clutter.h>
|
||||||
|
|
||||||
typedef struct _MetaCompScreen MetaCompScreen;
|
|
||||||
|
|
||||||
struct _MetaCompositor
|
struct _MetaCompositor
|
||||||
{
|
{
|
||||||
MetaDisplay *display;
|
MetaDisplay *display;
|
||||||
|
|
||||||
Atom atom_x_root_pixmap;
|
|
||||||
Atom atom_net_wm_window_opacity;
|
|
||||||
guint repaint_func_id;
|
guint repaint_func_id;
|
||||||
|
|
||||||
ClutterActor *shadow_src;
|
|
||||||
|
|
||||||
MetaPlugin *modal_plugin;
|
|
||||||
|
|
||||||
gint64 server_time_query_time;
|
gint64 server_time_query_time;
|
||||||
gint64 server_time_offset;
|
gint64 server_time_offset;
|
||||||
|
|
||||||
guint server_time_is_monotonic_time : 1;
|
guint server_time_is_monotonic_time : 1;
|
||||||
guint show_redraw : 1;
|
|
||||||
guint debug : 1;
|
|
||||||
guint no_mipmaps : 1;
|
guint no_mipmaps : 1;
|
||||||
};
|
|
||||||
|
|
||||||
struct _MetaCompScreen
|
ClutterActor *stage, *window_group, *top_window_group;
|
||||||
{
|
|
||||||
MetaScreen *screen;
|
|
||||||
|
|
||||||
ClutterActor *stage, *window_group, *top_window_group, *overlay_group;
|
|
||||||
ClutterActor *background_actor;
|
ClutterActor *background_actor;
|
||||||
GList *windows;
|
GList *windows;
|
||||||
GHashTable *windows_by_xid;
|
|
||||||
Window output;
|
Window output;
|
||||||
|
|
||||||
CoglOnscreen *onscreen;
|
CoglOnscreen *onscreen;
|
||||||
CoglFrameClosure *frame_closure;
|
CoglFrameClosure *frame_closure;
|
||||||
|
|
||||||
/* Used for unredirecting fullscreen windows */
|
/* Used for unredirecting fullscreen windows */
|
||||||
guint disable_unredirect_count;
|
guint disable_unredirect_count;
|
||||||
MetaWindowActor *unredirected_window;
|
MetaWindow *unredirected_window;
|
||||||
|
|
||||||
/* Before we create the output window */
|
|
||||||
XserverRegion pending_input_region;
|
|
||||||
|
|
||||||
gint switch_workspace_in_progress;
|
gint switch_workspace_in_progress;
|
||||||
|
|
||||||
@@ -62,19 +43,17 @@ struct _MetaCompScreen
|
|||||||
/* Wait 2ms after vblank before starting to draw next frame */
|
/* Wait 2ms after vblank before starting to draw next frame */
|
||||||
#define META_SYNC_DELAY 2
|
#define META_SYNC_DELAY 2
|
||||||
|
|
||||||
void meta_switch_workspace_completed (MetaScreen *screen);
|
void meta_switch_workspace_completed (MetaCompositor *compositor);
|
||||||
|
|
||||||
gboolean meta_begin_modal_for_plugin (MetaScreen *screen,
|
gboolean meta_begin_modal_for_plugin (MetaCompositor *compositor,
|
||||||
MetaPlugin *plugin,
|
MetaPlugin *plugin,
|
||||||
MetaModalOptions options,
|
MetaModalOptions options,
|
||||||
guint32 timestamp);
|
guint32 timestamp);
|
||||||
void meta_end_modal_for_plugin (MetaScreen *screen,
|
void meta_end_modal_for_plugin (MetaCompositor *compositor,
|
||||||
MetaPlugin *plugin,
|
MetaPlugin *plugin,
|
||||||
guint32 timestamp);
|
guint32 timestamp);
|
||||||
|
|
||||||
gint64 meta_compositor_monotonic_time_to_server_time (MetaDisplay *display,
|
gint64 meta_compositor_monotonic_time_to_server_time (MetaDisplay *display,
|
||||||
gint64 monotonic_time);
|
gint64 monotonic_time);
|
||||||
|
|
||||||
void meta_check_end_modal (MetaScreen *screen);
|
|
||||||
|
|
||||||
#endif /* META_COMPOSITOR_PRIVATE_H */
|
#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/screen.h>
|
||||||
#include <meta/meta-background-actor.h>
|
#include <meta/meta-background-actor.h>
|
||||||
|
|
||||||
void meta_background_actor_set_clip_region (MetaBackgroundActor *self,
|
|
||||||
cairo_region_t *clip_region);
|
|
||||||
|
|
||||||
cairo_region_t *meta_background_actor_get_clip_region (MetaBackgroundActor *self);
|
cairo_region_t *meta_background_actor_get_clip_region (MetaBackgroundActor *self);
|
||||||
|
|
||||||
#endif /* META_BACKGROUND_ACTOR_PRIVATE_H */
|
#endif /* META_BACKGROUND_ACTOR_PRIVATE_H */
|
||||||
|
|||||||
@@ -14,9 +14,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*
|
*
|
||||||
* Portions adapted from gnome-shell/src/shell-global.c
|
* Portions adapted from gnome-shell/src/shell-global.c
|
||||||
*/
|
*/
|
||||||
@@ -41,20 +39,35 @@
|
|||||||
#include <meta/errors.h>
|
#include <meta/errors.h>
|
||||||
#include <meta/meta-background.h>
|
#include <meta/meta-background.h>
|
||||||
#include "meta-background-actor-private.h"
|
#include "meta-background-actor-private.h"
|
||||||
|
#include "meta-cullable.h"
|
||||||
|
|
||||||
struct _MetaBackgroundActorPrivate
|
struct _MetaBackgroundActorPrivate
|
||||||
{
|
{
|
||||||
cairo_region_t *clip_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
|
static void
|
||||||
meta_background_actor_dispose (GObject *object)
|
meta_background_actor_dispose (GObject *object)
|
||||||
{
|
{
|
||||||
MetaBackgroundActor *self = META_BACKGROUND_ACTOR (object);
|
MetaBackgroundActor *self = META_BACKGROUND_ACTOR (object);
|
||||||
|
|
||||||
meta_background_actor_set_clip_region (self, NULL);
|
set_clip_region (self, NULL);
|
||||||
|
|
||||||
G_OBJECT_CLASS (meta_background_actor_parent_class)->dispose (object);
|
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;
|
*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
|
static void
|
||||||
meta_background_actor_class_init (MetaBackgroundActorClass *klass)
|
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_width = meta_background_actor_get_preferred_width;
|
||||||
actor_class->get_preferred_height = meta_background_actor_get_preferred_height;
|
actor_class->get_preferred_height = meta_background_actor_get_preferred_height;
|
||||||
actor_class->get_paint_volume = meta_background_actor_get_paint_volume;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@@ -166,31 +158,27 @@ meta_background_actor_new (void)
|
|||||||
return CLUTTER_ACTOR (self);
|
return CLUTTER_ACTOR (self);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
static void
|
||||||
* meta_background_actor_set_clip_region:
|
meta_background_actor_cull_out (MetaCullable *cullable,
|
||||||
* @self: a #MetaBackgroundActor
|
cairo_region_t *unobscured_region,
|
||||||
* @clip_region: (allow-none): the area of the actor (in allocate-relative
|
cairo_region_t *clip_region)
|
||||||
* 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_clip_region (MetaBackgroundActor *self,
|
|
||||||
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;
|
static void
|
||||||
|
cullable_iface_init (MetaCullableInterface *iface)
|
||||||
g_clear_pointer (&priv->clip_region,
|
{
|
||||||
(GDestroyNotify)
|
iface->cull_out = meta_background_actor_cull_out;
|
||||||
cairo_region_destroy);
|
iface->reset_culling = meta_background_actor_reset_culling;
|
||||||
|
|
||||||
if (clip_region)
|
|
||||||
priv->clip_region = cairo_region_copy (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_clip_region (MetaBackgroundGroup *self,
|
|
||||||
cairo_region_t *visible_region);
|
|
||||||
#endif /* META_BACKGROUND_GROUP_PRIVATE_H */
|
|
||||||
@@ -16,87 +16,43 @@
|
|||||||
|
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
#include "compositor-private.h"
|
#include <meta/meta-background-group.h>
|
||||||
#include "clutter-utils.h"
|
#include "meta-cullable.h"
|
||||||
#include "meta-background-actor-private.h"
|
|
||||||
#include "meta-background-group-private.h"
|
|
||||||
|
|
||||||
G_DEFINE_TYPE (MetaBackgroundGroup, meta_background_group, CLUTTER_TYPE_ACTOR);
|
static void cullable_iface_init (MetaCullableInterface *iface);
|
||||||
|
|
||||||
struct _MetaBackgroundGroupPrivate
|
G_DEFINE_TYPE_WITH_CODE (MetaBackgroundGroup, meta_background_group, CLUTTER_TYPE_ACTOR,
|
||||||
{
|
G_IMPLEMENT_INTERFACE (META_TYPE_CULLABLE, cullable_iface_init));
|
||||||
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);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
meta_background_group_class_init (MetaBackgroundGroupClass *klass)
|
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;
|
static void
|
||||||
object_class->dispose = meta_background_group_dispose;
|
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
|
static void
|
||||||
meta_background_group_init (MetaBackgroundGroup *self)
|
meta_background_group_init (MetaBackgroundGroup *self)
|
||||||
{
|
{
|
||||||
self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self,
|
|
||||||
META_TYPE_BACKGROUND_GROUP,
|
|
||||||
MetaBackgroundGroupPrivate);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* meta_background_group_set_clip_region:
|
|
||||||
* @self: a #MetaBackgroundGroup
|
|
||||||
* @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_clip_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_clip_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_clip_region (META_BACKGROUND_GROUP (actor), region);
|
|
||||||
cairo_region_translate (region, x, y);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
g_list_free (children);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ClutterActor *
|
ClutterActor *
|
||||||
|
|||||||
@@ -14,9 +14,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -28,8 +26,6 @@
|
|||||||
|
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
#include <cogl/cogl-texture-pixmap-x11.h>
|
|
||||||
|
|
||||||
#include <clutter/clutter.h>
|
#include <clutter/clutter.h>
|
||||||
|
|
||||||
#include "cogl-utils.h"
|
#include "cogl-utils.h"
|
||||||
@@ -37,6 +33,7 @@
|
|||||||
#include "mutter-enum-types.h"
|
#include "mutter-enum-types.h"
|
||||||
#include <meta/errors.h>
|
#include <meta/errors.h>
|
||||||
#include <meta/meta-background.h>
|
#include <meta/meta-background.h>
|
||||||
|
#include "util-private.h"
|
||||||
#include "meta-background-actor-private.h"
|
#include "meta-background-actor-private.h"
|
||||||
|
|
||||||
#define FRAGMENT_SHADER_DECLARATIONS \
|
#define FRAGMENT_SHADER_DECLARATIONS \
|
||||||
@@ -501,8 +498,7 @@ set_brightness (MetaBackground *self,
|
|||||||
|
|
||||||
priv->brightness = brightness;
|
priv->brightness = brightness;
|
||||||
|
|
||||||
if (clutter_feature_available (CLUTTER_FEATURE_SHADERS_GLSL) &&
|
if (priv->effects & META_BACKGROUND_EFFECTS_VIGNETTE)
|
||||||
priv->effects & META_BACKGROUND_EFFECTS_VIGNETTE)
|
|
||||||
{
|
{
|
||||||
ensure_pipeline (self);
|
ensure_pipeline (self);
|
||||||
cogl_pipeline_set_uniform_1f (priv->pipeline,
|
cogl_pipeline_set_uniform_1f (priv->pipeline,
|
||||||
@@ -510,14 +506,6 @@ set_brightness (MetaBackground *self,
|
|||||||
"brightness"),
|
"brightness"),
|
||||||
priv->brightness);
|
priv->brightness);
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
ensure_pipeline (self);
|
|
||||||
CoglColor blend_color;
|
|
||||||
cogl_color_init_from_4f (&blend_color, brightness, brightness, brightness, 1.0);
|
|
||||||
cogl_pipeline_set_layer_combine (priv->pipeline, 1, "RGB=MODULATE(PREVIOUS, CONSTANT) A=REPLACE(PREVIOUS)", NULL);
|
|
||||||
cogl_pipeline_set_layer_combine_constant (priv->pipeline, 1, &blend_color);
|
|
||||||
}
|
|
||||||
|
|
||||||
clutter_content_invalidate (CLUTTER_CONTENT (self));
|
clutter_content_invalidate (CLUTTER_CONTENT (self));
|
||||||
|
|
||||||
@@ -535,9 +523,6 @@ set_vignette_sharpness (MetaBackground *self,
|
|||||||
|
|
||||||
priv->vignette_sharpness = sharpness;
|
priv->vignette_sharpness = sharpness;
|
||||||
|
|
||||||
if (!clutter_feature_available (CLUTTER_FEATURE_SHADERS_GLSL))
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (priv->effects & META_BACKGROUND_EFFECTS_VIGNETTE)
|
if (priv->effects & META_BACKGROUND_EFFECTS_VIGNETTE)
|
||||||
{
|
{
|
||||||
ensure_pipeline (self);
|
ensure_pipeline (self);
|
||||||
@@ -558,9 +543,6 @@ add_vignette (MetaBackground *self)
|
|||||||
MetaBackgroundPrivate *priv = self->priv;
|
MetaBackgroundPrivate *priv = self->priv;
|
||||||
static CoglSnippet *snippet = NULL;
|
static CoglSnippet *snippet = NULL;
|
||||||
|
|
||||||
if (!clutter_feature_available (CLUTTER_FEATURE_SHADERS_GLSL))
|
|
||||||
return;
|
|
||||||
|
|
||||||
ensure_pipeline (self);
|
ensure_pipeline (self);
|
||||||
|
|
||||||
/* Cogl automatically caches pipelines with no eviction policy,
|
/* Cogl automatically caches pipelines with no eviction policy,
|
||||||
@@ -771,88 +753,6 @@ set_filename (MetaBackground *self,
|
|||||||
priv->filename = g_strdup (filename);
|
priv->filename = g_strdup (filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
static Pixmap
|
|
||||||
get_still_frame_for_monitor (MetaScreen *screen,
|
|
||||||
int monitor)
|
|
||||||
{
|
|
||||||
MetaDisplay *display = meta_screen_get_display (screen);
|
|
||||||
Display *xdisplay = meta_display_get_xdisplay (display);
|
|
||||||
Window xroot = meta_screen_get_xroot (screen);
|
|
||||||
Pixmap pixmap;
|
|
||||||
GC gc;
|
|
||||||
XGCValues values;
|
|
||||||
MetaRectangle geometry;
|
|
||||||
int depth;
|
|
||||||
|
|
||||||
meta_screen_get_monitor_geometry (screen, monitor, &geometry);
|
|
||||||
|
|
||||||
depth = DefaultDepth (xdisplay, meta_screen_get_screen_number (screen));
|
|
||||||
|
|
||||||
pixmap = XCreatePixmap (xdisplay,
|
|
||||||
xroot,
|
|
||||||
geometry.width, geometry.height, depth);
|
|
||||||
|
|
||||||
values.function = GXcopy;
|
|
||||||
values.plane_mask = AllPlanes;
|
|
||||||
values.fill_style = FillSolid;
|
|
||||||
values.subwindow_mode = IncludeInferiors;
|
|
||||||
|
|
||||||
gc = XCreateGC (xdisplay,
|
|
||||||
xroot,
|
|
||||||
GCFunction | GCPlaneMask | GCFillStyle | GCSubwindowMode,
|
|
||||||
&values);
|
|
||||||
|
|
||||||
XCopyArea (xdisplay,
|
|
||||||
xroot, pixmap, gc,
|
|
||||||
geometry.x, geometry.y,
|
|
||||||
geometry.width, geometry.height,
|
|
||||||
0, 0);
|
|
||||||
|
|
||||||
XFreeGC (xdisplay, gc);
|
|
||||||
|
|
||||||
return pixmap;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* meta_background_load_still_frame:
|
|
||||||
* @self: the #MetaBackground
|
|
||||||
*
|
|
||||||
* Takes a screenshot of the desktop and uses it as the background
|
|
||||||
* source.
|
|
||||||
*/
|
|
||||||
void
|
|
||||||
meta_background_load_still_frame (MetaBackground *self)
|
|
||||||
{
|
|
||||||
MetaBackgroundPrivate *priv = self->priv;
|
|
||||||
MetaDisplay *display = meta_screen_get_display (priv->screen);
|
|
||||||
Pixmap still_frame;
|
|
||||||
CoglTexture *texture;
|
|
||||||
CoglContext *context = clutter_backend_get_cogl_context (clutter_get_default_backend ());
|
|
||||||
GError *error = NULL;
|
|
||||||
|
|
||||||
ensure_pipeline (self);
|
|
||||||
|
|
||||||
unset_texture (self);
|
|
||||||
set_style (self, G_DESKTOP_BACKGROUND_STYLE_STRETCHED);
|
|
||||||
|
|
||||||
still_frame = get_still_frame_for_monitor (priv->screen, priv->monitor);
|
|
||||||
XSync (meta_display_get_xdisplay (display), False);
|
|
||||||
|
|
||||||
meta_error_trap_push (display);
|
|
||||||
texture = COGL_TEXTURE (cogl_texture_pixmap_x11_new (context, still_frame, FALSE, &error));
|
|
||||||
meta_error_trap_pop (display);
|
|
||||||
|
|
||||||
if (error != NULL)
|
|
||||||
{
|
|
||||||
g_warning ("Failed to create background texture from pixmap: %s",
|
|
||||||
error->message);
|
|
||||||
g_error_free (error);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
set_texture (self, texture);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* meta_background_load_gradient:
|
* meta_background_load_gradient:
|
||||||
* @self: the #MetaBackground
|
* @self: the #MetaBackground
|
||||||
|
|||||||
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.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <meta/meta-plugin.h>
|
#include <meta/meta-plugin.h>
|
||||||
|
|||||||
@@ -16,9 +16,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef META_MODULE_H_
|
#ifndef META_MODULE_H_
|
||||||
|
|||||||
@@ -16,9 +16,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
@@ -39,7 +37,7 @@ static GType plugin_type = G_TYPE_NONE;
|
|||||||
|
|
||||||
struct MetaPluginManager
|
struct MetaPluginManager
|
||||||
{
|
{
|
||||||
MetaScreen *screen;
|
MetaCompositor *compositor;
|
||||||
MetaPlugin *plugin;
|
MetaPlugin *plugin;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -93,7 +91,7 @@ on_confirm_display_change (MetaMonitorManager *monitors,
|
|||||||
}
|
}
|
||||||
|
|
||||||
MetaPluginManager *
|
MetaPluginManager *
|
||||||
meta_plugin_manager_new (MetaScreen *screen)
|
meta_plugin_manager_new (MetaCompositor *compositor)
|
||||||
{
|
{
|
||||||
MetaPluginManager *plugin_mgr;
|
MetaPluginManager *plugin_mgr;
|
||||||
MetaPluginClass *klass;
|
MetaPluginClass *klass;
|
||||||
@@ -101,8 +99,10 @@ meta_plugin_manager_new (MetaScreen *screen)
|
|||||||
MetaMonitorManager *monitors;
|
MetaMonitorManager *monitors;
|
||||||
|
|
||||||
plugin_mgr = g_new0 (MetaPluginManager, 1);
|
plugin_mgr = g_new0 (MetaPluginManager, 1);
|
||||||
plugin_mgr->screen = screen;
|
plugin_mgr->compositor = compositor;
|
||||||
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_compositor (plugin, compositor);
|
||||||
|
|
||||||
klass = META_PLUGIN_GET_CLASS (plugin);
|
klass = META_PLUGIN_GET_CLASS (plugin);
|
||||||
|
|
||||||
@@ -153,7 +153,7 @@ meta_plugin_manager_event_simple (MetaPluginManager *plugin_mgr,
|
|||||||
{
|
{
|
||||||
MetaPlugin *plugin = plugin_mgr->plugin;
|
MetaPlugin *plugin = plugin_mgr->plugin;
|
||||||
MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
|
MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
|
||||||
MetaDisplay *display = meta_screen_get_display (plugin_mgr->screen);
|
MetaDisplay *display = plugin_mgr->compositor->display;
|
||||||
gboolean retval = FALSE;
|
gboolean retval = FALSE;
|
||||||
|
|
||||||
if (display->display_opening)
|
if (display->display_opening)
|
||||||
@@ -167,8 +167,6 @@ meta_plugin_manager_event_simple (MetaPluginManager *plugin_mgr,
|
|||||||
retval = TRUE;
|
retval = TRUE;
|
||||||
meta_plugin_manager_kill_window_effects (plugin_mgr,
|
meta_plugin_manager_kill_window_effects (plugin_mgr,
|
||||||
actor);
|
actor);
|
||||||
|
|
||||||
_meta_plugin_effect_started (plugin);
|
|
||||||
klass->minimize (plugin, actor);
|
klass->minimize (plugin, actor);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -178,8 +176,6 @@ meta_plugin_manager_event_simple (MetaPluginManager *plugin_mgr,
|
|||||||
retval = TRUE;
|
retval = TRUE;
|
||||||
meta_plugin_manager_kill_window_effects (plugin_mgr,
|
meta_plugin_manager_kill_window_effects (plugin_mgr,
|
||||||
actor);
|
actor);
|
||||||
|
|
||||||
_meta_plugin_effect_started (plugin);
|
|
||||||
klass->map (plugin, actor);
|
klass->map (plugin, actor);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -187,7 +183,6 @@ meta_plugin_manager_event_simple (MetaPluginManager *plugin_mgr,
|
|||||||
if (klass->destroy)
|
if (klass->destroy)
|
||||||
{
|
{
|
||||||
retval = TRUE;
|
retval = TRUE;
|
||||||
_meta_plugin_effect_started (plugin);
|
|
||||||
klass->destroy (plugin, actor);
|
klass->destroy (plugin, actor);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@@ -218,7 +213,7 @@ meta_plugin_manager_event_maximize (MetaPluginManager *plugin_mgr,
|
|||||||
{
|
{
|
||||||
MetaPlugin *plugin = plugin_mgr->plugin;
|
MetaPlugin *plugin = plugin_mgr->plugin;
|
||||||
MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
|
MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
|
||||||
MetaDisplay *display = meta_screen_get_display (plugin_mgr->screen);
|
MetaDisplay *display = plugin_mgr->compositor->display;
|
||||||
gboolean retval = FALSE;
|
gboolean retval = FALSE;
|
||||||
|
|
||||||
if (display->display_opening)
|
if (display->display_opening)
|
||||||
@@ -232,8 +227,6 @@ meta_plugin_manager_event_maximize (MetaPluginManager *plugin_mgr,
|
|||||||
retval = TRUE;
|
retval = TRUE;
|
||||||
meta_plugin_manager_kill_window_effects (plugin_mgr,
|
meta_plugin_manager_kill_window_effects (plugin_mgr,
|
||||||
actor);
|
actor);
|
||||||
|
|
||||||
_meta_plugin_effect_started (plugin);
|
|
||||||
klass->maximize (plugin, actor,
|
klass->maximize (plugin, actor,
|
||||||
target_x, target_y,
|
target_x, target_y,
|
||||||
target_width, target_height);
|
target_width, target_height);
|
||||||
@@ -245,8 +238,6 @@ meta_plugin_manager_event_maximize (MetaPluginManager *plugin_mgr,
|
|||||||
retval = TRUE;
|
retval = TRUE;
|
||||||
meta_plugin_manager_kill_window_effects (plugin_mgr,
|
meta_plugin_manager_kill_window_effects (plugin_mgr,
|
||||||
actor);
|
actor);
|
||||||
|
|
||||||
_meta_plugin_effect_started (plugin);
|
|
||||||
klass->unmaximize (plugin, actor,
|
klass->unmaximize (plugin, actor,
|
||||||
target_x, target_y,
|
target_x, target_y,
|
||||||
target_width, target_height);
|
target_width, target_height);
|
||||||
@@ -275,7 +266,7 @@ meta_plugin_manager_switch_workspace (MetaPluginManager *plugin_mgr,
|
|||||||
{
|
{
|
||||||
MetaPlugin *plugin = plugin_mgr->plugin;
|
MetaPlugin *plugin = plugin_mgr->plugin;
|
||||||
MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
|
MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
|
||||||
MetaDisplay *display = meta_screen_get_display (plugin_mgr->screen);
|
MetaDisplay *display = plugin_mgr->compositor->display;
|
||||||
gboolean retval = FALSE;
|
gboolean retval = FALSE;
|
||||||
|
|
||||||
if (display->display_opening)
|
if (display->display_opening)
|
||||||
@@ -285,8 +276,6 @@ meta_plugin_manager_switch_workspace (MetaPluginManager *plugin_mgr,
|
|||||||
{
|
{
|
||||||
retval = TRUE;
|
retval = TRUE;
|
||||||
meta_plugin_manager_kill_switch_workspace (plugin_mgr);
|
meta_plugin_manager_kill_switch_workspace (plugin_mgr);
|
||||||
|
|
||||||
_meta_plugin_effect_started (plugin);
|
|
||||||
klass->switch_workspace (plugin, from, to, direction);
|
klass->switch_workspace (plugin, from, to, direction);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -326,3 +315,44 @@ meta_plugin_manager_confirm_display_change (MetaPluginManager *plugin_mgr)
|
|||||||
else
|
else
|
||||||
return meta_plugin_complete_display_change (plugin, TRUE);
|
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 = plugin_mgr->compositor->display;
|
||||||
|
|
||||||
|
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 = plugin_mgr->compositor->display;
|
||||||
|
|
||||||
|
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.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef META_PLUGIN_MANAGER_H_
|
#ifndef META_PLUGIN_MANAGER_H_
|
||||||
@@ -46,7 +44,7 @@
|
|||||||
*/
|
*/
|
||||||
typedef struct MetaPluginManager MetaPluginManager;
|
typedef struct MetaPluginManager MetaPluginManager;
|
||||||
|
|
||||||
MetaPluginManager * meta_plugin_manager_new (MetaScreen *screen);
|
MetaPluginManager * meta_plugin_manager_new (MetaCompositor *compositor);
|
||||||
|
|
||||||
void meta_plugin_manager_load (const gchar *plugin_name);
|
void meta_plugin_manager_load (const gchar *plugin_name);
|
||||||
|
|
||||||
@@ -77,4 +75,9 @@ gboolean _meta_plugin_xevent_filter (MetaPlugin *plugin,
|
|||||||
|
|
||||||
void meta_plugin_manager_confirm_display_change (MetaPluginManager *mgr);
|
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
|
#endif
|
||||||
|
|||||||
@@ -16,9 +16,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -32,6 +30,7 @@
|
|||||||
#include "meta-plugin-manager.h"
|
#include "meta-plugin-manager.h"
|
||||||
#include <meta/screen.h>
|
#include <meta/screen.h>
|
||||||
#include <meta/display.h>
|
#include <meta/display.h>
|
||||||
|
#include <meta/util.h>
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <X11/Xlib.h>
|
#include <X11/Xlib.h>
|
||||||
@@ -41,98 +40,22 @@
|
|||||||
|
|
||||||
#include "compositor-private.h"
|
#include "compositor-private.h"
|
||||||
#include "meta-window-actor-private.h"
|
#include "meta-window-actor-private.h"
|
||||||
#include "monitor-private.h"
|
#include "meta-monitor-manager.h"
|
||||||
|
|
||||||
G_DEFINE_ABSTRACT_TYPE (MetaPlugin, meta_plugin, G_TYPE_OBJECT);
|
G_DEFINE_ABSTRACT_TYPE (MetaPlugin, meta_plugin, G_TYPE_OBJECT);
|
||||||
|
|
||||||
#define META_PLUGIN_GET_PRIVATE(obj) \
|
#define META_PLUGIN_GET_PRIVATE(obj) \
|
||||||
(G_TYPE_INSTANCE_GET_PRIVATE ((obj), META_TYPE_PLUGIN, MetaPluginPrivate))
|
(G_TYPE_INSTANCE_GET_PRIVATE ((obj), META_TYPE_PLUGIN, MetaPluginPrivate))
|
||||||
|
|
||||||
enum
|
|
||||||
{
|
|
||||||
PROP_0,
|
|
||||||
PROP_SCREEN,
|
|
||||||
PROP_DEBUG_MODE,
|
|
||||||
};
|
|
||||||
|
|
||||||
struct _MetaPluginPrivate
|
struct _MetaPluginPrivate
|
||||||
{
|
{
|
||||||
MetaScreen *screen;
|
MetaCompositor *compositor;
|
||||||
|
|
||||||
gint running;
|
|
||||||
gboolean debug : 1;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
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
|
static void
|
||||||
meta_plugin_class_init (MetaPluginClass *klass)
|
meta_plugin_class_init (MetaPluginClass *klass)
|
||||||
{
|
{
|
||||||
GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
|
g_type_class_add_private (klass, sizeof (MetaPluginPrivate));
|
||||||
|
|
||||||
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));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@@ -141,22 +64,6 @@ meta_plugin_init (MetaPlugin *self)
|
|||||||
self->priv = META_PLUGIN_GET_PRIVATE (self);
|
self->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;
|
|
||||||
}
|
|
||||||
|
|
||||||
const MetaPluginInfo *
|
const MetaPluginInfo *
|
||||||
meta_plugin_get_info (MetaPlugin *plugin)
|
meta_plugin_get_info (MetaPlugin *plugin)
|
||||||
{
|
{
|
||||||
@@ -168,31 +75,26 @@ meta_plugin_get_info (MetaPlugin *plugin)
|
|||||||
return NULL;
|
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)
|
|
||||||
{
|
|
||||||
MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
|
|
||||||
|
|
||||||
priv->running++;
|
|
||||||
}
|
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
_meta_plugin_xevent_filter (MetaPlugin *plugin,
|
_meta_plugin_xevent_filter (MetaPlugin *plugin,
|
||||||
XEvent *xev)
|
XEvent *xev)
|
||||||
{
|
{
|
||||||
MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
|
MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
|
||||||
|
|
||||||
|
/* When mutter is running as a wayland compositor, things like input
|
||||||
|
* events just come directly from clutter so it won't have disabled
|
||||||
|
* clutter's event retrieval and won't need to forward it events (if
|
||||||
|
* it did it would lead to recursion). Also when running as a
|
||||||
|
* wayland compositor we shouldn't be assuming that we're running
|
||||||
|
* with the clutter x11 backend.
|
||||||
|
*/
|
||||||
|
|
||||||
if (klass->xevent_filter && klass->xevent_filter (plugin, xev))
|
if (klass->xevent_filter && klass->xevent_filter (plugin, xev))
|
||||||
return TRUE;
|
return TRUE;
|
||||||
else
|
else if (!meta_is_wayland_compositor ())
|
||||||
return clutter_x11_handle_event (xev) != CLUTTER_X11_FILTER_CONTINUE;
|
return clutter_x11_handle_event (xev) != CLUTTER_X11_FILTER_CONTINUE;
|
||||||
|
else
|
||||||
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@@ -200,15 +102,7 @@ meta_plugin_switch_workspace_completed (MetaPlugin *plugin)
|
|||||||
{
|
{
|
||||||
MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
|
MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
|
||||||
|
|
||||||
MetaScreen *screen = priv->screen;
|
meta_switch_workspace_completed (priv->compositor);
|
||||||
|
|
||||||
if (priv->running-- < 0)
|
|
||||||
{
|
|
||||||
g_warning ("Error in running effect accounting, adjusting.");
|
|
||||||
priv->running = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
meta_switch_workspace_completed (screen);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@@ -216,26 +110,6 @@ meta_plugin_window_effect_completed (MetaPlugin *plugin,
|
|||||||
MetaWindowActor *actor,
|
MetaWindowActor *actor,
|
||||||
unsigned long event)
|
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);
|
meta_window_actor_effect_completed (actor, event);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -302,7 +176,7 @@ meta_plugin_begin_modal (MetaPlugin *plugin,
|
|||||||
{
|
{
|
||||||
MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
|
MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
|
||||||
|
|
||||||
return meta_begin_modal_for_plugin (priv->screen, plugin,
|
return meta_begin_modal_for_plugin (priv->compositor, plugin,
|
||||||
options, timestamp);
|
options, timestamp);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -323,16 +197,14 @@ meta_plugin_end_modal (MetaPlugin *plugin,
|
|||||||
{
|
{
|
||||||
MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
|
MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
|
||||||
|
|
||||||
meta_end_modal_for_plugin (priv->screen, plugin, timestamp);
|
meta_end_modal_for_plugin (priv->compositor, plugin, timestamp);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* meta_plugin_get_screen:
|
* meta_plugin_get_screen:
|
||||||
* @plugin: a #MetaPlugin
|
* @plugin: a #MetaPlugin
|
||||||
*
|
*
|
||||||
* Gets the #MetaScreen corresponding to a plugin. Each plugin instance
|
* Gets the #MetaScreen corresponding to a plugin.
|
||||||
* is associated with exactly one screen; if Metacity is managing
|
|
||||||
* multiple screens, multiple plugin instances will be created.
|
|
||||||
*
|
*
|
||||||
* Return value: (transfer none): the #MetaScreen for the plugin
|
* Return value: (transfer none): the #MetaScreen for the plugin
|
||||||
*/
|
*/
|
||||||
@@ -341,7 +213,15 @@ meta_plugin_get_screen (MetaPlugin *plugin)
|
|||||||
{
|
{
|
||||||
MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
|
MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
|
||||||
|
|
||||||
return priv->screen;
|
return priv->compositor->display->screen;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
_meta_plugin_set_compositor (MetaPlugin *plugin, MetaCompositor *compositor)
|
||||||
|
{
|
||||||
|
MetaPluginPrivate *priv = META_PLUGIN (plugin)->priv;
|
||||||
|
|
||||||
|
priv->compositor = compositor;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|||||||
@@ -17,9 +17,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __META_SHADOW_FACTORY_PRIVATE_H__
|
#ifndef __META_SHADOW_FACTORY_PRIVATE_H__
|
||||||
|
|||||||
@@ -13,9 +13,7 @@
|
|||||||
* General Public License for more details.
|
* General Public License for more details.
|
||||||
*
|
*
|
||||||
* You should have received a copy of the GNU General Public License
|
* You should have received a copy of the GNU General Public License
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
|
|
||||||
* 02111-1307, USA.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user