Compare commits
	
		
			590 Commits
		
	
	
		
			3.31.2
			...
			wip/aday/s
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 34e9513e1f | ||
|   | 40a772c884 | ||
|   | 2ccd87ae44 | ||
|   | 2f5086efaf | ||
|   | 68e580e394 | ||
|   | b143869d5d | ||
|   | 6a477be874 | ||
|   | 03bb8cdcbd | ||
|   | 8864816b94 | ||
|   | 751cd2f1c1 | ||
|   | 6f6b6fb9d6 | ||
|   | fe346b89f0 | ||
|   | 0744c6af2e | ||
|   | 2e070ab834 | ||
|   | 00f9b7bf69 | ||
|   | 94ba52af0c | ||
|   | 44e1a6ce06 | ||
|   | ccf646f54a | ||
|   | 4e84b46c9b | ||
|   | b4797956c7 | ||
|   | c1c45f95af | ||
|   | ac09e0110a | ||
|   | 0e37cd2ec9 | ||
|   | 76dc77f617 | ||
|   | cb4c0d32c0 | ||
|   | 3d4ba028c4 | ||
|   | 5481c1899f | ||
|   | 2fd120162f | ||
|   | 523ba5a719 | ||
|   | 07d25cd69d | ||
|   | 520cea9394 | ||
|   | 58c4212cfa | ||
|   | 7059e31f6a | ||
|   | a9234f7631 | ||
|   | 1e5a8b0cd7 | ||
|   | 5ef343f245 | ||
|   | 22e33b4c47 | ||
|   | 5ace4682bf | ||
|   | 14d9839ed3 | ||
|   | 3b6fae582b | ||
|   | 3cbdf4f9a5 | ||
|   | d8825e0d12 | ||
|   | 3c5fea59df | ||
|   | 443c8347ea | ||
|   | ee3f52c097 | ||
|   | 4b01bb6f99 | ||
|   | 27ef8154dc | ||
|   | 0a7e717e0e | ||
|   | 2d2824b947 | ||
|   | 40c2a403ac | ||
|   | 238b87d386 | ||
|   | 8c01d341c7 | ||
|   | 866629b3d3 | ||
|   | 2b3ab3ecec | ||
|   | 759120b95f | ||
|   | de0e21612c | ||
|   | 83e83444db | ||
|   | 5060aee7b2 | ||
|   | 12bace2721 | ||
|   | 2c45b5416e | ||
|   | 96c2473317 | ||
|   | 6359d6ef30 | ||
|   | 2f6323afc2 | ||
|   | d25bcbc3a7 | ||
|   | dd5d7d3b70 | ||
|   | 771b1a0788 | ||
|   | 5a9d094f3e | ||
|   | 9ca8433170 | ||
|   | 0ada312748 | ||
|   | 88697add1b | ||
|   | 4730b7a094 | ||
|   | aa3e64aec3 | ||
|   | af26e2b212 | ||
|   | 8167f20972 | ||
|   | bd4aac8f49 | ||
|   | 785dd5c5f7 | ||
|   | 71e469a59c | ||
|   | 6d4b9d29b8 | ||
|   | 33f5bb39cd | ||
|   | a1c3900630 | ||
|   | cdaf164c01 | ||
|   | 2bd80579ed | ||
|   | 54039c3552 | ||
|   | b197a1affb | ||
|   | 51655be6a3 | ||
|   | 9697c209c0 | ||
|   | 6ecb0a4546 | ||
|   | 30861d4800 | ||
|   | a23391ea28 | ||
|   | 58e0b80cac | ||
|   | 41dd744b74 | ||
|   | bdf66d7b62 | ||
|   | 4258ae3ec2 | ||
|   | 9b379c49ba | ||
|   | 7e70dd8453 | ||
|   | 2e209a82f9 | ||
|   | ab0ecc469f | ||
|   | 7d75ddf635 | ||
|   | 271e43a1ed | ||
|   | 2702a82896 | ||
|   | 8ad33d8752 | ||
|   | d84bbb8770 | ||
|   | c0c2edf2e1 | ||
|   | de0c3251dd | ||
|   | 0afd600ea4 | ||
|   | 598407b14a | ||
|   | d9bfa16f05 | ||
|   | 03117d65b2 | ||
|   | 5520bb3890 | ||
|   | 4e6b2eb72a | ||
|   | 2e5295b3a9 | ||
|   | 3121c9aa29 | ||
|   | 1ebbd7c768 | ||
|   | 8572bb97c7 | ||
|   | d5ebd8c816 | ||
|   | ed999ce926 | ||
|   | 50b7739076 | ||
|   | 94995e9c1e | ||
|   | fb04dafb0b | ||
|   | d57234bec9 | ||
|   | 38da54fb02 | ||
|   | bbd3275dad | ||
|   | 3a3f9aa008 | ||
|   | 3c54e863e6 | ||
|   | a63ba61194 | ||
|   | ab9710ee7b | ||
|   | 43cef45229 | ||
|   | 8db4f3c67f | ||
|   | 594a070029 | ||
|   | c2e04e3cfa | ||
|   | 293f50e8e5 | ||
|   | df7fea3407 | ||
|   | 563412698a | ||
|   | 2b30146c6c | ||
|   | 0f531d8c44 | ||
|   | 218c87994b | ||
|   | f74c07b9ac | ||
|   | 59edea4bb4 | ||
|   | 4d4d5a0b16 | ||
|   | 03c4930883 | ||
|   | 9593e20425 | ||
|   | 2b1d6e607f | ||
|   | 1dff32e48a | ||
|   | 1e3a174de9 | ||
|   | 7bb84dae80 | ||
|   | 44fcb9e9af | ||
|   | 2d30e310bc | ||
|   | be2d630348 | ||
|   | bea6045aae | ||
|   | ad491e7922 | ||
|   | fedb8e706a | ||
|   | 1be933bc49 | ||
|   | 526bb72f3d | ||
|   | 49c95cff6c | ||
|   | 56a361650c | ||
|   | d4763b157d | ||
|   | d2dc072ba9 | ||
|   | ffaca00594 | ||
|   | 9090b7dc3d | ||
|   | a540fe4130 | ||
|   | 5be61bbb68 | ||
|   | 8e51fee5c1 | ||
|   | 9d6fcfdc85 | ||
|   | 5f5a3b78a5 | ||
|   | 4e5ca6d376 | ||
|   | 2fab75f448 | ||
|   | 22883f2fa2 | ||
|   | 5d9f80bc73 | ||
|   | f7d117488b | ||
|   | 244a329ee7 | ||
|   | 044572cb60 | ||
|   | 746875258d | ||
|   | 4892a87dfe | ||
|   | 8b9c8ddb1e | ||
|   | eb9000576c | ||
|   | 862aaf341e | ||
|   | a5c75ff58b | ||
|   | 4541fb9819 | ||
|   | 9f8edd980c | ||
|   | e5b9043435 | ||
|   | c0012c2ea4 | ||
|   | b77e4975f0 | ||
|   | e83f2344f6 | ||
|   | de6512be1a | ||
|   | 0b72ff1896 | ||
|   | fea0192772 | ||
|   | f81ac498fb | ||
|   | 5357e0a18c | ||
|   | d7632bbd3d | ||
|   | 1b5e91e4b3 | ||
|   | 727195c767 | ||
|   | 9158f55360 | ||
|   | 8146e9d527 | ||
|   | 4247251020 | ||
|   | 7eee0e0ed6 | ||
|   | 4f0851ca77 | ||
|   | 911ae49767 | ||
|   | 5af81d4057 | ||
|   | c435889baa | ||
|   | 49f79d9d5d | ||
|   | 1767cd0f6c | ||
|   | 3e0915521a | ||
|   | a298943fac | ||
|   | df9ddf96a5 | ||
|   | 4fa5d701d5 | ||
|   | b05683d586 | ||
|   | 2f3f3fbcdb | ||
|   | 611605a67f | ||
|   | 0427a782be | ||
|   | 32baff5906 | ||
|   | 0089143d06 | ||
|   | 05e55cee23 | ||
|   | 31e7f0340f | ||
|   | 6e317a54fd | ||
|   | 9c1f62c38c | ||
|   | 1341d5557f | ||
|   | b7d79a5f06 | ||
|   | 62233a4db4 | ||
|   | 4a7e2ddff5 | ||
|   | fb737ebde0 | ||
|   | bf77cb44e7 | ||
|   | c72e2bb4a9 | ||
|   | 68c182b1df | ||
|   | 348d303794 | ||
|   | ede0fd8660 | ||
|   | 187c2193e8 | ||
|   | 706bdd8059 | ||
|   | 436861edc8 | ||
|   | 9729a2e772 | ||
|   | 6b924c00c5 | ||
|   | b90f4d29a4 | ||
|   | 47915f8c11 | ||
|   | 5dfdeaa4ea | ||
|   | 98a2a81f2a | ||
|   | c4850027bc | ||
|   | d4202e7f38 | ||
|   | 4f65283f31 | ||
|   | d86d3bbe54 | ||
|   | 6f794738e8 | ||
|   | ef7a93bb07 | ||
|   | 5197a992a6 | ||
|   | 49d8540f6d | ||
|   | 6e1a1f1a57 | ||
|   | c73428247c | ||
|   | fc2caf5794 | ||
|   | b117826ada | ||
|   | 26b44b48ab | ||
|   | 6349f0feb1 | ||
|   | 2ae17cfb50 | ||
|   | 4785093a5c | ||
|   | 859aef78c4 | ||
|   | 20730a5465 | ||
|   | fc5f687afc | ||
|   | 53e56f2395 | ||
|   | da314aff79 | ||
|   | fe89f7c5ac | ||
|   | 8b3be5e063 | ||
|   | 58dc538510 | ||
|   | 6cbef9355d | ||
|   | 22eac5c508 | ||
|   | a2860e9c73 | ||
|   | 1c5258ab68 | ||
|   | 8641eaa538 | ||
|   | 88436383c0 | ||
|   | affdcdcb0e | ||
|   | 06174be777 | ||
|   | fde8401124 | ||
|   | 70ac33d58c | ||
|   | 5a897407d9 | ||
|   | 1b3c26364b | ||
|   | ae07aa7864 | ||
|   | fb80831269 | ||
|   | 561cecf383 | ||
|   | 60ccdc2deb | ||
|   | d7d996b1d3 | ||
|   | 32b8bc39ac | ||
|   | 9dc99ad611 | ||
|   | 628cb4d553 | ||
|   | ad80bce78d | ||
|   | 1c9d821aa2 | ||
|   | 510b060947 | ||
|   | 26e33ff093 | ||
|   | 5f2bd70690 | ||
|   | 6dfa550663 | ||
|   | 252e2420ad | ||
|   | 572d54981e | ||
|   | 61471f9fb4 | ||
|   | 4d0a742d64 | ||
|   | 5f4e0e5ff8 | ||
|   | a4c159ecad | ||
|   | b1f893e998 | ||
|   | 789dc165af | ||
|   | 115eda9650 | ||
|   | d027e35cef | ||
|   | b3e178af9d | ||
|   | 559ec8750a | ||
|   | 02c3980b83 | ||
|   | 6f027ee7dc | ||
|   | 6d6c2e5b99 | ||
|   | 4a4f752459 | ||
|   | 8f1fff1374 | ||
|   | deead2af97 | ||
|   | 9e881ab637 | ||
|   | b6ec02cef2 | ||
|   | 26e3ccda49 | ||
|   | 2bda79cb3a | ||
|   | 19c60ff5c5 | ||
|   | e3c5c9a2e7 | ||
|   | 2c17c186b8 | ||
|   | ef1697d00d | ||
|   | 40e7638a4b | ||
|   | aaf69b2898 | ||
|   | 0464361ca5 | ||
|   | 420697693b | ||
|   | 37f53a42da | ||
|   | 5617ffc79c | ||
|   | ca4d86e9e5 | ||
|   | 0141fef561 | ||
|   | 5d4a804c90 | ||
|   | 6bc3300e5a | ||
|   | 15f69bdc3b | ||
|   | 0bcf76970a | ||
|   | 03c4628cad | ||
|   | 9f4ae9618a | ||
|   | 3590af15bb | ||
|   | c5de7fd20e | ||
|   | 7127fb1fa1 | ||
|   | 7cf11abefc | ||
|   | d78b416e1a | ||
|   | f5144ec899 | ||
|   | 08d1ebe7ee | ||
|   | a665801e9f | ||
|   | 112e3b110b | ||
|   | 94a674c008 | ||
|   | 72be8eeb31 | ||
|   | ad8690bb2e | ||
|   | 76cb08a72a | ||
|   | 2d4989e937 | ||
|   | f248b91f82 | ||
|   | d671eb1969 | ||
|   | 70f4906ca5 | ||
|   | ffb9aa1ace | ||
|   | 823fd855cf | ||
|   | f5ee225362 | ||
|   | ff1ea4b1c9 | ||
|   | 779b5afa51 | ||
|   | 6d870f6ae4 | ||
|   | d3926cbca9 | ||
|   | a308804679 | ||
|   | a4e4da705a | ||
|   | 7a494ec027 | ||
|   | d53ebb101a | ||
|   | f3168d22a6 | ||
|   | be06101e9a | ||
|   | 6e4178981a | ||
|   | b85ea59cda | ||
|   | bbd68626cc | ||
|   | 8490173879 | ||
|   | baed9518c2 | ||
|   | 27d0d9f2b3 | ||
|   | 382282b931 | ||
|   | 23d233857e | ||
|   | 9620bd0f22 | ||
|   | ecfe56ca63 | ||
|   | eabb02d3da | ||
|   | da3953a388 | ||
|   | 2d26dbc96f | ||
|   | 7073471302 | ||
|   | 81f0e7de9e | ||
|   | 33e05f5912 | ||
|   | c1d3e304cb | ||
|   | 1b169655ac | ||
|   | 67393e09c3 | ||
|   | 1ec8d2c531 | ||
|   | a111bfb90a | ||
|   | 7dd326f090 | ||
|   | 24a26e025b | ||
|   | 1eb7ba0506 | ||
|   | d17d99bd6d | ||
|   | fd50b9a45e | ||
|   | a1534dab02 | ||
|   | 7484458b7c | ||
|   | 5ca039c1db | ||
|   | 2294ae0c46 | ||
|   | 4d2b2a12ea | ||
|   | c6d57059ff | ||
|   | 5f13cf767e | ||
|   | 93425b0500 | ||
|   | a87ab6d0fc | ||
|   | 1c117c469a | ||
|   | 8003f8b803 | ||
|   | 7df93458d7 | ||
|   | 753618a19f | ||
|   | e355756758 | ||
|   | 62a3b9e6a3 | ||
|   | dc79393b27 | ||
|   | c334aa2a4c | ||
|   | 9f61a4f5fd | ||
|   | 15d0050994 | ||
|   | 1846f337d8 | ||
|   | a9e63039ce | ||
|   | 7edd5f27d1 | ||
|   | 9b47195974 | ||
|   | 4ef8041be0 | ||
|   | f0a7395b30 | ||
|   | c1a6effea0 | ||
|   | f78efc46e7 | ||
|   | 42ae052da7 | ||
|   | fab390826e | ||
|   | 2a9923628b | ||
|   | 291aa0b053 | ||
|   | 83eb75ad7a | ||
|   | bb215966e5 | ||
|   | 545d49c70d | ||
|   | ace44af815 | ||
|   | 699e97559d | ||
|   | 4aecf4c973 | ||
|   | b092c5f37d | ||
|   | aca8aec94b | ||
|   | 9cfb51c106 | ||
|   | e2352f5126 | ||
|   | 40e624444c | ||
|   | 3cf67b1236 | ||
|   | 5dedb97fcc | ||
|   | 4590094605 | ||
|   | 15e7625c80 | ||
|   | cdd2803498 | ||
|   | 43fb2b38b1 | ||
|   | 95224bd006 | ||
|   | 446183adee | ||
|   | 345a8fe748 | ||
|   | d8593c5b4a | ||
|   | f89d721c12 | ||
|   | af34b7c25e | ||
|   | b108aa1ace | ||
|   | 5dbf09c008 | ||
|   | 680dc18c6b | ||
|   | 73413ac6c0 | ||
|   | f61c8e5e1d | ||
|   | 36713db990 | ||
|   | 6bb7d4002f | ||
|   | aa28d487d3 | ||
|   | a7d974481c | ||
|   | 3730314dd5 | ||
|   | 6b0c8c9fe0 | ||
|   | 28a56d24ad | ||
|   | 5e6629e1a7 | ||
|   | a00b967df0 | ||
|   | 193e4ae31e | ||
|   | 409a27c3b8 | ||
|   | ba97e8da7a | ||
|   | c47e672eea | ||
|   | 43a19739ab | ||
|   | 36f9147b21 | ||
|   | 8647922df9 | ||
|   | df3068d9ca | ||
|   | 036e67049b | ||
|   | f02033acb7 | ||
|   | 91d73d65c3 | ||
|   | 81c4c23016 | ||
|   | fef2bac8ab | ||
|   | c59c5eb893 | ||
|   | a977c1388a | ||
|   | 0f799ae313 | ||
|   | 23c3f3fdea | ||
|   | 82c7090e9e | ||
|   | 0fdfebdb67 | ||
|   | 208c551787 | ||
|   | b10606e884 | ||
|   | f4a64f77f2 | ||
|   | e92477a752 | ||
|   | 37e0a73c8f | ||
|   | 4f76e05058 | ||
|   | 3134222d27 | ||
|   | a9ed128dce | ||
|   | c264cc4131 | ||
|   | a7943ff934 | ||
|   | c353914dd0 | ||
|   | 91319e3963 | ||
|   | dc4ff941bd | ||
|   | b597d5faf0 | ||
|   | f6da36ad3a | ||
|   | 5f4e2749a2 | ||
|   | 69b1fb699f | ||
|   | 259f90bbf6 | ||
|   | 8665045326 | ||
|   | a7bb8ee639 | ||
|   | 8f732e4f45 | ||
|   | 95a31b0c31 | ||
|   | 36b9f45368 | ||
|   | 46575804cc | ||
|   | 86a00b6872 | ||
|   | 23d6d13d80 | ||
|   | 09addfc87c | ||
|   | a2f27a9409 | ||
|   | 412003efbf | ||
|   | 582b3aacf4 | ||
|   | 1af0b54c1e | ||
|   | 74ba2e6634 | ||
|   | 78608a5080 | ||
|   | 7a86637f8d | ||
|   | c2961f2152 | ||
|   | 6845c6f958 | ||
|   | 794a056819 | ||
|   | 69ad75cf48 | ||
|   | 3db52155dd | ||
|   | 38805ae662 | ||
|   | dfa0750ffd | ||
|   | d80e7e0118 | ||
|   | b7e2718bdc | ||
|   | e68dfed1f7 | ||
|   | bacfdbbb03 | ||
|   | 99ce3deeb0 | ||
|   | d75a3484d6 | ||
|   | 3dcb593a71 | ||
|   | 1847a4f4cc | ||
|   | deec0bf255 | ||
|   | 8bb9eb0fc9 | ||
|   | 21de3c327b | ||
|   | 081d94e0f6 | ||
|   | ddd1825162 | ||
|   | 5f223e0bd8 | ||
|   | 809d92129b | ||
|   | 8840608a25 | ||
|   | edbb204332 | ||
|   | 9dc3b73ef9 | ||
|   | a7d618915c | ||
|   | 3e3da8e2f8 | ||
|   | a6763e7731 | ||
|   | 8f15193b40 | ||
|   | 467b7c1bca | ||
|   | 97963a1ca8 | ||
|   | 2fc1f1adbe | ||
|   | 200f4908d5 | ||
|   | 1f864c905d | ||
|   | df77fb6793 | ||
|   | 3fa3889fa5 | ||
|   | 4b28b90e0f | ||
|   | e0a992af73 | ||
|   | 7c4e43c84f | ||
|   | b57832716a | ||
|   | 945a019974 | ||
|   | 22e21ad7d1 | ||
|   | ae48f8bda9 | ||
|   | 62abf3edc7 | ||
|   | f8ce47c24d | ||
|   | ddb3a5c625 | ||
|   | c6d2bc4c57 | ||
|   | e3a0b6d4ee | ||
|   | e5a0dcb47e | ||
|   | 3989cad3db | ||
|   | 2a1f915f9d | ||
|   | a6002652d0 | ||
|   | 25bfe99ed5 | ||
|   | 9a35c9902a | ||
|   | 4259676f6e | ||
|   | 2159d6886f | ||
|   | ca4e563f55 | ||
|   | 8be0c5a58a | ||
|   | 5edceba588 | ||
|   | 49133c7245 | ||
|   | c1c00a8c1d | ||
|   | d3bf1a9ee7 | ||
|   | f43f9557e4 | ||
|   | a92ad59595 | ||
|   | 616852cf2b | ||
|   | e5ce3d541e | ||
|   | 925a25da17 | ||
|   | 6743c18fdf | ||
|   | 4d649d6ee8 | ||
|   | 121c427438 | ||
|   | 25fbffc454 | ||
|   | 0e0574a0b4 | ||
|   | 4c11d15a07 | ||
|   | 3217c10ff2 | ||
|   | 264050742b | ||
|   | cdb8ac3a2f | ||
|   | 10b3671a99 | ||
|   | 4d2dce2c52 | ||
|   | 27c660d2a9 | ||
|   | 8e7c90b930 | ||
|   | ff2fbf5ae4 | ||
|   | e77463b875 | ||
|   | 74bb9e6249 | ||
|   | 43041f0464 | ||
|   | c3ec813f6f | ||
|   | 04d7069d83 | ||
|   | 52c59ac0dd | ||
|   | 240f3faf6e | ||
|   | 284978757e | 
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -80,3 +80,4 @@ tests/run-test.sh | |||||||
| *~ | *~ | ||||||
| *.patch | *.patch | ||||||
| *.sw? | *.sw? | ||||||
|  | .vscode | ||||||
|   | |||||||
							
								
								
									
										88
									
								
								.gitlab-ci.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,88 @@ | |||||||
|  | stages: | ||||||
|  |  - review | ||||||
|  |  - source_check | ||||||
|  |  - build | ||||||
|  |  - test | ||||||
|  |  | ||||||
|  | variables: | ||||||
|  |     JS_LOG: "js-report.txt" | ||||||
|  |     POT_LOG: "pot-update.txt" | ||||||
|  |  | ||||||
|  | .only_default: &only_default | ||||||
|  |     only: | ||||||
|  |         - branches | ||||||
|  |         - tags | ||||||
|  |         - merge_requests | ||||||
|  |  | ||||||
|  | check_commit_log: | ||||||
|  |     image: registry.gitlab.gnome.org/gnome/mutter/master:v2 | ||||||
|  |     stage: review | ||||||
|  |     variables: | ||||||
|  |         GIT_DEPTH: "100" | ||||||
|  |     script: | ||||||
|  |         - ./.gitlab-ci/check-commit-log.sh | ||||||
|  |     only: | ||||||
|  |         - merge_requests | ||||||
|  |  | ||||||
|  | js_check: | ||||||
|  |     image: registry.gitlab.gnome.org/gnome/gnome-shell/extension-ci:v1 | ||||||
|  |     stage: source_check | ||||||
|  |     script: | ||||||
|  |         - find js -name '*.js' -exec js60 -c -s '{}' ';' 2>&1 | tee $JS_LOG | ||||||
|  |         - (! grep -q . $JS_LOG) | ||||||
|  |     <<: *only_default | ||||||
|  |     only: | ||||||
|  |         changes: | ||||||
|  |             - js/**/* | ||||||
|  |     artifacts: | ||||||
|  |         paths: | ||||||
|  |             - ${JS_LOG} | ||||||
|  |         when: on_failure | ||||||
|  |  | ||||||
|  | build: | ||||||
|  |     image: registry.gitlab.gnome.org/gnome/mutter/master:v2 | ||||||
|  |     stage: build | ||||||
|  |     before_script: | ||||||
|  |         - .gitlab-ci/checkout-mutter.sh | ||||||
|  |         - meson mutter mutter/build --prefix=/usr -Dtests=false | ||||||
|  |         - ninja -C mutter/build install | ||||||
|  |     script: | ||||||
|  |         - meson . build -Dbuiltype=debugoptimized | ||||||
|  |         - ninja -C build | ||||||
|  |         - ninja -C build install | ||||||
|  |     <<: *only_default | ||||||
|  |     artifacts: | ||||||
|  |         expire_in: 1 day | ||||||
|  |         paths: | ||||||
|  |             - mutter | ||||||
|  |             - build | ||||||
|  |  | ||||||
|  | test: | ||||||
|  |     image: registry.gitlab.gnome.org/gnome/mutter/master:v2 | ||||||
|  |     stage: test | ||||||
|  |     before_script: | ||||||
|  |         - ninja -C mutter/build install | ||||||
|  |     script: | ||||||
|  |         - xvfb-run meson test -C build --no-rebuild | ||||||
|  |     <<: *only_default | ||||||
|  |     artifacts: | ||||||
|  |         expire_in: 1 day | ||||||
|  |         paths: | ||||||
|  |             - build/meson-logs/testlog.txt | ||||||
|  |         when: on_failure | ||||||
|  |  | ||||||
|  | test-pot: | ||||||
|  |     image: registry.gitlab.gnome.org/gnome/mutter/master:v2 | ||||||
|  |     stage: test | ||||||
|  |     before_script: | ||||||
|  |         - ninja -C mutter/build install | ||||||
|  |     script: | ||||||
|  |         # Check that pot files are generated correctly: | ||||||
|  |         # https://savannah.gnu.org/bugs/?50920#comment5 | ||||||
|  |         - ninja -C build gnome-shell-pot 2>&1 | awk ' | ||||||
|  |             BEGIN { start=0; } | ||||||
|  |             start==1 { print $0; } | ||||||
|  |             /gnome-shell-pot/ { start=1; } | ||||||
|  |           ' | tee $POT_LOG | ||||||
|  |         - (! grep -q . $POT_LOG) | ||||||
|  |     <<: *only_default | ||||||
							
								
								
									
										18
									
								
								.gitlab-ci/Dockerfile.extension-ci
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,18 @@ | |||||||
|  | FROM registry.fedoraproject.org/fedora:latest | ||||||
|  |  | ||||||
|  | RUN dnf -y update && dnf -y upgrade && \ | ||||||
|  |     dnf install -y 'dnf-command(copr)' && \ | ||||||
|  |  | ||||||
|  |     # For syntax checks with `find . -name '*.js' -exec js60 -c -s '{}' ';'` | ||||||
|  |     dnf install -y findutils mozjs60-devel && \ | ||||||
|  |  | ||||||
|  |     # For static analysis with eslint | ||||||
|  |     dnf install -y nodejs && \ | ||||||
|  |     npm install -g eslint && \ | ||||||
|  |  | ||||||
|  |     # Shameless plug for my own tooling; useful for generating zip | ||||||
|  |     dnf copr enable -y fmuellner/gnome-shell-ci && \ | ||||||
|  |     dnf install -y gnome-extensions-tool meson && \ | ||||||
|  |  | ||||||
|  |     dnf clean all && \ | ||||||
|  |     rm -rf /var/cache/dnf | ||||||
							
								
								
									
										31
									
								
								.gitlab-ci/check-commit-log.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						| @@ -0,0 +1,31 @@ | |||||||
|  | #!/usr/bin/env bash | ||||||
|  |  | ||||||
|  | if [ -z "$CI_MERGE_REQUEST_TARGET_BRANCH_NAME" ]; then | ||||||
|  |   echo Cannot review non-merge request | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | git fetch $CI_MERGE_REQUEST_PROJECT_URL.git $CI_MERGE_REQUEST_TARGET_BRANCH_NAME | ||||||
|  |  | ||||||
|  | branch_point=$(git merge-base HEAD FETCH_HEAD) | ||||||
|  |  | ||||||
|  | commits=$(git log --format='format:%H' $branch_point..$CI_COMMIT_SHA) | ||||||
|  |  | ||||||
|  | if [ -z "$commits" ]; then | ||||||
|  |   echo Commit range empty | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | function commit_message_has_url() { | ||||||
|  |   commit=$1 | ||||||
|  |   commit_message=$(git show -s --format='format:%b' $commit) | ||||||
|  |   echo "$commit_message" | grep -qe "\($CI_MERGE_REQUEST_PROJECT_URL/\(issues\|merge_requests\)/[0-9]\+\|https://bugzilla.gnome.org/show_bug.cgi?id=[0-9]\+\)" | ||||||
|  |   return $? | ||||||
|  | } | ||||||
|  |  | ||||||
|  | for commit in $commits; do | ||||||
|  |   if ! commit_message_has_url $commit; then | ||||||
|  |     echo "Missing merge request or issue URL on commit $(echo $commit | cut -c -8)" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|  | done | ||||||
							
								
								
									
										35
									
								
								.gitlab-ci/checkout-mutter.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						| @@ -0,0 +1,35 @@ | |||||||
|  | #!/usr/bin/bash | ||||||
|  |  | ||||||
|  | shell_branch=$(git describe --contains --all HEAD) | ||||||
|  | mutter_target= | ||||||
|  |  | ||||||
|  | git clone https://gitlab.gnome.org/GNOME/mutter.git | ||||||
|  |  | ||||||
|  | if [ $? -ne 0 ]; then | ||||||
|  |   echo Checkout failed | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | cd mutter | ||||||
|  |  | ||||||
|  | if [ "$CI_MERGE_REQUEST_TARGET_BRANCH_NAME" ]; then | ||||||
|  |   merge_request_remote=${CI_MERGE_REQUEST_SOURCE_PROJECT_URL//gnome-shell/mutter} | ||||||
|  |   merge_request_branch=$CI_MERGE_REQUEST_SOURCE_BRANCH_NAME | ||||||
|  |  | ||||||
|  |   echo Looking for $merge_request_branch on remote ... | ||||||
|  |   if git fetch -q $merge_request_remote $merge_request_branch 2>/dev/null; then | ||||||
|  |     mutter_target=FETCH_HEAD | ||||||
|  |   else | ||||||
|  |     mutter_target=origin/$CI_MERGE_REQUEST_TARGET_BRANCH_NAME | ||||||
|  |     echo Using $mutter_target instead | ||||||
|  |   fi | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | if [ -z "$mutter_target" ]; then | ||||||
|  |   mutter_target=$(git branch -r -l origin/$shell_branch) | ||||||
|  |   mutter_target=${mutter_target:-$(git branch -r -l ${shell_branch#remotes/})} | ||||||
|  |   mutter_target=${mutter_target:-origin/master} | ||||||
|  |   echo Using $mutter_target instead | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | git checkout -q $mutter_target | ||||||
							
								
								
									
										31
									
								
								.project
									
									
									
									
									
								
							
							
						
						| @@ -1,31 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8"?> |  | ||||||
| <projectDescription> |  | ||||||
| 	<name>gnome-shell</name> |  | ||||||
| 	<comment></comment> |  | ||||||
| 	<projects> |  | ||||||
| 	</projects> |  | ||||||
| 	<buildSpec> |  | ||||||
| 		<buildCommand> |  | ||||||
| 			<name>org.eclipse.wst.jsdt.core.javascriptValidator</name> |  | ||||||
| 			<arguments> |  | ||||||
| 			</arguments> |  | ||||||
| 		</buildCommand> |  | ||||||
| 		<buildCommand> |  | ||||||
| 			<name>org.eclipse.linuxtools.cdt.autotools.genmakebuilder</name> |  | ||||||
| 			<arguments> |  | ||||||
| 			</arguments> |  | ||||||
| 		</buildCommand> |  | ||||||
| 		<buildCommand> |  | ||||||
| 			<name>org.eclipse.cdt.managedbuilder.core.ScannerConfigBuilder</name> |  | ||||||
| 			<arguments> |  | ||||||
| 			</arguments> |  | ||||||
| 		</buildCommand> |  | ||||||
| 	</buildSpec> |  | ||||||
| 	<natures> |  | ||||||
| 		<nature>org.eclipse.cdt.managedbuilder.core.ScannerConfigNature</nature> |  | ||||||
| 		<nature>org.eclipse.linuxtools.cdt.autotools.autotoolsNature</nature> |  | ||||||
| 		<nature>org.eclipse.cdt.managedbuilder.core.managedBuildNature</nature> |  | ||||||
| 		<nature>org.eclipse.cdt.core.cnature</nature> |  | ||||||
| 		<nature>org.eclipse.wst.jsdt.core.jsNature</nature> |  | ||||||
| 	</natures> |  | ||||||
| </projectDescription> |  | ||||||
| @@ -1,148 +0,0 @@ | |||||||
| #Fri Nov 28 14:33:30 EST 2008 |  | ||||||
| eclipse.preferences.version=1 |  | ||||||
| org.eclipse.cdt.core.formatter.alignment_for_arguments_in_method_invocation=16 |  | ||||||
| org.eclipse.cdt.core.formatter.alignment_for_base_clause_in_type_declaration=80 |  | ||||||
| org.eclipse.cdt.core.formatter.alignment_for_compact_if=0 |  | ||||||
| org.eclipse.cdt.core.formatter.alignment_for_conditional_expression=80 |  | ||||||
| org.eclipse.cdt.core.formatter.alignment_for_declarator_list=16 |  | ||||||
| org.eclipse.cdt.core.formatter.alignment_for_enumerator_list=48 |  | ||||||
| org.eclipse.cdt.core.formatter.alignment_for_expression_list=0 |  | ||||||
| org.eclipse.cdt.core.formatter.alignment_for_expressions_in_array_initializer=16 |  | ||||||
| org.eclipse.cdt.core.formatter.alignment_for_parameters_in_method_declaration=16 |  | ||||||
| org.eclipse.cdt.core.formatter.alignment_for_throws_clause_in_method_declaration=16 |  | ||||||
| org.eclipse.cdt.core.formatter.brace_position_for_array_initializer=next_line_shifted |  | ||||||
| org.eclipse.cdt.core.formatter.brace_position_for_block=next_line_shifted |  | ||||||
| org.eclipse.cdt.core.formatter.brace_position_for_block_in_case=next_line_shifted |  | ||||||
| org.eclipse.cdt.core.formatter.brace_position_for_method_declaration=next_line |  | ||||||
| org.eclipse.cdt.core.formatter.brace_position_for_namespace_declaration=next_line |  | ||||||
| org.eclipse.cdt.core.formatter.brace_position_for_switch=next_line_shifted |  | ||||||
| org.eclipse.cdt.core.formatter.brace_position_for_type_declaration=next_line |  | ||||||
| org.eclipse.cdt.core.formatter.compact_else_if=true |  | ||||||
| org.eclipse.cdt.core.formatter.continuation_indentation=2 |  | ||||||
| org.eclipse.cdt.core.formatter.continuation_indentation_for_array_initializer=2 |  | ||||||
| org.eclipse.cdt.core.formatter.format_guardian_clause_on_one_line=false |  | ||||||
| org.eclipse.cdt.core.formatter.indent_access_specifier_compare_to_type_header=false |  | ||||||
| org.eclipse.cdt.core.formatter.indent_body_declarations_compare_to_access_specifier=true |  | ||||||
| org.eclipse.cdt.core.formatter.indent_body_declarations_compare_to_namespace_header=true |  | ||||||
| org.eclipse.cdt.core.formatter.indent_breaks_compare_to_cases=true |  | ||||||
| org.eclipse.cdt.core.formatter.indent_declaration_compare_to_template_header=true |  | ||||||
| org.eclipse.cdt.core.formatter.indent_empty_lines=false |  | ||||||
| org.eclipse.cdt.core.formatter.indent_statements_compare_to_block=true |  | ||||||
| org.eclipse.cdt.core.formatter.indent_statements_compare_to_body=true |  | ||||||
| org.eclipse.cdt.core.formatter.indent_switchstatements_compare_to_cases=true |  | ||||||
| org.eclipse.cdt.core.formatter.indent_switchstatements_compare_to_switch=false |  | ||||||
| org.eclipse.cdt.core.formatter.indentation.size=8 |  | ||||||
| org.eclipse.cdt.core.formatter.insert_new_line_after_opening_brace_in_array_initializer=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_new_line_after_template_declaration=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_new_line_at_end_of_file_if_missing=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_new_line_before_catch_in_try_statement=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_new_line_before_closing_brace_in_array_initializer=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_new_line_before_else_in_if_statement=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_new_line_before_identifier_in_function_declaration=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_new_line_before_while_in_do_statement=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_new_line_in_empty_block=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_assignment_operator=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_binary_operator=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_closing_angle_bracket_in_template_arguments=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_closing_angle_bracket_in_template_parameters=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_closing_brace_in_block=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_closing_paren_in_cast=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_colon_in_base_clause=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_colon_in_case=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_colon_in_conditional=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_colon_in_labeled_statement=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_comma_in_array_initializer=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_comma_in_base_types=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_comma_in_declarator_list=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_comma_in_enum_declarations=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_comma_in_expression_list=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_comma_in_method_declaration_parameters=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_comma_in_method_declaration_throws=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_comma_in_method_invocation_arguments=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_comma_in_template_arguments=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_comma_in_template_parameters=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_angle_bracket_in_template_arguments=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_angle_bracket_in_template_parameters=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_brace_in_array_initializer=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_bracket=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_paren_in_cast=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_paren_in_catch=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_paren_in_for=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_paren_in_if=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_paren_in_method_declaration=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_paren_in_method_invocation=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_paren_in_parenthesized_expression=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_paren_in_switch=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_opening_paren_in_while=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_postfix_operator=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_prefix_operator=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_question_in_conditional=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_semicolon_in_for=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_after_unary_operator=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_assignment_operator=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_binary_operator=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_angle_bracket_in_template_arguments=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_angle_bracket_in_template_parameters=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_brace_in_array_initializer=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_bracket=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_paren_in_cast=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_paren_in_catch=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_paren_in_for=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_paren_in_if=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_paren_in_method_declaration=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_paren_in_method_invocation=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_paren_in_parenthesized_expression=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_paren_in_switch=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_closing_paren_in_while=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_colon_in_base_clause=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_colon_in_case=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_colon_in_conditional=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_colon_in_default=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_colon_in_labeled_statement=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_comma_in_array_initializer=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_comma_in_base_types=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_comma_in_declarator_list=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_comma_in_enum_declarations=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_comma_in_expression_list=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_comma_in_method_declaration_parameters=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_comma_in_method_declaration_throws=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_comma_in_method_invocation_arguments=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_comma_in_template_arguments=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_comma_in_template_parameters=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_angle_bracket_in_template_arguments=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_angle_bracket_in_template_parameters=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_brace_in_array_initializer=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_brace_in_block=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_brace_in_method_declaration=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_brace_in_namespace_declaration=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_brace_in_switch=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_brace_in_type_declaration=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_bracket=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_paren_in_catch=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_paren_in_for=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_paren_in_if=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_paren_in_method_declaration=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_paren_in_method_invocation=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_paren_in_parenthesized_expression=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_paren_in_switch=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_opening_paren_in_while=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_postfix_operator=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_prefix_operator=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_question_in_conditional=insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_semicolon=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_semicolon_in_for=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_before_unary_operator=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_between_empty_braces_in_array_initializer=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_between_empty_brackets=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_between_empty_parens_in_method_declaration=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.insert_space_between_empty_parens_in_method_invocation=do not insert |  | ||||||
| org.eclipse.cdt.core.formatter.keep_else_statement_on_same_line=false |  | ||||||
| org.eclipse.cdt.core.formatter.keep_empty_array_initializer_on_one_line=false |  | ||||||
| org.eclipse.cdt.core.formatter.keep_imple_if_on_one_line=false |  | ||||||
| org.eclipse.cdt.core.formatter.keep_then_statement_on_same_line=false |  | ||||||
| org.eclipse.cdt.core.formatter.lineSplit=80 |  | ||||||
| org.eclipse.cdt.core.formatter.number_of_empty_lines_to_preserve=1 |  | ||||||
| org.eclipse.cdt.core.formatter.put_empty_statement_on_new_line=true |  | ||||||
| org.eclipse.cdt.core.formatter.tabulation.char=space |  | ||||||
| org.eclipse.cdt.core.formatter.tabulation.size=2 |  | ||||||
| org.eclipse.cdt.core.formatter.use_tabs_only_for_leading_indentations=false |  | ||||||
| @@ -1,4 +0,0 @@ | |||||||
| #Fri Nov 28 14:33:30 EST 2008 |  | ||||||
| eclipse.preferences.version=1 |  | ||||||
| formatter_profile=org.eclipse.cdt.ui.default.gnu_profile |  | ||||||
| formatter_settings_version=1 |  | ||||||
| @@ -1,315 +0,0 @@ | |||||||
| #Fri Nov 28 14:43:43 EST 2008 |  | ||||||
| eclipse.preferences.version=1 |  | ||||||
| org.eclipse.wst.jsdt.core.codeComplete.argumentPrefixes= |  | ||||||
| org.eclipse.wst.jsdt.core.codeComplete.argumentSuffixes= |  | ||||||
| org.eclipse.wst.jsdt.core.codeComplete.fieldPrefixes= |  | ||||||
| org.eclipse.wst.jsdt.core.codeComplete.fieldSuffixes= |  | ||||||
| org.eclipse.wst.jsdt.core.codeComplete.localPrefixes= |  | ||||||
| org.eclipse.wst.jsdt.core.codeComplete.localSuffixes= |  | ||||||
| org.eclipse.wst.jsdt.core.codeComplete.staticFieldPrefixes= |  | ||||||
| org.eclipse.wst.jsdt.core.codeComplete.staticFieldSuffixes= |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.codegen.inlineJsrBytecode=disabled |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.codegen.targetPlatform=1.2 |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.codegen.unusedLocal=preserve |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.compliance=1.4 |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.debug.lineNumber=generate |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.debug.localVariable=generate |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.debug.sourceFile=generate |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.assertIdentifier=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.deprecation=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.deprecationInDeprecatedCode=disabled |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.deprecationWhenOverridingDeprecatedMethod=disabled |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.discouragedReference=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.emptyStatement=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.enumIdentifier=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.fallthroughCase=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.fieldHiding=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.finallyBlockNotCompletingNormally=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.forbiddenReference=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.hiddenCatchBlock=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.indirectStaticAccess=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.localVariableHiding=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.looseVarDecleration=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.missingDeprecatedAnnotation=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.noEffectAssignment=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.nonExternalizedStringLiteral=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.nullReference=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.optionalSemicolon=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.parameterAssignment=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.possibleAccidentalBooleanAssignment=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.potentialNullReference=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.redundantNullCheck=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.undefinedField=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.undocumentedEmptyBlock=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.unnecessaryElse=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.unresolvedFieldReference=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.unresolvedMethodReference=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.unresolvedTypeReference=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.unusedDeclaredThrownExceptionWhenOverriding=disabled |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.unusedLabel=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.unusedLocal=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.unusedParameter=ignore |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.unusedParameterIncludeDocCommentReference=enabled |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.unusedParameterWhenImplementingAbstract=disabled |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.problem.unusedPrivateMember=warning |  | ||||||
| org.eclipse.wst.jsdt.core.compiler.source=1.3 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.align_type_members_on_columns=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_arguments_in_allocation_expression=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_arguments_in_enum_constant=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_arguments_in_explicit_constructor_call=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_arguments_in_method_invocation=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_arguments_in_qualified_allocation_expression=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_assignment=0 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_binary_expression=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_compact_if=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_conditional_expression=80 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_enum_constants=0 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_expressions_in_array_initializer=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_multiple_fields=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_parameters_in_constructor_declaration=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_parameters_in_method_declaration=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_selector_in_method_invocation=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_superclass_in_type_declaration=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_superinterfaces_in_enum_declaration=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_superinterfaces_in_type_declaration=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_throws_clause_in_constructor_declaration=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.alignment_for_throws_clause_in_method_declaration=16 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.blank_lines_after_imports=1 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.blank_lines_after_package=1 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.blank_lines_before_field=0 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.blank_lines_before_first_class_body_declaration=0 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.blank_lines_before_imports=1 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.blank_lines_before_member_type=1 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.blank_lines_before_method=1 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.blank_lines_before_new_chunk=1 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.blank_lines_before_package=0 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.blank_lines_between_import_groups=1 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.blank_lines_between_type_declarations=0 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.brace_position_for_annotation_type_declaration=end_of_line |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.brace_position_for_anonymous_type_declaration=end_of_line |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.brace_position_for_array_initializer=end_of_line |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.brace_position_for_block=end_of_line |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.brace_position_for_block_in_case=end_of_line |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.brace_position_for_constructor_declaration=end_of_line |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.brace_position_for_enum_constant=end_of_line |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.brace_position_for_enum_declaration=end_of_line |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.brace_position_for_method_declaration=end_of_line |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.brace_position_for_objlit_initializer=end_of_line |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.brace_position_for_switch=end_of_line |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.brace_position_for_type_declaration=end_of_line |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.clear_blank_lines_in_block_comment=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.clear_blank_lines_in_javadoc_comment=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.format_block_comments=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.format_header=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.format_html=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.format_javadoc_comments=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.format_line_comments=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.format_source_code=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.indent_parameter_description=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.indent_root_tags=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.insert_new_line_before_root_tags=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.insert_new_line_for_parameter=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.comment.line_length=80 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.compact_else_if=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.continuation_indentation=2 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.continuation_indentation_for_array_initializer=2 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.continuation_indentation_for_objlit_initializer=1 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.format_guardian_clause_on_one_line=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.indent_body_declarations_compare_to_annotation_declaration_header=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.indent_body_declarations_compare_to_enum_constant_header=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.indent_body_declarations_compare_to_enum_declaration_header=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.indent_body_declarations_compare_to_type_header=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.indent_breaks_compare_to_cases=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.indent_empty_lines=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.indent_statements_compare_to_block=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.indent_statements_compare_to_body=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.indent_switchstatements_compare_to_cases=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.indent_switchstatements_compare_to_switch=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.indentation.size=4 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_after_annotation=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_after_comma_in_objlit_initializer=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_after_opening_brace_in_array_initializer=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_after_opening_brace_in_objlit_initializer=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_at_end_of_file_if_missing=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_before_catch_in_try_statement=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_before_closing_brace_in_array_initializer=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_before_closing_brace_in_objlit_initializer=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_before_else_in_if_statement=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_before_finally_in_try_statement=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_before_while_in_do_statement=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_in_empty_annotation_declaration=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_in_empty_anonymous_type_declaration=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_in_empty_block=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_in_empty_enum_constant=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_in_empty_enum_declaration=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_in_empty_method_body=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_new_line_in_empty_type_declaration=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_and_in_type_parameter=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_assignment_operator=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_at_in_annotation=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_at_in_annotation_type_declaration=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_binary_operator=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_closing_angle_bracket_in_type_arguments=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_closing_angle_bracket_in_type_parameters=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_closing_brace_in_block=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_closing_paren_in_cast=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_colon_in_assert=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_colon_in_case=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_colon_in_conditional=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_colon_in_for=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_colon_in_labeled_statement=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_allocation_expression=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_annotation=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_array_initializer=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_constructor_declaration_parameters=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_constructor_declaration_throws=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_enum_constant_arguments=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_enum_declarations=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_explicitconstructorcall_arguments=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_for_increments=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_for_inits=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_method_declaration_parameters=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_method_declaration_throws=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_method_invocation_arguments=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_multiple_field_declarations=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_multiple_local_declarations=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_parameterized_type_reference=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_superinterfaces=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_type_arguments=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_comma_in_type_parameters=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_ellipsis=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_angle_bracket_in_parameterized_type_reference=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_angle_bracket_in_type_arguments=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_angle_bracket_in_type_parameters=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_brace_in_array_initializer=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_bracket_in_array_allocation_expression=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_bracket_in_array_reference=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_annotation=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_cast=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_catch=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_constructor_declaration=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_enum_constant=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_for=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_if=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_method_declaration=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_method_invocation=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_parenthesized_expression=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_switch=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_synchronized=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_opening_paren_in_while=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_postfix_operator=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_prefix_operator=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_question_in_conditional=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_question_in_wildcard=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_semicolon_in_for=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_after_unary_operator=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_and_in_type_parameter=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_assignment_operator=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_at_in_annotation_type_declaration=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_binary_operator=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_angle_bracket_in_parameterized_type_reference=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_angle_bracket_in_type_arguments=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_angle_bracket_in_type_parameters=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_brace_in_array_initializer=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_bracket_in_array_allocation_expression=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_bracket_in_array_reference=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_annotation=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_cast=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_catch=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_constructor_declaration=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_enum_constant=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_for=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_if=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_method_declaration=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_method_invocation=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_parenthesized_expression=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_switch=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_synchronized=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_closing_paren_in_while=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_colon_in_assert=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_colon_in_case=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_colon_in_conditional=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_colon_in_default=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_colon_in_for=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_colon_in_labeled_statement=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_allocation_expression=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_annotation=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_array_initializer=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_constructor_declaration_parameters=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_constructor_declaration_throws=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_enum_constant_arguments=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_enum_declarations=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_explicitconstructorcall_arguments=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_for_increments=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_for_inits=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_method_declaration_parameters=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_method_declaration_throws=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_method_invocation_arguments=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_multiple_field_declarations=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_multiple_local_declarations=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_parameterized_type_reference=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_superinterfaces=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_type_arguments=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_comma_in_type_parameters=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_ellipsis=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_angle_bracket_in_parameterized_type_reference=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_angle_bracket_in_type_arguments=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_angle_bracket_in_type_parameters=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_brace_in_annotation_type_declaration=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_brace_in_anonymous_type_declaration=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_brace_in_array_initializer=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_brace_in_block=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_brace_in_constructor_declaration=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_brace_in_enum_constant=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_brace_in_enum_declaration=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_brace_in_method_declaration=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_brace_in_switch=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_brace_in_type_declaration=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_bracket_in_array_allocation_expression=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_bracket_in_array_reference=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_bracket_in_array_type_reference=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_annotation=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_annotation_type_member_declaration=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_catch=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_constructor_declaration=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_enum_constant=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_for=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_if=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_method_declaration=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_method_invocation=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_parenthesized_expression=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_switch=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_synchronized=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_opening_paren_in_while=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_parenthesized_expression_in_return=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_parenthesized_expression_in_throw=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_postfix_operator=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_prefix_operator=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_question_in_conditional=insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_question_in_wildcard=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_semicolon=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_semicolon_in_for=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_before_unary_operator=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_between_brackets_in_array_type_reference=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_between_empty_braces_in_array_initializer=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_between_empty_brackets_in_array_allocation_expression=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_between_empty_parens_in_annotation_type_member_declaration=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_between_empty_parens_in_constructor_declaration=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_between_empty_parens_in_enum_constant=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_between_empty_parens_in_method_declaration=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.insert_space_between_empty_parens_in_method_invocation=do not insert |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.keep_else_statement_on_same_line=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.keep_empty_array_initializer_on_one_line=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.keep_empty_objlit_initializer_on_one_line=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.keep_imple_if_on_one_line=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.keep_then_statement_on_same_line=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.lineSplit=80 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.never_indent_block_comments_on_first_column=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.never_indent_line_comments_on_first_column=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.number_of_blank_lines_at_beginning_of_method_body=0 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.number_of_empty_lines_to_preserve=1 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.put_empty_statement_on_new_line=true |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.tabulation.char=space |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.tabulation.size=4 |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.use_tabs_only_for_leading_indentations=false |  | ||||||
| org.eclipse.wst.jsdt.core.formatter.wrap_before_binary_operator=true |  | ||||||
| @@ -1,10 +0,0 @@ | |||||||
| #Fri Nov 28 14:39:12 EST 2008 |  | ||||||
| eclipse.preferences.version=1 |  | ||||||
| formatter_profile=_gjs |  | ||||||
| formatter_settings_version=11 |  | ||||||
| org.eclipse.wst.jsdt.ui.exception.name=e |  | ||||||
| org.eclipse.wst.jsdt.ui.gettersetter.use.is=true |  | ||||||
| org.eclipse.wst.jsdt.ui.javadoc=false |  | ||||||
| org.eclipse.wst.jsdt.ui.keywordthis=false |  | ||||||
| org.eclipse.wst.jsdt.ui.overrideannotation=true |  | ||||||
| org.eclipse.wst.jsdt.ui.text.custom_code_templates=<?xml version\="1.0" encoding\="UTF-8" standalone\="no"?><templates/> |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| org.eclipse.wst.jsdt.launching.baseBrowserLibrary |  | ||||||
| @@ -1 +0,0 @@ | |||||||
| Window |  | ||||||
							
								
								
									
										93
									
								
								HACKING.md
									
									
									
									
									
								
							
							
						
						| @@ -80,10 +80,7 @@ e.g. `imports.ui.popupMenu`. | |||||||
| Each import block should be sorted alphabetically. Don't import modules you | Each import block should be sorted alphabetically. Don't import modules you | ||||||
| don't use. | don't use. | ||||||
| ```javascript | ```javascript | ||||||
|     const GLib = imports.gi.GLib; |     const { GLib, Gio, St } = imports.gi; | ||||||
|     const Gio = imports.gi.Gio; |  | ||||||
|     const Lang = imports.lang; |  | ||||||
|     const St = imports.gi.St; |  | ||||||
|  |  | ||||||
|     const Main = imports.ui.main; |     const Main = imports.ui.main; | ||||||
|     const Params = imports.misc.params; |     const Params = imports.misc.params; | ||||||
| @@ -121,40 +118,34 @@ See [What's new in JavaScript 1.7](https://developer.mozilla.org/en/JavaScript/N | |||||||
|  |  | ||||||
| ## Classes | ## Classes | ||||||
|  |  | ||||||
| There are many approaches to classes in JavaScript. We use our own class framework | There are many approaches to classes in JavaScript. We use standard ES6 classes | ||||||
| (sigh), which is built in gjs. The advantage is that it supports inheriting from | whenever possible, that is when not inheriting from GObjects. | ||||||
| GObjects, although this feature isn't used very often in the Shell itself. |  | ||||||
| ```javascript | ```javascript | ||||||
|     var IconLabelMenuItem = new Lang.Class({ |     var IconLabelMenuItem = class extends PopupMenu.PopupMenuBaseItem { | ||||||
|         Name: 'IconLabelMenuItem', |         constructor(icon, label) { | ||||||
|         Extends: PopupMenu.PopupMenuBaseItem, |             super({ reactive: false }); | ||||||
|  |  | ||||||
|         _init(icon, label) { |  | ||||||
|             this.parent({ reactive: false }); |  | ||||||
|             this.actor.add_child(icon); |             this.actor.add_child(icon); | ||||||
|             this.actor.add_child(label); |             this.actor.add_child(label); | ||||||
|         }, |         } | ||||||
|  |  | ||||||
|         open() { |         open() { | ||||||
|             log("menu opened!"); |             log("menu opened!"); | ||||||
|         } |         } | ||||||
|     }); |     }; | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| * 'Name' is required. 'Extends' is optional. If you leave it out, you will | For GObject inheritence, we use the GObject.registerClass() function provided | ||||||
|   automatically inherit from Object. | by gjs. | ||||||
|  | ```javascript | ||||||
|  |     var MyActor = GObject.registerClass( | ||||||
|  |     class MyActor extends Clutter.Actor { | ||||||
|  |         _init(params) { | ||||||
|  |             super._init(params); | ||||||
|  |  | ||||||
| * Leave a blank line between the "class header" (Name, Extends, and other |             this.name = 'MyCustomActor'; | ||||||
|   things)  and the "class body" (methods). Leave a blank line between each |         } | ||||||
|   method. |     }); | ||||||
|  | ``` | ||||||
| * No space before the colon, one space after. |  | ||||||
|  |  | ||||||
| * No trailing comma after the last item. |  | ||||||
|  |  | ||||||
| * Make sure to use a semicolon after the closing paren to the class. It's |  | ||||||
|   still a giant function call, even though it may resemble a more |  | ||||||
|   conventional syntax. |  | ||||||
|  |  | ||||||
| ## GObject Introspection | ## GObject Introspection | ||||||
|  |  | ||||||
| @@ -162,19 +153,18 @@ GObject Introspection is a powerful feature that allows us to have native | |||||||
| bindings for almost any library built around GObject. If a library requires | bindings for almost any library built around GObject. If a library requires | ||||||
| you to inherit from a type to use it, you can do so: | you to inherit from a type to use it, you can do so: | ||||||
| ```javascript | ```javascript | ||||||
|     var MyClutterActor = new Lang.Class({ |     var MyClutterActor = GObject.registerClass( | ||||||
|         Name: 'MyClutterActor', |     class MyClutterActor extends Clutter.Actor { | ||||||
|         Extends: Clutter.Actor, |  | ||||||
|  |  | ||||||
|         vfunc_get_preferred_width(actor, forHeight) { |         vfunc_get_preferred_width(forHeight) { | ||||||
|              return [100, 100]; |              return [100, 100]; | ||||||
|         }, |         } | ||||||
|  |  | ||||||
|         vfunc_get_preferred_height(actor, forWidth) { |         vfunc_get_preferred_height(forWidth) { | ||||||
|              return [100, 100]; |              return [100, 100]; | ||||||
|         }, |         } | ||||||
|  |  | ||||||
|         vfunc_paint(actor) { |         vfunc_paint() { | ||||||
|              let alloc = this.get_allocation_box(); |              let alloc = this.get_allocation_box(); | ||||||
|              Cogl.set_source_color4ub(255, 0, 0, 255); |              Cogl.set_source_color4ub(255, 0, 0, 255); | ||||||
|              Cogl.rectangle(alloc.x1, alloc.y1, |              Cogl.rectangle(alloc.x1, alloc.y1, | ||||||
| @@ -207,20 +197,18 @@ that has a property called `actor`. We call this wrapper class the "delegate". | |||||||
| We sometimes use expando properties to set a property called `_delegate` on | We sometimes use expando properties to set a property called `_delegate` on | ||||||
| the actor itself: | the actor itself: | ||||||
| ```javascript | ```javascript | ||||||
|     var MyClass = new Lang.Class({ |     var MyClass = class { | ||||||
|         Name: 'MyClass', |         constructor() { | ||||||
|  |  | ||||||
|         _init() { |  | ||||||
|             this.actor = new St.Button({ text: "This is a button" }); |             this.actor = new St.Button({ text: "This is a button" }); | ||||||
|             this.actor._delegate = this; |             this.actor._delegate = this; | ||||||
|  |  | ||||||
|             this.actor.connect('clicked', this._onClicked.bind(this)); |             this.actor.connect('clicked', this._onClicked.bind(this)); | ||||||
|         }, |         } | ||||||
|  |  | ||||||
|         _onClicked(actor) { |         _onClicked(actor) { | ||||||
|             actor.set_label("You clicked the button!"); |             actor.set_label("You clicked the button!"); | ||||||
|         } |         } | ||||||
|     }); |     }; | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| The 'delegate' property is important for anything which trying to get the | The 'delegate' property is important for anything which trying to get the | ||||||
| @@ -246,8 +234,6 @@ variable that can be captured in closures. | |||||||
| All closures should be wrapped with Function.prototype.bind or use arrow | All closures should be wrapped with Function.prototype.bind or use arrow | ||||||
| notation. | notation. | ||||||
| ```javascript | ```javascript | ||||||
|     const Lang = imports.lang; |  | ||||||
|  |  | ||||||
|     let closure1 = () => { this._fnorbate(); }; |     let closure1 = () => { this._fnorbate(); }; | ||||||
|     let closure2 = this._fnorbate.bind(this); |     let closure2 = this._fnorbate.bind(this); | ||||||
| ``` | ``` | ||||||
| @@ -255,19 +241,18 @@ notation. | |||||||
| A more realistic example would be connecting to a signal on a method of a | A more realistic example would be connecting to a signal on a method of a | ||||||
| prototype: | prototype: | ||||||
| ```javascript | ```javascript | ||||||
|     const Lang = imports.lang; |  | ||||||
|     const FnorbLib = imports.fborbLib; |     const FnorbLib = imports.fborbLib; | ||||||
|  |  | ||||||
|     var MyClass = new Lang.Class({ |     var MyClass = class { | ||||||
|         _init() { |         _init() { | ||||||
|             let fnorb = new FnorbLib.Fnorb(); |             let fnorb = new FnorbLib.Fnorb(); | ||||||
|             fnorb.connect('frobate', this._onFnorbFrobate.bind(this)); |             fnorb.connect('frobate', this._onFnorbFrobate.bind(this)); | ||||||
|         }, |         } | ||||||
|  |  | ||||||
|         _onFnorbFrobate(fnorb) { |         _onFnorbFrobate(fnorb) { | ||||||
|             this._updateFnorb(); |             this._updateFnorb(); | ||||||
|         } |         } | ||||||
|     }); |     }; | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| ## Object literal syntax | ## Object literal syntax | ||||||
| @@ -301,23 +286,21 @@ property. | |||||||
| ```javascript | ```javascript | ||||||
|     var ANIMATION_TIME = 2000; |     var ANIMATION_TIME = 2000; | ||||||
|  |  | ||||||
|     var MyClass = new Lang.Class({ |     var MyClass = class { | ||||||
|         Name: 'MyClass', |         constructor() { | ||||||
|  |  | ||||||
|         _init() { |  | ||||||
|             this.actor = new St.BoxLayout(); |             this.actor = new St.BoxLayout(); | ||||||
|             this._position = 0; |             this._position = 0; | ||||||
|         }, |         } | ||||||
|  |  | ||||||
|         get position() { |         get position() { | ||||||
|             return this._position; |             return this._position; | ||||||
|         }, |         } | ||||||
|  |  | ||||||
|         set position(value) { |         set position(value) { | ||||||
|             this._position = value; |             this._position = value; | ||||||
|             this.actor.set_position(value, value); |             this.actor.set_position(value, value); | ||||||
|         } |         } | ||||||
|     }); |     }; | ||||||
|  |  | ||||||
|     let myThing = new MyClass(); |     let myThing = new MyClass(); | ||||||
|     Tweener.addTween(myThing, |     Tweener.addTween(myThing, | ||||||
|   | |||||||
							
								
								
									
										220
									
								
								NEWS
									
									
									
									
									
								
							
							
						
						| @@ -1,3 +1,223 @@ | |||||||
|  | 3.33.3 | ||||||
|  | ====== | ||||||
|  | * Prepare for optional X11 [Carlos; !378] | ||||||
|  | * Fix opening window menu [Marco; !557] | ||||||
|  | * Reload search providers when installed applications change [Cosimo; !562] | ||||||
|  | * Implement locate-pointer accessibility feature [Olivier; #981] | ||||||
|  | * Allow to disable window menus via session mode [Cosimo; !569] | ||||||
|  | * Implement mouse accessibility [Olivier; !474] | ||||||
|  | * Call GDM's RegisterSession() after startup [Iain; !570] | ||||||
|  | * Fix extended keys popups being hidden by on-screen keyboard [Marco; !583] | ||||||
|  | * Fix top bar being hidden by lock screen [Jonas; !571] | ||||||
|  | * Update theme to better match GTK's Adwaita [Frederik; #841] | ||||||
|  | * Set up GJS profiler when GJS_TRACE_FD is set [Christian; !573] | ||||||
|  | * Misc. bug fixes and cleanups [Jonas, Cosimo, Robert, Florian, Marco, Simon, | ||||||
|  |   Laurent, Niels, Will; !551, !555, !464, #1333, !565, !572, !568, !558, #1205, | ||||||
|  |   #1336, !579, !576, #1392, !582, !586, #1406, #1351] | ||||||
|  |  | ||||||
|  | Contributors: | ||||||
|  |   Laurent Bigonville, Cosimo Cecchi, Piotr Drąg, Jonas Dreßler, | ||||||
|  |   Frederik Feichtmeier, Olivier Fourdan, Carlos Garnacho, Niels De Graef, | ||||||
|  |   Christian Hergert, Iain Lane, Robert Mader, Florian Müllner, Simon Schampijer, | ||||||
|  |   Jakub Steiner, Will Thompson, Marco Trevisan (Treviño) | ||||||
|  |  | ||||||
|  | Translators: | ||||||
|  |   Kukuh Syafaat [id], Balázs Meskó [hu], Daniel Mustieles [es], | ||||||
|  |   Fabio Tomat [fur], Nathan Follens [nl], Goran Vidović [hr], Jordi Mas [ca] | ||||||
|  |  | ||||||
|  | 3.33.2 | ||||||
|  | ====== | ||||||
|  | * Fix keeping actors visible in scrollviews [Marco; #1061] | ||||||
|  | * Move some chrome above popup windows [Jonas D.; !358] | ||||||
|  | * Include 'sandboxed-app-id' in winodw introspection info [Florian; #1289] | ||||||
|  | * Port to libecal-2.0 [Milan; !501] | ||||||
|  | * Support TCRYPT in mount password dialog [segfault; !126] | ||||||
|  | * Misc. bug fixes and cleanups [Florian, Marco, Veerasamy; !517, #745, !499, | ||||||
|  |   !510, !515, !546, !549] | ||||||
|  |  | ||||||
|  | Contributors: | ||||||
|  |   Cosimo Cecchi, Milan Crha, Jonas Dreßler, Florian Müllner, segfault, | ||||||
|  |   Veerasamy Sevagen, Marco Trevisan (Treviño) | ||||||
|  |  | ||||||
|  | Translators: | ||||||
|  |   Daniel Mustieles [es] | ||||||
|  |  | ||||||
|  | 3.33.1 | ||||||
|  | ====== | ||||||
|  | * Refine the app menu [Florian; #968] | ||||||
|  | * Refine window preview style [Feichtmeier; !461] | ||||||
|  | * Only emit ::style-changed on actual changes [Carlos; #1153] | ||||||
|  | * Disable emoji on-screen keyboard support on X11 [Florian; #1172] | ||||||
|  | * Fix tablet button mapping overlay [Carlos; #1220] | ||||||
|  | * Don't crash for world clock locations with no timezone [Florian; #1062] | ||||||
|  | * Don't leak old on-screen keyboard layout groups [Carlos; mutter#556] | ||||||
|  | * Fix ellipsization in dialog subtitles/bodies [Marco; !531] | ||||||
|  | * Fix glitch of fullscreen window in workspace switch animation [Jonas D.; !322] | ||||||
|  | * Fix distortion of some image contents [Florian; !525] | ||||||
|  | * Allow dragging unfocused tiled/maximized windows from top bar [Dylan; #679290] | ||||||
|  | * Handle network interface name changes [Fabrice; !534] | ||||||
|  | * Avoid unnecessary style changes when computing :first/:last-child | ||||||
|  |   [Florian; !529] | ||||||
|  | * Misc. bug fixes and cleanups [Florian, Marco, Robert, Georges, Carlos, Simon, | ||||||
|  |   Jonas D.; !487, !441, !502, !503, !504, !506, #822, !551, !512, !509, !511, | ||||||
|  |   #1054, !524, #1065, !331, !540] | ||||||
|  |  | ||||||
|  | Contributors: | ||||||
|  |   Fabrice Bellet, Jonas Dreßler, Feichtmeier, Carlos Garnacho, Robert Mader, | ||||||
|  |   Dylan McCall, Simon McVittie, Florian Müllner, Georges Basile Stavracas Neto, | ||||||
|  |   Marco Trevisan (Treviño) | ||||||
|  |  | ||||||
|  | Translators: | ||||||
|  |   Daniel Mustieles [es], Kukuh Syafaat [id], Fabio Tomat [fur], | ||||||
|  |   Carmen Bianca BAKKER [eo], Dingzhong Chen [zh_CN], Tim Sabsch [de] | ||||||
|  |  | ||||||
|  | 3.32.1 | ||||||
|  | ====== | ||||||
|  | * Fix avatar scaling on login screen [Florian; #1024] | ||||||
|  | * Fix distortion of desktop zoom [Florian; #646] | ||||||
|  | * Fix mouse cursor visibility when using desktop zoom [Florian, Marco; #1020] | ||||||
|  | * Fix screen dimming after wake-up on lock screen [Xiaoguang; #900] | ||||||
|  | * Fix Alt+Esc switcher [Florian; #1064] | ||||||
|  | * Respect struts for popover placement [Andrea; #1102] | ||||||
|  | * Fix app icons updates after theme changes [Florian; #1117] | ||||||
|  | * Fix desktop zoom after resolution changes [Marco; #1120] | ||||||
|  | * Implement stick-to-finger workspace switch overview gestures [Florian; #516] | ||||||
|  | * Make World Clocks offsets relative to local time [Florian; #1157] | ||||||
|  | * Fix top app icon disappearing from dash [Florian; #1053] | ||||||
|  | * Update switch style to match new Adwaita [Jakub; !496] | ||||||
|  | * Ensure CSS units are pixel-aligned when scaling is used [Carlos; #91] | ||||||
|  | * Misc. bug fixes and cleanups [Florian, Jakub, Robert, Alex, Carlos, Phil, | ||||||
|  |   Marco, Benjamin, AsciiWolf, Ray, verdre; !444, #1016, #1018, !449, #1036, | ||||||
|  |   !455, #1094, !440, #1023, #624, #1017, !476, !473, !480, #1130, !485, !481, | ||||||
|  |   !490, !489, #1151, !435, #1160, !482, #1150, #1166, !384] | ||||||
|  |  | ||||||
|  | Contributors: | ||||||
|  |   AsciiWolf, Andrea Azzarone, Benjamin Berg, Carlos Garnacho, Victor Ibragimov, | ||||||
|  |   Robert Mader, Alex Monday, Florian Müllner, Jakub Steiner, Ray Strode, | ||||||
|  |   Marco Trevisan (Treviño), verdre, Xiaoguang Wang, Phil Wyett | ||||||
|  |  | ||||||
|  | Translators: | ||||||
|  |   Victor Ibragimov [tg, af, et, ja], Bruce Cowan [en_GB], Piotr Drąg [tg], | ||||||
|  |   Charles Monzat [fr], Khaled Hosny [ar], Goran Vidović [hr], | ||||||
|  |   Cheng-Chia Tseng [zh_TW], Carmen Bianca BAKKER [eo], Daniel Mustieles [es], | ||||||
|  |   Dušan Kazik [sk] | ||||||
|  |  | ||||||
|  | 3.32.0 | ||||||
|  | ====== | ||||||
|  | * Fix sizing issues in on-screen-keyboard emoji panel [Carlos; !439] | ||||||
|  | * Fix test linker failure on Debian/Ubuntu [Iain; !442] | ||||||
|  | * Avoid assertion when sizing fallback app icons from CSS [Florian; #1027] | ||||||
|  | * Fix mis-sized menu arrows after texture cache changes [Florian; !452] | ||||||
|  |  | ||||||
|  | Contributors: | ||||||
|  |   Carlos Garnacho, Iain Lane, Florian Müllner | ||||||
|  |  | ||||||
|  | Translators: | ||||||
|  |   Gábor Kelemen [hu], Victor Ibragimov [tg], Ryuta Fujii [ja], Piotr Drąg [af, | ||||||
|  |   tg], Mart Raudsepp [et] | ||||||
|  |  | ||||||
|  | 3.31.92 | ||||||
|  | ======= | ||||||
|  | * Fix visual glitch in submenus [Alex; #987] | ||||||
|  | * Support fractional scaling [Jonas, Marco; #765011, !5] | ||||||
|  | * Only consider visible children for :first-child/:last-child [Florian; !312] | ||||||
|  | * Hide trailing separator in search results [verdre; !311] | ||||||
|  | * Remember choice in inhibit-shortcuts dialogue [Olivier; !382] | ||||||
|  | * Don't toggle on-screen keyboard on every focus change [Carlos; !397] | ||||||
|  | * Fix legacy tray icons not responding to events on wayland [Florian; #191] | ||||||
|  | * Fix generating French OSK layout [Florian; #997] | ||||||
|  | * Use borderless round user images [Florian; #811] | ||||||
|  | * Misc. bug fixes and cleanups [Andrea, Robert, Florian, Marco, Niels, | ||||||
|  |   Benjamin; !414, !417, !420, #996, !408, !422, !425, #1006, !427, !315, | ||||||
|  |   #989, !430, !431, !432, #1015, !429, !423, !419, !434] | ||||||
|  |  | ||||||
|  | Contributors: | ||||||
|  |   Jonas Ådahl, Alan, Andrea Azzarone, Benjamin Berg, Olivier Fourdan, | ||||||
|  |   Carlos Garnacho, Niels De Graef, Robert Mader, Alex Monday, Florian Müllner, | ||||||
|  |   Marco Trevisan (Treviño), verdre | ||||||
|  |  | ||||||
|  | Translators: | ||||||
|  |   Carmen Bianca BAKKER [eo], Asier Sarasua Garmendia [eu], Stas Solovey [ru], | ||||||
|  |   Changwoo Ryu [ko], Julien Humbert [fr], Milo Casagrande [it], | ||||||
|  |   Марко Костић [sr], Ask Hjorth Larsen [da], Kukuh Syafaat [id], | ||||||
|  |   Daniel Șerbănescu [ro], Bernd Homuth [de], Trần Ngọc Quân [vi], | ||||||
|  |   Nathan Follens [nl], Rūdolfs Mazurs [lv], Aurimas Černius [lt] | ||||||
|  |  | ||||||
|  | 3.31.91 | ||||||
|  | ======= | ||||||
|  | * Don't close on-screen-keyboard's language menu on hover [Florian; #171] | ||||||
|  | * Don't let unfullscreen gesture interfere with top bar taps [Jonas D.; #552] | ||||||
|  | * Always use symbolic user icon in system menu [Florian; #957] | ||||||
|  | * Add flags parameter in GrabAccelerators API [Andrea; #68] | ||||||
|  | * Misc. bug fixes and cleanups [Florian, Jonas A.; !399, !398, !400, !402, | ||||||
|  |   !407, !410, !411] | ||||||
|  |  | ||||||
|  | Contributors: | ||||||
|  |   Jonas Ådahl, Andrea Azzarone, Arnaud Bonatti, Jonas Dreßler, Florian Müllner | ||||||
|  |  | ||||||
|  | Translators: | ||||||
|  |   Jordi Mas [ca], Ryuta Fujii [ja], Marek Cernocky [cs], Fran Dieguez [gl], | ||||||
|  |   Jiri Grönroos [fi], Serdar Sağlam [tr], Anders Jonsson [sv], | ||||||
|  |   Matej Urbančič [sl], Gun Chleoc [gd], Kukuh Syafaat [id], | ||||||
|  |   Baurzhan Muftakhidinov [kk], Alan Mortensen [da], Rafael Fontenelle [pt_BR], | ||||||
|  |   Sveinn í Felli [is] | ||||||
|  |  | ||||||
|  | 3.31.90 | ||||||
|  | ======= | ||||||
|  | * Fix input methods after ibus restarts [Takao; #295] | ||||||
|  | * Refresh world clocks and weather sections [Florian; #262] | ||||||
|  | * Port to ES6 classes (update your extensions!) [Florian; !361] | ||||||
|  | * networkAgent: Advise users when WPS support is available [Lubomir; !329] | ||||||
|  | * Performance improvements [Carlos; #832, #815] | ||||||
|  | * Fix drag-and-drop with wacom pens [Carlos; #540] | ||||||
|  | * Fix CAPS LOCK indication on wayland [Carlos; #762881] | ||||||
|  | * Show details of non-sensitive notifications on lock screen [Philip; #726] | ||||||
|  | * Refine extension-prefs' error UI [Florian; !193] | ||||||
|  | * Add switch-to-application-n keybindings [Florian; #648000] | ||||||
|  | * Remove top bar translucency [Florian; #408] | ||||||
|  | * Support emojis and keypads in on-screen keyboard [Carlos; #675] | ||||||
|  | * Don't allow popups to re-enable keyboard shortcuts on lock screen | ||||||
|  |   (CVE-2019-3820) [Florian, Ray; #851] | ||||||
|  | * Replace app menu [Florian; #624] | ||||||
|  | * Include commonly copied+pasted extension helpers [Florian; !150] | ||||||
|  | * Misc. bug fixes and cleanups [Florian, Daniel, Philip, Sergio, Pascal, | ||||||
|  |   Georges, verdre, Carlos, Christopher; #780, #909, !316, !308, !309, #915, | ||||||
|  |   !350, !362, !357, !365, !366, !283, !367, #942, !371, !373, !374, !343, | ||||||
|  |   !375, !292, !317, !377, !379, !346, !383, #953, !388] | ||||||
|  |  | ||||||
|  | Contributors: | ||||||
|  |   Sergio Costas, Christopher Davis, Bilal Elmoussaoui, Takao Fujiwara, | ||||||
|  |   Carlos Garnacho, Niels De Graef, Christian Kellner, Ignat Loskutov, | ||||||
|  |   Florian Müllner, Georges Basile Stavracas Neto, Pascal Nowack, Lubomir Rintel, | ||||||
|  |   Jakub Steiner, Ray Strode, verdre, Daniel van Vugt, Philip Withnall | ||||||
|  |  | ||||||
|  | Translators: | ||||||
|  |   Daniel Mustieles [es], Carmen Bianca BAKKER [eo], Charles Monzat [fr], | ||||||
|  |   Pieter Schalk Schoeman [af], Jordi Mas [ca], Matej Urbančič [sl], | ||||||
|  |   Fran Dieguez [gl], Balázs Úr [hu], A S Alam [pa], Fabio Tomat [fur], | ||||||
|  |   Aurimas Černius [lt], Piotr Drąg [pl], Marek Cernocky [cs], Ryuta Fujii [ja] | ||||||
|  |  | ||||||
|  | 3.31.4 | ||||||
|  | ====== | ||||||
|  | * Improve icon grid performance [Daniel; #174] | ||||||
|  | * Remove browser plugin [Michael; #766776] | ||||||
|  | * Add DBus API for introspecting the application state [Jonas, Olivier; !326] | ||||||
|  | * Always allow leaving the overview via the hot-corner [Pascal; #429] | ||||||
|  | * Misc. bug fixes [Florian, Jasper, Andrea, Sam, Dani, Cosimo, Jonas, Carlos; | ||||||
|  |   #643595, #673767, !293, #783, #781, !298, !297, #782, !301, !314, !305, #799, | ||||||
|  |   #632, !327] | ||||||
|  |  | ||||||
|  | Contributors: | ||||||
|  |   Jonas Ådahl, Andrea Azzarone, Michael Catanzaro, Cosimo Cecchi, daniruiz, | ||||||
|  |   Olivier Fourdan, Carlos Garnacho, Sam Hewitt, Andre Klapper, Florian Müllner, | ||||||
|  |   Pascal Nowack, Jasper St. Pierre, RyuzakiKK, Marco Trevisan (Treviño), | ||||||
|  |   João Paulo Rechi Vita, Daniel van Vugt | ||||||
|  |  | ||||||
|  | Translators: | ||||||
|  |   Kristjan SCHMIDT [eo], Matej Urbančič [sl], Daniel Mustieles [es], | ||||||
|  |   Fabio Tomat [fur], Emin Tufan Çetin [tr], Anders Jonsson [sv], | ||||||
|  |   Ryuta Fujii [ja] | ||||||
|  |  | ||||||
| 3.31.2 | 3.31.2 | ||||||
| ====== | ====== | ||||||
| * Port away from and remove ShellGenericContainer [Georges; !153] | * Port away from and remove ShellGenericContainer [Georges; !153] | ||||||
|   | |||||||
| @@ -11,6 +11,14 @@ see the [project wiki][project-wiki]. | |||||||
|  |  | ||||||
| Bugs should be reported to the GNOME [bug tracking system][bug-tracker]. | Bugs should be reported to the GNOME [bug tracking system][bug-tracker]. | ||||||
|  |  | ||||||
|  | ## Contributing | ||||||
|  |  | ||||||
|  | To contribute, open merge requests at https://gitlab.gnome.org/GNOME/gnome-shell. | ||||||
|  |  | ||||||
|  | Commit messages should follow the [GNOME commit message | ||||||
|  | guidelines](https://wiki.gnome.org/Git/CommitMessages). We require an URL | ||||||
|  | to either an issue or a merge request in each commit. | ||||||
|  |  | ||||||
| ## License | ## License | ||||||
| GNOME Shell is distributed under the terms of the GNU General Public License, | GNOME Shell is distributed under the terms of the GNU General Public License, | ||||||
| version 2 or later. See the [COPYING][license] file for details. | version 2 or later. See the [COPYING][license] file for details. | ||||||
|   | |||||||
							
								
								
									
										40
									
								
								README.mdwn
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,40 @@ | |||||||
|  | cldr2json | ||||||
|  | ========= | ||||||
|  |  | ||||||
|  | This script converts Unicode CLDR android keyboard layouts to JSON usable by | ||||||
|  | GNOME Shell. | ||||||
|  |  | ||||||
|  | CLDR keyboard layouts can be found at | ||||||
|  | <http://www.unicode.org/Public/cldr/latest/keyboards.zip> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Usage | ||||||
|  | ===== | ||||||
|  |  | ||||||
|  |     ./cldr2json <input file or directory> <output directory> | ||||||
|  |  | ||||||
|  | example: | ||||||
|  |  | ||||||
|  |     ./cldr2json cldr/keyboards/android/ json_layouts/ | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Keyboard layout mapping | ||||||
|  | ======================= | ||||||
|  |  | ||||||
|  | Unicode CLDR layout identifiers are language codes, while XKB layout | ||||||
|  | identifiers are... something else. The mapping between the two currently uses | ||||||
|  | heuristic based on the layout descriptions, in this order: | ||||||
|  |  | ||||||
|  | - if the CLDR layout description matches an XKB layout description, chose its | ||||||
|  |   XKB identifier | ||||||
|  | - if one word of the CLDR layout description matches an XKB layout | ||||||
|  |   description, chose its XKB identifier | ||||||
|  | - if the CLDR layout description matches one word of an XKB layout description, | ||||||
|  |   chose its XKB identifier | ||||||
|  |  | ||||||
|  | That doesn't always work. For instance it fails for "en" language, that should | ||||||
|  | match "us" XKB identifier. For such cases, there is a mapping in | ||||||
|  | LOCALE_TO_XKB_OVERRIDES at the top of the script. If you discover a weird | ||||||
|  | mapping of if you get a "failed to find XKB mapping for <locale>" warning then | ||||||
|  | please consider adding an override there. | ||||||
|  |  | ||||||
| @@ -1,17 +0,0 @@ | |||||||
| The GNOME Shell Browser Plugin provides integration with gnome-shell and the |  | ||||||
| corresponding extensions repository, codenamed "SweetTooth". The plugin allows |  | ||||||
| the extensions repository to provide good integration, letting the website |  | ||||||
| know which extensions are enabled and disabled, and allowing the website to |  | ||||||
| enable, disable and install them. |  | ||||||
|  |  | ||||||
| Bugs should be reported to the GNOME [bug tracking system][bug-tracker]. |  | ||||||
|  |  | ||||||
| ## License |  | ||||||
| The GNOME Shell Browser Plugin, like GNOME Shell itself is distributed under |  | ||||||
| the GNU General Public License, version 2 or later. The plugin also contains |  | ||||||
| header files from the "NPAPI SDK" project, tri-licensed under MPL 1.1, GPL 2.0 |  | ||||||
| and LGPL 2.1. These headers are third-party sources and can be retrieved from: |  | ||||||
|  |  | ||||||
|   http://code.google.com/p/npapi-sdk/ |  | ||||||
|  |  | ||||||
| [bug-tracker]: https://gitlab.gnome.org/GNOME/gnome-shell/issues |  | ||||||
| @@ -1,19 +0,0 @@ | |||||||
| plugin_sources = [ |  | ||||||
|   'browser-plugin.c', |  | ||||||
|   'npapi/npapi.h', |  | ||||||
|   'npapi/npfunctions.h', |  | ||||||
|   'npapi/npruntime.h', |  | ||||||
|   'npapi/nptypes.h' |  | ||||||
| ] |  | ||||||
|  |  | ||||||
| shared_module('gnome-shell-browser-plugin', plugin_sources, |  | ||||||
|   dependencies: [gio_dep, json_glib_dep], |  | ||||||
|   c_args: ['-DG_LOG_DOMAIN="GnomeShellBrowserPlugin"'], |  | ||||||
|   # Browsers can unload and reload the module while browsing, which is not |  | ||||||
|   # supported by GObject. |  | ||||||
|   # We pass -Wl,-z,nodelete to the linker to ensure the module is never |  | ||||||
|   # unloaded. See https://bugzilla.gnome.org/show_bug.cgi?id=737932. |  | ||||||
|   link_args: ['-Wl,-z,nodelete'], |  | ||||||
|   install: true, |  | ||||||
|   install_dir: plugindir |  | ||||||
| ) |  | ||||||
| @@ -1,893 +0,0 @@ | |||||||
| /* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ |  | ||||||
| /* ***** BEGIN LICENSE BLOCK ***** |  | ||||||
|  * Version: MPL 1.1/GPL 2.0/LGPL 2.1 |  | ||||||
|  * |  | ||||||
|  * The contents of this file are subject to the Mozilla Public License Version |  | ||||||
|  * 1.1 (the "License"); you may not use this file except in compliance with |  | ||||||
|  * the License. You may obtain a copy of the License at |  | ||||||
|  * http://www.mozilla.org/MPL/ |  | ||||||
|  * |  | ||||||
|  * Software distributed under the License is distributed on an "AS IS" basis, |  | ||||||
|  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License |  | ||||||
|  * for the specific language governing rights and limitations under the |  | ||||||
|  * License. |  | ||||||
|  * |  | ||||||
|  * The Original Code is mozilla.org code. |  | ||||||
|  * |  | ||||||
|  * The Initial Developer of the Original Code is |  | ||||||
|  * Netscape Communications Corporation. |  | ||||||
|  * Portions created by the Initial Developer are Copyright (C) 1998 |  | ||||||
|  * the Initial Developer. All Rights Reserved. |  | ||||||
|  * |  | ||||||
|  * Contributor(s): |  | ||||||
|  * |  | ||||||
|  * Alternatively, the contents of this file may be used under the terms of |  | ||||||
|  * either the GNU General Public License Version 2 or later (the "GPL"), or |  | ||||||
|  * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), |  | ||||||
|  * in which case the provisions of the GPL or the LGPL are applicable instead |  | ||||||
|  * of those above. If you wish to allow use of your version of this file only |  | ||||||
|  * under the terms of either the GPL or the LGPL, and not to allow others to |  | ||||||
|  * use your version of this file under the terms of the MPL, indicate your |  | ||||||
|  * decision by deleting the provisions above and replace them with the notice |  | ||||||
|  * and other provisions required by the GPL or the LGPL. If you do not delete |  | ||||||
|  * the provisions above, a recipient may use your version of this file under |  | ||||||
|  * the terms of any one of the MPL, the GPL or the LGPL. |  | ||||||
|  * |  | ||||||
|  * ***** END LICENSE BLOCK ***** */ |  | ||||||
|  |  | ||||||
| #ifndef npapi_h_ |  | ||||||
| #define npapi_h_ |  | ||||||
|  |  | ||||||
| #if defined(__OS2__) |  | ||||||
| #pragma pack(1) |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #include "nptypes.h" |  | ||||||
|  |  | ||||||
| #if defined(__OS2__) || defined(OS2) |  | ||||||
| #ifndef XP_OS2 |  | ||||||
| #define XP_OS2 1 |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(_WIN32) && !defined(__SYMBIAN32__) |  | ||||||
| #include <windef.h> |  | ||||||
| #ifndef XP_WIN |  | ||||||
| #define XP_WIN 1 |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(__SYMBIAN32__) |  | ||||||
| #ifndef XP_SYMBIAN |  | ||||||
| #define XP_SYMBIAN 1 |  | ||||||
| #undef XP_WIN |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(__APPLE_CC__) && !defined(XP_UNIX) |  | ||||||
| #ifndef XP_MACOSX |  | ||||||
| #define XP_MACOSX 1 |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(XP_MACOSX) && defined(__LP64__) |  | ||||||
| #define NP_NO_QUICKDRAW |  | ||||||
| #define NP_NO_CARBON |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(XP_MACOSX) |  | ||||||
| #include <ApplicationServices/ApplicationServices.h> |  | ||||||
| #include <OpenGL/OpenGL.h> |  | ||||||
| #ifndef NP_NO_CARBON |  | ||||||
| #include <Carbon/Carbon.h> |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(XP_UNIX) |  | ||||||
| #include <stdio.h> |  | ||||||
| #if defined(MOZ_X11) |  | ||||||
| #include <X11/Xlib.h> |  | ||||||
| #include <X11/Xutil.h> |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(XP_SYMBIAN) |  | ||||||
| #include <QEvent> |  | ||||||
| #include <QRegion> |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| /*----------------------------------------------------------------------*/ |  | ||||||
| /*                        Plugin Version Constants                      */ |  | ||||||
| /*----------------------------------------------------------------------*/ |  | ||||||
|  |  | ||||||
| #define NP_VERSION_MAJOR 0 |  | ||||||
| #define NP_VERSION_MINOR 27 |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* The OS/2 version of Netscape uses RC_DATA to define the |  | ||||||
|    mime types, file extensions, etc that are required. |  | ||||||
|    Use a vertical bar to separate types, end types with \0. |  | ||||||
|    FileVersion and ProductVersion are 32bit ints, all other |  | ||||||
|    entries are strings that MUST be terminated with a \0. |  | ||||||
|  |  | ||||||
| AN EXAMPLE: |  | ||||||
|  |  | ||||||
| RCDATA NP_INFO_ProductVersion { 1,0,0,1,} |  | ||||||
|  |  | ||||||
| RCDATA NP_INFO_MIMEType    { "video/x-video|", |  | ||||||
|                              "video/x-flick\0" } |  | ||||||
| RCDATA NP_INFO_FileExtents { "avi|", |  | ||||||
|                              "flc\0" } |  | ||||||
| RCDATA NP_INFO_FileOpenName{ "MMOS2 video player(*.avi)|", |  | ||||||
|                              "MMOS2 Flc/Fli player(*.flc)\0" } |  | ||||||
|  |  | ||||||
| RCDATA NP_INFO_FileVersion       { 1,0,0,1 } |  | ||||||
| RCDATA NP_INFO_CompanyName       { "Netscape Communications\0" } |  | ||||||
| RCDATA NP_INFO_FileDescription   { "NPAVI32 Extension DLL\0" |  | ||||||
| RCDATA NP_INFO_InternalName      { "NPAVI32\0" ) |  | ||||||
| RCDATA NP_INFO_LegalCopyright    { "Copyright Netscape Communications \251 1996\0" |  | ||||||
| RCDATA NP_INFO_OriginalFilename  { "NVAPI32.DLL" } |  | ||||||
| RCDATA NP_INFO_ProductName       { "NPAVI32 Dynamic Link Library\0" } |  | ||||||
| */ |  | ||||||
| /* RC_DATA types for version info - required */ |  | ||||||
| #define NP_INFO_ProductVersion      1 |  | ||||||
| #define NP_INFO_MIMEType            2 |  | ||||||
| #define NP_INFO_FileOpenName        3 |  | ||||||
| #define NP_INFO_FileExtents         4 |  | ||||||
| /* RC_DATA types for version info - used if found */ |  | ||||||
| #define NP_INFO_FileDescription     5 |  | ||||||
| #define NP_INFO_ProductName         6 |  | ||||||
| /* RC_DATA types for version info - optional */ |  | ||||||
| #define NP_INFO_CompanyName         7 |  | ||||||
| #define NP_INFO_FileVersion         8 |  | ||||||
| #define NP_INFO_InternalName        9 |  | ||||||
| #define NP_INFO_LegalCopyright      10 |  | ||||||
| #define NP_INFO_OriginalFilename    11 |  | ||||||
|  |  | ||||||
| #ifndef RC_INVOKED |  | ||||||
|  |  | ||||||
| /*----------------------------------------------------------------------*/ |  | ||||||
| /*                       Definition of Basic Types                      */ |  | ||||||
| /*----------------------------------------------------------------------*/ |  | ||||||
|  |  | ||||||
| typedef unsigned char NPBool; |  | ||||||
| typedef int16_t       NPError; |  | ||||||
| typedef int16_t       NPReason; |  | ||||||
| typedef char*         NPMIMEType; |  | ||||||
|  |  | ||||||
| /*----------------------------------------------------------------------*/ |  | ||||||
| /*                       Structures and definitions                     */ |  | ||||||
| /*----------------------------------------------------------------------*/ |  | ||||||
|  |  | ||||||
| #if !defined(__LP64__) |  | ||||||
| #if defined(XP_MACOSX) |  | ||||||
| #pragma options align=mac68k |  | ||||||
| #endif |  | ||||||
| #endif /* __LP64__ */ |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  *  NPP is a plug-in's opaque instance handle |  | ||||||
|  */ |  | ||||||
| typedef struct _NPP |  | ||||||
| { |  | ||||||
|   void* pdata;      /* plug-in private data */ |  | ||||||
|   void* ndata;      /* netscape private data */ |  | ||||||
| } NPP_t; |  | ||||||
|  |  | ||||||
| typedef NPP_t*  NPP; |  | ||||||
|  |  | ||||||
| typedef struct _NPStream |  | ||||||
| { |  | ||||||
|   void*    pdata; /* plug-in private data */ |  | ||||||
|   void*    ndata; /* netscape private data */ |  | ||||||
|   const    char* url; |  | ||||||
|   uint32_t end; |  | ||||||
|   uint32_t lastmodified; |  | ||||||
|   void*    notifyData; |  | ||||||
|   const    char* headers; /* Response headers from host. |  | ||||||
|                            * Exists only for >= NPVERS_HAS_RESPONSE_HEADERS. |  | ||||||
|                            * Used for HTTP only; NULL for non-HTTP. |  | ||||||
|                            * Available from NPP_NewStream onwards. |  | ||||||
|                            * Plugin should copy this data before storing it. |  | ||||||
|                            * Includes HTTP status line and all headers, |  | ||||||
|                            * preferably verbatim as received from server, |  | ||||||
|                            * headers formatted as in HTTP ("Header: Value"), |  | ||||||
|                            * and newlines (\n, NOT \r\n) separating lines. |  | ||||||
|                            * Terminated by \n\0 (NOT \n\n\0). */ |  | ||||||
| } NPStream; |  | ||||||
|  |  | ||||||
| typedef struct _NPByteRange |  | ||||||
| { |  | ||||||
|   int32_t  offset; /* negative offset means from the end */ |  | ||||||
|   uint32_t length; |  | ||||||
|   struct _NPByteRange* next; |  | ||||||
| } NPByteRange; |  | ||||||
|  |  | ||||||
| typedef struct _NPSavedData |  | ||||||
| { |  | ||||||
|   int32_t len; |  | ||||||
|   void*   buf; |  | ||||||
| } NPSavedData; |  | ||||||
|  |  | ||||||
| typedef struct _NPRect |  | ||||||
| { |  | ||||||
|   uint16_t top; |  | ||||||
|   uint16_t left; |  | ||||||
|   uint16_t bottom; |  | ||||||
|   uint16_t right; |  | ||||||
| } NPRect; |  | ||||||
|  |  | ||||||
| typedef struct _NPSize |  | ||||||
| { |  | ||||||
|   int32_t width; |  | ||||||
|   int32_t height; |  | ||||||
| } NPSize; |  | ||||||
|  |  | ||||||
| typedef enum { |  | ||||||
|   NPFocusNext = 0, |  | ||||||
|   NPFocusPrevious = 1 |  | ||||||
| } NPFocusDirection; |  | ||||||
|  |  | ||||||
| /* Return values for NPP_HandleEvent */ |  | ||||||
| #define kNPEventNotHandled 0 |  | ||||||
| #define kNPEventHandled 1 |  | ||||||
| /* Exact meaning must be spec'd in event model. */ |  | ||||||
| #define kNPEventStartIME 2 |  | ||||||
|  |  | ||||||
| #if defined(XP_UNIX) |  | ||||||
| /* |  | ||||||
|  * Unix specific structures and definitions |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * Callback Structures. |  | ||||||
|  * |  | ||||||
|  * These are used to pass additional platform specific information. |  | ||||||
|  */ |  | ||||||
| enum { |  | ||||||
|   NP_SETWINDOW = 1, |  | ||||||
|   NP_PRINT |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| typedef struct |  | ||||||
| { |  | ||||||
|   int32_t type; |  | ||||||
| } NPAnyCallbackStruct; |  | ||||||
|  |  | ||||||
| typedef struct |  | ||||||
| { |  | ||||||
|   int32_t      type; |  | ||||||
| #if defined(MOZ_X11) |  | ||||||
|   Display*     display; |  | ||||||
|   Visual*      visual; |  | ||||||
|   Colormap     colormap; |  | ||||||
|   unsigned int depth; |  | ||||||
| #endif |  | ||||||
| } NPSetWindowCallbackStruct; |  | ||||||
|  |  | ||||||
| typedef struct |  | ||||||
| { |  | ||||||
|   int32_t type; |  | ||||||
|   FILE* fp; |  | ||||||
| } NPPrintCallbackStruct; |  | ||||||
|  |  | ||||||
| #endif /* XP_UNIX */ |  | ||||||
|  |  | ||||||
| #if defined(XP_MACOSX) |  | ||||||
| typedef enum { |  | ||||||
| #ifndef NP_NO_QUICKDRAW |  | ||||||
|   NPDrawingModelQuickDraw = 0, |  | ||||||
| #endif |  | ||||||
|   NPDrawingModelCoreGraphics = 1, |  | ||||||
|   NPDrawingModelOpenGL = 2, |  | ||||||
|   NPDrawingModelCoreAnimation = 3, |  | ||||||
|   NPDrawingModelInvalidatingCoreAnimation = 4 |  | ||||||
| } NPDrawingModel; |  | ||||||
|  |  | ||||||
| typedef enum { |  | ||||||
| #ifndef NP_NO_CARBON |  | ||||||
|   NPEventModelCarbon = 0, |  | ||||||
| #endif |  | ||||||
|   NPEventModelCocoa = 1 |  | ||||||
| } NPEventModel; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  *   The following masks are applied on certain platforms to NPNV and |  | ||||||
|  *   NPPV selectors that pass around pointers to COM interfaces. Newer |  | ||||||
|  *   compilers on some platforms may generate vtables that are not |  | ||||||
|  *   compatible with older compilers. To prevent older plugins from |  | ||||||
|  *   not understanding a new browser's ABI, these masks change the |  | ||||||
|  *   values of those selectors on those platforms. To remain backwards |  | ||||||
|  *   compatible with different versions of the browser, plugins can |  | ||||||
|  *   use these masks to dynamically determine and use the correct C++ |  | ||||||
|  *   ABI that the browser is expecting. This does not apply to Windows |  | ||||||
|  *   as Microsoft's COM ABI will likely not change. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #define NP_ABI_GCC3_MASK  0x10000000 |  | ||||||
| /* |  | ||||||
|  *   gcc 3.x generated vtables on UNIX and OSX are incompatible with |  | ||||||
|  *   previous compilers. |  | ||||||
|  */ |  | ||||||
| #if (defined(XP_UNIX) && defined(__GNUC__) && (__GNUC__ >= 3)) |  | ||||||
| #define _NP_ABI_MIXIN_FOR_GCC3 NP_ABI_GCC3_MASK |  | ||||||
| #else |  | ||||||
| #define _NP_ABI_MIXIN_FOR_GCC3 0 |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(XP_MACOSX) |  | ||||||
| #define NP_ABI_MACHO_MASK 0x01000000 |  | ||||||
| #define _NP_ABI_MIXIN_FOR_MACHO NP_ABI_MACHO_MASK |  | ||||||
| #else |  | ||||||
| #define _NP_ABI_MIXIN_FOR_MACHO 0 |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #define NP_ABI_MASK (_NP_ABI_MIXIN_FOR_GCC3 | _NP_ABI_MIXIN_FOR_MACHO) |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * List of variable names for which NPP_GetValue shall be implemented |  | ||||||
|  */ |  | ||||||
| typedef enum { |  | ||||||
|   NPPVpluginNameString = 1, |  | ||||||
|   NPPVpluginDescriptionString, |  | ||||||
|   NPPVpluginWindowBool, |  | ||||||
|   NPPVpluginTransparentBool, |  | ||||||
|   NPPVjavaClass, |  | ||||||
|   NPPVpluginWindowSize, |  | ||||||
|   NPPVpluginTimerInterval, |  | ||||||
|   NPPVpluginScriptableInstance = (10 | NP_ABI_MASK), |  | ||||||
|   NPPVpluginScriptableIID = 11, |  | ||||||
|   NPPVjavascriptPushCallerBool = 12, |  | ||||||
|   NPPVpluginKeepLibraryInMemory = 13, |  | ||||||
|   NPPVpluginNeedsXEmbed         = 14, |  | ||||||
|  |  | ||||||
|   /* Get the NPObject for scripting the plugin. Introduced in NPAPI minor version 14. |  | ||||||
|    */ |  | ||||||
|   NPPVpluginScriptableNPObject  = 15, |  | ||||||
|  |  | ||||||
|   /* Get the plugin value (as \0-terminated UTF-8 string data) for |  | ||||||
|    * form submission if the plugin is part of a form. Use |  | ||||||
|    * NPN_MemAlloc() to allocate memory for the string data. Introduced |  | ||||||
|    * in NPAPI minor version 15. |  | ||||||
|    */ |  | ||||||
|   NPPVformValue = 16, |  | ||||||
|  |  | ||||||
|   NPPVpluginUrlRequestsDisplayedBool = 17, |  | ||||||
|  |  | ||||||
|   /* Checks if the plugin is interested in receiving the http body of |  | ||||||
|    * all http requests (including failed ones, http status != 200). |  | ||||||
|    */ |  | ||||||
|   NPPVpluginWantsAllNetworkStreams = 18, |  | ||||||
|  |  | ||||||
|   /* Browsers can retrieve a native ATK accessibility plug ID via this variable. */ |  | ||||||
|   NPPVpluginNativeAccessibleAtkPlugId = 19, |  | ||||||
|  |  | ||||||
|   /* Checks to see if the plug-in would like the browser to load the "src" attribute. */ |  | ||||||
|   NPPVpluginCancelSrcStream = 20, |  | ||||||
|  |  | ||||||
|   NPPVsupportsAdvancedKeyHandling = 21, |  | ||||||
|  |  | ||||||
|   NPPVpluginUsesDOMForCursorBool = 22 |  | ||||||
|  |  | ||||||
| #if defined(XP_MACOSX) |  | ||||||
|   /* Used for negotiating drawing models */ |  | ||||||
|   , NPPVpluginDrawingModel = 1000 |  | ||||||
|   /* Used for negotiating event models */ |  | ||||||
|   , NPPVpluginEventModel = 1001 |  | ||||||
|   /* In the NPDrawingModelCoreAnimation drawing model, the browser asks the plug-in for a Core Animation layer. */ |  | ||||||
|   , NPPVpluginCoreAnimationLayer = 1003 |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if (MOZ_PLATFORM_MAEMO == 5) || (MOZ_PLATFORM_MAEMO == 6) |  | ||||||
|   , NPPVpluginWindowlessLocalBool = 2002 |  | ||||||
| #endif |  | ||||||
| } NPPVariable; |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * List of variable names for which NPN_GetValue should be implemented. |  | ||||||
|  */ |  | ||||||
| typedef enum { |  | ||||||
|   NPNVxDisplay = 1, |  | ||||||
|   NPNVxtAppContext, |  | ||||||
|   NPNVnetscapeWindow, |  | ||||||
|   NPNVjavascriptEnabledBool, |  | ||||||
|   NPNVasdEnabledBool, |  | ||||||
|   NPNVisOfflineBool, |  | ||||||
|  |  | ||||||
|   NPNVserviceManager = (10 | NP_ABI_MASK), |  | ||||||
|   NPNVDOMElement     = (11 | NP_ABI_MASK), |  | ||||||
|   NPNVDOMWindow      = (12 | NP_ABI_MASK), |  | ||||||
|   NPNVToolkit        = (13 | NP_ABI_MASK), |  | ||||||
|   NPNVSupportsXEmbedBool = 14, |  | ||||||
|  |  | ||||||
|   /* Get the NPObject wrapper for the browser window. */ |  | ||||||
|   NPNVWindowNPObject = 15, |  | ||||||
|  |  | ||||||
|   /* Get the NPObject wrapper for the plugins DOM element. */ |  | ||||||
|   NPNVPluginElementNPObject = 16, |  | ||||||
|  |  | ||||||
|   NPNVSupportsWindowless = 17, |  | ||||||
|  |  | ||||||
|   NPNVprivateModeBool = 18, |  | ||||||
|  |  | ||||||
|   NPNVsupportsAdvancedKeyHandling = 21 |  | ||||||
|  |  | ||||||
| #if defined(XP_MACOSX) |  | ||||||
|   /* Used for negotiating drawing models */ |  | ||||||
|   , NPNVpluginDrawingModel = 1000 |  | ||||||
| #ifndef NP_NO_QUICKDRAW |  | ||||||
|   , NPNVsupportsQuickDrawBool = 2000 |  | ||||||
| #endif |  | ||||||
|   , NPNVsupportsCoreGraphicsBool = 2001 |  | ||||||
|   , NPNVsupportsOpenGLBool = 2002 |  | ||||||
|   , NPNVsupportsCoreAnimationBool = 2003 |  | ||||||
|   , NPNVsupportsInvalidatingCoreAnimationBool = 2004 |  | ||||||
| #ifndef NP_NO_CARBON |  | ||||||
|   , NPNVsupportsCarbonBool = 3000 /* TRUE if the browser supports the Carbon event model */ |  | ||||||
| #endif |  | ||||||
|   , NPNVsupportsCocoaBool = 3001 /* TRUE if the browser supports the Cocoa event model */ |  | ||||||
|   , NPNVsupportsUpdatedCocoaTextInputBool = 3002 /* TRUE if the browser supports the updated |  | ||||||
|                                                     Cocoa text input specification. */ |  | ||||||
|   , NPNVsupportsCompositingCoreAnimationPluginsBool = 74656 /* TRUE if the browser supports |  | ||||||
|                                                                CA model compositing */ |  | ||||||
| #endif |  | ||||||
| #if (MOZ_PLATFORM_MAEMO == 5) || (MOZ_PLATFORM_MAEMO == 6) |  | ||||||
|   , NPNVSupportsWindowlessLocal = 2002 |  | ||||||
| #endif |  | ||||||
| } NPNVariable; |  | ||||||
|  |  | ||||||
| typedef enum { |  | ||||||
|   NPNURLVCookie = 501, |  | ||||||
|   NPNURLVProxy |  | ||||||
| } NPNURLVariable; |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * The type of Toolkit the widgets use |  | ||||||
|  */ |  | ||||||
| typedef enum { |  | ||||||
|   NPNVGtk12 = 1, |  | ||||||
|   NPNVGtk2 |  | ||||||
| } NPNToolkitType; |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * The type of a NPWindow - it specifies the type of the data structure |  | ||||||
|  * returned in the window field. |  | ||||||
|  */ |  | ||||||
| typedef enum { |  | ||||||
|   NPWindowTypeWindow = 1, |  | ||||||
|   NPWindowTypeDrawable |  | ||||||
| } NPWindowType; |  | ||||||
|  |  | ||||||
| typedef struct _NPWindow |  | ||||||
| { |  | ||||||
|   void* window;  /* Platform specific window handle */ |  | ||||||
|                  /* OS/2: x - Position of bottom left corner */ |  | ||||||
|                  /* OS/2: y - relative to visible netscape window */ |  | ||||||
|   int32_t  x;      /* Position of top left corner relative */ |  | ||||||
|   int32_t  y;      /* to a netscape page. */ |  | ||||||
|   uint32_t width;  /* Maximum window size */ |  | ||||||
|   uint32_t height; |  | ||||||
|   NPRect   clipRect; /* Clipping rectangle in port coordinates */ |  | ||||||
| #if (defined(XP_UNIX) || defined(XP_SYMBIAN)) && !defined(XP_MACOSX) |  | ||||||
|   void * ws_info; /* Platform-dependent additional data */ |  | ||||||
| #endif /* XP_UNIX */ |  | ||||||
|   NPWindowType type; /* Is this a window or a drawable? */ |  | ||||||
| } NPWindow; |  | ||||||
|  |  | ||||||
| typedef struct _NPImageExpose |  | ||||||
| { |  | ||||||
|   char*    data;       /* image pointer */ |  | ||||||
|   int32_t  stride;     /* Stride of data image pointer */ |  | ||||||
|   int32_t  depth;      /* Depth of image pointer */ |  | ||||||
|   int32_t  x;          /* Expose x */ |  | ||||||
|   int32_t  y;          /* Expose y */ |  | ||||||
|   uint32_t width;      /* Expose width */ |  | ||||||
|   uint32_t height;     /* Expose height */ |  | ||||||
|   NPSize   dataSize;   /* Data buffer size */ |  | ||||||
|   float    translateX; /* translate X matrix value */ |  | ||||||
|   float    translateY; /* translate Y matrix value */ |  | ||||||
|   float    scaleX;     /* scale X matrix value */ |  | ||||||
|   float    scaleY;     /* scale Y matrix value */ |  | ||||||
| } NPImageExpose; |  | ||||||
|  |  | ||||||
| typedef struct _NPFullPrint |  | ||||||
| { |  | ||||||
|   NPBool pluginPrinted;/* Set TRUE if plugin handled fullscreen printing */ |  | ||||||
|   NPBool printOne;     /* TRUE if plugin should print one copy to default |  | ||||||
|                           printer */ |  | ||||||
|   void* platformPrint; /* Platform-specific printing info */ |  | ||||||
| } NPFullPrint; |  | ||||||
|  |  | ||||||
| typedef struct _NPEmbedPrint |  | ||||||
| { |  | ||||||
|   NPWindow window; |  | ||||||
|   void* platformPrint; /* Platform-specific printing info */ |  | ||||||
| } NPEmbedPrint; |  | ||||||
|  |  | ||||||
| typedef struct _NPPrint |  | ||||||
| { |  | ||||||
|   uint16_t mode;               /* NP_FULL or NP_EMBED */ |  | ||||||
|   union |  | ||||||
|   { |  | ||||||
|     NPFullPrint fullPrint;   /* if mode is NP_FULL */ |  | ||||||
|     NPEmbedPrint embedPrint; /* if mode is NP_EMBED */ |  | ||||||
|   } print; |  | ||||||
| } NPPrint; |  | ||||||
|  |  | ||||||
| #if defined(XP_MACOSX) |  | ||||||
| #ifndef NP_NO_CARBON |  | ||||||
| typedef EventRecord NPEvent; |  | ||||||
| #endif |  | ||||||
| #elif defined(XP_SYMBIAN) |  | ||||||
| typedef QEvent NPEvent; |  | ||||||
| #elif defined(XP_WIN) |  | ||||||
| typedef struct _NPEvent |  | ||||||
| { |  | ||||||
|   uint16_t event; |  | ||||||
|   uintptr_t wParam; |  | ||||||
|   uintptr_t lParam; |  | ||||||
| } NPEvent; |  | ||||||
| #elif defined(XP_OS2) |  | ||||||
| typedef struct _NPEvent |  | ||||||
| { |  | ||||||
|   uint32_t event; |  | ||||||
|   uint32_t wParam; |  | ||||||
|   uint32_t lParam; |  | ||||||
| } NPEvent; |  | ||||||
| #elif defined(XP_UNIX) && defined(MOZ_X11) |  | ||||||
| typedef XEvent NPEvent; |  | ||||||
| #else |  | ||||||
| typedef void*  NPEvent; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(XP_MACOSX) |  | ||||||
| typedef void* NPRegion; |  | ||||||
| #ifndef NP_NO_QUICKDRAW |  | ||||||
| typedef RgnHandle NPQDRegion; |  | ||||||
| #endif |  | ||||||
| typedef CGPathRef NPCGRegion; |  | ||||||
| #elif defined(XP_WIN) |  | ||||||
| typedef HRGN NPRegion; |  | ||||||
| #elif defined(XP_UNIX) && defined(MOZ_X11) |  | ||||||
| typedef Region NPRegion; |  | ||||||
| #elif defined(XP_SYMBIAN) |  | ||||||
| typedef QRegion* NPRegion; |  | ||||||
| #else |  | ||||||
| typedef void *NPRegion; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| typedef struct _NPNSString NPNSString; |  | ||||||
| typedef struct _NPNSWindow NPNSWindow; |  | ||||||
| typedef struct _NPNSMenu   NPNSMenu; |  | ||||||
|  |  | ||||||
| #if defined(XP_MACOSX) |  | ||||||
| typedef NPNSMenu NPMenu; |  | ||||||
| #else |  | ||||||
| typedef void *NPMenu; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| typedef enum { |  | ||||||
|   NPCoordinateSpacePlugin = 1, |  | ||||||
|   NPCoordinateSpaceWindow, |  | ||||||
|   NPCoordinateSpaceFlippedWindow, |  | ||||||
|   NPCoordinateSpaceScreen, |  | ||||||
|   NPCoordinateSpaceFlippedScreen |  | ||||||
| } NPCoordinateSpace; |  | ||||||
|  |  | ||||||
| #if defined(XP_MACOSX) |  | ||||||
|  |  | ||||||
| #ifndef NP_NO_QUICKDRAW |  | ||||||
| typedef struct NP_Port |  | ||||||
| { |  | ||||||
|   CGrafPtr port; |  | ||||||
|   int32_t portx; /* position inside the topmost window */ |  | ||||||
|   int32_t porty; |  | ||||||
| } NP_Port; |  | ||||||
| #endif /* NP_NO_QUICKDRAW */ |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * NP_CGContext is the type of the NPWindow's 'window' when the plugin specifies NPDrawingModelCoreGraphics |  | ||||||
|  * as its drawing model. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| typedef struct NP_CGContext |  | ||||||
| { |  | ||||||
|   CGContextRef context; |  | ||||||
|   void *window; /* A WindowRef under the Carbon event model. */ |  | ||||||
| } NP_CGContext; |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * NP_GLContext is the type of the NPWindow's 'window' when the plugin specifies NPDrawingModelOpenGL as its |  | ||||||
|  * drawing model. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| typedef struct NP_GLContext |  | ||||||
| { |  | ||||||
|   CGLContextObj context; |  | ||||||
| #ifdef NP_NO_CARBON |  | ||||||
|   NPNSWindow *window; |  | ||||||
| #else |  | ||||||
|   void *window; /* Can be either an NSWindow or a WindowRef depending on the event model */ |  | ||||||
| #endif |  | ||||||
| } NP_GLContext; |  | ||||||
|  |  | ||||||
| typedef enum { |  | ||||||
|   NPCocoaEventDrawRect = 1, |  | ||||||
|   NPCocoaEventMouseDown, |  | ||||||
|   NPCocoaEventMouseUp, |  | ||||||
|   NPCocoaEventMouseMoved, |  | ||||||
|   NPCocoaEventMouseEntered, |  | ||||||
|   NPCocoaEventMouseExited, |  | ||||||
|   NPCocoaEventMouseDragged, |  | ||||||
|   NPCocoaEventKeyDown, |  | ||||||
|   NPCocoaEventKeyUp, |  | ||||||
|   NPCocoaEventFlagsChanged, |  | ||||||
|   NPCocoaEventFocusChanged, |  | ||||||
|   NPCocoaEventWindowFocusChanged, |  | ||||||
|   NPCocoaEventScrollWheel, |  | ||||||
|   NPCocoaEventTextInput |  | ||||||
| } NPCocoaEventType; |  | ||||||
|  |  | ||||||
| typedef struct _NPCocoaEvent { |  | ||||||
|   NPCocoaEventType type; |  | ||||||
|   uint32_t version; |  | ||||||
|   union { |  | ||||||
|     struct { |  | ||||||
|       uint32_t modifierFlags; |  | ||||||
|       double   pluginX; |  | ||||||
|       double   pluginY; |  | ||||||
|       int32_t  buttonNumber; |  | ||||||
|       int32_t  clickCount; |  | ||||||
|       double   deltaX; |  | ||||||
|       double   deltaY; |  | ||||||
|       double   deltaZ; |  | ||||||
|     } mouse; |  | ||||||
|     struct { |  | ||||||
|       uint32_t    modifierFlags; |  | ||||||
|       NPNSString *characters; |  | ||||||
|       NPNSString *charactersIgnoringModifiers; |  | ||||||
|       NPBool      isARepeat; |  | ||||||
|       uint16_t    keyCode; |  | ||||||
|     } key; |  | ||||||
|     struct { |  | ||||||
|       CGContextRef context; |  | ||||||
|       double x; |  | ||||||
|       double y; |  | ||||||
|       double width; |  | ||||||
|       double height; |  | ||||||
|     } draw; |  | ||||||
|     struct { |  | ||||||
|       NPBool hasFocus; |  | ||||||
|     } focus; |  | ||||||
|     struct { |  | ||||||
|       NPNSString *text; |  | ||||||
|     } text; |  | ||||||
|   } data; |  | ||||||
| } NPCocoaEvent; |  | ||||||
|  |  | ||||||
| #ifndef NP_NO_CARBON |  | ||||||
| /* Non-standard event types that can be passed to HandleEvent */ |  | ||||||
| enum NPEventType { |  | ||||||
|   NPEventType_GetFocusEvent = (osEvt + 16), |  | ||||||
|   NPEventType_LoseFocusEvent, |  | ||||||
|   NPEventType_AdjustCursorEvent, |  | ||||||
|   NPEventType_MenuCommandEvent, |  | ||||||
|   NPEventType_ClippingChangedEvent, |  | ||||||
|   NPEventType_ScrollingBeginsEvent = 1000, |  | ||||||
|   NPEventType_ScrollingEndsEvent |  | ||||||
| }; |  | ||||||
| #endif /* NP_NO_CARBON */ |  | ||||||
|  |  | ||||||
| #endif /* XP_MACOSX */ |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * Values for mode passed to NPP_New: |  | ||||||
|  */ |  | ||||||
| #define NP_EMBED 1 |  | ||||||
| #define NP_FULL  2 |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * Values for stream type passed to NPP_NewStream: |  | ||||||
|  */ |  | ||||||
| #define NP_NORMAL     1 |  | ||||||
| #define NP_SEEK       2 |  | ||||||
| #define NP_ASFILE     3 |  | ||||||
| #define NP_ASFILEONLY 4 |  | ||||||
|  |  | ||||||
| #define NP_MAXREADY (((unsigned)(~0)<<1)>>1) |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * Flags for NPP_ClearSiteData. |  | ||||||
|  */ |  | ||||||
| #define NP_CLEAR_ALL   0 |  | ||||||
| #define NP_CLEAR_CACHE (1 << 0) |  | ||||||
|  |  | ||||||
| #if !defined(__LP64__) |  | ||||||
| #if defined(XP_MACOSX) |  | ||||||
| #pragma options align=reset |  | ||||||
| #endif |  | ||||||
| #endif /* __LP64__ */ |  | ||||||
|  |  | ||||||
| /*----------------------------------------------------------------------*/ |  | ||||||
| /*       Error and Reason Code definitions                              */ |  | ||||||
| /*----------------------------------------------------------------------*/ |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * Values of type NPError: |  | ||||||
|  */ |  | ||||||
| #define NPERR_BASE                         0 |  | ||||||
| #define NPERR_NO_ERROR                    (NPERR_BASE + 0) |  | ||||||
| #define NPERR_GENERIC_ERROR               (NPERR_BASE + 1) |  | ||||||
| #define NPERR_INVALID_INSTANCE_ERROR      (NPERR_BASE + 2) |  | ||||||
| #define NPERR_INVALID_FUNCTABLE_ERROR     (NPERR_BASE + 3) |  | ||||||
| #define NPERR_MODULE_LOAD_FAILED_ERROR    (NPERR_BASE + 4) |  | ||||||
| #define NPERR_OUT_OF_MEMORY_ERROR         (NPERR_BASE + 5) |  | ||||||
| #define NPERR_INVALID_PLUGIN_ERROR        (NPERR_BASE + 6) |  | ||||||
| #define NPERR_INVALID_PLUGIN_DIR_ERROR    (NPERR_BASE + 7) |  | ||||||
| #define NPERR_INCOMPATIBLE_VERSION_ERROR  (NPERR_BASE + 8) |  | ||||||
| #define NPERR_INVALID_PARAM               (NPERR_BASE + 9) |  | ||||||
| #define NPERR_INVALID_URL                 (NPERR_BASE + 10) |  | ||||||
| #define NPERR_FILE_NOT_FOUND              (NPERR_BASE + 11) |  | ||||||
| #define NPERR_NO_DATA                     (NPERR_BASE + 12) |  | ||||||
| #define NPERR_STREAM_NOT_SEEKABLE         (NPERR_BASE + 13) |  | ||||||
| #define NPERR_TIME_RANGE_NOT_SUPPORTED    (NPERR_BASE + 14) |  | ||||||
| #define NPERR_MALFORMED_SITE              (NPERR_BASE + 15) |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * Values of type NPReason: |  | ||||||
|  */ |  | ||||||
| #define NPRES_BASE          0 |  | ||||||
| #define NPRES_DONE         (NPRES_BASE + 0) |  | ||||||
| #define NPRES_NETWORK_ERR  (NPRES_BASE + 1) |  | ||||||
| #define NPRES_USER_BREAK   (NPRES_BASE + 2) |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * Don't use these obsolete error codes any more. |  | ||||||
|  */ |  | ||||||
| #define NP_NOERR  NP_NOERR_is_obsolete_use_NPERR_NO_ERROR |  | ||||||
| #define NP_EINVAL NP_EINVAL_is_obsolete_use_NPERR_GENERIC_ERROR |  | ||||||
| #define NP_EABORT NP_EABORT_is_obsolete_use_NPRES_USER_BREAK |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * Version feature information |  | ||||||
|  */ |  | ||||||
| #define NPVERS_HAS_STREAMOUTPUT             8 |  | ||||||
| #define NPVERS_HAS_NOTIFICATION             9 |  | ||||||
| #define NPVERS_HAS_LIVECONNECT              9 |  | ||||||
| #define NPVERS_68K_HAS_LIVECONNECT          11 |  | ||||||
| #define NPVERS_HAS_WINDOWLESS               11 |  | ||||||
| #define NPVERS_HAS_XPCONNECT_SCRIPTING      13 |  | ||||||
| #define NPVERS_HAS_NPRUNTIME_SCRIPTING      14 |  | ||||||
| #define NPVERS_HAS_FORM_VALUES              15 |  | ||||||
| #define NPVERS_HAS_POPUPS_ENABLED_STATE     16 |  | ||||||
| #define NPVERS_HAS_RESPONSE_HEADERS         17 |  | ||||||
| #define NPVERS_HAS_NPOBJECT_ENUM            18 |  | ||||||
| #define NPVERS_HAS_PLUGIN_THREAD_ASYNC_CALL 19 |  | ||||||
| #define NPVERS_HAS_ALL_NETWORK_STREAMS      20 |  | ||||||
| #define NPVERS_HAS_URL_AND_AUTH_INFO        21 |  | ||||||
| #define NPVERS_HAS_PRIVATE_MODE             22 |  | ||||||
| #define NPVERS_MACOSX_HAS_COCOA_EVENTS      23 |  | ||||||
| #define NPVERS_HAS_ADVANCED_KEY_HANDLING    25 |  | ||||||
| #define NPVERS_HAS_URL_REDIRECT_HANDLING    26 |  | ||||||
| #define NPVERS_HAS_CLEAR_SITE_DATA          27 |  | ||||||
|  |  | ||||||
| /*----------------------------------------------------------------------*/ |  | ||||||
| /*                        Function Prototypes                           */ |  | ||||||
| /*----------------------------------------------------------------------*/ |  | ||||||
|  |  | ||||||
| #if defined(__OS2__) |  | ||||||
| #define NP_LOADDS _System |  | ||||||
| #else |  | ||||||
| #define NP_LOADDS |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus |  | ||||||
| extern "C" { |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| /* NPP_* functions are provided by the plugin and called by the navigator. */ |  | ||||||
|  |  | ||||||
| #if defined(XP_UNIX) |  | ||||||
| const char* NPP_GetMIMEDescription(void); |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| NPError NP_LOADDS NPP_New(NPMIMEType pluginType, NPP instance, |  | ||||||
|                           uint16_t mode, int16_t argc, char* argn[], |  | ||||||
|                           char* argv[], NPSavedData* saved); |  | ||||||
| NPError NP_LOADDS NPP_Destroy(NPP instance, NPSavedData** save); |  | ||||||
| NPError NP_LOADDS NPP_SetWindow(NPP instance, NPWindow* window); |  | ||||||
| NPError NP_LOADDS NPP_NewStream(NPP instance, NPMIMEType type, |  | ||||||
|                                 NPStream* stream, NPBool seekable, |  | ||||||
|                                 uint16_t* stype); |  | ||||||
| NPError NP_LOADDS NPP_DestroyStream(NPP instance, NPStream* stream, |  | ||||||
|                                     NPReason reason); |  | ||||||
| int32_t NP_LOADDS NPP_WriteReady(NPP instance, NPStream* stream); |  | ||||||
| int32_t NP_LOADDS NPP_Write(NPP instance, NPStream* stream, int32_t offset, |  | ||||||
|                             int32_t len, void* buffer); |  | ||||||
| void    NP_LOADDS NPP_StreamAsFile(NPP instance, NPStream* stream, |  | ||||||
|                                    const char* fname); |  | ||||||
| void    NP_LOADDS NPP_Print(NPP instance, NPPrint* platformPrint); |  | ||||||
| int16_t NP_LOADDS NPP_HandleEvent(NPP instance, void* event); |  | ||||||
| void    NP_LOADDS NPP_URLNotify(NPP instance, const char* url, |  | ||||||
|                                 NPReason reason, void* notifyData); |  | ||||||
| NPError NP_LOADDS NPP_GetValue(NPP instance, NPPVariable variable, void *value); |  | ||||||
| NPError NP_LOADDS NPP_SetValue(NPP instance, NPNVariable variable, void *value); |  | ||||||
| NPBool  NP_LOADDS NPP_GotFocus(NPP instance, NPFocusDirection direction); |  | ||||||
| void    NP_LOADDS NPP_LostFocus(NPP instance); |  | ||||||
| void    NP_LOADDS NPP_URLRedirectNotify(NPP instance, const char* url, int32_t status, void* notifyData); |  | ||||||
| NPError NP_LOADDS NPP_ClearSiteData(const char* site, uint64_t flags, uint64_t maxAge); |  | ||||||
| char**  NP_LOADDS NPP_GetSitesWithData(void); |  | ||||||
|  |  | ||||||
| /* NPN_* functions are provided by the navigator and called by the plugin. */ |  | ||||||
| void        NP_LOADDS NPN_Version(int* plugin_major, int* plugin_minor, |  | ||||||
|                                   int* netscape_major, int* netscape_minor); |  | ||||||
| NPError     NP_LOADDS NPN_GetURLNotify(NPP instance, const char* url, |  | ||||||
|                                        const char* target, void* notifyData); |  | ||||||
| NPError     NP_LOADDS NPN_GetURL(NPP instance, const char* url, |  | ||||||
|                                  const char* target); |  | ||||||
| NPError     NP_LOADDS NPN_PostURLNotify(NPP instance, const char* url, |  | ||||||
|                                         const char* target, uint32_t len, |  | ||||||
|                                         const char* buf, NPBool file, |  | ||||||
|                                         void* notifyData); |  | ||||||
| NPError     NP_LOADDS NPN_PostURL(NPP instance, const char* url, |  | ||||||
|                                   const char* target, uint32_t len, |  | ||||||
|                                   const char* buf, NPBool file); |  | ||||||
| NPError     NP_LOADDS NPN_RequestRead(NPStream* stream, NPByteRange* rangeList); |  | ||||||
| NPError     NP_LOADDS NPN_NewStream(NPP instance, NPMIMEType type, |  | ||||||
|                                     const char* target, NPStream** stream); |  | ||||||
| int32_t     NP_LOADDS NPN_Write(NPP instance, NPStream* stream, int32_t len, |  | ||||||
|                                 void* buffer); |  | ||||||
| NPError     NP_LOADDS NPN_DestroyStream(NPP instance, NPStream* stream, |  | ||||||
|                                         NPReason reason); |  | ||||||
| void        NP_LOADDS NPN_Status(NPP instance, const char* message); |  | ||||||
| const char* NP_LOADDS NPN_UserAgent(NPP instance); |  | ||||||
| void*       NP_LOADDS NPN_MemAlloc(uint32_t size); |  | ||||||
| void        NP_LOADDS NPN_MemFree(void* ptr); |  | ||||||
| uint32_t    NP_LOADDS NPN_MemFlush(uint32_t size); |  | ||||||
| void        NP_LOADDS NPN_ReloadPlugins(NPBool reloadPages); |  | ||||||
| NPError     NP_LOADDS NPN_GetValue(NPP instance, NPNVariable variable, |  | ||||||
|                                    void *value); |  | ||||||
| NPError     NP_LOADDS NPN_SetValue(NPP instance, NPPVariable variable, |  | ||||||
|                                    void *value); |  | ||||||
| void        NP_LOADDS NPN_InvalidateRect(NPP instance, NPRect *invalidRect); |  | ||||||
| void        NP_LOADDS NPN_InvalidateRegion(NPP instance, |  | ||||||
|                                            NPRegion invalidRegion); |  | ||||||
| void        NP_LOADDS NPN_ForceRedraw(NPP instance); |  | ||||||
| void        NP_LOADDS NPN_PushPopupsEnabledState(NPP instance, NPBool enabled); |  | ||||||
| void        NP_LOADDS NPN_PopPopupsEnabledState(NPP instance); |  | ||||||
| void        NP_LOADDS NPN_PluginThreadAsyncCall(NPP instance, |  | ||||||
|                                                 void (*func) (void *), |  | ||||||
|                                                 void *userData); |  | ||||||
| NPError     NP_LOADDS NPN_GetValueForURL(NPP instance, NPNURLVariable variable, |  | ||||||
|                                          const char *url, char **value, |  | ||||||
|                                          uint32_t *len); |  | ||||||
| NPError     NP_LOADDS NPN_SetValueForURL(NPP instance, NPNURLVariable variable, |  | ||||||
|                                          const char *url, const char *value, |  | ||||||
|                                          uint32_t len); |  | ||||||
| NPError     NP_LOADDS NPN_GetAuthenticationInfo(NPP instance, |  | ||||||
|                                                 const char *protocol, |  | ||||||
|                                                 const char *host, int32_t port, |  | ||||||
|                                                 const char *scheme, |  | ||||||
|                                                 const char *realm, |  | ||||||
|                                                 char **username, uint32_t *ulen, |  | ||||||
|                                                 char **password, |  | ||||||
|                                                 uint32_t *plen); |  | ||||||
| uint32_t    NP_LOADDS NPN_ScheduleTimer(NPP instance, uint32_t interval, NPBool repeat, void (*timerFunc)(NPP npp, uint32_t timerID)); |  | ||||||
| void        NP_LOADDS NPN_UnscheduleTimer(NPP instance, uint32_t timerID); |  | ||||||
| NPError     NP_LOADDS NPN_PopUpContextMenu(NPP instance, NPMenu* menu); |  | ||||||
| NPBool      NP_LOADDS NPN_ConvertPoint(NPP instance, double sourceX, double sourceY, NPCoordinateSpace sourceSpace, double *destX, double *destY, NPCoordinateSpace destSpace); |  | ||||||
| NPBool      NP_LOADDS NPN_HandleEvent(NPP instance, void *event, NPBool handled); |  | ||||||
| NPBool      NP_LOADDS NPN_UnfocusInstance(NPP instance, NPFocusDirection direction); |  | ||||||
| void        NP_LOADDS NPN_URLRedirectResponse(NPP instance, void* notifyData, NPBool allow); |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus |  | ||||||
| }  /* end extern "C" */ |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif /* RC_INVOKED */ |  | ||||||
| #if defined(__OS2__) |  | ||||||
| #pragma pack() |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif /* npapi_h_ */ |  | ||||||
| @@ -1,322 +0,0 @@ | |||||||
| /* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ |  | ||||||
| /* ***** BEGIN LICENSE BLOCK ***** |  | ||||||
|  * Version: MPL 1.1/GPL 2.0/LGPL 2.1 |  | ||||||
|  * |  | ||||||
|  * The contents of this file are subject to the Mozilla Public License Version |  | ||||||
|  * 1.1 (the "License"); you may not use this file except in compliance with |  | ||||||
|  * the License. You may obtain a copy of the License at |  | ||||||
|  * http://www.mozilla.org/MPL/ |  | ||||||
|  * |  | ||||||
|  * Software distributed under the License is distributed on an "AS IS" basis, |  | ||||||
|  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License |  | ||||||
|  * for the specific language governing rights and limitations under the |  | ||||||
|  * License. |  | ||||||
|  * |  | ||||||
|  * The Original Code is mozilla.org code. |  | ||||||
|  * |  | ||||||
|  * The Initial Developer of the Original Code is |  | ||||||
|  * Netscape Communications Corporation. |  | ||||||
|  * Portions created by the Initial Developer are Copyright (C) 1998 |  | ||||||
|  * the Initial Developer. All Rights Reserved. |  | ||||||
|  * |  | ||||||
|  * Contributor(s): |  | ||||||
|  * |  | ||||||
|  * Alternatively, the contents of this file may be used under the terms of |  | ||||||
|  * either the GNU General Public License Version 2 or later (the "GPL"), or |  | ||||||
|  * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), |  | ||||||
|  * in which case the provisions of the GPL or the LGPL are applicable instead |  | ||||||
|  * of those above. If you wish to allow use of your version of this file only |  | ||||||
|  * under the terms of either the GPL or the LGPL, and not to allow others to |  | ||||||
|  * use your version of this file under the terms of the MPL, indicate your |  | ||||||
|  * decision by deleting the provisions above and replace them with the notice |  | ||||||
|  * and other provisions required by the GPL or the LGPL. If you do not delete |  | ||||||
|  * the provisions above, a recipient may use your version of this file under |  | ||||||
|  * the terms of any one of the MPL, the GPL or the LGPL. |  | ||||||
|  * |  | ||||||
|  * ***** END LICENSE BLOCK ***** */ |  | ||||||
|  |  | ||||||
| #ifndef npfunctions_h_ |  | ||||||
| #define npfunctions_h_ |  | ||||||
|  |  | ||||||
| #ifdef __OS2__ |  | ||||||
| #pragma pack(1) |  | ||||||
| #define NP_LOADDS _System |  | ||||||
| #else |  | ||||||
| #define NP_LOADDS |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #include "npapi.h" |  | ||||||
| #include "npruntime.h" |  | ||||||
|  |  | ||||||
| typedef NPError      (* NP_LOADDS NPP_NewProcPtr)(NPMIMEType pluginType, NPP instance, uint16_t mode, int16_t argc, char* argn[], char* argv[], NPSavedData* saved); |  | ||||||
| typedef NPError      (* NP_LOADDS NPP_DestroyProcPtr)(NPP instance, NPSavedData** save); |  | ||||||
| typedef NPError      (* NP_LOADDS NPP_SetWindowProcPtr)(NPP instance, NPWindow* window); |  | ||||||
| typedef NPError      (* NP_LOADDS NPP_NewStreamProcPtr)(NPP instance, NPMIMEType type, NPStream* stream, NPBool seekable, uint16_t* stype); |  | ||||||
| typedef NPError      (* NP_LOADDS NPP_DestroyStreamProcPtr)(NPP instance, NPStream* stream, NPReason reason); |  | ||||||
| typedef int32_t      (* NP_LOADDS NPP_WriteReadyProcPtr)(NPP instance, NPStream* stream); |  | ||||||
| typedef int32_t      (* NP_LOADDS NPP_WriteProcPtr)(NPP instance, NPStream* stream, int32_t offset, int32_t len, void* buffer); |  | ||||||
| typedef void         (* NP_LOADDS NPP_StreamAsFileProcPtr)(NPP instance, NPStream* stream, const char* fname); |  | ||||||
| typedef void         (* NP_LOADDS NPP_PrintProcPtr)(NPP instance, NPPrint* platformPrint); |  | ||||||
| typedef int16_t      (* NP_LOADDS NPP_HandleEventProcPtr)(NPP instance, void* event); |  | ||||||
| typedef void         (* NP_LOADDS NPP_URLNotifyProcPtr)(NPP instance, const char* url, NPReason reason, void* notifyData); |  | ||||||
| /* Any NPObjects returned to the browser via NPP_GetValue should be retained |  | ||||||
|    by the plugin on the way out. The browser is responsible for releasing. */ |  | ||||||
| typedef NPError      (* NP_LOADDS NPP_GetValueProcPtr)(NPP instance, NPPVariable variable, void *ret_value); |  | ||||||
| typedef NPError      (* NP_LOADDS NPP_SetValueProcPtr)(NPP instance, NPNVariable variable, void *value); |  | ||||||
| typedef NPBool       (* NP_LOADDS NPP_GotFocusPtr)(NPP instance, NPFocusDirection direction); |  | ||||||
| typedef void         (* NP_LOADDS NPP_LostFocusPtr)(NPP instance); |  | ||||||
| typedef void         (* NP_LOADDS NPP_URLRedirectNotifyPtr)(NPP instance, const char* url, int32_t status, void* notifyData); |  | ||||||
| typedef NPError      (* NP_LOADDS NPP_ClearSiteDataPtr)(const char* site, uint64_t flags, uint64_t maxAge); |  | ||||||
| typedef char**       (* NP_LOADDS NPP_GetSitesWithDataPtr)(void); |  | ||||||
|  |  | ||||||
| typedef NPError      (*NPN_GetValueProcPtr)(NPP instance, NPNVariable variable, void *ret_value); |  | ||||||
| typedef NPError      (*NPN_SetValueProcPtr)(NPP instance, NPPVariable variable, void *value); |  | ||||||
| typedef NPError      (*NPN_GetURLNotifyProcPtr)(NPP instance, const char* url, const char* window, void* notifyData); |  | ||||||
| typedef NPError      (*NPN_PostURLNotifyProcPtr)(NPP instance, const char* url, const char* window, uint32_t len, const char* buf, NPBool file, void* notifyData); |  | ||||||
| typedef NPError      (*NPN_GetURLProcPtr)(NPP instance, const char* url, const char* window); |  | ||||||
| typedef NPError      (*NPN_PostURLProcPtr)(NPP instance, const char* url, const char* window, uint32_t len, const char* buf, NPBool file); |  | ||||||
| typedef NPError      (*NPN_RequestReadProcPtr)(NPStream* stream, NPByteRange* rangeList); |  | ||||||
| typedef NPError      (*NPN_NewStreamProcPtr)(NPP instance, NPMIMEType type, const char* window, NPStream** stream); |  | ||||||
| typedef int32_t      (*NPN_WriteProcPtr)(NPP instance, NPStream* stream, int32_t len, void* buffer); |  | ||||||
| typedef NPError      (*NPN_DestroyStreamProcPtr)(NPP instance, NPStream* stream, NPReason reason); |  | ||||||
| typedef void         (*NPN_StatusProcPtr)(NPP instance, const char* message); |  | ||||||
| /* Browser manages the lifetime of the buffer returned by NPN_UserAgent, don't |  | ||||||
|    depend on it sticking around and don't free it. */ |  | ||||||
| typedef const char*  (*NPN_UserAgentProcPtr)(NPP instance); |  | ||||||
| typedef void*        (*NPN_MemAllocProcPtr)(uint32_t size); |  | ||||||
| typedef void         (*NPN_MemFreeProcPtr)(void* ptr); |  | ||||||
| typedef uint32_t     (*NPN_MemFlushProcPtr)(uint32_t size); |  | ||||||
| typedef void         (*NPN_ReloadPluginsProcPtr)(NPBool reloadPages); |  | ||||||
| typedef void*        (*NPN_GetJavaEnvProcPtr)(void); |  | ||||||
| typedef void*        (*NPN_GetJavaPeerProcPtr)(NPP instance); |  | ||||||
| typedef void         (*NPN_InvalidateRectProcPtr)(NPP instance, NPRect *rect); |  | ||||||
| typedef void         (*NPN_InvalidateRegionProcPtr)(NPP instance, NPRegion region); |  | ||||||
| typedef void         (*NPN_ForceRedrawProcPtr)(NPP instance); |  | ||||||
| typedef NPIdentifier (*NPN_GetStringIdentifierProcPtr)(const NPUTF8* name); |  | ||||||
| typedef void         (*NPN_GetStringIdentifiersProcPtr)(const NPUTF8** names, int32_t nameCount, NPIdentifier* identifiers); |  | ||||||
| typedef NPIdentifier (*NPN_GetIntIdentifierProcPtr)(int32_t intid); |  | ||||||
| typedef bool         (*NPN_IdentifierIsStringProcPtr)(NPIdentifier identifier); |  | ||||||
| typedef NPUTF8*      (*NPN_UTF8FromIdentifierProcPtr)(NPIdentifier identifier); |  | ||||||
| typedef int32_t      (*NPN_IntFromIdentifierProcPtr)(NPIdentifier identifier); |  | ||||||
| typedef NPObject*    (*NPN_CreateObjectProcPtr)(NPP npp, NPClass *aClass); |  | ||||||
| typedef NPObject*    (*NPN_RetainObjectProcPtr)(NPObject *obj); |  | ||||||
| typedef void         (*NPN_ReleaseObjectProcPtr)(NPObject *obj); |  | ||||||
| typedef bool         (*NPN_InvokeProcPtr)(NPP npp, NPObject* obj, NPIdentifier methodName, const NPVariant *args, uint32_t argCount, NPVariant *result); |  | ||||||
| typedef bool         (*NPN_InvokeDefaultProcPtr)(NPP npp, NPObject* obj, const NPVariant *args, uint32_t argCount, NPVariant *result); |  | ||||||
| typedef bool         (*NPN_EvaluateProcPtr)(NPP npp, NPObject *obj, NPString *script, NPVariant *result); |  | ||||||
| typedef bool         (*NPN_GetPropertyProcPtr)(NPP npp, NPObject *obj, NPIdentifier propertyName, NPVariant *result); |  | ||||||
| typedef bool         (*NPN_SetPropertyProcPtr)(NPP npp, NPObject *obj, NPIdentifier propertyName, const NPVariant *value); |  | ||||||
| typedef bool         (*NPN_RemovePropertyProcPtr)(NPP npp, NPObject *obj, NPIdentifier propertyName); |  | ||||||
| typedef bool         (*NPN_HasPropertyProcPtr)(NPP npp, NPObject *obj, NPIdentifier propertyName); |  | ||||||
| typedef bool         (*NPN_HasMethodProcPtr)(NPP npp, NPObject *obj, NPIdentifier propertyName); |  | ||||||
| typedef void         (*NPN_ReleaseVariantValueProcPtr)(NPVariant *variant); |  | ||||||
| typedef void         (*NPN_SetExceptionProcPtr)(NPObject *obj, const NPUTF8 *message); |  | ||||||
| typedef void         (*NPN_PushPopupsEnabledStateProcPtr)(NPP npp, NPBool enabled); |  | ||||||
| typedef void         (*NPN_PopPopupsEnabledStateProcPtr)(NPP npp); |  | ||||||
| typedef bool         (*NPN_EnumerateProcPtr)(NPP npp, NPObject *obj, NPIdentifier **identifier, uint32_t *count); |  | ||||||
| typedef void         (*NPN_PluginThreadAsyncCallProcPtr)(NPP instance, void (*func)(void *), void *userData); |  | ||||||
| typedef bool         (*NPN_ConstructProcPtr)(NPP npp, NPObject* obj, const NPVariant *args, uint32_t argCount, NPVariant *result); |  | ||||||
| typedef NPError      (*NPN_GetValueForURLPtr)(NPP npp, NPNURLVariable variable, const char *url, char **value, uint32_t *len); |  | ||||||
| typedef NPError      (*NPN_SetValueForURLPtr)(NPP npp, NPNURLVariable variable, const char *url, const char *value, uint32_t len); |  | ||||||
| typedef NPError      (*NPN_GetAuthenticationInfoPtr)(NPP npp, const char *protocol, const char *host, int32_t port, const char *scheme, const char *realm, char **username, uint32_t *ulen, char **password, uint32_t *plen); |  | ||||||
| typedef uint32_t     (*NPN_ScheduleTimerPtr)(NPP instance, uint32_t interval, NPBool repeat, void (*timerFunc)(NPP npp, uint32_t timerID)); |  | ||||||
| typedef void         (*NPN_UnscheduleTimerPtr)(NPP instance, uint32_t timerID); |  | ||||||
| typedef NPError      (*NPN_PopUpContextMenuPtr)(NPP instance, NPMenu* menu); |  | ||||||
| typedef NPBool       (*NPN_ConvertPointPtr)(NPP instance, double sourceX, double sourceY, NPCoordinateSpace sourceSpace, double *destX, double *destY, NPCoordinateSpace destSpace); |  | ||||||
| typedef NPBool       (*NPN_HandleEventPtr)(NPP instance, void *event, NPBool handled); |  | ||||||
| typedef NPBool       (*NPN_UnfocusInstancePtr)(NPP instance, NPFocusDirection direction); |  | ||||||
| typedef void         (*NPN_URLRedirectResponsePtr)(NPP instance, void* notifyData, NPBool allow); |  | ||||||
|  |  | ||||||
| typedef struct _NPPluginFuncs { |  | ||||||
|   uint16_t size; |  | ||||||
|   uint16_t version; |  | ||||||
|   NPP_NewProcPtr newp; |  | ||||||
|   NPP_DestroyProcPtr destroy; |  | ||||||
|   NPP_SetWindowProcPtr setwindow; |  | ||||||
|   NPP_NewStreamProcPtr newstream; |  | ||||||
|   NPP_DestroyStreamProcPtr destroystream; |  | ||||||
|   NPP_StreamAsFileProcPtr asfile; |  | ||||||
|   NPP_WriteReadyProcPtr writeready; |  | ||||||
|   NPP_WriteProcPtr write; |  | ||||||
|   NPP_PrintProcPtr print; |  | ||||||
|   NPP_HandleEventProcPtr event; |  | ||||||
|   NPP_URLNotifyProcPtr urlnotify; |  | ||||||
|   void* javaClass; |  | ||||||
|   NPP_GetValueProcPtr getvalue; |  | ||||||
|   NPP_SetValueProcPtr setvalue; |  | ||||||
|   NPP_GotFocusPtr gotfocus; |  | ||||||
|   NPP_LostFocusPtr lostfocus; |  | ||||||
|   NPP_URLRedirectNotifyPtr urlredirectnotify; |  | ||||||
|   NPP_ClearSiteDataPtr clearsitedata; |  | ||||||
|   NPP_GetSitesWithDataPtr getsiteswithdata; |  | ||||||
| } NPPluginFuncs; |  | ||||||
|  |  | ||||||
| typedef struct _NPNetscapeFuncs { |  | ||||||
|   uint16_t size; |  | ||||||
|   uint16_t version; |  | ||||||
|   NPN_GetURLProcPtr geturl; |  | ||||||
|   NPN_PostURLProcPtr posturl; |  | ||||||
|   NPN_RequestReadProcPtr requestread; |  | ||||||
|   NPN_NewStreamProcPtr newstream; |  | ||||||
|   NPN_WriteProcPtr write; |  | ||||||
|   NPN_DestroyStreamProcPtr destroystream; |  | ||||||
|   NPN_StatusProcPtr status; |  | ||||||
|   NPN_UserAgentProcPtr uagent; |  | ||||||
|   NPN_MemAllocProcPtr memalloc; |  | ||||||
|   NPN_MemFreeProcPtr memfree; |  | ||||||
|   NPN_MemFlushProcPtr memflush; |  | ||||||
|   NPN_ReloadPluginsProcPtr reloadplugins; |  | ||||||
|   NPN_GetJavaEnvProcPtr getJavaEnv; |  | ||||||
|   NPN_GetJavaPeerProcPtr getJavaPeer; |  | ||||||
|   NPN_GetURLNotifyProcPtr geturlnotify; |  | ||||||
|   NPN_PostURLNotifyProcPtr posturlnotify; |  | ||||||
|   NPN_GetValueProcPtr getvalue; |  | ||||||
|   NPN_SetValueProcPtr setvalue; |  | ||||||
|   NPN_InvalidateRectProcPtr invalidaterect; |  | ||||||
|   NPN_InvalidateRegionProcPtr invalidateregion; |  | ||||||
|   NPN_ForceRedrawProcPtr forceredraw; |  | ||||||
|   NPN_GetStringIdentifierProcPtr getstringidentifier; |  | ||||||
|   NPN_GetStringIdentifiersProcPtr getstringidentifiers; |  | ||||||
|   NPN_GetIntIdentifierProcPtr getintidentifier; |  | ||||||
|   NPN_IdentifierIsStringProcPtr identifierisstring; |  | ||||||
|   NPN_UTF8FromIdentifierProcPtr utf8fromidentifier; |  | ||||||
|   NPN_IntFromIdentifierProcPtr intfromidentifier; |  | ||||||
|   NPN_CreateObjectProcPtr createobject; |  | ||||||
|   NPN_RetainObjectProcPtr retainobject; |  | ||||||
|   NPN_ReleaseObjectProcPtr releaseobject; |  | ||||||
|   NPN_InvokeProcPtr invoke; |  | ||||||
|   NPN_InvokeDefaultProcPtr invokeDefault; |  | ||||||
|   NPN_EvaluateProcPtr evaluate; |  | ||||||
|   NPN_GetPropertyProcPtr getproperty; |  | ||||||
|   NPN_SetPropertyProcPtr setproperty; |  | ||||||
|   NPN_RemovePropertyProcPtr removeproperty; |  | ||||||
|   NPN_HasPropertyProcPtr hasproperty; |  | ||||||
|   NPN_HasMethodProcPtr hasmethod; |  | ||||||
|   NPN_ReleaseVariantValueProcPtr releasevariantvalue; |  | ||||||
|   NPN_SetExceptionProcPtr setexception; |  | ||||||
|   NPN_PushPopupsEnabledStateProcPtr pushpopupsenabledstate; |  | ||||||
|   NPN_PopPopupsEnabledStateProcPtr poppopupsenabledstate; |  | ||||||
|   NPN_EnumerateProcPtr enumerate; |  | ||||||
|   NPN_PluginThreadAsyncCallProcPtr pluginthreadasynccall; |  | ||||||
|   NPN_ConstructProcPtr construct; |  | ||||||
|   NPN_GetValueForURLPtr getvalueforurl; |  | ||||||
|   NPN_SetValueForURLPtr setvalueforurl; |  | ||||||
|   NPN_GetAuthenticationInfoPtr getauthenticationinfo; |  | ||||||
|   NPN_ScheduleTimerPtr scheduletimer; |  | ||||||
|   NPN_UnscheduleTimerPtr unscheduletimer; |  | ||||||
|   NPN_PopUpContextMenuPtr popupcontextmenu; |  | ||||||
|   NPN_ConvertPointPtr convertpoint; |  | ||||||
|   NPN_HandleEventPtr handleevent; |  | ||||||
|   NPN_UnfocusInstancePtr unfocusinstance; |  | ||||||
|   NPN_URLRedirectResponsePtr urlredirectresponse; |  | ||||||
| } NPNetscapeFuncs; |  | ||||||
|  |  | ||||||
| #ifdef XP_MACOSX |  | ||||||
| /* |  | ||||||
|  * Mac OS X version(s) of NP_GetMIMEDescription(const char *) |  | ||||||
|  * These can be called to retreive MIME information from the plugin dynamically |  | ||||||
|  * |  | ||||||
|  * Note: For compatibility with Quicktime, BPSupportedMIMEtypes is another way |  | ||||||
|  *       to get mime info from the plugin only on OSX and may not be supported |  | ||||||
|  *       in furture version -- use NP_GetMIMEDescription instead |  | ||||||
|  */ |  | ||||||
| enum |  | ||||||
| { |  | ||||||
|  kBPSupportedMIMETypesStructVers_1    = 1 |  | ||||||
| }; |  | ||||||
| typedef struct _BPSupportedMIMETypes |  | ||||||
| { |  | ||||||
|  SInt32    structVersion;      /* struct version */ |  | ||||||
|  Handle    typeStrings;        /* STR# formated handle, allocated by plug-in */ |  | ||||||
|  Handle    infoStrings;        /* STR# formated handle, allocated by plug-in */ |  | ||||||
| } BPSupportedMIMETypes; |  | ||||||
| OSErr BP_GetSupportedMIMETypes(BPSupportedMIMETypes *mimeInfo, UInt32 flags); |  | ||||||
| #define NP_GETMIMEDESCRIPTION_NAME "NP_GetMIMEDescription" |  | ||||||
| typedef const char* (*NP_GetMIMEDescriptionProcPtr)(void); |  | ||||||
| typedef OSErr (*BP_GetSupportedMIMETypesProcPtr)(BPSupportedMIMETypes*, UInt32); |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(_WIN32) |  | ||||||
| #define OSCALL WINAPI |  | ||||||
| #else |  | ||||||
| #if defined(__OS2__) |  | ||||||
| #define OSCALL _System |  | ||||||
| #else |  | ||||||
| #define OSCALL |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(XP_UNIX) |  | ||||||
| /* GCC 3.3 and later support the visibility attribute. */ |  | ||||||
| #if defined(__GNUC__) && ((__GNUC__ >= 4) || (__GNUC__ == 3 && __GNUC_MINOR__ >= 3)) |  | ||||||
| #define NP_VISIBILITY_DEFAULT __attribute__((visibility("default"))) |  | ||||||
| #elif defined(__SUNPRO_C) || defined(__SUNPRO_CC) |  | ||||||
| #define NP_VISIBILITY_DEFAULT __global |  | ||||||
| #else |  | ||||||
| #define NP_VISIBILITY_DEFAULT |  | ||||||
| #endif |  | ||||||
| #define NP_EXPORT(__type) NP_VISIBILITY_DEFAULT __type |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(_WIN32) || defined (__OS2__) |  | ||||||
| #ifdef __cplusplus |  | ||||||
| extern "C" { |  | ||||||
| #endif |  | ||||||
| /* plugin meta member functions */ |  | ||||||
| #if defined(__OS2__) |  | ||||||
| typedef struct _NPPluginData {   /* Alternate OS2 Plugin interface */ |  | ||||||
|   char *pMimeTypes; |  | ||||||
|   char *pFileExtents; |  | ||||||
|   char *pFileOpenTemplate; |  | ||||||
|   char *pProductName; |  | ||||||
|   char *pProductDescription; |  | ||||||
|   unsigned long dwProductVersionMS; |  | ||||||
|   unsigned long dwProductVersionLS; |  | ||||||
| } NPPluginData; |  | ||||||
| typedef NPError     (*NP_GetPluginDataFunc)(NPPluginData*); |  | ||||||
| NPError OSCALL      NP_GetPluginData(NPPluginData * pPluginData); |  | ||||||
| #endif |  | ||||||
| typedef NPError     (*NP_GetEntryPointsFunc)(NPPluginFuncs*); |  | ||||||
| NPError OSCALL      NP_GetEntryPoints(NPPluginFuncs* pFuncs); |  | ||||||
| typedef NPError     (*NP_InitializeFunc)(NPNetscapeFuncs*); |  | ||||||
| NPError OSCALL      NP_Initialize(NPNetscapeFuncs* bFuncs); |  | ||||||
| typedef NPError     (*NP_ShutdownFunc)(void); |  | ||||||
| NPError OSCALL      NP_Shutdown(void); |  | ||||||
| typedef const char* (*NP_GetMIMEDescriptionFunc)(void); |  | ||||||
| const char*         NP_GetMIMEDescription(void); |  | ||||||
| #ifdef __cplusplus |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(__OS2__) |  | ||||||
| #pragma pack() |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #ifdef XP_UNIX |  | ||||||
| #ifdef __cplusplus |  | ||||||
| extern "C" { |  | ||||||
| #endif |  | ||||||
| typedef char*          (*NP_GetPluginVersionFunc)(void); |  | ||||||
| NP_EXPORT(char*)       NP_GetPluginVersion(void); |  | ||||||
| typedef const char*    (*NP_GetMIMEDescriptionFunc)(void); |  | ||||||
| NP_EXPORT(const char*) NP_GetMIMEDescription(void); |  | ||||||
| #ifdef XP_MACOSX |  | ||||||
| typedef NPError        (*NP_InitializeFunc)(NPNetscapeFuncs*); |  | ||||||
| NP_EXPORT(NPError)     NP_Initialize(NPNetscapeFuncs* bFuncs); |  | ||||||
| typedef NPError        (*NP_GetEntryPointsFunc)(NPPluginFuncs*); |  | ||||||
| NP_EXPORT(NPError)     NP_GetEntryPoints(NPPluginFuncs* pFuncs); |  | ||||||
| #else |  | ||||||
| typedef NPError        (*NP_InitializeFunc)(NPNetscapeFuncs*, NPPluginFuncs*); |  | ||||||
| NP_EXPORT(NPError)     NP_Initialize(NPNetscapeFuncs* bFuncs, NPPluginFuncs* pFuncs); |  | ||||||
| #endif |  | ||||||
| typedef NPError        (*NP_ShutdownFunc)(void); |  | ||||||
| NP_EXPORT(NPError)     NP_Shutdown(void); |  | ||||||
| typedef NPError        (*NP_GetValueFunc)(void *, NPPVariable, void *); |  | ||||||
| NP_EXPORT(NPError)     NP_GetValue(void *future, NPPVariable aVariable, void *aValue); |  | ||||||
| #ifdef __cplusplus |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif /* npfunctions_h_ */ |  | ||||||
| @@ -1,393 +0,0 @@ | |||||||
| /* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ |  | ||||||
| /* |  | ||||||
|  * Copyright (c) 2004, Apple Computer, Inc. and The Mozilla Foundation. |  | ||||||
|  * All rights reserved. |  | ||||||
|  * |  | ||||||
|  * Redistribution and use in source and binary forms, with or without |  | ||||||
|  * modification, are permitted provided that the following conditions are |  | ||||||
|  * met: |  | ||||||
|  * |  | ||||||
|  * 1. Redistributions of source code must retain the above copyright |  | ||||||
|  * notice, this list of conditions and the following disclaimer. |  | ||||||
|  * 2. Redistributions in binary form must reproduce the above copyright |  | ||||||
|  * notice, this list of conditions and the following disclaimer in the |  | ||||||
|  * documentation and/or other materials provided with the distribution. |  | ||||||
|  * 3. Neither the names of Apple Computer, Inc. ("Apple") or The Mozilla |  | ||||||
|  * Foundation ("Mozilla") nor the names of their contributors may be used |  | ||||||
|  * to endorse or promote products derived from this software without |  | ||||||
|  * specific prior written permission. |  | ||||||
|  * |  | ||||||
|  * THIS SOFTWARE IS PROVIDED BY APPLE, MOZILLA AND THEIR CONTRIBUTORS "AS |  | ||||||
|  * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED |  | ||||||
|  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A |  | ||||||
|  * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE, MOZILLA OR |  | ||||||
|  * THEIR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |  | ||||||
|  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED |  | ||||||
|  * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |  | ||||||
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF |  | ||||||
|  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING |  | ||||||
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |  | ||||||
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  | ||||||
|  * |  | ||||||
|  */ |  | ||||||
| #ifndef _NP_RUNTIME_H_ |  | ||||||
| #define _NP_RUNTIME_H_ |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus |  | ||||||
| extern "C" { |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #include "nptypes.h" |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     This API is used to facilitate binding code written in C to script |  | ||||||
|     objects.  The API in this header does not assume the presence of a |  | ||||||
|     user agent.  That is, it can be used to bind C code to scripting |  | ||||||
|     environments outside of the context of a user agent. |  | ||||||
|  |  | ||||||
|     However, the normal use of the this API is in the context of a |  | ||||||
|     scripting environment running in a browser or other user agent. |  | ||||||
|     In particular it is used to support the extended Netscape |  | ||||||
|     script-ability API for plugins (NP-SAP).  NP-SAP is an extension |  | ||||||
|     of the Netscape plugin API.  As such we have adopted the use of |  | ||||||
|     the "NP" prefix for this API. |  | ||||||
|  |  | ||||||
|     The following NP{N|P}Variables were added to the Netscape plugin |  | ||||||
|     API (in npapi.h): |  | ||||||
|  |  | ||||||
|     NPNVWindowNPObject |  | ||||||
|     NPNVPluginElementNPObject |  | ||||||
|     NPPVpluginScriptableNPObject |  | ||||||
|  |  | ||||||
|     These variables are exposed through NPN_GetValue() and |  | ||||||
|     NPP_GetValue() (respectively) and are used to establish the |  | ||||||
|     initial binding between the user agent and native code.  The DOM |  | ||||||
|     objects in the user agent can be examined and manipulated using |  | ||||||
|     the NPN_ functions that operate on NPObjects described in this |  | ||||||
|     header. |  | ||||||
|  |  | ||||||
|     To the extent possible the assumptions about the scripting |  | ||||||
|     language used by the scripting environment have been minimized. |  | ||||||
| */ |  | ||||||
|  |  | ||||||
| #define NP_BEGIN_MACRO  do { |  | ||||||
| #define NP_END_MACRO    } while (0) |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     Objects (non-primitive data) passed between 'C' and script is |  | ||||||
|     always wrapped in an NPObject.  The 'interface' of an NPObject is |  | ||||||
|     described by an NPClass. |  | ||||||
| */ |  | ||||||
| typedef struct NPObject NPObject; |  | ||||||
| typedef struct NPClass NPClass; |  | ||||||
|  |  | ||||||
| typedef char NPUTF8; |  | ||||||
| typedef struct _NPString { |  | ||||||
|     const NPUTF8 *UTF8Characters; |  | ||||||
|     uint32_t UTF8Length; |  | ||||||
| } NPString; |  | ||||||
|  |  | ||||||
| typedef enum { |  | ||||||
|     NPVariantType_Void, |  | ||||||
|     NPVariantType_Null, |  | ||||||
|     NPVariantType_Bool, |  | ||||||
|     NPVariantType_Int32, |  | ||||||
|     NPVariantType_Double, |  | ||||||
|     NPVariantType_String, |  | ||||||
|     NPVariantType_Object |  | ||||||
| } NPVariantType; |  | ||||||
|  |  | ||||||
| typedef struct _NPVariant { |  | ||||||
|     NPVariantType type; |  | ||||||
|     union { |  | ||||||
|         bool boolValue; |  | ||||||
|         int32_t intValue; |  | ||||||
|         double doubleValue; |  | ||||||
|         NPString stringValue; |  | ||||||
|         NPObject *objectValue; |  | ||||||
|     } value; |  | ||||||
| } NPVariant; |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     NPN_ReleaseVariantValue is called on all 'out' parameters |  | ||||||
|     references.  Specifically it is to be called on variants that own |  | ||||||
|     their value, as is the case with all non-const NPVariant* |  | ||||||
|     arguments after a successful call to any methods (except this one) |  | ||||||
|     in this API. |  | ||||||
|  |  | ||||||
|     After calling NPN_ReleaseVariantValue, the type of the variant |  | ||||||
|     will be NPVariantType_Void. |  | ||||||
| */ |  | ||||||
| void NPN_ReleaseVariantValue(NPVariant *variant); |  | ||||||
|  |  | ||||||
| #define NPVARIANT_IS_VOID(_v)    ((_v).type == NPVariantType_Void) |  | ||||||
| #define NPVARIANT_IS_NULL(_v)    ((_v).type == NPVariantType_Null) |  | ||||||
| #define NPVARIANT_IS_BOOLEAN(_v) ((_v).type == NPVariantType_Bool) |  | ||||||
| #define NPVARIANT_IS_INT32(_v)   ((_v).type == NPVariantType_Int32) |  | ||||||
| #define NPVARIANT_IS_DOUBLE(_v)  ((_v).type == NPVariantType_Double) |  | ||||||
| #define NPVARIANT_IS_STRING(_v)  ((_v).type == NPVariantType_String) |  | ||||||
| #define NPVARIANT_IS_OBJECT(_v)  ((_v).type == NPVariantType_Object) |  | ||||||
|  |  | ||||||
| #define NPVARIANT_TO_BOOLEAN(_v) ((_v).value.boolValue) |  | ||||||
| #define NPVARIANT_TO_INT32(_v)   ((_v).value.intValue) |  | ||||||
| #define NPVARIANT_TO_DOUBLE(_v)  ((_v).value.doubleValue) |  | ||||||
| #define NPVARIANT_TO_STRING(_v)  ((_v).value.stringValue) |  | ||||||
| #define NPVARIANT_TO_OBJECT(_v)  ((_v).value.objectValue) |  | ||||||
|  |  | ||||||
| #define VOID_TO_NPVARIANT(_v)                                                 \ |  | ||||||
| NP_BEGIN_MACRO                                                                \ |  | ||||||
|     (_v).type = NPVariantType_Void;                                           \ |  | ||||||
|     (_v).value.objectValue = NULL;                                            \ |  | ||||||
| NP_END_MACRO |  | ||||||
|  |  | ||||||
| #define NULL_TO_NPVARIANT(_v)                                                 \ |  | ||||||
| NP_BEGIN_MACRO                                                                \ |  | ||||||
|     (_v).type = NPVariantType_Null;                                           \ |  | ||||||
|     (_v).value.objectValue = NULL;                                            \ |  | ||||||
| NP_END_MACRO |  | ||||||
|  |  | ||||||
| #define BOOLEAN_TO_NPVARIANT(_val, _v)                                        \ |  | ||||||
| NP_BEGIN_MACRO                                                                \ |  | ||||||
|     (_v).type = NPVariantType_Bool;                                           \ |  | ||||||
|     (_v).value.boolValue = !!(_val);                                          \ |  | ||||||
| NP_END_MACRO |  | ||||||
|  |  | ||||||
| #define INT32_TO_NPVARIANT(_val, _v)                                          \ |  | ||||||
| NP_BEGIN_MACRO                                                                \ |  | ||||||
|     (_v).type = NPVariantType_Int32;                                          \ |  | ||||||
|     (_v).value.intValue = _val;                                               \ |  | ||||||
| NP_END_MACRO |  | ||||||
|  |  | ||||||
| #define DOUBLE_TO_NPVARIANT(_val, _v)                                         \ |  | ||||||
| NP_BEGIN_MACRO                                                                \ |  | ||||||
|     (_v).type = NPVariantType_Double;                                         \ |  | ||||||
|     (_v).value.doubleValue = _val;                                            \ |  | ||||||
| NP_END_MACRO |  | ||||||
|  |  | ||||||
| #define STRINGZ_TO_NPVARIANT(_val, _v)                                        \ |  | ||||||
| NP_BEGIN_MACRO                                                                \ |  | ||||||
|     (_v).type = NPVariantType_String;                                         \ |  | ||||||
|     NPString str = { _val, (uint32_t)(strlen(_val)) };                        \ |  | ||||||
|     (_v).value.stringValue = str;                                             \ |  | ||||||
| NP_END_MACRO |  | ||||||
|  |  | ||||||
| #define STRINGN_TO_NPVARIANT(_val, _len, _v)                                  \ |  | ||||||
| NP_BEGIN_MACRO                                                                \ |  | ||||||
|     (_v).type = NPVariantType_String;                                         \ |  | ||||||
|     NPString str = { _val, (uint32_t)(_len) };                                \ |  | ||||||
|     (_v).value.stringValue = str;                                             \ |  | ||||||
| NP_END_MACRO |  | ||||||
|  |  | ||||||
| #define OBJECT_TO_NPVARIANT(_val, _v)                                         \ |  | ||||||
| NP_BEGIN_MACRO                                                                \ |  | ||||||
|     (_v).type = NPVariantType_Object;                                         \ |  | ||||||
|     (_v).value.objectValue = _val;                                            \ |  | ||||||
| NP_END_MACRO |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|   Type mappings (JavaScript types have been used for illustration |  | ||||||
|     purposes): |  | ||||||
|  |  | ||||||
|   JavaScript       to             C (NPVariant with type:) |  | ||||||
|   undefined                       NPVariantType_Void |  | ||||||
|   null                            NPVariantType_Null |  | ||||||
|   Boolean                         NPVariantType_Bool |  | ||||||
|   Number                          NPVariantType_Double or NPVariantType_Int32 |  | ||||||
|   String                          NPVariantType_String |  | ||||||
|   Object                          NPVariantType_Object |  | ||||||
|  |  | ||||||
|   C (NPVariant with type:)   to   JavaScript |  | ||||||
|   NPVariantType_Void              undefined |  | ||||||
|   NPVariantType_Null              null |  | ||||||
|   NPVariantType_Bool              Boolean |  | ||||||
|   NPVariantType_Int32             Number |  | ||||||
|   NPVariantType_Double            Number |  | ||||||
|   NPVariantType_String            String |  | ||||||
|   NPVariantType_Object            Object |  | ||||||
| */ |  | ||||||
|  |  | ||||||
| typedef void *NPIdentifier; |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     NPObjects have methods and properties.  Methods and properties are |  | ||||||
|     identified with NPIdentifiers.  These identifiers may be reflected |  | ||||||
|     in script.  NPIdentifiers can be either strings or integers, IOW, |  | ||||||
|     methods and properties can be identified by either strings or |  | ||||||
|     integers (i.e. foo["bar"] vs foo[1]). NPIdentifiers can be |  | ||||||
|     compared using ==.  In case of any errors, the requested |  | ||||||
|     NPIdentifier(s) will be NULL. NPIdentifier lifetime is controlled |  | ||||||
|     by the browser. Plugins do not need to worry about memory management |  | ||||||
|     with regards to NPIdentifiers. |  | ||||||
| */ |  | ||||||
| NPIdentifier NPN_GetStringIdentifier(const NPUTF8 *name); |  | ||||||
| void NPN_GetStringIdentifiers(const NPUTF8 **names, int32_t nameCount, |  | ||||||
|                               NPIdentifier *identifiers); |  | ||||||
| NPIdentifier NPN_GetIntIdentifier(int32_t intid); |  | ||||||
| bool NPN_IdentifierIsString(NPIdentifier identifier); |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     The NPUTF8 returned from NPN_UTF8FromIdentifier SHOULD be freed. |  | ||||||
| */ |  | ||||||
| NPUTF8 *NPN_UTF8FromIdentifier(NPIdentifier identifier); |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     Get the integer represented by identifier. If identifier is not an |  | ||||||
|     integer identifier, the behaviour is undefined. |  | ||||||
| */ |  | ||||||
| int32_t NPN_IntFromIdentifier(NPIdentifier identifier); |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     NPObject behavior is implemented using the following set of |  | ||||||
|     callback functions. |  | ||||||
|  |  | ||||||
|     The NPVariant *result argument of these functions (where |  | ||||||
|     applicable) should be released using NPN_ReleaseVariantValue(). |  | ||||||
| */ |  | ||||||
| typedef NPObject *(*NPAllocateFunctionPtr)(NPP npp, NPClass *aClass); |  | ||||||
| typedef void (*NPDeallocateFunctionPtr)(NPObject *npobj); |  | ||||||
| typedef void (*NPInvalidateFunctionPtr)(NPObject *npobj); |  | ||||||
| typedef bool (*NPHasMethodFunctionPtr)(NPObject *npobj, NPIdentifier name); |  | ||||||
| typedef bool (*NPInvokeFunctionPtr)(NPObject *npobj, NPIdentifier name, |  | ||||||
|                                     const NPVariant *args, uint32_t argCount, |  | ||||||
|                                     NPVariant *result); |  | ||||||
| typedef bool (*NPInvokeDefaultFunctionPtr)(NPObject *npobj, |  | ||||||
|                                            const NPVariant *args, |  | ||||||
|                                            uint32_t argCount, |  | ||||||
|                                            NPVariant *result); |  | ||||||
| typedef bool (*NPHasPropertyFunctionPtr)(NPObject *npobj, NPIdentifier name); |  | ||||||
| typedef bool (*NPGetPropertyFunctionPtr)(NPObject *npobj, NPIdentifier name, |  | ||||||
|                                          NPVariant *result); |  | ||||||
| typedef bool (*NPSetPropertyFunctionPtr)(NPObject *npobj, NPIdentifier name, |  | ||||||
|                                          const NPVariant *value); |  | ||||||
| typedef bool (*NPRemovePropertyFunctionPtr)(NPObject *npobj, |  | ||||||
|                                             NPIdentifier name); |  | ||||||
| typedef bool (*NPEnumerationFunctionPtr)(NPObject *npobj, NPIdentifier **value, |  | ||||||
|                                          uint32_t *count); |  | ||||||
| typedef bool (*NPConstructFunctionPtr)(NPObject *npobj, |  | ||||||
|                                        const NPVariant *args, |  | ||||||
|                                        uint32_t argCount, |  | ||||||
|                                        NPVariant *result); |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     NPObjects returned by create, retain, invoke, and getProperty pass |  | ||||||
|     a reference count to the caller.  That is, the callee adds a |  | ||||||
|     reference count which passes to the caller.  It is the caller's |  | ||||||
|     responsibility to release the returned object. |  | ||||||
|  |  | ||||||
|     NPInvokeFunctionPtr function may return 0 to indicate a void |  | ||||||
|     result. |  | ||||||
|  |  | ||||||
|     NPInvalidateFunctionPtr is called by the scripting environment |  | ||||||
|     when the native code is shutdown.  Any attempt to message a |  | ||||||
|     NPObject instance after the invalidate callback has been |  | ||||||
|     called will result in undefined behavior, even if the native code |  | ||||||
|     is still retaining those NPObject instances.  (The runtime |  | ||||||
|     will typically return immediately, with 0 or NULL, from an attempt |  | ||||||
|     to dispatch to a NPObject, but this behavior should not be |  | ||||||
|     depended upon.) |  | ||||||
|  |  | ||||||
|     The NPEnumerationFunctionPtr function may pass an array of |  | ||||||
|     NPIdentifiers back to the caller. The callee allocs the memory of |  | ||||||
|     the array using NPN_MemAlloc(), and it's the caller's responsibility |  | ||||||
|     to release it using NPN_MemFree(). |  | ||||||
| */ |  | ||||||
| struct NPClass |  | ||||||
| { |  | ||||||
|     uint32_t structVersion; |  | ||||||
|     NPAllocateFunctionPtr allocate; |  | ||||||
|     NPDeallocateFunctionPtr deallocate; |  | ||||||
|     NPInvalidateFunctionPtr invalidate; |  | ||||||
|     NPHasMethodFunctionPtr hasMethod; |  | ||||||
|     NPInvokeFunctionPtr invoke; |  | ||||||
|     NPInvokeDefaultFunctionPtr invokeDefault; |  | ||||||
|     NPHasPropertyFunctionPtr hasProperty; |  | ||||||
|     NPGetPropertyFunctionPtr getProperty; |  | ||||||
|     NPSetPropertyFunctionPtr setProperty; |  | ||||||
|     NPRemovePropertyFunctionPtr removeProperty; |  | ||||||
|     NPEnumerationFunctionPtr enumerate; |  | ||||||
|     NPConstructFunctionPtr construct; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| #define NP_CLASS_STRUCT_VERSION      3 |  | ||||||
|  |  | ||||||
| #define NP_CLASS_STRUCT_VERSION_ENUM 2 |  | ||||||
| #define NP_CLASS_STRUCT_VERSION_CTOR 3 |  | ||||||
|  |  | ||||||
| #define NP_CLASS_STRUCT_VERSION_HAS_ENUM(npclass)   \ |  | ||||||
|         ((npclass)->structVersion >= NP_CLASS_STRUCT_VERSION_ENUM) |  | ||||||
|  |  | ||||||
| #define NP_CLASS_STRUCT_VERSION_HAS_CTOR(npclass)   \ |  | ||||||
|         ((npclass)->structVersion >= NP_CLASS_STRUCT_VERSION_CTOR) |  | ||||||
|  |  | ||||||
| struct NPObject { |  | ||||||
|     NPClass *_class; |  | ||||||
|     uint32_t referenceCount; |  | ||||||
|     /* |  | ||||||
|      * Additional space may be allocated here by types of NPObjects |  | ||||||
|      */ |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     If the class has an allocate function, NPN_CreateObject invokes |  | ||||||
|     that function, otherwise a NPObject is allocated and |  | ||||||
|     returned. This method will initialize the referenceCount member of |  | ||||||
|     the NPObject to 1. |  | ||||||
| */ |  | ||||||
| NPObject *NPN_CreateObject(NPP npp, NPClass *aClass); |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     Increment the NPObject's reference count. |  | ||||||
| */ |  | ||||||
| NPObject *NPN_RetainObject(NPObject *npobj); |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     Decremented the NPObject's reference count.  If the reference |  | ||||||
|     count goes to zero, the class's destroy function is invoke if |  | ||||||
|     specified, otherwise the object is freed directly. |  | ||||||
| */ |  | ||||||
| void NPN_ReleaseObject(NPObject *npobj); |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     Functions to access script objects represented by NPObject. |  | ||||||
|  |  | ||||||
|     Calls to script objects are synchronous.  If a function returns a |  | ||||||
|     value, it will be supplied via the result NPVariant |  | ||||||
|     argument. Successful calls will return true, false will be |  | ||||||
|     returned in case of an error. |  | ||||||
|  |  | ||||||
|     Calls made from plugin code to script must be made from the thread |  | ||||||
|     on which the plugin was initialized. |  | ||||||
| */ |  | ||||||
|  |  | ||||||
| bool NPN_Invoke(NPP npp, NPObject *npobj, NPIdentifier methodName, |  | ||||||
|                 const NPVariant *args, uint32_t argCount, NPVariant *result); |  | ||||||
| bool NPN_InvokeDefault(NPP npp, NPObject *npobj, const NPVariant *args, |  | ||||||
|                        uint32_t argCount, NPVariant *result); |  | ||||||
| bool NPN_Evaluate(NPP npp, NPObject *npobj, NPString *script, |  | ||||||
|                   NPVariant *result); |  | ||||||
| bool NPN_GetProperty(NPP npp, NPObject *npobj, NPIdentifier propertyName, |  | ||||||
|                      NPVariant *result); |  | ||||||
| bool NPN_SetProperty(NPP npp, NPObject *npobj, NPIdentifier propertyName, |  | ||||||
|                      const NPVariant *value); |  | ||||||
| bool NPN_RemoveProperty(NPP npp, NPObject *npobj, NPIdentifier propertyName); |  | ||||||
| bool NPN_HasProperty(NPP npp, NPObject *npobj, NPIdentifier propertyName); |  | ||||||
| bool NPN_HasMethod(NPP npp, NPObject *npobj, NPIdentifier methodName); |  | ||||||
| bool NPN_Enumerate(NPP npp, NPObject *npobj, NPIdentifier **identifier, |  | ||||||
|                    uint32_t *count); |  | ||||||
| bool NPN_Construct(NPP npp, NPObject *npobj, const NPVariant *args, |  | ||||||
|                    uint32_t argCount, NPVariant *result); |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|     NPN_SetException may be called to trigger a script exception upon |  | ||||||
|     return from entry points into NPObjects.  Typical usage: |  | ||||||
|  |  | ||||||
|     NPN_SetException (npobj, message); |  | ||||||
| */ |  | ||||||
| void NPN_SetException(NPObject *npobj, const NPUTF8 *message); |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif |  | ||||||
| @@ -1,121 +0,0 @@ | |||||||
| /* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ |  | ||||||
| /* ***** BEGIN LICENSE BLOCK ***** |  | ||||||
|  * Version: MPL 1.1/GPL 2.0/LGPL 2.1 |  | ||||||
|  * |  | ||||||
|  * The contents of this file are subject to the Mozilla Public License Version |  | ||||||
|  * 1.1 (the "License"); you may not use this file except in compliance with |  | ||||||
|  * the License. You may obtain a copy of the License at |  | ||||||
|  * http://www.mozilla.org/MPL/ |  | ||||||
|  * |  | ||||||
|  * Software distributed under the License is distributed on an "AS IS" basis, |  | ||||||
|  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License |  | ||||||
|  * for the specific language governing rights and limitations under the |  | ||||||
|  * License. |  | ||||||
|  * |  | ||||||
|  * The Original Code is mozilla.org code. |  | ||||||
|  * |  | ||||||
|  * The Initial Developer of the Original Code is |  | ||||||
|  * mozilla.org. |  | ||||||
|  * Portions created by the Initial Developer are Copyright (C) 2004 |  | ||||||
|  * the Initial Developer. All Rights Reserved. |  | ||||||
|  * |  | ||||||
|  * Contributor(s): |  | ||||||
|  *   Johnny Stenback <jst@mozilla.org> (Original author) |  | ||||||
|  * |  | ||||||
|  * Alternatively, the contents of this file may be used under the terms of |  | ||||||
|  * either the GNU General Public License Version 2 or later (the "GPL"), or |  | ||||||
|  * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), |  | ||||||
|  * in which case the provisions of the GPL or the LGPL are applicable instead |  | ||||||
|  * of those above. If you wish to allow use of your version of this file only |  | ||||||
|  * under the terms of either the GPL or the LGPL, and not to allow others to |  | ||||||
|  * use your version of this file under the terms of the MPL, indicate your |  | ||||||
|  * decision by deleting the provisions above and replace them with the notice |  | ||||||
|  * and other provisions required by the GPL or the LGPL. If you do not delete |  | ||||||
|  * the provisions above, a recipient may use your version of this file under |  | ||||||
|  * the terms of any one of the MPL, the GPL or the LGPL. |  | ||||||
|  * |  | ||||||
|  * ***** END LICENSE BLOCK ***** */ |  | ||||||
|  |  | ||||||
| #ifndef nptypes_h_ |  | ||||||
| #define nptypes_h_ |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * Header file for ensuring that C99 types ([u]int32_t, [u]int64_t and bool) and |  | ||||||
|  * true/false macros are available. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| #if defined(WIN32) || defined(OS2) |  | ||||||
|   /* |  | ||||||
|    * Win32 and OS/2 don't know C99, so define [u]int_16/32/64 here. The bool |  | ||||||
|    * is predefined tho, both in C and C++. |  | ||||||
|    */ |  | ||||||
|   typedef short int16_t; |  | ||||||
|   typedef unsigned short uint16_t; |  | ||||||
|   typedef int int32_t; |  | ||||||
|   typedef unsigned int uint32_t; |  | ||||||
|   typedef long long int64_t; |  | ||||||
|   typedef unsigned long long uint64_t; |  | ||||||
| #elif defined(_AIX) || defined(__sun) || defined(__osf__) || defined(IRIX) || defined(HPUX) |  | ||||||
|   /* |  | ||||||
|    * AIX and SunOS ship a inttypes.h header that defines [u]int32_t, |  | ||||||
|    * but not bool for C. |  | ||||||
|    */ |  | ||||||
|   #include <inttypes.h> |  | ||||||
|  |  | ||||||
|   #ifndef __cplusplus |  | ||||||
|     typedef int bool; |  | ||||||
|     #define true   1 |  | ||||||
|     #define false  0 |  | ||||||
|   #endif |  | ||||||
| #elif defined(bsdi) || defined(FREEBSD) || defined(OPENBSD) |  | ||||||
|   /* |  | ||||||
|    * BSD/OS, FreeBSD, and OpenBSD ship sys/types.h that define int32_t and |  | ||||||
|    * u_int32_t. |  | ||||||
|    */ |  | ||||||
|   #include <sys/types.h> |  | ||||||
|  |  | ||||||
|   /* |  | ||||||
|    * BSD/OS ships no header that defines uint32_t, nor bool (for C) |  | ||||||
|    */ |  | ||||||
|   #if defined(bsdi) |  | ||||||
|   typedef u_int32_t uint32_t; |  | ||||||
|   typedef u_int64_t uint64_t; |  | ||||||
|  |  | ||||||
|   #if !defined(__cplusplus) |  | ||||||
|     typedef int bool; |  | ||||||
|     #define true   1 |  | ||||||
|     #define false  0 |  | ||||||
|   #endif |  | ||||||
|   #else |  | ||||||
|   /* |  | ||||||
|    * FreeBSD and OpenBSD define uint32_t and bool. |  | ||||||
|    */ |  | ||||||
|     #include <inttypes.h> |  | ||||||
|     #include <stdbool.h> |  | ||||||
|   #endif |  | ||||||
| #elif defined(BEOS) |  | ||||||
|   #include <inttypes.h> |  | ||||||
| #else |  | ||||||
|   /* |  | ||||||
|    * For those that ship a standard C99 stdint.h header file, include |  | ||||||
|    * it. Can't do the same for stdbool.h tho, since some systems ship |  | ||||||
|    * with a stdbool.h file that doesn't compile! |  | ||||||
|    */ |  | ||||||
|   #include <stdint.h> |  | ||||||
|  |  | ||||||
|   #ifndef __cplusplus |  | ||||||
|     #if !defined(__GNUC__) || (__GNUC__ > 2 || __GNUC_MINOR__ > 95) |  | ||||||
|       #include <stdbool.h> |  | ||||||
|     #else |  | ||||||
|       /* |  | ||||||
|        * GCC 2.91 can't deal with a typedef for bool, but a #define |  | ||||||
|        * works. |  | ||||||
|        */ |  | ||||||
|       #define bool int |  | ||||||
|       #define true   1 |  | ||||||
|       #define false  0 |  | ||||||
|     #endif |  | ||||||
|   #endif |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif /* nptypes_h_ */ |  | ||||||
							
								
								
									
										208
									
								
								cldr2json.py
									
									
									
									
									
										Executable file
									
								
							
							
						
						| @@ -0,0 +1,208 @@ | |||||||
|  | #!/usr/bin/python3 | ||||||
|  | # | ||||||
|  | # Copyright 2015  Daiki Ueno <dueno@src.gnome.org> | ||||||
|  | #           2016  Parag Nemade <pnemade@redhat.com> | ||||||
|  | #           2017  Alan <alan@boum.org> | ||||||
|  | # | ||||||
|  | # This program is free software; you can redistribute it and/or modify | ||||||
|  | # it under the terms of the GNU Lesser 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 | ||||||
|  | # Lesser General Public License for more details. | ||||||
|  | # | ||||||
|  | # You should have received a copy of the GNU Lesser General Public | ||||||
|  | # License along with this program; if not, see | ||||||
|  | # <http://www.gnu.org/licenses/>. | ||||||
|  |  | ||||||
|  | import glob | ||||||
|  | import json | ||||||
|  | import locale | ||||||
|  | import logging | ||||||
|  | import os | ||||||
|  | import re | ||||||
|  | import sys | ||||||
|  | import xml.etree.ElementTree | ||||||
|  |  | ||||||
|  | import gi | ||||||
|  | gi.require_version('GnomeDesktop', '3.0')   # NOQA: E402 | ||||||
|  | from gi.repository import GnomeDesktop | ||||||
|  |  | ||||||
|  | ESCAPE_PATTERN = re.compile(r'\\u\{([0-9A-Fa-f]+?)\}') | ||||||
|  | ISO_PATTERN = re.compile(r'[A-E]([0-9]+)') | ||||||
|  |  | ||||||
|  | LOCALE_TO_XKB_OVERRIDES = { | ||||||
|  |     'af':    'za', | ||||||
|  |     'en':    'us', | ||||||
|  |     'en-GB': 'uk', | ||||||
|  |     'es-US': 'latam', | ||||||
|  |     'fr-CA': 'ca', | ||||||
|  |     'hi':    'in+bolnagri', | ||||||
|  |     'ky':    'kg', | ||||||
|  |     'nl-BE': 'be', | ||||||
|  |     'zu':    None | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def parse_single_key(value): | ||||||
|  |     def unescape(m): | ||||||
|  |         return chr(int(m.group(1), 16)) | ||||||
|  |     value = ESCAPE_PATTERN.sub(unescape, value) | ||||||
|  |     return value | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def parse_rows(keymap): | ||||||
|  |     unsorted_rows = {} | ||||||
|  |     for _map in keymap.iter('map'): | ||||||
|  |         value = _map.get('to') | ||||||
|  |         key = [parse_single_key(value)] | ||||||
|  |         iso = _map.get('iso') | ||||||
|  |         if not ISO_PATTERN.match(iso): | ||||||
|  |             sys.stderr.write('invalid ISO key name: %s\n' % iso) | ||||||
|  |             continue | ||||||
|  |         if not iso[0] in unsorted_rows: | ||||||
|  |             unsorted_rows[iso[0]] = [] | ||||||
|  |         unsorted_rows[iso[0]].append((int(iso[1:]), key)) | ||||||
|  |         # add subkeys | ||||||
|  |         longPress = _map.get('longPress') | ||||||
|  |         if longPress: | ||||||
|  |             for value in longPress.split(' '): | ||||||
|  |                 subkey = parse_single_key(value) | ||||||
|  |                 key.append(subkey) | ||||||
|  |  | ||||||
|  |     rows = [] | ||||||
|  |     for k, v in sorted(list(unsorted_rows.items()), | ||||||
|  |                        key=lambda x: x[0], | ||||||
|  |                        reverse=True): | ||||||
|  |         row = [] | ||||||
|  |         for key in sorted(v, key=lambda x: x): | ||||||
|  |             row.append(key[1]) | ||||||
|  |         rows.append(row) | ||||||
|  |  | ||||||
|  |     return rows | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def convert_xml(tree): | ||||||
|  |     root = {} | ||||||
|  |     for xml_keyboard in tree.iter("keyboard"): | ||||||
|  |         locale_full = xml_keyboard.get("locale") | ||||||
|  |         locale, sep, end = locale_full.partition("-t-") | ||||||
|  |     root["locale"] = locale | ||||||
|  |     for xml_name in tree.iter("name"): | ||||||
|  |         name = xml_name.get("value") | ||||||
|  |     root["name"] = name | ||||||
|  |     root["levels"] = [] | ||||||
|  |     # parse levels | ||||||
|  |     for index, keymap in enumerate(tree.iter('keyMap')): | ||||||
|  |         # FIXME: heuristics here | ||||||
|  |         modifiers = keymap.get('modifiers') | ||||||
|  |         if not modifiers: | ||||||
|  |             mode = 'default' | ||||||
|  |             modifiers = '' | ||||||
|  |         elif 'shift' in modifiers.split(' '): | ||||||
|  |             mode = 'latched' | ||||||
|  |             modifiers = 'shift' | ||||||
|  |         else: | ||||||
|  |             mode = 'locked' | ||||||
|  |         level = {} | ||||||
|  |         level["level"] = modifiers | ||||||
|  |         level["mode"] = mode | ||||||
|  |         level["rows"] = parse_rows(keymap) | ||||||
|  |         root["levels"].append(level) | ||||||
|  |     return root | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def locale_to_xkb(locale, name): | ||||||
|  |     if locale in sorted(LOCALE_TO_XKB_OVERRIDES.keys()): | ||||||
|  |         xkb = LOCALE_TO_XKB_OVERRIDES[locale] | ||||||
|  |         logging.debug("override for %s → %s", | ||||||
|  |                       locale, xkb) | ||||||
|  |         if xkb: | ||||||
|  |             return xkb | ||||||
|  |         else: | ||||||
|  |             raise KeyError("layout %s explicitely disabled in overrides" | ||||||
|  |                            % locale) | ||||||
|  |     xkb_names = sorted(name_to_xkb.keys()) | ||||||
|  |     if name in xkb_names: | ||||||
|  |         return name_to_xkb[name] | ||||||
|  |     else: | ||||||
|  |         logging.debug("name %s failed" % name) | ||||||
|  |     for sub_name in name.split(' '): | ||||||
|  |         if sub_name in xkb_names: | ||||||
|  |             xkb = name_to_xkb[sub_name] | ||||||
|  |             logging.debug("dumb mapping failed but match with locale word: " | ||||||
|  |                           "%s (%s) → %s (%s)", | ||||||
|  |                           locale, name, xkb, sub_name) | ||||||
|  |             return xkb | ||||||
|  |         else: | ||||||
|  |             logging.debug("sub_name failed") | ||||||
|  |     for xkb_name in xkb_names: | ||||||
|  |         for xkb_sub_name in xkb_name.split(' '): | ||||||
|  |             if xkb_sub_name.strip('()') == name: | ||||||
|  |                 xkb = name_to_xkb[xkb_name] | ||||||
|  |                 logging.debug("dumb mapping failed but match with xkb word: " | ||||||
|  |                               "%s (%s) → %s (%s)", | ||||||
|  |                               locale, name, xkb, xkb_name) | ||||||
|  |                 return xkb | ||||||
|  |     raise KeyError("failed to find XKB mapping for %s" % locale) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def convert_file(source_file, destination_path): | ||||||
|  |     logging.info("Parsing %s", source_file) | ||||||
|  |  | ||||||
|  |     itree = xml.etree.ElementTree.ElementTree() | ||||||
|  |     itree.parse(source_file) | ||||||
|  |  | ||||||
|  |     root = convert_xml(itree) | ||||||
|  |  | ||||||
|  |     try: | ||||||
|  |         xkb_name = locale_to_xkb(root["locale"], root["name"]) | ||||||
|  |     except KeyError as e: | ||||||
|  |         logging.warn(e) | ||||||
|  |         return False | ||||||
|  |     destination_file = os.path.join(destination_path, xkb_name + ".json") | ||||||
|  |  | ||||||
|  |     with open(destination_file, 'w', encoding="utf-8") as dest_fd: | ||||||
|  |         json.dump(root, dest_fd, ensure_ascii=False, indent=2, sort_keys=True) | ||||||
|  |  | ||||||
|  |     logging.debug("written %s", destination_file) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def load_xkb_mappings(): | ||||||
|  |     xkb = GnomeDesktop.XkbInfo() | ||||||
|  |     layouts = xkb.get_all_layouts() | ||||||
|  |     name_to_xkb = {} | ||||||
|  |  | ||||||
|  |     for layout in layouts: | ||||||
|  |         name = xkb.get_layout_info(layout).display_name | ||||||
|  |         name_to_xkb[name] = layout | ||||||
|  |  | ||||||
|  |     return name_to_xkb | ||||||
|  |  | ||||||
|  |  | ||||||
|  | locale.setlocale(locale.LC_ALL, "C") | ||||||
|  | name_to_xkb = load_xkb_mappings() | ||||||
|  |  | ||||||
|  |  | ||||||
|  | if __name__ == "__main__": | ||||||
|  |     if "DEBUG" in os.environ: | ||||||
|  |         logging.basicConfig(level=logging.DEBUG) | ||||||
|  |  | ||||||
|  |     if len(sys.argv) < 2: | ||||||
|  |         print("supply a CLDR keyboard file") | ||||||
|  |         sys.exit(1) | ||||||
|  |  | ||||||
|  |     if len(sys.argv) < 3: | ||||||
|  |         print("supply an output directory") | ||||||
|  |         sys.exit(1) | ||||||
|  |  | ||||||
|  |     source = sys.argv[1] | ||||||
|  |     destination = sys.argv[2] | ||||||
|  |     if os.path.isfile(source): | ||||||
|  |         convert_file(source, destination) | ||||||
|  |     elif os.path.isdir(source): | ||||||
|  |         for path in glob.glob(source + "/*-t-k0-android.xml"): | ||||||
|  |             convert_file(path, destination) | ||||||
| @@ -1,5 +1,6 @@ | |||||||
| dbus_interfaces = [ | dbus_interfaces = [ | ||||||
|   'org.gnome.Shell.Extensions.xml', |   'org.gnome.Shell.Extensions.xml', | ||||||
|  |   'org.gnome.Shell.Introspect.xml', | ||||||
|   'org.gnome.Shell.PadOsd.xml', |   'org.gnome.Shell.PadOsd.xml', | ||||||
|   'org.gnome.Shell.Screencast.xml', |   'org.gnome.Shell.Screencast.xml', | ||||||
|   'org.gnome.Shell.Screenshot.xml', |   'org.gnome.Shell.Screenshot.xml', | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								data/dbus-interfaces/org.gnome.Shell.CalendarServer.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,12 @@ | |||||||
|  | <node> | ||||||
|  |   <interface name="org.gnome.Shell.CalendarServer"> | ||||||
|  |     <method name="GetEvents"> | ||||||
|  |       <arg type="x" direction="in" /> | ||||||
|  |       <arg type="x" direction="in" /> | ||||||
|  |       <arg type="b" direction="in" /> | ||||||
|  |       <arg type="a(sssbxxa{sv})" direction="out" /> | ||||||
|  |     </method> | ||||||
|  |     <property name="HasCalendars" type="b" access="read" /> | ||||||
|  |     <signal name="Changed" /> | ||||||
|  |   </interface> | ||||||
|  | </node> | ||||||
							
								
								
									
										61
									
								
								data/dbus-interfaces/org.gnome.Shell.Introspect.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,61 @@ | |||||||
|  | <!DOCTYPE node PUBLIC | ||||||
|  | '-//freedesktop//DTD D-BUS Object Introspection 1.0//EN' | ||||||
|  | 'http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd'> | ||||||
|  | <node> | ||||||
|  |  | ||||||
|  |   <!-- | ||||||
|  |       org.gnome.Shell.Introspect: | ||||||
|  |       @short_description: Introspection interface | ||||||
|  |  | ||||||
|  |       The interface used to introspect the state of Shell, such as running | ||||||
|  |       applications, currently active application, etc. | ||||||
|  |   --> | ||||||
|  |   <interface name="org.gnome.Shell.Introspect"> | ||||||
|  |  | ||||||
|  |     <!-- | ||||||
|  |         RunningApplicationsChanged: | ||||||
|  |         @short_description: Notifies when the running applications changes | ||||||
|  |     --> | ||||||
|  |     <signal name="RunningApplicationsChanged" /> | ||||||
|  |  | ||||||
|  |     <!-- | ||||||
|  |         GetRunningApplications: | ||||||
|  |         @short_description: Retrieves the description of all running applications | ||||||
|  |  | ||||||
|  |         Each application is associated by an application ID. The details of | ||||||
|  |         each application consists of a varlist of keys and values. Available | ||||||
|  |         keys are listed below. | ||||||
|  |  | ||||||
|  |         'active-on-seats' - (as)   list of seats the application is active on | ||||||
|  |                                    (a seat only has at most one active | ||||||
|  |                                    application) | ||||||
|  |     --> | ||||||
|  |     <method name="GetRunningApplications"> | ||||||
|  |       <arg name="apps" direction="out" type="a{sa{sv}}" /> | ||||||
|  |     </method> | ||||||
|  |  | ||||||
|  |     <!-- | ||||||
|  |         GetWindows: | ||||||
|  |         @short_description: Retrieves the current list of windows and their properties | ||||||
|  |  | ||||||
|  |         A window is exposed as: | ||||||
|  |         * t ID: unique ID of the window | ||||||
|  |         * a{sv} properties: high-level properties | ||||||
|  |  | ||||||
|  |           Known properties: | ||||||
|  |  | ||||||
|  |           - "title"       (s): (readonly) title of the window | ||||||
|  |           - "app-id"      (s): (readonly) application ID of the window | ||||||
|  |           - "wm-class"    (s): (readonly) class of the window | ||||||
|  |           - "client-type" (u): (readonly) 0 for Wayland, 1 for X11 | ||||||
|  |           - "is-hidden"   (b): (readonly) if the window is currently hidden | ||||||
|  |           - "has-focus"   (b): (readonly) if the window currently have | ||||||
|  |                                           keyboard focus | ||||||
|  |           - "width"       (u): (readonly) width of the window | ||||||
|  |           - "height"      (u): (readonly) height of the window | ||||||
|  |     --> | ||||||
|  |     <method name="GetWindows"> | ||||||
|  |       <arg name="windows" direction="out" type="a{ta{sv}}" /> | ||||||
|  |     </method> | ||||||
|  |   </interface> | ||||||
|  | </node> | ||||||
| @@ -9,9 +9,6 @@ | |||||||
|     <method name="ShowOSD"> |     <method name="ShowOSD"> | ||||||
|       <arg type="a{sv}" direction="in" name="params"/> |       <arg type="a{sv}" direction="in" name="params"/> | ||||||
|     </method> |     </method> | ||||||
|     <method name="ShowMonitorLabels"> |  | ||||||
|       <arg type="a{uv}" direction="in" name="params"/> |  | ||||||
|     </method> |  | ||||||
|     <method name="ShowMonitorLabels2"> |     <method name="ShowMonitorLabels2"> | ||||||
|       <arg type="a{sv}" direction="in" name="params"/> |       <arg type="a{sv}" direction="in" name="params"/> | ||||||
|     </method> |     </method> | ||||||
| @@ -22,17 +19,22 @@ | |||||||
|     <method name="ShowApplications"/> |     <method name="ShowApplications"/> | ||||||
|     <method name="GrabAccelerator"> |     <method name="GrabAccelerator"> | ||||||
|       <arg type="s" direction="in" name="accelerator"/> |       <arg type="s" direction="in" name="accelerator"/> | ||||||
|       <arg type="u" direction="in" name="flags"/> |       <arg type="u" direction="in" name="modeFlags"/> | ||||||
|  |       <arg type="u" direction="in" name="grabFlags"/> | ||||||
|       <arg type="u" direction="out" name="action"/> |       <arg type="u" direction="out" name="action"/> | ||||||
|     </method> |     </method> | ||||||
|     <method name="GrabAccelerators"> |     <method name="GrabAccelerators"> | ||||||
|       <arg type="a(su)" direction="in" name="accelerators"/> |       <arg type="a(suu)" direction="in" name="accelerators"/> | ||||||
|       <arg type="au" direction="out" name="actions"/> |       <arg type="au" direction="out" name="actions"/> | ||||||
|     </method> |     </method> | ||||||
|     <method name="UngrabAccelerator"> |     <method name="UngrabAccelerator"> | ||||||
|       <arg type="u" direction="in" name="action"/> |       <arg type="u" direction="in" name="action"/> | ||||||
|       <arg type="b" direction="out" name="success"/> |       <arg type="b" direction="out" name="success"/> | ||||||
|     </method> |     </method> | ||||||
|  |     <method name="UngrabAccelerators"> | ||||||
|  |       <arg type="au" direction="in" name="action"/> | ||||||
|  |       <arg type="b" direction="out" name="success"/> | ||||||
|  |     </method> | ||||||
|     <signal name="AcceleratorActivated"> |     <signal name="AcceleratorActivated"> | ||||||
|       <arg name="action" type="u"/> |       <arg name="action" type="u"/> | ||||||
|       <arg name="parameters" type="a{sv}"/> |       <arg name="parameters" type="a{sv}"/> | ||||||
|   | |||||||
							
								
								
									
										15740
									
								
								data/emoji.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -39,7 +39,9 @@ | |||||||
|     <file preprocess="xml-stripblanks">org.gnome.SettingsDaemon.Rfkill.xml</file> |     <file preprocess="xml-stripblanks">org.gnome.SettingsDaemon.Rfkill.xml</file> | ||||||
|     <file preprocess="xml-stripblanks">org.gnome.SettingsDaemon.Wacom.xml</file> |     <file preprocess="xml-stripblanks">org.gnome.SettingsDaemon.Wacom.xml</file> | ||||||
|     <file preprocess="xml-stripblanks">org.gnome.Shell.AudioDeviceSelection.xml</file> |     <file preprocess="xml-stripblanks">org.gnome.Shell.AudioDeviceSelection.xml</file> | ||||||
|  |     <file preprocess="xml-stripblanks">org.gnome.Shell.CalendarServer.xml</file> | ||||||
|     <file preprocess="xml-stripblanks">org.gnome.Shell.Extensions.xml</file> |     <file preprocess="xml-stripblanks">org.gnome.Shell.Extensions.xml</file> | ||||||
|  |     <file preprocess="xml-stripblanks">org.gnome.Shell.Introspect.xml</file> | ||||||
|     <file preprocess="xml-stripblanks">org.gnome.Shell.HotplugSniffer.xml</file> |     <file preprocess="xml-stripblanks">org.gnome.Shell.HotplugSniffer.xml</file> | ||||||
|     <file preprocess="xml-stripblanks">org.gnome.Shell.PerfHelper.xml</file> |     <file preprocess="xml-stripblanks">org.gnome.Shell.PerfHelper.xml</file> | ||||||
|     <file preprocess="xml-stripblanks">org.gnome.Shell.PortalHelper.xml</file> |     <file preprocess="xml-stripblanks">org.gnome.Shell.PortalHelper.xml</file> | ||||||
|   | |||||||
| @@ -6,6 +6,7 @@ | |||||||
|     <file>be.json</file> |     <file>be.json</file> | ||||||
|     <file>bg.json</file> |     <file>bg.json</file> | ||||||
|     <file>by.json</file> |     <file>by.json</file> | ||||||
|  |     <file>ca.json</file> | ||||||
|     <file>cz.json</file> |     <file>cz.json</file> | ||||||
|     <file>de.json</file> |     <file>de.json</file> | ||||||
|     <file>dk.json</file> |     <file>dk.json</file> | ||||||
| @@ -54,5 +55,6 @@ | |||||||
|     <file>us.json</file> |     <file>us.json</file> | ||||||
|     <file>vn.json</file> |     <file>vn.json</file> | ||||||
|     <file>za.json</file> |     <file>za.json</file> | ||||||
|  |     <file>emoji.json</file> | ||||||
|   </gresource> |   </gresource> | ||||||
| </gresources> | </gresources> | ||||||
|   | |||||||
| @@ -1,18 +1,11 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8"?> | <?xml version="1.0" encoding="UTF-8"?> | ||||||
| <gresources> | <gresources> | ||||||
|   <gresource prefix="/org/gnome/shell/theme"> |   <gresource prefix="/org/gnome/shell/theme"> | ||||||
|     <file>calendar-arrow-left.svg</file> |  | ||||||
|     <file>calendar-arrow-right.svg</file> |  | ||||||
|     <file>calendar-today.svg</file> |     <file>calendar-today.svg</file> | ||||||
|     <file>checkbox-focused.svg</file> |     <file>checkbox-focused.svg</file> | ||||||
|     <file>checkbox-off-focused.svg</file> |     <file>checkbox-off-focused.svg</file> | ||||||
|     <file>checkbox-off.svg</file> |     <file>checkbox-off.svg</file> | ||||||
|     <file>checkbox.svg</file> |     <file>checkbox.svg</file> | ||||||
|     <file>close-window.svg</file> |  | ||||||
|     <file>close-window-active.svg</file> |  | ||||||
|     <file>close-window-hover.svg</file> |  | ||||||
|     <file>corner-ripple-ltr.png</file> |  | ||||||
|     <file>corner-ripple-rtl.png</file> |  | ||||||
|     <file>dash-placeholder.svg</file> |     <file>dash-placeholder.svg</file> | ||||||
|     <file>gnome-shell.css</file> |     <file>gnome-shell.css</file> | ||||||
|     <file>gnome-shell-high-contrast.css</file> |     <file>gnome-shell-high-contrast.css</file> | ||||||
| @@ -27,16 +20,16 @@ | |||||||
|     <file>no-notifications.svg</file> |     <file>no-notifications.svg</file> | ||||||
|     <file>noise-texture.png</file> |     <file>noise-texture.png</file> | ||||||
|     <file>pad-osd.css</file> |     <file>pad-osd.css</file> | ||||||
|     <file>page-indicator-active.svg</file> |     <file alias="icons/pointer-double-click-symbolic.svg">pointer-double-click-symbolic.svg</file> | ||||||
|     <file>page-indicator-inactive.svg</file> |     <file alias="icons/pointer-drag-symbolic.svg">pointer-drag-symbolic.svg</file> | ||||||
|     <file>page-indicator-checked.svg</file> |     <file alias="icons/pointer-primary-click-symbolic.svg">pointer-primary-click-symbolic.svg</file> | ||||||
|     <file>page-indicator-hover.svg</file> |     <file alias="icons/pointer-secondary-click-symbolic.svg">pointer-secondary-click-symbolic.svg</file> | ||||||
|     <file>process-working.svg</file> |     <file>process-working.svg</file> | ||||||
|     <file>toggle-off-us.svg</file> |     <file>toggle-off.svg</file> | ||||||
|     <file>toggle-off-intl.svg</file> |     <file>toggle-off-dark.svg</file> | ||||||
|     <file>toggle-off-hc.svg</file> |     <file>toggle-off-hc.svg</file> | ||||||
|     <file>toggle-on-us.svg</file> |     <file>toggle-on.svg</file> | ||||||
|     <file>toggle-on-intl.svg</file> |     <file>toggle-on-dark.svg</file> | ||||||
|     <file>toggle-on-hc.svg</file> |     <file>toggle-on-hc.svg</file> | ||||||
|   </gresource> |   </gresource> | ||||||
| </gresources> | </gresources> | ||||||
|   | |||||||
| @@ -90,6 +90,14 @@ | |||||||
|         adapter is ever seen not to have devices associated to it. |         adapter is ever seen not to have devices associated to it. | ||||||
|       </description> |       </description> | ||||||
|     </key> |     </key> | ||||||
|  |     <key name="introspect" type="b"> | ||||||
|  |       <default>false</default> | ||||||
|  |       <summary>Enable introspection API</summary> | ||||||
|  |       <description> | ||||||
|  |         Enables a D-Bus API that allows to introspect the application state of | ||||||
|  |         the shell. | ||||||
|  |       </description> | ||||||
|  |     </key> | ||||||
|     <child name="keybindings" schema="org.gnome.shell.keybindings"/> |     <child name="keybindings" schema="org.gnome.shell.keybindings"/> | ||||||
|     <child name="keyboard" schema="org.gnome.shell.keyboard"/> |     <child name="keyboard" schema="org.gnome.shell.keyboard"/> | ||||||
|   </schema> |   </schema> | ||||||
| @@ -137,6 +145,42 @@ | |||||||
|       <summary>Keybinding that pauses and resumes all running tweens, for debugging purposes</summary> |       <summary>Keybinding that pauses and resumes all running tweens, for debugging purposes</summary> | ||||||
|       <description></description> |       <description></description> | ||||||
|     </key> |     </key> | ||||||
|  |     <key name="switch-to-application-1" type="as"> | ||||||
|  |       <default>["<Super>1"]</default> | ||||||
|  |       <summary>Switch to application 1</summary> | ||||||
|  |     </key> | ||||||
|  |     <key name="switch-to-application-2" type="as"> | ||||||
|  |       <default>["<Super>2"]</default> | ||||||
|  |       <summary>Switch to application 2</summary> | ||||||
|  |     </key> | ||||||
|  |     <key name="switch-to-application-3" type="as"> | ||||||
|  |       <default>["<Super>3"]</default> | ||||||
|  |       <summary>Switch to application 3</summary> | ||||||
|  |     </key> | ||||||
|  |     <key name="switch-to-application-4" type="as"> | ||||||
|  |       <default>["<Super>4"]</default> | ||||||
|  |       <summary>Switch to application 4</summary> | ||||||
|  |     </key> | ||||||
|  |     <key name="switch-to-application-5" type="as"> | ||||||
|  |       <default>["<Super>5"]</default> | ||||||
|  |       <summary>Switch to application 5</summary> | ||||||
|  |     </key> | ||||||
|  |     <key name="switch-to-application-6" type="as"> | ||||||
|  |       <default>["<Super>6"]</default> | ||||||
|  |       <summary>Switch to application 6</summary> | ||||||
|  |     </key> | ||||||
|  |     <key name="switch-to-application-7" type="as"> | ||||||
|  |       <default>["<Super>7"]</default> | ||||||
|  |       <summary>Switch to application 7</summary> | ||||||
|  |     </key> | ||||||
|  |     <key name="switch-to-application-8" type="as"> | ||||||
|  |       <default>["<Super>8"]</default> | ||||||
|  |       <summary>Switch to application 8</summary> | ||||||
|  |     </key> | ||||||
|  |     <key name="switch-to-application-9" type="as"> | ||||||
|  |       <default>["<Super>9"]</default> | ||||||
|  |       <summary>Switch to application 9</summary> | ||||||
|  |     </key> | ||||||
|   </schema> |   </schema> | ||||||
|  |  | ||||||
|   <schema id="org.gnome.shell.keyboard" path="/org/gnome/shell/keyboard/" |   <schema id="org.gnome.shell.keyboard" path="/org/gnome/shell/keyboard/" | ||||||
|   | |||||||
							
								
								
									
										599
									
								
								data/osk-layouts/ca.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,599 @@ | |||||||
|  | { | ||||||
|  |   "levels": [ | ||||||
|  |     { | ||||||
|  |       "level": "", | ||||||
|  |       "mode": "default", | ||||||
|  |       "rows": [ | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "q" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "w" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "e", | ||||||
|  |             "é", | ||||||
|  |             "è", | ||||||
|  |             "ê", | ||||||
|  |             "ë", | ||||||
|  |             "%", | ||||||
|  |             "ę", | ||||||
|  |             "ė", | ||||||
|  |             "ē" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "r" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "t" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "y", | ||||||
|  |             "%", | ||||||
|  |             "ÿ" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "u", | ||||||
|  |             "ù", | ||||||
|  |             "û", | ||||||
|  |             "%", | ||||||
|  |             "ü", | ||||||
|  |             "ú", | ||||||
|  |             "ū" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "i", | ||||||
|  |             "î", | ||||||
|  |             "%", | ||||||
|  |             "ï", | ||||||
|  |             "ì", | ||||||
|  |             "í", | ||||||
|  |             "į", | ||||||
|  |             "ī" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "o", | ||||||
|  |             "ô", | ||||||
|  |             "œ", | ||||||
|  |             "%", | ||||||
|  |             "ö", | ||||||
|  |             "ò", | ||||||
|  |             "ó", | ||||||
|  |             "õ", | ||||||
|  |             "ø", | ||||||
|  |             "ō", | ||||||
|  |             "º" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "p" | ||||||
|  |           ] | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "a", | ||||||
|  |             "à", | ||||||
|  |             "â", | ||||||
|  |             "%", | ||||||
|  |             "æ", | ||||||
|  |             "á", | ||||||
|  |             "ä", | ||||||
|  |             "ã", | ||||||
|  |             "å", | ||||||
|  |             "ā", | ||||||
|  |             "ª" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "s" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "d" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "f" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "g" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "h" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "j" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "k" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "l" | ||||||
|  |           ] | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "z" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "x" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "c", | ||||||
|  |             "ç", | ||||||
|  |             "ć", | ||||||
|  |             "č" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "v" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "b" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "n" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "m" | ||||||
|  |           ] | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "," | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             " " | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             ".", | ||||||
|  |             "#", | ||||||
|  |             "!", | ||||||
|  |             ",", | ||||||
|  |             "?", | ||||||
|  |             "-", | ||||||
|  |             ":", | ||||||
|  |             "'", | ||||||
|  |             "@" | ||||||
|  |           ] | ||||||
|  |         ] | ||||||
|  |       ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "level": "shift", | ||||||
|  |       "mode": "latched", | ||||||
|  |       "rows": [ | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "Q" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "W" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "E", | ||||||
|  |             "É", | ||||||
|  |             "È", | ||||||
|  |             "Ê", | ||||||
|  |             "Ë", | ||||||
|  |             "%", | ||||||
|  |             "Ę", | ||||||
|  |             "Ė", | ||||||
|  |             "Ē" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "R" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "T" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "Y", | ||||||
|  |             "%", | ||||||
|  |             "Ÿ" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "U", | ||||||
|  |             "Ù", | ||||||
|  |             "Û", | ||||||
|  |             "%", | ||||||
|  |             "Ü", | ||||||
|  |             "Ú", | ||||||
|  |             "Ū" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "I", | ||||||
|  |             "Î", | ||||||
|  |             "%", | ||||||
|  |             "Ï", | ||||||
|  |             "Ì", | ||||||
|  |             "Í", | ||||||
|  |             "Į", | ||||||
|  |             "Ī" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "O", | ||||||
|  |             "Ô", | ||||||
|  |             "Œ", | ||||||
|  |             "%", | ||||||
|  |             "Ö", | ||||||
|  |             "Ò", | ||||||
|  |             "Ó", | ||||||
|  |             "Õ", | ||||||
|  |             "Ø", | ||||||
|  |             "Ō", | ||||||
|  |             "º" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "P" | ||||||
|  |           ] | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "A", | ||||||
|  |             "À", | ||||||
|  |             "Â", | ||||||
|  |             "%", | ||||||
|  |             "Æ", | ||||||
|  |             "Á", | ||||||
|  |             "Ä", | ||||||
|  |             "Ã", | ||||||
|  |             "Å", | ||||||
|  |             "Ā", | ||||||
|  |             "ª" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "S" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "D" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "F" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "G" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "H" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "J" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "K" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "L" | ||||||
|  |           ] | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "Z" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "X" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "C", | ||||||
|  |             "Ç", | ||||||
|  |             "Ć", | ||||||
|  |             "Č" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "V" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "B" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "N" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "M" | ||||||
|  |           ] | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "," | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             " " | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             ".", | ||||||
|  |             "#", | ||||||
|  |             "!", | ||||||
|  |             ",", | ||||||
|  |             "?", | ||||||
|  |             "-", | ||||||
|  |             ":", | ||||||
|  |             "'", | ||||||
|  |             "@" | ||||||
|  |           ] | ||||||
|  |         ] | ||||||
|  |       ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "level": "opt", | ||||||
|  |       "mode": "locked", | ||||||
|  |       "rows": [ | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "1", | ||||||
|  |             "¹", | ||||||
|  |             "½", | ||||||
|  |             "⅓", | ||||||
|  |             "¼", | ||||||
|  |             "⅛" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "2", | ||||||
|  |             "²", | ||||||
|  |             "⅔" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "3", | ||||||
|  |             "³", | ||||||
|  |             "¾", | ||||||
|  |             "⅜" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "4", | ||||||
|  |             "⁴" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "5", | ||||||
|  |             "⅝" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "6" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "7", | ||||||
|  |             "⅞" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "8" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "9" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "0", | ||||||
|  |             "ⁿ", | ||||||
|  |             "∅" | ||||||
|  |           ] | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "@" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "#" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "$", | ||||||
|  |             "¢", | ||||||
|  |             "£", | ||||||
|  |             "€", | ||||||
|  |             "¥", | ||||||
|  |             "₱" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "%", | ||||||
|  |             "‰" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "&" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "-", | ||||||
|  |             "_", | ||||||
|  |             "–", | ||||||
|  |             "—", | ||||||
|  |             "·" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "+", | ||||||
|  |             "±" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "(", | ||||||
|  |             "<", | ||||||
|  |             "{", | ||||||
|  |             "[" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             ")", | ||||||
|  |             ">", | ||||||
|  |             "}", | ||||||
|  |             "]" | ||||||
|  |           ] | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "*", | ||||||
|  |             "†", | ||||||
|  |             "‡", | ||||||
|  |             "★" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "\"", | ||||||
|  |             "“", | ||||||
|  |             "”", | ||||||
|  |             "«", | ||||||
|  |             "»" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "'", | ||||||
|  |             "‘", | ||||||
|  |             "’", | ||||||
|  |             "‹", | ||||||
|  |             "›" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             ":" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             ";" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "!", | ||||||
|  |             "¡" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "?", | ||||||
|  |             "¿" | ||||||
|  |           ] | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "_" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "/" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             " " | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "," | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             ".", | ||||||
|  |             "…" | ||||||
|  |           ] | ||||||
|  |         ] | ||||||
|  |       ] | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "level": "opt+shift", | ||||||
|  |       "mode": "locked", | ||||||
|  |       "rows": [ | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "~" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "`" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "|" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "•", | ||||||
|  |             "♪", | ||||||
|  |             "♥", | ||||||
|  |             "♠", | ||||||
|  |             "♦", | ||||||
|  |             "♣" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "√" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "Π", | ||||||
|  |             "π" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "÷" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "×" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "¶", | ||||||
|  |             "§" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "∆" | ||||||
|  |           ] | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "£" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "¢" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "€" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "¥" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "^", | ||||||
|  |             "↑", | ||||||
|  |             "↓", | ||||||
|  |             "←", | ||||||
|  |             "→" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "°", | ||||||
|  |             "′", | ||||||
|  |             "″" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "=", | ||||||
|  |             "≠", | ||||||
|  |             "≈", | ||||||
|  |             "∞" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "{" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "}" | ||||||
|  |           ] | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "\\" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "©" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "®" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "™" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "℅" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "[" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "]" | ||||||
|  |           ] | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           [ | ||||||
|  |             "<", | ||||||
|  |             "‹", | ||||||
|  |             "≤", | ||||||
|  |             "«" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             ">", | ||||||
|  |             "›", | ||||||
|  |             "≥", | ||||||
|  |             "»" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             " " | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "," | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             ".", | ||||||
|  |             "…" | ||||||
|  |           ] | ||||||
|  |         ] | ||||||
|  |       ] | ||||||
|  |     } | ||||||
|  |   ], | ||||||
|  |   "locale": "fr-CA", | ||||||
|  |   "name": "French Canada" | ||||||
|  | } | ||||||
| @@ -6,10 +6,20 @@ | |||||||
|       "rows": [ |       "rows": [ | ||||||
|         [ |         [ | ||||||
|           [ |           [ | ||||||
|             "q" |             "a", | ||||||
|  |             "à", | ||||||
|  |             "â", | ||||||
|  |             "%", | ||||||
|  |             "æ", | ||||||
|  |             "á", | ||||||
|  |             "ä", | ||||||
|  |             "ã", | ||||||
|  |             "å", | ||||||
|  |             "ā", | ||||||
|  |             "ª" | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "w" |             "z" | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "e", |             "e", | ||||||
| @@ -71,17 +81,7 @@ | |||||||
|         ], |         ], | ||||||
|         [ |         [ | ||||||
|           [ |           [ | ||||||
|             "a", |             "q" | ||||||
|             "à", |  | ||||||
|             "â", |  | ||||||
|             "%", |  | ||||||
|             "æ", |  | ||||||
|             "á", |  | ||||||
|             "ä", |  | ||||||
|             "ã", |  | ||||||
|             "å", |  | ||||||
|             "ā", |  | ||||||
|             "ª" |  | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "s" |             "s" | ||||||
| @@ -106,11 +106,14 @@ | |||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "l" |             "l" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "m" | ||||||
|           ] |           ] | ||||||
|         ], |         ], | ||||||
|         [ |         [ | ||||||
|           [ |           [ | ||||||
|             "z" |             "w" | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "x" |             "x" | ||||||
| @@ -131,7 +134,11 @@ | |||||||
|             "n" |             "n" | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "m" |             "'", | ||||||
|  |             "‘", | ||||||
|  |             "’", | ||||||
|  |             "‹", | ||||||
|  |             "›" | ||||||
|           ] |           ] | ||||||
|         ], |         ], | ||||||
|         [ |         [ | ||||||
| @@ -161,10 +168,20 @@ | |||||||
|       "rows": [ |       "rows": [ | ||||||
|         [ |         [ | ||||||
|           [ |           [ | ||||||
|             "Q" |             "A", | ||||||
|  |             "À", | ||||||
|  |             "Â", | ||||||
|  |             "%", | ||||||
|  |             "Æ", | ||||||
|  |             "Á", | ||||||
|  |             "Ä", | ||||||
|  |             "Ã", | ||||||
|  |             "Å", | ||||||
|  |             "Ā", | ||||||
|  |             "ª" | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "W" |             "Z" | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "E", |             "E", | ||||||
| @@ -226,17 +243,7 @@ | |||||||
|         ], |         ], | ||||||
|         [ |         [ | ||||||
|           [ |           [ | ||||||
|             "A", |             "Q" | ||||||
|             "À", |  | ||||||
|             "Â", |  | ||||||
|             "%", |  | ||||||
|             "Æ", |  | ||||||
|             "Á", |  | ||||||
|             "Ä", |  | ||||||
|             "Ã", |  | ||||||
|             "Å", |  | ||||||
|             "Ā", |  | ||||||
|             "ª" |  | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "S" |             "S" | ||||||
| @@ -261,11 +268,14 @@ | |||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "L" |             "L" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "M" | ||||||
|           ] |           ] | ||||||
|         ], |         ], | ||||||
|         [ |         [ | ||||||
|           [ |           [ | ||||||
|             "Z" |             "W" | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "X" |             "X" | ||||||
| @@ -286,7 +296,11 @@ | |||||||
|             "N" |             "N" | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "M" |             "'", | ||||||
|  |             "‘", | ||||||
|  |             "’", | ||||||
|  |             "‹", | ||||||
|  |             "›" | ||||||
|           ] |           ] | ||||||
|         ], |         ], | ||||||
|         [ |         [ | ||||||
| @@ -369,10 +383,10 @@ | |||||||
|             "#" |             "#" | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "$", |             "€", | ||||||
|             "¢", |             "¢", | ||||||
|             "£", |             "£", | ||||||
|             "€", |             "$", | ||||||
|             "¥", |             "¥", | ||||||
|             "₱" |             "₱" | ||||||
|           ], |           ], | ||||||
| @@ -511,13 +525,14 @@ | |||||||
|             "£" |             "£" | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|  |             "¥" | ||||||
|  |           ], | ||||||
|  |           [ | ||||||
|  |             "$", | ||||||
|             "¢" |             "¢" | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "€" |             "¢" | ||||||
|           ], |  | ||||||
|           [ |  | ||||||
|             "¥" |  | ||||||
|           ], |           ], | ||||||
|           [ |           [ | ||||||
|             "^", |             "^", | ||||||
| @@ -594,6 +609,6 @@ | |||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|   ], |   ], | ||||||
|   "locale": "fr-CA", |   "locale": "fr", | ||||||
|   "name": "French Canada" |   "name": "French" | ||||||
| } | } | ||||||
| @@ -1,82 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    width="16" |  | ||||||
|    height="16" |  | ||||||
|    id="svg2" |  | ||||||
|    version="1.1" |  | ||||||
|    inkscape:version="0.48+devel r9942 custom" |  | ||||||
|    sodipodi:docname="New document 4"> |  | ||||||
|   <defs |  | ||||||
|      id="defs4" /> |  | ||||||
|   <sodipodi:namedview |  | ||||||
|      id="base" |  | ||||||
|      pagecolor="#ffffff" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      inkscape:pageopacity="0.0" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:zoom="1" |  | ||||||
|      inkscape:cx="8.984481" |  | ||||||
|      inkscape:cy="5.6224906" |  | ||||||
|      inkscape:document-units="px" |  | ||||||
|      inkscape:current-layer="layer1" |  | ||||||
|      showgrid="false" |  | ||||||
|      borderlayer="true" |  | ||||||
|      inkscape:showpageshadow="false" |  | ||||||
|      inkscape:window-width="930" |  | ||||||
|      inkscape:window-height="681" |  | ||||||
|      inkscape:window-x="1892" |  | ||||||
|      inkscape:window-y="272" |  | ||||||
|      inkscape:window-maximized="0"> |  | ||||||
|     <inkscape:grid |  | ||||||
|        type="xygrid" |  | ||||||
|        id="grid17403" |  | ||||||
|        empspacing="5" |  | ||||||
|        visible="true" |  | ||||||
|        enabled="true" |  | ||||||
|        snapvisiblegridlinesonly="true" /> |  | ||||||
|   </sodipodi:namedview> |  | ||||||
|   <metadata |  | ||||||
|      id="metadata7"> |  | ||||||
|     <rdf:RDF> |  | ||||||
|       <cc:Work |  | ||||||
|          rdf:about=""> |  | ||||||
|         <dc:format>image/svg+xml</dc:format> |  | ||||||
|         <dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |  | ||||||
|         <dc:title></dc:title> |  | ||||||
|       </cc:Work> |  | ||||||
|     </rdf:RDF> |  | ||||||
|   </metadata> |  | ||||||
|   <g |  | ||||||
|      inkscape:label="Layer 1" |  | ||||||
|      inkscape:groupmode="layer" |  | ||||||
|      id="layer1" |  | ||||||
|      transform="translate(0,-1036.3622)"> |  | ||||||
|     <path |  | ||||||
|        sodipodi:type="star" |  | ||||||
|        style="fill:#5f5f5f;fill-opacity:1;stroke:#5f5f5f;stroke-width:0.43015847;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" |  | ||||||
|        id="path18028" |  | ||||||
|        sodipodi:sides="3" |  | ||||||
|        sodipodi:cx="84.5" |  | ||||||
|        sodipodi:cy="337.5" |  | ||||||
|        sodipodi:r1="5" |  | ||||||
|        sodipodi:r2="2.5" |  | ||||||
|        sodipodi:arg1="0.52359878" |  | ||||||
|        sodipodi:arg2="1.5707963" |  | ||||||
|        inkscape:flatsided="true" |  | ||||||
|        inkscape:rounded="0" |  | ||||||
|        inkscape:randomized="0" |  | ||||||
|        d="M 88.830127,340 80.169873,340 84.5,332.5 z" |  | ||||||
|        transform="matrix(0,1.3621708,0.99186247,0,-325.48222,929.32667)" /> |  | ||||||
|   </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 2.5 KiB | 
| @@ -1,82 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    width="16" |  | ||||||
|    height="16" |  | ||||||
|    id="svg2" |  | ||||||
|    version="1.1" |  | ||||||
|    inkscape:version="0.48+devel r9942 custom" |  | ||||||
|    sodipodi:docname="arrow-left.svg"> |  | ||||||
|   <defs |  | ||||||
|      id="defs4" /> |  | ||||||
|   <sodipodi:namedview |  | ||||||
|      id="base" |  | ||||||
|      pagecolor="#ffffff" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      inkscape:pageopacity="0.0" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:zoom="1" |  | ||||||
|      inkscape:cx="7.7366092" |  | ||||||
|      inkscape:cy="6.4536271" |  | ||||||
|      inkscape:document-units="px" |  | ||||||
|      inkscape:current-layer="layer1" |  | ||||||
|      showgrid="false" |  | ||||||
|      borderlayer="true" |  | ||||||
|      inkscape:showpageshadow="false" |  | ||||||
|      inkscape:window-width="930" |  | ||||||
|      inkscape:window-height="681" |  | ||||||
|      inkscape:window-x="1892" |  | ||||||
|      inkscape:window-y="272" |  | ||||||
|      inkscape:window-maximized="0"> |  | ||||||
|     <inkscape:grid |  | ||||||
|        type="xygrid" |  | ||||||
|        id="grid17403" |  | ||||||
|        empspacing="5" |  | ||||||
|        visible="true" |  | ||||||
|        enabled="true" |  | ||||||
|        snapvisiblegridlinesonly="true" /> |  | ||||||
|   </sodipodi:namedview> |  | ||||||
|   <metadata |  | ||||||
|      id="metadata7"> |  | ||||||
|     <rdf:RDF> |  | ||||||
|       <cc:Work |  | ||||||
|          rdf:about=""> |  | ||||||
|         <dc:format>image/svg+xml</dc:format> |  | ||||||
|         <dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |  | ||||||
|         <dc:title></dc:title> |  | ||||||
|       </cc:Work> |  | ||||||
|     </rdf:RDF> |  | ||||||
|   </metadata> |  | ||||||
|   <g |  | ||||||
|      inkscape:label="Layer 1" |  | ||||||
|      inkscape:groupmode="layer" |  | ||||||
|      id="layer1" |  | ||||||
|      transform="translate(0,-1036.3622)"> |  | ||||||
|     <path |  | ||||||
|        sodipodi:type="star" |  | ||||||
|        style="fill:#5f5f5f;fill-opacity:1;stroke:#5f5f5f;stroke-width:0.43015847;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;display:inline" |  | ||||||
|        id="path18028" |  | ||||||
|        sodipodi:sides="3" |  | ||||||
|        sodipodi:cx="84.5" |  | ||||||
|        sodipodi:cy="337.5" |  | ||||||
|        sodipodi:r1="5" |  | ||||||
|        sodipodi:r2="2.5" |  | ||||||
|        sodipodi:arg1="0.52359878" |  | ||||||
|        sodipodi:arg2="1.5707963" |  | ||||||
|        inkscape:flatsided="true" |  | ||||||
|        inkscape:rounded="0" |  | ||||||
|        inkscape:randomized="0" |  | ||||||
|        d="M 88.830127,340 80.169873,340 84.5,332.5 z" |  | ||||||
|        transform="matrix(0,1.3621708,-0.99186247,0,342.48324,929.32667)" /> |  | ||||||
|   </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 2.5 KiB | 
| @@ -1,81 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Generator: Adobe Illustrator 13.0.2, SVG Export Plug-In . SVG Version: 6.00 Build 14948)  --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    version="1.0" |  | ||||||
|    id="Foreground" |  | ||||||
|    x="0px" |  | ||||||
|    y="0px" |  | ||||||
|    width="32" |  | ||||||
|    height="32" |  | ||||||
|    viewBox="0 0 32 32" |  | ||||||
|    enable-background="new 0 0 16 16" |  | ||||||
|    xml:space="preserve" |  | ||||||
|    sodipodi:version="0.32" |  | ||||||
|    inkscape:version="0.92.2 5c3e80d, 2017-08-06" |  | ||||||
|    sodipodi:docname="close-window-active.svg" |  | ||||||
|    inkscape:output_extension="org.inkscape.output.svg.inkscape"><metadata |  | ||||||
|      id="metadata2399"><rdf:RDF><cc:Work |  | ||||||
|          rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><defs |  | ||||||
|      id="defs2397"><linearGradient |  | ||||||
|        id="linearGradient3173"><stop |  | ||||||
|          style="stop-color:#c4c4c4;stop-opacity:1;" |  | ||||||
|          offset="0" |  | ||||||
|          id="stop3175" /><stop |  | ||||||
|          style="stop-color:#ffffff;stop-opacity:1;" |  | ||||||
|          offset="1" |  | ||||||
|          id="stop3177" /></linearGradient><inkscape:perspective |  | ||||||
|        sodipodi:type="inkscape:persp3d" |  | ||||||
|        inkscape:vp_x="0 : 11 : 1" |  | ||||||
|        inkscape:vp_y="0 : 1375 : 0" |  | ||||||
|        inkscape:vp_z="22 : 11 : 1" |  | ||||||
|        inkscape:persp3d-origin="11 : 7.3333334 : 1" |  | ||||||
|        id="perspective2401" /></defs><sodipodi:namedview |  | ||||||
|      inkscape:window-height="1106" |  | ||||||
|      inkscape:window-width="1700" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:pageopacity="0" |  | ||||||
|      guidetolerance="10.0" |  | ||||||
|      gridtolerance="10.0" |  | ||||||
|      objecttolerance="10.0" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      pagecolor="#797979" |  | ||||||
|      id="base" |  | ||||||
|      showgrid="false" |  | ||||||
|      inkscape:zoom="4" |  | ||||||
|      inkscape:cx="28.483745" |  | ||||||
|      inkscape:cy="67.714004" |  | ||||||
|      inkscape:window-x="1427" |  | ||||||
|      inkscape:window-y="127" |  | ||||||
|      inkscape:current-layer="Foreground" |  | ||||||
|      showguides="true" |  | ||||||
|      inkscape:guide-bbox="true" |  | ||||||
|      borderlayer="true" |  | ||||||
|      inkscape:showpageshadow="false" |  | ||||||
|      inkscape:window-maximized="0" |  | ||||||
|      inkscape:document-rotation="0"><inkscape:grid |  | ||||||
|        type="xygrid" |  | ||||||
|        id="grid11246" |  | ||||||
|        empspacing="32" |  | ||||||
|        visible="true" |  | ||||||
|        enabled="true" |  | ||||||
|        snapvisiblegridlinesonly="true" /></sodipodi:namedview><path |  | ||||||
|      d="m 4.4362021,16 c 0,-6.410121 5.1728276,-11.60728 11.5529359,-11.60728 6.380109,0 11.552937,5.197159 11.552937,11.60728 0,6.410122 -5.172828,11.607281 -11.552937,11.607281 C 9.6090297,27.607281 4.4362021,22.410122 4.4362021,16 Z" |  | ||||||
|      id="path883" |  | ||||||
|      style="color:#000000;clip-rule:evenodd;display:inline;overflow:visible;visibility:visible;fill:#a5c8ec;fill-opacity:1;fill-rule:nonzero;stroke:#2975c4;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate" |  | ||||||
|      sodipodi:nodetypes="csssc" |  | ||||||
|      inkscape:connector-curvature="0" /><path |  | ||||||
|      d="m 11.718386,11.764547 h 1.055207 c 0.01091,-1.26e-4 0.02193,-4.86e-4 0.03298,0 0.269026,0.01183 0.538019,0.135679 0.725455,0.329752 l 2.407192,2.407192 2.440166,-2.407192 c 0.28029,-0.243226 0.471333,-0.322366 0.725455,-0.329752 h 1.055207 v 1.055208 c 0,0.302285 -0.03623,0.581049 -0.263801,0.791405 l -2.407191,2.407191 2.374217,2.374216 c 0.198577,0.198559 0.296768,0.478484 0.296775,0.758432 v 1.055206 h -1.055211 c -0.279947,-10e-6 -0.559877,-0.09824 -0.75843,-0.296777 l -2.407192,-2.407192 -2.407192,2.407192 c -0.198551,0.198579 -0.478493,0.296777 -0.758429,0.296777 H 11.71839 v -1.055206 c -3e-6,-0.279936 0.0982,-0.559873 0.296777,-0.758432 L 14.422359,16.018351 12.015167,13.61116 C 11.79279,13.405784 11.69527,13.116003 11.71839,12.819755 Z" |  | ||||||
|      inkscape:connector-curvature="0" |  | ||||||
|      id="path887" |  | ||||||
|      style="color:#bebebe;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:medium;line-height:normal;font-family:'Andale Mono';-inkscape-font-specification:'Andale Mono';text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;letter-spacing:normal;word-spacing:normal;text-transform:none;writing-mode:lr-tb;direction:ltr;text-anchor:start;display:inline;overflow:visible;visibility:visible;fill:#4a90d9;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.87958801;marker:none;enable-background:new" |  | ||||||
|      sodipodi:nodetypes="ccsccccccccccccccccccccccc" /></svg> |  | ||||||
| Before Width: | Height: | Size: 4.6 KiB | 
| @@ -1,81 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Generator: Adobe Illustrator 13.0.2, SVG Export Plug-In . SVG Version: 6.00 Build 14948)  --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    version="1.0" |  | ||||||
|    id="Foreground" |  | ||||||
|    x="0px" |  | ||||||
|    y="0px" |  | ||||||
|    width="32" |  | ||||||
|    height="32" |  | ||||||
|    viewBox="0 0 32 32" |  | ||||||
|    enable-background="new 0 0 16 16" |  | ||||||
|    xml:space="preserve" |  | ||||||
|    sodipodi:version="0.32" |  | ||||||
|    inkscape:version="0.92.2 5c3e80d, 2017-08-06" |  | ||||||
|    sodipodi:docname="close-window-hover.svg" |  | ||||||
|    inkscape:output_extension="org.inkscape.output.svg.inkscape"><metadata |  | ||||||
|      id="metadata2399"><rdf:RDF><cc:Work |  | ||||||
|          rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title /></cc:Work></rdf:RDF></metadata><defs |  | ||||||
|      id="defs2397"><linearGradient |  | ||||||
|        id="linearGradient3173"><stop |  | ||||||
|          style="stop-color:#c4c4c4;stop-opacity:1;" |  | ||||||
|          offset="0" |  | ||||||
|          id="stop3175" /><stop |  | ||||||
|          style="stop-color:#ffffff;stop-opacity:1;" |  | ||||||
|          offset="1" |  | ||||||
|          id="stop3177" /></linearGradient><inkscape:perspective |  | ||||||
|        sodipodi:type="inkscape:persp3d" |  | ||||||
|        inkscape:vp_x="0 : 11 : 1" |  | ||||||
|        inkscape:vp_y="0 : 1375 : 0" |  | ||||||
|        inkscape:vp_z="22 : 11 : 1" |  | ||||||
|        inkscape:persp3d-origin="11 : 7.3333334 : 1" |  | ||||||
|        id="perspective2401" /></defs><sodipodi:namedview |  | ||||||
|      inkscape:window-height="1106" |  | ||||||
|      inkscape:window-width="1700" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:pageopacity="0" |  | ||||||
|      guidetolerance="10.0" |  | ||||||
|      gridtolerance="10.0" |  | ||||||
|      objecttolerance="10.0" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      pagecolor="#797979" |  | ||||||
|      id="base" |  | ||||||
|      showgrid="false" |  | ||||||
|      inkscape:zoom="4" |  | ||||||
|      inkscape:cx="28.483745" |  | ||||||
|      inkscape:cy="67.714004" |  | ||||||
|      inkscape:window-x="1427" |  | ||||||
|      inkscape:window-y="127" |  | ||||||
|      inkscape:current-layer="Foreground" |  | ||||||
|      showguides="true" |  | ||||||
|      inkscape:guide-bbox="true" |  | ||||||
|      borderlayer="true" |  | ||||||
|      inkscape:showpageshadow="false" |  | ||||||
|      inkscape:window-maximized="0" |  | ||||||
|      inkscape:document-rotation="0"><inkscape:grid |  | ||||||
|        type="xygrid" |  | ||||||
|        id="grid11246" |  | ||||||
|        empspacing="32" |  | ||||||
|        visible="true" |  | ||||||
|        enabled="true" |  | ||||||
|        snapvisiblegridlinesonly="true" /></sodipodi:namedview><path |  | ||||||
|      inkscape:connector-curvature="0" |  | ||||||
|      sodipodi:nodetypes="csssc" |  | ||||||
|      style="color:#000000;clip-rule:evenodd;display:inline;overflow:visible;visibility:visible;fill:#2975c4;fill-opacity:1;fill-rule:nonzero;stroke:#ffffff;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate" |  | ||||||
|      id="path822" |  | ||||||
|      d="m 4.4362021,16 c 0,-6.410121 5.1728276,-11.60728 11.5529359,-11.60728 6.380109,0 11.552937,5.197159 11.552937,11.60728 0,6.410122 -5.172828,11.607281 -11.552937,11.607281 C 9.6090297,27.607281 4.4362021,22.410122 4.4362021,16 Z" /><path |  | ||||||
|      sodipodi:nodetypes="ccsccccccccccccccccccccccc" |  | ||||||
|      style="color:#bebebe;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:medium;line-height:normal;font-family:'Andale Mono';-inkscape-font-specification:'Andale Mono';text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;letter-spacing:normal;word-spacing:normal;text-transform:none;writing-mode:lr-tb;direction:ltr;text-anchor:start;display:inline;overflow:visible;visibility:visible;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.87958801;marker:none;enable-background:new" |  | ||||||
|      id="path826" |  | ||||||
|      inkscape:connector-curvature="0" |  | ||||||
|      d="m 11.718386,11.764547 h 1.055207 c 0.01091,-1.26e-4 0.02193,-4.86e-4 0.03298,0 0.269026,0.01183 0.538019,0.135679 0.725455,0.329752 l 2.407192,2.407192 2.440166,-2.407192 c 0.28029,-0.243226 0.471333,-0.322366 0.725455,-0.329752 h 1.055207 v 1.055208 c 0,0.302285 -0.03623,0.581049 -0.263801,0.791405 l -2.407191,2.407191 2.374217,2.374216 c 0.198577,0.198559 0.296768,0.478484 0.296775,0.758432 v 1.055206 h -1.055211 c -0.279947,-10e-6 -0.559877,-0.09824 -0.75843,-0.296777 l -2.407192,-2.407192 -2.407192,2.407192 c -0.198551,0.198579 -0.478493,0.296777 -0.758429,0.296777 H 11.71839 v -1.055206 c -3e-6,-0.279936 0.0982,-0.559873 0.296777,-0.758432 L 14.422359,16.018351 12.015167,13.61116 C 11.79279,13.405784 11.69527,13.116003 11.71839,12.819755 Z" /></svg> |  | ||||||
| Before Width: | Height: | Size: 4.6 KiB | 
| @@ -1,85 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Generator: Adobe Illustrator 13.0.2, SVG Export Plug-In . SVG Version: 6.00 Build 14948)  --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    version="1.0" |  | ||||||
|    id="Foreground" |  | ||||||
|    x="0px" |  | ||||||
|    y="0px" |  | ||||||
|    width="32" |  | ||||||
|    height="32" |  | ||||||
|    viewBox="0 0 32 32" |  | ||||||
|    enable-background="new 0 0 16 16" |  | ||||||
|    xml:space="preserve" |  | ||||||
|    sodipodi:version="0.32" |  | ||||||
|    inkscape:version="0.92.2 5c3e80d, 2017-08-06" |  | ||||||
|    sodipodi:docname="close-window.svg" |  | ||||||
|    inkscape:output_extension="org.inkscape.output.svg.inkscape"><metadata |  | ||||||
|      id="metadata2399"><rdf:RDF><cc:Work |  | ||||||
|          rdf:about=""><dc:format>image/svg+xml</dc:format><dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /><dc:title></dc:title></cc:Work></rdf:RDF></metadata><defs |  | ||||||
|      id="defs2397"><linearGradient |  | ||||||
|        id="linearGradient3173"><stop |  | ||||||
|          style="stop-color:#c4c4c4;stop-opacity:1;" |  | ||||||
|          offset="0" |  | ||||||
|          id="stop3175" /><stop |  | ||||||
|          style="stop-color:#ffffff;stop-opacity:1;" |  | ||||||
|          offset="1" |  | ||||||
|          id="stop3177" /></linearGradient><inkscape:perspective |  | ||||||
|        sodipodi:type="inkscape:persp3d" |  | ||||||
|        inkscape:vp_x="0 : 11 : 1" |  | ||||||
|        inkscape:vp_y="0 : 1375 : 0" |  | ||||||
|        inkscape:vp_z="22 : 11 : 1" |  | ||||||
|        inkscape:persp3d-origin="11 : 7.3333334 : 1" |  | ||||||
|        id="perspective2401" /></defs><sodipodi:namedview |  | ||||||
|      inkscape:window-height="1106" |  | ||||||
|      inkscape:window-width="1700" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:pageopacity="0" |  | ||||||
|      guidetolerance="10.0" |  | ||||||
|      gridtolerance="10.0" |  | ||||||
|      objecttolerance="10.0" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      pagecolor="#797979" |  | ||||||
|      id="base" |  | ||||||
|      showgrid="false" |  | ||||||
|      inkscape:zoom="4" |  | ||||||
|      inkscape:cx="28.483745" |  | ||||||
|      inkscape:cy="67.714004" |  | ||||||
|      inkscape:window-x="1427" |  | ||||||
|      inkscape:window-y="127" |  | ||||||
|      inkscape:current-layer="Foreground" |  | ||||||
|      showguides="true" |  | ||||||
|      inkscape:guide-bbox="true" |  | ||||||
|      borderlayer="true" |  | ||||||
|      inkscape:showpageshadow="false" |  | ||||||
|      inkscape:window-maximized="0" |  | ||||||
|      inkscape:document-rotation="0"><inkscape:grid |  | ||||||
|        type="xygrid" |  | ||||||
|        id="grid11246" |  | ||||||
|        empspacing="32" |  | ||||||
|        visible="true" |  | ||||||
|        enabled="true" |  | ||||||
|        snapvisiblegridlinesonly="true" /></sodipodi:namedview><path |  | ||||||
|      d="m 4.4362021,15.860384 c 0,-6.410121 5.1728276,-11.60728 11.5529359,-11.60728 6.380109,0 11.552937,5.197159 11.552937,11.60728 0,6.410122 -5.172828,11.607281 -11.552937,11.607281 -6.3801083,0 -11.5529359,-5.197159 -11.5529359,-11.607281 z" |  | ||||||
|      id="path2394-32" |  | ||||||
|      style="color:#000000;clip-rule:evenodd;display:inline;overflow:visible;visibility:visible;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:#2975c4;stroke-width:4;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate" |  | ||||||
|      sodipodi:nodetypes="csssc" |  | ||||||
|      inkscape:connector-curvature="0" /><path |  | ||||||
|      style="color:#000000;display:inline;overflow:visible;visibility:visible;opacity:0.49900004;fill:#4a90d9;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.74932218;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate" |  | ||||||
|      d="m 6.4654832,15.001321 c -0.025906,0.288419 -0.044417,0.579469 -0.044417,0.874662 0,5.313347 4.2883848,9.621271 9.5768588,9.621271 5.288466,0 9.575143,-4.307924 9.575143,-9.621271 0,-0.295193 -0.01852,-0.586243 -0.04441,-0.874662 -0.440376,4.903023 -4.536071,8.746611 -9.53073,8.746611 -4.994659,0 -9.0920617,-3.843588 -9.5324391,-8.746611 z" |  | ||||||
|      id="path2561" |  | ||||||
|      inkscape:connector-curvature="0" /><path |  | ||||||
|      d="m 11.718386,11.639547 h 1.055207 c 0.01091,-1.26e-4 0.02193,-4.86e-4 0.03298,0 0.269026,0.01183 0.538019,0.135679 0.725455,0.329752 l 2.407192,2.407192 2.440166,-2.407192 c 0.28029,-0.243226 0.471333,-0.322366 0.725455,-0.329752 h 1.055207 v 1.055208 c 0,0.302285 -0.03623,0.581049 -0.263801,0.791405 l -2.407191,2.407191 2.374217,2.374216 c 0.198577,0.198559 0.296768,0.478484 0.296775,0.758432 v 1.055206 h -1.055211 c -0.279947,-10e-6 -0.559877,-0.09824 -0.75843,-0.296777 l -2.407192,-2.407192 -2.407192,2.407192 c -0.198551,0.198579 -0.478493,0.296777 -0.758429,0.296777 H 11.71839 v -1.055206 c -3e-6,-0.279936 0.0982,-0.559873 0.296777,-0.758432 L 14.422359,15.893351 12.015167,13.48616 C 11.79279,13.280784 11.69527,12.991003 11.71839,12.694755 Z" |  | ||||||
|      inkscape:connector-curvature="0" |  | ||||||
|      id="path27279-0-5" |  | ||||||
|      style="color:#bebebe;font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:medium;line-height:normal;font-family:'Andale Mono';-inkscape-font-specification:'Andale Mono';text-indent:0;text-align:start;text-decoration:none;text-decoration-line:none;letter-spacing:normal;word-spacing:normal;text-transform:none;writing-mode:lr-tb;direction:ltr;text-anchor:start;display:inline;overflow:visible;visibility:visible;fill:#4a90d9;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.87958801;marker:none;enable-background:new" |  | ||||||
|      sodipodi:nodetypes="ccsccccccccccccccccccccccc" /></svg> |  | ||||||
| Before Width: | Height: | Size: 5.3 KiB | 
| Before Width: | Height: | Size: 2.4 KiB | 
| Before Width: | Height: | Size: 2.3 KiB | 
| @@ -1,3 +1,5 @@ | |||||||
|  | $variant: 'light'; | ||||||
|  |  | ||||||
| @import "gnome-shell-sass/_high-contrast-colors"; //use gtk colors | @import "gnome-shell-sass/_high-contrast-colors"; //use gtk colors | ||||||
| @import "gnome-shell-sass/_drawing"; | @import "gnome-shell-sass/_drawing"; | ||||||
| @import "gnome-shell-sass/_common"; | @import "gnome-shell-sass/_common"; | ||||||
|   | |||||||
| @@ -2,33 +2,34 @@ | |||||||
| // it gets @if ed depending on $variant | // it gets @if ed depending on $variant | ||||||
|  |  | ||||||
|  |  | ||||||
| $base_color: if($variant =='light', #ffffff, #292929); | $base_color: if($variant == 'light', #ffffff, lighten(desaturate(#241f31, 20%), 2%)); | ||||||
| $bg_color: if($variant =='light', #ededed, #393f3f); | $bg_color: if($variant == 'light', #f6f5f4, darken(desaturate(#3d3846, 100%), 4%)); | ||||||
| $fg_color: if($variant =='light', #2e3436, #eeeeec); | $fg_color: if($variant == 'light', #2e3436, #eeeeec); | ||||||
|  |  | ||||||
| $selected_fg_color: #ffffff; | $selected_fg_color: #ffffff; | ||||||
| $selected_bg_color: if($variant == 'light', #4a90d9, darken(#4a90d9,20%)); | $selected_bg_color: if($variant == 'light', #3584e4, darken(#3584e4, 10%)); | ||||||
| $selected_borders_color: if($variant=='light', darken($selected_bg_color, 30%), | $selected_borders_color: if($variant== 'light', darken($selected_bg_color, 15%), darken($selected_bg_color, 30%)); | ||||||
|                                                darken($selected_bg_color, 20%)); | $borders_color: if($variant == 'light', darken($bg_color, 18%), darken($bg_color, 10%)); | ||||||
| $borders_color: if($variant =='light', darken($bg_color,30%), darken($bg_color,12%)); | $borders_edge: if($variant == 'light', transparentize(white, 0.2), transparentize($fg_color, 0.93)); | ||||||
| $borders_edge: if($variant =='light', white, transparentize($fg_color, 0.9)); | $link_color: if($variant == 'light', darken($selected_bg_color, 10%), lighten($selected_bg_color, 20%)); | ||||||
| $link_color: if($variant == 'light', darken($selected_bg_color,10%), | $link_visited_color: if($variant == 'light', darken($selected_bg_color, 20%), lighten($selected_bg_color, 10%)); | ||||||
|                                      lighten($selected_bg_color,20%)); |  | ||||||
| $link_visited_color: if($variant == 'light', darken($selected_bg_color,20%), |  | ||||||
|                                      lighten($selected_bg_color,10%)); |  | ||||||
| $top_hilight: $borders_edge; | $top_hilight: $borders_edge; | ||||||
|  |  | ||||||
| $warning_color: #f57900; | $warning_color: #f57900; | ||||||
| $error_color: #cc0000; | $error_color: #ff8080; | ||||||
| $success_color: if($variant =='light', #73d216, darken(#73d216,10%)); | $success_color: if($variant == 'light', #33d17a, darken(#33d17a, 10%)); | ||||||
| $destructive_color: if($variant =='light', #ef2929, darken(#ef2929,10%)); | $destructive_color: if($variant == 'light', #e01b24, darken(#e01b24, 10%)); | ||||||
|  |  | ||||||
| $osd_fg_color: #eeeeec; | $osd_fg_color: #eeeeec; | ||||||
| $osd_bg_color: #2e3436; | $osd_text_color: white; | ||||||
|  | $osd_bg_color: transparentize(darken(desaturate(#3d3846, 100%), 12%),0.04); | ||||||
|  | $osd_insensitive_bg_color: transparentize(mix($osd_fg_color, opacify($osd_bg_color, 1), 10%), 0.5); | ||||||
|  | $osd_insensitive_fg_color: mix($osd_fg_color, opacify($osd_bg_color, 1), 50%); | ||||||
| $osd_borders_color: transparentize(black, 0.3); | $osd_borders_color: transparentize(black, 0.3); | ||||||
| $osd_outer_borders_color: transparentize(white, 0.9); | $osd_outer_borders_color: transparentize(white, 0.84); | ||||||
|  |  | ||||||
| $tooltip_borders_color: $osd_outer_borders_color; | $tooltip_borders_color: $osd_outer_borders_color; | ||||||
|  | $shadow_color: transparentize(black, 0.9); | ||||||
|  |  | ||||||
| //insensitive state derived colors | //insensitive state derived colors | ||||||
| $insensitive_fg_color: mix($fg_color, $bg_color, 50%); | $insensitive_fg_color: mix($fg_color, $bg_color, 50%); | ||||||
|   | |||||||
| @@ -37,16 +37,13 @@ | |||||||
| // possible $t values: | // possible $t values: | ||||||
| // normal, focus, insensitive | // normal, focus, insensitive | ||||||
| // | // | ||||||
|   $_inner_shadows: inset 0 2px 4px transparentize(black, 0.6); |  | ||||||
|  |  | ||||||
|   @if $t==normal { |   @if $t==normal { | ||||||
|     background-color: $base_color; |     background-color: $base_color; | ||||||
|     border-color: $borders_color; |     border-color: $borders_color; | ||||||
|     @include _shadows($_inner_shadows); |  | ||||||
|  |  | ||||||
|   } |   } | ||||||
|   @if $t==focus { |   @if $t==focus { | ||||||
|     @include _shadows($_inner_shadows); |  | ||||||
|     border-color: if($fc==$selected_bg_color, |     border-color: if($fc==$selected_bg_color, | ||||||
|                      $selected_borders_color, |                      $selected_borders_color, | ||||||
|                      darken($fc,35%)); |                      darken($fc,35%)); | ||||||
| @@ -111,7 +108,7 @@ | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| @mixin button($t, $c:$osd_bg_color, $tc:$fg_color, $edge: $borders_edge) { | @mixin button($t, $c:$bg_color, $tc:$fg_color, $edge: $borders_edge) { | ||||||
| // | // | ||||||
| // Button drawing function | // Button drawing function | ||||||
| // | // | ||||||
| @@ -130,46 +127,39 @@ | |||||||
|   $_hilight_color: _button_hilight_color($c); |   $_hilight_color: _button_hilight_color($c); | ||||||
|   $_button_edge: if($edge == none, none, _widget_edge($edge)); |   $_button_edge: if($edge == none, none, _widget_edge($edge)); | ||||||
|   $_blank_edge: if($edge == none, none, _widget_edge(transparentize($edge,1))); |   $_blank_edge: if($edge == none, none, _widget_edge(transparentize($edge,1))); | ||||||
|  |   $_button_shadow: 0 1px 2px transparentize($shadow_color, 0.03); | ||||||
|  |  | ||||||
|   @if $t==normal { |   @if $t==normal { | ||||||
|   // |   // | ||||||
|   // normal button |   // normal button | ||||||
|   // |   // | ||||||
|     $_bg: if($c!=$osd_bg_color, transparentize($c, 0.5), |  | ||||||
|                             $osd_bg_color); |  | ||||||
|  |  | ||||||
|     color: $osd_fg_color; |     color: $tc; | ||||||
|     background-color: $_bg; |     background-color: $c; | ||||||
|     border-color: $osd_borders_color; |     border-color: $borders_color; | ||||||
|     box-shadow: inset 0 1px lighten($osd_bg_color,10%); |     box-shadow: $_button_shadow; | ||||||
|     text-shadow: 0 1px black; |     text-shadow: 0 1px black; | ||||||
|     icon-shadow: 0 1px black; |     icon-shadow: 0 1px black; | ||||||
|   } |   } | ||||||
|   @if $t==focus { |   @if $t==focus { | ||||||
|   // |   // | ||||||
|   // focused button |   // focused button | ||||||
|   // |   //   | ||||||
|     $_bg: if($c!=$osd_bg_color, transparentize($c, 0.3), |     color: $tc; | ||||||
|                           lighten($osd_bg_color,3%)); |  | ||||||
|  |  | ||||||
|     color: $osd_fg_color; |  | ||||||
|     text-shadow: 0 1px black; |     text-shadow: 0 1px black; | ||||||
|     icon-shadow: 0 1px black; |     icon-shadow: 0 1px black; | ||||||
|     box-shadow: inset 0px 0px 0px 1px $selected_bg_color; |     box-shadow: inset 0px 0px 0px 2px $selected_bg_color; | ||||||
|  |     //border-color: $selected_bg_color; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   @else if $t==hover { |   @else if $t==hover { | ||||||
|   // |   // | ||||||
|   // active osd button |   // active osd button | ||||||
|   // |   // | ||||||
|     $_bg: if($c!=$osd_bg_color, transparentize($c, 0.3), |     color: $tc; | ||||||
|                             lighten($osd_bg_color,3%)); |     border-color: $borders_color; | ||||||
|  |     background-color: $c; | ||||||
|     color: white; |     box-shadow: $_button_shadow; | ||||||
|     border-color: $osd_borders_color; |  | ||||||
|     background-color: $_bg; |  | ||||||
|     box-shadow: inset 0 1px lighten($osd_bg_color,20%); |  | ||||||
|     text-shadow: 0 1px black; |     text-shadow: 0 1px black; | ||||||
|     icon-shadow: 0 1px black; |     icon-shadow: 0 1px black; | ||||||
|  |  | ||||||
| @@ -178,27 +168,18 @@ | |||||||
|   // |   // | ||||||
|   // active osd button |   // active osd button | ||||||
|   // |   // | ||||||
|     $_bg: if($c!=$bg_color, $c, $osd_borders_color); |     color: $tc; | ||||||
|  |     border-color: $borders_color; | ||||||
|     color: white; |     background-color: $c; | ||||||
|     border-color: $osd_borders_color; |  | ||||||
|     background-color: $selected_bg_color; |  | ||||||
|     // This should be none, but it's creating some issues with borders, so to |  | ||||||
|     // workaround it for now, use inset wich goes through a different code path. |  | ||||||
|     // see https://bugzilla.gnome.org/show_bug.cgi?id=752934 |  | ||||||
|     box-shadow: inset 0 0 black; |  | ||||||
|     text-shadow: none; |     text-shadow: none; | ||||||
|     icon-shadow: none; |     icon-shadow: none; | ||||||
|  |     box-shadow: none; | ||||||
|   } |   } | ||||||
|   @else if $t==insensitive { |   @else if $t==insensitive { | ||||||
|   // |  | ||||||
|   // insensitive osd button |  | ||||||
|   // |  | ||||||
|     $_bg: transparentize(mix($insensitive_fg_color,$osd_bg_color,20%),0.3); |  | ||||||
|  |  | ||||||
|     color: $insensitive_fg_color; |     color: $insensitive_fg_color; | ||||||
|     border-color: $osd_borders_color; |     border-color: $insensitive_borders_color; | ||||||
|     background-color: $_bg; |     background-color: $insensitive_bg_color; | ||||||
|     box-shadow: none; |     box-shadow: none; | ||||||
|     text-shadow: none; |     text-shadow: none; | ||||||
|     icon-shadow: none; |     icon-shadow: none; | ||||||
|   | |||||||
| @@ -26,6 +26,7 @@ $osd_borders_color: transparentize(black, 0.3); | |||||||
| $osd_outer_borders_color: transparentize(white, 0.9); | $osd_outer_borders_color: transparentize(white, 0.9); | ||||||
|  |  | ||||||
| $tooltip_borders_color: $osd_outer_borders_color; | $tooltip_borders_color: $osd_outer_borders_color; | ||||||
|  | $shadow_color: transparentize(black, 0.9); | ||||||
|  |  | ||||||
| //insensitive state derived colors | //insensitive state derived colors | ||||||
| $insensitive_fg_color: mix($fg_color, $bg_color, 50%); | $insensitive_fg_color: mix($fg_color, $bg_color, 50%); | ||||||
|   | |||||||
| @@ -1,71 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    width="18" |  | ||||||
|    height="18" |  | ||||||
|    id="svg4703" |  | ||||||
|    version="1.1" |  | ||||||
|    inkscape:version="0.48.4 r9939" |  | ||||||
|    sodipodi:docname="page-indicator-pushed.svg"> |  | ||||||
|   <defs |  | ||||||
|      id="defs4705" /> |  | ||||||
|   <sodipodi:namedview |  | ||||||
|      id="base" |  | ||||||
|      pagecolor="#ffffff" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      inkscape:pageopacity="0.0" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:zoom="31.392433" |  | ||||||
|      inkscape:cx="1.0245308" |  | ||||||
|      inkscape:cy="13.3715" |  | ||||||
|      inkscape:current-layer="layer1" |  | ||||||
|      showgrid="true" |  | ||||||
|      inkscape:grid-bbox="true" |  | ||||||
|      inkscape:document-units="px" |  | ||||||
|      inkscape:window-width="2560" |  | ||||||
|      inkscape:window-height="1374" |  | ||||||
|      inkscape:window-x="0" |  | ||||||
|      inkscape:window-y="27" |  | ||||||
|      inkscape:window-maximized="1"> |  | ||||||
|     <inkscape:grid |  | ||||||
|        type="xygrid" |  | ||||||
|        id="grid6140" /> |  | ||||||
|   </sodipodi:namedview> |  | ||||||
|   <metadata |  | ||||||
|      id="metadata4708"> |  | ||||||
|     <rdf:RDF> |  | ||||||
|       <cc:Work |  | ||||||
|          rdf:about=""> |  | ||||||
|         <dc:format>image/svg+xml</dc:format> |  | ||||||
|         <dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |  | ||||||
|         <dc:title></dc:title> |  | ||||||
|       </cc:Work> |  | ||||||
|     </rdf:RDF> |  | ||||||
|   </metadata> |  | ||||||
|   <g |  | ||||||
|      id="layer1" |  | ||||||
|      inkscape:label="Layer 1" |  | ||||||
|      inkscape:groupmode="layer" |  | ||||||
|      transform="translate(0,2)"> |  | ||||||
|     <path |  | ||||||
|        transform="matrix(0.54617904,0,0,0.62523128,-1131.9904,-392.39214)" |  | ||||||
|        d="m 2099.9808,638.83099 a 10.985409,9.5964489 0 1 1 -21.9708,0 10.985409,9.5964489 0 1 1 21.9708,0 z" |  | ||||||
|        sodipodi:ry="9.5964489" |  | ||||||
|        sodipodi:rx="10.985409" |  | ||||||
|        sodipodi:cy="638.83099" |  | ||||||
|        sodipodi:cx="2088.9954" |  | ||||||
|        id="path4711" |  | ||||||
|        style="fill:#fdffff;fill-opacity:1;stroke:none" |  | ||||||
|        sodipodi:type="arc" /> |  | ||||||
|   </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 2.1 KiB | 
| @@ -1,67 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    width="18" |  | ||||||
|    height="18" |  | ||||||
|    id="svg4703" |  | ||||||
|    version="1.1" |  | ||||||
|    inkscape:version="0.48.4 r9939" |  | ||||||
|    sodipodi:docname="page-indicator-active.svg"> |  | ||||||
|   <defs |  | ||||||
|      id="defs4705" /> |  | ||||||
|   <sodipodi:namedview |  | ||||||
|      id="base" |  | ||||||
|      pagecolor="#ffffff" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      inkscape:pageopacity="0.0" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:zoom="22.197802" |  | ||||||
|      inkscape:cx="2.1522887" |  | ||||||
|      inkscape:cy="16.782904" |  | ||||||
|      inkscape:current-layer="layer1" |  | ||||||
|      showgrid="true" |  | ||||||
|      inkscape:grid-bbox="true" |  | ||||||
|      inkscape:document-units="px" |  | ||||||
|      inkscape:window-width="1920" |  | ||||||
|      inkscape:window-height="1021" |  | ||||||
|      inkscape:window-x="0" |  | ||||||
|      inkscape:window-y="27" |  | ||||||
|      inkscape:window-maximized="1" /> |  | ||||||
|   <metadata |  | ||||||
|      id="metadata4708"> |  | ||||||
|     <rdf:RDF> |  | ||||||
|       <cc:Work |  | ||||||
|          rdf:about=""> |  | ||||||
|         <dc:format>image/svg+xml</dc:format> |  | ||||||
|         <dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |  | ||||||
|         <dc:title /> |  | ||||||
|       </cc:Work> |  | ||||||
|     </rdf:RDF> |  | ||||||
|   </metadata> |  | ||||||
|   <g |  | ||||||
|      id="layer1" |  | ||||||
|      inkscape:label="Layer 1" |  | ||||||
|      inkscape:groupmode="layer" |  | ||||||
|      transform="translate(0,2)"> |  | ||||||
|     <path |  | ||||||
|        transform="matrix(0.72823872,0,0,0.8336417,-1512.2872,-525.55618)" |  | ||||||
|        d="m 2099.9808,638.83099 c 0,5.29998 -4.9184,9.59645 -10.9854,9.59645 -6.0671,0 -10.9854,-4.29647 -10.9854,-9.59645 0,-5.29997 4.9183,-9.59645 10.9854,-9.59645 6.067,0 10.9854,4.29648 10.9854,9.59645 z" |  | ||||||
|        sodipodi:ry="9.5964489" |  | ||||||
|        sodipodi:rx="10.985409" |  | ||||||
|        sodipodi:cy="638.83099" |  | ||||||
|        sodipodi:cx="2088.9954" |  | ||||||
|        id="path4711" |  | ||||||
|        style="fill:#fdffff;fill-opacity:0.94117647;stroke:none" |  | ||||||
|        sodipodi:type="arc" /> |  | ||||||
|   </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 2.1 KiB | 
| @@ -1,67 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    width="18" |  | ||||||
|    height="18" |  | ||||||
|    id="svg5266" |  | ||||||
|    version="1.1" |  | ||||||
|    inkscape:version="0.48.4 r9939" |  | ||||||
|    sodipodi:docname="page-indicator-inactive.svg"> |  | ||||||
|   <defs |  | ||||||
|      id="defs5268" /> |  | ||||||
|   <sodipodi:namedview |  | ||||||
|      id="base" |  | ||||||
|      pagecolor="#ffffff" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      inkscape:pageopacity="0" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:zoom="11.313709" |  | ||||||
|      inkscape:cx="-2.307566" |  | ||||||
|      inkscape:cy="17.859535" |  | ||||||
|      inkscape:current-layer="layer1" |  | ||||||
|      showgrid="true" |  | ||||||
|      inkscape:grid-bbox="true" |  | ||||||
|      inkscape:document-units="px" |  | ||||||
|      inkscape:window-width="2560" |  | ||||||
|      inkscape:window-height="1374" |  | ||||||
|      inkscape:window-x="0" |  | ||||||
|      inkscape:window-y="27" |  | ||||||
|      inkscape:window-maximized="1" /> |  | ||||||
|   <metadata |  | ||||||
|      id="metadata5271"> |  | ||||||
|     <rdf:RDF> |  | ||||||
|       <cc:Work |  | ||||||
|          rdf:about=""> |  | ||||||
|         <dc:format>image/svg+xml</dc:format> |  | ||||||
|         <dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |  | ||||||
|         <dc:title></dc:title> |  | ||||||
|       </cc:Work> |  | ||||||
|     </rdf:RDF> |  | ||||||
|   </metadata> |  | ||||||
|   <g |  | ||||||
|      id="layer1" |  | ||||||
|      inkscape:label="Layer 1" |  | ||||||
|      inkscape:groupmode="layer" |  | ||||||
|      transform="translate(0,2)"> |  | ||||||
|     <path |  | ||||||
|        sodipodi:type="arc" |  | ||||||
|        style="fill:none;fill-opacity:0;stroke:#ffffff;stroke-width:2.93356276000000005;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none" |  | ||||||
|        id="path5274" |  | ||||||
|        sodipodi:cx="2088.9954" |  | ||||||
|        sodipodi:cy="638.83099" |  | ||||||
|        sodipodi:rx="10.985409" |  | ||||||
|        sodipodi:ry="9.5964489" |  | ||||||
|        d="m 2099.9808,638.83099 c 0,5.29998 -4.9184,9.59645 -10.9854,9.59645 -6.0671,0 -10.9854,-4.29647 -10.9854,-9.59645 0,-5.29997 4.9183,-9.59645 10.9854,-9.59645 6.067,0 10.9854,4.29648 10.9854,9.59645 z" |  | ||||||
|        transform="matrix(0.63720887,0,0,0.72943648,-1322.1264,-458.98661)" /> |  | ||||||
|   </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 2.2 KiB | 
| @@ -1,67 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    width="18" |  | ||||||
|    height="18" |  | ||||||
|    id="svg5266" |  | ||||||
|    version="1.1" |  | ||||||
|    inkscape:version="0.48.4 r9939" |  | ||||||
|    sodipodi:docname="page-indicator-inactive.svg"> |  | ||||||
|   <defs |  | ||||||
|      id="defs5268" /> |  | ||||||
|   <sodipodi:namedview |  | ||||||
|      id="base" |  | ||||||
|      pagecolor="#ffffff" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      inkscape:pageopacity="0" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:zoom="11.313709" |  | ||||||
|      inkscape:cx="-2.307566" |  | ||||||
|      inkscape:cy="17.859535" |  | ||||||
|      inkscape:current-layer="layer1" |  | ||||||
|      showgrid="true" |  | ||||||
|      inkscape:grid-bbox="true" |  | ||||||
|      inkscape:document-units="px" |  | ||||||
|      inkscape:window-width="2560" |  | ||||||
|      inkscape:window-height="1374" |  | ||||||
|      inkscape:window-x="0" |  | ||||||
|      inkscape:window-y="27" |  | ||||||
|      inkscape:window-maximized="1" /> |  | ||||||
|   <metadata |  | ||||||
|      id="metadata5271"> |  | ||||||
|     <rdf:RDF> |  | ||||||
|       <cc:Work |  | ||||||
|          rdf:about=""> |  | ||||||
|         <dc:format>image/svg+xml</dc:format> |  | ||||||
|         <dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |  | ||||||
|         <dc:title /> |  | ||||||
|       </cc:Work> |  | ||||||
|     </rdf:RDF> |  | ||||||
|   </metadata> |  | ||||||
|   <g |  | ||||||
|      id="layer1" |  | ||||||
|      inkscape:label="Layer 1" |  | ||||||
|      inkscape:groupmode="layer" |  | ||||||
|      transform="translate(0,2)"> |  | ||||||
|     <path |  | ||||||
|        sodipodi:type="arc" |  | ||||||
|        style="fill:none;fill-opacity:0;stroke:#ffffff;stroke-width:2.93356276000000005;stroke-miterlimit:4;stroke-opacity:0.39215686000000000;stroke-dasharray:none" |  | ||||||
|        id="path5274" |  | ||||||
|        sodipodi:cx="2088.9954" |  | ||||||
|        sodipodi:cy="638.83099" |  | ||||||
|        sodipodi:rx="10.985409" |  | ||||||
|        sodipodi:ry="9.5964489" |  | ||||||
|        d="m 2099.9808,638.83099 c 0,5.29998 -4.9184,9.59645 -10.9854,9.59645 -6.0671,0 -10.9854,-4.29647 -10.9854,-9.59645 0,-5.29997 4.9183,-9.59645 10.9854,-9.59645 6.067,0 10.9854,4.29648 10.9854,9.59645 z" |  | ||||||
|        transform="matrix(0.63720887,0,0,0.72943648,-1322.1264,-458.98661)" /> |  | ||||||
|   </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 2.2 KiB | 
							
								
								
									
										28
									
								
								data/theme/pointer-double-click-symbolic.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,28 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
|  | <svg | ||||||
|  |    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||||
|  |    xmlns:cc="http://creativecommons.org/ns#" | ||||||
|  |    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||||
|  |    xmlns:svg="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" | ||||||
|  |    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||||
|  |    width="20" | ||||||
|  |    height="20" | ||||||
|  |    id="svg2"> | ||||||
|  |   <g | ||||||
|  |      id="layer1" | ||||||
|  |      style="display:inline"> | ||||||
|  |     <g | ||||||
|  |        id="id1" | ||||||
|  |        transform="translate(-19,-0.75)"> | ||||||
|  |       <path | ||||||
|  |          style="color:#000000;shape-padding:0;clip-rule:nonzero;display:block;overflow:visible;visibility:visible;opacity:1;solid-color:#000000;solid-opacity:1;fill:#464646;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.5;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:10;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate" | ||||||
|  |          d="m 19.855469,0.45507812 c 0,6.69466128 0,13.38932288 0,20.08398388 1.414713,-1.38151 2.829427,-2.763021 4.24414,-4.144531 0.5882,1.18866 1.158389,2.386561 1.758464,3.569127 1.108631,1.640259 4.157538,0.465128 3.89799,-1.495859 0.01057,-0.470226 -0.405577,-0.908445 -0.434651,-1.313638 0.259401,-0.25321 0.518802,-0.50642 0.778203,-0.75963 0.5882,1.18866 1.158389,2.386561 1.758464,3.569127 1.108631,1.640259 4.157538,0.465128 3.89799,-1.495859 -0.192325,-0.904303 -0.717854,-1.698026 -1.068629,-2.548967 -0.238908,-0.512658 -0.477817,-1.025315 -0.716725,-1.537973 1.755859,0 3.511719,0 5.267578,0 C 34.777352,9.738932 30.31641,5.0970051 25.855469,0.45507812 c 0,2.08138018 0,4.16276048 0,6.24414068 -2,-2.0813802 -4,-4.1627605 -6,-6.24414068 z m 1.5,3.72656248 c 2,2.0813801 4,4.1627603 6,6.2441404 0,-2.0813801 0,-4.1627603 0,-6.2441404 2.786458,2.8997395 5.572917,5.7994789 8.359375,8.6992184 -1.366537,0 -2.733073,0 -4.09961,0 0.883468,1.903435 1.781983,3.800273 2.656081,5.707817 0.0065,0.622781 -1.227555,0.980575 -1.325116,0.207118 -0.80433,-1.640251 -1.608661,-3.280501 -2.412991,-4.920752 -1.020182,0.995443 -2.040365,1.990885 -3.060547,2.986328 0.263642,0.608048 0.596803,1.192457 0.814693,1.816134 -0.182662,0.601037 -1.26833,0.8373 -1.365856,0.06795 -0.796094,-1.623456 -1.592189,-3.246912 -2.388284,-4.870368 -1.059245,1.033854 -2.118489,2.067708 -3.177734,3.101562 -4e-6,-4.265002 -7e-6,-8.5300036 -1.1e-5,-12.7950054 z" | ||||||
|  |          id="path5565" /> | ||||||
|  |     </g> | ||||||
|  |     <g | ||||||
|  |        id="id2" | ||||||
|  |        transform="translate(-25,-0.75)" /> | ||||||
|  |   </g> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 2.5 KiB | 
							
								
								
									
										20
									
								
								data/theme/pointer-drag-symbolic.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,20 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
|  | <svg | ||||||
|  |    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||||
|  |    xmlns:cc="http://creativecommons.org/ns#" | ||||||
|  |    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||||
|  |    xmlns:svg="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" | ||||||
|  |    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||||
|  |    width="20" | ||||||
|  |    height="20" | ||||||
|  |    id="svg2"> | ||||||
|  |   <g | ||||||
|  |      id="g835"> | ||||||
|  |     <path | ||||||
|  |        style="color:#000000;shape-padding:0;clip-rule:nonzero;display:block;overflow:visible;visibility:visible;opacity:1;solid-color:#000000;solid-opacity:1;fill:#464646;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.5;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:10;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate" | ||||||
|  |        d="M 10.705078 1.671875 C 9.8685536 1.7465699 8.886927 1.5353073 8.2578125 2.2480469 C 8.0785627 2.7511513 7.8667422 2.9777446 7.3125 2.8652344 C 6.5186841 2.8141575 5.6105879 2.9190179 5.125 3.6386719 C 4.5700923 4.4696324 4.8113194 5.4949043 4.7578125 6.4316406 L 4.7578125 7.9335938 C 4.2480917 7.6156216 3.6258927 7.8015358 3.0585938 7.7519531 C 2.6157606 7.7312277 2.1774807 7.7771069 1.7402344 7.84375 C 1.7971654 10.529678 1.813967 13.217089 1.8613281 15.902344 C 1.9550191 17.204635 3.0933719 18.307155 4.40625 18.326172 C 5.0391993 18.341272 5.8885801 18.332951 6.6308594 18.337891 C 9.8526764 18.325821 13.076973 18.38774 16.296875 18.28125 C 17.459088 18.161027 18.510143 17.092798 18.367188 15.884766 L 18.367188 6.4042969 C 17.660379 5.4636119 16.551912 4.623434 15.308594 4.8339844 C 15.009045 4.3804158 14.822476 3.3608651 14.082031 3.0351562 C 13.727176 2.744118 13.242443 2.9253873 12.822266 2.8730469 C 12.524824 2.8003648 11.966366 3.0655864 11.953125 2.6210938 C 11.795774 2.0995736 11.23789 1.7125276 10.705078 1.671875 z M 10.599609 3.1757812 C 10.764131 3.4472414 10.782382 3.9294982 10.818359 4.3007812 C 10.824915 4.3076775 10.838155 4.3066925 10.845703 4.3125 C 10.836598 4.3123268 10.827465 4.3126732 10.818359 4.3125 L 11.3125 10.212891 L 11.976562 4.3710938 L 13.322266 4.375 C 13.858345 4.7645492 13.735252 5.5154752 13.876953 6.0976562 C 13.865826 6.1651282 13.88335 6.1937019 13.892578 6.234375 C 13.891928 6.2343667 13.891276 6.2343833 13.890625 6.234375 L 13.902344 6.3203125 L 14.384766 10.185547 L 15.048828 6.265625 C 15.622863 6.228498 16.206517 6.3041365 16.607422 6.7675781 C 17.017062 6.9844433 16.823063 7.4565491 16.867188 7.8261719 L 16.867188 16.167969 C 16.530129 17.131654 15.267211 16.71624 14.492188 16.828125 C 11.121671 16.841205 7.7500508 16.861953 4.3808594 16.814453 C 3.4051926 16.786173 3.2389196 15.744474 3.3398438 14.972656 C 3.3282027 13.065594 3.2950998 11.158732 3.2617188 9.2519531 C 3.5880829 9.2584131 3.9376766 9.2391948 4.25 9.2617188 C 4.7438842 10.17694 4.7346154 11.262903 4.7578125 12.277344 C 5.2504494 12.270544 5.8011939 12.317174 6.2578125 12.277344 C 6.2669593 9.7577406 6.2393741 7.2373172 6.2714844 4.71875 C 6.3763823 4.198849 7.0022289 4.409587 7.3828125 4.3652344 L 8.0585938 4.3652344 L 8.546875 10.212891 L 9.2167969 4.3359375 L 9.2128906 4.3359375 C 9.2438386 3.9531035 9.0622615 3.4401006 9.4609375 3.2167969 L 10.599609 3.1757812 z " | ||||||
|  |        id="path5630" /> | ||||||
|  |   </g> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 3.3 KiB | 
							
								
								
									
										26
									
								
								data/theme/pointer-primary-click-symbolic.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,26 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
|  | <svg | ||||||
|  |    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||||
|  |    xmlns:cc="http://creativecommons.org/ns#" | ||||||
|  |    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||||
|  |    xmlns:svg="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" | ||||||
|  |    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||||
|  |    width="20" | ||||||
|  |    height="20" | ||||||
|  |    id="svg2" | ||||||
|  |    version="1.1"> | ||||||
|  |   <g | ||||||
|  |      id="layer1" | ||||||
|  |      style="display:inline"> | ||||||
|  |     <g | ||||||
|  |        id="id1" | ||||||
|  |        transform="translate(-22.25,-0.75)"> | ||||||
|  |       <path | ||||||
|  |          style="color:#000000;shape-padding:0;clip-rule:nonzero;display:block;overflow:visible;visibility:visible;opacity:1;solid-color:#000000;solid-opacity:1;fill:#464646;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.5;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:10;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate" | ||||||
|  |          d="m 25.855469,0.45507812 c 0,6.69466128 0,13.38932288 0,20.08398388 1.414713,-1.380859 2.829427,-2.761719 4.24414,-4.142578 0.612408,1.215372 1.173049,2.460221 1.819709,3.656095 1.141947,1.476279 3.975266,0.389006 3.846009,-1.473608 -0.09413,-0.822519 -0.594755,-1.521423 -0.899969,-2.277599 -0.298869,-0.640171 -0.597739,-1.280342 -0.896608,-1.920513 1.75651,0 3.513021,0 5.269531,0 C 34.777344,9.738932 30.316406,5.0970051 25.855469,0.45507812 Z m 1.5,3.72656248 c 2.786458,2.8997395 5.572917,5.7994789 8.359375,8.6992184 -1.367188,0 -2.734375,0 -4.101563,0 0.885072,1.903196 1.781799,3.80152 2.659622,5.707744 0.0349,0.566084 -1.149057,0.988823 -1.282093,0.297971 -0.818567,-1.671162 -1.637133,-3.342323 -2.455699,-5.013485 -1.059896,1.034505 -2.119791,2.06901 -3.179687,3.103515 1.5e-5,-4.264988 3e-5,-8.5299756 4.5e-5,-12.7949634 z" | ||||||
|  |          id="path5565" /> | ||||||
|  |     </g> | ||||||
|  |   </g> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 1.9 KiB | 
							
								
								
									
										26
									
								
								data/theme/pointer-secondary-click-symbolic.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,26 @@ | |||||||
|  | <?xml version="1.0" encoding="UTF-8" standalone="no"?> | ||||||
|  | <svg | ||||||
|  |    xmlns:dc="http://purl.org/dc/elements/1.1/" | ||||||
|  |    xmlns:cc="http://creativecommons.org/ns#" | ||||||
|  |    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" | ||||||
|  |    xmlns:svg="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns="http://www.w3.org/2000/svg" | ||||||
|  |    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" | ||||||
|  |    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" | ||||||
|  |    width="20" | ||||||
|  |    height="20" | ||||||
|  |    id="svg2"> | ||||||
|  |   <g | ||||||
|  |      id="layer1" | ||||||
|  |      style="display:inline;stroke-width:1.5;stroke-miterlimit:4;stroke-dasharray:none;stroke:#000000;stroke-opacity:1"> | ||||||
|  |     <g | ||||||
|  |        transform="matrix(-1,0,0,1,42,-0.75)" | ||||||
|  |        id="g5847" | ||||||
|  |        style="stroke-width:1.5;stroke-miterlimit:4;stroke-dasharray:none;stroke:#000000;stroke-opacity:1"> | ||||||
|  |       <path | ||||||
|  |          style="color:#000000;shape-padding:0;clip-rule:nonzero;display:block;overflow:visible;visibility:visible;opacity:1;solid-color:#000000;solid-opacity:1;fill:#464646;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:1.5;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:10;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;marker:none;enable-background:accumulate" | ||||||
|  |          d="m 25.855469,0.45507812 c 0,6.69466128 0,13.38932288 0,20.08398388 1.414713,-1.380859 2.829427,-2.761719 4.24414,-4.142578 0.612408,1.215372 1.173049,2.460221 1.819709,3.656095 1.141947,1.476279 3.975266,0.389006 3.846009,-1.473608 -0.09413,-0.822519 -0.594755,-1.521423 -0.899969,-2.277599 -0.298869,-0.640171 -0.597739,-1.280342 -0.896608,-1.920513 1.75651,0 3.513021,0 5.269531,0 C 34.777344,9.738932 30.316406,5.0970051 25.855469,0.45507812 Z m 1.5,3.72656248 c 2.786458,2.8997395 5.572917,5.7994789 8.359375,8.6992184 -1.367188,0 -2.734375,0 -4.101563,0 0.885072,1.903196 1.781799,3.80152 2.659622,5.707744 0.0349,0.566084 -1.149057,0.988823 -1.282093,0.297971 -0.818567,-1.671162 -1.637133,-3.342323 -2.455699,-5.013485 -1.059896,1.034505 -2.119791,2.06901 -3.179687,3.103515 1.5e-5,-4.264988 3e-5,-8.5299756 4.5e-5,-12.7949634 z" | ||||||
|  |          id="path5851" /> | ||||||
|  |     </g> | ||||||
|  |   </g> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 2.0 KiB | 
							
								
								
									
										1
									
								
								data/theme/toggle-off-dark.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | |||||||
|  | <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="46" height="22"><defs><linearGradient id="a"><stop offset="0" stop-color="#39393a"/><stop offset="1" stop-color="#302f30"/></linearGradient><linearGradient xlink:href="#a" id="b" x1="53" y1="294.429" x2="53" y2="309.804" gradientUnits="userSpaceOnUse" gradientTransform="translate(-42.76)"/></defs><g transform="translate(0 -291.18)" stroke-width="1.085"><rect style="marker:none" width="44.446" height="20.911" x=".625" y="291.715" rx="10.455" ry="10.073" fill="#323233" stroke="#272728"/><rect ry="10.455" rx="10.455" y="291.715" x=".543" height="20.911" width="21.143" style="marker:none" fill="url(#b)" stroke="#151515"/></g></svg> | ||||||
| After Width: | Height: | Size: 725 B | 
| @@ -1,209 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:xlink="http://www.w3.org/1999/xlink" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    width="65" |  | ||||||
|    height="22" |  | ||||||
|    id="svg2857" |  | ||||||
|    version="1.1" |  | ||||||
|    inkscape:version="0.48.5 r10040" |  | ||||||
|    sodipodi:docname="toggle-off-us.svg"> |  | ||||||
|   <defs |  | ||||||
|      id="defs2859"> |  | ||||||
|     <inkscape:perspective |  | ||||||
|        sodipodi:type="inkscape:persp3d" |  | ||||||
|        inkscape:vp_x="0 : 526.18109 : 1" |  | ||||||
|        inkscape:vp_y="0 : 1000 : 0" |  | ||||||
|        inkscape:vp_z="744.09448 : 526.18109 : 1" |  | ||||||
|        inkscape:persp3d-origin="372.04724 : 350.78739 : 1" |  | ||||||
|        id="perspective2865" /> |  | ||||||
|     <inkscape:perspective |  | ||||||
|        id="perspective2843" |  | ||||||
|        inkscape:persp3d-origin="0.5 : 0.33333333 : 1" |  | ||||||
|        inkscape:vp_z="1 : 0.5 : 1" |  | ||||||
|        inkscape:vp_y="0 : 1000 : 0" |  | ||||||
|        inkscape:vp_x="0 : 0.5 : 1" |  | ||||||
|        sodipodi:type="inkscape:persp3d" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        xlink:href="#linearGradient76469-7-7-4" |  | ||||||
|        id="linearGradient38024" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        gradientTransform="matrix(1.0215462,0,0,1.0322581,717.22867,428.68472)" |  | ||||||
|        x1="6" |  | ||||||
|        y1="102.95528" |  | ||||||
|        x2="6" |  | ||||||
|        y2="84.505203" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        id="linearGradient76469-7-7-4"> |  | ||||||
|       <stop |  | ||||||
|          style="stop-color:#2e3232;stop-opacity:1" |  | ||||||
|          offset="0" |  | ||||||
|          id="stop76471-7-1-5" /> |  | ||||||
|       <stop |  | ||||||
|          style="stop-color:#3e4545;stop-opacity:1" |  | ||||||
|          offset="1" |  | ||||||
|          id="stop76473-9-0-0" /> |  | ||||||
|     </linearGradient> |  | ||||||
|     <inkscape:path-effect |  | ||||||
|        effect="spiro" |  | ||||||
|        id="path-effect77541-4" |  | ||||||
|        is_visible="true" /> |  | ||||||
|     <inkscape:path-effect |  | ||||||
|        effect="spiro" |  | ||||||
|        id="path-effect77541-4-0" |  | ||||||
|        is_visible="true" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        xlink:href="#linearGradient37802-8" |  | ||||||
|        id="linearGradient12311-3-1-0-5-4" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.071426)" |  | ||||||
|        x1="610.13782" |  | ||||||
|        y1="501.43866" |  | ||||||
|        x2="610.13782" |  | ||||||
|        y2="492.52756" /> |  | ||||||
|     <linearGradient |  | ||||||
|        id="linearGradient37802-8" |  | ||||||
|        inkscape:collect="always"> |  | ||||||
|       <stop |  | ||||||
|          id="stop37804-1" |  | ||||||
|          offset="0" |  | ||||||
|          style="stop-color:#2c2c2c;stop-opacity:1" /> |  | ||||||
|       <stop |  | ||||||
|          id="stop37806-8" |  | ||||||
|          offset="1" |  | ||||||
|          style="stop-color:#16191a;stop-opacity:1" /> |  | ||||||
|     </linearGradient> |  | ||||||
|     <linearGradient |  | ||||||
|        y2="492.52756" |  | ||||||
|        x2="610.13782" |  | ||||||
|        y1="501.43866" |  | ||||||
|        x1="610.13782" |  | ||||||
|        gradientTransform="matrix(1.5918367,0,0,0.85714285,-900.56122,-423.92857)" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        id="linearGradient13602" |  | ||||||
|        xlink:href="#linearGradient37802-8" |  | ||||||
|        inkscape:collect="always" /> |  | ||||||
|   </defs> |  | ||||||
|   <sodipodi:namedview |  | ||||||
|      id="base" |  | ||||||
|      pagecolor="#000000" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      inkscape:pageopacity="1" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:zoom="1" |  | ||||||
|      inkscape:cx="-5.0602834" |  | ||||||
|      inkscape:cy="16.473273" |  | ||||||
|      inkscape:document-units="px" |  | ||||||
|      inkscape:current-layer="g37994" |  | ||||||
|      showgrid="false" |  | ||||||
|      inkscape:window-width="2560" |  | ||||||
|      inkscape:window-height="1375" |  | ||||||
|      inkscape:window-x="0" |  | ||||||
|      inkscape:window-y="27" |  | ||||||
|      inkscape:window-maximized="1" |  | ||||||
|      borderlayer="true" |  | ||||||
|      inkscape:showpageshadow="false" |  | ||||||
|      inkscape:snap-nodes="false" |  | ||||||
|      inkscape:snap-bbox="true" |  | ||||||
|      showborder="false"> |  | ||||||
|     <inkscape:grid |  | ||||||
|        type="xygrid" |  | ||||||
|        id="grid12954" |  | ||||||
|        empspacing="5" |  | ||||||
|        visible="true" |  | ||||||
|        enabled="true" |  | ||||||
|        snapvisiblegridlinesonly="true" /> |  | ||||||
|   </sodipodi:namedview> |  | ||||||
|   <metadata |  | ||||||
|      id="metadata2862"> |  | ||||||
|     <rdf:RDF> |  | ||||||
|       <cc:Work |  | ||||||
|          rdf:about=""> |  | ||||||
|         <dc:format>image/svg+xml</dc:format> |  | ||||||
|         <dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |  | ||||||
|         <dc:title></dc:title> |  | ||||||
|       </cc:Work> |  | ||||||
|     </rdf:RDF> |  | ||||||
|   </metadata> |  | ||||||
|   <g |  | ||||||
|      inkscape:label="Layer 1" |  | ||||||
|      inkscape:groupmode="layer" |  | ||||||
|      id="layer1" |  | ||||||
|      transform="translate(-444.64286,-781.36218)"> |  | ||||||
|     <g |  | ||||||
|        transform="matrix(0.6526046,0,0,0.80554422,99.592644,-636.32172)" |  | ||||||
|        id="g37994"> |  | ||||||
|       <g |  | ||||||
|          id="g37996" |  | ||||||
|          transform="translate(-115,1277)"> |  | ||||||
|         <rect |  | ||||||
|            style="color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964000000001;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;opacity:0.19591837" |  | ||||||
|            id="rect13475" |  | ||||||
|            width="98" |  | ||||||
|            height="25" |  | ||||||
|            x="644.5" |  | ||||||
|            y="484.61118" |  | ||||||
|            rx="4.7429576" |  | ||||||
|            ry="3.8424656" /> |  | ||||||
|         <rect |  | ||||||
|            ry="3.8424656" |  | ||||||
|            rx="4.7429576" |  | ||||||
|            y="483.5" |  | ||||||
|            x="644.5" |  | ||||||
|            height="25" |  | ||||||
|            width="98" |  | ||||||
|            id="rect38000" |  | ||||||
|            style="color:#000000;fill:url(#linearGradient12311-3-1-0-5-4);fill-opacity:1;fill-rule:nonzero;stroke:#16191a;stroke-width:1.37920942;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new" /> |  | ||||||
|       </g> |  | ||||||
|       <g |  | ||||||
|          transform="translate(-49.946213,-1.890275)" |  | ||||||
|          id="g38002"> |  | ||||||
|         <g |  | ||||||
|            transform="translate(-115,1247)" |  | ||||||
|            style="display:inline" |  | ||||||
|            id="g38004"> |  | ||||||
|           <rect |  | ||||||
|              ry="3.7972314" |  | ||||||
|              rx="4.6871223" |  | ||||||
|              y="515.5" |  | ||||||
|              x="694.53046" |  | ||||||
|              height="25" |  | ||||||
|              width="45.969578" |  | ||||||
|              id="rect38006" |  | ||||||
|              style="color:#000000;fill:url(#linearGradient38024);fill-opacity:1;fill-rule:nonzero;stroke:#1f2020;stroke-width:1.37920964;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" /> |  | ||||||
|           <path |  | ||||||
|              sodipodi:nodetypes="cc" |  | ||||||
|              style="opacity:0.1;color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964px;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" |  | ||||||
|              d="m 699.09675,516.7365 36.86904,0" |  | ||||||
|              id="path38016" |  | ||||||
|              inkscape:path-effect="#path-effect77541-4" |  | ||||||
|              inkscape:original-d="m 699.09675,516.7365 36.86904,0" |  | ||||||
|              inkscape:connector-curvature="0" /> |  | ||||||
|         </g> |  | ||||||
|       </g> |  | ||||||
|       <path |  | ||||||
|          sodipodi:type="arc" |  | ||||||
|          style="color:#000000;fill:none;stroke:#ffffff;stroke-width:2.15627193;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new" |  | ||||||
|          id="path13479" |  | ||||||
|          sodipodi:cx="16.4375" |  | ||||||
|          sodipodi:cy="10.8125" |  | ||||||
|          sodipodi:rx="4.3125" |  | ||||||
|          sodipodi:ry="4.3125" |  | ||||||
|          d="m 20.75,10.8125 a 4.3125,4.3125 0 1 1 -8.625,0 4.3125,4.3125 0 1 1 8.625,0 z" |  | ||||||
|          transform="matrix(1.4212691,0,0,1.1514287,577.38488,1761.1138)" /> |  | ||||||
|     </g> |  | ||||||
|   </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 7.5 KiB | 
| @@ -1,255 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:xlink="http://www.w3.org/1999/xlink" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    width="65" |  | ||||||
|    height="22" |  | ||||||
|    id="svg2857" |  | ||||||
|    version="1.1" |  | ||||||
|    inkscape:version="0.48.5 r10040" |  | ||||||
|    sodipodi:docname="toggle-on-intl.svg"> |  | ||||||
|   <defs |  | ||||||
|      id="defs2859"> |  | ||||||
|     <inkscape:perspective |  | ||||||
|        sodipodi:type="inkscape:persp3d" |  | ||||||
|        inkscape:vp_x="0 : 526.18109 : 1" |  | ||||||
|        inkscape:vp_y="0 : 1000 : 0" |  | ||||||
|        inkscape:vp_z="744.09448 : 526.18109 : 1" |  | ||||||
|        inkscape:persp3d-origin="372.04724 : 350.78739 : 1" |  | ||||||
|        id="perspective2865" /> |  | ||||||
|     <inkscape:perspective |  | ||||||
|        id="perspective2843" |  | ||||||
|        inkscape:persp3d-origin="0.5 : 0.33333333 : 1" |  | ||||||
|        inkscape:vp_z="1 : 0.5 : 1" |  | ||||||
|        inkscape:vp_y="0 : 1000 : 0" |  | ||||||
|        inkscape:vp_x="0 : 0.5 : 1" |  | ||||||
|        sodipodi:type="inkscape:persp3d" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        xlink:href="#linearGradient76469-7-7-4" |  | ||||||
|        id="linearGradient38024" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        gradientTransform="matrix(1.0215462,0,0,1.0322581,717.22867,428.68472)" |  | ||||||
|        x1="6" |  | ||||||
|        y1="102.95528" |  | ||||||
|        x2="6" |  | ||||||
|        y2="84.505203" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        id="linearGradient76469-7-7-4"> |  | ||||||
|       <stop |  | ||||||
|          style="stop-color:#2e3232;stop-opacity:1" |  | ||||||
|          offset="0" |  | ||||||
|          id="stop76471-7-1-5" /> |  | ||||||
|       <stop |  | ||||||
|          style="stop-color:#3e4545;stop-opacity:1" |  | ||||||
|          offset="1" |  | ||||||
|          id="stop76473-9-0-0" /> |  | ||||||
|     </linearGradient> |  | ||||||
|     <inkscape:path-effect |  | ||||||
|        effect="spiro" |  | ||||||
|        id="path-effect77541-4" |  | ||||||
|        is_visible="true" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        xlink:href="#linearGradient37802" |  | ||||||
|        id="linearGradient12311-3-1-0-5" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.071426)" |  | ||||||
|        x1="610.13782" |  | ||||||
|        y1="501.43866" |  | ||||||
|        x2="610.13782" |  | ||||||
|        y2="492.52756" /> |  | ||||||
|     <linearGradient |  | ||||||
|        id="linearGradient37802" |  | ||||||
|        inkscape:collect="always"> |  | ||||||
|       <stop |  | ||||||
|          id="stop37804" |  | ||||||
|          offset="0" |  | ||||||
|          style="stop-color:#2c2c2c;stop-opacity:1" /> |  | ||||||
|       <stop |  | ||||||
|          id="stop37806" |  | ||||||
|          offset="1" |  | ||||||
|          style="stop-color:#16191a;stop-opacity:1" /> |  | ||||||
|     </linearGradient> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        xlink:href="#linearGradient76469-7-7-4-3" |  | ||||||
|        id="linearGradient77680" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        gradientTransform="matrix(1,0,0,1.0322581,717.71949,428.68472)" |  | ||||||
|        x1="6" |  | ||||||
|        y1="102.95528" |  | ||||||
|        x2="6" |  | ||||||
|        y2="84.505203" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        id="linearGradient76469-7-7-4-3"> |  | ||||||
|       <stop |  | ||||||
|          style="stop-color:#2e3232;stop-opacity:1" |  | ||||||
|          offset="0" |  | ||||||
|          id="stop76471-7-1-5-7" /> |  | ||||||
|       <stop |  | ||||||
|          style="stop-color:#3e4545;stop-opacity:1" |  | ||||||
|          offset="1" |  | ||||||
|          id="stop76473-9-0-0-9" /> |  | ||||||
|     </linearGradient> |  | ||||||
|     <inkscape:path-effect |  | ||||||
|        effect="spiro" |  | ||||||
|        id="path-effect77541-4-0" |  | ||||||
|        is_visible="true" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        xlink:href="#linearGradient37802-8" |  | ||||||
|        id="linearGradient12311-3-1-0-5-4" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        gradientTransform="matrix(1.5918367,0,0,0.85714285,-256.56122,59.071426)" |  | ||||||
|        x1="610.13782" |  | ||||||
|        y1="501.43866" |  | ||||||
|        x2="610.13782" |  | ||||||
|        y2="492.52756" /> |  | ||||||
|     <linearGradient |  | ||||||
|        id="linearGradient37802-8" |  | ||||||
|        inkscape:collect="always"> |  | ||||||
|       <stop |  | ||||||
|          id="stop37804-1" |  | ||||||
|          offset="0" |  | ||||||
|          style="stop-color:#2c2c2c;stop-opacity:1" /> |  | ||||||
|       <stop |  | ||||||
|          id="stop37806-8" |  | ||||||
|          offset="1" |  | ||||||
|          style="stop-color:#16191a;stop-opacity:1" /> |  | ||||||
|     </linearGradient> |  | ||||||
|     <linearGradient |  | ||||||
|        y2="492.52756" |  | ||||||
|        x2="610.13782" |  | ||||||
|        y1="501.43866" |  | ||||||
|        x1="610.13782" |  | ||||||
|        gradientTransform="matrix(1.5918367,0,0,0.85714285,-900.56122,-423.92857)" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        id="linearGradient13602" |  | ||||||
|        xlink:href="#linearGradient37802-8" |  | ||||||
|        inkscape:collect="always" /> |  | ||||||
|   </defs> |  | ||||||
|   <sodipodi:namedview |  | ||||||
|      id="base" |  | ||||||
|      pagecolor="#000000" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      inkscape:pageopacity="1" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:zoom="1" |  | ||||||
|      inkscape:cx="16.760995" |  | ||||||
|      inkscape:cy="21.955673" |  | ||||||
|      inkscape:document-units="px" |  | ||||||
|      inkscape:current-layer="g37994" |  | ||||||
|      showgrid="false" |  | ||||||
|      inkscape:window-width="2560" |  | ||||||
|      inkscape:window-height="1375" |  | ||||||
|      inkscape:window-x="0" |  | ||||||
|      inkscape:window-y="27" |  | ||||||
|      inkscape:window-maximized="1" |  | ||||||
|      borderlayer="true" |  | ||||||
|      inkscape:showpageshadow="false" |  | ||||||
|      inkscape:snap-nodes="false" |  | ||||||
|      inkscape:snap-bbox="true" |  | ||||||
|      showborder="false"> |  | ||||||
|     <inkscape:grid |  | ||||||
|        type="xygrid" |  | ||||||
|        id="grid12954" |  | ||||||
|        empspacing="5" |  | ||||||
|        visible="true" |  | ||||||
|        enabled="true" |  | ||||||
|        snapvisiblegridlinesonly="true" /> |  | ||||||
|   </sodipodi:namedview> |  | ||||||
|   <metadata |  | ||||||
|      id="metadata2862"> |  | ||||||
|     <rdf:RDF> |  | ||||||
|       <cc:Work |  | ||||||
|          rdf:about=""> |  | ||||||
|         <dc:format>image/svg+xml</dc:format> |  | ||||||
|         <dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |  | ||||||
|         <dc:title></dc:title> |  | ||||||
|       </cc:Work> |  | ||||||
|     </rdf:RDF> |  | ||||||
|   </metadata> |  | ||||||
|   <g |  | ||||||
|      inkscape:label="Layer 1" |  | ||||||
|      inkscape:groupmode="layer" |  | ||||||
|      id="layer1" |  | ||||||
|      transform="translate(-444.64286,-781.36218)"> |  | ||||||
|     <g |  | ||||||
|        transform="matrix(0.6526046,0,0,0.80554422,99.592644,-636.32172)" |  | ||||||
|        id="g37994"> |  | ||||||
|       <g |  | ||||||
|          id="g37996" |  | ||||||
|          transform="translate(-115,1277)"> |  | ||||||
|         <rect |  | ||||||
|            style="color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964000000001;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;opacity:0.19591837" |  | ||||||
|            id="rect13475" |  | ||||||
|            width="98" |  | ||||||
|            height="25" |  | ||||||
|            x="644.5" |  | ||||||
|            y="484.61118" |  | ||||||
|            rx="4.7429576" |  | ||||||
|            ry="3.8424656" /> |  | ||||||
|         <rect |  | ||||||
|            ry="3.8424656" |  | ||||||
|            rx="4.7429576" |  | ||||||
|            y="483.5" |  | ||||||
|            x="644.5" |  | ||||||
|            height="25" |  | ||||||
|            width="98" |  | ||||||
|            id="rect38000" |  | ||||||
|            style="color:#000000;fill:url(#linearGradient12311-3-1-0-5-4);fill-opacity:1;fill-rule:nonzero;stroke:#16191a;stroke-width:1.37920942;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new" /> |  | ||||||
|       </g> |  | ||||||
|       <g |  | ||||||
|          transform="translate(-49.946213,-1.890275)" |  | ||||||
|          id="g38002"> |  | ||||||
|         <g |  | ||||||
|            transform="translate(-115,1247)" |  | ||||||
|            style="display:inline" |  | ||||||
|            id="g38004"> |  | ||||||
|           <rect |  | ||||||
|              ry="3.7972314" |  | ||||||
|              rx="4.6871223" |  | ||||||
|              y="515.5" |  | ||||||
|              x="694.53046" |  | ||||||
|              height="25" |  | ||||||
|              width="45.969578" |  | ||||||
|              id="rect38006" |  | ||||||
|              style="color:#000000;fill:url(#linearGradient38024);fill-opacity:1;fill-rule:nonzero;stroke:#1f2020;stroke-width:1.37920964;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" /> |  | ||||||
|           <path |  | ||||||
|              sodipodi:nodetypes="cc" |  | ||||||
|              style="opacity:0.1;color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964px;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" |  | ||||||
|              d="m 699.09675,516.7365 36.86904,0" |  | ||||||
|              id="path38016" |  | ||||||
|              inkscape:path-effect="#path-effect77541-4" |  | ||||||
|              inkscape:original-d="m 699.09675,516.7365 36.86904,0" |  | ||||||
|              inkscape:connector-curvature="0" /> |  | ||||||
|         </g> |  | ||||||
|       </g> |  | ||||||
|       <text |  | ||||||
|          xml:space="preserve" |  | ||||||
|          style="font-size:13.79166794px;font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold" |  | ||||||
|          x="520.29974" |  | ||||||
|          y="1997.0011" |  | ||||||
|          id="text75614" |  | ||||||
|          sodipodi:linespacing="125%" |  | ||||||
|          transform="scale(1.1236771,0.88993537)"><tspan |  | ||||||
|            sodipodi:role="line" |  | ||||||
|            id="tspan75616" |  | ||||||
|            x="520.29974" |  | ||||||
|            y="1997.0011">OFF</tspan></text> |  | ||||||
|     </g> |  | ||||||
|   </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 8.8 KiB | 
							
								
								
									
										1
									
								
								data/theme/toggle-off.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | |||||||
|  | <svg xmlns="http://www.w3.org/2000/svg" width="46" height="22"><g transform="translate(0 -291.18)"><rect style="marker:none;font-variant-east_asian:normal" width="44.446" height="20.911" x=".625" y="291.715" rx="10.455" ry="10.073" fill="#e1dedb" stroke="#cdc7c2" stroke-linecap="round" stroke-linejoin="round"/><rect ry="10.455" rx="10.455" y="291.715" x=".543" height="20.911" width="21.143" style="marker:none;font-variant-east_asian:normal" fill="#f8f7f7" stroke="#aa9f98" stroke-linecap="round" stroke-linejoin="round"/><g transform="matrix(.97148 0 0 1 1658.914 -2552.91)" stroke-width="1.015" stroke-linecap="round" stroke-linejoin="round"><rect ry="13.17" rx="13.556" y="1234.681" x="-1242.732" height="26" width="49.409" style="marker:none" fill="#e1dedb" stroke="#cdc7c2"/><rect style="marker:none" width="26.763" height="26" x="-1242.732" y="1234.769" rx="13.511" ry="13.126" fill="#f8f7f7" stroke="#aa9f98"/></g><g transform="matrix(.97148 0 0 1 1658.914 -2512.91)" stroke-width="1.015" stroke="#2b73cc"><rect style="marker:none" width="49.409" height="26" x="-1242.732" y="1234.681" rx="13.556" ry="13.17" fill="#3081e3"/><rect ry="13.126" rx="13.511" y="1234.769" x="-1220.086" height="26" width="26.763" style="marker:none" fill="#f8f7f7" stroke-linecap="round" stroke-linejoin="round"/></g></g></svg> | ||||||
| After Width: | Height: | Size: 1.3 KiB | 
							
								
								
									
										1
									
								
								data/theme/toggle-on-dark.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | |||||||
|  | <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="46" height="22"><defs><linearGradient id="a"><stop offset="0" stop-color="#39393a"/><stop offset="1" stop-color="#302f30"/></linearGradient><linearGradient xlink:href="#a" id="b" x1="53" y1="294.429" x2="53" y2="309.804" gradientUnits="userSpaceOnUse" gradientTransform="translate(-19)"/></defs><g transform="translate(0 -291.18)" stroke="#030e1b" stroke-width="1.085"><rect style="marker:none" width="44.446" height="20.911" x=".625" y="291.715" rx="10.455" ry="10.073" fill="#15539e"/><rect ry="10.455" rx="10.455" y="291.715" x="24.304" height="20.911" width="21.143" style="marker:none" fill="url(#b)"/></g></svg> | ||||||
| After Width: | Height: | Size: 707 B | 
| @@ -1,192 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:xlink="http://www.w3.org/1999/xlink" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    width="65" |  | ||||||
|    height="22" |  | ||||||
|    id="svg2857" |  | ||||||
|    version="1.1" |  | ||||||
|    inkscape:version="0.91 r13725" |  | ||||||
|    sodipodi:docname="toggle-on-intl.svg"> |  | ||||||
|   <defs |  | ||||||
|      id="defs2859"> |  | ||||||
|     <inkscape:perspective |  | ||||||
|        sodipodi:type="inkscape:persp3d" |  | ||||||
|        inkscape:vp_x="0 : 526.18109 : 1" |  | ||||||
|        inkscape:vp_y="0 : 1000 : 0" |  | ||||||
|        inkscape:vp_z="744.09448 : 526.18109 : 1" |  | ||||||
|        inkscape:persp3d-origin="372.04724 : 350.78739 : 1" |  | ||||||
|        id="perspective2865" /> |  | ||||||
|     <inkscape:perspective |  | ||||||
|        id="perspective2843" |  | ||||||
|        inkscape:persp3d-origin="0.5 : 0.33333333 : 1" |  | ||||||
|        inkscape:vp_z="1 : 0.5 : 1" |  | ||||||
|        inkscape:vp_y="0 : 1000 : 0" |  | ||||||
|        inkscape:vp_x="0 : 0.5 : 1" |  | ||||||
|        sodipodi:type="inkscape:persp3d" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        xlink:href="#linearGradient77461" |  | ||||||
|        id="linearGradient77551" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        gradientTransform="matrix(1.3066667,0,0,1,-841.64667,-483)" |  | ||||||
|        x1="1164.7644" |  | ||||||
|        y1="962.93695" |  | ||||||
|        x2="1164.7644" |  | ||||||
|        y2="970.51404" /> |  | ||||||
|     <linearGradient |  | ||||||
|        id="linearGradient77461" |  | ||||||
|        inkscape:collect="always"> |  | ||||||
|       <stop |  | ||||||
|          id="stop77463" |  | ||||||
|          offset="0" |  | ||||||
|          style="stop-color:#182f4c;stop-opacity:1" /> |  | ||||||
|       <stop |  | ||||||
|          id="stop77465" |  | ||||||
|          offset="1" |  | ||||||
|          style="stop-color:#205b9a;stop-opacity:1" /> |  | ||||||
|     </linearGradient> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        xlink:href="#linearGradient76469-7-7-4" |  | ||||||
|        id="linearGradient38024" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        gradientTransform="matrix(1.0215462,0,0,1.0322581,717.22867,428.68472)" |  | ||||||
|        x1="6" |  | ||||||
|        y1="102.95528" |  | ||||||
|        x2="6" |  | ||||||
|        y2="84.505203" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        id="linearGradient76469-7-7-4"> |  | ||||||
|       <stop |  | ||||||
|          style="stop-color:#2e3232;stop-opacity:1" |  | ||||||
|          offset="0" |  | ||||||
|          id="stop76471-7-1-5" /> |  | ||||||
|       <stop |  | ||||||
|          style="stop-color:#3e4545;stop-opacity:1" |  | ||||||
|          offset="1" |  | ||||||
|          id="stop76473-9-0-0" /> |  | ||||||
|     </linearGradient> |  | ||||||
|     <inkscape:path-effect |  | ||||||
|        effect="spiro" |  | ||||||
|        id="path-effect77541-4" |  | ||||||
|        is_visible="true" /> |  | ||||||
|   </defs> |  | ||||||
|   <sodipodi:namedview |  | ||||||
|      id="base" |  | ||||||
|      pagecolor="#000000" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      inkscape:pageopacity="1" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:zoom="1" |  | ||||||
|      inkscape:cx="37.410841" |  | ||||||
|      inkscape:cy="16.009314" |  | ||||||
|      inkscape:document-units="px" |  | ||||||
|      inkscape:current-layer="g37994" |  | ||||||
|      showgrid="false" |  | ||||||
|      inkscape:window-width="2560" |  | ||||||
|      inkscape:window-height="1376" |  | ||||||
|      inkscape:window-x="0" |  | ||||||
|      inkscape:window-y="27" |  | ||||||
|      inkscape:window-maximized="1" |  | ||||||
|      borderlayer="true" |  | ||||||
|      inkscape:showpageshadow="false" |  | ||||||
|      inkscape:snap-nodes="false" |  | ||||||
|      inkscape:snap-bbox="true" |  | ||||||
|      showborder="false"> |  | ||||||
|     <inkscape:grid |  | ||||||
|        type="xygrid" |  | ||||||
|        id="grid12954" |  | ||||||
|        empspacing="5" |  | ||||||
|        visible="true" |  | ||||||
|        enabled="true" |  | ||||||
|        snapvisiblegridlinesonly="true" /> |  | ||||||
|   </sodipodi:namedview> |  | ||||||
|   <metadata |  | ||||||
|      id="metadata2862"> |  | ||||||
|     <rdf:RDF> |  | ||||||
|       <cc:Work |  | ||||||
|          rdf:about=""> |  | ||||||
|         <dc:format>image/svg+xml</dc:format> |  | ||||||
|         <dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |  | ||||||
|         <dc:title /> |  | ||||||
|       </cc:Work> |  | ||||||
|     </rdf:RDF> |  | ||||||
|   </metadata> |  | ||||||
|   <g |  | ||||||
|      inkscape:label="Layer 1" |  | ||||||
|      inkscape:groupmode="layer" |  | ||||||
|      id="layer1" |  | ||||||
|      transform="translate(-444.64286,-781.36218)"> |  | ||||||
|     <g |  | ||||||
|        transform="matrix(0.6526046,0,0,0.80554422,99.592644,-636.32172)" |  | ||||||
|        id="g37994"> |  | ||||||
|       <g |  | ||||||
|          id="g37996" |  | ||||||
|          transform="translate(-115,1277)"> |  | ||||||
|         <rect |  | ||||||
|            style="color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964000000001;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;opacity:0.19591837" |  | ||||||
|            id="rect13475" |  | ||||||
|            width="98" |  | ||||||
|            height="25" |  | ||||||
|            x="644.5" |  | ||||||
|            y="484.61118" |  | ||||||
|            rx="4.7429576" |  | ||||||
|            ry="3.8424656" /> |  | ||||||
|         <rect |  | ||||||
|            ry="3.8424656" |  | ||||||
|            rx="4.7429576" |  | ||||||
|            y="483.5" |  | ||||||
|            x="644.5" |  | ||||||
|            height="25" |  | ||||||
|            width="98" |  | ||||||
|            id="rect38000" |  | ||||||
|            style="color:#000000;fill:url(#linearGradient77551);fill-opacity:1;fill-rule:nonzero;stroke:#182f4c;stroke-width:1.37920964;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" /> |  | ||||||
|       </g> |  | ||||||
|       <g |  | ||||||
|          transform="translate(2.0625,-2)" |  | ||||||
|          id="g38002"> |  | ||||||
|         <g |  | ||||||
|            transform="translate(-115,1247)" |  | ||||||
|            style="display:inline" |  | ||||||
|            id="g38004"> |  | ||||||
|           <rect |  | ||||||
|              ry="3.7972314" |  | ||||||
|              rx="4.6871223" |  | ||||||
|              y="515.5" |  | ||||||
|              x="694.53046" |  | ||||||
|              height="25" |  | ||||||
|              width="45.969578" |  | ||||||
|              id="rect38006" |  | ||||||
|              style="color:#000000;fill:url(#linearGradient38024);fill-opacity:1;fill-rule:nonzero;stroke:#1f2020;stroke-width:1.37920964;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" /> |  | ||||||
|           <path |  | ||||||
|              sodipodi:nodetypes="cc" |  | ||||||
|              style="opacity:0.1;color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964px;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" |  | ||||||
|              d="m 699.09675,516.7365 36.86904,0" |  | ||||||
|              id="path38016" |  | ||||||
|              inkscape:path-effect="#path-effect77541-4" |  | ||||||
|              inkscape:original-d="m 699.09675,516.7365 36.86904,0" |  | ||||||
|              inkscape:connector-curvature="0" /> |  | ||||||
|         </g> |  | ||||||
|       </g> |  | ||||||
|       <rect |  | ||||||
|          style="color:#000000;fill:#ffffff;fill-opacity:1;fill-rule:nonzero;stroke:none;stroke-width:0.99999994;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:new" |  | ||||||
|          id="rect13678" |  | ||||||
|          width="3.0646207" |  | ||||||
|          height="12.414008" |  | ||||||
|          x="554.77728" |  | ||||||
|          y="1767.3566" /> |  | ||||||
|     </g> |  | ||||||
|   </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 6.8 KiB | 
| @@ -1,207 +0,0 @@ | |||||||
| <?xml version="1.0" encoding="UTF-8" standalone="no"?> |  | ||||||
| <!-- Created with Inkscape (http://www.inkscape.org/) --> |  | ||||||
|  |  | ||||||
| <svg |  | ||||||
|    xmlns:dc="http://purl.org/dc/elements/1.1/" |  | ||||||
|    xmlns:cc="http://creativecommons.org/ns#" |  | ||||||
|    xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" |  | ||||||
|    xmlns:svg="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns="http://www.w3.org/2000/svg" |  | ||||||
|    xmlns:xlink="http://www.w3.org/1999/xlink" |  | ||||||
|    xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" |  | ||||||
|    xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" |  | ||||||
|    width="65" |  | ||||||
|    height="22" |  | ||||||
|    id="svg2857" |  | ||||||
|    version="1.1" |  | ||||||
|    inkscape:version="0.91 r13725" |  | ||||||
|    sodipodi:docname="toggle-on-us.svg"> |  | ||||||
|   <defs |  | ||||||
|      id="defs2859"> |  | ||||||
|     <inkscape:perspective |  | ||||||
|        sodipodi:type="inkscape:persp3d" |  | ||||||
|        inkscape:vp_x="0 : 526.18109 : 1" |  | ||||||
|        inkscape:vp_y="0 : 1000 : 0" |  | ||||||
|        inkscape:vp_z="744.09448 : 526.18109 : 1" |  | ||||||
|        inkscape:persp3d-origin="372.04724 : 350.78739 : 1" |  | ||||||
|        id="perspective2865" /> |  | ||||||
|     <inkscape:perspective |  | ||||||
|        id="perspective2843" |  | ||||||
|        inkscape:persp3d-origin="0.5 : 0.33333333 : 1" |  | ||||||
|        inkscape:vp_z="1 : 0.5 : 1" |  | ||||||
|        inkscape:vp_y="0 : 1000 : 0" |  | ||||||
|        inkscape:vp_x="0 : 0.5 : 1" |  | ||||||
|        sodipodi:type="inkscape:persp3d" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        xlink:href="#linearGradient76469-7-7-4" |  | ||||||
|        id="linearGradient38024" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        gradientTransform="matrix(1.0215462,0,0,1.0322581,717.22867,428.68472)" |  | ||||||
|        x1="6" |  | ||||||
|        y1="102.95528" |  | ||||||
|        x2="6" |  | ||||||
|        y2="84.505203" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        id="linearGradient76469-7-7-4"> |  | ||||||
|       <stop |  | ||||||
|          style="stop-color:#2e3232;stop-opacity:1" |  | ||||||
|          offset="0" |  | ||||||
|          id="stop76471-7-1-5" /> |  | ||||||
|       <stop |  | ||||||
|          style="stop-color:#3e4545;stop-opacity:1" |  | ||||||
|          offset="1" |  | ||||||
|          id="stop76473-9-0-0" /> |  | ||||||
|     </linearGradient> |  | ||||||
|     <inkscape:path-effect |  | ||||||
|        effect="spiro" |  | ||||||
|        id="path-effect77541-4" |  | ||||||
|        is_visible="true" /> |  | ||||||
|     <linearGradient |  | ||||||
|        id="linearGradient77461-1" |  | ||||||
|        inkscape:collect="always"> |  | ||||||
|       <stop |  | ||||||
|          id="stop77463-1" |  | ||||||
|          offset="0" |  | ||||||
|          style="stop-color:#182f4c;stop-opacity:1" /> |  | ||||||
|       <stop |  | ||||||
|          id="stop77465-4" |  | ||||||
|          offset="1" |  | ||||||
|          style="stop-color:#205b9a;stop-opacity:1" /> |  | ||||||
|     </linearGradient> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        xlink:href="#linearGradient77461-1" |  | ||||||
|        id="linearGradient77551-6-5" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        gradientTransform="matrix(0.8527367,0,0,0.80554422,-969.41608,-778.00299)" |  | ||||||
|        x1="1164.7644" |  | ||||||
|        y1="962.93695" |  | ||||||
|        x2="1164.7644" |  | ||||||
|        y2="970.51404" /> |  | ||||||
|     <linearGradient |  | ||||||
|        inkscape:collect="always" |  | ||||||
|        xlink:href="#linearGradient77461-1" |  | ||||||
|        id="linearGradient11198" |  | ||||||
|        gradientUnits="userSpaceOnUse" |  | ||||||
|        gradientTransform="matrix(1.3066667,0,0,1,-1066.3709,794.25325)" |  | ||||||
|        x1="1322.5831" |  | ||||||
|        y1="-312.51855" |  | ||||||
|        x2="1322.5831" |  | ||||||
|        y2="-306.53461" /> |  | ||||||
|   </defs> |  | ||||||
|   <sodipodi:namedview |  | ||||||
|      id="base" |  | ||||||
|      pagecolor="#000000" |  | ||||||
|      bordercolor="#666666" |  | ||||||
|      borderopacity="1.0" |  | ||||||
|      inkscape:pageopacity="1" |  | ||||||
|      inkscape:pageshadow="2" |  | ||||||
|      inkscape:zoom="1" |  | ||||||
|      inkscape:cx="-26.798898" |  | ||||||
|      inkscape:cy="5.3753009" |  | ||||||
|      inkscape:document-units="px" |  | ||||||
|      inkscape:current-layer="g37994" |  | ||||||
|      showgrid="false" |  | ||||||
|      inkscape:window-width="2560" |  | ||||||
|      inkscape:window-height="1376" |  | ||||||
|      inkscape:window-x="0" |  | ||||||
|      inkscape:window-y="27" |  | ||||||
|      inkscape:window-maximized="1" |  | ||||||
|      borderlayer="true" |  | ||||||
|      inkscape:showpageshadow="false" |  | ||||||
|      inkscape:snap-nodes="false" |  | ||||||
|      inkscape:snap-bbox="true" |  | ||||||
|      showborder="false"> |  | ||||||
|     <inkscape:grid |  | ||||||
|        type="xygrid" |  | ||||||
|        id="grid12954" |  | ||||||
|        empspacing="5" |  | ||||||
|        visible="true" |  | ||||||
|        enabled="true" |  | ||||||
|        snapvisiblegridlinesonly="true" /> |  | ||||||
|   </sodipodi:namedview> |  | ||||||
|   <metadata |  | ||||||
|      id="metadata2862"> |  | ||||||
|     <rdf:RDF> |  | ||||||
|       <cc:Work |  | ||||||
|          rdf:about=""> |  | ||||||
|         <dc:format>image/svg+xml</dc:format> |  | ||||||
|         <dc:type |  | ||||||
|            rdf:resource="http://purl.org/dc/dcmitype/StillImage" /> |  | ||||||
|         <dc:title /> |  | ||||||
|       </cc:Work> |  | ||||||
|     </rdf:RDF> |  | ||||||
|   </metadata> |  | ||||||
|   <g |  | ||||||
|      inkscape:label="Layer 1" |  | ||||||
|      inkscape:groupmode="layer" |  | ||||||
|      id="layer1" |  | ||||||
|      transform="translate(-444.64286,-781.36218)"> |  | ||||||
|     <g |  | ||||||
|        transform="matrix(0.6526046,0,0,0.80554422,99.592644,-636.32172)" |  | ||||||
|        id="g37994"> |  | ||||||
|       <g |  | ||||||
|          id="g37996" |  | ||||||
|          transform="translate(-115,1277)"> |  | ||||||
|         <rect |  | ||||||
|            style="color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964000000001;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;opacity:0.19591837" |  | ||||||
|            id="rect13475" |  | ||||||
|            width="98" |  | ||||||
|            height="25" |  | ||||||
|            x="644.5" |  | ||||||
|            y="484.61118" |  | ||||||
|            rx="4.7429576" |  | ||||||
|            ry="3.8424656" /> |  | ||||||
|         <rect |  | ||||||
|            ry="3.8424656" |  | ||||||
|            rx="4.7429576" |  | ||||||
|            y="483.5" |  | ||||||
|            x="644.5" |  | ||||||
|            height="25" |  | ||||||
|            width="98" |  | ||||||
|            id="rect38000" |  | ||||||
|            style="color:#000000;fill:url(#linearGradient11198);fill-opacity:1;fill-rule:nonzero;stroke:#182f4c;stroke-width:1.37920964;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate;clip-rule:nonzero;opacity:1;isolation:auto;mix-blend-mode:normal;color-interpolation:sRGB;color-interpolation-filters:linearRGB;solid-color:#000000;solid-opacity:1;filter-blend-mode:normal;filter-gaussianBlur-deviation:0;color-rendering:auto;image-rendering:auto;shape-rendering:auto;text-rendering:auto" /> |  | ||||||
|       </g> |  | ||||||
|       <g |  | ||||||
|          transform="translate(2.0625,-2)" |  | ||||||
|          id="g38002"> |  | ||||||
|         <g |  | ||||||
|            transform="translate(-115,1247)" |  | ||||||
|            style="display:inline" |  | ||||||
|            id="g38004"> |  | ||||||
|           <rect |  | ||||||
|              ry="3.7972314" |  | ||||||
|              rx="4.6871223" |  | ||||||
|              y="515.5" |  | ||||||
|              x="694.53046" |  | ||||||
|              height="25" |  | ||||||
|              width="45.969578" |  | ||||||
|              id="rect38006" |  | ||||||
|              style="color:#000000;fill:url(#linearGradient38024);fill-opacity:1;fill-rule:nonzero;stroke:#1f2020;stroke-width:1.37920964;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" /> |  | ||||||
|           <path |  | ||||||
|              sodipodi:nodetypes="cc" |  | ||||||
|              style="opacity:0.1;color:#000000;fill:none;stroke:#ffffff;stroke-width:1.37920964px;stroke-linecap:round;stroke-linejoin:miter;stroke-miterlimit:4;stroke-opacity:1;stroke-dasharray:none;stroke-dashoffset:0;marker:none;visibility:visible;display:inline;overflow:visible;enable-background:accumulate" |  | ||||||
|              d="m 699.09675,516.7365 36.86904,0" |  | ||||||
|              id="path38016" |  | ||||||
|              inkscape:path-effect="#path-effect77541-4" |  | ||||||
|              inkscape:original-d="m 699.09675,516.7365 36.86904,0" |  | ||||||
|              inkscape:connector-curvature="0" /> |  | ||||||
|         </g> |  | ||||||
|       </g> |  | ||||||
|       <text |  | ||||||
|          transform="scale(1.1000946,0.90901274)" |  | ||||||
|          sodipodi:linespacing="125%" |  | ||||||
|          id="text38018" |  | ||||||
|          y="1955.5205" |  | ||||||
|          x="495.94223" |  | ||||||
|          style="font-size:13.29953671px;font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;line-height:125%;letter-spacing:0px;word-spacing:0px;fill:#ffffff;fill-opacity:1;stroke:none;font-family:Cantarell;-inkscape-font-specification:Cantarell Bold" |  | ||||||
|          xml:space="preserve"><tspan |  | ||||||
|            y="1955.5205" |  | ||||||
|            x="495.94223" |  | ||||||
|            id="tspan38020" |  | ||||||
|            sodipodi:role="line">ON</tspan></text> |  | ||||||
|     </g> |  | ||||||
|   </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 7.7 KiB | 
							
								
								
									
										1
									
								
								data/theme/toggle-on.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | |||||||
|  | <svg xmlns="http://www.w3.org/2000/svg" width="46" height="22"><g transform="translate(0 -291.18)" stroke="#2b73cc"><rect style="marker:none;font-variant-east_asian:normal" width="44.446" height="20.911" x=".625" y="291.715" rx="10.455" ry="10.073" fill="#3081e3"/><rect ry="10.455" rx="10.455" y="291.715" x="24.304" height="20.911" width="21.143" style="marker:none;font-variant-east_asian:normal" fill="#f8f7f7" stroke-linecap="round" stroke-linejoin="round"/></g></svg> | ||||||
| After Width: | Height: | Size: 473 B | 
| @@ -40,6 +40,7 @@ do | |||||||
| done | done | ||||||
|  |  | ||||||
| cat >>$TMP_GRESOURCE_FILE <<EOF | cat >>$TMP_GRESOURCE_FILE <<EOF | ||||||
|  |     <file>emoji.json</file> | ||||||
|   </gresource> |   </gresource> | ||||||
| </gresources> | </gresources> | ||||||
| EOF | EOF | ||||||
|   | |||||||
| @@ -25,7 +25,7 @@ its dependencies to build from tarballs.</description> | |||||||
|   <homepage rdf:resource="https://wiki.gnome.org/Projects/GnomeShell" /> |   <homepage rdf:resource="https://wiki.gnome.org/Projects/GnomeShell" /> | ||||||
|   <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/gnome-shell/" /> |   <download-page rdf:resource="http://download.gnome.org/sources/gnome-shell/" /> | ||||||
|   <bug-database rdf:resource="https://bugzilla.gnome.org/browse.cgi?product=gnome-shell" /> |   <bug-database rdf:resource="https://gitlab.gnome.org/GNOME/gnome-shell/issues/" /> | ||||||
|  |  | ||||||
|   <category rdf:resource="http://api.gnome.org/doap-extensions#core" /> |   <category rdf:resource="http://api.gnome.org/doap-extensions#core" /> | ||||||
|   <programming-language>JavaScript</programming-language> |   <programming-language>JavaScript</programming-language> | ||||||
|   | |||||||
| @@ -1,12 +1,5 @@ | |||||||
|  |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Gettext = imports.gettext; | const Gettext = imports.gettext; | ||||||
| const GLib = imports.gi.GLib; | const { Gdk, GLib, Gio, GObject, Gtk, Pango } = imports.gi; | ||||||
| const GObject = imports.gi.GObject; |  | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const Gtk = imports.gi.Gtk; |  | ||||||
| const Gdk = imports.gi.Gdk; |  | ||||||
| const Pango = imports.gi.Pango; |  | ||||||
| const Format = imports.format; | const Format = imports.format; | ||||||
|  |  | ||||||
| const _ = Gettext.gettext; | const _ = Gettext.gettext; | ||||||
| @@ -24,9 +17,8 @@ function stripPrefix(string, prefix) { | |||||||
|     return string; |     return string; | ||||||
| } | } | ||||||
|  |  | ||||||
| var Application = new Lang.Class({ | var Application = class { | ||||||
|     Name: 'Application', |     constructor() { | ||||||
|     _init() { |  | ||||||
|         GLib.set_prgname('gnome-shell-extension-prefs'); |         GLib.set_prgname('gnome-shell-extension-prefs'); | ||||||
|         this.application = new Gtk.Application({ |         this.application = new Gtk.Application({ | ||||||
|             application_id: 'org.gnome.shell.ExtensionPrefs', |             application_id: 'org.gnome.shell.ExtensionPrefs', | ||||||
| @@ -42,7 +34,7 @@ var Application = new Lang.Class({ | |||||||
|         this._startupUuid = null; |         this._startupUuid = null; | ||||||
|         this._loaded = false; |         this._loaded = false; | ||||||
|         this._skipMainWindow = false; |         this._skipMainWindow = false; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _extensionAvailable(uuid) { |     _extensionAvailable(uuid) { | ||||||
|         let extension = ExtensionUtils.extensions[uuid]; |         let extension = ExtensionUtils.extensions[uuid]; | ||||||
| @@ -54,7 +46,7 @@ var Application = new Lang.Class({ | |||||||
|             return false; |             return false; | ||||||
|  |  | ||||||
|         return true; |         return true; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _getExtensionPrefsModule(extension) { |     _getExtensionPrefsModule(extension) { | ||||||
|         let uuid = extension.metadata.uuid; |         let uuid = extension.metadata.uuid; | ||||||
| @@ -69,7 +61,7 @@ var Application = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._extensionPrefsModules[uuid] = prefsModule; |         this._extensionPrefsModules[uuid] = prefsModule; | ||||||
|         return prefsModule; |         return prefsModule; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _selectExtension(uuid) { |     _selectExtension(uuid) { | ||||||
|         if (!this._extensionAvailable(uuid)) |         if (!this._extensionAvailable(uuid)) | ||||||
| @@ -104,33 +96,115 @@ var Application = new Lang.Class({ | |||||||
|         dialog.set_default_size(600, 400); |         dialog.set_default_size(600, 400); | ||||||
|         dialog.add(widget); |         dialog.add(widget); | ||||||
|         dialog.show(); |         dialog.show(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _buildErrorUI(extension, exc) { |     _buildErrorUI(extension, exc) { | ||||||
|         let box = new Gtk.Box({ orientation: Gtk.Orientation.VERTICAL }); |         let scroll = new Gtk.ScrolledWindow({ | ||||||
|  |             hscrollbar_policy: Gtk.PolicyType.NEVER, | ||||||
|  |             propagate_natural_height: true | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         let box = new Gtk.Box({ | ||||||
|  |             orientation: Gtk.Orientation.VERTICAL, | ||||||
|  |             spacing: 12, | ||||||
|  |             margin: 100, | ||||||
|  |             margin_bottom: 60 | ||||||
|  |         }); | ||||||
|  |         scroll.add(box); | ||||||
|  |  | ||||||
|         let label = new Gtk.Label({ |         let label = new Gtk.Label({ | ||||||
|             label: _("There was an error loading the preferences dialog for %s:").format(extension.metadata.name) |             label: '<span size="x-large">%s</span>'.format(_("Something’s gone wrong")), | ||||||
|  |             use_markup: true | ||||||
|  |         }); | ||||||
|  |         label.get_style_context().add_class(Gtk.STYLE_CLASS_DIM_LABEL); | ||||||
|  |         box.add(label); | ||||||
|  |  | ||||||
|  |         label = new Gtk.Label({ | ||||||
|  |             label: _("We’re very sorry, but there’s been a problem: the settings for this extension can’t be displayed. We recommend that you report the issue to the extension authors."), | ||||||
|  |             justify: Gtk.Justification.CENTER, | ||||||
|  |             wrap: true | ||||||
|         }); |         }); | ||||||
|         box.add(label); |         box.add(label); | ||||||
|  |  | ||||||
|         let errortext = ''; |         let expander = new Expander({ | ||||||
|         errortext += exc; |             label: _("Technical Details"), | ||||||
|         errortext += '\n\n'; |             margin_top: 12 | ||||||
|         errortext += 'Stack trace:\n'; |         }); | ||||||
|  |         box.add(expander); | ||||||
|  |  | ||||||
|         // Indent stack trace. |         let errortext = `${exc}\n\nStack trace:\n${ | ||||||
|         errortext += exc.stack.split('\n').map(line => '  ' + line).join('\n'); |             // Indent stack trace. | ||||||
|  |             exc.stack.split('\n').map(line => `  ${line}`).join('\n') | ||||||
|  |         }`; | ||||||
|  |  | ||||||
|         let scroll = new Gtk.ScrolledWindow({ vexpand: true }); |  | ||||||
|         let buffer = new Gtk.TextBuffer({ text: errortext }); |         let buffer = new Gtk.TextBuffer({ text: errortext }); | ||||||
|         let textview = new Gtk.TextView({ buffer: buffer }); |         let textview = new Gtk.TextView({ | ||||||
|         textview.override_font(Pango.font_description_from_string('monospace')); |             buffer: buffer, | ||||||
|         scroll.add(textview); |             wrap_mode: Gtk.WrapMode.WORD, | ||||||
|         box.add(scroll); |             monospace: true, | ||||||
|  |             editable: false, | ||||||
|  |             top_margin: 12, | ||||||
|  |             bottom_margin: 12, | ||||||
|  |             left_margin: 12, | ||||||
|  |             right_margin: 12 | ||||||
|  |         }); | ||||||
|  |  | ||||||
|         box.show_all(); |         let toolbar = new Gtk.Toolbar(); | ||||||
|         return box; |         let provider = new Gtk.CssProvider(); | ||||||
|     }, |         provider.load_from_data(`* { | ||||||
|  |             border: 0 solid @borders; | ||||||
|  |             border-top-width: 1px; | ||||||
|  |         }`); | ||||||
|  |         toolbar.get_style_context().add_provider( | ||||||
|  |             provider, | ||||||
|  |             Gtk.STYLE_PROVIDER_PRIORITY_APPLICATION | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         let copyButton = new Gtk.ToolButton({ | ||||||
|  |             icon_name: 'edit-copy-symbolic', | ||||||
|  |             tooltip_text: _("Copy Error") | ||||||
|  |         }); | ||||||
|  |         toolbar.add(copyButton); | ||||||
|  |  | ||||||
|  |         copyButton.connect('clicked', w => { | ||||||
|  |             let clipboard = Gtk.Clipboard.get_default(w.get_display()); | ||||||
|  |             let backticks = '```'; | ||||||
|  |             clipboard.set_text( | ||||||
|  |                 // markdown for pasting in gitlab issues | ||||||
|  |                 `The settings of extension ${extension.uuid} had an error:\n${ | ||||||
|  |                 backticks}\n${exc}\n${backticks}\n\nStack trace:\n${ | ||||||
|  |                 backticks}\n${exc.stack}${backticks}\n`, -1 | ||||||
|  |             ); | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         let spacing = new Gtk.SeparatorToolItem({ draw: false }); | ||||||
|  |         toolbar.add(spacing); | ||||||
|  |         toolbar.child_set_property(spacing, "expand", true); | ||||||
|  |  | ||||||
|  |         let urlButton = new Gtk.ToolButton({ | ||||||
|  |             label: _("Homepage"), | ||||||
|  |             tooltip_text: _("Visit extension homepage"), | ||||||
|  |             no_show_all: true, | ||||||
|  |             visible: extension.metadata.url != null | ||||||
|  |         }); | ||||||
|  |         toolbar.add(urlButton); | ||||||
|  |  | ||||||
|  |         urlButton.connect('clicked', w => { | ||||||
|  |             let context = w.get_display().get_app_launch_context(); | ||||||
|  |             Gio.AppInfo.launch_default_for_uri(extension.metadata.url, context); | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         let expandedBox = new Gtk.Box({ | ||||||
|  |             orientation: Gtk.Orientation.VERTICAL | ||||||
|  |         }); | ||||||
|  |         expandedBox.add(textview); | ||||||
|  |         expandedBox.add(toolbar); | ||||||
|  |  | ||||||
|  |         expander.add(expandedBox); | ||||||
|  |  | ||||||
|  |         scroll.show_all(); | ||||||
|  |         return scroll; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     _buildUI(app) { |     _buildUI(app) { | ||||||
|         this._window = new Gtk.ApplicationWindow({ application: app, |         this._window = new Gtk.ApplicationWindow({ application: app, | ||||||
| @@ -150,8 +224,12 @@ var Application = new Lang.Class({ | |||||||
|                             Gio.SettingsBindFlags.DEFAULT | |                             Gio.SettingsBindFlags.DEFAULT | | ||||||
|                             Gio.SettingsBindFlags.INVERT_BOOLEAN); |                             Gio.SettingsBindFlags.INVERT_BOOLEAN); | ||||||
|  |  | ||||||
|  |         this._mainStack = new Gtk.Stack({ | ||||||
|  |             transition_type: Gtk.StackTransitionType.CROSSFADE | ||||||
|  |         }); | ||||||
|  |         this._window.add(this._mainStack); | ||||||
|  |  | ||||||
|         let scroll = new Gtk.ScrolledWindow({ hscrollbar_policy: Gtk.PolicyType.NEVER }); |         let scroll = new Gtk.ScrolledWindow({ hscrollbar_policy: Gtk.PolicyType.NEVER }); | ||||||
|         this._window.add(scroll); |  | ||||||
|  |  | ||||||
|         this._extensionSelector = new Gtk.ListBox({ selection_mode: Gtk.SelectionMode.NONE }); |         this._extensionSelector = new Gtk.ListBox({ selection_mode: Gtk.SelectionMode.NONE }); | ||||||
|         this._extensionSelector.set_sort_func(this._sortList.bind(this)); |         this._extensionSelector.set_sort_func(this._sortList.bind(this)); | ||||||
| @@ -159,6 +237,8 @@ var Application = new Lang.Class({ | |||||||
|  |  | ||||||
|         scroll.add(this._extensionSelector); |         scroll.add(this._extensionSelector); | ||||||
|  |  | ||||||
|  |         this._mainStack.add_named(scroll, 'listing'); | ||||||
|  |         this._mainStack.add_named(new EmptyPlaceholder(), 'placeholder'); | ||||||
|  |  | ||||||
|         this._shellProxy = new GnomeShellProxy(Gio.DBus.session, 'org.gnome.Shell', '/org/gnome/Shell'); |         this._shellProxy = new GnomeShellProxy(Gio.DBus.session, 'org.gnome.Shell', '/org/gnome/Shell'); | ||||||
|         this._shellProxy.connectSignal('ExtensionStatusChanged', (proxy, senderName, [uuid, state, error]) => { |         this._shellProxy.connectSignal('ExtensionStatusChanged', (proxy, senderName, [uuid, state, error]) => { | ||||||
| @@ -167,13 +247,13 @@ var Application = new Lang.Class({ | |||||||
|         }); |         }); | ||||||
|  |  | ||||||
|         this._window.show_all(); |         this._window.show_all(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _sortList(row1, row2) { |     _sortList(row1, row2) { | ||||||
|         let name1 = ExtensionUtils.extensions[row1.uuid].metadata.name; |         let name1 = ExtensionUtils.extensions[row1.uuid].metadata.name; | ||||||
|         let name2 = ExtensionUtils.extensions[row2.uuid].metadata.name; |         let name2 = ExtensionUtils.extensions[row2.uuid].metadata.name; | ||||||
|         return name1.localeCompare(name2); |         return name1.localeCompare(name2); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateHeader(row, before) { |     _updateHeader(row, before) { | ||||||
|         if (!before || row.get_header()) |         if (!before || row.get_header()) | ||||||
| @@ -181,14 +261,14 @@ var Application = new Lang.Class({ | |||||||
|  |  | ||||||
|         let sep = new Gtk.Separator({ orientation: Gtk.Orientation.HORIZONTAL }); |         let sep = new Gtk.Separator({ orientation: Gtk.Orientation.HORIZONTAL }); | ||||||
|         row.set_header(sep); |         row.set_header(sep); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _scanExtensions() { |     _scanExtensions() { | ||||||
|         let finder = new ExtensionUtils.ExtensionFinder(); |         let finder = new ExtensionUtils.ExtensionFinder(); | ||||||
|         finder.connect('extension-found', this._extensionFound.bind(this)); |         finder.connect('extension-found', this._extensionFound.bind(this)); | ||||||
|         finder.scanExtensions(); |         finder.scanExtensions(); | ||||||
|         this._extensionsLoaded(); |         this._extensionsLoaded(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _extensionFound(finder, extension) { |     _extensionFound(finder, extension) { | ||||||
|         let row = new ExtensionRow(extension.uuid); |         let row = new ExtensionRow(extension.uuid); | ||||||
| @@ -200,24 +280,29 @@ var Application = new Lang.Class({ | |||||||
|  |  | ||||||
|         row.show_all(); |         row.show_all(); | ||||||
|         this._extensionSelector.add(row); |         this._extensionSelector.add(row); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _extensionsLoaded() { |     _extensionsLoaded() { | ||||||
|  |         if (this._extensionSelector.get_children().length > 0) | ||||||
|  |             this._mainStack.visible_child_name = 'listing'; | ||||||
|  |         else | ||||||
|  |             this._mainStack.visible_child_name = 'placeholder'; | ||||||
|  |  | ||||||
|         if (this._startupUuid && this._extensionAvailable(this._startupUuid)) |         if (this._startupUuid && this._extensionAvailable(this._startupUuid)) | ||||||
|             this._selectExtension(this._startupUuid); |             this._selectExtension(this._startupUuid); | ||||||
|         this._startupUuid = null; |         this._startupUuid = null; | ||||||
|         this._skipMainWindow = false; |         this._skipMainWindow = false; | ||||||
|         this._loaded = true; |         this._loaded = true; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onActivate() { |     _onActivate() { | ||||||
|         this._window.present(); |         this._window.present(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onStartup(app) { |     _onStartup(app) { | ||||||
|         this._buildUI(app); |         this._buildUI(app); | ||||||
|         this._scanExtensions(); |         this._scanExtensions(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onCommandLine(app, commandLine) { |     _onCommandLine(app, commandLine) { | ||||||
|         app.activate(); |         app.activate(); | ||||||
| @@ -240,26 +325,187 @@ var Application = new Lang.Class({ | |||||||
|         } |         } | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
|  |  | ||||||
| var DescriptionLabel = new Lang.Class({ | var Expander = GObject.registerClass({ | ||||||
|     Name: 'DescriptionLabel', |     Properties: { | ||||||
|     Extends: Gtk.Label, |         'label': GObject.ParamSpec.string( | ||||||
|  |             'label', 'label', 'label', | ||||||
|  |             GObject.ParamFlags.READWRITE, | ||||||
|  |             null | ||||||
|  |         ) | ||||||
|  |     } | ||||||
|  | }, class Expander extends Gtk.Box { | ||||||
|  |     _init(params = {}) { | ||||||
|  |         this._labelText = null; | ||||||
|  |  | ||||||
|     vfunc_get_preferred_height_for_width(width) { |         super._init(Object.assign(params, { | ||||||
|         // Hack: Request the maximum height allowed by the line limit |             orientation: Gtk.Orientation.VERTICAL, | ||||||
|         if (this.lines > 0) |             spacing: 0 | ||||||
|             return this.parent(0); |         })); | ||||||
|         return this.parent(width); |  | ||||||
|  |         this._frame = new Gtk.Frame({ | ||||||
|  |             shadow_type: Gtk.ShadowType.IN, | ||||||
|  |             hexpand: true | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         let eventBox = new Gtk.EventBox(); | ||||||
|  |         this._frame.add(eventBox); | ||||||
|  |  | ||||||
|  |         let hbox = new Gtk.Box({ | ||||||
|  |             spacing: 6, | ||||||
|  |             margin: 12 | ||||||
|  |         }); | ||||||
|  |         eventBox.add(hbox); | ||||||
|  |  | ||||||
|  |         this._arrow = new Gtk.Image({ | ||||||
|  |             icon_name: 'pan-end-symbolic' | ||||||
|  |         }); | ||||||
|  |         hbox.add(this._arrow); | ||||||
|  |  | ||||||
|  |         this._label = new Gtk.Label({ label: this._labelText }); | ||||||
|  |         hbox.add(this._label); | ||||||
|  |  | ||||||
|  |         this._revealer = new Gtk.Revealer(); | ||||||
|  |  | ||||||
|  |         this._childBin = new Gtk.Frame({ | ||||||
|  |             shadow_type: Gtk.ShadowType.IN | ||||||
|  |         }); | ||||||
|  |         this._revealer.add(this._childBin); | ||||||
|  |  | ||||||
|  |         // Directly chain up to parent for internal children | ||||||
|  |         super.add(this._frame); | ||||||
|  |         super.add(this._revealer); | ||||||
|  |  | ||||||
|  |         let provider = new Gtk.CssProvider(); | ||||||
|  |         provider.load_from_data('* { border-top-width: 0; }'); | ||||||
|  |         this._childBin.get_style_context().add_provider( | ||||||
|  |             provider, | ||||||
|  |             Gtk.STYLE_PROVIDER_PRIORITY_APPLICATION | ||||||
|  |         ); | ||||||
|  |  | ||||||
|  |         this._gesture = new Gtk.GestureMultiPress({ | ||||||
|  |             widget: this._frame, | ||||||
|  |             button: 0, | ||||||
|  |             exclusive: true | ||||||
|  |         }); | ||||||
|  |         this._gesture.connect('released', (gesture, nPress) => { | ||||||
|  |             if (nPress == 1) | ||||||
|  |                 this._revealer.reveal_child = !this._revealer.reveal_child; | ||||||
|  |         }); | ||||||
|  |         this._revealer.connect('notify::reveal-child', () => { | ||||||
|  |             if (this._revealer.reveal_child) | ||||||
|  |                 this._arrow.icon_name = 'pan-down-symbolic'; | ||||||
|  |             else | ||||||
|  |                 this._arrow.icon_name = 'pan-end-symbolic'; | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     get label() { | ||||||
|  |         return this._labelText; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     set label(text) { | ||||||
|  |         if (this._labelText == text) | ||||||
|  |             return; | ||||||
|  |  | ||||||
|  |         if (this._label) | ||||||
|  |             this._label.label = text; | ||||||
|  |         this._labelText = text; | ||||||
|  |         this.notify('label'); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     add(child) { | ||||||
|  |         // set expanded child | ||||||
|  |         this._childBin.get_children().forEach(c => { | ||||||
|  |             this._childBin.remove(c); | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         if (child) | ||||||
|  |             this._childBin.add(child); | ||||||
|     } |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var ExtensionRow = new Lang.Class({ | var EmptyPlaceholder = GObject.registerClass( | ||||||
|     Name: 'ExtensionRow', | class EmptyPlaceholder extends Gtk.Box { | ||||||
|     Extends: Gtk.ListBoxRow, |     _init() { | ||||||
|  |         super._init({ | ||||||
|  |             orientation: Gtk.Orientation.VERTICAL, | ||||||
|  |             spacing: 6, | ||||||
|  |             margin: 32 | ||||||
|  |         }); | ||||||
|  |  | ||||||
|  |         let image = new Gtk.Image({ | ||||||
|  |             icon_name: 'application-x-addon-symbolic', | ||||||
|  |             pixel_size: 96, | ||||||
|  |             visible: true, | ||||||
|  |             vexpand: true, | ||||||
|  |             valign: Gtk.Align.END | ||||||
|  |         }); | ||||||
|  |         image.get_style_context().add_class(Gtk.STYLE_CLASS_DIM_LABEL); | ||||||
|  |         this.add(image); | ||||||
|  |  | ||||||
|  |         let label = new Gtk.Label({ | ||||||
|  |             label: `<b><span size="x-large">${_("No Extensions Installed" )}</span></b>`, | ||||||
|  |             use_markup: true, | ||||||
|  |             visible: true | ||||||
|  |         }); | ||||||
|  |         label.get_style_context().add_class(Gtk.STYLE_CLASS_DIM_LABEL); | ||||||
|  |         this.add(label); | ||||||
|  |  | ||||||
|  |         let appInfo = Gio.DesktopAppInfo.new('org.gnome.Software.desktop'); | ||||||
|  |  | ||||||
|  |         let desc = new Gtk.Label({ | ||||||
|  |             label: _("Extensions can be installed through Software or <a href=\"https://extensions.gnome.org\">extensions.gnome.org</a>."), | ||||||
|  |             use_markup: true, | ||||||
|  |             wrap: true, | ||||||
|  |             justify: Gtk.Justification.CENTER, | ||||||
|  |             visible: true, | ||||||
|  |             max_width_chars: 50, | ||||||
|  |             hexpand: true, | ||||||
|  |             vexpand: (appInfo == null), | ||||||
|  |             halign: Gtk.Align.CENTER, | ||||||
|  |             valign: Gtk.Align.START | ||||||
|  |         }); | ||||||
|  |         this.add(desc); | ||||||
|  |  | ||||||
|  |         if (appInfo) { | ||||||
|  |             let button = new Gtk.Button({ | ||||||
|  |                 label: _("Browse in Software"), | ||||||
|  |                 image: new Gtk.Image({ | ||||||
|  |                     icon_name: "org.gnome.Software-symbolic" | ||||||
|  |                 }), | ||||||
|  |                 always_show_image: true, | ||||||
|  |                 margin_top: 12, | ||||||
|  |                 visible: true, | ||||||
|  |                 halign: Gtk.Align.CENTER, | ||||||
|  |                 valign: Gtk.Align.START, | ||||||
|  |                 vexpand: true | ||||||
|  |             }); | ||||||
|  |             this.add(button); | ||||||
|  |  | ||||||
|  |             button.connect('clicked', w => { | ||||||
|  |                 let context = w.get_display().get_app_launch_context(); | ||||||
|  |                 appInfo.launch([], context); | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | var DescriptionLabel = GObject.registerClass( | ||||||
|  | class DescriptionLabel extends Gtk.Label { | ||||||
|  |     vfunc_get_preferred_height_for_width(width) { | ||||||
|  |         // Hack: Request the maximum height allowed by the line limit | ||||||
|  |         if (this.lines > 0) | ||||||
|  |             return super.vfunc_get_preferred_height_for_width(0); | ||||||
|  |         return super.vfunc_get_preferred_height_for_width(width); | ||||||
|  |     } | ||||||
|  | }); | ||||||
|  |  | ||||||
|  | var ExtensionRow = GObject.registerClass( | ||||||
|  | class ExtensionRow extends Gtk.ListBoxRow { | ||||||
|     _init(uuid) { |     _init(uuid) { | ||||||
|         this.parent(); |         super._init(); | ||||||
|  |  | ||||||
|         this.uuid = uuid; |         this.uuid = uuid; | ||||||
|  |  | ||||||
| @@ -277,7 +523,7 @@ var ExtensionRow = new Lang.Class({ | |||||||
|             }); |             }); | ||||||
|  |  | ||||||
|         this._buildUI(); |         this._buildUI(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _buildUI() { |     _buildUI() { | ||||||
|         let extension = ExtensionUtils.extensions[this.uuid]; |         let extension = ExtensionUtils.extensions[this.uuid]; | ||||||
| @@ -305,9 +551,9 @@ var ExtensionRow = new Lang.Class({ | |||||||
|  |  | ||||||
|         let button = new Gtk.Button({ valign: Gtk.Align.CENTER, |         let button = new Gtk.Button({ valign: Gtk.Align.CENTER, | ||||||
|                                       no_show_all: true }); |                                       no_show_all: true }); | ||||||
|         button.add(new Gtk.Image({ icon_name: 'emblem-system-symbolic', |         button.set_image(new Gtk.Image({ icon_name: 'emblem-system-symbolic', | ||||||
|                                    icon_size: Gtk.IconSize.BUTTON, |                                          icon_size: Gtk.IconSize.BUTTON, | ||||||
|                                    visible: true })); |                                          visible: true })); | ||||||
|         button.get_style_context().add_class('circular'); |         button.get_style_context().add_class('circular'); | ||||||
|         hbox.add(button); |         hbox.add(button); | ||||||
|  |  | ||||||
| @@ -324,7 +570,7 @@ var ExtensionRow = new Lang.Class({ | |||||||
|         }); |         }); | ||||||
|         this._switch.connect('state-set', () => true); |         this._switch.connect('state-set', () => true); | ||||||
|         hbox.add(this._switch); |         hbox.add(this._switch); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _canEnable() { |     _canEnable() { | ||||||
|         let extension = ExtensionUtils.extensions[this.uuid]; |         let extension = ExtensionUtils.extensions[this.uuid]; | ||||||
| @@ -332,12 +578,12 @@ var ExtensionRow = new Lang.Class({ | |||||||
|  |  | ||||||
|         return !this._settings.get_boolean('disable-user-extensions') && |         return !this._settings.get_boolean('disable-user-extensions') && | ||||||
|                !(checkVersion && ExtensionUtils.isOutOfDate(extension)); |                !(checkVersion && ExtensionUtils.isOutOfDate(extension)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _isEnabled() { |     _isEnabled() { | ||||||
|         let extensions = this._settings.get_strv('enabled-extensions'); |         let extensions = this._settings.get_strv('enabled-extensions'); | ||||||
|         return extensions.indexOf(this.uuid) != -1; |         return extensions.indexOf(this.uuid) != -1; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _enable() { |     _enable() { | ||||||
|         let extensions = this._settings.get_strv('enabled-extensions'); |         let extensions = this._settings.get_strv('enabled-extensions'); | ||||||
| @@ -346,7 +592,7 @@ var ExtensionRow = new Lang.Class({ | |||||||
|  |  | ||||||
|         extensions.push(this.uuid); |         extensions.push(this.uuid); | ||||||
|         this._settings.set_strv('enabled-extensions', extensions); |         this._settings.set_strv('enabled-extensions', extensions); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _disable() { |     _disable() { | ||||||
|         let extensions = this._settings.get_strv('enabled-extensions'); |         let extensions = this._settings.get_strv('enabled-extensions'); | ||||||
|   | |||||||
| @@ -1,11 +1,7 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Clutter = imports.gi.Clutter; | const { Clutter, Pango, Shell, St } = imports.gi; | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Pango = imports.gi.Pango; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
| const St = imports.gi.St; |  | ||||||
|  |  | ||||||
| const Animation = imports.ui.animation; | const Animation = imports.ui.animation; | ||||||
| const Batch = imports.gdm.batch; | const Batch = imports.gdm.batch; | ||||||
| @@ -38,10 +34,8 @@ var BeginRequestType = { | |||||||
|     DONT_PROVIDE_USERNAME: 1 |     DONT_PROVIDE_USERNAME: 1 | ||||||
| }; | }; | ||||||
|  |  | ||||||
| var AuthPrompt = new Lang.Class({ | var AuthPrompt = class { | ||||||
|     Name: 'AuthPrompt', |     constructor(gdmClient, mode) { | ||||||
|  |  | ||||||
|     _init(gdmClient, mode) { |  | ||||||
|         this.verificationStatus = AuthPromptStatus.NOT_VERIFYING; |         this.verificationStatus = AuthPromptStatus.NOT_VERIFYING; | ||||||
|  |  | ||||||
|         this._gdmClient = gdmClient; |         this._gdmClient = gdmClient; | ||||||
| @@ -99,7 +93,7 @@ var AuthPrompt = new Lang.Class({ | |||||||
|                          x_align: St.Align.START }); |                          x_align: St.Align.START }); | ||||||
|         this._entry = new St.Entry({ style_class: 'login-dialog-prompt-entry', |         this._entry = new St.Entry({ style_class: 'login-dialog-prompt-entry', | ||||||
|                                      can_focus: true }); |                                      can_focus: true }); | ||||||
|         ShellEntry.addContextMenu(this._entry, { isPassword: true }); |         ShellEntry.addContextMenu(this._entry, { isPassword: true, actionMode: Shell.ActionMode.NONE }); | ||||||
|  |  | ||||||
|         this.actor.add(this._entry, |         this.actor.add(this._entry, | ||||||
|                        { expand: true, |                        { expand: true, | ||||||
| @@ -127,17 +121,16 @@ var AuthPrompt = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._initButtons(); |         this._initButtons(); | ||||||
|  |  | ||||||
|         let spinnerIcon = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/process-working.svg'); |         this._spinner = new Animation.Spinner(DEFAULT_BUTTON_WELL_ICON_SIZE); | ||||||
|         this._spinner = new Animation.AnimatedIcon(spinnerIcon, DEFAULT_BUTTON_WELL_ICON_SIZE); |  | ||||||
|         this._spinner.actor.opacity = 0; |         this._spinner.actor.opacity = 0; | ||||||
|         this._spinner.actor.show(); |         this._spinner.actor.show(); | ||||||
|         this._defaultButtonWell.add_child(this._spinner.actor); |         this._defaultButtonWell.add_child(this._spinner.actor); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDestroy() { |     _onDestroy() { | ||||||
|         this._userVerifier.destroy(); |         this._userVerifier.destroy(); | ||||||
|         this._userVerifier = null; |         this._userVerifier = null; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _initButtons() { |     _initButtons() { | ||||||
|         this.cancelButton = new St.Button({ style_class: 'modal-dialog-button button', |         this.cancelButton = new St.Button({ style_class: 'modal-dialog-button button', | ||||||
| @@ -185,7 +178,7 @@ var AuthPrompt = new Lang.Class({ | |||||||
|             if (this.nextButton.reactive) |             if (this.nextButton.reactive) | ||||||
|                 this.emit('next'); |                 this.emit('next'); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onAskQuestion(verifier, serviceName, question, passwordChar) { |     _onAskQuestion(verifier, serviceName, question, passwordChar) { | ||||||
|         if (this._queryingService) |         if (this._queryingService) | ||||||
| @@ -211,12 +204,12 @@ var AuthPrompt = new Lang.Class({ | |||||||
|  |  | ||||||
|         this.updateSensitivity(true); |         this.updateSensitivity(true); | ||||||
|         this.emit('prompted'); |         this.emit('prompted'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onOVirtUserAuthenticated() { |     _onOVirtUserAuthenticated() { | ||||||
|         if (this.verificationStatus != AuthPromptStatus.VERIFICATION_SUCCEEDED) |         if (this.verificationStatus != AuthPromptStatus.VERIFICATION_SUCCEEDED) | ||||||
|             this.reset(); |             this.reset(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onSmartcardStatusChanged() { |     _onSmartcardStatusChanged() { | ||||||
|         this.smartcardDetected = this._userVerifier.smartcardDetected; |         this.smartcardDetected = this._userVerifier.smartcardDetected; | ||||||
| @@ -235,12 +228,12 @@ var AuthPrompt = new Lang.Class({ | |||||||
|  |  | ||||||
|         if (this.verificationStatus != AuthPromptStatus.VERIFICATION_SUCCEEDED) |         if (this.verificationStatus != AuthPromptStatus.VERIFICATION_SUCCEEDED) | ||||||
|             this.reset(); |             this.reset(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onShowMessage(userVerifier, message, type) { |     _onShowMessage(userVerifier, message, type) { | ||||||
|         this.setMessage(message, type); |         this.setMessage(message, type); | ||||||
|         this.emit('prompted'); |         this.emit('prompted'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onVerificationFailed(userVerifier, canRetry) { |     _onVerificationFailed(userVerifier, canRetry) { | ||||||
|         this._queryingService = null; |         this._queryingService = null; | ||||||
| @@ -249,22 +242,22 @@ var AuthPrompt = new Lang.Class({ | |||||||
|         this.updateSensitivity(canRetry); |         this.updateSensitivity(canRetry); | ||||||
|         this.setActorInDefaultButtonWell(null); |         this.setActorInDefaultButtonWell(null); | ||||||
|         this.verificationStatus = AuthPromptStatus.VERIFICATION_FAILED; |         this.verificationStatus = AuthPromptStatus.VERIFICATION_FAILED; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onVerificationComplete() { |     _onVerificationComplete() { | ||||||
|         this.setActorInDefaultButtonWell(null); |         this.setActorInDefaultButtonWell(null); | ||||||
|         this.verificationStatus = AuthPromptStatus.VERIFICATION_SUCCEEDED; |         this.verificationStatus = AuthPromptStatus.VERIFICATION_SUCCEEDED; | ||||||
|         this.cancelButton.reactive = false; |         this.cancelButton.reactive = false; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onReset() { |     _onReset() { | ||||||
|         this.verificationStatus = AuthPromptStatus.NOT_VERIFYING; |         this.verificationStatus = AuthPromptStatus.NOT_VERIFYING; | ||||||
|         this.reset(); |         this.reset(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     addActorToDefaultButtonWell(actor) { |     addActorToDefaultButtonWell(actor) { | ||||||
|         this._defaultButtonWell.add_child(actor); |         this._defaultButtonWell.add_child(actor); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     setActorInDefaultButtonWell(actor, animate) { |     setActorInDefaultButtonWell(actor, animate) { | ||||||
|         if (!this._defaultButtonWellActor && |         if (!this._defaultButtonWellActor && | ||||||
| @@ -328,25 +321,25 @@ var AuthPrompt = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this._defaultButtonWellActor = actor; |         this._defaultButtonWellActor = actor; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     startSpinning() { |     startSpinning() { | ||||||
|         this.setActorInDefaultButtonWell(this._spinner.actor, true); |         this.setActorInDefaultButtonWell(this._spinner.actor, true); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     stopSpinning() { |     stopSpinning() { | ||||||
|         this.setActorInDefaultButtonWell(null, false); |         this.setActorInDefaultButtonWell(null, false); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     clear() { |     clear() { | ||||||
|         this._entry.text = ''; |         this._entry.text = ''; | ||||||
|         this.stopSpinning(); |         this.stopSpinning(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     setPasswordChar(passwordChar) { |     setPasswordChar(passwordChar) { | ||||||
|         this._entry.clutter_text.set_password_char(passwordChar); |         this._entry.clutter_text.set_password_char(passwordChar); | ||||||
|         this._entry.menu.isPassword = passwordChar != ''; |         this._entry.menu.isPassword = passwordChar != ''; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     setQuestion(question) { |     setQuestion(question) { | ||||||
|         this._label.set_text(question); |         this._label.set_text(question); | ||||||
| @@ -355,7 +348,7 @@ var AuthPrompt = new Lang.Class({ | |||||||
|         this._entry.show(); |         this._entry.show(); | ||||||
|  |  | ||||||
|         this._entry.grab_key_focus(); |         this._entry.grab_key_focus(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getAnswer() { |     getAnswer() { | ||||||
|         let text; |         let text; | ||||||
| @@ -368,7 +361,7 @@ var AuthPrompt = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         return text; |         return text; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _fadeOutMessage() { |     _fadeOutMessage() { | ||||||
|         if (this._message.opacity == 0) |         if (this._message.opacity == 0) | ||||||
| @@ -379,7 +372,7 @@ var AuthPrompt = new Lang.Class({ | |||||||
|                            time: MESSAGE_FADE_OUT_ANIMATION_TIME, |                            time: MESSAGE_FADE_OUT_ANIMATION_TIME, | ||||||
|                            transition: 'easeOutQuad' |                            transition: 'easeOutQuad' | ||||||
|                          }); |                          }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     setMessage(message, type) { |     setMessage(message, type) { | ||||||
|         if (type == GdmUtil.MessageType.ERROR) |         if (type == GdmUtil.MessageType.ERROR) | ||||||
| @@ -399,18 +392,18 @@ var AuthPrompt = new Lang.Class({ | |||||||
|         } else { |         } else { | ||||||
|             this._message.opacity = 0; |             this._message.opacity = 0; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateNextButtonSensitivity(sensitive) { |     _updateNextButtonSensitivity(sensitive) { | ||||||
|         this.nextButton.reactive = sensitive; |         this.nextButton.reactive = sensitive; | ||||||
|         this.nextButton.can_focus = sensitive; |         this.nextButton.can_focus = sensitive; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     updateSensitivity(sensitive) { |     updateSensitivity(sensitive) { | ||||||
|         this._updateNextButtonSensitivity(sensitive && (this._entry.text.length > 0 || this.verificationStatus == AuthPromptStatus.VERIFYING)); |         this._updateNextButtonSensitivity(sensitive && (this._entry.text.length > 0 || this.verificationStatus == AuthPromptStatus.VERIFYING)); | ||||||
|         this._entry.reactive = sensitive; |         this._entry.reactive = sensitive; | ||||||
|         this._entry.clutter_text.editable = sensitive; |         this._entry.clutter_text.editable = sensitive; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     hide() { |     hide() { | ||||||
|         this.setActorInDefaultButtonWell(null, true); |         this.setActorInDefaultButtonWell(null, true); | ||||||
| @@ -421,7 +414,7 @@ var AuthPrompt = new Lang.Class({ | |||||||
|  |  | ||||||
|         this.updateSensitivity(true); |         this.updateSensitivity(true); | ||||||
|         this._entry.set_text(''); |         this._entry.set_text(''); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     setUser(user) { |     setUser(user) { | ||||||
|         let oldChild = this._userWell.get_child(); |         let oldChild = this._userWell.get_child(); | ||||||
| @@ -432,7 +425,7 @@ var AuthPrompt = new Lang.Class({ | |||||||
|             let userWidget = new UserWidget.UserWidget(user); |             let userWidget = new UserWidget.UserWidget(user); | ||||||
|             this._userWell.set_child(userWidget.actor); |             this._userWell.set_child(userWidget.actor); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     reset() { |     reset() { | ||||||
|         let oldStatus = this.verificationStatus; |         let oldStatus = this.verificationStatus; | ||||||
| @@ -470,7 +463,7 @@ var AuthPrompt = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this.emit('reset', beginRequestType); |         this.emit('reset', beginRequestType); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     addCharacter(unichar) { |     addCharacter(unichar) { | ||||||
|         if (!this._entry.visible) |         if (!this._entry.visible) | ||||||
| @@ -478,7 +471,7 @@ var AuthPrompt = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._entry.grab_key_focus(); |         this._entry.grab_key_focus(); | ||||||
|         this._entry.clutter_text.insert_unichar(unichar); |         this._entry.clutter_text.insert_unichar(unichar); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     begin(params) { |     begin(params) { | ||||||
|         params = Params.parse(params, { userName: null, |         params = Params.parse(params, { userName: null, | ||||||
| @@ -492,7 +485,7 @@ var AuthPrompt = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._userVerifier.begin(params.userName, hold); |         this._userVerifier.begin(params.userName, hold); | ||||||
|         this.verificationStatus = AuthPromptStatus.VERIFYING; |         this.verificationStatus = AuthPromptStatus.VERIFYING; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     finish(onComplete) { |     finish(onComplete) { | ||||||
|         if (!this._userVerifier.hasPendingMessages) { |         if (!this._userVerifier.hasPendingMessages) { | ||||||
| @@ -506,7 +499,7 @@ var AuthPrompt = new Lang.Class({ | |||||||
|             this._userVerifier.clear(); |             this._userVerifier.clear(); | ||||||
|             onComplete(); |             onComplete(); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     cancel() { |     cancel() { | ||||||
|         if (this.verificationStatus == AuthPromptStatus.VERIFICATION_SUCCEEDED) { |         if (this.verificationStatus == AuthPromptStatus.VERIFICATION_SUCCEEDED) { | ||||||
| @@ -515,5 +508,5 @@ var AuthPrompt = new Lang.Class({ | |||||||
|         this.reset(); |         this.reset(); | ||||||
|         this.emit('cancelled'); |         this.emit('cancelled'); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(AuthPrompt.prototype); | Signals.addSignalMethods(AuthPrompt.prototype); | ||||||
|   | |||||||
| @@ -44,45 +44,39 @@ | |||||||
|  * replaced by something else. |  * replaced by something else. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
|  |  | ||||||
| var Task = new Lang.Class({ | var Task = class { | ||||||
|     Name: 'Task', |     constructor(scope, handler) { | ||||||
|  |  | ||||||
|     _init(scope, handler) { |  | ||||||
|         if (scope) |         if (scope) | ||||||
|             this.scope = scope; |             this.scope = scope; | ||||||
|         else |         else | ||||||
|             this.scope = this; |             this.scope = this; | ||||||
|  |  | ||||||
|         this.handler = handler; |         this.handler = handler; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     run() { |     run() { | ||||||
|         if (this.handler) |         if (this.handler) | ||||||
|             return this.handler.call(this.scope); |             return this.handler.call(this.scope); | ||||||
|  |  | ||||||
|         return null; |         return null; | ||||||
|     }, |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(Task.prototype); | Signals.addSignalMethods(Task.prototype); | ||||||
|  |  | ||||||
| var Hold = new Lang.Class({ | var Hold = class extends Task { | ||||||
|     Name: 'Hold', |     constructor() { | ||||||
|     Extends: Task, |         super(null, () => this); | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         this.parent(this, () => this); |  | ||||||
|  |  | ||||||
|         this._acquisitions = 1; |         this._acquisitions = 1; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     acquire() { |     acquire() { | ||||||
|         if (this._acquisitions <= 0) |         if (this._acquisitions <= 0) | ||||||
|             throw new Error("Cannot acquire hold after it's been released"); |             throw new Error("Cannot acquire hold after it's been released"); | ||||||
|         this._acquisitions++; |         this._acquisitions++; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     acquireUntilAfter(hold) { |     acquireUntilAfter(hold) { | ||||||
|         if (!hold.isAcquired()) |         if (!hold.isAcquired()) | ||||||
| @@ -93,27 +87,24 @@ var Hold = new Lang.Class({ | |||||||
|             hold.disconnect(signalId); |             hold.disconnect(signalId); | ||||||
|             this.release(); |             this.release(); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     release() { |     release() { | ||||||
|         this._acquisitions--; |         this._acquisitions--; | ||||||
|  |  | ||||||
|         if (this._acquisitions == 0) |         if (this._acquisitions == 0) | ||||||
|             this.emit('release'); |             this.emit('release'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     isAcquired() { |     isAcquired() { | ||||||
|         return this._acquisitions > 0; |         return this._acquisitions > 0; | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(Hold.prototype); | Signals.addSignalMethods(Hold.prototype); | ||||||
|  |  | ||||||
| var Batch = new Lang.Class({ | var Batch = class extends Task { | ||||||
|     Name: 'Batch', |     constructor(scope, tasks) { | ||||||
|     Extends: Task, |         super(); | ||||||
|  |  | ||||||
|     _init(scope, tasks) { |  | ||||||
|         this.parent(); |  | ||||||
|  |  | ||||||
|         this.tasks = []; |         this.tasks = []; | ||||||
|  |  | ||||||
| @@ -130,11 +121,11 @@ var Batch = new Lang.Class({ | |||||||
|  |  | ||||||
|             this.tasks.push(task); |             this.tasks.push(task); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     process() { |     process() { | ||||||
|         throw new Error('Not implemented'); |         throw new GObject.NotImplementedError(`process in ${this.constructor.name}`); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     runTask() { |     runTask() { | ||||||
|         if (!(this._currentTaskIndex in this.tasks)) { |         if (!(this._currentTaskIndex in this.tasks)) { | ||||||
| @@ -142,11 +133,11 @@ var Batch = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         return this.tasks[this._currentTaskIndex].run(); |         return this.tasks[this._currentTaskIndex].run(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _finish() { |     _finish() { | ||||||
|         this.hold.release(); |         this.hold.release(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     nextTask() { |     nextTask() { | ||||||
|         this._currentTaskIndex++; |         this._currentTaskIndex++; | ||||||
| @@ -159,7 +150,7 @@ var Batch = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this.process(); |         this.process(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _start() { |     _start() { | ||||||
|         // acquire a hold to get released when the entire |         // acquire a hold to get released when the entire | ||||||
| @@ -167,7 +158,7 @@ var Batch = new Lang.Class({ | |||||||
|         this.hold = new Hold(); |         this.hold = new Hold(); | ||||||
|         this._currentTaskIndex = 0; |         this._currentTaskIndex = 0; | ||||||
|         this.process(); |         this.process(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     run() { |     run() { | ||||||
|         this._start(); |         this._start(); | ||||||
| @@ -175,18 +166,15 @@ var Batch = new Lang.Class({ | |||||||
|         // hold may be destroyed at this point |         // hold may be destroyed at this point | ||||||
|         // if we're already done running |         // if we're already done running | ||||||
|         return this.hold; |         return this.hold; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     cancel() { |     cancel() { | ||||||
|         this.tasks = this.tasks.splice(0, this._currentTaskIndex + 1); |         this.tasks = this.tasks.splice(0, this._currentTaskIndex + 1); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(Batch.prototype); | Signals.addSignalMethods(Batch.prototype); | ||||||
|  |  | ||||||
| var ConcurrentBatch = new Lang.Class({ | var ConcurrentBatch = class extends Batch { | ||||||
|     Name: 'ConcurrentBatch', |  | ||||||
|     Extends: Batch, |  | ||||||
|  |  | ||||||
|     process() { |     process() { | ||||||
|        let hold = this.runTask(); |        let hold = this.runTask(); | ||||||
|  |  | ||||||
| @@ -199,13 +187,10 @@ var ConcurrentBatch = new Lang.Class({ | |||||||
|        // concurrently. |        // concurrently. | ||||||
|        this.nextTask(); |        this.nextTask(); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(ConcurrentBatch.prototype); | Signals.addSignalMethods(ConcurrentBatch.prototype); | ||||||
|  |  | ||||||
| var ConsecutiveBatch = new Lang.Class({ | var ConsecutiveBatch = class extends Batch { | ||||||
|     Name: 'ConsecutiveBatch', |  | ||||||
|     Extends: Batch, |  | ||||||
|  |  | ||||||
|     process() { |     process() { | ||||||
|        let hold = this.runTask(); |        let hold = this.runTask(); | ||||||
|  |  | ||||||
| @@ -222,5 +207,5 @@ var ConsecutiveBatch = new Lang.Class({ | |||||||
|            this.nextTask(); |            this.nextTask(); | ||||||
|        } |        } | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(ConsecutiveBatch.prototype); | Signals.addSignalMethods(ConsecutiveBatch.prototype); | ||||||
|   | |||||||
| @@ -1,9 +1,6 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Gio = imports.gi.Gio; | const Gio = imports.gi.Gio; | ||||||
| const Lang = imports.lang; |  | ||||||
| const Shell = imports.gi.Shell; |  | ||||||
| const Signals = imports.signals; |  | ||||||
|  |  | ||||||
| const FprintManagerIface = ` | const FprintManagerIface = ` | ||||||
| <node> | <node> | ||||||
|   | |||||||
| @@ -16,20 +16,9 @@ | |||||||
|  * along with this program; if not, see <http://www.gnu.org/licenses/>. |  * along with this program; if not, see <http://www.gnu.org/licenses/>. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| const AccountsService = imports.gi.AccountsService; | const { AccountsService, Atk, Clutter, Gdm, Gio, | ||||||
| const Atk = imports.gi.Atk; |         GLib, GObject, Meta, Pango, Shell, St } = imports.gi; | ||||||
| const Clutter = imports.gi.Clutter; |  | ||||||
| const Gdm = imports.gi.Gdm; |  | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const GLib = imports.gi.GLib; |  | ||||||
| const GObject = imports.gi.GObject; |  | ||||||
| const Gtk = imports.gi.Gtk; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Meta = imports.gi.Meta; |  | ||||||
| const Pango = imports.gi.Pango; |  | ||||||
| const Shell = imports.gi.Shell; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
| const St = imports.gi.St; |  | ||||||
|  |  | ||||||
| const AuthPrompt = imports.gdm.authPrompt; | const AuthPrompt = imports.gdm.authPrompt; | ||||||
| const Batch = imports.gdm.batch; | const Batch = imports.gdm.batch; | ||||||
| @@ -50,10 +39,8 @@ const _TIMED_LOGIN_IDLE_THRESHOLD = 5.0; | |||||||
| const _LOGO_ICON_HEIGHT = 48; | const _LOGO_ICON_HEIGHT = 48; | ||||||
| const _MAX_BOTTOM_MENU_ITEMS = 5; | const _MAX_BOTTOM_MENU_ITEMS = 5; | ||||||
|  |  | ||||||
| var UserListItem = new Lang.Class({ | var UserListItem = class { | ||||||
|     Name: 'UserListItem', |     constructor(user) { | ||||||
|  |  | ||||||
|     _init(user) { |  | ||||||
|         this.user = user; |         this.user = user; | ||||||
|         this._userChangedId = this.user.connect('changed', |         this._userChangedId = this.user.connect('changed', | ||||||
|                                                  this._onUserChanged.bind(this)); |                                                  this._onUserChanged.bind(this)); | ||||||
| @@ -91,26 +78,26 @@ var UserListItem = new Lang.Class({ | |||||||
|  |  | ||||||
|         this.actor.connect('clicked', this._onClicked.bind(this)); |         this.actor.connect('clicked', this._onClicked.bind(this)); | ||||||
|         this._onUserChanged(); |         this._onUserChanged(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onUserChanged() { |     _onUserChanged() { | ||||||
|         this._updateLoggedIn(); |         this._updateLoggedIn(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateLoggedIn() { |     _updateLoggedIn() { | ||||||
|         if (this.user.is_logged_in()) |         if (this.user.is_logged_in()) | ||||||
|             this.actor.add_style_pseudo_class('logged-in'); |             this.actor.add_style_pseudo_class('logged-in'); | ||||||
|         else |         else | ||||||
|             this.actor.remove_style_pseudo_class('logged-in'); |             this.actor.remove_style_pseudo_class('logged-in'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDestroy() { |     _onDestroy() { | ||||||
|         this.user.disconnect(this._userChangedId); |         this.user.disconnect(this._userChangedId); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onClicked() { |     _onClicked() { | ||||||
|         this.emit('activate'); |         this.emit('activate'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _setSelected(selected) { |     _setSelected(selected) { | ||||||
|         if (selected) { |         if (selected) { | ||||||
| @@ -119,7 +106,7 @@ var UserListItem = new Lang.Class({ | |||||||
|         } else { |         } else { | ||||||
|             this.actor.remove_style_pseudo_class('selected'); |             this.actor.remove_style_pseudo_class('selected'); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     showTimedLoginIndicator(time) { |     showTimedLoginIndicator(time) { | ||||||
|         let hold = new Batch.Hold(); |         let hold = new Batch.Hold(); | ||||||
| @@ -147,7 +134,7 @@ var UserListItem = new Lang.Class({ | |||||||
|         GLib.Source.set_name_by_id(this._timedLoginTimeoutId, '[gnome-shell] this._timedLoginTimeoutId'); |         GLib.Source.set_name_by_id(this._timedLoginTimeoutId, '[gnome-shell] this._timedLoginTimeoutId'); | ||||||
|  |  | ||||||
|         return hold; |         return hold; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     hideTimedLoginIndicator() { |     hideTimedLoginIndicator() { | ||||||
|         if (this._timedLoginTimeoutId) { |         if (this._timedLoginTimeoutId) { | ||||||
| @@ -158,16 +145,14 @@ var UserListItem = new Lang.Class({ | |||||||
|         this._timedLoginIndicator.visible = false; |         this._timedLoginIndicator.visible = false; | ||||||
|         this._timedLoginIndicator.scale_x = 0.; |         this._timedLoginIndicator.scale_x = 0.; | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(UserListItem.prototype); | Signals.addSignalMethods(UserListItem.prototype); | ||||||
|  |  | ||||||
| var UserList = new Lang.Class({ | var UserList = class { | ||||||
|     Name: 'UserList', |     constructor() { | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         this.actor = new St.ScrollView({ style_class: 'login-dialog-user-list-view'}); |         this.actor = new St.ScrollView({ style_class: 'login-dialog-user-list-view'}); | ||||||
|         this.actor.set_policy(Gtk.PolicyType.NEVER, |         this.actor.set_policy(St.PolicyType.NEVER, | ||||||
|                               Gtk.PolicyType.AUTOMATIC); |                               St.PolicyType.AUTOMATIC); | ||||||
|  |  | ||||||
|         this._box = new St.BoxLayout({ vertical: true, |         this._box = new St.BoxLayout({ vertical: true, | ||||||
|                                        style_class: 'login-dialog-user-list', |                                        style_class: 'login-dialog-user-list', | ||||||
| @@ -177,7 +162,7 @@ var UserList = new Lang.Class({ | |||||||
|         this._items = {}; |         this._items = {}; | ||||||
|  |  | ||||||
|         this.actor.connect('key-focus-in', this._moveFocusToItems.bind(this)); |         this.actor.connect('key-focus-in', this._moveFocusToItems.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _moveFocusToItems() { |     _moveFocusToItems() { | ||||||
|         let hasItems = Object.keys(this._items).length > 0; |         let hasItems = Object.keys(this._items).length > 0; | ||||||
| @@ -188,18 +173,18 @@ var UserList = new Lang.Class({ | |||||||
|         if (global.stage.get_key_focus() != this.actor) |         if (global.stage.get_key_focus() != this.actor) | ||||||
|             return; |             return; | ||||||
|  |  | ||||||
|         let focusSet = this.actor.navigate_focus(null, Gtk.DirectionType.TAB_FORWARD, false); |         let focusSet = this.actor.navigate_focus(null, St.DirectionType.TAB_FORWARD, false); | ||||||
|         if (!focusSet) { |         if (!focusSet) { | ||||||
|             Meta.later_add(Meta.LaterType.BEFORE_REDRAW, () => { |             Meta.later_add(Meta.LaterType.BEFORE_REDRAW, () => { | ||||||
|                 this._moveFocusToItems(); |                 this._moveFocusToItems(); | ||||||
|                 return false; |                 return false; | ||||||
|             }); |             }); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onItemActivated(activatedItem) { |     _onItemActivated(activatedItem) { | ||||||
|         this.emit('activate', activatedItem); |         this.emit('activate', activatedItem); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     updateStyle(isExpanded) { |     updateStyle(isExpanded) { | ||||||
|         let tasks = []; |         let tasks = []; | ||||||
| @@ -213,7 +198,7 @@ var UserList = new Lang.Class({ | |||||||
|             let item = this._items[userName]; |             let item = this._items[userName]; | ||||||
|             item.actor.sync_hover(); |             item.actor.sync_hover(); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     scrollToItem(item) { |     scrollToItem(item) { | ||||||
|         let box = item.actor.get_allocation_box(); |         let box = item.actor.get_allocation_box(); | ||||||
| @@ -226,7 +211,7 @@ var UserList = new Lang.Class({ | |||||||
|                           { value: value, |                           { value: value, | ||||||
|                             time: _SCROLL_ANIMATION_TIME, |                             time: _SCROLL_ANIMATION_TIME, | ||||||
|                             transition: 'easeOutQuad' }); |                             transition: 'easeOutQuad' }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     jumpToItem(item) { |     jumpToItem(item) { | ||||||
|         let box = item.actor.get_allocation_box(); |         let box = item.actor.get_allocation_box(); | ||||||
| @@ -236,7 +221,7 @@ var UserList = new Lang.Class({ | |||||||
|         let value = (box.y1 + adjustment.step_increment / 2.0) - (adjustment.page_size / 2.0); |         let value = (box.y1 + adjustment.step_increment / 2.0) - (adjustment.page_size / 2.0); | ||||||
|  |  | ||||||
|         adjustment.set_value(value); |         adjustment.set_value(value); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getItemFromUserName(userName) { |     getItemFromUserName(userName) { | ||||||
|         let item = this._items[userName]; |         let item = this._items[userName]; | ||||||
| @@ -245,11 +230,11 @@ var UserList = new Lang.Class({ | |||||||
|             return null; |             return null; | ||||||
|  |  | ||||||
|         return item; |         return item; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     containsUser(user) { |     containsUser(user) { | ||||||
|         return this._items[user.get_user_name()] != null; |         return this._items[user.get_user_name()] != null; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     addUser(user) { |     addUser(user) { | ||||||
|         if (!user.is_loaded) |         if (!user.is_loaded) | ||||||
| @@ -281,7 +266,7 @@ var UserList = new Lang.Class({ | |||||||
|         this._moveFocusToItems(); |         this._moveFocusToItems(); | ||||||
|  |  | ||||||
|         this.emit('item-added', item); |         this.emit('item-added', item); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     removeUser(user) { |     removeUser(user) { | ||||||
|         if (!user.is_loaded) |         if (!user.is_loaded) | ||||||
| @@ -299,18 +284,16 @@ var UserList = new Lang.Class({ | |||||||
|  |  | ||||||
|         item.actor.destroy(); |         item.actor.destroy(); | ||||||
|         delete this._items[userName]; |         delete this._items[userName]; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     numItems() { |     numItems() { | ||||||
|         return Object.keys(this._items).length; |         return Object.keys(this._items).length; | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(UserList.prototype); | Signals.addSignalMethods(UserList.prototype); | ||||||
|  |  | ||||||
| var SessionMenuButton = new Lang.Class({ | var SessionMenuButton = class { | ||||||
|     Name: 'SessionMenuButton', |     constructor() { | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         let gearIcon = new St.Icon({ icon_name: 'emblem-system-symbolic' }); |         let gearIcon = new St.Icon({ icon_name: 'emblem-system-symbolic' }); | ||||||
|         this._button = new St.Button({ style_class: 'login-dialog-session-list-button', |         this._button = new St.Button({ style_class: 'login-dialog-session-list-button', | ||||||
|                                        reactive: true, |                                        reactive: true, | ||||||
| @@ -342,7 +325,8 @@ var SessionMenuButton = new Lang.Class({ | |||||||
|                  this._button.remove_style_pseudo_class('active'); |                  this._button.remove_style_pseudo_class('active'); | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
|         this._manager = new PopupMenu.PopupMenuManager({ actor: this._button }); |         this._manager = new PopupMenu.PopupMenuManager(this._button, | ||||||
|  |                                                        { actionMode: Shell.ActionMode.NONE }); | ||||||
|         this._manager.addMenu(this._menu); |         this._manager.addMenu(this._menu); | ||||||
|  |  | ||||||
|         this._button.connect('clicked', () => { this._menu.toggle(); }); |         this._button.connect('clicked', () => { this._menu.toggle(); }); | ||||||
| @@ -350,13 +334,13 @@ var SessionMenuButton = new Lang.Class({ | |||||||
|         this._items = {}; |         this._items = {}; | ||||||
|         this._activeSessionId = null; |         this._activeSessionId = null; | ||||||
|         this._populate(); |         this._populate(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     updateSensitivity(sensitive) { |     updateSensitivity(sensitive) { | ||||||
|         this._button.reactive = sensitive; |         this._button.reactive = sensitive; | ||||||
|         this._button.can_focus = sensitive; |         this._button.can_focus = sensitive; | ||||||
|         this._menu.close(BoxPointer.PopupAnimation.NONE); |         this._menu.close(BoxPointer.PopupAnimation.NONE); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateOrnament() { |     _updateOrnament() { | ||||||
|         let itemIds = Object.keys(this._items); |         let itemIds = Object.keys(this._items); | ||||||
| @@ -366,7 +350,7 @@ var SessionMenuButton = new Lang.Class({ | |||||||
|             else |             else | ||||||
|                 this._items[itemIds[i]].setOrnament(PopupMenu.Ornament.NONE); |                 this._items[itemIds[i]].setOrnament(PopupMenu.Ornament.NONE); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     setActiveSession(sessionId) { |     setActiveSession(sessionId) { | ||||||
|          if (sessionId == this._activeSessionId) |          if (sessionId == this._activeSessionId) | ||||||
| @@ -374,11 +358,11 @@ var SessionMenuButton = new Lang.Class({ | |||||||
|  |  | ||||||
|          this._activeSessionId = sessionId; |          this._activeSessionId = sessionId; | ||||||
|          this._updateOrnament(); |          this._updateOrnament(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     close() { |     close() { | ||||||
|         this._menu.close(); |         this._menu.close(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _populate() { |     _populate() { | ||||||
|         let ids = Gdm.get_session_ids(); |         let ids = Gdm.get_session_ids(); | ||||||
| @@ -403,16 +387,14 @@ var SessionMenuButton = new Lang.Class({ | |||||||
|             }); |             }); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(SessionMenuButton.prototype); | Signals.addSignalMethods(SessionMenuButton.prototype); | ||||||
|  |  | ||||||
| var LoginDialog = new Lang.Class({ | var LoginDialog = GObject.registerClass({ | ||||||
|     Name: 'LoginDialog', |  | ||||||
|     Extends: St.Widget, |  | ||||||
|     Signals: { 'failed': {} }, |     Signals: { 'failed': {} }, | ||||||
|  | }, class LoginDialog extends St.Widget { | ||||||
|     _init(parentActor) { |     _init(parentActor) { | ||||||
|         this.parent({ style_class: 'login-dialog', |         super._init({ style_class: 'login-dialog', | ||||||
|                       visible: false }); |                       visible: false }); | ||||||
|  |  | ||||||
|         this.get_accessible().set_role(Atk.Role.WINDOW); |         this.get_accessible().set_role(Atk.Role.WINDOW); | ||||||
| @@ -482,8 +464,8 @@ var LoginDialog = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._bannerView = new St.ScrollView({ style_class: 'login-dialog-banner-view', |         this._bannerView = new St.ScrollView({ style_class: 'login-dialog-banner-view', | ||||||
|                                                opacity: 0, |                                                opacity: 0, | ||||||
|                                                vscrollbar_policy: Gtk.PolicyType.AUTOMATIC, |                                                vscrollbar_policy: St.PolicyType.AUTOMATIC, | ||||||
|                                                hscrollbar_policy: Gtk.PolicyType.NEVER }); |                                                hscrollbar_policy: St.PolicyType.NEVER }); | ||||||
|         this.add_child(this._bannerView); |         this.add_child(this._bannerView); | ||||||
|  |  | ||||||
|         let bannerBox = new St.BoxLayout({ vertical: true }); |         let bannerBox = new St.BoxLayout({ vertical: true }); | ||||||
| @@ -499,6 +481,9 @@ var LoginDialog = new Lang.Class({ | |||||||
|         this._logoBin = new St.Widget({ style_class: 'login-dialog-logo-bin', |         this._logoBin = new St.Widget({ style_class: 'login-dialog-logo-bin', | ||||||
|                                         x_align: Clutter.ActorAlign.CENTER, |                                         x_align: Clutter.ActorAlign.CENTER, | ||||||
|                                         y_align: Clutter.ActorAlign.END }); |                                         y_align: Clutter.ActorAlign.END }); | ||||||
|  |         this._logoBin.connect('resource-scale-changed', () => { | ||||||
|  |             this._updateLogoTexture(this._textureCache, this._logoFile); | ||||||
|  |         }); | ||||||
|         this.add_child(this._logoBin); |         this.add_child(this._logoBin); | ||||||
|         this._updateLogo(); |         this._updateLogo(); | ||||||
|  |  | ||||||
| @@ -530,7 +515,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|         // focus later |         // focus later | ||||||
|         this._startupCompleteId = Main.layoutManager.connect('startup-complete', |         this._startupCompleteId = Main.layoutManager.connect('startup-complete', | ||||||
|                                                              this._updateDisableUserList.bind(this)); |                                                              this._updateDisableUserList.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _getBannerAllocation(dialogBox) { |     _getBannerAllocation(dialogBox) { | ||||||
|         let actorBox = new Clutter.ActorBox(); |         let actorBox = new Clutter.ActorBox(); | ||||||
| @@ -544,7 +529,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|         actorBox.y2 = actorBox.y1 + natHeight; |         actorBox.y2 = actorBox.y1 + natHeight; | ||||||
|  |  | ||||||
|         return actorBox; |         return actorBox; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _getLogoBinAllocation(dialogBox) { |     _getLogoBinAllocation(dialogBox) { | ||||||
|         let actorBox = new Clutter.ActorBox(); |         let actorBox = new Clutter.ActorBox(); | ||||||
| @@ -558,7 +543,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|         actorBox.y2 = actorBox.y1 + natHeight; |         actorBox.y2 = actorBox.y1 + natHeight; | ||||||
|  |  | ||||||
|         return actorBox; |         return actorBox; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _getCenterActorAllocation(dialogBox, actor) { |     _getCenterActorAllocation(dialogBox, actor) { | ||||||
|         let actorBox = new Clutter.ActorBox(); |         let actorBox = new Clutter.ActorBox(); | ||||||
| @@ -576,7 +561,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|         actorBox.y2 = actorBox.y1 + natHeight; |         actorBox.y2 = actorBox.y1 + natHeight; | ||||||
|  |  | ||||||
|         return actorBox; |         return actorBox; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_allocate(dialogBox, flags) { |     vfunc_allocate(dialogBox, flags) { | ||||||
|         this.set_allocation(dialogBox, flags); |         this.set_allocation(dialogBox, flags); | ||||||
| @@ -667,7 +652,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|                      bannerAllocation.x2 = Math.floor(centerX - centerGap / 2); |                      bannerAllocation.x2 = Math.floor(centerX - centerGap / 2); | ||||||
|                      bannerAllocation.x1 = Math.floor(bannerAllocation.x2 - wideBannerWidth); |                      bannerAllocation.x1 = Math.floor(bannerAllocation.x2 - wideBannerWidth); | ||||||
|  |  | ||||||
|                      // figure out how tall it would like to be and try to accomodate |                      // figure out how tall it would like to be and try to accommodate | ||||||
|                      // but don't let it get too close to the logo |                      // but don't let it get too close to the logo | ||||||
|                      let [wideMinHeight, wideBannerHeight] = this._bannerView.get_preferred_height(wideBannerWidth); |                      let [wideMinHeight, wideBannerHeight] = this._bannerView.get_preferred_height(wideBannerWidth); | ||||||
|  |  | ||||||
| @@ -719,7 +704,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|  |  | ||||||
|         if (logoAllocation) |         if (logoAllocation) | ||||||
|             this._logoBin.allocate(logoAllocation, flags); |             this._logoBin.allocate(logoAllocation, flags); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _ensureUserListLoaded() { |     _ensureUserListLoaded() { | ||||||
|         if (!this._userManager.is_loaded) { |         if (!this._userManager.is_loaded) { | ||||||
| @@ -735,7 +720,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|             let id = GLib.idle_add(GLib.PRIORITY_DEFAULT, this._loadUserList.bind(this)); |             let id = GLib.idle_add(GLib.PRIORITY_DEFAULT, this._loadUserList.bind(this)); | ||||||
|             GLib.Source.set_name_by_id(id, '[gnome-shell] _loadUserList'); |             GLib.Source.set_name_by_id(id, '[gnome-shell] _loadUserList'); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateDisableUserList() { |     _updateDisableUserList() { | ||||||
|         let disableUserList = this._settings.get_boolean(GdmUtil.DISABLE_USER_LIST_KEY); |         let disableUserList = this._settings.get_boolean(GdmUtil.DISABLE_USER_LIST_KEY); | ||||||
| @@ -750,7 +735,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|             if (this._authPrompt.verificationStatus == AuthPrompt.AuthPromptStatus.NOT_VERIFYING) |             if (this._authPrompt.verificationStatus == AuthPrompt.AuthPromptStatus.NOT_VERIFYING) | ||||||
|                 this._authPrompt.reset(); |                 this._authPrompt.reset(); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateCancelButton() { |     _updateCancelButton() { | ||||||
|         let cancelVisible; |         let cancelVisible; | ||||||
| @@ -763,7 +748,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|             cancelVisible = true; |             cancelVisible = true; | ||||||
|  |  | ||||||
|         this._authPrompt.cancelButton.visible = cancelVisible; |         this._authPrompt.cancelButton.visible = cancelVisible; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateBanner() { |     _updateBanner() { | ||||||
|         let enabled = this._settings.get_boolean(GdmUtil.BANNER_MESSAGE_KEY); |         let enabled = this._settings.get_boolean(GdmUtil.BANNER_MESSAGE_KEY); | ||||||
| @@ -775,7 +760,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|         } else { |         } else { | ||||||
|             this._bannerLabel.hide(); |             this._bannerLabel.hide(); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _fadeInBannerView() { |     _fadeInBannerView() { | ||||||
|         this._bannerView.show(); |         this._bannerView.show(); | ||||||
| @@ -783,33 +768,34 @@ var LoginDialog = new Lang.Class({ | |||||||
|                          { opacity: 255, |                          { opacity: 255, | ||||||
|                            time: _FADE_ANIMATION_TIME, |                            time: _FADE_ANIMATION_TIME, | ||||||
|                            transition: 'easeOutQuad' }); |                            transition: 'easeOutQuad' }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _hideBannerView() { |     _hideBannerView() { | ||||||
|         Tweener.removeTweens(this._bannerView); |         Tweener.removeTweens(this._bannerView); | ||||||
|         this._bannerView.opacity = 0; |         this._bannerView.opacity = 0; | ||||||
|         this._bannerView.hide(); |         this._bannerView.hide(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateLogoTexture(cache, file) { |     _updateLogoTexture(cache, file) { | ||||||
|         if (this._logoFile && !this._logoFile.equal(file)) |         if (this._logoFile && !this._logoFile.equal(file)) | ||||||
|             return; |             return; | ||||||
|  |  | ||||||
|         this._logoBin.destroy_all_children(); |         this._logoBin.destroy_all_children(); | ||||||
|         if (this._logoFile) { |         if (this._logoFile && this._logoBin.resource_scale > 0) { | ||||||
|             let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor; |             let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor; | ||||||
|             this._logoBin.add_child(this._textureCache.load_file_async(this._logoFile, |             this._logoBin.add_child(this._textureCache.load_file_async(this._logoFile, | ||||||
|                                                                        -1, _LOGO_ICON_HEIGHT, |                                                                        -1, _LOGO_ICON_HEIGHT, | ||||||
|                                                                        scaleFactor)); |                                                                        scaleFactor, | ||||||
|  |                                                                        this._logoBin.resource_scale)); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateLogo() { |     _updateLogo() { | ||||||
|         let path = this._settings.get_string(GdmUtil.LOGO_KEY); |         let path = this._settings.get_string(GdmUtil.LOGO_KEY); | ||||||
|  |  | ||||||
|         this._logoFile = path ? Gio.file_new_for_path(path) : null; |         this._logoFile = path ? Gio.file_new_for_path(path) : null; | ||||||
|         this._updateLogoTexture(this._textureCache, this._logoFile); |         this._updateLogoTexture(this._textureCache, this._logoFile); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onPrompted() { |     _onPrompted() { | ||||||
|         if (this._shouldShowSessionMenuButton()) { |         if (this._shouldShowSessionMenuButton()) { | ||||||
| @@ -819,7 +805,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|             this._sessionMenuButton.updateSensitivity(false); |             this._sessionMenuButton.updateSensitivity(false); | ||||||
|         } |         } | ||||||
|         this._showPrompt(); |         this._showPrompt(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _resetGreeterProxy() { |     _resetGreeterProxy() { | ||||||
|         if (GLib.getenv('GDM_GREETER_TEST') != '1') { |         if (GLib.getenv('GDM_GREETER_TEST') != '1') { | ||||||
| @@ -835,7 +821,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|             this._timedLoginRequestedId = this._greeter.connect('timed-login-requested', |             this._timedLoginRequestedId = this._greeter.connect('timed-login-requested', | ||||||
|                                                                 this._onTimedLoginRequested.bind(this)); |                                                                 this._onTimedLoginRequested.bind(this)); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onReset(authPrompt, beginRequest) { |     _onReset(authPrompt, beginRequest) { | ||||||
|         this._resetGreeterProxy(); |         this._resetGreeterProxy(); | ||||||
| @@ -856,11 +842,11 @@ var LoginDialog = new Lang.Class({ | |||||||
|         } else { |         } else { | ||||||
|             this._hideUserListAndBeginVerification(); |             this._hideUserListAndBeginVerification(); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDefaultSessionChanged(client, sessionId) { |     _onDefaultSessionChanged(client, sessionId) { | ||||||
|         this._sessionMenuButton.setActiveSession(sessionId); |         this._sessionMenuButton.setActiveSession(sessionId); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _shouldShowSessionMenuButton() { |     _shouldShowSessionMenuButton() { | ||||||
|         if (this._authPrompt.verificationStatus != AuthPrompt.AuthPromptStatus.VERIFYING && |         if (this._authPrompt.verificationStatus != AuthPrompt.AuthPromptStatus.VERIFYING && | ||||||
| @@ -871,7 +857,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|           return false; |           return false; | ||||||
|  |  | ||||||
|         return true; |         return true; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _showPrompt() { |     _showPrompt() { | ||||||
|         if (this._authPrompt.actor.visible) |         if (this._authPrompt.actor.visible) | ||||||
| @@ -883,7 +869,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|                            time: _FADE_ANIMATION_TIME, |                            time: _FADE_ANIMATION_TIME, | ||||||
|                            transition: 'easeOutQuad' }); |                            transition: 'easeOutQuad' }); | ||||||
|         this._fadeInBannerView(); |         this._fadeInBannerView(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _showRealmLoginHint(realmManager, hint) { |     _showRealmLoginHint(realmManager, hint) { | ||||||
|         if (!hint) |         if (!hint) | ||||||
| @@ -896,7 +882,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|         // Translators: this message is shown below the username entry field |         // Translators: this message is shown below the username entry field | ||||||
|         // to clue the user in on how to login to the local network realm |         // to clue the user in on how to login to the local network realm | ||||||
|         this._authPrompt.setMessage(_("(e.g., user or %s)").format(hint), GdmUtil.MessageType.HINT); |         this._authPrompt.setMessage(_("(e.g., user or %s)").format(hint), GdmUtil.MessageType.HINT); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _askForUsernameAndBeginVerification() { |     _askForUsernameAndBeginVerification() { | ||||||
|         this._authPrompt.setPasswordChar(''); |         this._authPrompt.setPasswordChar(''); | ||||||
| @@ -923,7 +909,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|         this._sessionMenuButton.updateSensitivity(false); |         this._sessionMenuButton.updateSensitivity(false); | ||||||
|         this._authPrompt.updateSensitivity(true); |         this._authPrompt.updateSensitivity(true); | ||||||
|         this._showPrompt(); |         this._showPrompt(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _loginScreenSessionActivated() { |     _loginScreenSessionActivated() { | ||||||
|         if (this.opacity == 255 && this._authPrompt.verificationStatus == AuthPrompt.AuthPromptStatus.NOT_VERIFYING) |         if (this.opacity == 255 && this._authPrompt.verificationStatus == AuthPrompt.AuthPromptStatus.NOT_VERIFYING) | ||||||
| @@ -947,7 +933,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|                                    this._authPrompt.reset(); |                                    this._authPrompt.reset(); | ||||||
|                            }, |                            }, | ||||||
|                            onCompleteScope: this }); |                            onCompleteScope: this }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _gotGreeterSessionProxy(proxy) { |     _gotGreeterSessionProxy(proxy) { | ||||||
|         this._greeterSessionProxy = proxy; |         this._greeterSessionProxy = proxy; | ||||||
| @@ -956,7 +942,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|                 if (proxy.Active) |                 if (proxy.Active) | ||||||
|                     this._loginScreenSessionActivated(); |                     this._loginScreenSessionActivated(); | ||||||
|             }); |             }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _startSession(serviceName) { |     _startSession(serviceName) { | ||||||
|         Tweener.addTween(this, |         Tweener.addTween(this, | ||||||
| @@ -976,11 +962,11 @@ var LoginDialog = new Lang.Class({ | |||||||
|                                this._greeter.call_start_session_when_ready_sync(serviceName, true, null); |                                this._greeter.call_start_session_when_ready_sync(serviceName, true, null); | ||||||
|                            }, |                            }, | ||||||
|                            onCompleteScope: this }); |                            onCompleteScope: this }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onSessionOpened(client, serviceName) { |     _onSessionOpened(client, serviceName) { | ||||||
|         this._authPrompt.finish(() => { this._startSession(serviceName); }); |         this._authPrompt.finish(() => { this._startSession(serviceName); }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _waitForItemForUser(userName) { |     _waitForItemForUser(userName) { | ||||||
|         let item = this._userList.getItemFromUserName(userName); |         let item = this._userList.getItemFromUserName(userName); | ||||||
| @@ -1000,7 +986,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|         hold.connect('release', () => { this._userList.disconnect(signalId); }); |         hold.connect('release', () => { this._userList.disconnect(signalId); }); | ||||||
|  |  | ||||||
|         return hold; |         return hold; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _blockTimedLoginUntilIdle() { |     _blockTimedLoginUntilIdle() { | ||||||
|         let hold = new Batch.Hold(); |         let hold = new Batch.Hold(); | ||||||
| @@ -1013,7 +999,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|             }); |             }); | ||||||
|         GLib.Source.set_name_by_id(this._timedLoginIdleTimeOutId, '[gnome-shell] this._timedLoginIdleTimeOutId'); |         GLib.Source.set_name_by_id(this._timedLoginIdleTimeOutId, '[gnome-shell] this._timedLoginIdleTimeOutId'); | ||||||
|         return hold; |         return hold; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _startTimedLogin(userName, delay) { |     _startTimedLogin(userName, delay) { | ||||||
|         let firstRun = true; |         let firstRun = true; | ||||||
| @@ -1086,7 +1072,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|         this._timedLoginBatch = new Batch.ConsecutiveBatch(this, tasks); |         this._timedLoginBatch = new Batch.ConsecutiveBatch(this, tasks); | ||||||
|  |  | ||||||
|         return this._timedLoginBatch.run(); |         return this._timedLoginBatch.run(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onTimedLoginRequested(client, userName, seconds) { |     _onTimedLoginRequested(client, userName, seconds) { | ||||||
|         if (this._timedLoginBatch) |         if (this._timedLoginBatch) | ||||||
| @@ -1103,28 +1089,28 @@ var LoginDialog = new Lang.Class({ | |||||||
|  |  | ||||||
|            return Clutter.EVENT_PROPAGATE; |            return Clutter.EVENT_PROPAGATE; | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _setUserListExpanded(expanded) { |     _setUserListExpanded(expanded) { | ||||||
|         this._userList.updateStyle(expanded); |         this._userList.updateStyle(expanded); | ||||||
|         this._userSelectionBox.visible = expanded; |         this._userSelectionBox.visible = expanded; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _hideUserList() { |     _hideUserList() { | ||||||
|         this._setUserListExpanded(false); |         this._setUserListExpanded(false); | ||||||
|         if (this._userSelectionBox.visible) |         if (this._userSelectionBox.visible) | ||||||
|             GdmUtil.cloneAndFadeOutActor(this._userSelectionBox); |             GdmUtil.cloneAndFadeOutActor(this._userSelectionBox); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _hideUserListAskForUsernameAndBeginVerification() { |     _hideUserListAskForUsernameAndBeginVerification() { | ||||||
|         this._hideUserList(); |         this._hideUserList(); | ||||||
|         this._askForUsernameAndBeginVerification(); |         this._askForUsernameAndBeginVerification(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _hideUserListAndBeginVerification() { |     _hideUserListAndBeginVerification() { | ||||||
|         this._hideUserList(); |         this._hideUserList(); | ||||||
|         this._authPrompt.begin(); |         this._authPrompt.begin(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _showUserList() { |     _showUserList() { | ||||||
|         this._ensureUserListLoaded(); |         this._ensureUserListLoaded(); | ||||||
| @@ -1134,7 +1120,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|         this._setUserListExpanded(true); |         this._setUserListExpanded(true); | ||||||
|         this._notListedButton.show(); |         this._notListedButton.show(); | ||||||
|         this._userList.actor.grab_key_focus(); |         this._userList.actor.grab_key_focus(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _beginVerificationForItem(item) { |     _beginVerificationForItem(item) { | ||||||
|         this._authPrompt.setUser(item.user); |         this._authPrompt.setUser(item.user); | ||||||
| @@ -1145,7 +1131,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|         this._authPrompt.begin({ userName: userName, |         this._authPrompt.begin({ userName: userName, | ||||||
|                                  hold: hold }); |                                  hold: hold }); | ||||||
|         return hold; |         return hold; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onUserListActivated(activatedItem) { |     _onUserListActivated(activatedItem) { | ||||||
|         this._user = activatedItem.user; |         this._user = activatedItem.user; | ||||||
| @@ -1155,7 +1141,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|         let batch = new Batch.ConcurrentBatch(this, [GdmUtil.cloneAndFadeOutActor(this._userSelectionBox), |         let batch = new Batch.ConcurrentBatch(this, [GdmUtil.cloneAndFadeOutActor(this._userSelectionBox), | ||||||
|                                                      this._beginVerificationForItem(activatedItem)]); |                                                      this._beginVerificationForItem(activatedItem)]); | ||||||
|         batch.run(); |         batch.run(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDestroy() { |     _onDestroy() { | ||||||
|         if (this._userManagerLoadedId) { |         if (this._userManagerLoadedId) { | ||||||
| @@ -1196,7 +1182,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|             this._realmManager.release(); |             this._realmManager.release(); | ||||||
|             this._realmManager = null; |             this._realmManager = null; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _loadUserList() { |     _loadUserList() { | ||||||
|         if (this._userListLoaded) |         if (this._userListLoaded) | ||||||
| @@ -1234,7 +1220,7 @@ var LoginDialog = new Lang.Class({ | |||||||
|             }); |             }); | ||||||
|  |  | ||||||
|         return GLib.SOURCE_REMOVE; |         return GLib.SOURCE_REMOVE; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     open() { |     open() { | ||||||
|         Main.ctrlAltTabManager.addGroup(this, |         Main.ctrlAltTabManager.addGroup(this, | ||||||
| @@ -1253,22 +1239,22 @@ var LoginDialog = new Lang.Class({ | |||||||
|                            transition: 'easeInQuad' }); |                            transition: 'easeInQuad' }); | ||||||
|  |  | ||||||
|         return true; |         return true; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     close() { |     close() { | ||||||
|         Main.popModal(this); |         Main.popModal(this); | ||||||
|         Main.ctrlAltTabManager.removeGroup(this); |         Main.ctrlAltTabManager.removeGroup(this); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     cancel() { |     cancel() { | ||||||
|         this._authPrompt.cancel(); |         this._authPrompt.cancel(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     addCharacter(unichar) { |     addCharacter(unichar) { | ||||||
|         // Don't allow type ahead at the login screen |         // Don't allow type ahead at the login screen | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     finish(onComplete) { |     finish(onComplete) { | ||||||
|         this._authPrompt.finish(onComplete); |         this._authPrompt.finish(onComplete); | ||||||
|     }, |     } | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Gio = imports.gi.Gio; | const Gio = imports.gi.Gio; | ||||||
| const Lang = imports.lang; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
|  |  | ||||||
| const OVirtCredentialsIface = ` | const OVirtCredentialsIface = ` | ||||||
| @@ -28,33 +27,32 @@ function OVirtCredentials() { | |||||||
|     return self; |     return self; | ||||||
| } | } | ||||||
|  |  | ||||||
| var OVirtCredentialsManager = new Lang.Class({ | var OVirtCredentialsManager = class { | ||||||
|     Name: 'OVirtCredentialsManager', |     constructor() { | ||||||
|     _init() { |  | ||||||
|         this._token = null; |         this._token = null; | ||||||
|  |  | ||||||
|         this._credentials = new OVirtCredentials(); |         this._credentials = new OVirtCredentials(); | ||||||
|         this._credentials.connectSignal('UserAuthenticated', |         this._credentials.connectSignal('UserAuthenticated', | ||||||
|                                         this._onUserAuthenticated.bind(this)); |                                         this._onUserAuthenticated.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onUserAuthenticated(proxy, sender, [token]) { |     _onUserAuthenticated(proxy, sender, [token]) { | ||||||
|         this._token = token; |         this._token = token; | ||||||
|         this.emit('user-authenticated', token); |         this.emit('user-authenticated', token); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     hasToken() { |     hasToken() { | ||||||
|         return this._token != null; |         return this._token != null; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getToken() { |     getToken() { | ||||||
|         return this._token; |         return this._token; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     resetToken() { |     resetToken() { | ||||||
|         this._token = null; |         this._token = null; | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(OVirtCredentialsManager.prototype); | Signals.addSignalMethods(OVirtCredentialsManager.prototype); | ||||||
|  |  | ||||||
| function getOVirtCredentialsManager() { | function getOVirtCredentialsManager() { | ||||||
|   | |||||||
| @@ -1,8 +1,6 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Gio = imports.gi.Gio; | const Gio = imports.gi.Gio; | ||||||
| const Lang = imports.lang; |  | ||||||
| const Shell = imports.gi.Shell; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
|  |  | ||||||
| const { loadInterfaceXML } = imports.misc.fileUtils; | const { loadInterfaceXML } = imports.misc.fileUtils; | ||||||
| @@ -16,10 +14,8 @@ const Service = Gio.DBusProxy.makeProxyWrapper(ServiceIface); | |||||||
| const RealmIface = loadInterfaceXML("org.freedesktop.realmd.Realm"); | const RealmIface = loadInterfaceXML("org.freedesktop.realmd.Realm"); | ||||||
| const Realm = Gio.DBusProxy.makeProxyWrapper(RealmIface); | const Realm = Gio.DBusProxy.makeProxyWrapper(RealmIface); | ||||||
|  |  | ||||||
| var Manager = new Lang.Class({ | var Manager = class { | ||||||
|     Name: 'Manager', |     constructor(parentActor) { | ||||||
|  |  | ||||||
|     _init(parentActor) { |  | ||||||
|         this._aggregateProvider = Provider(Gio.DBus.system, |         this._aggregateProvider = Provider(Gio.DBus.system, | ||||||
|                                            'org.freedesktop.realmd', |                                            'org.freedesktop.realmd', | ||||||
|                                            '/org/freedesktop/realmd', |                                            '/org/freedesktop/realmd', | ||||||
| @@ -31,7 +27,7 @@ var Manager = new Lang.Class({ | |||||||
|                 if ('Realms' in properties.deep_unpack()) |                 if ('Realms' in properties.deep_unpack()) | ||||||
|                     this._reloadRealms(); |                     this._reloadRealms(); | ||||||
|             }); |             }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _reloadRealms() { |     _reloadRealms() { | ||||||
|         let realmPaths = this._aggregateProvider.Realms; |         let realmPaths = this._aggregateProvider.Realms; | ||||||
| @@ -45,7 +41,7 @@ var Manager = new Lang.Class({ | |||||||
|                               realmPaths[i], |                               realmPaths[i], | ||||||
|                               this._onRealmLoaded.bind(this)); |                               this._onRealmLoaded.bind(this)); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _reloadRealm(realm) { |     _reloadRealm(realm) { | ||||||
|         if (!realm.Configured) { |         if (!realm.Configured) { | ||||||
| @@ -58,7 +54,7 @@ var Manager = new Lang.Class({ | |||||||
|         this._realms[realm.get_object_path()] = realm; |         this._realms[realm.get_object_path()] = realm; | ||||||
|  |  | ||||||
|         this._updateLoginFormat(); |         this._updateLoginFormat(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onRealmLoaded(realm, error) { |     _onRealmLoaded(realm, error) { | ||||||
|         if (error) |         if (error) | ||||||
| @@ -70,7 +66,7 @@ var Manager = new Lang.Class({ | |||||||
|             if ('Configured' in properties.deep_unpack()) |             if ('Configured' in properties.deep_unpack()) | ||||||
|                 this._reloadRealm(realm); |                 this._reloadRealm(realm); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateLoginFormat() { |     _updateLoginFormat() { | ||||||
|         let newLoginFormat; |         let newLoginFormat; | ||||||
| @@ -87,7 +83,7 @@ var Manager = new Lang.Class({ | |||||||
|             this._loginFormat = newLoginFormat; |             this._loginFormat = newLoginFormat; | ||||||
|             this.emit('login-format-changed', newLoginFormat); |             this.emit('login-format-changed', newLoginFormat); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get loginFormat() { |     get loginFormat() { | ||||||
|         if (this._loginFormat !== undefined) |         if (this._loginFormat !== undefined) | ||||||
| @@ -96,7 +92,7 @@ var Manager = new Lang.Class({ | |||||||
|         this._updateLoginFormat(); |         this._updateLoginFormat(); | ||||||
|  |  | ||||||
|         return this._loginFormat; |         return this._loginFormat; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     release() { |     release() { | ||||||
|         Service(Gio.DBus.system, |         Service(Gio.DBus.system, | ||||||
| @@ -107,5 +103,5 @@ var Manager = new Lang.Class({ | |||||||
|         this._realms = { }; |         this._realms = { }; | ||||||
|         this._updateLoginFormat(); |         this._updateLoginFormat(); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(Manager.prototype) | Signals.addSignalMethods(Manager.prototype) | ||||||
|   | |||||||
| @@ -1,19 +1,13 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Clutter = imports.gi.Clutter; | const { Clutter, Gio, GLib } = imports.gi; | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const GLib = imports.gi.GLib; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Mainloop = imports.mainloop; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
| const St = imports.gi.St; |  | ||||||
|  |  | ||||||
| const Batch = imports.gdm.batch; | const Batch = imports.gdm.batch; | ||||||
| const Fprint = imports.gdm.fingerprint; | const Fprint = imports.gdm.fingerprint; | ||||||
| const OVirt = imports.gdm.oVirt; | const OVirt = imports.gdm.oVirt; | ||||||
| const Main = imports.ui.main; | const Main = imports.ui.main; | ||||||
| const Params = imports.misc.params; | const Params = imports.misc.params; | ||||||
| const ShellEntry = imports.ui.shellEntry; |  | ||||||
| const SmartcardManager = imports.misc.smartcardManager; | const SmartcardManager = imports.misc.smartcardManager; | ||||||
| const Tweener = imports.ui.tweener; | const Tweener = imports.ui.tweener; | ||||||
|  |  | ||||||
| @@ -119,10 +113,8 @@ function cloneAndFadeOutActor(actor) { | |||||||
|     return hold; |     return hold; | ||||||
| } | } | ||||||
|  |  | ||||||
| var ShellUserVerifier = new Lang.Class({ | var ShellUserVerifier = class { | ||||||
|     Name: 'ShellUserVerifier', |     constructor(client, params) { | ||||||
|  |  | ||||||
|     _init(client, params) { |  | ||||||
|         params = Params.parse(params, { reauthenticationOnly: false }); |         params = Params.parse(params, { reauthenticationOnly: false }); | ||||||
|         this._reauthOnly = params.reauthenticationOnly; |         this._reauthOnly = params.reauthenticationOnly; | ||||||
|  |  | ||||||
| @@ -165,7 +157,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._oVirtUserAuthenticatedId = this._oVirtCredentialsManager.connect('user-authenticated', |         this._oVirtUserAuthenticatedId = this._oVirtCredentialsManager.connect('user-authenticated', | ||||||
|                                                                                this._oVirtUserAuthenticated.bind(this)); |                                                                                this._oVirtUserAuthenticated.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     begin(userName, hold) { |     begin(userName, hold) { | ||||||
|         this._cancellable = new Gio.Cancellable(); |         this._cancellable = new Gio.Cancellable(); | ||||||
| @@ -183,7 +175,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|         } else { |         } else { | ||||||
|             this._client.get_user_verifier(this._cancellable, this._userVerifierGot.bind(this)); |             this._client.get_user_verifier(this._cancellable, this._userVerifierGot.bind(this)); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     cancel() { |     cancel() { | ||||||
|         if (this._cancellable) |         if (this._cancellable) | ||||||
| @@ -193,14 +185,14 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|             this._userVerifier.call_cancel_sync(null); |             this._userVerifier.call_cancel_sync(null); | ||||||
|             this.clear(); |             this.clear(); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _clearUserVerifier() { |     _clearUserVerifier() { | ||||||
|         if (this._userVerifier) { |         if (this._userVerifier) { | ||||||
|             this._userVerifier.run_dispose(); |             this._userVerifier.run_dispose(); | ||||||
|             this._userVerifier = null; |             this._userVerifier = null; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     clear() { |     clear() { | ||||||
|         if (this._cancellable) { |         if (this._cancellable) { | ||||||
| @@ -210,7 +202,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._clearUserVerifier(); |         this._clearUserVerifier(); | ||||||
|         this._clearMessageQueue(); |         this._clearMessageQueue(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     destroy() { |     destroy() { | ||||||
|         this.clear(); |         this.clear(); | ||||||
| @@ -224,7 +216,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._oVirtCredentialsManager.disconnect(this._oVirtUserAuthenticatedId); |         this._oVirtCredentialsManager.disconnect(this._oVirtUserAuthenticatedId); | ||||||
|         this._oVirtCredentialsManager = null; |         this._oVirtCredentialsManager = null; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     answerQuery(serviceName, answer) { |     answerQuery(serviceName, answer) { | ||||||
|         if (!this.hasPendingMessages) { |         if (!this.hasPendingMessages) { | ||||||
| @@ -235,12 +227,12 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|                 this._userVerifier.call_answer_query(serviceName, answer, this._cancellable, null); |                 this._userVerifier.call_answer_query(serviceName, answer, this._cancellable, null); | ||||||
|             }); |             }); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _getIntervalForMessage(message) { |     _getIntervalForMessage(message) { | ||||||
|         // We probably could be smarter here |         // We probably could be smarter here | ||||||
|         return message.length * USER_READ_TIME; |         return message.length * USER_READ_TIME; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     finishMessageQueue() { |     finishMessageQueue() { | ||||||
|         if (!this.hasPendingMessages) |         if (!this.hasPendingMessages) | ||||||
| @@ -250,7 +242,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|  |  | ||||||
|         this.hasPendingMessages = false; |         this.hasPendingMessages = false; | ||||||
|         this.emit('no-more-messages'); |         this.emit('no-more-messages'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _queueMessageTimeout() { |     _queueMessageTimeout() { | ||||||
|         if (this._messageQueue.length == 0) { |         if (this._messageQueue.length == 0) { | ||||||
| @@ -273,7 +265,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|                                                            return GLib.SOURCE_REMOVE; |                                                            return GLib.SOURCE_REMOVE; | ||||||
|                                                        }); |                                                        }); | ||||||
|         GLib.Source.set_name_by_id(this._messageQueueTimeoutId, '[gnome-shell] this._queueMessageTimeout'); |         GLib.Source.set_name_by_id(this._messageQueueTimeoutId, '[gnome-shell] this._queueMessageTimeout'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _queueMessage(message, messageType) { |     _queueMessage(message, messageType) { | ||||||
|         let interval = this._getIntervalForMessage(message); |         let interval = this._getIntervalForMessage(message); | ||||||
| @@ -281,7 +273,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|         this.hasPendingMessages = true; |         this.hasPendingMessages = true; | ||||||
|         this._messageQueue.push({ text: message, type: messageType, interval: interval }); |         this._messageQueue.push({ text: message, type: messageType, interval: interval }); | ||||||
|         this._queueMessageTimeout(); |         this._queueMessageTimeout(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _clearMessageQueue() { |     _clearMessageQueue() { | ||||||
|         this.finishMessageQueue(); |         this.finishMessageQueue(); | ||||||
| @@ -291,7 +283,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|             this._messageQueueTimeoutId = 0; |             this._messageQueueTimeoutId = 0; | ||||||
|         } |         } | ||||||
|         this.emit('show-message', null, MessageType.NONE); |         this.emit('show-message', null, MessageType.NONE); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _checkForFingerprintReader() { |     _checkForFingerprintReader() { | ||||||
|         this._haveFingerprintReader = false; |         this._haveFingerprintReader = false; | ||||||
| @@ -309,12 +301,12 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|                     this._updateDefaultService(); |                     this._updateDefaultService(); | ||||||
|                 } |                 } | ||||||
|             }); |             }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _oVirtUserAuthenticated(token) { |     _oVirtUserAuthenticated(token) { | ||||||
|         this._preemptingService = OVIRT_SERVICE_NAME; |         this._preemptingService = OVIRT_SERVICE_NAME; | ||||||
|         this.emit('ovirt-user-authenticated'); |         this.emit('ovirt-user-authenticated'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _checkForSmartcard() { |     _checkForSmartcard() { | ||||||
|         let smartcardDetected; |         let smartcardDetected; | ||||||
| @@ -336,7 +328,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|  |  | ||||||
|             this.emit('smartcard-status-changed'); |             this.emit('smartcard-status-changed'); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _reportInitError(where, error) { |     _reportInitError(where, error) { | ||||||
|         logError(error, where); |         logError(error, where); | ||||||
| @@ -344,7 +336,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._queueMessage(_("Authentication error"), MessageType.ERROR); |         this._queueMessage(_("Authentication error"), MessageType.ERROR); | ||||||
|         this._verificationFailed(false); |         this._verificationFailed(false); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _reauthenticationChannelOpened(client, result) { |     _reauthenticationChannelOpened(client, result) { | ||||||
|         try { |         try { | ||||||
| @@ -371,7 +363,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|         this._connectSignals(); |         this._connectSignals(); | ||||||
|         this._beginVerification(); |         this._beginVerification(); | ||||||
|         this._hold.release(); |         this._hold.release(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _userVerifierGot(client, result) { |     _userVerifierGot(client, result) { | ||||||
|         try { |         try { | ||||||
| @@ -387,7 +379,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|         this._connectSignals(); |         this._connectSignals(); | ||||||
|         this._beginVerification(); |         this._beginVerification(); | ||||||
|         this._hold.release(); |         this._hold.release(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _connectSignals() { |     _connectSignals() { | ||||||
|         this._userVerifier.connect('info', this._onInfo.bind(this)); |         this._userVerifier.connect('info', this._onInfo.bind(this)); | ||||||
| @@ -397,22 +389,22 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|         this._userVerifier.connect('conversation-stopped', this._onConversationStopped.bind(this)); |         this._userVerifier.connect('conversation-stopped', this._onConversationStopped.bind(this)); | ||||||
|         this._userVerifier.connect('reset', this._onReset.bind(this)); |         this._userVerifier.connect('reset', this._onReset.bind(this)); | ||||||
|         this._userVerifier.connect('verification-complete', this._onVerificationComplete.bind(this)); |         this._userVerifier.connect('verification-complete', this._onVerificationComplete.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _getForegroundService() { |     _getForegroundService() { | ||||||
|         if (this._preemptingService) |         if (this._preemptingService) | ||||||
|             return this._preemptingService; |             return this._preemptingService; | ||||||
|  |  | ||||||
|         return this._defaultService; |         return this._defaultService; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     serviceIsForeground(serviceName) { |     serviceIsForeground(serviceName) { | ||||||
|         return serviceName == this._getForegroundService(); |         return serviceName == this._getForegroundService(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     serviceIsDefault(serviceName) { |     serviceIsDefault(serviceName) { | ||||||
|         return serviceName == this._defaultService; |         return serviceName == this._defaultService; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateDefaultService() { |     _updateDefaultService() { | ||||||
|         if (this._settings.get_boolean(PASSWORD_AUTHENTICATION_KEY)) |         if (this._settings.get_boolean(PASSWORD_AUTHENTICATION_KEY)) | ||||||
| @@ -426,7 +418,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|             log("no authentication service is enabled, using password authentication"); |             log("no authentication service is enabled, using password authentication"); | ||||||
|             this._defaultService = PASSWORD_SERVICE_NAME; |             this._defaultService = PASSWORD_SERVICE_NAME; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _startService(serviceName) { |     _startService(serviceName) { | ||||||
|         this._hold.acquire(); |         this._hold.acquire(); | ||||||
| @@ -462,14 +454,14 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|                this._hold.release(); |                this._hold.release(); | ||||||
|            }); |            }); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _beginVerification() { |     _beginVerification() { | ||||||
|         this._startService(this._getForegroundService()); |         this._startService(this._getForegroundService()); | ||||||
|  |  | ||||||
|         if (this._userName && this._haveFingerprintReader && !this.serviceIsForeground(FINGERPRINT_SERVICE_NAME)) |         if (this._userName && this._haveFingerprintReader && !this.serviceIsForeground(FINGERPRINT_SERVICE_NAME)) | ||||||
|             this._startService(FINGERPRINT_SERVICE_NAME); |             this._startService(FINGERPRINT_SERVICE_NAME); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onInfo(client, serviceName, info) { |     _onInfo(client, serviceName, info) { | ||||||
|         if (this.serviceIsForeground(serviceName)) { |         if (this.serviceIsForeground(serviceName)) { | ||||||
| @@ -484,21 +476,21 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|             // to indicate the user can swipe their finger instead |             // to indicate the user can swipe their finger instead | ||||||
|             this._queueMessage(_("(or swipe finger)"), MessageType.HINT); |             this._queueMessage(_("(or swipe finger)"), MessageType.HINT); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onProblem(client, serviceName, problem) { |     _onProblem(client, serviceName, problem) { | ||||||
|         if (!this.serviceIsForeground(serviceName)) |         if (!this.serviceIsForeground(serviceName)) | ||||||
|             return; |             return; | ||||||
|  |  | ||||||
|         this._queueMessage(problem, MessageType.ERROR); |         this._queueMessage(problem, MessageType.ERROR); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onInfoQuery(client, serviceName, question) { |     _onInfoQuery(client, serviceName, question) { | ||||||
|         if (!this.serviceIsForeground(serviceName)) |         if (!this.serviceIsForeground(serviceName)) | ||||||
|             return; |             return; | ||||||
|  |  | ||||||
|         this.emit('ask-question', serviceName, question, ''); |         this.emit('ask-question', serviceName, question, ''); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onSecretInfoQuery(client, serviceName, secretQuestion) { |     _onSecretInfoQuery(client, serviceName, secretQuestion) { | ||||||
|         if (!this.serviceIsForeground(serviceName)) |         if (!this.serviceIsForeground(serviceName)) | ||||||
| @@ -511,7 +503,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this.emit('ask-question', serviceName, secretQuestion, '\u25cf'); |         this.emit('ask-question', serviceName, secretQuestion, '\u25cf'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onReset() { |     _onReset() { | ||||||
|         // Clear previous attempts to authenticate |         // Clear previous attempts to authenticate | ||||||
| @@ -519,20 +511,20 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|         this._updateDefaultService(); |         this._updateDefaultService(); | ||||||
|  |  | ||||||
|         this.emit('reset'); |         this.emit('reset'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onVerificationComplete() { |     _onVerificationComplete() { | ||||||
|         this.emit('verification-complete'); |         this.emit('verification-complete'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _cancelAndReset() { |     _cancelAndReset() { | ||||||
|         this.cancel(); |         this.cancel(); | ||||||
|         this._onReset(); |         this._onReset(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _retry() { |     _retry() { | ||||||
|         this.begin(this._userName, new Batch.Hold()); |         this.begin(this._userName, new Batch.Hold()); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _verificationFailed(retry) { |     _verificationFailed(retry) { | ||||||
|         // For Not Listed / enterprise logins, immediately reset |         // For Not Listed / enterprise logins, immediately reset | ||||||
| @@ -567,7 +559,7 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this.emit('verification-failed', canRetry); |         this.emit('verification-failed', canRetry); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onConversationStopped(client, serviceName) { |     _onConversationStopped(client, serviceName) { | ||||||
|         // If the login failed with the preauthenticated oVirt credentials |         // If the login failed with the preauthenticated oVirt credentials | ||||||
| @@ -586,6 +578,6 @@ var ShellUserVerifier = new Lang.Class({ | |||||||
|         if (this.serviceIsForeground(serviceName)) { |         if (this.serviceIsForeground(serviceName)) { | ||||||
|             this._verificationFailed(true); |             this._verificationFailed(true); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(ShellUserVerifier.prototype); | Signals.addSignalMethods(ShellUserVerifier.prototype); | ||||||
|   | |||||||
| @@ -16,6 +16,7 @@ | |||||||
|     <file>misc/history.js</file> |     <file>misc/history.js</file> | ||||||
|     <file>misc/ibusManager.js</file> |     <file>misc/ibusManager.js</file> | ||||||
|     <file>misc/inputMethod.js</file> |     <file>misc/inputMethod.js</file> | ||||||
|  |     <file>misc/introspect.js</file> | ||||||
|     <file>misc/jsParse.js</file> |     <file>misc/jsParse.js</file> | ||||||
|     <file>misc/keyboardManager.js</file> |     <file>misc/keyboardManager.js</file> | ||||||
|     <file>misc/loginManager.js</file> |     <file>misc/loginManager.js</file> | ||||||
| @@ -63,6 +64,7 @@ | |||||||
|     <file>ui/keyboard.js</file> |     <file>ui/keyboard.js</file> | ||||||
|     <file>ui/layout.js</file> |     <file>ui/layout.js</file> | ||||||
|     <file>ui/lightbox.js</file> |     <file>ui/lightbox.js</file> | ||||||
|  |     <file>ui/locatePointer.js</file> | ||||||
|     <file>ui/lookingGlass.js</file> |     <file>ui/lookingGlass.js</file> | ||||||
|     <file>ui/magnifier.js</file> |     <file>ui/magnifier.js</file> | ||||||
|     <file>ui/magnifierDBus.js</file> |     <file>ui/magnifierDBus.js</file> | ||||||
| @@ -77,12 +79,14 @@ | |||||||
|     <file>ui/overview.js</file> |     <file>ui/overview.js</file> | ||||||
|     <file>ui/overviewControls.js</file> |     <file>ui/overviewControls.js</file> | ||||||
|     <file>ui/padOsd.js</file> |     <file>ui/padOsd.js</file> | ||||||
|  |     <file>ui/pageIndicators.js</file> | ||||||
|     <file>ui/panel.js</file> |     <file>ui/panel.js</file> | ||||||
|     <file>ui/panelMenu.js</file> |     <file>ui/panelMenu.js</file> | ||||||
|  |     <file>ui/pointerA11yTimeout.js</file> | ||||||
|     <file>ui/pointerWatcher.js</file> |     <file>ui/pointerWatcher.js</file> | ||||||
|     <file>ui/popupMenu.js</file> |     <file>ui/popupMenu.js</file> | ||||||
|     <file>ui/remoteMenu.js</file> |  | ||||||
|     <file>ui/remoteSearch.js</file> |     <file>ui/remoteSearch.js</file> | ||||||
|  |     <file>ui/ripples.js</file> | ||||||
|     <file>ui/runDialog.js</file> |     <file>ui/runDialog.js</file> | ||||||
|     <file>ui/screenShield.js</file> |     <file>ui/screenShield.js</file> | ||||||
|     <file>ui/screencast.js</file> |     <file>ui/screencast.js</file> | ||||||
| @@ -119,6 +123,7 @@ | |||||||
|  |  | ||||||
|     <file>ui/status/accessibility.js</file> |     <file>ui/status/accessibility.js</file> | ||||||
|     <file>ui/status/brightness.js</file> |     <file>ui/status/brightness.js</file> | ||||||
|  |     <file>ui/status/dwellClick.js</file> | ||||||
|     <file>ui/status/location.js</file> |     <file>ui/status/location.js</file> | ||||||
|     <file>ui/status/keyboard.js</file> |     <file>ui/status/keyboard.js</file> | ||||||
|     <file>ui/status/nightLight.js</file> |     <file>ui/status/nightLight.js</file> | ||||||
|   | |||||||
| @@ -3,7 +3,7 @@ | |||||||
| // Common utils for the extension system and the extension | // Common utils for the extension system and the extension | ||||||
| // preferences tool | // preferences tool | ||||||
|  |  | ||||||
| const Lang = imports.lang; | const Gettext = imports.gettext; | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
|  |  | ||||||
| const Gio = imports.gi.Gio; | const Gio = imports.gi.Gio; | ||||||
| @@ -64,6 +64,66 @@ function getCurrentExtension() { | |||||||
|     return null; |     return null; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * initTranslations: | ||||||
|  |  * @domain: (optional): the gettext domain to use | ||||||
|  |  * | ||||||
|  |  * Initialize Gettext to load translations from extensionsdir/locale. | ||||||
|  |  * If @domain is not provided, it will be taken from metadata['gettext-domain'] | ||||||
|  |  */ | ||||||
|  | function initTranslations(domain) { | ||||||
|  |     let extension = getCurrentExtension(); | ||||||
|  |  | ||||||
|  |     if (!extension) | ||||||
|  |         throw new Error('initTranslations() can only be called from extensions'); | ||||||
|  |  | ||||||
|  |     domain = domain || extension.metadata['gettext-domain']; | ||||||
|  |  | ||||||
|  |     // Expect USER extensions to have a locale/ subfolder, otherwise assume a | ||||||
|  |     // SYSTEM extension that has been installed in the same prefix as the shell | ||||||
|  |     let localeDir = extension.dir.get_child('locale'); | ||||||
|  |     if (localeDir.query_exists(null)) | ||||||
|  |         Gettext.bindtextdomain(domain, localeDir.get_path()); | ||||||
|  |     else | ||||||
|  |         Gettext.bindtextdomain(domain, Config.LOCALEDIR); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * getSettings: | ||||||
|  |  * @schema: (optional): the GSettings schema id | ||||||
|  |  * | ||||||
|  |  * Builds and returns a GSettings schema for @schema, using schema files | ||||||
|  |  * in extensionsdir/schemas. If @schema is omitted, it is taken from | ||||||
|  |  * metadata['settings-schema']. | ||||||
|  |  */ | ||||||
|  | function getSettings(schema) { | ||||||
|  |     let extension = getCurrentExtension(); | ||||||
|  |  | ||||||
|  |     if (!extension) | ||||||
|  |         throw new Error('getSettings() can only be called from extensions'); | ||||||
|  |  | ||||||
|  |     schema = schema || extension.metadata['settings-schema']; | ||||||
|  |  | ||||||
|  |     const GioSSS = Gio.SettingsSchemaSource; | ||||||
|  |  | ||||||
|  |     // Expect USER extensions to have a schemas/ subfolder, otherwise assume a | ||||||
|  |     // SYSTEM extension that has been installed in the same prefix as the shell | ||||||
|  |     let schemaDir = extension.dir.get_child('schemas'); | ||||||
|  |     let schemaSource; | ||||||
|  |     if (schemaDir.query_exists(null)) | ||||||
|  |         schemaSource = GioSSS.new_from_directory(schemaDir.get_path(), | ||||||
|  |                                                  GioSSS.get_default(), | ||||||
|  |                                                  false); | ||||||
|  |     else | ||||||
|  |         schemaSource = GioSSS.get_default(); | ||||||
|  |  | ||||||
|  |     let schemaObj = schemaSource.lookup(schema, true); | ||||||
|  |     if (!schemaObj) | ||||||
|  |         throw new Error(`Schema ${schema} could not be found for extension ${extension.metadata.uuid}. Please check your installation`); | ||||||
|  |  | ||||||
|  |     return new Gio.Settings({ settings_schema: schemaObj }); | ||||||
|  | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * versionCheck: |  * versionCheck: | ||||||
|  * @required: an array of versions we're compatible with |  * @required: an array of versions we're compatible with | ||||||
| @@ -160,9 +220,7 @@ function installImporter(extension) { | |||||||
|     imports.searchPath = oldSearchPath; |     imports.searchPath = oldSearchPath; | ||||||
| } | } | ||||||
|  |  | ||||||
| var ExtensionFinder = new Lang.Class({ | var ExtensionFinder = class { | ||||||
|     Name: 'ExtensionFinder', |  | ||||||
|  |  | ||||||
|     _loadExtension(extensionDir, info, perUserDir) { |     _loadExtension(extensionDir, info, perUserDir) { | ||||||
|         let fileType = info.get_file_type(); |         let fileType = info.get_file_type(); | ||||||
|         if (fileType != Gio.FileType.DIRECTORY) |         if (fileType != Gio.FileType.DIRECTORY) | ||||||
| @@ -184,7 +242,7 @@ var ExtensionFinder = new Lang.Class({ | |||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         this.emit('extension-found', extension); |         this.emit('extension-found', extension); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     scanExtensions() { |     scanExtensions() { | ||||||
|         let perUserDir = Gio.File.new_for_path(global.userdatadir); |         let perUserDir = Gio.File.new_for_path(global.userdatadir); | ||||||
| @@ -192,5 +250,5 @@ var ExtensionFinder = new Lang.Class({ | |||||||
|             this._loadExtension(dir, info, perUserDir); |             this._loadExtension(dir, info, perUserDir); | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(ExtensionFinder.prototype); | Signals.addSignalMethods(ExtensionFinder.prototype); | ||||||
|   | |||||||
| @@ -1,10 +1,7 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Gio = imports.gi.Gio; | const { Gio, GLib } = imports.gi; | ||||||
| const GLib = imports.gi.GLib; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Config = imports.misc.config; | const Config = imports.misc.config; | ||||||
| const Params = imports.misc.params; |  | ||||||
|  |  | ||||||
| function collectFromDatadirs(subdir, includeUserDir, processFile) { | function collectFromDatadirs(subdir, includeUserDir, processFile) { | ||||||
|     let dataDirs = GLib.get_system_data_dirs(); |     let dataDirs = GLib.get_system_data_dirs(); | ||||||
|   | |||||||
| @@ -1,8 +1,6 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Gio = imports.gi.Gio; | const Gio = imports.gi.Gio; | ||||||
| const Lang = imports.lang; |  | ||||||
| const Signals = imports.signals; |  | ||||||
|  |  | ||||||
| const { loadInterfaceXML } = imports.misc.fileUtils; | const { loadInterfaceXML } = imports.misc.fileUtils; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,16 +1,13 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
| const Clutter = imports.gi.Clutter; | const Clutter = imports.gi.Clutter; | ||||||
| const Params = imports.misc.params; | const Params = imports.misc.params; | ||||||
|  |  | ||||||
| var DEFAULT_LIMIT = 512; | var DEFAULT_LIMIT = 512; | ||||||
|  |  | ||||||
| var HistoryManager = new Lang.Class({ | var HistoryManager = class { | ||||||
|     Name: 'HistoryManager', |     constructor(params) { | ||||||
|  |  | ||||||
|     _init(params) { |  | ||||||
|         params = Params.parse(params, { gsettingsKey: null, |         params = Params.parse(params, { gsettingsKey: null, | ||||||
|                                         limit: DEFAULT_LIMIT, |                                         limit: DEFAULT_LIMIT, | ||||||
|                                         entry: null }); |                                         entry: null }); | ||||||
| @@ -34,12 +31,12 @@ var HistoryManager = new Lang.Class({ | |||||||
|             this._entry.connect('key-press-event',  |             this._entry.connect('key-press-event',  | ||||||
|                                 this._onEntryKeyPress.bind(this)); |                                 this._onEntryKeyPress.bind(this)); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _historyChanged() { |     _historyChanged() { | ||||||
|         this._history = global.settings.get_strv(this._key); |         this._history = global.settings.get_strv(this._key); | ||||||
|         this._historyIndex = this._history.length; |         this._historyIndex = this._history.length; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _setPrevItem(text) { |     _setPrevItem(text) { | ||||||
|         if (this._historyIndex <= 0) |         if (this._historyIndex <= 0) | ||||||
| @@ -50,7 +47,7 @@ var HistoryManager = new Lang.Class({ | |||||||
|         this._historyIndex--; |         this._historyIndex--; | ||||||
|         this._indexChanged(); |         this._indexChanged(); | ||||||
|         return true; |         return true; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _setNextItem(text) { |     _setNextItem(text) { | ||||||
|         if (this._historyIndex >= this._history.length) |         if (this._historyIndex >= this._history.length) | ||||||
| @@ -61,7 +58,7 @@ var HistoryManager = new Lang.Class({ | |||||||
|         this._historyIndex++; |         this._historyIndex++; | ||||||
|         this._indexChanged(); |         this._indexChanged(); | ||||||
|         return true; |         return true; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     lastItem() { |     lastItem() { | ||||||
|         if (this._historyIndex != this._history.length) { |         if (this._historyIndex != this._history.length) { | ||||||
| @@ -70,7 +67,7 @@ var HistoryManager = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         return this._historyIndex ? this._history[this._historyIndex -1] : null; |         return this._historyIndex ? this._history[this._historyIndex -1] : null; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     addItem(input) { |     addItem(input) { | ||||||
|         if (this._history.length == 0 || |         if (this._history.length == 0 || | ||||||
| @@ -81,7 +78,7 @@ var HistoryManager = new Lang.Class({ | |||||||
|             this._save(); |             this._save(); | ||||||
|         } |         } | ||||||
|         this._historyIndex = this._history.length; |         this._historyIndex = this._history.length; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onEntryKeyPress(entry, event) { |     _onEntryKeyPress(entry, event) { | ||||||
|         let symbol = event.get_key_symbol(); |         let symbol = event.get_key_symbol(); | ||||||
| @@ -91,7 +88,7 @@ var HistoryManager = new Lang.Class({ | |||||||
|             return this._setNextItem(entry.get_text()); |             return this._setNextItem(entry.get_text()); | ||||||
|         } |         } | ||||||
|         return Clutter.EVENT_PROPAGATE; |         return Clutter.EVENT_PROPAGATE; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _indexChanged() { |     _indexChanged() { | ||||||
|         let current = this._history[this._historyIndex] || ''; |         let current = this._history[this._historyIndex] || ''; | ||||||
| @@ -99,7 +96,7 @@ var HistoryManager = new Lang.Class({ | |||||||
|  |  | ||||||
|         if (this._entry) |         if (this._entry) | ||||||
|             this._entry.set_text(current); |             this._entry.set_text(current); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _save() { |     _save() { | ||||||
|         if (this._history.length > this._limit) |         if (this._history.length > this._limit) | ||||||
| @@ -108,5 +105,5 @@ var HistoryManager = new Lang.Class({ | |||||||
|         if (this._key) |         if (this._key) | ||||||
|             global.settings.set_strv(this._key, this._history); |             global.settings.set_strv(this._key, this._history); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(HistoryManager.prototype); | Signals.addSignalMethods(HistoryManager.prototype); | ||||||
|   | |||||||
| @@ -1,12 +1,9 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Gio = imports.gi.Gio; | const { Gio, GLib, IBus } = imports.gi; | ||||||
| const GLib = imports.gi.GLib; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Mainloop = imports.mainloop; | const Mainloop = imports.mainloop; | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
|  |  | ||||||
| const IBus = imports.gi.IBus; |  | ||||||
| const IBusCandidatePopup = imports.ui.ibusCandidatePopup; | const IBusCandidatePopup = imports.ui.ibusCandidatePopup; | ||||||
|  |  | ||||||
| // Ensure runtime version matches | // Ensure runtime version matches | ||||||
| @@ -32,17 +29,16 @@ function getIBusManager() { | |||||||
|     return _ibusManager; |     return _ibusManager; | ||||||
| } | } | ||||||
|  |  | ||||||
| var IBusManager = new Lang.Class({ | var IBusManager = class { | ||||||
|     Name: 'IBusManager', |     constructor() { | ||||||
|  |  | ||||||
|     // This is the longest we'll keep the keyboard frozen until an input |  | ||||||
|     // source is active. |  | ||||||
|     _MAX_INPUT_SOURCE_ACTIVATION_TIME: 4000, // ms |  | ||||||
|     _PRELOAD_ENGINES_DELAY_TIME: 30, // sec |  | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         IBus.init(); |         IBus.init(); | ||||||
|  |  | ||||||
|  |         // This is the longest we'll keep the keyboard frozen until an input | ||||||
|  |         // source is active. | ||||||
|  |         this._MAX_INPUT_SOURCE_ACTIVATION_TIME = 4000; // ms | ||||||
|  |         this._PRELOAD_ENGINES_DELAY_TIME = 30; // sec | ||||||
|  |  | ||||||
|  |  | ||||||
|         this._candidatePopup = new IBusCandidatePopup.CandidatePopup(); |         this._candidatePopup = new IBusCandidatePopup.CandidatePopup(); | ||||||
|  |  | ||||||
|         this._panelService = null; |         this._panelService = null; | ||||||
| @@ -60,7 +56,7 @@ var IBusManager = new Lang.Class({ | |||||||
|         this._ibus.connect('global-engine-changed', this._engineChanged.bind(this)); |         this._ibus.connect('global-engine-changed', this._engineChanged.bind(this)); | ||||||
|  |  | ||||||
|         this._spawn(); |         this._spawn(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _spawn() { |     _spawn() { | ||||||
|         try { |         try { | ||||||
| @@ -69,7 +65,7 @@ var IBusManager = new Lang.Class({ | |||||||
|         } catch(e) { |         } catch(e) { | ||||||
|             log('Failed to launch ibus-daemon: ' + e.message); |             log('Failed to launch ibus-daemon: ' + e.message); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _clear() { |     _clear() { | ||||||
|         if (this._panelService) |         if (this._panelService) | ||||||
| @@ -85,7 +81,7 @@ var IBusManager = new Lang.Class({ | |||||||
|         this.emit('ready', false); |         this.emit('ready', false); | ||||||
|  |  | ||||||
|         this._spawn(); |         this._spawn(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onConnected() { |     _onConnected() { | ||||||
|         this._ibus.list_engines_async(-1, null, this._initEngines.bind(this)); |         this._ibus.list_engines_async(-1, null, this._initEngines.bind(this)); | ||||||
| @@ -93,7 +89,7 @@ var IBusManager = new Lang.Class({ | |||||||
|                                       IBus.BusNameFlag.REPLACE_EXISTING, |                                       IBus.BusNameFlag.REPLACE_EXISTING, | ||||||
|                                       -1, null, |                                       -1, null, | ||||||
|                                       this._initPanelService.bind(this)); |                                       this._initPanelService.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _initEngines(ibus, result) { |     _initEngines(ibus, result) { | ||||||
|         let enginesList = this._ibus.list_engines_async_finish(result); |         let enginesList = this._ibus.list_engines_async_finish(result); | ||||||
| @@ -106,7 +102,7 @@ var IBusManager = new Lang.Class({ | |||||||
|         } else { |         } else { | ||||||
|             this._clear(); |             this._clear(); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _initPanelService(ibus, result) { |     _initPanelService(ibus, result) { | ||||||
|         let success = this._ibus.request_name_async_finish(result); |         let success = this._ibus.request_name_async_finish(result); | ||||||
| @@ -151,13 +147,13 @@ var IBusManager = new Lang.Class({ | |||||||
|         } else { |         } else { | ||||||
|             this._clear(); |             this._clear(); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateReadiness() { |     _updateReadiness() { | ||||||
|         this._ready = (Object.keys(this._engines).length > 0 && |         this._ready = (Object.keys(this._engines).length > 0 && | ||||||
|                        this._panelService != null); |                        this._panelService != null); | ||||||
|         this.emit('ready', this._ready); |         this.emit('ready', this._ready); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _engineChanged(bus, engineName) { |     _engineChanged(bus, engineName) { | ||||||
|         if (!this._ready) |         if (!this._ready) | ||||||
| @@ -178,26 +174,26 @@ var IBusManager = new Lang.Class({ | |||||||
|  |  | ||||||
|                 this.emit('properties-registered', this._currentEngineName, props); |                 this.emit('properties-registered', this._currentEngineName, props); | ||||||
|             }); |             }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateProperty(panel, prop) { |     _updateProperty(panel, prop) { | ||||||
|         this.emit('property-updated', this._currentEngineName, prop); |         this.emit('property-updated', this._currentEngineName, prop); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _setContentType(panel, purpose, hints) { |     _setContentType(panel, purpose, hints) { | ||||||
|         this.emit('set-content-type', purpose, hints); |         this.emit('set-content-type', purpose, hints); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     activateProperty(key, state) { |     activateProperty(key, state) { | ||||||
|         this._panelService.property_activate(key, state); |         this._panelService.property_activate(key, state); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getEngineDesc(id) { |     getEngineDesc(id) { | ||||||
|         if (!this._ready || !this._engines.hasOwnProperty(id)) |         if (!this._ready || !this._engines.hasOwnProperty(id)) | ||||||
|             return null; |             return null; | ||||||
|  |  | ||||||
|         return this._engines[id]; |         return this._engines[id]; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     setEngine(id, callback) { |     setEngine(id, callback) { | ||||||
|         // Send id even if id == this._currentEngineName |         // Send id even if id == this._currentEngineName | ||||||
| @@ -210,8 +206,8 @@ var IBusManager = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this._ibus.set_global_engine_async(id, this._MAX_INPUT_SOURCE_ACTIVATION_TIME, |         this._ibus.set_global_engine_async(id, this._MAX_INPUT_SOURCE_ACTIVATION_TIME, | ||||||
|                                            null, callback); |                                            null, callback || null); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     preloadEngines(ids) { |     preloadEngines(ids) { | ||||||
|         if (!this._ibus || ids.length == 0) |         if (!this._ibus || ids.length == 0) | ||||||
| @@ -233,6 +229,6 @@ var IBusManager = new Lang.Class({ | |||||||
|                                              this._preloadEnginesId = 0; |                                              this._preloadEnginesId = 0; | ||||||
|                                              return GLib.SOURCE_REMOVE; |                                              return GLib.SOURCE_REMOVE; | ||||||
|                                          }); |                                          }); | ||||||
|     }, |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(IBusManager.prototype); | Signals.addSignalMethods(IBusManager.prototype); | ||||||
|   | |||||||
| @@ -1,23 +1,21 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
| const Clutter = imports.gi.Clutter; | const { Clutter, GLib, GObject, IBus } = imports.gi; | ||||||
| const IBus = imports.gi.IBus; |  | ||||||
| const Keyboard = imports.ui.status.keyboard; | const Keyboard = imports.ui.status.keyboard; | ||||||
| const Lang = imports.lang; |  | ||||||
| const Signals = imports.signals; |  | ||||||
|  |  | ||||||
| var InputMethod = new Lang.Class({ | var HIDE_PANEL_TIME = 50; | ||||||
|     Name: 'InputMethod', |  | ||||||
|     Extends: Clutter.InputMethod, |  | ||||||
|  |  | ||||||
|  | var InputMethod = GObject.registerClass( | ||||||
|  | class InputMethod extends Clutter.InputMethod { | ||||||
|     _init() { |     _init() { | ||||||
|         this.parent(); |         super._init(); | ||||||
|         this._hints = 0; |         this._hints = 0; | ||||||
|         this._purpose = 0; |         this._purpose = 0; | ||||||
|         this._enabled = true; |  | ||||||
|         this._currentFocus = null; |         this._currentFocus = null; | ||||||
|         this._preeditStr = ''; |         this._preeditStr = ''; | ||||||
|         this._preeditPos = 0; |         this._preeditPos = 0; | ||||||
|         this._preeditVisible = false; |         this._preeditVisible = false; | ||||||
|  |         this._hidePanelId = 0; | ||||||
|         this._ibus = IBus.Bus.new_async(); |         this._ibus = IBus.Bus.new_async(); | ||||||
|         this._ibus.connect('connected', this._onConnected.bind(this)); |         this._ibus.connect('connected', this._onConnected.bind(this)); | ||||||
|         this._ibus.connect('disconnected', this._clear.bind(this)); |         this._ibus.connect('disconnected', this._clear.bind(this)); | ||||||
| @@ -30,11 +28,11 @@ var InputMethod = new Lang.Class({ | |||||||
|  |  | ||||||
|         if (this._ibus.is_connected()) |         if (this._ibus.is_connected()) | ||||||
|             this._onConnected(); |             this._onConnected(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get currentFocus() { |     get currentFocus() { | ||||||
|         return this._currentFocus; |         return this._currentFocus; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateCapabilities() { |     _updateCapabilities() { | ||||||
|         let caps = 0; |         let caps = 0; | ||||||
| @@ -49,21 +47,19 @@ var InputMethod = new Lang.Class({ | |||||||
|  |  | ||||||
|         if (this._context) |         if (this._context) | ||||||
|             this._context.set_capabilities(caps); |             this._context.set_capabilities(caps); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onSourceChanged() { |     _onSourceChanged() { | ||||||
|         this._currentSource = this._inputSourceManager.currentSource; |         this._currentSource = this._inputSourceManager.currentSource; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onConnected() { |     _onConnected() { | ||||||
|         this._ibus.create_input_context_async ('gnome-shell', -1, null, |         this._ibus.create_input_context_async ('gnome-shell', -1, null, | ||||||
|                                                this._setContext.bind(this)); |                                                this._setContext.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _setContext(bus, res) { |     _setContext(bus, res) { | ||||||
|         this._context = this._ibus.create_input_context_async_finish(res); |         this._context = this._ibus.create_input_context_async_finish(res); | ||||||
|         this._context.connect('enabled', () => { this._enabled = true }); |  | ||||||
|         this._context.connect('disabled', () => { this._enabled = false }); |  | ||||||
|         this._context.connect('commit-text', this._onCommitText.bind(this)); |         this._context.connect('commit-text', this._onCommitText.bind(this)); | ||||||
|         this._context.connect('delete-surrounding-text', this._onDeleteSurroundingText.bind(this)); |         this._context.connect('delete-surrounding-text', this._onDeleteSurroundingText.bind(this)); | ||||||
|         this._context.connect('update-preedit-text', this._onUpdatePreeditText.bind(this)); |         this._context.connect('update-preedit-text', this._onUpdatePreeditText.bind(this)); | ||||||
| @@ -72,30 +68,29 @@ var InputMethod = new Lang.Class({ | |||||||
|         this._context.connect('forward-key-event', this._onForwardKeyEvent.bind(this)); |         this._context.connect('forward-key-event', this._onForwardKeyEvent.bind(this)); | ||||||
|  |  | ||||||
|         this._updateCapabilities(); |         this._updateCapabilities(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _clear() { |     _clear() { | ||||||
|         this._context = null; |         this._context = null; | ||||||
|         this._hints = 0; |         this._hints = 0; | ||||||
|         this._purpose = 0; |         this._purpose = 0; | ||||||
|         this._enabled = false; |  | ||||||
|         this._preeditStr = '' |         this._preeditStr = '' | ||||||
|         this._preeditPos = 0; |         this._preeditPos = 0; | ||||||
|         this._preeditVisible = false; |         this._preeditVisible = false; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _emitRequestSurrounding() { |     _emitRequestSurrounding() { | ||||||
|         if (this._context.needs_surrounding_text()) |         if (this._context.needs_surrounding_text()) | ||||||
|             this.emit('request-surrounding'); |             this.emit('request-surrounding'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onCommitText(context, text) { |     _onCommitText(context, text) { | ||||||
|         this.commit(text.get_text()); |         this.commit(text.get_text()); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDeleteSurroundingText(context) { |     _onDeleteSurroundingText(context) { | ||||||
|         this.delete_surrounding(); |         this.delete_surrounding(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onUpdatePreeditText(context, text, pos, visible) { |     _onUpdatePreeditText(context, text, pos, visible) { | ||||||
|         if (text == null) |         if (text == null) | ||||||
| @@ -111,17 +106,17 @@ var InputMethod = new Lang.Class({ | |||||||
|         this._preeditStr = preedit; |         this._preeditStr = preedit; | ||||||
|         this._preeditPos = pos; |         this._preeditPos = pos; | ||||||
|         this._preeditVisible = visible; |         this._preeditVisible = visible; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onShowPreeditText(context) { |     _onShowPreeditText(context) { | ||||||
|         this._preeditVisible = true; |         this._preeditVisible = true; | ||||||
|         this.set_preedit_text(this._preeditStr, this._preeditPos); |         this.set_preedit_text(this._preeditStr, this._preeditPos); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onHidePreeditText(context) { |     _onHidePreeditText(context) { | ||||||
|         this.set_preedit_text(null, this._preeditPos); |         this.set_preedit_text(null, this._preeditPos); | ||||||
|         this._preeditVisible = false; |         this._preeditVisible = false; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onForwardKeyEvent(context, keyval, keycode, state) { |     _onForwardKeyEvent(context, keyval, keycode, state) { | ||||||
|         let press = (state & IBus.ModifierType.RELEASE_MASK) == 0; |         let press = (state & IBus.ModifierType.RELEASE_MASK) == 0; | ||||||
| @@ -135,7 +130,7 @@ var InputMethod = new Lang.Class({ | |||||||
|             time = global.display.get_current_time_roundtrip(); |             time = global.display.get_current_time_roundtrip(); | ||||||
|  |  | ||||||
|         this.forward_key(keyval, keycode + 8, state & Clutter.ModifierType.MODIFIER_MASK, time, press); |         this.forward_key(keyval, keycode + 8, state & Clutter.ModifierType.MODIFIER_MASK, time, press); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_focus_in(focus) { |     vfunc_focus_in(focus) { | ||||||
|         this._currentFocus = focus; |         this._currentFocus = focus; | ||||||
| @@ -144,7 +139,12 @@ var InputMethod = new Lang.Class({ | |||||||
|             this._updateCapabilities(); |             this._updateCapabilities(); | ||||||
|             this._emitRequestSurrounding(); |             this._emitRequestSurrounding(); | ||||||
|         } |         } | ||||||
|     }, |  | ||||||
|  |         if (this._hidePanelId) { | ||||||
|  |             GLib.source_remove(this._hidePanelId); | ||||||
|  |             this._hidePanelId = 0; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     vfunc_focus_out() { |     vfunc_focus_out() { | ||||||
|         this._currentFocus = null; |         this._currentFocus = null; | ||||||
| @@ -158,7 +158,13 @@ var InputMethod = new Lang.Class({ | |||||||
|             this.set_preedit_text(null, 0); |             this.set_preedit_text(null, 0); | ||||||
|             this._preeditStr = null; |             this._preeditStr = null; | ||||||
|         } |         } | ||||||
|     }, |  | ||||||
|  |         this._hidePanelId = GLib.timeout_add(GLib.PRIORITY_DEFAULT, HIDE_PANEL_TIME, () => { | ||||||
|  |             this.set_input_panel_state(Clutter.InputPanelState.OFF); | ||||||
|  |             this._hidePanelId = 0; | ||||||
|  |             return GLib.SOURCE_REMOVE; | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     vfunc_reset() { |     vfunc_reset() { | ||||||
|         if (this._context) { |         if (this._context) { | ||||||
| @@ -171,7 +177,7 @@ var InputMethod = new Lang.Class({ | |||||||
|             this.set_preedit_text(null, 0); |             this.set_preedit_text(null, 0); | ||||||
|             this._preeditStr = null; |             this._preeditStr = null; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_set_cursor_location(rect) { |     vfunc_set_cursor_location(rect) { | ||||||
|         if (this._context) { |         if (this._context) { | ||||||
| @@ -179,7 +185,7 @@ var InputMethod = new Lang.Class({ | |||||||
|                                               rect.get_width(), rect.get_height()); |                                               rect.get_width(), rect.get_height()); | ||||||
|             this._emitRequestSurrounding(); |             this._emitRequestSurrounding(); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_set_surrounding(text, cursor, anchor) { |     vfunc_set_surrounding(text, cursor, anchor) { | ||||||
|         if (!this._context || !text) |         if (!this._context || !text) | ||||||
| @@ -187,7 +193,7 @@ var InputMethod = new Lang.Class({ | |||||||
|  |  | ||||||
|         let ibusText = IBus.Text.new_from_string(text); |         let ibusText = IBus.Text.new_from_string(text); | ||||||
|         this._context.set_surrounding_text(ibusText, cursor, anchor); |         this._context.set_surrounding_text(ibusText, cursor, anchor); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_update_content_hints(hints) { |     vfunc_update_content_hints(hints) { | ||||||
|         let ibusHints = 0; |         let ibusHints = 0; | ||||||
| @@ -207,7 +213,7 @@ var InputMethod = new Lang.Class({ | |||||||
|         this._hints = ibusHints; |         this._hints = ibusHints; | ||||||
|         if (this._context) |         if (this._context) | ||||||
|             this._context.set_content_type(this._purpose, this._hints); |             this._context.set_content_type(this._purpose, this._hints); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_update_content_purpose(purpose) { |     vfunc_update_content_purpose(purpose) { | ||||||
|         let ibusPurpose = 0; |         let ibusPurpose = 0; | ||||||
| @@ -233,10 +239,10 @@ var InputMethod = new Lang.Class({ | |||||||
|         this._purpose = ibusPurpose; |         this._purpose = ibusPurpose; | ||||||
|         if (this._context) |         if (this._context) | ||||||
|             this._context.set_content_type(this._purpose, this._hints); |             this._context.set_content_type(this._purpose, this._hints); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_filter_key_event(event) { |     vfunc_filter_key_event(event) { | ||||||
|         if (!this._context || !this._enabled) |         if (!this._context) | ||||||
|             return false; |             return false; | ||||||
|         if (!this._currentSource) |         if (!this._currentSource) | ||||||
|             return false; |             return false; | ||||||
| @@ -260,5 +266,5 @@ var InputMethod = new Lang.Class({ | |||||||
|                                                   } |                                                   } | ||||||
|                                               }); |                                               }); | ||||||
|         return true; |         return true; | ||||||
|     }, |     } | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										172
									
								
								js/misc/introspect.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,172 @@ | |||||||
|  | const { Gio, GLib, Meta, Shell } = imports.gi; | ||||||
|  |  | ||||||
|  | const INTROSPECT_SCHEMA = 'org.gnome.shell'; | ||||||
|  | const INTROSPECT_KEY = 'introspect'; | ||||||
|  | const APP_WHITELIST = ['org.freedesktop.impl.portal.desktop.gtk']; | ||||||
|  |  | ||||||
|  | const { loadInterfaceXML } = imports.misc.fileUtils; | ||||||
|  |  | ||||||
|  | const IntrospectDBusIface = loadInterfaceXML('org.gnome.Shell.Introspect'); | ||||||
|  |  | ||||||
|  | var IntrospectService = class { | ||||||
|  |     constructor() { | ||||||
|  |         this._dbusImpl = Gio.DBusExportedObject.wrapJSObject(IntrospectDBusIface, | ||||||
|  |                                                              this); | ||||||
|  |         this._dbusImpl.export(Gio.DBus.session, '/org/gnome/Shell/Introspect'); | ||||||
|  |         Gio.DBus.session.own_name('org.gnome.Shell.Introspect', | ||||||
|  |                                   Gio.BusNameOwnerFlags.REPLACE, | ||||||
|  |                                   null, null); | ||||||
|  |  | ||||||
|  |         this._runningApplications = {}; | ||||||
|  |         this._runningApplicationsDirty = true; | ||||||
|  |         this._activeApplication = null; | ||||||
|  |         this._activeApplicationDirty = true; | ||||||
|  |  | ||||||
|  |         this._appSystem = Shell.AppSystem.get_default(); | ||||||
|  |         this._appSystem.connect('app-state-changed', | ||||||
|  |                                 () => { | ||||||
|  |                                     this._runningApplicationsDirty = true; | ||||||
|  |                                     this._syncRunningApplications(); | ||||||
|  |                                 }); | ||||||
|  |  | ||||||
|  |         this._settings = new Gio.Settings({ schema_id: INTROSPECT_SCHEMA }); | ||||||
|  |  | ||||||
|  |         let tracker = Shell.WindowTracker.get_default(); | ||||||
|  |         tracker.connect('notify::focus-app', | ||||||
|  |                         () => { | ||||||
|  |                             this._activeApplicationDirty = true; | ||||||
|  |                             this._syncRunningApplications(); | ||||||
|  |                         }); | ||||||
|  |  | ||||||
|  |         this._syncRunningApplications(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     _isStandaloneApp(app) { | ||||||
|  |         return app.get_windows().some(w => w.transient_for == null); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     _isIntrospectEnabled() { | ||||||
|  |        return this._settings.get_boolean(INTROSPECT_KEY); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     _isSenderWhitelisted(sender) { | ||||||
|  |        return APP_WHITELIST.includes(sender); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     _getSandboxedAppId(app) { | ||||||
|  |         let ids = app.get_windows().map(w => w.get_sandboxed_app_id()); | ||||||
|  |         return ids.find(id => id != null); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     _syncRunningApplications() { | ||||||
|  |         let tracker = Shell.WindowTracker.get_default(); | ||||||
|  |         let apps = this._appSystem.get_running(); | ||||||
|  |         let seatName = "seat0"; | ||||||
|  |         let newRunningApplications = {}; | ||||||
|  |  | ||||||
|  |         let newActiveApplication = null; | ||||||
|  |         let focusedApp = tracker.focus_app; | ||||||
|  |  | ||||||
|  |         for (let app of apps) { | ||||||
|  |             let appInfo = {}; | ||||||
|  |             let isAppActive = (focusedApp == app); | ||||||
|  |  | ||||||
|  |             if (!this._isStandaloneApp(app)) | ||||||
|  |                 continue; | ||||||
|  |  | ||||||
|  |             if (isAppActive) { | ||||||
|  |                 appInfo['active-on-seats'] = new GLib.Variant('as', [seatName]); | ||||||
|  |                 newActiveApplication = app.get_id(); | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             let sandboxedAppId = this._getSandboxedAppId(app); | ||||||
|  |             if (sandboxedAppId) | ||||||
|  |                 appInfo['sandboxed-app-id'] = new GLib.Variant('s', sandboxedAppId); | ||||||
|  |  | ||||||
|  |             newRunningApplications[app.get_id()] = appInfo; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (this._runningApplicationsDirty || | ||||||
|  |             (this._activeApplicationDirty && | ||||||
|  |              this._activeApplication != newActiveApplication)) { | ||||||
|  |             this._runningApplications = newRunningApplications; | ||||||
|  |             this._activeApplication = newActiveApplication; | ||||||
|  |  | ||||||
|  |             this._dbusImpl.emit_signal('RunningApplicationsChanged', null); | ||||||
|  |         } | ||||||
|  |         this._runningApplicationsDirty = false; | ||||||
|  |         this._activeApplicationDirty = false; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     _isEligibleWindow(window) { | ||||||
|  |         if (window.is_override_redirect()) | ||||||
|  |             return false; | ||||||
|  |  | ||||||
|  |         let type = window.get_window_type(); | ||||||
|  |         return (type == Meta.WindowType.NORMAL || | ||||||
|  |                 type == Meta.WindowType.DIALOG || | ||||||
|  |                 type == Meta.WindowType.MODAL_DIALOG || | ||||||
|  |                 type == Meta.WindowType.UTILITY); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     GetRunningApplicationsAsync(params, invocation) { | ||||||
|  |         if (!this._isIntrospectEnabled() && | ||||||
|  |             !this._isSenderWhitelisted(invocation.get_sender())) { | ||||||
|  |             invocation.return_error_literal(Gio.DBusError, | ||||||
|  |                                             Gio.DBusError.ACCESS_DENIED, | ||||||
|  |                                             'App introspection not allowed'); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         invocation.return_value(new GLib.Variant('(a{sa{sv}})', [this._runningApplications])); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     GetWindowsAsync(params, invocation) { | ||||||
|  |         let focusWindow = global.display.get_focus_window(); | ||||||
|  |         let apps = this._appSystem.get_running(); | ||||||
|  |         let windowsList = {}; | ||||||
|  |  | ||||||
|  |         if (!this._isIntrospectEnabled()) { | ||||||
|  |             invocation.return_error_literal(Gio.DBusError, | ||||||
|  |                                             Gio.DBusError.ACCESS_DENIED, | ||||||
|  |                                             'App introspection not allowed'); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         for (let app of apps) { | ||||||
|  |             let windows = app.get_windows(); | ||||||
|  |             for (let window of windows) { | ||||||
|  |  | ||||||
|  |                 if (!this._isEligibleWindow(window)) | ||||||
|  |                     continue; | ||||||
|  |  | ||||||
|  |                 let windowId = window.get_id(); | ||||||
|  |                 let frameRect = window.get_frame_rect(); | ||||||
|  |                 let title = window.get_title(); | ||||||
|  |                 let wmClass = window.get_wm_class(); | ||||||
|  |                 let sandboxedAppId = window.get_sandboxed_app_id(); | ||||||
|  |  | ||||||
|  |                 windowsList[windowId] = { | ||||||
|  |                     'app-id': GLib.Variant.new('s', app.get_id()), | ||||||
|  |                     'client-type': GLib.Variant.new('u', window.get_client_type()), | ||||||
|  |                     'is-hidden': GLib.Variant.new('b', window.is_hidden()), | ||||||
|  |                     'has-focus': GLib.Variant.new('b', (window == focusWindow)), | ||||||
|  |                     'width': GLib.Variant.new('u', frameRect.width), | ||||||
|  |                     'height': GLib.Variant.new('u', frameRect.height) | ||||||
|  |                 }; | ||||||
|  |  | ||||||
|  |                 // These properties may not be available for all windows: | ||||||
|  |                 if (title != null) | ||||||
|  |                     windowsList[windowId]['title'] = GLib.Variant.new('s', title); | ||||||
|  |  | ||||||
|  |                 if (wmClass != null) | ||||||
|  |                     windowsList[windowId]['wm-class'] = GLib.Variant.new('s', wmClass); | ||||||
|  |  | ||||||
|  |                 if (sandboxedAppId != null) | ||||||
|  |                     windowsList[windowId]['sandboxed-app-id'] = | ||||||
|  |                         GLib.Variant.new('s', sandboxedAppId); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         invocation.return_value(new GLib.Variant('(a{ta{sv}})', [windowsList])); | ||||||
|  |     } | ||||||
|  | }; | ||||||
| @@ -1,9 +1,6 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const GLib = imports.gi.GLib; | const { GLib, GnomeDesktop, Meta } = imports.gi; | ||||||
| const GnomeDesktop = imports.gi.GnomeDesktop; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Meta = imports.gi.Meta; |  | ||||||
|  |  | ||||||
| const Main = imports.ui.main; | const Main = imports.ui.main; | ||||||
|  |  | ||||||
| @@ -38,22 +35,20 @@ function holdKeyboard() { | |||||||
|     global.display.freeze_keyboard(global.get_current_time()); |     global.display.freeze_keyboard(global.get_current_time()); | ||||||
| } | } | ||||||
|  |  | ||||||
| var KeyboardManager = new Lang.Class({ | var KeyboardManager = class { | ||||||
|     Name: 'KeyboardManager', |     constructor() { | ||||||
|  |         // The XKB protocol doesn't allow for more that 4 layouts in a | ||||||
|  |         // keymap. Wayland doesn't impose this limit and libxkbcommon can | ||||||
|  |         // handle up to 32 layouts but since we need to support X clients | ||||||
|  |         // even as a Wayland compositor, we can't bump this. | ||||||
|  |         this.MAX_LAYOUTS_PER_GROUP = 4; | ||||||
|  |  | ||||||
|     // The XKB protocol doesn't allow for more that 4 layouts in a |  | ||||||
|     // keymap. Wayland doesn't impose this limit and libxkbcommon can |  | ||||||
|     // handle up to 32 layouts but since we need to support X clients |  | ||||||
|     // even as a Wayland compositor, we can't bump this. |  | ||||||
|     MAX_LAYOUTS_PER_GROUP: 4, |  | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         this._xkbInfo = getXkbInfo(); |         this._xkbInfo = getXkbInfo(); | ||||||
|         this._current = null; |         this._current = null; | ||||||
|         this._localeLayoutInfo = this._getLocaleLayout(); |         this._localeLayoutInfo = this._getLocaleLayout(); | ||||||
|         this._layoutInfos = {}; |         this._layoutInfos = {}; | ||||||
|         this._currentKeymap = null; |         this._currentKeymap = null; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _applyLayoutGroup(group) { |     _applyLayoutGroup(group) { | ||||||
|         let options = this._buildOptionsString(); |         let options = this._buildOptionsString(); | ||||||
| @@ -67,11 +62,11 @@ var KeyboardManager = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._currentKeymap = {layouts, variants, options}; |         this._currentKeymap = {layouts, variants, options}; | ||||||
|         Meta.get_backend().set_keymap(layouts, variants, options); |         Meta.get_backend().set_keymap(layouts, variants, options); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _applyLayoutGroupIndex(idx) { |     _applyLayoutGroupIndex(idx) { | ||||||
|         Meta.get_backend().lock_layout_group(idx); |         Meta.get_backend().lock_layout_group(idx); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     apply(id) { |     apply(id) { | ||||||
|         let info = this._layoutInfos[id]; |         let info = this._layoutInfos[id]; | ||||||
| @@ -87,7 +82,7 @@ var KeyboardManager = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this._current = info; |         this._current = info; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     reapply() { |     reapply() { | ||||||
|         if (!this._current) |         if (!this._current) | ||||||
| @@ -95,7 +90,7 @@ var KeyboardManager = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._applyLayoutGroup(this._current.group); |         this._applyLayoutGroup(this._current.group); | ||||||
|         this._applyLayoutGroupIndex(this._current.groupIndex); |         this._applyLayoutGroupIndex(this._current.groupIndex); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     setUserLayouts(ids) { |     setUserLayouts(ids) { | ||||||
|         this._current = null; |         this._current = null; | ||||||
| @@ -126,7 +121,7 @@ var KeyboardManager = new Lang.Class({ | |||||||
|  |  | ||||||
|             i += 1; |             i += 1; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _getLocaleLayout() { |     _getLocaleLayout() { | ||||||
|         let locale = GLib.get_language_names()[0]; |         let locale = GLib.get_language_names()[0]; | ||||||
| @@ -143,21 +138,21 @@ var KeyboardManager = new Lang.Class({ | |||||||
|             return { layout: _layout, variant: _variant }; |             return { layout: _layout, variant: _variant }; | ||||||
|         else |         else | ||||||
|             return { layout: DEFAULT_LAYOUT, variant: DEFAULT_VARIANT }; |             return { layout: DEFAULT_LAYOUT, variant: DEFAULT_VARIANT }; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _buildGroupStrings(_group) { |     _buildGroupStrings(_group) { | ||||||
|         let group = _group.concat(this._localeLayoutInfo); |         let group = _group.concat(this._localeLayoutInfo); | ||||||
|         let layouts = group.map(g => g.layout).join(','); |         let layouts = group.map(g => g.layout).join(','); | ||||||
|         let variants = group.map(g => g.variant).join(','); |         let variants = group.map(g => g.variant).join(','); | ||||||
|         return [layouts, variants]; |         return [layouts, variants]; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     setKeyboardOptions(options) { |     setKeyboardOptions(options) { | ||||||
|         this._xkbOptions = options; |         this._xkbOptions = options; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _buildOptionsString() { |     _buildOptionsString() { | ||||||
|         let options = this._xkbOptions.join(','); |         let options = this._xkbOptions.join(','); | ||||||
|         return options; |         return options; | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
|   | |||||||
| @@ -1,10 +1,6 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const GLib = imports.gi.GLib; | const { GLib, Gio } = imports.gi; | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Mainloop = imports.mainloop; |  | ||||||
| const Shell = imports.gi.Shell; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
|  |  | ||||||
| const { loadInterfaceXML } = imports.misc.fileUtils; | const { loadInterfaceXML } = imports.misc.fileUtils; | ||||||
| @@ -52,6 +48,28 @@ function canLock() { | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | function registerSessionWithGDM() { | ||||||
|  |     log("Registering session with GDM"); | ||||||
|  |     Gio.DBus.system.call('org.gnome.DisplayManager', | ||||||
|  |                          '/org/gnome/DisplayManager/Manager', | ||||||
|  |                          'org.gnome.DisplayManager.Manager', | ||||||
|  |                          'RegisterSession', | ||||||
|  |                          GLib.Variant.new('(a{sv})', [{}]), null, | ||||||
|  |                          Gio.DBusCallFlags.NONE, -1, null, | ||||||
|  |         (source, result) => { | ||||||
|  |             try { | ||||||
|  |                 source.call_finish(result); | ||||||
|  |             } catch (e) { | ||||||
|  |                 if (!e.matches(Gio.DBusError, Gio.DBusError.UNKNOWN_METHOD)) | ||||||
|  |                     log(`Error registering session with GDM: ${e.message}`); | ||||||
|  |                 else | ||||||
|  |                     log("Not calling RegisterSession(): method not exported, GDM too old?"); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     ); | ||||||
|  | } | ||||||
|  |  | ||||||
| let _loginManager = null; | let _loginManager = null; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -70,10 +88,8 @@ function getLoginManager() { | |||||||
|     return _loginManager; |     return _loginManager; | ||||||
| } | } | ||||||
|  |  | ||||||
| var LoginManagerSystemd = new Lang.Class({ | var LoginManagerSystemd = class { | ||||||
|     Name: 'LoginManagerSystemd', |     constructor() { | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         this._proxy = new SystemdLoginManager(Gio.DBus.system, |         this._proxy = new SystemdLoginManager(Gio.DBus.system, | ||||||
|                                               'org.freedesktop.login1', |                                               'org.freedesktop.login1', | ||||||
|                                               '/org/freedesktop/login1'); |                                               '/org/freedesktop/login1'); | ||||||
| @@ -82,7 +98,7 @@ var LoginManagerSystemd = new Lang.Class({ | |||||||
|                                                '/org/freedesktop/login1/user/self'); |                                                '/org/freedesktop/login1/user/self'); | ||||||
|         this._proxy.connectSignal('PrepareForSleep', |         this._proxy.connectSignal('PrepareForSleep', | ||||||
|                                   this._prepareForSleep.bind(this)); |                                   this._prepareForSleep.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getCurrentSessionProxy(callback) { |     getCurrentSessionProxy(callback) { | ||||||
|         if (this._currentSession) { |         if (this._currentSession) { | ||||||
| @@ -129,7 +145,7 @@ var LoginManagerSystemd = new Lang.Class({ | |||||||
|                 callback(this._currentSession); |                 callback(this._currentSession); | ||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     canSuspend(asyncCallback) { |     canSuspend(asyncCallback) { | ||||||
|         this._proxy.CanSuspendRemote((result, error) => { |         this._proxy.CanSuspendRemote((result, error) => { | ||||||
| @@ -141,7 +157,7 @@ var LoginManagerSystemd = new Lang.Class({ | |||||||
|                 asyncCallback(canSuspend, needsAuth); |                 asyncCallback(canSuspend, needsAuth); | ||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     listSessions(asyncCallback) { |     listSessions(asyncCallback) { | ||||||
|         this._proxy.ListSessionsRemote((result, error) => { |         this._proxy.ListSessionsRemote((result, error) => { | ||||||
| @@ -150,11 +166,11 @@ var LoginManagerSystemd = new Lang.Class({ | |||||||
|             else |             else | ||||||
|                 asyncCallback(result[0]); |                 asyncCallback(result[0]); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     suspend() { |     suspend() { | ||||||
|         this._proxy.SuspendRemote(true); |         this._proxy.SuspendRemote(true); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     inhibit(reason, callback) { |     inhibit(reason, callback) { | ||||||
|         let inVariant = GLib.Variant.new('(ssss)', |         let inVariant = GLib.Variant.new('(ssss)', | ||||||
| @@ -174,38 +190,36 @@ var LoginManagerSystemd = new Lang.Class({ | |||||||
|                     callback(null); |                     callback(null); | ||||||
|                 } |                 } | ||||||
|             }); |             }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _prepareForSleep(proxy, sender, [aboutToSuspend]) { |     _prepareForSleep(proxy, sender, [aboutToSuspend]) { | ||||||
|         this.emit('prepare-for-sleep', aboutToSuspend); |         this.emit('prepare-for-sleep', aboutToSuspend); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(LoginManagerSystemd.prototype); | Signals.addSignalMethods(LoginManagerSystemd.prototype); | ||||||
|  |  | ||||||
| var LoginManagerDummy = new Lang.Class({ | var LoginManagerDummy = class { | ||||||
|     Name: 'LoginManagerDummy', |  | ||||||
|  |  | ||||||
|     getCurrentSessionProxy(callback) { |     getCurrentSessionProxy(callback) { | ||||||
|         // we could return a DummySession object that fakes whatever callers |         // we could return a DummySession object that fakes whatever callers | ||||||
|         // expect (at the time of writing: connect() and connectSignal() |         // expect (at the time of writing: connect() and connectSignal() | ||||||
|         // methods), but just never calling the callback should be safer |         // methods), but just never calling the callback should be safer | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     canSuspend(asyncCallback) { |     canSuspend(asyncCallback) { | ||||||
|         asyncCallback(false, false); |         asyncCallback(false, false); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     listSessions(asyncCallback) { |     listSessions(asyncCallback) { | ||||||
|         asyncCallback([]); |         asyncCallback([]); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     suspend() { |     suspend() { | ||||||
|         this.emit('prepare-for-sleep', true); |         this.emit('prepare-for-sleep', true); | ||||||
|         this.emit('prepare-for-sleep', false); |         this.emit('prepare-for-sleep', false); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     inhibit(reason, callback) { |     inhibit(reason, callback) { | ||||||
|         callback(null); |         callback(null); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(LoginManagerDummy.prototype); | Signals.addSignalMethods(LoginManagerDummy.prototype); | ||||||
|   | |||||||
| @@ -1,8 +1,6 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Gio = imports.gi.Gio; | const { Gio, NMA } = imports.gi; | ||||||
| const Lang = imports.lang; |  | ||||||
| const NMA = imports.gi.NMA; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
|  |  | ||||||
| const { loadInterfaceXML } = imports.misc.fileUtils; | const { loadInterfaceXML } = imports.misc.fileUtils; | ||||||
| @@ -73,7 +71,7 @@ function _findProviderForMccMnc(operator_name, operator_code) { | |||||||
| // Tries to find the operator name corresponding to the given SID | // Tries to find the operator name corresponding to the given SID | ||||||
| // | // | ||||||
| function _findProviderForSid(sid) { | function _findProviderForSid(sid) { | ||||||
|     if (sid == 0) |     if (!sid) | ||||||
|         return null; |         return null; | ||||||
|  |  | ||||||
|     let mpd = _getMobileProvidersDatabase(); |     let mpd = _getMobileProvidersDatabase(); | ||||||
| @@ -100,10 +98,8 @@ const ModemGsmNetworkProxy = Gio.DBusProxy.makeProxyWrapper(ModemGsmNetworkInter | |||||||
| const ModemCdmaInterface = loadInterfaceXML('org.freedesktop.ModemManager.Modem.Cdma'); | const ModemCdmaInterface = loadInterfaceXML('org.freedesktop.ModemManager.Modem.Cdma'); | ||||||
| const ModemCdmaProxy = Gio.DBusProxy.makeProxyWrapper(ModemCdmaInterface); | const ModemCdmaProxy = Gio.DBusProxy.makeProxyWrapper(ModemCdmaInterface); | ||||||
|  |  | ||||||
| var ModemGsm = new Lang.Class({ | var ModemGsm = class { | ||||||
|     Name: 'ModemGsm', |     constructor(path) { | ||||||
|  |  | ||||||
|     _init(path) { |  | ||||||
|         this._proxy = new ModemGsmNetworkProxy(Gio.DBus.system, 'org.freedesktop.ModemManager', path); |         this._proxy = new ModemGsmNetworkProxy(Gio.DBus.system, 'org.freedesktop.ModemManager', path); | ||||||
|  |  | ||||||
|         this.signal_quality = 0; |         this.signal_quality = 0; | ||||||
| @@ -139,13 +135,11 @@ var ModemGsm = new Lang.Class({ | |||||||
|             this.emit('notify::signal-quality'); |             this.emit('notify::signal-quality'); | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(ModemGsm.prototype); | Signals.addSignalMethods(ModemGsm.prototype); | ||||||
|  |  | ||||||
| var ModemCdma = new Lang.Class({ | var ModemCdma = class { | ||||||
|     Name: 'ModemCdma', |     constructor(path) { | ||||||
|  |  | ||||||
|     _init(path) { |  | ||||||
|         this._proxy = new ModemCdmaProxy(Gio.DBus.system, 'org.freedesktop.ModemManager', path); |         this._proxy = new ModemCdmaProxy(Gio.DBus.system, 'org.freedesktop.ModemManager', path); | ||||||
|  |  | ||||||
|         this.signal_quality = 0; |         this.signal_quality = 0; | ||||||
| @@ -169,7 +163,7 @@ var ModemCdma = new Lang.Class({ | |||||||
|             } |             } | ||||||
|             this.emit('notify::signal-quality'); |             this.emit('notify::signal-quality'); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _refreshServingSystem() { |     _refreshServingSystem() { | ||||||
|         this._proxy.GetServingSystemRemote(([result], err) => { |         this._proxy.GetServingSystemRemote(([result], err) => { | ||||||
| @@ -184,7 +178,7 @@ var ModemCdma = new Lang.Class({ | |||||||
|             this.emit('notify::operator-name'); |             this.emit('notify::operator-name'); | ||||||
|         }); |         }); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(ModemCdma.prototype); | Signals.addSignalMethods(ModemCdma.prototype); | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -201,10 +195,8 @@ const BroadbandModem3gppProxy = Gio.DBusProxy.makeProxyWrapper(BroadbandModem3gp | |||||||
| const BroadbandModemCdmaInterface = loadInterfaceXML('org.freedesktop.ModemManager1.Modem.ModemCdma'); | const BroadbandModemCdmaInterface = loadInterfaceXML('org.freedesktop.ModemManager1.Modem.ModemCdma'); | ||||||
| const BroadbandModemCdmaProxy = Gio.DBusProxy.makeProxyWrapper(BroadbandModemCdmaInterface); | const BroadbandModemCdmaProxy = Gio.DBusProxy.makeProxyWrapper(BroadbandModemCdmaInterface); | ||||||
|  |  | ||||||
| var BroadbandModem = new Lang.Class({ | var BroadbandModem = class { | ||||||
|     Name: 'BroadbandModem', |     constructor(path, capabilities) { | ||||||
|  |  | ||||||
|     _init(path, capabilities) { |  | ||||||
|         this._proxy = new BroadbandModemProxy(Gio.DBus.system, 'org.freedesktop.ModemManager1', path); |         this._proxy = new BroadbandModemProxy(Gio.DBus.system, 'org.freedesktop.ModemManager1', path); | ||||||
|         this._proxy_3gpp = new BroadbandModem3gppProxy(Gio.DBus.system, 'org.freedesktop.ModemManager1', path); |         this._proxy_3gpp = new BroadbandModem3gppProxy(Gio.DBus.system, 'org.freedesktop.ModemManager1', path); | ||||||
|         this._proxy_cdma = new BroadbandModemCdmaProxy(Gio.DBus.system, 'org.freedesktop.ModemManager1', path); |         this._proxy_cdma = new BroadbandModemCdmaProxy(Gio.DBus.system, 'org.freedesktop.ModemManager1', path); | ||||||
| @@ -229,13 +221,13 @@ var BroadbandModem = new Lang.Class({ | |||||||
|                 this._reloadCdmaOperatorName(); |                 this._reloadCdmaOperatorName(); | ||||||
|         }); |         }); | ||||||
|         this._reloadCdmaOperatorName(); |         this._reloadCdmaOperatorName(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _reloadSignalQuality() { |     _reloadSignalQuality() { | ||||||
|         let [quality, recent] = this._proxy.SignalQuality; |         let [quality, recent] = this._proxy.SignalQuality; | ||||||
|         this.signal_quality = quality; |         this.signal_quality = quality; | ||||||
|         this.emit('notify::signal-quality'); |         this.emit('notify::signal-quality'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _reloadOperatorName() { |     _reloadOperatorName() { | ||||||
|         let new_name = ""; |         let new_name = ""; | ||||||
| @@ -250,19 +242,19 @@ var BroadbandModem = new Lang.Class({ | |||||||
|  |  | ||||||
|         this.operator_name = new_name; |         this.operator_name = new_name; | ||||||
|         this.emit('notify::operator-name'); |         this.emit('notify::operator-name'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _reload3gppOperatorName() { |     _reload3gppOperatorName() { | ||||||
|         let name = this._proxy_3gpp.OperatorName; |         let name = this._proxy_3gpp.OperatorName; | ||||||
|         let code = this._proxy_3gpp.OperatorCode; |         let code = this._proxy_3gpp.OperatorCode; | ||||||
|         this.operator_name_3gpp = _findProviderForMccMnc(name, code); |         this.operator_name_3gpp = _findProviderForMccMnc(name, code); | ||||||
|         this._reloadOperatorName(); |         this._reloadOperatorName(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _reloadCdmaOperatorName() { |     _reloadCdmaOperatorName() { | ||||||
|         let sid = this._proxy_cdma.Sid; |         let sid = this._proxy_cdma.Sid; | ||||||
|         this.operator_name_cdma = _findProviderForSid(sid); |         this.operator_name_cdma = _findProviderForSid(sid); | ||||||
|         this._reloadOperatorName(); |         this._reloadOperatorName(); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(BroadbandModem.prototype); | Signals.addSignalMethods(BroadbandModem.prototype); | ||||||
|   | |||||||
| @@ -1,8 +1,6 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Gio = imports.gi.Gio; | const { Gio, GLib } = imports.gi; | ||||||
| const GLib = imports.gi.GLib; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Params = imports.misc.params; | const Params = imports.misc.params; | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
|  |  | ||||||
| @@ -27,9 +25,8 @@ const ObjectManagerIface = ` | |||||||
|  |  | ||||||
| const ObjectManagerInfo = Gio.DBusInterfaceInfo.new_for_xml(ObjectManagerIface); | const ObjectManagerInfo = Gio.DBusInterfaceInfo.new_for_xml(ObjectManagerIface); | ||||||
|  |  | ||||||
| var ObjectManager = new Lang.Class({ | var ObjectManager = class { | ||||||
|     Name: 'ObjectManager', |     constructor(params) { | ||||||
|     _init(params) { |  | ||||||
|         params = Params.parse(params, { connection: null, |         params = Params.parse(params, { connection: null, | ||||||
|                                         name: null, |                                         name: null, | ||||||
|                                         objectPath: null, |                                         objectPath: null, | ||||||
| @@ -63,7 +60,7 @@ var ObjectManager = new Lang.Class({ | |||||||
|         this._managerProxy.init_async(GLib.PRIORITY_DEFAULT, |         this._managerProxy.init_async(GLib.PRIORITY_DEFAULT, | ||||||
|                                       this._cancellable, |                                       this._cancellable, | ||||||
|                                       this._onManagerProxyLoaded.bind(this)); |                                       this._onManagerProxyLoaded.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _tryToCompleteLoad() { |     _tryToCompleteLoad() { | ||||||
|         if (this._numLoadInhibitors == 0) |         if (this._numLoadInhibitors == 0) | ||||||
| @@ -74,7 +71,7 @@ var ObjectManager = new Lang.Class({ | |||||||
|             if (this._onLoaded) |             if (this._onLoaded) | ||||||
|                 this._onLoaded(); |                 this._onLoaded(); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _addInterface(objectPath, interfaceName, onFinished) { |     _addInterface(objectPath, interfaceName, onFinished) { | ||||||
|         let info = this._interfaceInfos[interfaceName]; |         let info = this._interfaceInfos[interfaceName]; | ||||||
| @@ -129,7 +126,7 @@ var ObjectManager = new Lang.Class({ | |||||||
|                if (onFinished) |                if (onFinished) | ||||||
|                    onFinished(); |                    onFinished(); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _removeInterface(objectPath, interfaceName) { |     _removeInterface(objectPath, interfaceName) { | ||||||
|         if (!this._objects[objectPath]) |         if (!this._objects[objectPath]) | ||||||
| @@ -155,14 +152,14 @@ var ObjectManager = new Lang.Class({ | |||||||
|             delete this._objects[objectPath]; |             delete this._objects[objectPath]; | ||||||
|             this.emit('object-removed', objectPath); |             this.emit('object-removed', objectPath); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onManagerProxyLoaded(initable, result) { |     _onManagerProxyLoaded(initable, result) { | ||||||
|         let error = null; |         let error = null; | ||||||
|         try { |         try { | ||||||
|             initable.init_finish(result); |             initable.init_finish(result); | ||||||
|         } catch(e) { |         } catch(e) { | ||||||
|             logError(e, 'could not initialize object manager for object ' + params.name); |             logError(e, 'could not initialize object manager for object ' + this._serviceName); | ||||||
|  |  | ||||||
|             this._tryToCompleteLoad(); |             this._tryToCompleteLoad(); | ||||||
|             return; |             return; | ||||||
| @@ -194,7 +191,7 @@ var ObjectManager = new Lang.Class({ | |||||||
|  |  | ||||||
|         if (this._managerProxy.g_name_owner) |         if (this._managerProxy.g_name_owner) | ||||||
|             this._onNameAppeared(); |             this._onNameAppeared(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onNameAppeared() { |     _onNameAppeared() { | ||||||
|         this._managerProxy.GetManagedObjectsRemote((result, error) => { |         this._managerProxy.GetManagedObjectsRemote((result, error) => { | ||||||
| @@ -232,7 +229,7 @@ var ObjectManager = new Lang.Class({ | |||||||
|             } |             } | ||||||
|             this._tryToCompleteLoad(); |             this._tryToCompleteLoad(); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onNameVanished() { |     _onNameVanished() { | ||||||
|         let objectPaths = Object.keys(this._objects); |         let objectPaths = Object.keys(this._objects); | ||||||
| @@ -248,14 +245,14 @@ var ObjectManager = new Lang.Class({ | |||||||
|                     this._removeInterface(objectPath, interfaceName); |                     this._removeInterface(objectPath, interfaceName); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _registerInterfaces(interfaces) { |     _registerInterfaces(interfaces) { | ||||||
|         for (let i = 0; i < interfaces.length; i++) { |         for (let i = 0; i < interfaces.length; i++) { | ||||||
|             let info = Gio.DBusInterfaceInfo.new_for_xml(interfaces[i]); |             let info = Gio.DBusInterfaceInfo.new_for_xml(interfaces[i]); | ||||||
|             this._interfaceInfos[info.name] = info; |             this._interfaceInfos[info.name] = info; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getProxy(objectPath, interfaceName) { |     getProxy(objectPath, interfaceName) { | ||||||
|         let object = this._objects[objectPath]; |         let object = this._objects[objectPath]; | ||||||
| @@ -264,7 +261,7 @@ var ObjectManager = new Lang.Class({ | |||||||
|             return null; |             return null; | ||||||
|  |  | ||||||
|         return object[interfaceName]; |         return object[interfaceName]; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getProxiesForInterface(interfaceName) { |     getProxiesForInterface(interfaceName) { | ||||||
|         let proxyList = this._interfaces[interfaceName]; |         let proxyList = this._interfaces[interfaceName]; | ||||||
| @@ -273,7 +270,7 @@ var ObjectManager = new Lang.Class({ | |||||||
|             return []; |             return []; | ||||||
|  |  | ||||||
|         return proxyList; |         return proxyList; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getAllProxies() { |     getAllProxies() { | ||||||
|         let proxies = []; |         let proxies = []; | ||||||
| @@ -283,8 +280,8 @@ var ObjectManager = new Lang.Class({ | |||||||
|             let object = this._objects[objectPaths]; |             let object = this._objects[objectPaths]; | ||||||
|  |  | ||||||
|             let interfaceNames = Object.keys(object); |             let interfaceNames = Object.keys(object); | ||||||
|             for (let j = 0; i < interfaceNames.length; i++) { |             for (let j = 0; j < interfaceNames.length; j++) { | ||||||
|                 let interfaceName = interfaceNames[i]; |                 let interfaceName = interfaceNames[j]; | ||||||
|                 if (object[interfaceName]) |                 if (object[interfaceName]) | ||||||
|                     proxies.push(object(interfaceName)); |                     proxies.push(object(interfaceName)); | ||||||
|             } |             } | ||||||
| @@ -292,5 +289,5 @@ var ObjectManager = new Lang.Class({ | |||||||
|  |  | ||||||
|         return proxies; |         return proxies; | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(ObjectManager.prototype); | Signals.addSignalMethods(ObjectManager.prototype); | ||||||
|   | |||||||
| @@ -1,8 +1,6 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Gio = imports.gi.Gio; | const Gio = imports.gi.Gio; | ||||||
| const Lang = imports.lang; |  | ||||||
| const Shell = imports.gi.Shell; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
|  |  | ||||||
| const ObjectManager = imports.misc.objectManager; | const ObjectManager = imports.misc.objectManager; | ||||||
| @@ -26,9 +24,8 @@ function getSmartcardManager() { | |||||||
|     return _smartcardManager; |     return _smartcardManager; | ||||||
| } | } | ||||||
|  |  | ||||||
| var SmartcardManager = new Lang.Class({ | var SmartcardManager = class { | ||||||
|     Name: 'SmartcardManager', |     constructor() { | ||||||
|     _init() { |  | ||||||
|         this._objectManager = new ObjectManager.ObjectManager({ connection: Gio.DBus.session, |         this._objectManager = new ObjectManager.ObjectManager({ connection: Gio.DBus.session, | ||||||
|                                                                 name: "org.gnome.SettingsDaemon.Smartcard", |                                                                 name: "org.gnome.SettingsDaemon.Smartcard", | ||||||
|                                                                 objectPath: '/org/gnome/SettingsDaemon/Smartcard', |                                                                 objectPath: '/org/gnome/SettingsDaemon/Smartcard', | ||||||
| @@ -36,7 +33,7 @@ var SmartcardManager = new Lang.Class({ | |||||||
|                                                                 onLoaded: this._onLoaded.bind(this) }); |                                                                 onLoaded: this._onLoaded.bind(this) }); | ||||||
|         this._insertedTokens = {}; |         this._insertedTokens = {}; | ||||||
|         this._loginToken = null; |         this._loginToken = null; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onLoaded() { |     _onLoaded() { | ||||||
|         let tokens = this._objectManager.getProxiesForInterface('org.gnome.SettingsDaemon.Smartcard.Token'); |         let tokens = this._objectManager.getProxiesForInterface('org.gnome.SettingsDaemon.Smartcard.Token'); | ||||||
| @@ -53,7 +50,7 @@ var SmartcardManager = new Lang.Class({ | |||||||
|             if (interfaceName == 'org.gnome.SettingsDaemon.Smartcard.Token') |             if (interfaceName == 'org.gnome.SettingsDaemon.Smartcard.Token') | ||||||
|                 this._removeToken(proxy); |                 this._removeToken(proxy); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateToken(token) { |     _updateToken(token) { | ||||||
|         let objectPath = token.get_object_path(); |         let objectPath = token.get_object_path(); | ||||||
| @@ -65,7 +62,7 @@ var SmartcardManager = new Lang.Class({ | |||||||
|  |  | ||||||
|         if (token.UsedToLogin) |         if (token.UsedToLogin) | ||||||
|             this._loginToken = token; |             this._loginToken = token; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _addToken(token) { |     _addToken(token) { | ||||||
|         this._updateToken(token); |         this._updateToken(token); | ||||||
| @@ -85,7 +82,7 @@ var SmartcardManager = new Lang.Class({ | |||||||
|         // Emit a smartcard-inserted at startup if it's already plugged in |         // Emit a smartcard-inserted at startup if it's already plugged in | ||||||
|         if (token.IsInserted) |         if (token.IsInserted) | ||||||
|             this.emit('smartcard-inserted', token); |             this.emit('smartcard-inserted', token); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _removeToken(token) { |     _removeToken(token) { | ||||||
|         let objectPath = token.get_object_path(); |         let objectPath = token.get_object_path(); | ||||||
| @@ -99,11 +96,11 @@ var SmartcardManager = new Lang.Class({ | |||||||
|             this._loginToken = null; |             this._loginToken = null; | ||||||
|  |  | ||||||
|         token.disconnectAll(); |         token.disconnectAll(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     hasInsertedTokens() { |     hasInsertedTokens() { | ||||||
|         return Object.keys(this._insertedTokens).length > 0; |         return Object.keys(this._insertedTokens).length > 0; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     hasInsertedLoginToken() { |     hasInsertedLoginToken() { | ||||||
|         if (!this._loginToken) |         if (!this._loginToken) | ||||||
| @@ -115,5 +112,5 @@ var SmartcardManager = new Lang.Class({ | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(SmartcardManager.prototype); | Signals.addSignalMethods(SmartcardManager.prototype); | ||||||
|   | |||||||
| @@ -1,11 +1,4 @@ | |||||||
| const AccountsService = imports.gi.AccountsService; | const { AccountsService, Clutter, Gdm, Gio, GLib, GObject, Meta } = imports.gi; | ||||||
| const Clutter = imports.gi.Clutter; |  | ||||||
| const Gdm = imports.gi.Gdm; |  | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const GLib = imports.gi.GLib; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Meta = imports.gi.Meta; |  | ||||||
| const GObject = imports.gi.GObject; |  | ||||||
|  |  | ||||||
| const GnomeSession = imports.misc.gnomeSession; | const GnomeSession = imports.misc.gnomeSession; | ||||||
| const LoginManager = imports.misc.loginManager; | const LoginManager = imports.misc.loginManager; | ||||||
| @@ -44,9 +37,7 @@ function getDefault() { | |||||||
|     return _singleton; |     return _singleton; | ||||||
| } | } | ||||||
|  |  | ||||||
| const SystemActions = new Lang.Class({ | const SystemActions = GObject.registerClass({ | ||||||
|     Name: 'SystemActions', |  | ||||||
|     Extends: GObject.Object, |  | ||||||
|     Properties: { |     Properties: { | ||||||
|         'can-power-off': GObject.ParamSpec.boolean('can-power-off', |         'can-power-off': GObject.ParamSpec.boolean('can-power-off', | ||||||
|                                                    'can-power-off', |                                                    'can-power-off', | ||||||
| @@ -83,10 +74,10 @@ const SystemActions = new Lang.Class({ | |||||||
|                                                           'orientation-lock-icon', |                                                           'orientation-lock-icon', | ||||||
|                                                           GObject.ParamFlags.READWRITE, |                                                           GObject.ParamFlags.READWRITE, | ||||||
|                                                           null) |                                                           null) | ||||||
|     }, |     } | ||||||
|  | }, class SystemActions extends GObject.Object { | ||||||
|     _init() { |     _init() { | ||||||
|         this.parent(); |         super._init(); | ||||||
|  |  | ||||||
|         this._canHavePowerOff = true; |         this._canHavePowerOff = true; | ||||||
|         this._canHaveSuspend = true; |         this._canHaveSuspend = true; | ||||||
| @@ -97,42 +88,42 @@ const SystemActions = new Lang.Class({ | |||||||
|                             name: C_("search-result", "Power Off"), |                             name: C_("search-result", "Power Off"), | ||||||
|                             iconName: 'system-shutdown-symbolic', |                             iconName: 'system-shutdown-symbolic', | ||||||
|                             // Translators: A list of keywords that match the power-off action, separated by semicolons |                             // Translators: A list of keywords that match the power-off action, separated by semicolons | ||||||
|                             keywords: _("power off;shutdown;reboot;restart").split(';'), |                             keywords: _("power off;shutdown;reboot;restart").split(/[; ]/), | ||||||
|                             available: false }); |                             available: false }); | ||||||
|         this._actions.set(LOCK_SCREEN_ACTION_ID, |         this._actions.set(LOCK_SCREEN_ACTION_ID, | ||||||
|                           { // Translators: The name of the lock screen action in search |                           { // Translators: The name of the lock screen action in search | ||||||
|                             name: C_("search-result", "Lock Screen"), |                             name: C_("search-result", "Lock Screen"), | ||||||
|                             iconName: 'system-lock-screen-symbolic', |                             iconName: 'system-lock-screen-symbolic', | ||||||
|                             // Translators: A list of keywords that match the lock screen action, separated by semicolons |                             // Translators: A list of keywords that match the lock screen action, separated by semicolons | ||||||
|                             keywords: _("lock screen").split(';'), |                             keywords: _("lock screen").split(/[; ]/), | ||||||
|                             available: false }); |                             available: false }); | ||||||
|         this._actions.set(LOGOUT_ACTION_ID, |         this._actions.set(LOGOUT_ACTION_ID, | ||||||
|                           { // Translators: The name of the logout action in search |                           { // Translators: The name of the logout action in search | ||||||
|                             name: C_("search-result", "Log Out"), |                             name: C_("search-result", "Log Out"), | ||||||
|                             iconName: 'application-exit-symbolic', |                             iconName: 'application-exit-symbolic', | ||||||
|                             // Translators: A list of keywords that match the logout action, separated by semicolons |                             // Translators: A list of keywords that match the logout action, separated by semicolons | ||||||
|                             keywords: _("logout;sign off").split(';'), |                             keywords: _("logout;log out;sign off").split(/[; ]/), | ||||||
|                             available: false }); |                             available: false }); | ||||||
|         this._actions.set(SUSPEND_ACTION_ID, |         this._actions.set(SUSPEND_ACTION_ID, | ||||||
|                           { // Translators: The name of the suspend action in search |                           { // Translators: The name of the suspend action in search | ||||||
|                             name: C_("search-result", "Suspend"), |                             name: C_("search-result", "Suspend"), | ||||||
|                             iconName: 'media-playback-pause-symbolic', |                             iconName: 'media-playback-pause-symbolic', | ||||||
|                             // Translators: A list of keywords that match the suspend action, separated by semicolons |                             // Translators: A list of keywords that match the suspend action, separated by semicolons | ||||||
|                             keywords: _("suspend;sleep").split(';'), |                             keywords: _("suspend;sleep").split(/[; ]/), | ||||||
|                             available: false }); |                             available: false }); | ||||||
|         this._actions.set(SWITCH_USER_ACTION_ID, |         this._actions.set(SWITCH_USER_ACTION_ID, | ||||||
|                           { // Translators: The name of the switch user action in search |                           { // Translators: The name of the switch user action in search | ||||||
|                             name: C_("search-result", "Switch User"), |                             name: C_("search-result", "Switch User"), | ||||||
|                             iconName: 'system-switch-user-symbolic', |                             iconName: 'system-switch-user-symbolic', | ||||||
|                             // Translators: A list of keywords that match the switch user action, separated by semicolons |                             // Translators: A list of keywords that match the switch user action, separated by semicolons | ||||||
|                             keywords: _("switch user").split(';'), |                             keywords: _("switch user").split(/[; ]/), | ||||||
|                             available: false }); |                             available: false }); | ||||||
|         this._actions.set(LOCK_ORIENTATION_ACTION_ID, |         this._actions.set(LOCK_ORIENTATION_ACTION_ID, | ||||||
|                           { // Translators: The name of the lock orientation action in search |                           { // Translators: The name of the lock orientation action in search | ||||||
|                             name: C_("search-result", "Lock Orientation"), |                             name: C_("search-result", "Lock Orientation"), | ||||||
|                             iconName: '', |                             iconName: '', | ||||||
|                             // Translators: A list of keywords that match the lock orientation action, separated by semicolons |                             // Translators: A list of keywords that match the lock orientation action, separated by semicolons | ||||||
|                             keywords: _("lock orientation;screen;rotation").split(';'), |                             keywords: _("lock orientation;screen;rotation").split(/[; ]/), | ||||||
|                             available: false }); |                             available: false }); | ||||||
|  |  | ||||||
|         this._loginScreenSettings = new Gio.Settings({ schema_id: LOGIN_SCREEN_SCHEMA }); |         this._loginScreenSettings = new Gio.Settings({ schema_id: LOGIN_SCREEN_SCHEMA }); | ||||||
| @@ -186,35 +177,35 @@ const SystemActions = new Lang.Class({ | |||||||
|  |  | ||||||
|         Main.sessionMode.connect('updated', () => { this._sessionUpdated(); }); |         Main.sessionMode.connect('updated', () => { this._sessionUpdated(); }); | ||||||
|         this._sessionUpdated(); |         this._sessionUpdated(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get can_power_off() { |     get can_power_off() { | ||||||
|         return this._actions.get(POWER_OFF_ACTION_ID).available; |         return this._actions.get(POWER_OFF_ACTION_ID).available; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get can_suspend() { |     get can_suspend() { | ||||||
|         return this._actions.get(SUSPEND_ACTION_ID).available; |         return this._actions.get(SUSPEND_ACTION_ID).available; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get can_lock_screen() { |     get can_lock_screen() { | ||||||
|         return this._actions.get(LOCK_SCREEN_ACTION_ID).available; |         return this._actions.get(LOCK_SCREEN_ACTION_ID).available; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get can_switch_user() { |     get can_switch_user() { | ||||||
|         return this._actions.get(SWITCH_USER_ACTION_ID).available; |         return this._actions.get(SWITCH_USER_ACTION_ID).available; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get can_logout() { |     get can_logout() { | ||||||
|         return this._actions.get(LOGOUT_ACTION_ID).available; |         return this._actions.get(LOGOUT_ACTION_ID).available; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get can_lock_orientation() { |     get can_lock_orientation() { | ||||||
|         return this._actions.get(LOCK_ORIENTATION_ACTION_ID).available; |         return this._actions.get(LOCK_ORIENTATION_ACTION_ID).available; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get orientation_lock_icon() { |     get orientation_lock_icon() { | ||||||
|         return this._actions.get(LOCK_ORIENTATION_ACTION_ID).iconName; |         return this._actions.get(LOCK_ORIENTATION_ACTION_ID).iconName; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _sensorProxyAppeared() { |     _sensorProxyAppeared() { | ||||||
|         this._sensorProxy = new SensorProxy(Gio.DBus.system, SENSOR_BUS_NAME, SENSOR_OBJECT_PATH, |         this._sensorProxy = new SensorProxy(Gio.DBus.system, SENSOR_BUS_NAME, SENSOR_OBJECT_PATH, | ||||||
| @@ -227,7 +218,7 @@ const SystemActions = new Lang.Class({ | |||||||
|                                           () => { this._updateOrientationLock(); }); |                                           () => { this._updateOrientationLock(); }); | ||||||
|                 this._updateOrientationLock(); |                 this._updateOrientationLock(); | ||||||
|             }); |             }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateOrientationLock() { |     _updateOrientationLock() { | ||||||
|         let available = false; |         let available = false; | ||||||
| @@ -238,7 +229,7 @@ const SystemActions = new Lang.Class({ | |||||||
|         this._actions.get(LOCK_ORIENTATION_ACTION_ID).available = available; |         this._actions.get(LOCK_ORIENTATION_ACTION_ID).available = available; | ||||||
|  |  | ||||||
|         this.notify('can-lock-orientation'); |         this.notify('can-lock-orientation'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateOrientationLockIcon() { |     _updateOrientationLockIcon() { | ||||||
|         let locked = this._orientationSettings.get_boolean('orientation-lock'); |         let locked = this._orientationSettings.get_boolean('orientation-lock'); | ||||||
| @@ -247,14 +238,14 @@ const SystemActions = new Lang.Class({ | |||||||
|         this._actions.get(LOCK_ORIENTATION_ACTION_ID).iconName = iconName; |         this._actions.get(LOCK_ORIENTATION_ACTION_ID).iconName = iconName; | ||||||
|  |  | ||||||
|         this.notify('orientation-lock-icon'); |         this.notify('orientation-lock-icon'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _sessionUpdated() { |     _sessionUpdated() { | ||||||
|         this._updateLockScreen(); |         this._updateLockScreen(); | ||||||
|         this._updatePowerOff(); |         this._updatePowerOff(); | ||||||
|         this._updateSuspend(); |         this._updateSuspend(); | ||||||
|         this._updateMultiUser(); |         this._updateMultiUser(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     forceUpdate() { |     forceUpdate() { | ||||||
|         // Whether those actions are available or not depends on both lockdown |         // Whether those actions are available or not depends on both lockdown | ||||||
| @@ -262,7 +253,7 @@ const SystemActions = new Lang.Class({ | |||||||
|         // latter, so their value may be outdated; force an update now |         // latter, so their value may be outdated; force an update now | ||||||
|         this._updateHaveShutdown(); |         this._updateHaveShutdown(); | ||||||
|         this._updateHaveSuspend(); |         this._updateHaveSuspend(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getMatchingActions(terms) { |     getMatchingActions(terms) { | ||||||
|         // terms is a list of strings |         // terms is a list of strings | ||||||
| @@ -271,19 +262,19 @@ const SystemActions = new Lang.Class({ | |||||||
|         let results = []; |         let results = []; | ||||||
|  |  | ||||||
|         for (let [key, {available, keywords}] of this._actions) |         for (let [key, {available, keywords}] of this._actions) | ||||||
|             if (available && terms.every(t => keywords.some(k => (k.indexOf(t) >= 0)))) |             if (available && terms.every(t => keywords.some(k => k.startsWith(t)))) | ||||||
|                 results.push(key); |                 results.push(key); | ||||||
|  |  | ||||||
|         return results; |         return results; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getName(id) { |     getName(id) { | ||||||
|         return this._actions.get(id).name; |         return this._actions.get(id).name; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getIconName(id) { |     getIconName(id) { | ||||||
|         return this._actions.get(id).iconName; |         return this._actions.get(id).iconName; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     activateAction(id) { |     activateAction(id) { | ||||||
|         switch (id) { |         switch (id) { | ||||||
| @@ -306,14 +297,14 @@ const SystemActions = new Lang.Class({ | |||||||
|                 this.activateLockOrientation(); |                 this.activateLockOrientation(); | ||||||
|                 break; |                 break; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateLockScreen() { |     _updateLockScreen() { | ||||||
|         let showLock = !Main.sessionMode.isLocked && !Main.sessionMode.isGreeter; |         let showLock = !Main.sessionMode.isLocked && !Main.sessionMode.isGreeter; | ||||||
|         let allowLockScreen = !this._lockdownSettings.get_boolean(DISABLE_LOCK_SCREEN_KEY); |         let allowLockScreen = !this._lockdownSettings.get_boolean(DISABLE_LOCK_SCREEN_KEY); | ||||||
|         this._actions.get(LOCK_SCREEN_ACTION_ID).available = showLock && allowLockScreen && LoginManager.canLock(); |         this._actions.get(LOCK_SCREEN_ACTION_ID).available = showLock && allowLockScreen && LoginManager.canLock(); | ||||||
|         this.notify('can-lock-screen'); |         this.notify('can-lock-screen'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateHaveShutdown() { |     _updateHaveShutdown() { | ||||||
|         this._session.CanShutdownRemote((result, error) => { |         this._session.CanShutdownRemote((result, error) => { | ||||||
| @@ -323,7 +314,7 @@ const SystemActions = new Lang.Class({ | |||||||
|             this._canHavePowerOff = result[0]; |             this._canHavePowerOff = result[0]; | ||||||
|             this._updatePowerOff(); |             this._updatePowerOff(); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updatePowerOff() { |     _updatePowerOff() { | ||||||
|         let disabled = Main.sessionMode.isLocked || |         let disabled = Main.sessionMode.isLocked || | ||||||
| @@ -331,7 +322,7 @@ const SystemActions = new Lang.Class({ | |||||||
|                         this._loginScreenSettings.get_boolean(DISABLE_RESTART_KEY)); |                         this._loginScreenSettings.get_boolean(DISABLE_RESTART_KEY)); | ||||||
|         this._actions.get(POWER_OFF_ACTION_ID).available = this._canHavePowerOff && !disabled; |         this._actions.get(POWER_OFF_ACTION_ID).available = this._canHavePowerOff && !disabled; | ||||||
|         this.notify('can-power-off'); |         this.notify('can-power-off'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateHaveSuspend() { |     _updateHaveSuspend() { | ||||||
|         this._loginManager.canSuspend( |         this._loginManager.canSuspend( | ||||||
| @@ -340,7 +331,7 @@ const SystemActions = new Lang.Class({ | |||||||
|                 this._suspendNeedsAuth = needsAuth; |                 this._suspendNeedsAuth = needsAuth; | ||||||
|                 this._updateSuspend(); |                 this._updateSuspend(); | ||||||
|             }); |             }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateSuspend() { |     _updateSuspend() { | ||||||
|         let disabled = (Main.sessionMode.isLocked && |         let disabled = (Main.sessionMode.isLocked && | ||||||
| @@ -349,12 +340,12 @@ const SystemActions = new Lang.Class({ | |||||||
|                         this._loginScreenSettings.get_boolean(DISABLE_RESTART_KEY)); |                         this._loginScreenSettings.get_boolean(DISABLE_RESTART_KEY)); | ||||||
|         this._actions.get(SUSPEND_ACTION_ID).available = this._canHaveSuspend && !disabled; |         this._actions.get(SUSPEND_ACTION_ID).available = this._canHaveSuspend && !disabled; | ||||||
|         this.notify('can-suspend'); |         this.notify('can-suspend'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateMultiUser() { |     _updateMultiUser() { | ||||||
|         this._updateLogout(); |         this._updateLogout(); | ||||||
|         this._updateSwitchUser(); |         this._updateSwitchUser(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateSwitchUser() { |     _updateSwitchUser() { | ||||||
|         let allowSwitch = !this._lockdownSettings.get_boolean(DISABLE_USER_SWITCH_KEY); |         let allowSwitch = !this._lockdownSettings.get_boolean(DISABLE_USER_SWITCH_KEY); | ||||||
| @@ -366,7 +357,7 @@ const SystemActions = new Lang.Class({ | |||||||
|         this.notify('can-switch-user'); |         this.notify('can-switch-user'); | ||||||
|  |  | ||||||
|         return visible; |         return visible; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateLogout() { |     _updateLogout() { | ||||||
|         let user = this._userManager.get_user(GLib.get_user_name()); |         let user = this._userManager.get_user(GLib.get_user_name()); | ||||||
| @@ -384,7 +375,7 @@ const SystemActions = new Lang.Class({ | |||||||
|         this.notify('can-logout'); |         this.notify('can-logout'); | ||||||
|  |  | ||||||
|         return visible; |         return visible; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     activateLockOrientation() { |     activateLockOrientation() { | ||||||
|         if (!this._actions.get(LOCK_ORIENTATION_ACTION_ID).available) |         if (!this._actions.get(LOCK_ORIENTATION_ACTION_ID).available) | ||||||
| @@ -392,14 +383,14 @@ const SystemActions = new Lang.Class({ | |||||||
|  |  | ||||||
|         let locked = this._orientationSettings.get_boolean('orientation-lock'); |         let locked = this._orientationSettings.get_boolean('orientation-lock'); | ||||||
|         this._orientationSettings.set_boolean('orientation-lock', !locked); |         this._orientationSettings.set_boolean('orientation-lock', !locked); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     activateLockScreen() { |     activateLockScreen() { | ||||||
|         if (!this._actions.get(LOCK_SCREEN_ACTION_ID).available) |         if (!this._actions.get(LOCK_SCREEN_ACTION_ID).available) | ||||||
|             throw new Error('The lock-screen action is not available!'); |             throw new Error('The lock-screen action is not available!'); | ||||||
|  |  | ||||||
|         Main.screenShield.lock(true); |         Main.screenShield.lock(true); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     activateSwitchUser() { |     activateSwitchUser() { | ||||||
|         if (!this._actions.get(SWITCH_USER_ACTION_ID).available) |         if (!this._actions.get(SWITCH_USER_ACTION_ID).available) | ||||||
| @@ -412,7 +403,7 @@ const SystemActions = new Lang.Class({ | |||||||
|             Gdm.goto_login_session_sync(null); |             Gdm.goto_login_session_sync(null); | ||||||
|             return false; |             return false; | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     activateLogout() { |     activateLogout() { | ||||||
|         if (!this._actions.get(LOGOUT_ACTION_ID).available) |         if (!this._actions.get(LOGOUT_ACTION_ID).available) | ||||||
| @@ -420,14 +411,14 @@ const SystemActions = new Lang.Class({ | |||||||
|  |  | ||||||
|         Main.overview.hide(); |         Main.overview.hide(); | ||||||
|         this._session.LogoutRemote(0); |         this._session.LogoutRemote(0); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     activatePowerOff() { |     activatePowerOff() { | ||||||
|         if (!this._actions.get(POWER_OFF_ACTION_ID).available) |         if (!this._actions.get(POWER_OFF_ACTION_ID).available) | ||||||
|             throw new Error('The power-off action is not available!'); |             throw new Error('The power-off action is not available!'); | ||||||
|  |  | ||||||
|         this._session.ShutdownRemote(0); |         this._session.ShutdownRemote(0); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     activateSuspend() { |     activateSuspend() { | ||||||
|         if (!this._actions.get(SUSPEND_ACTION_ID).available) |         if (!this._actions.get(SUSPEND_ACTION_ID).available) | ||||||
|   | |||||||
| @@ -1,14 +1,9 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Clutter = imports.gi.Clutter; | const { Clutter, Gio, GLib, GObject, Shell, St } = imports.gi; | ||||||
| const Gettext = imports.gettext; | const Gettext = imports.gettext; | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const GLib = imports.gi.GLib; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Mainloop = imports.mainloop; | const Mainloop = imports.mainloop; | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
| const Shell = imports.gi.Shell; |  | ||||||
| const St = imports.gi.St; |  | ||||||
|  |  | ||||||
| const Main = imports.ui.main; | const Main = imports.ui.main; | ||||||
| const Tweener = imports.ui.tweener; | const Tweener = imports.ui.tweener; | ||||||
| @@ -348,12 +343,10 @@ function insertSorted(array, val, cmp) { | |||||||
|     return pos; |     return pos; | ||||||
| } | } | ||||||
|  |  | ||||||
| var CloseButton = new Lang.Class({ | var CloseButton = GObject.registerClass( | ||||||
|     Name: 'CloseButton', | class CloseButton extends St.Button { | ||||||
|     Extends: St.Button, |  | ||||||
|  |  | ||||||
|     _init(boxpointer) { |     _init(boxpointer) { | ||||||
|         this.parent({ style_class: 'notification-close'}); |         super._init({ style_class: 'notification-close'}); | ||||||
|  |  | ||||||
|         // This is a bit tricky. St.Bin has its own x-align/y-align properties |         // This is a bit tricky. St.Bin has its own x-align/y-align properties | ||||||
|         // that compete with Clutter's properties. This should be fixed for |         // that compete with Clutter's properties. This should be fixed for | ||||||
| @@ -370,10 +363,10 @@ var CloseButton = new Lang.Class({ | |||||||
|         this._boxPointer = boxpointer; |         this._boxPointer = boxpointer; | ||||||
|         if (boxpointer) |         if (boxpointer) | ||||||
|             this._boxPointer.connect('arrow-side-changed', this._sync.bind(this)); |             this._boxPointer.connect('arrow-side-changed', this._sync.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _computeBoxPointerOffset() { |     _computeBoxPointerOffset() { | ||||||
|         if (!this._boxPointer || !this._boxPointer.actor.get_stage()) |         if (!this._boxPointer || !this._boxPointer.get_stage()) | ||||||
|             return 0; |             return 0; | ||||||
|  |  | ||||||
|         let side = this._boxPointer.arrowSide; |         let side = this._boxPointer.arrowSide; | ||||||
| @@ -381,7 +374,7 @@ var CloseButton = new Lang.Class({ | |||||||
|             return this._boxPointer.getArrowHeight(); |             return this._boxPointer.getArrowHeight(); | ||||||
|         else |         else | ||||||
|             return 0; |             return 0; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _sync() { |     _sync() { | ||||||
|         let themeNode = this.get_theme_node(); |         let themeNode = this.get_theme_node(); | ||||||
| @@ -389,12 +382,12 @@ var CloseButton = new Lang.Class({ | |||||||
|         let offY = this._computeBoxPointerOffset(); |         let offY = this._computeBoxPointerOffset(); | ||||||
|         this.translation_x = themeNode.get_length('-shell-close-overlap-x') |         this.translation_x = themeNode.get_length('-shell-close-overlap-x') | ||||||
|         this.translation_y = themeNode.get_length('-shell-close-overlap-y') + offY; |         this.translation_y = themeNode.get_length('-shell-close-overlap-y') + offY; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_style_changed() { |     vfunc_style_changed() { | ||||||
|         this._sync(); |         this._sync(); | ||||||
|         this.parent(); |         super.vfunc_style_changed(); | ||||||
|     }, |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| function makeCloseButton(boxpointer) { | function makeCloseButton(boxpointer) { | ||||||
| @@ -437,10 +430,8 @@ function ensureActorVisibleInScrollView(scrollView, actor) { | |||||||
|                        transition: 'easeOutQuad' }); |                        transition: 'easeOutQuad' }); | ||||||
| } | } | ||||||
|  |  | ||||||
| var AppSettingsMonitor = new Lang.Class({ | var AppSettingsMonitor = class { | ||||||
|     Name: 'AppSettingsMonitor', |     constructor(appId, schemaId) { | ||||||
|  |  | ||||||
|     _init(appId, schemaId) { |  | ||||||
|         this._appId = appId; |         this._appId = appId; | ||||||
|         this._schemaId = schemaId; |         this._schemaId = schemaId; | ||||||
|  |  | ||||||
| @@ -454,23 +445,23 @@ var AppSettingsMonitor = new Lang.Class({ | |||||||
|         this._appSystem.connect('installed-changed', |         this._appSystem.connect('installed-changed', | ||||||
|                                 this._onInstalledChanged.bind(this)); |                                 this._onInstalledChanged.bind(this)); | ||||||
|         this._onInstalledChanged(); |         this._onInstalledChanged(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get available() { |     get available() { | ||||||
|         return this._app != null && this._settings != null; |         return this._app != null && this._settings != null; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     activateApp() { |     activateApp() { | ||||||
|         if (this._app) |         if (this._app) | ||||||
|             this._app.activate(); |             this._app.activate(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     watchSetting(key, callback) { |     watchSetting(key, callback) { | ||||||
|         let handler = { id: 0, key: key, callback: callback }; |         let handler = { id: 0, key: key, callback: callback }; | ||||||
|         this._handlers.push(handler); |         this._handlers.push(handler); | ||||||
|  |  | ||||||
|         this._connectHandler(handler); |         this._connectHandler(handler); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _connectHandler(handler) { |     _connectHandler(handler) { | ||||||
|         if (!this._settings || handler.id > 0) |         if (!this._settings || handler.id > 0) | ||||||
| @@ -479,13 +470,13 @@ var AppSettingsMonitor = new Lang.Class({ | |||||||
|         handler.id = this._settings.connect('changed::' + handler.key, |         handler.id = this._settings.connect('changed::' + handler.key, | ||||||
|                                             handler.callback); |                                             handler.callback); | ||||||
|         handler.callback(this._settings, handler.key); |         handler.callback(this._settings, handler.key); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _disconnectHandler(handler) { |     _disconnectHandler(handler) { | ||||||
|         if (this._settings && handler.id > 0) |         if (this._settings && handler.id > 0) | ||||||
|             this._settings.disconnect(handler.id); |             this._settings.disconnect(handler.id); | ||||||
|         handler.id = 0; |         handler.id = 0; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onInstalledChanged() { |     _onInstalledChanged() { | ||||||
|         let hadApp = (this._app != null); |         let hadApp = (this._app != null); | ||||||
| @@ -499,7 +490,7 @@ var AppSettingsMonitor = new Lang.Class({ | |||||||
|             this._checkSettings(); |             this._checkSettings(); | ||||||
|         else |         else | ||||||
|             this._setSettings(null); |             this._setSettings(null); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _setSettings(settings) { |     _setSettings(settings) { | ||||||
|         this._handlers.forEach((handler) => { this._disconnectHandler(handler); }); |         this._handlers.forEach((handler) => { this._disconnectHandler(handler); }); | ||||||
| @@ -512,7 +503,7 @@ var AppSettingsMonitor = new Lang.Class({ | |||||||
|  |  | ||||||
|         if (hadSettings != haveSettings) |         if (hadSettings != haveSettings) | ||||||
|             this.emit('available-changed'); |             this.emit('available-changed'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _checkSettings() { |     _checkSettings() { | ||||||
|         let schema = this._schemaSource.lookup(this._schemaId, true); |         let schema = this._schemaSource.lookup(this._schemaId, true); | ||||||
| @@ -525,5 +516,5 @@ var AppSettingsMonitor = new Lang.Class({ | |||||||
|             }); |             }); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(AppSettingsMonitor.prototype); | Signals.addSignalMethods(AppSettingsMonitor.prototype); | ||||||
|   | |||||||
| @@ -1,10 +1,6 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Geoclue = imports.gi.Geoclue; | const { Geoclue, Gio, GLib, GWeather } = imports.gi; | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const GLib = imports.gi.GLib; |  | ||||||
| const GWeather = imports.gi.GWeather; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
|  |  | ||||||
| const PermissionStore = imports.misc.permissionStore; | const PermissionStore = imports.misc.permissionStore; | ||||||
| @@ -13,10 +9,8 @@ const Util = imports.misc.util; | |||||||
| // Minimum time between updates to show loading indication | // Minimum time between updates to show loading indication | ||||||
| var UPDATE_THRESHOLD = 10 * GLib.TIME_SPAN_MINUTE; | var UPDATE_THRESHOLD = 10 * GLib.TIME_SPAN_MINUTE; | ||||||
|  |  | ||||||
| var WeatherClient = new Lang.Class({ | var WeatherClient = class { | ||||||
|     Name: 'WeatherClient', |     constructor() { | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         this._loading = false; |         this._loading = false; | ||||||
|         this._locationValid = false; |         this._locationValid = false; | ||||||
|         this._lastUpdate = GLib.DateTime.new_from_unix_local(0); |         this._lastUpdate = GLib.DateTime.new_from_unix_local(0); | ||||||
| @@ -36,6 +30,14 @@ var WeatherClient = new Lang.Class({ | |||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  |             if (this._permStore.g_name_owner == null) { | ||||||
|  |                 // Failed to auto-start, likely because xdg-desktop-portal | ||||||
|  |                 // isn't installed; don't restrict access to location service | ||||||
|  |                 this._weatherAuthorized = true; | ||||||
|  |                 this._updateAutoLocation(); | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |  | ||||||
|             this._permStore.LookupRemote('gnome', 'geolocation', (res, error) => { |             this._permStore.LookupRemote('gnome', 'geolocation', (res, error) => { | ||||||
|                 if (error) |                 if (error) | ||||||
|                     log('Error looking up permission: ' + error.message); |                     log('Error looking up permission: ' + error.message); | ||||||
| @@ -64,34 +66,34 @@ var WeatherClient = new Lang.Class({ | |||||||
|             this.emit('changed'); |             this.emit('changed'); | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
|         this._weatherAppMon = new Util.AppSettingsMonitor('org.gnome.Weather.Application.desktop', |         this._weatherAppMon = new Util.AppSettingsMonitor('org.gnome.Weather.desktop', | ||||||
|                                                           'org.gnome.Weather.Application'); |                                                           'org.gnome.Weather'); | ||||||
|         this._weatherAppMon.connect('available-changed', () => { this.emit('changed'); }); |         this._weatherAppMon.connect('available-changed', () => { this.emit('changed'); }); | ||||||
|         this._weatherAppMon.watchSetting('automatic-location', |         this._weatherAppMon.watchSetting('automatic-location', | ||||||
|                                          this._onAutomaticLocationChanged.bind(this)); |                                          this._onAutomaticLocationChanged.bind(this)); | ||||||
|         this._weatherAppMon.watchSetting('locations', |         this._weatherAppMon.watchSetting('locations', | ||||||
|                                          this._onLocationsChanged.bind(this)); |                                          this._onLocationsChanged.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get available() { |     get available() { | ||||||
|         return this._weatherAppMon.available; |         return this._weatherAppMon.available; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get loading() { |     get loading() { | ||||||
|         return this._loading; |         return this._loading; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get hasLocation() { |     get hasLocation() { | ||||||
|         return this._locationValid; |         return this._locationValid; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get info() { |     get info() { | ||||||
|         return this._weatherInfo; |         return this._weatherInfo; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     activateApp() { |     activateApp() { | ||||||
|         this._weatherAppMon.activateApp(); |         this._weatherAppMon.activateApp(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     update() { |     update() { | ||||||
|         if (!this._locationValid) |         if (!this._locationValid) | ||||||
| @@ -104,13 +106,13 @@ var WeatherClient = new Lang.Class({ | |||||||
|             this._weatherInfo.update(); |             this._weatherInfo.update(); | ||||||
|         else |         else | ||||||
|             this._loadInfo(); |             this._loadInfo(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     get _useAutoLocation() { |     get _useAutoLocation() { | ||||||
|         return this._autoLocationRequested && |         return this._autoLocationRequested && | ||||||
|                this._locationSettings.get_boolean('enabled') && |                this._locationSettings.get_boolean('enabled') && | ||||||
|                this._weatherAuthorized; |                this._weatherAuthorized; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _loadInfo() { |     _loadInfo() { | ||||||
|         let id = this._weatherInfo.connect('updated', () => { |         let id = this._weatherInfo.connect('updated', () => { | ||||||
| @@ -122,7 +124,7 @@ var WeatherClient = new Lang.Class({ | |||||||
|         this.emit('changed'); |         this.emit('changed'); | ||||||
|  |  | ||||||
|         this._weatherInfo.update(); |         this._weatherInfo.update(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _locationsEqual(loc1, loc2) { |     _locationsEqual(loc1, loc2) { | ||||||
|         if (loc1 == loc2) |         if (loc1 == loc2) | ||||||
| @@ -132,7 +134,7 @@ var WeatherClient = new Lang.Class({ | |||||||
|             return false; |             return false; | ||||||
|  |  | ||||||
|         return loc1.equal(loc2); |         return loc1.equal(loc2); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _setLocation(location) { |     _setLocation(location) { | ||||||
|         if (this._locationsEqual(this._weatherInfo.location, location)) |         if (this._locationsEqual(this._weatherInfo.location, location)) | ||||||
| @@ -148,7 +150,7 @@ var WeatherClient = new Lang.Class({ | |||||||
|             this._loadInfo(); |             this._loadInfo(); | ||||||
|         else |         else | ||||||
|             this.emit('changed'); |             this.emit('changed'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateLocationMonitoring() { |     _updateLocationMonitoring() { | ||||||
|         if (this._useAutoLocation) { |         if (this._useAutoLocation) { | ||||||
| @@ -164,7 +166,7 @@ var WeatherClient = new Lang.Class({ | |||||||
|                 this._gclueService.disconnect(this._gclueLocationChangedId); |                 this._gclueService.disconnect(this._gclueLocationChangedId); | ||||||
|             this._gclueLocationChangedId = 0; |             this._gclueLocationChangedId = 0; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _startGClueService() { |     _startGClueService() { | ||||||
|         if (this._gclueStarting) |         if (this._gclueStarting) | ||||||
| @@ -185,7 +187,7 @@ var WeatherClient = new Lang.Class({ | |||||||
|                 this._gclueService.get_client().distance_threshold = 100; |                 this._gclueService.get_client().distance_threshold = 100; | ||||||
|                 this._updateLocationMonitoring(); |                 this._updateLocationMonitoring(); | ||||||
|             }); |             }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onGClueLocationChanged() { |     _onGClueLocationChanged() { | ||||||
|         let geoLocation = this._gclueService.location; |         let geoLocation = this._gclueService.location; | ||||||
| @@ -194,7 +196,7 @@ var WeatherClient = new Lang.Class({ | |||||||
|                                                       geoLocation.latitude, |                                                       geoLocation.latitude, | ||||||
|                                                       geoLocation.longitude); |                                                       geoLocation.longitude); | ||||||
|         this._setLocation(location); |         this._setLocation(location); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onAutomaticLocationChanged(settings, key) { |     _onAutomaticLocationChanged(settings, key) { | ||||||
|         let useAutoLocation = settings.get_boolean(key); |         let useAutoLocation = settings.get_boolean(key); | ||||||
| @@ -204,7 +206,7 @@ var WeatherClient = new Lang.Class({ | |||||||
|         this._autoLocationRequested = useAutoLocation; |         this._autoLocationRequested = useAutoLocation; | ||||||
|  |  | ||||||
|         this._updateAutoLocation(); |         this._updateAutoLocation(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateAutoLocation() { |     _updateAutoLocation() { | ||||||
|         this._updateLocationMonitoring(); |         this._updateLocationMonitoring(); | ||||||
| @@ -213,7 +215,7 @@ var WeatherClient = new Lang.Class({ | |||||||
|             this._startGClueService(); |             this._startGClueService(); | ||||||
|         else |         else | ||||||
|             this._setLocation(this._mostRecentLocation); |             this._setLocation(this._mostRecentLocation); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onLocationsChanged(settings, key) { |     _onLocationsChanged(settings, key) { | ||||||
|         let serialized = settings.get_value(key).deep_unpack().shift(); |         let serialized = settings.get_value(key).deep_unpack().shift(); | ||||||
| @@ -229,7 +231,7 @@ var WeatherClient = new Lang.Class({ | |||||||
|  |  | ||||||
|         if (!this._useAutoLocation || !this._gclueStarted) |         if (!this._useAutoLocation || !this._gclueStarted) | ||||||
|             this._setLocation(this._mostRecentLocation); |             this._setLocation(this._mostRecentLocation); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onPermStoreChanged(proxy, sender, params) { |     _onPermStoreChanged(proxy, sender, params) { | ||||||
|         let [table, id, deleted, data, perms] = params; |         let [table, id, deleted, data, perms] = params; | ||||||
| @@ -237,11 +239,11 @@ var WeatherClient = new Lang.Class({ | |||||||
|         if (table != 'gnome' || id != 'geolocation') |         if (table != 'gnome' || id != 'geolocation') | ||||||
|             return; |             return; | ||||||
|  |  | ||||||
|         let permission = perms['org.gnome.Weather.Application'] || ['NONE']; |         let permission = perms['org.gnome.Weather'] || ['NONE']; | ||||||
|         let [accuracy] = permission; |         let [accuracy] = permission; | ||||||
|         this._weatherAuthorized = accuracy != 'NONE'; |         this._weatherAuthorized = accuracy != 'NONE'; | ||||||
|  |  | ||||||
|         this._updateAutoLocation(); |         this._updateAutoLocation(); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(WeatherClient.prototype); | Signals.addSignalMethods(WeatherClient.prototype); | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ const Scripting = imports.ui.scripting; | |||||||
| // someone should be able to get an idea of how well the shell is performing | // someone should be able to get an idea of how well the shell is performing | ||||||
| // on a particular system. | // on a particular system. | ||||||
|  |  | ||||||
| let METRICS = { | var METRICS = { | ||||||
|     overviewLatencyFirst: |     overviewLatencyFirst: | ||||||
|     { description: "Time to first frame after triggering overview, first time", |     { description: "Time to first frame after triggering overview, first time", | ||||||
|       units: "us" }, |       units: "us" }, | ||||||
| @@ -65,7 +65,7 @@ let WINDOW_CONFIGS = [ | |||||||
|     { width: 640, height: 480, alpha: true,  maximized: false, count: 10, metric: 'overviewFps10Alpha' } |     { width: 640, height: 480, alpha: true,  maximized: false, count: 10, metric: 'overviewFps10Alpha' } | ||||||
| ]; | ]; | ||||||
|  |  | ||||||
| function run() { | function *run() { | ||||||
|     Scripting.defineScriptEvent("overviewShowStart", "Starting to show the overview"); |     Scripting.defineScriptEvent("overviewShowStart", "Starting to show the overview"); | ||||||
|     Scripting.defineScriptEvent("overviewShowDone", "Overview finished showing"); |     Scripting.defineScriptEvent("overviewShowDone", "Overview finished showing"); | ||||||
|     Scripting.defineScriptEvent("afterShowHide", "After a show/hide cycle for the overview"); |     Scripting.defineScriptEvent("afterShowHide", "After a show/hide cycle for the overview"); | ||||||
|   | |||||||
| @@ -1,12 +1,8 @@ | |||||||
| const Clutter = imports.gi.Clutter; | const { Clutter, Gio, Shell } = imports.gi; | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const Gtk = imports.gi.Gtk; |  | ||||||
| const Meta = imports.gi.Meta; |  | ||||||
| const Main = imports.ui.main; | const Main = imports.ui.main; | ||||||
| const Scripting = imports.ui.scripting; | const Scripting = imports.ui.scripting; | ||||||
| const Shell = imports.gi.Shell; |  | ||||||
|  |  | ||||||
| let METRICS = { | var METRICS = { | ||||||
|     timeToDesktop: |     timeToDesktop: | ||||||
|     { description: "Time from starting graphical.target to desktop showing", |     { description: "Time from starting graphical.target to desktop showing", | ||||||
|       units: "us" }, |       units: "us" }, | ||||||
| @@ -89,7 +85,7 @@ function extractBootTimestamp() { | |||||||
|     return result; |     return result; | ||||||
| } | } | ||||||
|  |  | ||||||
| function run() { | function *run() { | ||||||
|     Scripting.defineScriptEvent("desktopShown", "Finished initial animation"); |     Scripting.defineScriptEvent("desktopShown", "Finished initial animation"); | ||||||
|     Scripting.defineScriptEvent("overviewShowStart", "Starting to show the overview"); |     Scripting.defineScriptEvent("overviewShowStart", "Starting to show the overview"); | ||||||
|     Scripting.defineScriptEvent("overviewShowDone", "Overview finished showing"); |     Scripting.defineScriptEvent("overviewShowDone", "Overview finished showing"); | ||||||
| @@ -108,7 +104,10 @@ function run() { | |||||||
|     yield Scripting.waitLeisure(); |     yield Scripting.waitLeisure(); | ||||||
|     Scripting.scriptEvent('desktopShown'); |     Scripting.scriptEvent('desktopShown'); | ||||||
|  |  | ||||||
|     Gtk.Settings.get_default().gtk_enable_animations = false; |     let interfaceSettings = new Gio.Settings({ | ||||||
|  |         schema_id: 'org.gnome.desktop.interface' | ||||||
|  |     }); | ||||||
|  |     interfaceSettings.set_boolean('enable-animations', false); | ||||||
|  |  | ||||||
|     Scripting.scriptEvent('overviewShowStart'); |     Scripting.scriptEvent('overviewShowStart'); | ||||||
|     Main.overview.show(); |     Main.overview.show(); | ||||||
| @@ -204,7 +203,7 @@ function run() { | |||||||
|  |  | ||||||
|     yield Scripting.sleep(1000); |     yield Scripting.sleep(1000); | ||||||
|  |  | ||||||
|     Gtk.Settings.get_default().gtk_enable_animations = true; |     interfaceSettings.set_boolean('enable-animations', true); | ||||||
| } | } | ||||||
|  |  | ||||||
| let overviewShowStart; | let overviewShowStart; | ||||||
|   | |||||||
| @@ -1,13 +1,6 @@ | |||||||
| const Format = imports.format; | const Format = imports.format; | ||||||
| const Gettext = imports.gettext; | const Gettext = imports.gettext; | ||||||
| const GLib = imports.gi.GLib; | const { Gio, GLib, GObject, Gtk, Pango, Soup, WebKit2: WebKit } = imports.gi; | ||||||
| const GObject = imports.gi.GObject; |  | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const Gtk = imports.gi.Gtk; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Pango = imports.gi.Pango; |  | ||||||
| const Soup = imports.gi.Soup; |  | ||||||
| const WebKit = imports.gi.WebKit2; |  | ||||||
|  |  | ||||||
| const _ = Gettext.gettext; | const _ = Gettext.gettext; | ||||||
|  |  | ||||||
| @@ -33,12 +26,10 @@ const CONNECTIVITY_RECHECK_RATELIMIT_TIMEOUT = 30 * GLib.USEC_PER_SEC; | |||||||
|  |  | ||||||
| const HelperDBusInterface = loadInterfaceXML('org.gnome.Shell.PortalHelper'); | const HelperDBusInterface = loadInterfaceXML('org.gnome.Shell.PortalHelper'); | ||||||
|  |  | ||||||
| var PortalHeaderBar = new Lang.Class({ | var PortalHeaderBar = GObject.registerClass( | ||||||
|     Name: 'PortalHeaderBar', | class PortalHeaderBar extends Gtk.HeaderBar { | ||||||
|     Extends: Gtk.HeaderBar, |  | ||||||
|  |  | ||||||
|     _init() { |     _init() { | ||||||
|         this.parent({ show_close_button: true }); |         super._init({ show_close_button: true }); | ||||||
|  |  | ||||||
|         // See ephy-title-box.c in epiphany for the layout |         // See ephy-title-box.c in epiphany for the layout | ||||||
|         let vbox = new Gtk.Box({ orientation: Gtk.Orientation.VERTICAL, |         let vbox = new Gtk.Box({ orientation: Gtk.Orientation.VERTICAL, | ||||||
| @@ -73,11 +64,11 @@ var PortalHeaderBar = new Lang.Class({ | |||||||
|         hbox.add(this.subtitleLabel); |         hbox.add(this.subtitleLabel); | ||||||
|  |  | ||||||
|         vbox.show_all(); |         vbox.show_all(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     setSubtitle(label) { |     setSubtitle(label) { | ||||||
|         this.subtitleLabel.set_text(label); |         this.subtitleLabel.set_text(label); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     setSecurityIcon(securityLevel) { |     setSecurityIcon(securityLevel) { | ||||||
|         switch (securityLevel) { |         switch (securityLevel) { | ||||||
| @@ -95,15 +86,13 @@ var PortalHeaderBar = new Lang.Class({ | |||||||
|             this._lockImage.set_tooltip_text(_('Your connection to this hotspot login is not secure. Passwords or other information you enter on this page can be viewed by people nearby.')); |             this._lockImage.set_tooltip_text(_('Your connection to this hotspot login is not secure. Passwords or other information you enter on this page can be viewed by people nearby.')); | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var PortalWindow = new Lang.Class({ | var PortalWindow = GObject.registerClass( | ||||||
|     Name: 'PortalWindow', | class PortalWindow extends Gtk.ApplicationWindow { | ||||||
|     Extends: Gtk.ApplicationWindow, |  | ||||||
|  |  | ||||||
|     _init(application, url, timestamp, doneCallback) { |     _init(application, url, timestamp, doneCallback) { | ||||||
|         this.parent({ application: application }); |         super._init({ application: application }); | ||||||
|  |  | ||||||
|         this.connect('delete-event', this.destroyWindow.bind(this)); |         this.connect('delete-event', this.destroyWindow.bind(this)); | ||||||
|         this._headerBar = new PortalHeaderBar(); |         this._headerBar = new PortalHeaderBar(); | ||||||
| @@ -144,11 +133,11 @@ var PortalWindow = new Lang.Class({ | |||||||
|         this.present_with_time(timestamp); |         this.present_with_time(timestamp); | ||||||
|  |  | ||||||
|         this.application.set_accels_for_action('app.quit', ['<Primary>q', '<Primary>w']); |         this.application.set_accels_for_action('app.quit', ['<Primary>q', '<Primary>w']); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     destroyWindow() { |     destroyWindow() { | ||||||
|         this.destroy(); |         this.destroy(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _syncUri() { |     _syncUri() { | ||||||
|         let uri = this._webView.uri; |         let uri = this._webView.uri; | ||||||
| @@ -156,12 +145,12 @@ var PortalWindow = new Lang.Class({ | |||||||
|             this._headerBar.setSubtitle(GLib.uri_unescape_string(uri, null)); |             this._headerBar.setSubtitle(GLib.uri_unescape_string(uri, null)); | ||||||
|         else |         else | ||||||
|             this._headerBar.setSubtitle(''); |             this._headerBar.setSubtitle(''); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     refresh() { |     refresh() { | ||||||
|         this._everSeenRedirect = false; |         this._everSeenRedirect = false; | ||||||
|         this._webView.load_uri(this._originalUrl); |         this._webView.load_uri(this._originalUrl); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_delete_event(event) { |     vfunc_delete_event(event) { | ||||||
|         if (this._recheckAtExit) |         if (this._recheckAtExit) | ||||||
| @@ -169,7 +158,7 @@ var PortalWindow = new Lang.Class({ | |||||||
|         else |         else | ||||||
|             this._doneCallback(PortalHelperResult.CANCELLED); |             this._doneCallback(PortalHelperResult.CANCELLED); | ||||||
|         return false; |         return false; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onLoadChanged(view, loadEvent) { |     _onLoadChanged(view, loadEvent) { | ||||||
|         if (loadEvent == WebKit.LoadEvent.STARTED) { |         if (loadEvent == WebKit.LoadEvent.STARTED) { | ||||||
| @@ -183,11 +172,11 @@ var PortalWindow = new Lang.Class({ | |||||||
|             else |             else | ||||||
|                 this._headerBar.setSecurityIcon(PortalHelperSecurityLevel.INSECURE); |                 this._headerBar.setSecurityIcon(PortalHelperSecurityLevel.INSECURE); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onInsecureContentDetected() { |     _onInsecureContentDetected() { | ||||||
|         this._headerBar.setSecurityIcon(PortalHelperSecurityLevel.INSECURE); |         this._headerBar.setSecurityIcon(PortalHelperSecurityLevel.INSECURE); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onLoadFailedWithTlsErrors(view, failingURI, certificate, errors) { |     _onLoadFailedWithTlsErrors(view, failingURI, certificate, errors) { | ||||||
|         this._headerBar.setSecurityIcon(PortalHelperSecurityLevel.INSECURE); |         this._headerBar.setSecurityIcon(PortalHelperSecurityLevel.INSECURE); | ||||||
| @@ -195,7 +184,7 @@ var PortalWindow = new Lang.Class({ | |||||||
|         this._webContext.allow_tls_certificate_for_host(certificate, uri.get_host()); |         this._webContext.allow_tls_certificate_for_host(certificate, uri.get_host()); | ||||||
|         this._webView.load_uri(failingURI); |         this._webView.load_uri(failingURI); | ||||||
|         return true; |         return true; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDecidePolicy(view, decision, type) { |     _onDecidePolicy(view, decision, type) { | ||||||
|         if (type == WebKit.PolicyDecisionType.NEW_WINDOW_ACTION) { |         if (type == WebKit.PolicyDecisionType.NEW_WINDOW_ACTION) { | ||||||
| @@ -262,15 +251,13 @@ var PortalWindow = new Lang.Class({ | |||||||
|  |  | ||||||
|         decision.use(); |         decision.use(); | ||||||
|         return true; |         return true; | ||||||
|     }, |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var WebPortalHelper = new Lang.Class({ | var WebPortalHelper = GObject.registerClass( | ||||||
|     Name: 'WebPortalHelper', | class WebPortalHelper extends Gtk.Application { | ||||||
|     Extends: Gtk.Application, |  | ||||||
|  |  | ||||||
|     _init() { |     _init() { | ||||||
|         this.parent({ application_id: 'org.gnome.Shell.PortalHelper', |         super._init({ application_id: 'org.gnome.Shell.PortalHelper', | ||||||
|                       flags: Gio.ApplicationFlags.IS_SERVICE, |                       flags: Gio.ApplicationFlags.IS_SERVICE, | ||||||
|                       inactivity_timeout: 30000 }); |                       inactivity_timeout: 30000 }); | ||||||
|  |  | ||||||
| @@ -280,30 +267,30 @@ var WebPortalHelper = new Lang.Class({ | |||||||
|         let action = new Gio.SimpleAction({ name: 'quit' }); |         let action = new Gio.SimpleAction({ name: 'quit' }); | ||||||
|         action.connect('activate', () => { this.active_window.destroyWindow(); }); |         action.connect('activate', () => { this.active_window.destroyWindow(); }); | ||||||
|         this.add_action(action); |         this.add_action(action); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_dbus_register(connection, path) { |     vfunc_dbus_register(connection, path) { | ||||||
|         this._dbusImpl.export(connection, path); |         this._dbusImpl.export(connection, path); | ||||||
|         this.parent(connection, path); |         super.vfunc_dbus_register(connection, path); | ||||||
|         return true; |         return true; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_dbus_unregister(connection, path) { |     vfunc_dbus_unregister(connection, path) { | ||||||
|         this._dbusImpl.unexport_from_connection(connection); |         this._dbusImpl.unexport_from_connection(connection); | ||||||
|         this.parent(connection, path); |         super.vfunc_dbus_unregister(connection, path); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_activate() { |     vfunc_activate() { | ||||||
|         // If launched manually (for example for testing), force a dummy authentication |         // If launched manually (for example for testing), force a dummy authentication | ||||||
|         // session with the default url |         // session with the default url | ||||||
|         this.Authenticate('/org/gnome/dummy', '', 0); |         this.Authenticate('/org/gnome/dummy', '', 0); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     Authenticate(connection, url, timestamp) { |     Authenticate(connection, url, timestamp) { | ||||||
|         this._queue.push({ connection: connection, url: url, timestamp: timestamp }); |         this._queue.push({ connection: connection, url: url, timestamp: timestamp }); | ||||||
|  |  | ||||||
|         this._processQueue(); |         this._processQueue(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     Close(connection) { |     Close(connection) { | ||||||
|         for (let i = 0; i < this._queue.length; i++) { |         for (let i = 0; i < this._queue.length; i++) { | ||||||
| @@ -318,7 +305,7 @@ var WebPortalHelper = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this._processQueue(); |         this._processQueue(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     Refresh(connection) { |     Refresh(connection) { | ||||||
|         for (let i = 0; i < this._queue.length; i++) { |         for (let i = 0; i < this._queue.length; i++) { | ||||||
| @@ -330,7 +317,7 @@ var WebPortalHelper = new Lang.Class({ | |||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _processQueue() { |     _processQueue() { | ||||||
|         if (this._queue.length == 0) |         if (this._queue.length == 0) | ||||||
| @@ -343,7 +330,7 @@ var WebPortalHelper = new Lang.Class({ | |||||||
|         top.window = new PortalWindow(this, top.url, top.timestamp, result => { |         top.window = new PortalWindow(this, top.url, top.timestamp, result => { | ||||||
|             this._dbusImpl.emit_signal('Done', new GLib.Variant('(ou)', [top.connection, result])); |             this._dbusImpl.emit_signal('Done', new GLib.Variant('(ou)', [top.connection, result])); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| function initEnvironment() { | function initEnvironment() { | ||||||
|   | |||||||
| @@ -1,10 +1,4 @@ | |||||||
| const Clutter = imports.gi.Clutter; | const { Clutter, Gio, GLib, GObject, Shell } = imports.gi; | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const GLib = imports.gi.GLib; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Pango = imports.gi.Pango; |  | ||||||
| const Shell = imports.gi.Shell; |  | ||||||
| const St = imports.gi.St; |  | ||||||
|  |  | ||||||
| const CheckBox = imports.ui.checkBox; | const CheckBox = imports.ui.checkBox; | ||||||
| const Dialog = imports.ui.dialog; | const Dialog = imports.ui.dialog; | ||||||
| @@ -21,12 +15,10 @@ var DialogResponse = { | |||||||
|     CLOSED: 2 |     CLOSED: 2 | ||||||
| }; | }; | ||||||
|  |  | ||||||
| var AccessDialog = new Lang.Class({ | var AccessDialog = GObject.registerClass( | ||||||
|     Name: 'AccessDialog', | class AccessDialog extends ModalDialog.ModalDialog { | ||||||
|     Extends: ModalDialog.ModalDialog, |  | ||||||
|  |  | ||||||
|     _init(invocation, handle, title, subtitle, body, options) { |     _init(invocation, handle, title, subtitle, body, options) { | ||||||
|         this.parent({ styleClass: 'access-dialog' }); |         super._init({ styleClass: 'access-dialog' }); | ||||||
|  |  | ||||||
|         this._invocation = invocation; |         this._invocation = invocation; | ||||||
|         this._handle = handle; |         this._handle = handle; | ||||||
| @@ -38,7 +30,7 @@ var AccessDialog = new Lang.Class({ | |||||||
|             options[option] = options[option].deep_unpack(); |             options[option] = options[option].deep_unpack(); | ||||||
|  |  | ||||||
|         this._buildLayout(title, subtitle, body, options); |         this._buildLayout(title, subtitle, body, options); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _buildLayout(title, subtitle, body, options) { |     _buildLayout(title, subtitle, body, options) { | ||||||
|         // No support for non-modal system dialogs, so ignore the option |         // No support for non-modal system dialogs, so ignore the option | ||||||
| @@ -78,14 +70,14 @@ var AccessDialog = new Lang.Class({ | |||||||
|                          action: () => { |                          action: () => { | ||||||
|                              this._sendResponse(DialogResponse.OK); |                              this._sendResponse(DialogResponse.OK); | ||||||
|                          }}); |                          }}); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     open() { |     open() { | ||||||
|         this.parent(); |         super.open(); | ||||||
|  |  | ||||||
|         let connection = this._invocation.get_connection(); |         let connection = this._invocation.get_connection(); | ||||||
|         this._requestExported = this._request.export(connection, this._handle); |         this._requestExported = this._request.export(connection, this._handle); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     CloseAsync(invocation, params) { |     CloseAsync(invocation, params) { | ||||||
|         if (this._invocation.get_sender() != invocation.get_sender()) { |         if (this._invocation.get_sender() != invocation.get_sender()) { | ||||||
| @@ -96,7 +88,7 @@ var AccessDialog = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this._sendResponse(DialogResponse.CLOSED); |         this._sendResponse(DialogResponse.CLOSED); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _sendResponse(response) { |     _sendResponse(response) { | ||||||
|         if (this._requestExported) |         if (this._requestExported) | ||||||
| @@ -120,10 +112,8 @@ var AccessDialog = new Lang.Class({ | |||||||
|     } |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var AccessDialogDBus = new Lang.Class({ | var AccessDialogDBus = class { | ||||||
|     Name: 'AccessDialogDBus', |     constructor() { | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         this._accessDialog = null; |         this._accessDialog = null; | ||||||
|  |  | ||||||
|         this._windowTracker = Shell.WindowTracker.get_default(); |         this._windowTracker = Shell.WindowTracker.get_default(); | ||||||
| @@ -132,7 +122,7 @@ var AccessDialogDBus = new Lang.Class({ | |||||||
|         this._dbusImpl.export(Gio.DBus.session, '/org/freedesktop/portal/desktop'); |         this._dbusImpl.export(Gio.DBus.session, '/org/freedesktop/portal/desktop'); | ||||||
|  |  | ||||||
|         Gio.DBus.session.own_name('org.freedesktop.impl.portal.desktop.gnome', Gio.BusNameOwnerFlags.REPLACE, null, null); |         Gio.DBus.session.own_name('org.freedesktop.impl.portal.desktop.gnome', Gio.BusNameOwnerFlags.REPLACE, null, null); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     AccessDialogAsync(params, invocation) { |     AccessDialogAsync(params, invocation) { | ||||||
|         if (this._accessDialog) { |         if (this._accessDialog) { | ||||||
| @@ -160,4 +150,4 @@ var AccessDialogDBus = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._accessDialog = dialog; |         this._accessDialog = dialog; | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
|   | |||||||
							
								
								
									
										242
									
								
								js/ui/altTab.js
									
									
									
									
									
								
							
							
						
						| @@ -1,15 +1,7 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Clutter = imports.gi.Clutter; | const { Atk, Clutter, Gio, GLib, GObject, Meta, Shell, St } = imports.gi; | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const GLib = imports.gi.GLib; |  | ||||||
| const GObject = imports.gi.GObject; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Mainloop = imports.mainloop; | const Mainloop = imports.mainloop; | ||||||
| const Meta = imports.gi.Meta; |  | ||||||
| const Shell = imports.gi.Shell; |  | ||||||
| const St = imports.gi.St; |  | ||||||
| const Atk = imports.gi.Atk; |  | ||||||
|  |  | ||||||
| const Main = imports.ui.main; | const Main = imports.ui.main; | ||||||
| const SwitcherPopup = imports.ui.switcherPopup; | const SwitcherPopup = imports.ui.switcherPopup; | ||||||
| @@ -59,12 +51,10 @@ function getWindows(workspace) { | |||||||
|     }).filter((w, i, a) => !w.skip_taskbar && a.indexOf(w) == i); |     }).filter((w, i, a) => !w.skip_taskbar && a.indexOf(w) == i); | ||||||
| } | } | ||||||
|  |  | ||||||
| var AppSwitcherPopup = new Lang.Class({ | var AppSwitcherPopup = GObject.registerClass( | ||||||
|     Name: 'AppSwitcherPopup', | class AppSwitcherPopup extends SwitcherPopup.SwitcherPopup { | ||||||
|     Extends: SwitcherPopup.SwitcherPopup, |  | ||||||
|  |  | ||||||
|     _init() { |     _init() { | ||||||
|         this.parent(); |         super._init(); | ||||||
|  |  | ||||||
|         this._thumbnails = null; |         this._thumbnails = null; | ||||||
|         this._thumbnailTimeoutId = 0; |         this._thumbnailTimeoutId = 0; | ||||||
| @@ -79,10 +69,10 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._switcherList = new AppSwitcher(apps, this); |         this._switcherList = new AppSwitcher(apps, this); | ||||||
|         this._items = this._switcherList.icons; |         this._items = this._switcherList.icons; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_allocate(box, flags) { |     vfunc_allocate(box, flags) { | ||||||
|         this.parent(box, flags); |         super.vfunc_allocate(box, flags); | ||||||
|  |  | ||||||
|         // Allocate the thumbnails |         // Allocate the thumbnails | ||||||
|         // We try to avoid overflowing the screen so we base the resulting size on |         // We try to avoid overflowing the screen so we base the resulting size on | ||||||
| @@ -117,7 +107,7 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|             childBox.y2 = childBox.y1 + childNaturalHeight; |             childBox.y2 = childBox.y1 + childNaturalHeight; | ||||||
|             this._thumbnails.allocate(childBox, flags); |             this._thumbnails.allocate(childBox, flags); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _initialSelection(backward, binding) { |     _initialSelection(backward, binding) { | ||||||
|         if (binding == 'switch-group') { |         if (binding == 'switch-group') { | ||||||
| @@ -140,7 +130,7 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|         } else { |         } else { | ||||||
|             this._select(1); |             this._select(1); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _nextWindow() { |     _nextWindow() { | ||||||
|         // We actually want the second window if we're in the unset state |         // We actually want the second window if we're in the unset state | ||||||
| @@ -148,14 +138,15 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|             this._currentWindow = 0; |             this._currentWindow = 0; | ||||||
|         return SwitcherPopup.mod(this._currentWindow + 1, |         return SwitcherPopup.mod(this._currentWindow + 1, | ||||||
|                                  this._items[this._selectedIndex].cachedWindows.length); |                                  this._items[this._selectedIndex].cachedWindows.length); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _previousWindow() { |     _previousWindow() { | ||||||
|         // Also assume second window here |         // Also assume second window here | ||||||
|         if (this._currentWindow == -1) |         if (this._currentWindow == -1) | ||||||
|             this._currentWindow = 1; |             this._currentWindow = 1; | ||||||
|         return SwitcherPopup.mod(this._currentWindow - 1, |         return SwitcherPopup.mod(this._currentWindow - 1, | ||||||
|                                  this._items[this._selectedIndex].cachedWindows.length); |                                  this._items[this._selectedIndex].cachedWindows.length); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _closeAppWindow(appIndex, windowIndex) { |     _closeAppWindow(appIndex, windowIndex) { | ||||||
|         let appIcon = this._items[appIndex]; |         let appIcon = this._items[appIndex]; | ||||||
| @@ -167,7 +158,7 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|             return; |             return; | ||||||
|  |  | ||||||
|         window.delete(global.get_current_time()); |         window.delete(global.get_current_time()); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _quitApplication(appIndex) { |     _quitApplication(appIndex) { | ||||||
|         let appIcon = this._items[appIndex]; |         let appIcon = this._items[appIndex]; | ||||||
| @@ -175,7 +166,7 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|             return; |             return; | ||||||
|  |  | ||||||
|         appIcon.app.request_quit(); |         appIcon.app.request_quit(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _keyPressHandler(keysym, action) { |     _keyPressHandler(keysym, action) { | ||||||
|         if (action == Meta.KeyBindingAction.SWITCH_GROUP) { |         if (action == Meta.KeyBindingAction.SWITCH_GROUP) { | ||||||
| @@ -214,7 +205,7 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         return Clutter.EVENT_STOP; |         return Clutter.EVENT_STOP; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _scrollHandler(direction) { |     _scrollHandler(direction) { | ||||||
|         if (direction == Clutter.ScrollDirection.UP) { |         if (direction == Clutter.ScrollDirection.UP) { | ||||||
| @@ -244,7 +235,7 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|                     this._select(this._next()); |                     this._select(this._next()); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _itemActivatedHandler(n) { |     _itemActivatedHandler(n) { | ||||||
|         // If the user clicks on the selected app, activate the |         // If the user clicks on the selected app, activate the | ||||||
| @@ -254,24 +245,24 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|             this._select(n, this._currentWindow); |             this._select(n, this._currentWindow); | ||||||
|         else |         else | ||||||
|             this._select(n); |             this._select(n); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _itemEnteredHandler(n) { |     _itemEnteredHandler(n) { | ||||||
|         this._select(n); |         this._select(n); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _windowActivated(thumbnailList, n) { |     _windowActivated(thumbnailList, n) { | ||||||
|         let appIcon = this._items[this._selectedIndex]; |         let appIcon = this._items[this._selectedIndex]; | ||||||
|         Main.activateWindow(appIcon.cachedWindows[n]); |         Main.activateWindow(appIcon.cachedWindows[n]); | ||||||
|         this.fadeAndDestroy(); |         this.fadeAndDestroy(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _windowEntered(thumbnailList, n) { |     _windowEntered(thumbnailList, n) { | ||||||
|         if (!this.mouseActive) |         if (!this.mouseActive) | ||||||
|             return; |             return; | ||||||
|  |  | ||||||
|         this._select(this._selectedIndex, n); |         this._select(this._selectedIndex, n); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _windowRemoved(thumbnailList, n) { |     _windowRemoved(thumbnailList, n) { | ||||||
|         let appIcon = this._items[this._selectedIndex]; |         let appIcon = this._items[this._selectedIndex]; | ||||||
| @@ -282,7 +273,7 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|             let newIndex = Math.min(n, appIcon.cachedWindows.length - 1); |             let newIndex = Math.min(n, appIcon.cachedWindows.length - 1); | ||||||
|             this._select(this._selectedIndex, newIndex); |             this._select(this._selectedIndex, newIndex); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _finish(timestamp) { |     _finish(timestamp) { | ||||||
|         let appIcon = this._items[this._selectedIndex]; |         let appIcon = this._items[this._selectedIndex]; | ||||||
| @@ -291,17 +282,17 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|         else if (appIcon.cachedWindows[this._currentWindow]) |         else if (appIcon.cachedWindows[this._currentWindow]) | ||||||
|             Main.activateWindow(appIcon.cachedWindows[this._currentWindow], timestamp); |             Main.activateWindow(appIcon.cachedWindows[this._currentWindow], timestamp); | ||||||
|  |  | ||||||
|         this.parent(); |         super._finish(timestamp); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDestroy() { |     _onDestroy() { | ||||||
|         this.parent(); |         super._onDestroy(); | ||||||
|  |  | ||||||
|         if (this._thumbnails) |         if (this._thumbnails) | ||||||
|             this._destroyThumbnails(); |             this._destroyThumbnails(); | ||||||
|         if (this._thumbnailTimeoutId != 0) |         if (this._thumbnailTimeoutId != 0) | ||||||
|             Mainloop.source_remove(this._thumbnailTimeoutId); |             Mainloop.source_remove(this._thumbnailTimeoutId); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * _select: |      * _select: | ||||||
| @@ -357,7 +348,7 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|                 this._timeoutPopupThumbnails.bind(this)); |                 this._timeoutPopupThumbnails.bind(this)); | ||||||
|             GLib.Source.set_name_by_id(this._thumbnailTimeoutId, '[gnome-shell] this._timeoutPopupThumbnails'); |             GLib.Source.set_name_by_id(this._thumbnailTimeoutId, '[gnome-shell] this._timeoutPopupThumbnails'); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _timeoutPopupThumbnails() { |     _timeoutPopupThumbnails() { | ||||||
|         if (!this._thumbnails) |         if (!this._thumbnails) | ||||||
| @@ -365,7 +356,7 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|         this._thumbnailTimeoutId = 0; |         this._thumbnailTimeoutId = 0; | ||||||
|         this._thumbnailsFocused = false; |         this._thumbnailsFocused = false; | ||||||
|         return GLib.SOURCE_REMOVE; |         return GLib.SOURCE_REMOVE; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _destroyThumbnails() { |     _destroyThumbnails() { | ||||||
|         let thumbnailsActor = this._thumbnails; |         let thumbnailsActor = this._thumbnails; | ||||||
| @@ -379,9 +370,9 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|                            } |                            } | ||||||
|                          }); |                          }); | ||||||
|         this._thumbnails = null; |         this._thumbnails = null; | ||||||
|         if  (this._switcherList._items[this._selectedIndex]) |         if (this._switcherList._items[this._selectedIndex]) | ||||||
|             this._switcherList._items[this._selectedIndex].remove_accessible_state (Atk.StateType.EXPANDED); |             this._switcherList._items[this._selectedIndex].remove_accessible_state (Atk.StateType.EXPANDED); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _createThumbnails() { |     _createThumbnails() { | ||||||
|         this._thumbnails = new ThumbnailList (this._items[this._selectedIndex].cachedWindows); |         this._thumbnails = new ThumbnailList (this._items[this._selectedIndex].cachedWindows); | ||||||
| @@ -411,10 +402,8 @@ var AppSwitcherPopup = new Lang.Class({ | |||||||
|     } |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var CyclerHighlight = new Lang.Class({ | class CyclerHighlight { | ||||||
|     Name: 'CyclerHighlight', |     constructor() { | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         this._window = null; |         this._window = null; | ||||||
|  |  | ||||||
|         this.actor = new St.Widget({ layout_manager: new Clutter.BinLayout() }); |         this.actor = new St.Widget({ layout_manager: new Clutter.BinLayout() }); | ||||||
| @@ -434,7 +423,7 @@ var CyclerHighlight = new Lang.Class({ | |||||||
|         this.actor.connect('notify::allocation', |         this.actor.connect('notify::allocation', | ||||||
|                            this._onAllocationChanged.bind(this)); |                            this._onAllocationChanged.bind(this)); | ||||||
|         this.actor.connect('destroy', this._onDestroy.bind(this)); |         this.actor.connect('destroy', this._onDestroy.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     set window(w) { |     set window(w) { | ||||||
|         if (this._window == w) |         if (this._window == w) | ||||||
| @@ -452,7 +441,7 @@ var CyclerHighlight = new Lang.Class({ | |||||||
|             windowActor.hide(); |             windowActor.hide(); | ||||||
|  |  | ||||||
|         this._clone.source = windowActor; |         this._clone.source = windowActor; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onAllocationChanged() { |     _onAllocationChanged() { | ||||||
|         if (!this._window) { |         if (!this._window) { | ||||||
| @@ -465,35 +454,31 @@ var CyclerHighlight = new Lang.Class({ | |||||||
|             this._highlight.set_position(rect.x - x, rect.y - y); |             this._highlight.set_position(rect.x - x, rect.y - y); | ||||||
|             this._highlight.show(); |             this._highlight.show(); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDestroy() { |     _onDestroy() { | ||||||
|         this.window = null; |         this.window = null; | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
|  |  | ||||||
| // We don't show an actual popup, so just provide what SwitcherPopup | // We don't show an actual popup, so just provide what SwitcherPopup | ||||||
| // expects instead of inheriting from SwitcherList | // expects instead of inheriting from SwitcherList | ||||||
| var CyclerList = new Lang.Class({ | var CyclerList = GObject.registerClass({ | ||||||
|     Name: 'CyclerList', |  | ||||||
|     Extends: St.Widget, |  | ||||||
|     Signals: { 'item-activated': { param_types: [GObject.TYPE_INT] }, |     Signals: { 'item-activated': { param_types: [GObject.TYPE_INT] }, | ||||||
|                'item-entered': { param_types: [GObject.TYPE_INT] }, |                'item-entered': { param_types: [GObject.TYPE_INT] }, | ||||||
|                'item-removed': { param_types: [GObject.TYPE_INT] }, |                'item-removed': { param_types: [GObject.TYPE_INT] }, | ||||||
|                'item-highlighted': { param_types: [GObject.TYPE_INT] } }, |                'item-highlighted': { param_types: [GObject.TYPE_INT] } }, | ||||||
|  | }, class CyclerList extends St.Widget { | ||||||
|     highlight(index, justOutline) { |     highlight(index, justOutline) { | ||||||
|         this.emit('item-highlighted', index); |         this.emit('item-highlighted', index); | ||||||
|     } |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var CyclerPopup = new Lang.Class({ | var CyclerPopup = GObject.registerClass({ | ||||||
|     Name: 'CyclerPopup', |     GTypeFlags: GObject.TypeFlags.ABSTRACT | ||||||
|     Extends: SwitcherPopup.SwitcherPopup, | }, class CyclerPopup extends SwitcherPopup.SwitcherPopup { | ||||||
|     Abstract: true, |  | ||||||
|  |  | ||||||
|     _init() { |     _init() { | ||||||
|         this.parent(); |         super._init(); | ||||||
|  |  | ||||||
|         this._items = this._getWindows(); |         this._items = this._getWindows(); | ||||||
|  |  | ||||||
| @@ -507,12 +492,12 @@ var CyclerPopup = new Lang.Class({ | |||||||
|         this._switcherList.connect('item-highlighted', (list, index) => { |         this._switcherList.connect('item-highlighted', (list, index) => { | ||||||
|             this._highlightItem(index); |             this._highlightItem(index); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _highlightItem(index, justOutline) { |     _highlightItem(index, justOutline) { | ||||||
|         this._highlight.window = this._items[index]; |         this._highlight.window = this._items[index]; | ||||||
|         global.window_group.set_child_above_sibling(this._highlight.actor, null); |         global.window_group.set_child_above_sibling(this._highlight.actor, null); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _finish() { |     _finish() { | ||||||
|         let window = this._items[this._selectedIndex]; |         let window = this._items[this._selectedIndex]; | ||||||
| @@ -537,25 +522,23 @@ var CyclerPopup = new Lang.Class({ | |||||||
|             Main.wm.actionMoveWindow(window, ws); |             Main.wm.actionMoveWindow(window, ws); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         this.parent(); |         super._finish(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDestroy() { |     _onDestroy() { | ||||||
|         this._highlight.actor.destroy(); |         this._highlight.actor.destroy(); | ||||||
|  |  | ||||||
|         this.parent(); |         super._onDestroy(); | ||||||
|     } |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  |  | ||||||
| var GroupCyclerPopup = new Lang.Class({ | var GroupCyclerPopup = GObject.registerClass( | ||||||
|     Name: 'GroupCyclerPopup', | class GroupCyclerPopup extends CyclerPopup { | ||||||
|     Extends: CyclerPopup, |  | ||||||
|  |  | ||||||
|     _getWindows() { |     _getWindows() { | ||||||
|         let app = Shell.WindowTracker.get_default().focus_app; |         let app = Shell.WindowTracker.get_default().focus_app; | ||||||
|         return app ? app.get_windows() : []; |         return app ? app.get_windows() : []; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _keyPressHandler(keysym, action) { |     _keyPressHandler(keysym, action) { | ||||||
|         if (action == Meta.KeyBindingAction.CYCLE_GROUP) |         if (action == Meta.KeyBindingAction.CYCLE_GROUP) | ||||||
| @@ -569,12 +552,10 @@ var GroupCyclerPopup = new Lang.Class({ | |||||||
|     } |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var WindowSwitcherPopup = new Lang.Class({ | var WindowSwitcherPopup = GObject.registerClass( | ||||||
|     Name: 'WindowSwitcherPopup', | class WindowSwitcherPopup extends SwitcherPopup.SwitcherPopup { | ||||||
|     Extends: SwitcherPopup.SwitcherPopup, |  | ||||||
|  |  | ||||||
|     _init() { |     _init() { | ||||||
|         this.parent(); |         super._init(); | ||||||
|         this._settings = new Gio.Settings({ schema_id: 'org.gnome.shell.window-switcher' }); |         this._settings = new Gio.Settings({ schema_id: 'org.gnome.shell.window-switcher' }); | ||||||
|  |  | ||||||
|         let windows = this._getWindowList(); |         let windows = this._getWindowList(); | ||||||
| @@ -585,7 +566,7 @@ var WindowSwitcherPopup = new Lang.Class({ | |||||||
|         let mode = this._settings.get_enum('app-icon-mode'); |         let mode = this._settings.get_enum('app-icon-mode'); | ||||||
|         this._switcherList = new WindowList(windows, mode); |         this._switcherList = new WindowList(windows, mode); | ||||||
|         this._items = this._switcherList.icons; |         this._items = this._switcherList.icons; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _getWindowList() { |     _getWindowList() { | ||||||
|         let workspace = null; |         let workspace = null; | ||||||
| @@ -597,7 +578,7 @@ var WindowSwitcherPopup = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         return getWindows(workspace); |         return getWindows(workspace); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _closeWindow(windowIndex) { |     _closeWindow(windowIndex) { | ||||||
|         let windowIcon = this._items[windowIndex]; |         let windowIcon = this._items[windowIndex]; | ||||||
| @@ -605,7 +586,7 @@ var WindowSwitcherPopup = new Lang.Class({ | |||||||
|             return; |             return; | ||||||
|  |  | ||||||
|         windowIcon.window.delete(global.get_current_time()); |         windowIcon.window.delete(global.get_current_time()); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _keyPressHandler(keysym, action) { |     _keyPressHandler(keysym, action) { | ||||||
|         if (action == Meta.KeyBindingAction.SWITCH_WINDOWS) { |         if (action == Meta.KeyBindingAction.SWITCH_WINDOWS) { | ||||||
| @@ -624,23 +605,21 @@ var WindowSwitcherPopup = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         return Clutter.EVENT_STOP; |         return Clutter.EVENT_STOP; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _finish() { |     _finish() { | ||||||
|         Main.activateWindow(this._items[this._selectedIndex].window); |         Main.activateWindow(this._items[this._selectedIndex].window); | ||||||
|  |  | ||||||
|         this.parent(); |         super._finish(); | ||||||
|     } |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var WindowCyclerPopup = new Lang.Class({ | var WindowCyclerPopup = GObject.registerClass( | ||||||
|     Name: 'WindowCyclerPopup', | class WindowCyclerPopup extends CyclerPopup { | ||||||
|     Extends: CyclerPopup, |  | ||||||
|  |  | ||||||
|     _init() { |     _init() { | ||||||
|         this._settings = new Gio.Settings({ schema_id: 'org.gnome.shell.window-switcher' }); |         this._settings = new Gio.Settings({ schema_id: 'org.gnome.shell.window-switcher' }); | ||||||
|         this.parent(); |         super._init(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _getWindows() { |     _getWindows() { | ||||||
|         let workspace = null; |         let workspace = null; | ||||||
| @@ -652,7 +631,7 @@ var WindowCyclerPopup = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         return getWindows(workspace); |         return getWindows(workspace); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _keyPressHandler(keysym, action) { |     _keyPressHandler(keysym, action) { | ||||||
|         if (action == Meta.KeyBindingAction.CYCLE_WINDOWS) |         if (action == Meta.KeyBindingAction.CYCLE_WINDOWS) | ||||||
| @@ -666,12 +645,10 @@ var WindowCyclerPopup = new Lang.Class({ | |||||||
|     } |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var AppIcon = new Lang.Class({ | var AppIcon = GObject.registerClass( | ||||||
|     Name: 'AppIcon', | class AppIcon extends St.BoxLayout { | ||||||
|     Extends: St.BoxLayout, |  | ||||||
|  |  | ||||||
|     _init(app) { |     _init(app) { | ||||||
|         this.parent({ style_class: 'alt-tab-app', |         super._init({ style_class: 'alt-tab-app', | ||||||
|                       vertical: true }); |                       vertical: true }); | ||||||
|  |  | ||||||
|         this.app = app; |         this.app = app; | ||||||
| @@ -681,28 +658,26 @@ var AppIcon = new Lang.Class({ | |||||||
|         this.add(this._iconBin, { x_fill: false, y_fill: false } ); |         this.add(this._iconBin, { x_fill: false, y_fill: false } ); | ||||||
|         this.label = new St.Label({ text: this.app.get_name() }); |         this.label = new St.Label({ text: this.app.get_name() }); | ||||||
|         this.add(this.label, { x_fill: false }); |         this.add(this.label, { x_fill: false }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     set_size(size) { |     set_size(size) { | ||||||
|         this.icon = this.app.create_icon_texture(size); |         this.icon = this.app.create_icon_texture(size); | ||||||
|         this._iconBin.child = this.icon; |         this._iconBin.child = this.icon; | ||||||
|         this._iconBin.set_size(size, size); |         this._iconBin.set_size(size, size); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_get_preferred_width(forHeight) { |     vfunc_get_preferred_width(forHeight) { | ||||||
|         let [minWidth, ] = this.parent(forHeight); |         let [minWidth, ] = super.vfunc_get_preferred_width(forHeight); | ||||||
|  |  | ||||||
|         minWidth = Math.max(minWidth, forHeight); |         minWidth = Math.max(minWidth, forHeight); | ||||||
|         return [minWidth, minWidth]; |         return [minWidth, minWidth]; | ||||||
|     } |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var AppSwitcher = new Lang.Class({ | var AppSwitcher = GObject.registerClass( | ||||||
|     Name: 'AppSwitcher', | class AppSwitcher extends SwitcherPopup.SwitcherList { | ||||||
|     Extends: SwitcherPopup.SwitcherList, |  | ||||||
|  |  | ||||||
|     _init(apps, altTabPopup) { |     _init(apps, altTabPopup) { | ||||||
|         this.parent(true); |         super._init(true); | ||||||
|  |  | ||||||
|         this.icons = []; |         this.icons = []; | ||||||
|         this._arrows = []; |         this._arrows = []; | ||||||
| @@ -736,7 +711,7 @@ var AppSwitcher = new Lang.Class({ | |||||||
|         this._mouseTimeOutId = 0; |         this._mouseTimeOutId = 0; | ||||||
|  |  | ||||||
|         this.connect('destroy', this._onDestroy.bind(this)); |         this.connect('destroy', this._onDestroy.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDestroy() { |     _onDestroy() { | ||||||
|         if (this._mouseTimeOutId != 0) |         if (this._mouseTimeOutId != 0) | ||||||
| @@ -745,7 +720,7 @@ var AppSwitcher = new Lang.Class({ | |||||||
|         this.icons.forEach(icon => { |         this.icons.forEach(icon => { | ||||||
|             icon.app.disconnect(icon._stateChangedId); |             icon.app.disconnect(icon._stateChangedId); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _setIconSize() { |     _setIconSize() { | ||||||
|         let j = 0; |         let j = 0; | ||||||
| @@ -786,16 +761,16 @@ var AppSwitcher = new Lang.Class({ | |||||||
|                 break; |                 break; | ||||||
|             this.icons[i].set_size(iconSize); |             this.icons[i].set_size(iconSize); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_get_preferred_height(forWidth) { |     vfunc_get_preferred_height(forWidth) { | ||||||
|         this._setIconSize(); |         this._setIconSize(); | ||||||
|         return this.parent(forWidth); |         return super.vfunc_get_preferred_height(forWidth); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_allocate(box, flags) { |     vfunc_allocate(box, flags) { | ||||||
|         // Allocate the main list items |         // Allocate the main list items | ||||||
|         this.parent(box, flags); |         super.vfunc_allocate(box, flags); | ||||||
|  |  | ||||||
|         let contentBox = this.get_theme_node().get_content_box(box); |         let contentBox = this.get_theme_node().get_content_box(box); | ||||||
|  |  | ||||||
| @@ -812,7 +787,7 @@ var AppSwitcher = new Lang.Class({ | |||||||
|             childBox.y2 = childBox.y1 + arrowHeight; |             childBox.y2 = childBox.y1 + arrowHeight; | ||||||
|             this._arrows[i].allocate(childBox, flags); |             this._arrows[i].allocate(childBox, flags); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     // We override SwitcherList's _onItemEnter method to delay |     // We override SwitcherList's _onItemEnter method to delay | ||||||
|     // activation when the thumbnail list is open |     // activation when the thumbnail list is open | ||||||
| @@ -829,14 +804,14 @@ var AppSwitcher = new Lang.Class({ | |||||||
|             GLib.Source.set_name_by_id(this._mouseTimeOutId, '[gnome-shell] this._enterItem'); |             GLib.Source.set_name_by_id(this._mouseTimeOutId, '[gnome-shell] this._enterItem'); | ||||||
|         } else |         } else | ||||||
|            this._itemEntered(index); |            this._itemEntered(index); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _enterItem(index) { |     _enterItem(index) { | ||||||
|         let [x, y, mask] = global.get_pointer(); |         let [x, y, mask] = global.get_pointer(); | ||||||
|         let pickedActor = global.stage.get_actor_at_pos(Clutter.PickMode.ALL, x, y); |         let pickedActor = global.stage.get_actor_at_pos(Clutter.PickMode.ALL, x, y); | ||||||
|         if (this._items[index].contains(pickedActor)) |         if (this._items[index].contains(pickedActor)) | ||||||
|             this._itemEntered(index); |             this._itemEntered(index); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     // We override SwitcherList's highlight() method to also deal with |     // We override SwitcherList's highlight() method to also deal with | ||||||
|     // the AppSwitcher->ThumbnailList arrows. Apps with only 1 window |     // the AppSwitcher->ThumbnailList arrows. Apps with only 1 window | ||||||
| @@ -853,7 +828,7 @@ var AppSwitcher = new Lang.Class({ | |||||||
|                 this._arrows[this._curApp].remove_style_pseudo_class('highlighted'); |                 this._arrows[this._curApp].remove_style_pseudo_class('highlighted'); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         this.parent(n, justOutline); |         super.highlight(n, justOutline); | ||||||
|         this._curApp = n; |         this._curApp = n; | ||||||
|  |  | ||||||
|         if (this._curApp != -1) { |         if (this._curApp != -1) { | ||||||
| @@ -862,7 +837,7 @@ var AppSwitcher = new Lang.Class({ | |||||||
|             else |             else | ||||||
|                 this._arrows[this._curApp].add_style_pseudo_class('highlighted'); |                 this._arrows[this._curApp].add_style_pseudo_class('highlighted'); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _addIcon(appIcon) { |     _addIcon(appIcon) { | ||||||
|         this.icons.push(appIcon); |         this.icons.push(appIcon); | ||||||
| @@ -883,7 +858,7 @@ var AppSwitcher = new Lang.Class({ | |||||||
|             arrow.hide(); |             arrow.hide(); | ||||||
|         else |         else | ||||||
|             item.add_accessible_state (Atk.StateType.EXPANDABLE); |             item.add_accessible_state (Atk.StateType.EXPANDABLE); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _removeIcon(app) { |     _removeIcon(app) { | ||||||
|         let index = this.icons.findIndex(icon => { |         let index = this.icons.findIndex(icon => { | ||||||
| @@ -894,15 +869,13 @@ var AppSwitcher = new Lang.Class({ | |||||||
|  |  | ||||||
|         this.icons.splice(index, 1); |         this.icons.splice(index, 1); | ||||||
|         this.removeItem(index); |         this.removeItem(index); | ||||||
|     }, |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var ThumbnailList = new Lang.Class({ | var ThumbnailList = GObject.registerClass( | ||||||
|     Name: 'ThumbnailList', | class ThumbnailList extends SwitcherPopup.SwitcherList { | ||||||
|     Extends: SwitcherPopup.SwitcherList, |  | ||||||
|  |  | ||||||
|     _init(windows) { |     _init(windows) { | ||||||
|         this.parent(false); |         super._init(false); | ||||||
|  |  | ||||||
|         this._labels = new Array(); |         this._labels = new Array(); | ||||||
|         this._thumbnailBins = new Array(); |         this._thumbnailBins = new Array(); | ||||||
| @@ -935,7 +908,7 @@ var ThumbnailList = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this.connect('destroy', this._onDestroy.bind(this)); |         this.connect('destroy', this._onDestroy.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     addClones(availHeight) { |     addClones(availHeight) { | ||||||
|         if (!this._thumbnailBins.length) |         if (!this._thumbnailBins.length) | ||||||
| @@ -968,7 +941,7 @@ var ThumbnailList = new Lang.Class({ | |||||||
|  |  | ||||||
|         // Make sure we only do this once |         // Make sure we only do this once | ||||||
|         this._thumbnailBins = new Array(); |         this._thumbnailBins = new Array(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _removeThumbnail(source, clone) { |     _removeThumbnail(source, clone) { | ||||||
|         let index = this._clones.indexOf(clone); |         let index = this._clones.indexOf(clone); | ||||||
| @@ -984,23 +957,20 @@ var ThumbnailList = new Lang.Class({ | |||||||
|             this.highlight(SwitcherPopup.mod(index, this._clones.length)); |             this.highlight(SwitcherPopup.mod(index, this._clones.length)); | ||||||
|         else |         else | ||||||
|             this.destroy(); |             this.destroy(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDestroy() { |     _onDestroy() { | ||||||
|         this._clones.forEach(clone => { |         this._clones.forEach(clone => { | ||||||
|             if (clone.source) |             if (clone.source) | ||||||
|                 clone.source.disconnect(clone._destroyId); |                 clone.source.disconnect(clone._destroyId); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var WindowIcon = new Lang.Class({ | var WindowIcon = GObject.registerClass( | ||||||
|     Name: 'WindowIcon', | class WindowIcon extends St.BoxLayout { | ||||||
|     Extends: St.BoxLayout, |  | ||||||
|  |  | ||||||
|     _init(window, mode) { |     _init(window, mode) { | ||||||
|         this.parent({ style_class: 'alt-tab-app', |         super._init({ style_class: 'alt-tab-app', | ||||||
|                       vertical: true }); |                       vertical: true }); | ||||||
|  |  | ||||||
|         this.window = window; |         this.window = window; | ||||||
| @@ -1041,7 +1011,7 @@ var WindowIcon = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this._icon.set_size(size * scaleFactor, size * scaleFactor); |         this._icon.set_size(size * scaleFactor, size * scaleFactor); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _createAppIcon(app, size) { |     _createAppIcon(app, size) { | ||||||
|         let appIcon = app ? app.create_icon_texture(size) |         let appIcon = app ? app.create_icon_texture(size) | ||||||
| @@ -1054,12 +1024,10 @@ var WindowIcon = new Lang.Class({ | |||||||
|     } |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var WindowList = new Lang.Class({ | var WindowList = GObject.registerClass( | ||||||
|     Name: 'WindowList', | class WindowList extends SwitcherPopup.SwitcherList { | ||||||
|     Extends: SwitcherPopup.SwitcherList, |  | ||||||
|  |  | ||||||
|     _init(windows, mode) { |     _init(windows, mode) { | ||||||
|         this.parent(true); |         super._init(true); | ||||||
|  |  | ||||||
|         this._label = new St.Label({ x_align: Clutter.ActorAlign.CENTER, |         this._label = new St.Label({ x_align: Clutter.ActorAlign.CENTER, | ||||||
|                                      y_align: Clutter.ActorAlign.CENTER }); |                                      y_align: Clutter.ActorAlign.CENTER }); | ||||||
| @@ -1081,16 +1049,16 @@ var WindowList = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this.connect('destroy', this._onDestroy.bind(this)); |         this.connect('destroy', this._onDestroy.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDestroy() { |     _onDestroy() { | ||||||
|         this.icons.forEach(icon => { |         this.icons.forEach(icon => { | ||||||
|             icon.window.disconnect(icon._unmanagedSignalId); |             icon.window.disconnect(icon._unmanagedSignalId); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_get_preferred_height(forWidth) { |     vfunc_get_preferred_height(forWidth) { | ||||||
|         let [minHeight, natHeight] = this.parent(forWidth); |         let [minHeight, natHeight] = super.vfunc_get_preferred_height(forWidth); | ||||||
|  |  | ||||||
|         let spacing = this.get_theme_node().get_padding(St.Side.BOTTOM); |         let spacing = this.get_theme_node().get_padding(St.Side.BOTTOM); | ||||||
|         let [labelMin, labelNat] = this._label.get_preferred_height(-1); |         let [labelMin, labelNat] = this._label.get_preferred_height(-1); | ||||||
| @@ -1099,7 +1067,7 @@ var WindowList = new Lang.Class({ | |||||||
|         natHeight += labelNat + spacing; |         natHeight += labelNat + spacing; | ||||||
|  |  | ||||||
|         return [minHeight, natHeight]; |         return [minHeight, natHeight]; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     vfunc_allocate(box, flags) { |     vfunc_allocate(box, flags) { | ||||||
|         let themeNode = this.get_theme_node(); |         let themeNode = this.get_theme_node(); | ||||||
| @@ -1117,19 +1085,19 @@ var WindowList = new Lang.Class({ | |||||||
|         childBox.x2 = box.x2; |         childBox.x2 = box.x2; | ||||||
|         childBox.y1 = box.y1; |         childBox.y1 = box.y1; | ||||||
|         childBox.y2 = box.y2 - totalLabelHeight; |         childBox.y2 = box.y2 - totalLabelHeight; | ||||||
|         this.parent(childBox, flags); |         super.vfunc_allocate(childBox, flags); | ||||||
|  |  | ||||||
|         // Hooking up the parent vfunc will call this.set_allocation() with |         // Hooking up the parent vfunc will call this.set_allocation() with | ||||||
|         // the height without the label height, so call it again with the |         // the height without the label height, so call it again with the | ||||||
|         // correct size here. |         // correct size here. | ||||||
|         this.set_allocation(box, flags); |         this.set_allocation(box, flags); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     highlight(index, justOutline) { |     highlight(index, justOutline) { | ||||||
|         this.parent(index, justOutline); |         super.highlight(index, justOutline); | ||||||
|  |  | ||||||
|         this._label.set_text(index == -1 ? '' : this.icons[index].label.text); |         this._label.set_text(index == -1 ? '' : this.icons[index].label.text); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _removeWindow(window) { |     _removeWindow(window) { | ||||||
|         let index = this.icons.findIndex(icon => { |         let index = this.icons.findIndex(icon => { | ||||||
|   | |||||||
| @@ -1,20 +1,27 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const GLib = imports.gi.GLib; | const { GLib, Gio, St } = imports.gi; | ||||||
| const Lang = imports.lang; |  | ||||||
| const Mainloop = imports.mainloop; | const Mainloop = imports.mainloop; | ||||||
| const St = imports.gi.St; |  | ||||||
| const Signals = imports.signals; | const Tweener = imports.ui.tweener; | ||||||
| const Atk = imports.gi.Atk; |  | ||||||
|  |  | ||||||
| var ANIMATED_ICON_UPDATE_TIMEOUT = 16; | var ANIMATED_ICON_UPDATE_TIMEOUT = 16; | ||||||
|  | var SPINNER_ANIMATION_TIME = 0.3; | ||||||
|  | var SPINNER_ANIMATION_DELAY = 1.0; | ||||||
|  |  | ||||||
| var Animation = new Lang.Class({ | var Animation = class { | ||||||
|     Name: 'Animation', |     constructor(file, width, height, speed) { | ||||||
|  |  | ||||||
|     _init(file, width, height, speed) { |  | ||||||
|         this.actor = new St.Bin(); |         this.actor = new St.Bin(); | ||||||
|  |         this.actor.set_size(width, height); | ||||||
|         this.actor.connect('destroy', this._onDestroy.bind(this)); |         this.actor.connect('destroy', this._onDestroy.bind(this)); | ||||||
|  |         this.actor.connect('notify::size', this._syncAnimationSize.bind(this)); | ||||||
|  |         this.actor.connect('resource-scale-changed', | ||||||
|  |             this._loadFile.bind(this, file, width, height)); | ||||||
|  |  | ||||||
|  |         let themeContext = St.ThemeContext.get_for_stage(global.stage); | ||||||
|  |         this._scaleChangedId = themeContext.connect('notify::scale-factor', | ||||||
|  |             this._loadFile.bind(this, file, width, height)); | ||||||
|  |  | ||||||
|         this._speed = speed; |         this._speed = speed; | ||||||
|  |  | ||||||
|         this._isLoaded = false; |         this._isLoaded = false; | ||||||
| @@ -22,11 +29,8 @@ var Animation = new Lang.Class({ | |||||||
|         this._timeoutId = 0; |         this._timeoutId = 0; | ||||||
|         this._frame = 0; |         this._frame = 0; | ||||||
|  |  | ||||||
|         let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor; |         this._loadFile(file, width, height); | ||||||
|         this._animations = St.TextureCache.get_default().load_sliced_image (file, width, height, scaleFactor, |     } | ||||||
|                                                                             this._animationsLoaded.bind(this)); |  | ||||||
|         this.actor.set_child(this._animations); |  | ||||||
|     }, |  | ||||||
|  |  | ||||||
|     play() { |     play() { | ||||||
|         if (this._isLoaded && this._timeoutId == 0) { |         if (this._isLoaded && this._timeoutId == 0) { | ||||||
| @@ -38,7 +42,7 @@ var Animation = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this._isPlaying = true; |         this._isPlaying = true; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     stop() { |     stop() { | ||||||
|         if (this._timeoutId > 0) { |         if (this._timeoutId > 0) { | ||||||
| @@ -47,7 +51,24 @@ var Animation = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this._isPlaying = false; |         this._isPlaying = false; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|  |     _loadFile(file, width, height) { | ||||||
|  |         let [validResourceScale, resourceScale] = this.actor.get_resource_scale(); | ||||||
|  |  | ||||||
|  |         this._isLoaded = false; | ||||||
|  |         this.actor.destroy_all_children(); | ||||||
|  |  | ||||||
|  |         if (!validResourceScale) | ||||||
|  |             return; | ||||||
|  |  | ||||||
|  |         let texture_cache = St.TextureCache.get_default(); | ||||||
|  |         let scaleFactor = St.ThemeContext.get_for_stage(global.stage).scale_factor; | ||||||
|  |         this._animations = texture_cache.load_sliced_image(file, width, height, | ||||||
|  |                                                            scaleFactor, resourceScale, | ||||||
|  |                                                            this._animationsLoaded.bind(this)); | ||||||
|  |         this.actor.set_child(this._animations); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     _showFrame(frame) { |     _showFrame(frame) { | ||||||
|         let oldFrameActor = this._animations.get_child_at_index(this._frame); |         let oldFrameActor = this._animations.get_child_at_index(this._frame); | ||||||
| @@ -59,30 +80,94 @@ var Animation = new Lang.Class({ | |||||||
|         let newFrameActor = this._animations.get_child_at_index(this._frame); |         let newFrameActor = this._animations.get_child_at_index(this._frame); | ||||||
|         if (newFrameActor) |         if (newFrameActor) | ||||||
|             newFrameActor.show(); |             newFrameActor.show(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _update() { |     _update() { | ||||||
|         this._showFrame(this._frame + 1); |         this._showFrame(this._frame + 1); | ||||||
|         return GLib.SOURCE_CONTINUE; |         return GLib.SOURCE_CONTINUE; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|  |     _syncAnimationSize() { | ||||||
|  |         if (!this._isLoaded) | ||||||
|  |             return; | ||||||
|  |  | ||||||
|  |         let [width, height] = this.actor.get_size(); | ||||||
|  |  | ||||||
|  |         for (let i = 0; i < this._animations.get_n_children(); ++i) | ||||||
|  |             this._animations.get_child_at_index(i).set_size(width, height); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     _animationsLoaded() { |     _animationsLoaded() { | ||||||
|         this._isLoaded = this._animations.get_n_children() > 0; |         this._isLoaded = this._animations.get_n_children() > 0; | ||||||
|  |  | ||||||
|  |         this._syncAnimationSize(); | ||||||
|  |  | ||||||
|         if (this._isPlaying) |         if (this._isPlaying) | ||||||
|             this.play(); |             this.play(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDestroy() { |     _onDestroy() { | ||||||
|         this.stop(); |         this.stop(); | ||||||
|     } |  | ||||||
| }); |  | ||||||
|  |  | ||||||
| var AnimatedIcon = new Lang.Class({ |         let themeContext = St.ThemeContext.get_for_stage(global.stage); | ||||||
|     Name: 'AnimatedIcon', |         if (this._scaleChangedId) | ||||||
|     Extends: Animation, |             themeContext.disconnect(this._scaleChangedId); | ||||||
|  |         this._scaleChangedId = 0; | ||||||
|     _init(file, size) { |  | ||||||
|         this.parent(file, size, size, ANIMATED_ICON_UPDATE_TIMEOUT); |  | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
|  |  | ||||||
|  | var AnimatedIcon = class extends Animation { | ||||||
|  |     constructor(file, size) { | ||||||
|  |         super(file, size, size, ANIMATED_ICON_UPDATE_TIMEOUT); | ||||||
|  |     } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | var Spinner = class extends AnimatedIcon { | ||||||
|  |     constructor(size, animate=false) { | ||||||
|  |         let file = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/process-working.svg'); | ||||||
|  |         super(file, size); | ||||||
|  |  | ||||||
|  |         this.actor.opacity = 0; | ||||||
|  |         this._animate = animate; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     _onDestroy() { | ||||||
|  |         this._animate = false; | ||||||
|  |         super._onDestroy(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     play() { | ||||||
|  |         Tweener.removeTweens(this.actor); | ||||||
|  |  | ||||||
|  |         if (this._animate) { | ||||||
|  |             super.play(); | ||||||
|  |             Tweener.addTween(this.actor, { | ||||||
|  |                 opacity: 255, | ||||||
|  |                 delay: SPINNER_ANIMATION_DELAY, | ||||||
|  |                 time: SPINNER_ANIMATION_TIME, | ||||||
|  |                 transition: 'linear' | ||||||
|  |             }); | ||||||
|  |         } else { | ||||||
|  |             this.actor.opacity = 255; | ||||||
|  |             super.play(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     stop() { | ||||||
|  |         Tweener.removeTweens(this.actor); | ||||||
|  |  | ||||||
|  |         if (this._animate) { | ||||||
|  |             Tweener.addTween(this.actor, { | ||||||
|  |                 opacity: 0, | ||||||
|  |                 time: SPINNER_ANIMATION_TIME, | ||||||
|  |                 transition: 'linear', | ||||||
|  |                 onComplete: () => { | ||||||
|  |                     this.stop(false); | ||||||
|  |                 } | ||||||
|  |             }); | ||||||
|  |         } else { | ||||||
|  |             this.actor.opacity = 0; | ||||||
|  |             super.stop(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | }; | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Shell = imports.gi.Shell; | const Shell = imports.gi.Shell; | ||||||
| const Lang = imports.lang; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
|  |  | ||||||
| const Main = imports.ui.main; | const Main = imports.ui.main; | ||||||
| @@ -15,53 +14,63 @@ const RENAMED_DESKTOP_IDS = { | |||||||
|     'epiphany.desktop': 'org.gnome.Epiphany.desktop', |     'epiphany.desktop': 'org.gnome.Epiphany.desktop', | ||||||
|     'evolution.desktop': 'org.gnome.Evolution.desktop', |     'evolution.desktop': 'org.gnome.Evolution.desktop', | ||||||
|     'file-roller.desktop': 'org.gnome.FileRoller.desktop', |     'file-roller.desktop': 'org.gnome.FileRoller.desktop', | ||||||
|  |     'five-or-more.desktop': 'org.gnome.five-or-more.desktop', | ||||||
|  |     'four-in-a-row.desktop': 'org.gnome.Four-in-a-row.desktop', | ||||||
|     'gcalctool.desktop': 'org.gnome.Calculator.desktop', |     'gcalctool.desktop': 'org.gnome.Calculator.desktop', | ||||||
|     'geary.desktop': 'org.gnome.Geary.desktop', |     'geary.desktop': 'org.gnome.Geary.desktop', | ||||||
|     'gedit.desktop': 'org.gnome.gedit.desktop', |     'gedit.desktop': 'org.gnome.gedit.desktop', | ||||||
|     'glchess.desktop': 'gnome-chess.desktop', |     'glchess.desktop': 'org.gnome.Chess.desktop', | ||||||
|     'glines.desktop': 'five-or-more.desktop', |     'glines.desktop': 'org.gnome.five-or-more.desktop', | ||||||
|     'gnect.desktop': 'four-in-a-row.desktop', |     'gnect.desktop': 'org.gnome.Four-in-a-row.desktop', | ||||||
|     'gnibbles.desktop': 'org.gnome.Nibbles.desktop', |     'gnibbles.desktop': 'org.gnome.Nibbles.desktop', | ||||||
|     'gnobots2.desktop': 'gnome-robots.desktop', |     'gnobots2.desktop': 'org.gnome.Robots.desktop', | ||||||
|     'gnome-boxes.desktop': 'org.gnome.Boxes.desktop', |     'gnome-boxes.desktop': 'org.gnome.Boxes.desktop', | ||||||
|     'gnome-calculator.desktop': 'org.gnome.Calculator.desktop', |     'gnome-calculator.desktop': 'org.gnome.Calculator.desktop', | ||||||
|  |     'gnome-chess.desktop': 'org.gnome.Chess.desktop', | ||||||
|     'gnome-clocks.desktop': 'org.gnome.clocks.desktop', |     'gnome-clocks.desktop': 'org.gnome.clocks.desktop', | ||||||
|     'gnome-contacts.desktop': 'org.gnome.Contacts.desktop', |     'gnome-contacts.desktop': 'org.gnome.Contacts.desktop', | ||||||
|     'gnome-documents.desktop': 'org.gnome.Documents.desktop', |     'gnome-documents.desktop': 'org.gnome.Documents.desktop', | ||||||
|     'gnome-font-viewer.desktop': 'org.gnome.font-viewer.desktop', |     'gnome-font-viewer.desktop': 'org.gnome.font-viewer.desktop', | ||||||
|  |     'gnome-klotski.desktop': 'org.gnome.Klotski.desktop', | ||||||
|     'gnome-nibbles.desktop': 'org.gnome.Nibbles.desktop', |     'gnome-nibbles.desktop': 'org.gnome.Nibbles.desktop', | ||||||
|  |     'gnome-mahjongg.desktop': 'org.gnome.Mahjongg.desktop', | ||||||
|  |     'gnome-mines.desktop': 'org.gnome.Mines.desktop', | ||||||
|     'gnome-music.desktop': 'org.gnome.Music.desktop', |     'gnome-music.desktop': 'org.gnome.Music.desktop', | ||||||
|     'gnome-photos.desktop': 'org.gnome.Photos.desktop', |     'gnome-photos.desktop': 'org.gnome.Photos.desktop', | ||||||
|  |     'gnome-robots.desktop': 'org.gnome.Robots.desktop', | ||||||
|     'gnome-screenshot.desktop': 'org.gnome.Screenshot.desktop', |     'gnome-screenshot.desktop': 'org.gnome.Screenshot.desktop', | ||||||
|     'gnome-software.desktop': 'org.gnome.Software.desktop', |     'gnome-software.desktop': 'org.gnome.Software.desktop', | ||||||
|     'gnome-terminal.desktop': 'org.gnome.Terminal.desktop', |     'gnome-terminal.desktop': 'org.gnome.Terminal.desktop', | ||||||
|  |     'gnome-tetravex.desktop': 'org.gnome.Tetravex.desktop', | ||||||
|     'gnome-tweaks.desktop': 'org.gnome.tweaks.desktop', |     'gnome-tweaks.desktop': 'org.gnome.tweaks.desktop', | ||||||
|     'gnome-weather.desktop': 'org.gnome.Weather.Application.desktop', |     'gnome-weather.desktop': 'org.gnome.Weather.desktop', | ||||||
|     'gnomine.desktop': 'gnome-mines.desktop', |     'gnomine.desktop': 'org.gnome.Mines.desktop', | ||||||
|     'gnotravex.desktop': 'gnome-tetravex.desktop', |     'gnotravex.desktop': 'org.gnome.Tetravex.desktop', | ||||||
|     'gnotski.desktop': 'gnome-klotski.desktop', |     'gnotski.desktop': 'org.gnome.Klotski.desktop', | ||||||
|     'gtali.desktop': 'tali.desktop', |     'gtali.desktop': 'org.gnome.Tali.desktop', | ||||||
|  |     'iagno.desktop': 'org.gnome.Reversi.desktop', | ||||||
|     'nautilus.desktop': 'org.gnome.Nautilus.desktop', |     'nautilus.desktop': 'org.gnome.Nautilus.desktop', | ||||||
|  |     'org.gnome.gnome-2048.desktop': 'org.gnome.TwentyFortyEight.desktop', | ||||||
|  |     'org.gnome.taquin.desktop': 'org.gnome.Taquin.desktop', | ||||||
|  |     'org.gnome.Weather.Application.desktop': 'org.gnome.Weather.desktop', | ||||||
|     'polari.desktop': 'org.gnome.Polari.desktop', |     'polari.desktop': 'org.gnome.Polari.desktop', | ||||||
|  |     'tali.desktop': 'org.gnome.Tali.desktop', | ||||||
|     'totem.desktop': 'org.gnome.Totem.desktop', |     'totem.desktop': 'org.gnome.Totem.desktop', | ||||||
|     'evince.desktop': 'org.gnome.Evince.desktop', |     'evince.desktop': 'org.gnome.Evince.desktop', | ||||||
| }; | }; | ||||||
|  |  | ||||||
| var AppFavorites = new Lang.Class({ | class AppFavorites { | ||||||
|     Name: 'AppFavorites', |     constructor() { | ||||||
|  |         this.FAVORITE_APPS_KEY = 'favorite-apps'; | ||||||
|     FAVORITE_APPS_KEY: 'favorite-apps', |  | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         this._favorites = {}; |         this._favorites = {}; | ||||||
|         global.settings.connect('changed::' + this.FAVORITE_APPS_KEY, this._onFavsChanged.bind(this)); |         global.settings.connect('changed::' + this.FAVORITE_APPS_KEY, this._onFavsChanged.bind(this)); | ||||||
|         this.reload(); |         this.reload(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onFavsChanged() { |     _onFavsChanged() { | ||||||
|         this.reload(); |         this.reload(); | ||||||
|         this.emit('changed'); |         this.emit('changed'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     reload() { |     reload() { | ||||||
|         let ids = global.settings.get_strv(this.FAVORITE_APPS_KEY); |         let ids = global.settings.get_strv(this.FAVORITE_APPS_KEY); | ||||||
| @@ -89,29 +98,29 @@ var AppFavorites = new Lang.Class({ | |||||||
|             let app = apps[i]; |             let app = apps[i]; | ||||||
|             this._favorites[app.get_id()] = app; |             this._favorites[app.get_id()] = app; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _getIds() { |     _getIds() { | ||||||
|         let ret = []; |         let ret = []; | ||||||
|         for (let id in this._favorites) |         for (let id in this._favorites) | ||||||
|             ret.push(id); |             ret.push(id); | ||||||
|         return ret; |         return ret; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getFavoriteMap() { |     getFavoriteMap() { | ||||||
|         return this._favorites; |         return this._favorites; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getFavorites() { |     getFavorites() { | ||||||
|         let ret = []; |         let ret = []; | ||||||
|         for (let id in this._favorites) |         for (let id in this._favorites) | ||||||
|             ret.push(this._favorites[id]); |             ret.push(this._favorites[id]); | ||||||
|         return ret; |         return ret; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     isFavorite(appId) { |     isFavorite(appId) { | ||||||
|         return appId in this._favorites; |         return appId in this._favorites; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _addFavorite(appId, pos) { |     _addFavorite(appId, pos) { | ||||||
|         if (appId in this._favorites) |         if (appId in this._favorites) | ||||||
| @@ -129,7 +138,7 @@ var AppFavorites = new Lang.Class({ | |||||||
|             ids.splice(pos, 0, appId); |             ids.splice(pos, 0, appId); | ||||||
|         global.settings.set_strv(this.FAVORITE_APPS_KEY, ids); |         global.settings.set_strv(this.FAVORITE_APPS_KEY, ids); | ||||||
|         return true; |         return true; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     addFavoriteAtPos(appId, pos) { |     addFavoriteAtPos(appId, pos) { | ||||||
|         if (!this._addFavorite(appId, pos)) |         if (!this._addFavorite(appId, pos)) | ||||||
| @@ -143,25 +152,25 @@ var AppFavorites = new Lang.Class({ | |||||||
|                                        this._removeFavorite(appId); |                                        this._removeFavorite(appId); | ||||||
|                                    } |                                    } | ||||||
|                                  }); |                                  }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     addFavorite(appId) { |     addFavorite(appId) { | ||||||
|         this.addFavoriteAtPos(appId, -1); |         this.addFavoriteAtPos(appId, -1); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     moveFavoriteToPos(appId, pos) { |     moveFavoriteToPos(appId, pos) { | ||||||
|         this._removeFavorite(appId); |         this._removeFavorite(appId); | ||||||
|         this._addFavorite(appId, pos); |         this._addFavorite(appId, pos); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _removeFavorite(appId) { |     _removeFavorite(appId) { | ||||||
|         if (!appId in this._favorites) |         if (!(appId in this._favorites)) | ||||||
|             return false; |             return false; | ||||||
|  |  | ||||||
|         let ids = this._getIds().filter(id => id != appId); |         let ids = this._getIds().filter(id => id != appId); | ||||||
|         global.settings.set_strv(this.FAVORITE_APPS_KEY, ids); |         global.settings.set_strv(this.FAVORITE_APPS_KEY, ids); | ||||||
|         return true; |         return true; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     removeFavorite(appId) { |     removeFavorite(appId) { | ||||||
|         let ids = this._getIds(); |         let ids = this._getIds(); | ||||||
| @@ -178,7 +187,7 @@ var AppFavorites = new Lang.Class({ | |||||||
|                                    } |                                    } | ||||||
|                                  }); |                                  }); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(AppFavorites.prototype); | Signals.addSignalMethods(AppFavorites.prototype); | ||||||
|  |  | ||||||
| var appFavoritesInstance = null; | var appFavoritesInstance = null; | ||||||
|   | |||||||
| @@ -1,10 +1,4 @@ | |||||||
| const Clutter = imports.gi.Clutter; | const { Clutter, Gio, GLib, GObject, Meta, Shell, St } = imports.gi; | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const GLib = imports.gi.GLib; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Meta = imports.gi.Meta; |  | ||||||
| const Shell = imports.gi.Shell; |  | ||||||
| const St = imports.gi.St; |  | ||||||
|  |  | ||||||
| const Main = imports.ui.main; | const Main = imports.ui.main; | ||||||
| const ModalDialog = imports.ui.modalDialog; | const ModalDialog = imports.ui.modalDialog; | ||||||
| @@ -19,12 +13,11 @@ var AudioDevice = { | |||||||
|  |  | ||||||
| const AudioDeviceSelectionIface = loadInterfaceXML('org.gnome.Shell.AudioDeviceSelection'); | const AudioDeviceSelectionIface = loadInterfaceXML('org.gnome.Shell.AudioDeviceSelection'); | ||||||
|  |  | ||||||
| var AudioDeviceSelectionDialog = new Lang.Class({ | var AudioDeviceSelectionDialog = GObject.registerClass({ | ||||||
|     Name: 'AudioDeviceSelectionDialog', |     Signals: { 'device-selected': { param_types: [GObject.TYPE_UINT] } } | ||||||
|     Extends: ModalDialog.ModalDialog, | }, class AudioDeviceSelectionDialog extends ModalDialog.ModalDialog { | ||||||
|  |  | ||||||
|     _init(devices) { |     _init(devices) { | ||||||
|         this.parent({ styleClass: 'audio-device-selection-dialog' }); |         super._init({ styleClass: 'audio-device-selection-dialog' }); | ||||||
|  |  | ||||||
|         this._deviceItems = {}; |         this._deviceItems = {}; | ||||||
|  |  | ||||||
| @@ -39,11 +32,7 @@ var AudioDeviceSelectionDialog = new Lang.Class({ | |||||||
|  |  | ||||||
|         if (this._selectionBox.get_n_children() < 2) |         if (this._selectionBox.get_n_children() < 2) | ||||||
|             throw new Error('Too few devices for a selection'); |             throw new Error('Too few devices for a selection'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     destroy() { |  | ||||||
|         this.parent(); |  | ||||||
|     }, |  | ||||||
|  |  | ||||||
|     _buildLayout(devices) { |     _buildLayout(devices) { | ||||||
|         let title = new St.Label({ style_class: 'audio-selection-title', |         let title = new St.Label({ style_class: 'audio-selection-title', | ||||||
| @@ -56,12 +45,13 @@ var AudioDeviceSelectionDialog = new Lang.Class({ | |||||||
|         this._selectionBox = new St.BoxLayout({ style_class: 'audio-selection-box' }); |         this._selectionBox = new St.BoxLayout({ style_class: 'audio-selection-box' }); | ||||||
|         this.contentLayout.add(this._selectionBox, { expand: true }); |         this.contentLayout.add(this._selectionBox, { expand: true }); | ||||||
|  |  | ||||||
|         this.addButton({ action: this._openSettings.bind(this), |         if (Main.sessionMode.allowSettings) | ||||||
|                          label: _("Sound Settings") }); |             this.addButton({ action: this._openSettings.bind(this), | ||||||
|  |                              label: _("Sound Settings") }); | ||||||
|         this.addButton({ action: this.close.bind(this), |         this.addButton({ action: this.close.bind(this), | ||||||
|                          label: _("Cancel"), |                          label: _("Cancel"), | ||||||
|                          key: Clutter.Escape }); |                          key: Clutter.Escape }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _getDeviceLabel(device) { |     _getDeviceLabel(device) { | ||||||
|         switch(device) { |         switch(device) { | ||||||
| @@ -74,7 +64,7 @@ var AudioDeviceSelectionDialog = new Lang.Class({ | |||||||
|             default: |             default: | ||||||
|                 return null; |                 return null; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _getDeviceIcon(device) { |     _getDeviceIcon(device) { | ||||||
|         switch(device) { |         switch(device) { | ||||||
| @@ -87,7 +77,7 @@ var AudioDeviceSelectionDialog = new Lang.Class({ | |||||||
|             default: |             default: | ||||||
|                 return null; |                 return null; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _addDevice(device) { |     _addDevice(device) { | ||||||
|         let box = new St.BoxLayout({ style_class: 'audio-selection-device-box', |         let box = new St.BoxLayout({ style_class: 'audio-selection-device-box', | ||||||
| @@ -117,7 +107,7 @@ var AudioDeviceSelectionDialog = new Lang.Class({ | |||||||
|             this.close(); |             this.close(); | ||||||
|             Main.overview.hide(); |             Main.overview.hide(); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _openSettings() { |     _openSettings() { | ||||||
|         let desktopFile = 'gnome-sound-panel.desktop' |         let desktopFile = 'gnome-sound-panel.desktop' | ||||||
| @@ -134,21 +124,19 @@ var AudioDeviceSelectionDialog = new Lang.Class({ | |||||||
|     } |     } | ||||||
| }); | }); | ||||||
|  |  | ||||||
| var AudioDeviceSelectionDBus = new Lang.Class({ | var AudioDeviceSelectionDBus = class AudioDeviceSelectionDBus { | ||||||
|     Name: 'AudioDeviceSelectionDBus', |     constructor() { | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         this._audioSelectionDialog = null; |         this._audioSelectionDialog = null; | ||||||
|  |  | ||||||
|         this._dbusImpl = Gio.DBusExportedObject.wrapJSObject(AudioDeviceSelectionIface, this); |         this._dbusImpl = Gio.DBusExportedObject.wrapJSObject(AudioDeviceSelectionIface, this); | ||||||
|         this._dbusImpl.export(Gio.DBus.session, '/org/gnome/Shell/AudioDeviceSelection'); |         this._dbusImpl.export(Gio.DBus.session, '/org/gnome/Shell/AudioDeviceSelection'); | ||||||
|  |  | ||||||
|         Gio.DBus.session.own_name('org.gnome.Shell.AudioDeviceSelection', Gio.BusNameOwnerFlags.REPLACE, null, null); |         Gio.DBus.session.own_name('org.gnome.Shell.AudioDeviceSelection', Gio.BusNameOwnerFlags.REPLACE, null, null); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDialogClosed() { |     _onDialogClosed() { | ||||||
|         this._audioSelectionDialog = null; |         this._audioSelectionDialog = null; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onDeviceSelected(dialog, device) { |     _onDeviceSelected(dialog, device) { | ||||||
|         let connection = this._dbusImpl.get_connection(); |         let connection = this._dbusImpl.get_connection(); | ||||||
| @@ -161,7 +149,7 @@ var AudioDeviceSelectionDBus = new Lang.Class({ | |||||||
|                                info ? info.name : null, |                                info ? info.name : null, | ||||||
|                                'DeviceSelected', |                                'DeviceSelected', | ||||||
|                                GLib.Variant.new('(s)', [deviceName])); |                                GLib.Variant.new('(s)', [deviceName])); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     OpenAsync(params, invocation) { |     OpenAsync(params, invocation) { | ||||||
|         if (this._audioSelectionDialog) { |         if (this._audioSelectionDialog) { | ||||||
| @@ -189,7 +177,7 @@ var AudioDeviceSelectionDBus = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._audioSelectionDialog = dialog; |         this._audioSelectionDialog = dialog; | ||||||
|         invocation.return_value(null); |         invocation.return_value(null); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     CloseAsync(params, invocation) { |     CloseAsync(params, invocation) { | ||||||
|         if (this._audioSelectionDialog && |         if (this._audioSelectionDialog && | ||||||
| @@ -198,4 +186,4 @@ var AudioDeviceSelectionDBus = new Lang.Class({ | |||||||
|  |  | ||||||
|         invocation.return_value(null); |         invocation.return_value(null); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
|   | |||||||
| @@ -93,13 +93,7 @@ | |||||||
| //     MetaBackgroundImage         MetaBackgroundImage | //     MetaBackgroundImage         MetaBackgroundImage | ||||||
| //     MetaBackgroundImage         MetaBackgroundImage | //     MetaBackgroundImage         MetaBackgroundImage | ||||||
|  |  | ||||||
| const Clutter = imports.gi.Clutter; | const { Clutter, GDesktopEnums, Gio, GLib, GnomeDesktop, Meta } = imports.gi; | ||||||
| const GDesktopEnums = imports.gi.GDesktopEnums; |  | ||||||
| const Gio = imports.gi.Gio; |  | ||||||
| const GLib = imports.gi.GLib; |  | ||||||
| const GnomeDesktop = imports.gi.GnomeDesktop; |  | ||||||
| const Lang = imports.lang; |  | ||||||
| const Meta = imports.gi.Meta; |  | ||||||
| const Signals = imports.signals; | const Signals = imports.signals; | ||||||
|  |  | ||||||
| const LoginManager = imports.misc.loginManager; | const LoginManager = imports.misc.loginManager; | ||||||
| @@ -138,14 +132,12 @@ function _fileEqual0(file1, file2) { | |||||||
|     return file1.equal(file2); |     return file1.equal(file2); | ||||||
| } | } | ||||||
|  |  | ||||||
| var BackgroundCache = new Lang.Class({ | var BackgroundCache = class BackgroundCache { | ||||||
|     Name: 'BackgroundCache', |     constructor() { | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         this._fileMonitors = {}; |         this._fileMonitors = {}; | ||||||
|         this._backgroundSources = {}; |         this._backgroundSources = {}; | ||||||
|         this._animations = {}; |         this._animations = {}; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     monitorFile(file) { |     monitorFile(file) { | ||||||
|         let key = file.hash(); |         let key = file.hash(); | ||||||
| @@ -163,7 +155,7 @@ var BackgroundCache = new Lang.Class({ | |||||||
|                         }); |                         }); | ||||||
|  |  | ||||||
|         this._fileMonitors[key] = monitor; |         this._fileMonitors[key] = monitor; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getAnimation(params) { |     getAnimation(params) { | ||||||
|         params = Params.parse(params, { file: null, |         params = Params.parse(params, { file: null, | ||||||
| @@ -195,7 +187,7 @@ var BackgroundCache = new Lang.Class({ | |||||||
|                 GLib.Source.set_name_by_id(id, '[gnome-shell] params.onLoaded'); |                 GLib.Source.set_name_by_id(id, '[gnome-shell] params.onLoaded'); | ||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getBackgroundSource(layoutManager, settingsSchema) { |     getBackgroundSource(layoutManager, settingsSchema) { | ||||||
|         // The layoutManager is always the same one; we pass in it since |         // The layoutManager is always the same one; we pass in it since | ||||||
| @@ -209,7 +201,7 @@ var BackgroundCache = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         return this._backgroundSources[settingsSchema]; |         return this._backgroundSources[settingsSchema]; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     releaseBackgroundSource(settingsSchema) { |     releaseBackgroundSource(settingsSchema) { | ||||||
|         if (settingsSchema in this._backgroundSources) { |         if (settingsSchema in this._backgroundSources) { | ||||||
| @@ -221,7 +213,7 @@ var BackgroundCache = new Lang.Class({ | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(BackgroundCache.prototype); | Signals.addSignalMethods(BackgroundCache.prototype); | ||||||
|  |  | ||||||
| function getBackgroundCache() { | function getBackgroundCache() { | ||||||
| @@ -230,10 +222,8 @@ function getBackgroundCache() { | |||||||
|     return _backgroundCache; |     return _backgroundCache; | ||||||
| } | } | ||||||
|  |  | ||||||
| var Background = new Lang.Class({ | var Background = class Background { | ||||||
|     Name: 'Background', |     constructor(params) { | ||||||
|  |  | ||||||
|     _init(params) { |  | ||||||
|         params = Params.parse(params, { monitorIndex: 0, |         params = Params.parse(params, { monitorIndex: 0, | ||||||
|                                         layoutManager: Main.layoutManager, |                                         layoutManager: Main.layoutManager, | ||||||
|                                         settings: null, |                                         settings: null, | ||||||
| @@ -267,14 +257,15 @@ var Background = new Lang.Class({ | |||||||
|                 this._refreshAnimation(); |                 this._refreshAnimation(); | ||||||
|             }); |             }); | ||||||
|  |  | ||||||
|         this._settingsChangedSignalId = this._settings.connect('changed', () => { |         this._settingsChangedSignalId = | ||||||
|             this.emit('changed'); |             this._settings.connect('changed', this._emitChangedSignal.bind(this)); | ||||||
|         }); |  | ||||||
|  |  | ||||||
|         this._load(); |         this._load(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     destroy() { |     destroy() { | ||||||
|  |         this.background = null; | ||||||
|  |  | ||||||
|         this._cancellable.cancel(); |         this._cancellable.cancel(); | ||||||
|         this._removeAnimationTimeout(); |         this._removeAnimationTimeout(); | ||||||
|  |  | ||||||
| @@ -298,12 +289,28 @@ var Background = new Lang.Class({ | |||||||
|         if (this._settingsChangedSignalId != 0) |         if (this._settingsChangedSignalId != 0) | ||||||
|             this._settings.disconnect(this._settingsChangedSignalId); |             this._settings.disconnect(this._settingsChangedSignalId); | ||||||
|         this._settingsChangedSignalId = 0; |         this._settingsChangedSignalId = 0; | ||||||
|     }, |  | ||||||
|  |         if (this._changedIdleId) { | ||||||
|  |             GLib.source_remove(this._changedIdleId); | ||||||
|  |             this._changedIdleId = 0; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     _emitChangedSignal() { | ||||||
|  |         if (this._changedIdleId) | ||||||
|  |             return; | ||||||
|  |  | ||||||
|  |         this._changedIdleId = GLib.idle_add(GLib.PRIORITY_DEFAULT, () => { | ||||||
|  |             this._changedIdleId = 0; | ||||||
|  |             this.emit('changed'); | ||||||
|  |             return GLib.SOURCE_REMOVE; | ||||||
|  |         }); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     updateResolution() { |     updateResolution() { | ||||||
|         if (this._animation) |         if (this._animation) | ||||||
|             this._refreshAnimation(); |             this._refreshAnimation(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _refreshAnimation() { |     _refreshAnimation() { | ||||||
|         if (!this._animation) |         if (!this._animation) | ||||||
| @@ -311,7 +318,7 @@ var Background = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._removeAnimationTimeout(); |         this._removeAnimationTimeout(); | ||||||
|         this._updateAnimation(); |         this._updateAnimation(); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _setLoaded() { |     _setLoaded() { | ||||||
|         if (this.isLoaded) |         if (this.isLoaded) | ||||||
| @@ -324,7 +331,7 @@ var Background = new Lang.Class({ | |||||||
|             return GLib.SOURCE_REMOVE; |             return GLib.SOURCE_REMOVE; | ||||||
|         }); |         }); | ||||||
|         GLib.Source.set_name_by_id(id, '[gnome-shell] this.emit'); |         GLib.Source.set_name_by_id(id, '[gnome-shell] this.emit'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _loadPattern() { |     _loadPattern() { | ||||||
|         let colorString, res, color, secondColor; |         let colorString, res, color, secondColor; | ||||||
| @@ -340,7 +347,7 @@ var Background = new Lang.Class({ | |||||||
|             this.background.set_color(color); |             this.background.set_color(color); | ||||||
|         else |         else | ||||||
|             this.background.set_gradient(shadingType, color, secondColor); |             this.background.set_gradient(shadingType, color, secondColor); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _watchFile(file) { |     _watchFile(file) { | ||||||
|         let key = file.hash(); |         let key = file.hash(); | ||||||
| @@ -353,18 +360,18 @@ var Background = new Lang.Class({ | |||||||
|                                                if (changedFile.equal(file)) { |                                                if (changedFile.equal(file)) { | ||||||
|                                                    let imageCache = Meta.BackgroundImageCache.get_default(); |                                                    let imageCache = Meta.BackgroundImageCache.get_default(); | ||||||
|                                                    imageCache.purge(changedFile); |                                                    imageCache.purge(changedFile); | ||||||
|                                                    this.emit('changed'); |                                                    this._emitChangedSignal(); | ||||||
|                                                } |                                                } | ||||||
|                                            }); |                                            }); | ||||||
|         this._fileWatches[key] = signalId; |         this._fileWatches[key] = signalId; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _removeAnimationTimeout() { |     _removeAnimationTimeout() { | ||||||
|         if (this._updateAnimationTimeoutId) { |         if (this._updateAnimationTimeoutId) { | ||||||
|             GLib.source_remove(this._updateAnimationTimeoutId); |             GLib.source_remove(this._updateAnimationTimeoutId); | ||||||
|             this._updateAnimationTimeoutId = 0; |             this._updateAnimationTimeoutId = 0; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateAnimation() { |     _updateAnimation() { | ||||||
|         this._updateAnimationTimeoutId = 0; |         this._updateAnimationTimeoutId = 0; | ||||||
| @@ -404,7 +411,7 @@ var Background = new Lang.Class({ | |||||||
|                 }); |                 }); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _queueUpdateAnimation() { |     _queueUpdateAnimation() { | ||||||
|         if (this._updateAnimationTimeoutId != 0) |         if (this._updateAnimationTimeoutId != 0) | ||||||
| @@ -433,7 +440,7 @@ var Background = new Lang.Class({ | |||||||
|                                                           return GLib.SOURCE_REMOVE; |                                                           return GLib.SOURCE_REMOVE; | ||||||
|                                                       }); |                                                       }); | ||||||
|         GLib.Source.set_name_by_id(this._updateAnimationTimeoutId, '[gnome-shell] this._updateAnimation'); |         GLib.Source.set_name_by_id(this._updateAnimationTimeoutId, '[gnome-shell] this._updateAnimation'); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _loadAnimation(file) { |     _loadAnimation(file) { | ||||||
|         this._cache.getAnimation({ file: file, |         this._cache.getAnimation({ file: file, | ||||||
| @@ -450,7 +457,7 @@ var Background = new Lang.Class({ | |||||||
|                                        this._watchFile(file); |                                        this._watchFile(file); | ||||||
|                                    } |                                    } | ||||||
|                                  }); |                                  }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _loadImage(file) { |     _loadImage(file) { | ||||||
|         this.background.set_file(file, this._style); |         this.background.set_file(file, this._style); | ||||||
| @@ -466,14 +473,14 @@ var Background = new Lang.Class({ | |||||||
|                 image.disconnect(id); |                 image.disconnect(id); | ||||||
|             }); |             }); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _loadFile(file) { |     _loadFile(file) { | ||||||
|         if (file.get_basename().endsWith('.xml')) |         if (file.get_basename().endsWith('.xml')) | ||||||
|             this._loadAnimation(file); |             this._loadAnimation(file); | ||||||
|         else |         else | ||||||
|             this._loadImage(file); |             this._loadImage(file); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _load() { |     _load() { | ||||||
|         this._cache = getBackgroundCache(); |         this._cache = getBackgroundCache(); | ||||||
| @@ -486,16 +493,14 @@ var Background = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         this._loadFile(this._file); |         this._loadFile(this._file); | ||||||
|     }, |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(Background.prototype); | Signals.addSignalMethods(Background.prototype); | ||||||
|  |  | ||||||
| let _systemBackground; | let _systemBackground; | ||||||
|  |  | ||||||
| var SystemBackground = new Lang.Class({ | var SystemBackground = class SystemBackground { | ||||||
|     Name: 'SystemBackground', |     constructor() { | ||||||
|  |  | ||||||
|     _init() { |  | ||||||
|         let file = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/noise-texture.png'); |         let file = Gio.File.new_for_uri('resource:///org/gnome/shell/theme/noise-texture.png'); | ||||||
|  |  | ||||||
|         if (_systemBackground == null) { |         if (_systemBackground == null) { | ||||||
| @@ -524,14 +529,12 @@ var SystemBackground = new Lang.Class({ | |||||||
|                 image = null; |                 image = null; | ||||||
|             }); |             }); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(SystemBackground.prototype); | Signals.addSignalMethods(SystemBackground.prototype); | ||||||
|  |  | ||||||
| var BackgroundSource = new Lang.Class({ | var BackgroundSource = class BackgroundSource { | ||||||
|     Name: 'BackgroundSource', |     constructor(layoutManager, settingsSchema) { | ||||||
|  |  | ||||||
|     _init(layoutManager, settingsSchema) { |  | ||||||
|         // Allow override the background image setting for performance testing |         // Allow override the background image setting for performance testing | ||||||
|         this._layoutManager = layoutManager; |         this._layoutManager = layoutManager; | ||||||
|         this._overrideImage = GLib.getenv('SHELL_BACKGROUND_IMAGE'); |         this._overrideImage = GLib.getenv('SHELL_BACKGROUND_IMAGE'); | ||||||
| @@ -542,7 +545,7 @@ var BackgroundSource = new Lang.Class({ | |||||||
|         this._monitorsChangedId = |         this._monitorsChangedId = | ||||||
|             monitorManager.connect('monitors-changed', |             monitorManager.connect('monitors-changed', | ||||||
|                                    this._onMonitorsChanged.bind(this)); |                                    this._onMonitorsChanged.bind(this)); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _onMonitorsChanged() { |     _onMonitorsChanged() { | ||||||
|         for (let monitorIndex in this._backgrounds) { |         for (let monitorIndex in this._backgrounds) { | ||||||
| @@ -556,7 +559,7 @@ var BackgroundSource = new Lang.Class({ | |||||||
|                 delete this._backgrounds[monitorIndex]; |                 delete this._backgrounds[monitorIndex]; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     getBackground(monitorIndex) { |     getBackground(monitorIndex) { | ||||||
|         let file = null; |         let file = null; | ||||||
| @@ -603,7 +606,7 @@ var BackgroundSource = new Lang.Class({ | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         return this._backgrounds[monitorIndex]; |         return this._backgrounds[monitorIndex]; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     destroy() { |     destroy() { | ||||||
|         let monitorManager = Meta.MonitorManager.get(); |         let monitorManager = Meta.MonitorManager.get(); | ||||||
| @@ -617,12 +620,10 @@ var BackgroundSource = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._backgrounds = null; |         this._backgrounds = null; | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
|  |  | ||||||
| var Animation = new Lang.Class({ | var Animation = class Animation { | ||||||
|     Name: 'Animation', |     constructor(params) { | ||||||
|  |  | ||||||
|     _init(params) { |  | ||||||
|         params = Params.parse(params, { file: null }); |         params = Params.parse(params, { file: null }); | ||||||
|  |  | ||||||
|         this.file = params.file; |         this.file = params.file; | ||||||
| @@ -630,7 +631,7 @@ var Animation = new Lang.Class({ | |||||||
|         this.transitionProgress = 0.0; |         this.transitionProgress = 0.0; | ||||||
|         this.transitionDuration = 0.0; |         this.transitionDuration = 0.0; | ||||||
|         this.loaded = false; |         this.loaded = false; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     load(callback) { |     load(callback) { | ||||||
|         this._show = new GnomeDesktop.BGSlideShow({ filename: this.file.get_path() }); |         this._show = new GnomeDesktop.BGSlideShow({ filename: this.file.get_path() }); | ||||||
| @@ -640,7 +641,7 @@ var Animation = new Lang.Class({ | |||||||
|             if (callback) |             if (callback) | ||||||
|                 callback(); |                 callback(); | ||||||
|         }); |         }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     update(monitor) { |     update(monitor) { | ||||||
|         this.keyFrameFiles = []; |         this.keyFrameFiles = []; | ||||||
| @@ -661,14 +662,12 @@ var Animation = new Lang.Class({ | |||||||
|  |  | ||||||
|         if (filename2) |         if (filename2) | ||||||
|             this.keyFrameFiles.push(Gio.File.new_for_path(filename2)); |             this.keyFrameFiles.push(Gio.File.new_for_path(filename2)); | ||||||
|     }, |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(Animation.prototype); | Signals.addSignalMethods(Animation.prototype); | ||||||
|  |  | ||||||
| var BackgroundManager = new Lang.Class({ | var BackgroundManager = class BackgroundManager { | ||||||
|     Name: 'BackgroundManager', |     constructor(params) { | ||||||
|  |  | ||||||
|     _init(params) { |  | ||||||
|         params = Params.parse(params, { container: null, |         params = Params.parse(params, { container: null, | ||||||
|                                         layoutManager: Main.layoutManager, |                                         layoutManager: Main.layoutManager, | ||||||
|                                         monitorIndex: null, |                                         monitorIndex: null, | ||||||
| @@ -688,7 +687,7 @@ var BackgroundManager = new Lang.Class({ | |||||||
|  |  | ||||||
|         this.backgroundActor = this._createBackgroundActor(); |         this.backgroundActor = this._createBackgroundActor(); | ||||||
|         this._newBackgroundActor = null; |         this._newBackgroundActor = null; | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     destroy() { |     destroy() { | ||||||
|         let cache = getBackgroundCache(); |         let cache = getBackgroundCache(); | ||||||
| @@ -704,7 +703,7 @@ var BackgroundManager = new Lang.Class({ | |||||||
|             this.backgroundActor.destroy(); |             this.backgroundActor.destroy(); | ||||||
|             this.backgroundActor = null; |             this.backgroundActor = null; | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _swapBackgroundActor() { |     _swapBackgroundActor() { | ||||||
|         let oldBackgroundActor = this.backgroundActor; |         let oldBackgroundActor = this.backgroundActor; | ||||||
| @@ -717,11 +716,10 @@ var BackgroundManager = new Lang.Class({ | |||||||
|                            time: FADE_ANIMATION_TIME, |                            time: FADE_ANIMATION_TIME, | ||||||
|                            transition: 'easeOutQuad', |                            transition: 'easeOutQuad', | ||||||
|                            onComplete() { |                            onComplete() { | ||||||
|                                oldBackgroundActor.background.run_dispose(); |  | ||||||
|                                oldBackgroundActor.destroy(); |                                oldBackgroundActor.destroy(); | ||||||
|                            } |                            } | ||||||
|                          }); |                          }); | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _updateBackgroundActor() { |     _updateBackgroundActor() { | ||||||
|         if (this._newBackgroundActor) { |         if (this._newBackgroundActor) { | ||||||
| @@ -750,7 +748,7 @@ var BackgroundManager = new Lang.Class({ | |||||||
|                     this._swapBackgroundActor(); |                     this._swapBackgroundActor(); | ||||||
|                 }); |                 }); | ||||||
|         } |         } | ||||||
|     }, |     } | ||||||
|  |  | ||||||
|     _createBackgroundActor() { |     _createBackgroundActor() { | ||||||
|         let background = this._backgroundSource.getBackground(this._monitorIndex); |         let background = this._backgroundSource.getBackground(this._monitorIndex); | ||||||
| @@ -764,10 +762,8 @@ var BackgroundManager = new Lang.Class({ | |||||||
|  |  | ||||||
|         this._container.add_child(backgroundActor); |         this._container.add_child(backgroundActor); | ||||||
|  |  | ||||||
|         let monitor = this._layoutManager.monitors[this._monitorIndex]; |  | ||||||
|  |  | ||||||
|         backgroundActor.set_size(monitor.width, monitor.height); |  | ||||||
|         if (this._controlPosition) { |         if (this._controlPosition) { | ||||||
|  |             let monitor = this._layoutManager.monitors[this._monitorIndex]; | ||||||
|             backgroundActor.set_position(monitor.x, monitor.y); |             backgroundActor.set_position(monitor.x, monitor.y); | ||||||
|             backgroundActor.lower_bottom(); |             backgroundActor.lower_bottom(); | ||||||
|         } |         } | ||||||
| @@ -787,6 +783,6 @@ var BackgroundManager = new Lang.Class({ | |||||||
|         }); |         }); | ||||||
|  |  | ||||||
|         return backgroundActor; |         return backgroundActor; | ||||||
|     }, |     } | ||||||
| }); | }; | ||||||
| Signals.addSignalMethods(BackgroundManager.prototype); | Signals.addSignalMethods(BackgroundManager.prototype); | ||||||
|   | |||||||
| @@ -1,20 +1,14 @@ | |||||||
| // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | // -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- | ||||||
|  |  | ||||||
| const Clutter = imports.gi.Clutter; | const { Clutter, St } = imports.gi; | ||||||
| const Lang = imports.lang; |  | ||||||
| const St = imports.gi.St; |  | ||||||
| const Shell = imports.gi.Shell; |  | ||||||
|  |  | ||||||
| const BoxPointer = imports.ui.boxpointer; | const BoxPointer = imports.ui.boxpointer; | ||||||
| const Main = imports.ui.main; | const Main = imports.ui.main; | ||||||
| const PopupMenu = imports.ui.popupMenu; | const PopupMenu = imports.ui.popupMenu; | ||||||
|  |  | ||||||
| var BackgroundMenu = new Lang.Class({ | var BackgroundMenu = class BackgroundMenu extends PopupMenu.PopupMenu { | ||||||
|     Name: 'BackgroundMenu', |     constructor(layoutManager) { | ||||||
|     Extends: PopupMenu.PopupMenu, |         super(layoutManager.dummyCursor, 0, St.Side.TOP); | ||||||
|  |  | ||||||
|     _init(layoutManager) { |  | ||||||
|         this.parent(layoutManager.dummyCursor, 0, St.Side.TOP); |  | ||||||
|  |  | ||||||
|         this.addSettingsAction(_("Change Background…"), 'gnome-background-panel.desktop'); |         this.addSettingsAction(_("Change Background…"), 'gnome-background-panel.desktop'); | ||||||
|         this.addMenuItem(new PopupMenu.PopupSeparatorMenuItem()); |         this.addMenuItem(new PopupMenu.PopupSeparatorMenuItem()); | ||||||
| @@ -26,12 +20,12 @@ var BackgroundMenu = new Lang.Class({ | |||||||
|         layoutManager.uiGroup.add_actor(this.actor); |         layoutManager.uiGroup.add_actor(this.actor); | ||||||
|         this.actor.hide(); |         this.actor.hide(); | ||||||
|     } |     } | ||||||
| }); | }; | ||||||
|  |  | ||||||
| function addBackgroundMenu(actor, layoutManager) { | function addBackgroundMenu(actor, layoutManager) { | ||||||
|     actor.reactive = true; |     actor.reactive = true; | ||||||
|     actor._backgroundMenu = new BackgroundMenu(layoutManager); |     actor._backgroundMenu = new BackgroundMenu(layoutManager); | ||||||
|     actor._backgroundManager = new PopupMenu.PopupMenuManager({ actor: actor }); |     actor._backgroundManager = new PopupMenu.PopupMenuManager(actor); | ||||||
|     actor._backgroundManager.addMenu(actor._backgroundMenu); |     actor._backgroundManager.addMenu(actor._backgroundMenu); | ||||||
|  |  | ||||||
|     function openMenu(x, y) { |     function openMenu(x, y) { | ||||||
|   | |||||||