Compare commits
972 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| abaf233a07 | |||
| b251c98a4e | |||
| 23c8496e24 | |||
| 18220a7847 | |||
| a26698c377 | |||
| ac8cc42b7a | |||
| 7126f31d3f | |||
| 44db410dad | |||
| bc7b1082e7 | |||
| ea0bf9d56d | |||
| 6657bdd9b1 | |||
| 11871d343d | |||
| 12cf55d4fc | |||
| e4cf1392c9 | |||
| f2a54f4af0 | |||
| fce1a37e97 | |||
| 90e79dad75 | |||
| 8f8874370e | |||
| 3d67865ffc | |||
| 22a303842e | |||
| c20671f1db | |||
| 844dac439a | |||
| 5e781e6095 | |||
| 2b379b31cd | |||
| 8bb23179c4 | |||
| a8588ab507 | |||
| c80cd56f27 | |||
| 7743d9008d | |||
| 2ecf91e50a | |||
| d8c7367900 | |||
| 8a53b4bc8e | |||
| fc1f3b0142 | |||
| 814d63af28 | |||
| a9bfcf3c81 | |||
| fb8104ff86 | |||
| a0a28e7a94 | |||
| 9188d4b1c1 | |||
| d392547fd8 | |||
| 220bf3178c | |||
| c0692b6fc7 | |||
| 47ed13868f | |||
| 09d4b1a27a | |||
| 4e641adae9 | |||
| 568f5c7fc5 | |||
| a0ac24a42c | |||
| f69bd5601c | |||
| 37728cc7a3 | |||
| b4dbce385c | |||
| 9aeb04b4a6 | |||
| 3db4c60155 | |||
| c37c7e2354 | |||
| 4314159a0b | |||
| 7f4b942817 | |||
| c2342d5124 | |||
| dd55247380 | |||
| fe9407ca33 | |||
| 9376c68739 | |||
| 439541fac1 | |||
| dfae2aaf20 | |||
| 5ea8874583 | |||
| 07de9efe7c | |||
| c791135160 | |||
| 79fdf3a1f6 | |||
| 76353eceb3 | |||
| fb60189078 | |||
| 3c140ed479 | |||
| 5b4dfefcf7 | |||
| 033e5530c3 | |||
| 727d6ff166 | |||
| aa54bd329f | |||
| 692f43d8af | |||
| 263a23fcaa | |||
| bde89d4026 | |||
| b3cecdde7f | |||
| 5534232a1d | |||
| 4c7f546c60 | |||
| 1ca8695659 | |||
| e7363aaf8e | |||
| 6ccef50b7c | |||
| d7fb9bc6d2 | |||
| 41197334f0 | |||
| 74c25fdff6 | |||
| f6348736e8 | |||
| 208556b5aa | |||
| 58963de10f | |||
| 457c31fbaf | |||
| 690d6a67ef | |||
| 094cbadf91 | |||
| 760e3b99b0 | |||
| 042abd699d | |||
| f6b1546f8b | |||
| 2cc19c9f1e | |||
| 329cf07275 | |||
| 99da66dbf7 | |||
| 3c6aa9999b | |||
| 19724e3b69 | |||
| b96619d726 | |||
| c9aaeaee2a | |||
| 1b6def23d8 | |||
| c1172ab8b5 | |||
| 12860646d2 | |||
| 869bd0e2aa | |||
| 71929e8332 | |||
| fe285dc192 | |||
| 67066c339e | |||
| 759ed684e3 | |||
| 611a3300ba | |||
| 64c104a5c2 | |||
| f9857e102a | |||
| 9dc76c1caf | |||
| 68f867b914 | |||
| dd77f79b17 | |||
| e555b63931 | |||
| b33eb0135d | |||
| f9d7c75492 | |||
| a532f655c1 | |||
| 82588a7fc9 | |||
| 1f2d169b0d | |||
| 1c99736c16 | |||
| 050cb649c2 | |||
| 5612e99f1d | |||
| a520e3b2e9 | |||
| 380f65954d | |||
| 0f6ec6c196 | |||
| 857326b274 | |||
| 5e8a6f0bcb | |||
| a960f2ff30 | |||
| 5c3e1f182c | |||
| 84e1e722c0 | |||
| 4200de66ee | |||
| be4e861604 | |||
| 8f5a4106d3 | |||
| 145e9ec926 | |||
| 05c050b81e | |||
| 403c4ad9b9 | |||
| f065979b3f | |||
| 933617d5b1 | |||
| adbaef7dfb | |||
| fdf6a5b8f3 | |||
| 028b71a833 | |||
| b2b2951fb7 | |||
| dbed37e9ba | |||
| 0d3768d838 | |||
| be2546c27b | |||
| 6459eb40df | |||
| 555cb6888f | |||
| a00230829c | |||
| 1df5ab0851 | |||
| 26cb66c1e5 | |||
| 348e26564f | |||
| 1ed394e3ef | |||
| 2cf4fc8d0a | |||
| d6ffcd37d7 | |||
| 046c15736b | |||
| 6980e86d6a | |||
| 973cc76927 | |||
| 86c8c66b6e | |||
| a5b2a4fab9 | |||
| e7eb324f16 | |||
| 1157bff34b | |||
| 3a242e7fc1 | |||
| fe179556ad | |||
| c7a427a94c | |||
| ed114252e2 | |||
| 34f949dc72 | |||
| 1763c82ccc | |||
| 6d8804f08f | |||
| ed7e29589b | |||
| 7641fe7549 | |||
| c63fd21c8e | |||
| 281b3b8d07 | |||
| d6fe8fa2d5 | |||
| ffa887838f | |||
| 49f38c6a8b | |||
| 7a2ceeedf4 | |||
| b25f083433 | |||
| c45d586bbf | |||
| d193af8cc8 | |||
| bb88bd8695 | |||
| 73dbe62e48 | |||
| 1163cb842c | |||
| 15db716f04 | |||
| 9f8f805888 | |||
| 119f23a085 | |||
| aca274e9ee | |||
| 50e7b3aadf | |||
| e5e53c02b5 | |||
| 938db301f0 | |||
| d8dfba6372 | |||
| 7f57d53494 | |||
| 5e61a2b5ce | |||
| 2da14c3da3 | |||
| cab33df72d | |||
| 35ee17f959 | |||
| 7fdb26f2ea | |||
| 3993449594 | |||
| f8ae8c5781 | |||
| 22dad7ac06 | |||
| db10f1c5a4 | |||
| 0c368f402b | |||
| 0e04364d17 | |||
| 3ff06b7d9a | |||
| c7da833f07 | |||
| 09c1bd1582 | |||
| d324dd1a93 | |||
| 889689bd8e | |||
| 844ebf5216 | |||
| ae9ca35448 | |||
| dac9539ad9 | |||
| b8e0415632 | |||
| 3598eb6a47 | |||
| 38722f7308 | |||
| 8d52facc0b | |||
| 61fcad2c14 | |||
| a84e91a3f2 | |||
| c2314ad893 | |||
| 1973005e98 | |||
| 00235ba189 | |||
| 495277c7c9 | |||
| a73057f3a7 | |||
| a0f06d907f | |||
| 3d8cf17d57 | |||
| ca418b3ba5 | |||
| 189053697b | |||
| e674d8b27c | |||
| 7682e17afe | |||
| 163ec18730 | |||
| d27fd22d8f | |||
| cbebaad3b8 | |||
| 16d35349d3 | |||
| f8d9de1f2e | |||
| 53d2c5e399 | |||
| 89ee932db3 | |||
| fb63b70e8d | |||
| 4a62e51d1d | |||
| 2dd0360dec | |||
| 9976caafab | |||
| 530bcad8a6 | |||
| 949913cd6e | |||
| 1855d33e1f | |||
| ccd40c2927 | |||
| 6851046c5a | |||
| 1a9316150d | |||
| b56dd3f387 | |||
| 2cbe2c65e8 | |||
| b8b7799a47 | |||
| 2b8e7fa6b2 | |||
| fdb5405e2c | |||
| 0c440843b0 | |||
| caf77fe342 | |||
| b432cbc145 | |||
| ce97817d45 | |||
| 2b4b6a8470 | |||
| 5c34d0edc5 | |||
| 049f8d718a | |||
| c693d258fd | |||
| b23e9f9b04 | |||
| a5bb310e94 | |||
| 7f3d661e31 | |||
| 6982ce824f | |||
| 0c5b7de554 | |||
| 2a54f57532 | |||
| f0e77c499b | |||
| fa78b957b5 | |||
| 60d5bb8378 | |||
| d8e2537d47 | |||
| 425d427fce | |||
| 8f972bf15e | |||
| c36074df9f | |||
| 5e347d8725 | |||
| ef734a869c | |||
| c942de81e7 | |||
| dfe6c82a5c | |||
| 97b11bf2da | |||
| 023c9509e0 | |||
| b1bac23dcb | |||
| 13750f4175 | |||
| 27579e4fae | |||
| cb4621cad7 | |||
| 2d682d9151 | |||
| 26417a2543 | |||
| 87e6521f65 | |||
| b151666f6b | |||
| d1e2865319 | |||
| 70c54d6cf7 | |||
| 62a73996b9 | |||
| 75a1ab9719 | |||
| 6174043c7f | |||
| bfc65ebf6b | |||
| 53441821e0 | |||
| f012cf2e4b | |||
| c73923947a | |||
| a6daff59f6 | |||
| dc76366a48 | |||
| 9b40bf2f9b | |||
| ea0222b1e6 | |||
| 78234f60c4 | |||
| 7d07222832 | |||
| e5513101a6 | |||
| df78f0757e | |||
| 8e8ab25fd0 | |||
| b4e4277e08 | |||
| 13219ca49c | |||
| 0446db93e6 | |||
| a37d30c6ab | |||
| a78702d68f | |||
| 7831ba293a | |||
| a01a6b0b89 | |||
| c1b5e125b0 | |||
| accb9d9c59 | |||
| 11fa5d636e | |||
| cca6f80cb5 | |||
| 1ebcab60e2 | |||
| 2485916ad1 | |||
| 5287c51957 | |||
| 695dc04c00 | |||
| fd94403a73 | |||
| d35716f574 | |||
| b6bc9202db | |||
| 4cb184989c | |||
| ff02285a6a | |||
| 1a6f81a34b | |||
| 2dfba73cfb | |||
| 52e0daba0f | |||
| 2f5166fafa | |||
| 274fae1e31 | |||
| 7e278b6210 | |||
| 5736566a79 | |||
| bd4db268f1 | |||
| c13421c20a | |||
| 0d5d66b880 | |||
| ad01e296dc | |||
| 4698326717 | |||
| 2087097415 | |||
| 94eaa79768 | |||
| 6f10cd269e | |||
| c4a2dfd300 | |||
| 393c2fa9bc | |||
| 91b9680643 | |||
| 4216acdb3a | |||
| bc857a7cb4 | |||
| 2039106be2 | |||
| 18ed5faf99 | |||
| cdf9a5606d | |||
| 2166de2114 | |||
| 15b6da097c | |||
| 3b2d687bfd | |||
| dc4947af5c | |||
| 1e4d15c4b6 | |||
| d4ff55da13 | |||
| d8bdad4e1d | |||
| fb119f3c56 | |||
| 525123573e | |||
| 858a5d71bd | |||
| f88f79ef8d | |||
| b547493bc5 | |||
| cace2892ba | |||
| 82e23716ac | |||
| 92e3e9ac64 | |||
| 50fd3365e8 | |||
| 4ebf5ff479 | |||
| ab4feaa037 | |||
| 21900ade68 | |||
| 7b0e8e8188 | |||
| c5f7a3792a | |||
| 7a60f0cc9e | |||
| 9ed0b06a42 | |||
| 5ef4f64b11 | |||
| c7e90d3cf5 | |||
| d157713a85 | |||
| 90e7d475f8 | |||
| ecb03297fd | |||
| a09dfad22a | |||
| 9960b657e3 | |||
| bbabb91d42 | |||
| e55c67fa2f | |||
| 56bb41a291 | |||
| 4285361413 | |||
| 37177f8e45 | |||
| 6eadba1ab2 | |||
| aa11dc94ba | |||
| 82c18e26e5 | |||
| e7018bd75a | |||
| 10585e6afd | |||
| 35d26645a7 | |||
| 2376c61292 | |||
| 43a04308f0 | |||
| 0463518baa | |||
| 8e7a950d11 | |||
| ae5dc085d5 | |||
| bc9bc906a5 | |||
| 0890bcac42 | |||
| 22d27f7245 | |||
| 94b7e2ffff | |||
| 1a9e468c86 | |||
| 204a6cca8a | |||
| 4df7c54afb | |||
| 999f174441 | |||
| aca08a5e74 | |||
| ddcd2f0ff1 | |||
| ec9f7efcff | |||
| 8256a3ba43 | |||
| e011351aad | |||
| ad33114e0c | |||
| 4728525ece | |||
| cbc74d99b0 | |||
| f372ccd2b8 | |||
| 4d2597c31b | |||
| 281cda1d14 | |||
| 4a67694676 | |||
| f45df39032 | |||
| 186a20a1ac | |||
| 7eee265010 | |||
| b3cd759a4e | |||
| 93beb491db | |||
| 6d89ee0660 | |||
| b2cdf38fca | |||
| 567766508a | |||
| 1b67293d9c | |||
| 75922cb944 | |||
| e712bf6c8e | |||
| f26ea08469 | |||
| 6a86c2990e | |||
| 859af720c9 | |||
| 5441464a1d | |||
| de63751516 | |||
| 39382bfd8c | |||
| 477c7b07e5 | |||
| 63026752b5 | |||
| 5bcefbe582 | |||
| 8e754b2ce2 | |||
| 1556908ef6 | |||
| 57d36b51af | |||
| c72cdedd4f | |||
| 759457f739 | |||
| 78c90fe7c6 | |||
| 1875c599a4 | |||
| ab1a87ba04 | |||
| d492ddfbbb | |||
| cad92d2ff7 | |||
| 9737f23f5c | |||
| e26c737776 | |||
| d36576a079 | |||
| e48ee3d368 | |||
| 891d5c9bb7 | |||
| cbf3627ae2 | |||
| 44882cfa7a | |||
| c91e051082 | |||
| e01837579d | |||
| 0a5b39be7a | |||
| 19f49e746b | |||
| 8d34bfdcc6 | |||
| 725c2e96a4 | |||
| 113801f967 | |||
| c3e017bd68 | |||
| 71bb8eb750 | |||
| 01cdbf48d4 | |||
| 04bea86254 | |||
| 176b5c2459 | |||
| dad46a5a34 | |||
| 997b0c5f1b | |||
| a13e3f895d | |||
| 6a895f5c45 | |||
| 98a49b7f7a | |||
| 4b3399d951 | |||
| 2743e1dbae | |||
| aff73bbded | |||
| f8b299ff67 | |||
| f294daa077 | |||
| e389b2ed56 | |||
| 9b145c2739 | |||
| bc8dcf76ad | |||
| 93f42df4db | |||
| 00f10bdb14 | |||
| 2ca2500954 | |||
| b20201007e | |||
| 959e6b2d0d | |||
| 65a7fbb90b | |||
| c2ae5eae08 | |||
| 06ac0a747f | |||
| e2a78ac5ac | |||
| 9f213fa1dd | |||
| 6924c4f09d | |||
| 58bb8a0fcf | |||
| e8702cd716 | |||
| fb5e532ff6 | |||
| 1e371ad84a | |||
| 7ce5ce5d41 | |||
| 68a15486ae | |||
| bb42cfb8fd | |||
| af0321ce77 | |||
| fbdee8e10e | |||
| 489d984ab6 | |||
| 1e672bb8a1 | |||
| 6147e9604b | |||
| 97367a20c5 | |||
| 5a029110a3 | |||
| e4557c6b95 | |||
| 685312866b | |||
| a0959e0334 | |||
| a376a714e8 | |||
| 21a7d7db4b | |||
| b4649b4f9c | |||
| 0a407b6726 | |||
| 8b89489d40 | |||
| e8073de989 | |||
| 74e4f1a1e1 | |||
| d9493da173 | |||
| 0e8fdb18d8 | |||
| e07a9f58f7 | |||
| 1f6f6d5dc6 | |||
| 19814c61d7 | |||
| 66efc9c70e | |||
| c4fd8699f9 | |||
| 5dc8263e54 | |||
| 52b23e6609 | |||
| 90fb80872c | |||
| 754210e8f4 | |||
| 5966b8f1b8 | |||
| 72496548de | |||
| 0091cc5e9a | |||
| 241be6abd8 | |||
| f0eaa3efaa | |||
| f56073a090 | |||
| ca2a7d14f0 | |||
| 3ffe8d7c86 | |||
| e130cbb706 | |||
| e6792b00d7 | |||
| f89e857223 | |||
| 5256f05963 | |||
| 8e83b16f5e | |||
| c18e3c9ef2 | |||
| 0a67f63af6 | |||
| 8ef2319b0d | |||
| 0e98702944 | |||
| 080a6e8b54 | |||
| 8fadbecf00 | |||
| eab38dc23e | |||
| 3e76a39326 | |||
| 3af83dd9f2 | |||
| aba38b949f | |||
| 67ceedcad0 | |||
| 6c8c6f5208 | |||
| 6ab1579d38 | |||
| fc6e9f1447 | |||
| 1750dd9149 | |||
| 8134521cca | |||
| b204204920 | |||
| 8066ac8e2f | |||
| 43989dc964 | |||
| c066e394a8 | |||
| 78eae652fd | |||
| e1c0803018 | |||
| 1d82be270a | |||
| b22fa1550a | |||
| dc0a85d34f | |||
| 9f669dbbce | |||
| a5bcc90988 | |||
| acd4b59b4c | |||
| 50240c1fc3 | |||
| 091d309444 | |||
| 90d6fc6f08 | |||
| 6ff8b053af | |||
| 1f950f4c2a | |||
| 4afc20e2c3 | |||
| 550f7c3e06 | |||
| 135fe27007 | |||
| 7e6a674210 | |||
| dc997a80d5 | |||
| 293c321ba5 | |||
| 4816608c50 | |||
| 14fa29505d | |||
| eee4efd59d | |||
| 066e63cc86 | |||
| f4ca17ba3d | |||
| 8c6fa880b4 | |||
| 83e0a6b1ea | |||
| 495a5e6479 | |||
| def479bc7b | |||
| 0bf6e1e9f8 | |||
| a140b3bcca | |||
| 8b513efc95 | |||
| 17392a8e06 | |||
| ddc827e6f1 | |||
| 72792e7d4d | |||
| 1b6a5ced08 | |||
| 9906421460 | |||
| a62613f219 | |||
| 91a82b22b2 | |||
| 73e44916e7 | |||
| 84d2c56b54 | |||
| 18d90aa0bf | |||
| 40c20e3f5e | |||
| 1e0bd5822a | |||
| 7b0d74aace | |||
| becbb01286 | |||
| fc1769ce66 | |||
| 31573bf6e8 | |||
| 2efcc76933 | |||
| 3580b4ead9 | |||
| a82e9a4a74 | |||
| 2d7174c3b2 | |||
| c3f0b18df6 | |||
| 71c1bb87ca | |||
| bf3fd82630 | |||
| bdacd6a994 | |||
| f2a3c708a8 | |||
| 77bf32cb0e | |||
| 0ca87f7576 | |||
| b96e94be14 | |||
| 091dbc0729 | |||
| 29f7a57d97 | |||
| 8d0c1af032 | |||
| 2b83a0ac0f | |||
| 453686655b | |||
| 61f3113d61 | |||
| bf6986bcba | |||
| 6b2c3c1844 | |||
| 023e8dc78e | |||
| b5c188abbc | |||
| 8226c4162b | |||
| 2016ce887b | |||
| 4a0e2c492c | |||
| a34971fee7 | |||
| 5fc4e9dba6 | |||
| 42b90a2b14 | |||
| 6b05c2abc0 | |||
| 697cd57adb | |||
| 88e385d050 | |||
| 91b836a486 | |||
| b8bd6903e4 | |||
| ea7a493c13 | |||
| e108afdb80 | |||
| 4be0dd3d9d | |||
| 55a9596bd5 | |||
| 71fc1a47fb | |||
| d036c5a07c | |||
| e1fbcb379e | |||
| ed8e71072e | |||
| dbc3229b40 | |||
| 8b489b8301 | |||
| d32b98ec34 | |||
| 78e394a210 | |||
| c11a1caf59 | |||
| debfd4dc69 | |||
| 41d5359f4d | |||
| 34f56af6d6 | |||
| 687fd5411a | |||
| bb1394ceeb | |||
| 3ece50e292 | |||
| 497813e198 | |||
| a4aa540bc8 | |||
| 58c750471f | |||
| 7c3ec372df | |||
| 0f335d46bb | |||
| 2b203c8cdd | |||
| ac7bd1ceca | |||
| de6be901b9 | |||
| 0ab65410cc | |||
| a057437e1a | |||
| f9c007cc3a | |||
| d45196304f | |||
| 004089f887 | |||
| 13990438d3 | |||
| a120441a10 | |||
| 26c2f672be | |||
| 48195f9347 | |||
| 5a632bbb6d | |||
| 173638d6f5 | |||
| bd0c5a68f1 | |||
| e3f940c70a | |||
| bb1e2ecc78 | |||
| 8d0c368c8f | |||
| 9e94a4fe0e | |||
| 8d577aaa93 | |||
| 47662c359e | |||
| 4fb76bec41 | |||
| 5945114b7b | |||
| 559b7b5a17 | |||
| a346ff6161 | |||
| eed4b49ea0 | |||
| 88c0c49ba3 | |||
| f64d430f96 | |||
| f4a6d3d43d | |||
| 04b3f5c769 | |||
| aae3067f03 | |||
| 0820c5a188 | |||
| 8ea2671e65 | |||
| 12ea23a3bd | |||
| 0bc82c3a57 | |||
| 3270b40455 | |||
| 9f2327932d | |||
| 1b44a24d75 | |||
| 8db65da345 | |||
| 558833ca05 | |||
| 06263ceaad | |||
| 4a5f173422 | |||
| e30025ea8b | |||
| 59d860874e | |||
| 5978694d95 | |||
| d98f8a524d | |||
| 37827f0540 | |||
| 6fa8ba087a | |||
| a78959e66f | |||
| 5fc00f7af4 | |||
| 2cb36777f9 | |||
| b0fe79d527 | |||
| efebe9ca56 | |||
| bf7a50ab0e | |||
| cfedfc2c1e | |||
| cfd580fb21 | |||
| 1884ab3555 | |||
| eeaf139bd9 | |||
| 295137dbd2 | |||
| c2ee366e23 | |||
| a8348b1ccb | |||
| ff4c9dc421 | |||
| 53b36801e1 | |||
| f3a1bbaf5b | |||
| 05f377e21b | |||
| ead49c4025 | |||
| 5e02adc772 | |||
| 10f34f214f | |||
| 6f574a3076 | |||
| dc86538456 | |||
| 7698980576 | |||
| 9fe445ebd0 | |||
| 087afd22b2 | |||
| 8192d7b2d8 | |||
| d9ce9c4f10 | |||
| 4dfc98c93c | |||
| abbfc91192 | |||
| e3f5e045b7 | |||
| 7f7e7de841 | |||
| bd63d54a9e | |||
| 9dae55fc6f | |||
| e35a2b1c29 | |||
| 4157367aaa | |||
| 3945dc927c | |||
| 801ada88b7 | |||
| c234f2fc66 | |||
| 7b866ec632 | |||
| ff1726677b | |||
| 57e34ded54 | |||
| 03e014c753 | |||
| fd7950bc04 | |||
| 9f8c45b449 | |||
| bf5b0de6ee | |||
| 3aef2f4309 | |||
| 134c8fd1c1 | |||
| 35c7fe7fc4 | |||
| 612ca91f9c | |||
| 4632bec405 | |||
| fcdea215be | |||
| 6f18cf74c5 | |||
| 162cb85811 | |||
| 5ea8d0326a | |||
| 7a2591a1fa | |||
| 56a1bd68dd | |||
| 2f2754ab97 | |||
| 9883fb988a | |||
| 38a74d7d0f | |||
| 949f1d6534 | |||
| de42f53d68 | |||
| 247d48d318 | |||
| c4c2f7f37f | |||
| 66a022a012 | |||
| 19eefd65c1 | |||
| ad383ad9d4 | |||
| 539ddcaf48 | |||
| b30f8d253c | |||
| c477d0fcc6 | |||
| bc63961e7e | |||
| 30ce0bdf45 | |||
| dd66dd21bb | |||
| 27075a0260 | |||
| 6cfd89af8c | |||
| 8e99700657 | |||
| e21c4cdd4d | |||
| 88efc14bc2 | |||
| a9d518fbc8 | |||
| 43b1014700 | |||
| 2e722bdfeb | |||
| aedbffa809 | |||
| dc0db9d192 | |||
| 9f3e724218 | |||
| f98f8b10d1 | |||
| b788d63044 | |||
| d5936a9e08 | |||
| 81c53d3690 | |||
| 89003082d7 | |||
| fe1a48fa28 | |||
| c4b2f91424 | |||
| f16c13fa54 | |||
| 43ce3c50e5 | |||
| 204a6b5a44 | |||
| a6dc455477 | |||
| 138ede0536 | |||
| eae089d3ec | |||
| 340df69ca2 | |||
| 507c98adff | |||
| 0501f2892d | |||
| 104d2facdb | |||
| 398c9726f3 | |||
| eb2f885983 | |||
| 4a16931c5d | |||
| 78b83c5639 | |||
| 9cf25c4caf | |||
| f0e02724ee | |||
| 60e71aad38 | |||
| d1897efa8b | |||
| 490dac5048 | |||
| 549133e619 | |||
| 323d011476 | |||
| 4e8a67925f | |||
| cba3881f41 | |||
| 78eb353985 | |||
| e7880b72f1 | |||
| d864361085 | |||
| 66366dd95b | |||
| 2c6c65f71e | |||
| 9eede5470c | |||
| 07edccb469 | |||
| 927075688c | |||
| ddadd4ad83 | |||
| b18c3b588f | |||
| fb144a5e66 | |||
| 34c439b3de | |||
| 934ddf1499 | |||
| 4302d50a42 | |||
| 3e96c4d0aa | |||
| 53f787d6ea | |||
| d368b92165 | |||
| 97e3524a24 | |||
| 299ebea0e2 | |||
| 7e12c5b76d | |||
| 3a66969dec | |||
| 65c5d3673d | |||
| e2b4bc45bd | |||
| d3c0ce8895 | |||
| 2b3e7adc0b | |||
| 26983dc0e4 | |||
| a0d75b28ba | |||
| e9cec877f2 | |||
| 0bb8ff646a | |||
| 9268fef89d | |||
| 6f8b3f481d | |||
| 3b2d7fc0b3 | |||
| 7cac145500 | |||
| b2aa638b1f | |||
| 2990a1f686 | |||
| c3f2c04a28 | |||
| 347cb46f15 | |||
| bcb6c368b1 | |||
| a9e87d5ef5 | |||
| 4eec183598 | |||
| 6c6e5fc4d2 | |||
| 0d7d21aeb2 | |||
| ea6f4ce221 | |||
| 1c7d5de01b | |||
| d2d28f5ad6 | |||
| 04ca52b94e | |||
| e369e1ed80 | |||
| 0dfd4ebc4a | |||
| a7048f76f9 | |||
| 8d92a8df68 | |||
| d6b53ea718 | |||
| 64dc2299da | |||
| 2e193c6a78 | |||
| f95230549a | |||
| a13803df94 | |||
| 2ba7fb2f05 | |||
| 9442295227 | |||
| 8d87f3250d | |||
| e700867a32 | |||
| a21d48defb | |||
| 3770e2c39e | |||
| 8d90515446 | |||
| db67550db3 | |||
| 85e7d95188 | |||
| 651e093e04 | |||
| 02fb9915bf | |||
| 6153f64fb7 | |||
| f91df1639b | |||
| 63bd2e71b0 | |||
| e1d00d59a4 | |||
| 5def3f1f6a | |||
| 6840e1e7eb | |||
| 85d89f9846 | |||
| 8929f85bf7 | |||
| 9601180e1b | |||
| 64786ddcb7 | |||
| e4a9d1eb78 | |||
| 1b04b1137c | |||
| 813b0c3828 | |||
| 22a358fb49 | |||
| ada2813f9f | |||
| 906c07e4fd | |||
| a4c0e30bb8 | |||
| a5c9744258 | |||
| a8bf217e62 | |||
| fff25b4144 | |||
| 82ba5a4b97 | |||
| 436f5b7f0a | |||
| cf1789545a | |||
| d7f882f0c4 | |||
| 2a84ef0ebf | |||
| 4f644acbca | |||
| 9a9bd7e262 | |||
| 47bb33e065 | |||
| 40423397e3 | |||
| 4955e8c2ba | |||
| 24480ce946 | |||
| 76d5ac0a34 | |||
| d20887f34a | |||
| 0cbc922478 | |||
| 38866cf2c1 | |||
| 32165f5b58 | |||
| 1968669a39 | |||
| 3b2b8a9ebe | |||
| 048ce47008 | |||
| d321e2a874 | |||
| 21f47de36c | |||
| 0352e1c6d6 | |||
| 98d03fb098 | |||
| 739cdc1752 | |||
| 54a7ef24d9 | |||
| c4ff0b1832 | |||
| b70c6556c9 | |||
| 80408b985e | |||
| ff1e7f3c9f | |||
| b2eb3a036d | |||
| 229fedf347 | |||
| cfccee1592 | |||
| 0c728beb01 | |||
| 4e01e3f337 | |||
| 92ae41852d | |||
| 4f9b042f5a | |||
| 1236fa4cab | |||
| e69be64773 | |||
| c2db28a624 | |||
| 1f92f2a2ed | |||
| 74bbd5af25 | |||
| 023037f7ee | |||
| fe19f4de66 | |||
| d120cc853d | |||
| c78665dc35 | |||
| c4c4c09eb2 | |||
| 2cccc3d0c8 | |||
| 59c414ebad | |||
| 1e7143b85e | |||
| a6068ad6f6 | |||
| 11caf55522 | |||
| f73d098b1f | |||
| 9673943556 | |||
| 7c06ae39ef | |||
| ffa5b88cdf | |||
| 8977d70dd9 | |||
| 943141d65c | |||
| 49e36cfdc6 | |||
| 283e0c6367 | |||
| 902f5823f2 | |||
| 7785c954d5 | |||
| db841f71bd | |||
| 84c2234869 | |||
| 51e467d45e | |||
| e184475a24 | |||
| 1fb2789cb1 | |||
| 8979d7f94f | |||
| 9033198aed | |||
| db55c3f0e7 | |||
| ba4375a28b |
9
.github/CODEOWNERS
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# Apply to all files
|
||||||
|
* @nbolton @sithlord48
|
||||||
|
|
||||||
|
# Translators
|
||||||
|
translations/deskflow_es.ts @sithlord48
|
||||||
|
translations/deskflow_it.ts @sithlord48
|
||||||
|
translations/deskflow_ja.ts @ykasap
|
||||||
|
translations/deskflow_ru.ts @levpr1c
|
||||||
|
translations/deskflow_zh_CN.ts @sailordiary
|
||||||
18
.github/CODE_OF_CONDUCT.md
vendored
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
# Deskflow Code of Conduct
|
||||||
|
|
||||||
|
## Our Pledge
|
||||||
|
|
||||||
|
We want the Deskflow community to be one where everyone can work together. We pledge to keep our community focused on the project and the code around the project.
|
||||||
|
|
||||||
|
## Community Standards
|
||||||
|
|
||||||
|
* Keep interactions respectful and focused on the project
|
||||||
|
* Contributions are expected to follow the [contribution guide](https://github.com/deskflow/deskflow/wiki/Contributing).
|
||||||
|
|
||||||
|
## Enforcement
|
||||||
|
|
||||||
|
Enforcement will be done at the descression of the Deskflow Moderators.
|
||||||
|
|
||||||
|
1. Warning
|
||||||
|
2. Temporary ban
|
||||||
|
3. Permanent banning
|
||||||
75
.github/ISSUE_TEMPLATE/bug_report.yml
vendored
@ -4,24 +4,24 @@ type: "Triage [bug]"
|
|||||||
body:
|
body:
|
||||||
- type: markdown
|
- type: markdown
|
||||||
attributes:
|
attributes:
|
||||||
value: Thanks for taking the time to help us improve Deskflow.
|
value: |
|
||||||
|
Thanks for taking the time to help us improve Deskflow.
|
||||||
|
|
||||||
- type: dropdown
|
- type: checkboxes
|
||||||
id: project
|
id: sanity-checks
|
||||||
attributes:
|
attributes:
|
||||||
label: Project
|
label: Sanity checks
|
||||||
description: Are you using Deskflow or a fork/derivative?
|
description: |
|
||||||
|
Before reporting a bug, please first:
|
||||||
|
1. Try the latest [continuous build](https://github.com/deskflow/deskflow/releases).
|
||||||
|
2. Wayland users, please review the [known issues](https://github.com/deskflow/deskflow/discussions/7499).
|
||||||
|
3. macOS users, if the app crashes, try [Apple's solution](https://support.apple.com/guide/mac-help/open-a-mac-app-from-an-unknown-developer-mh40616/mac).
|
||||||
options:
|
options:
|
||||||
# Empty option to force selection
|
- label: I have done the sanity checks, and my issue persists
|
||||||
-
|
- label: These sanity checks are not relevant to the bug
|
||||||
- Deskflow
|
|
||||||
- Barrier
|
|
||||||
- Input Leap
|
|
||||||
- Synergy
|
|
||||||
default: 0
|
|
||||||
validations:
|
validations:
|
||||||
required: true
|
required: true
|
||||||
|
|
||||||
- type: textarea
|
- type: textarea
|
||||||
id: version
|
id: version
|
||||||
attributes:
|
attributes:
|
||||||
@ -66,60 +66,21 @@ body:
|
|||||||
validations:
|
validations:
|
||||||
required: true
|
required: true
|
||||||
|
|
||||||
- type: checkboxes
|
|
||||||
id: linux-wayland
|
|
||||||
attributes:
|
|
||||||
label: Wayland on Linux
|
|
||||||
description: If using Wayland on Linux, please review the [known issues](https://github.com/deskflow/deskflow/discussions/7499) before reporting.
|
|
||||||
options:
|
|
||||||
- label: I have reviewed the Wayland [known issues](https://github.com/deskflow/deskflow/discussions/7499) and my issue is new
|
|
||||||
- label: I am not using Wayland on Linux
|
|
||||||
|
|
||||||
- type: checkboxes
|
|
||||||
id: mac-signing
|
|
||||||
attributes:
|
|
||||||
label: Signing on macOS
|
|
||||||
description: If using macOS and the app crashes, try [Apple's solution](https://support.apple.com/guide/mac-help/open-a-mac-app-from-an-unknown-developer-mh40616/mac) before reporting.
|
|
||||||
options:
|
|
||||||
- label: I have authorized the app to run on my Mac
|
|
||||||
- label: I am not using macOS
|
|
||||||
|
|
||||||
- type: checkboxes
|
|
||||||
id: continuous-build
|
|
||||||
attributes:
|
|
||||||
label: Continuous build
|
|
||||||
description: Please try the latest [continuous build](https://github.com/deskflow/deskflow/releases) of Deskflow. It may have a fix for your issue.
|
|
||||||
options:
|
|
||||||
- label: I have tried the latest continuous build and the issue persists
|
|
||||||
- label: I am unable to try the latest continuous build
|
|
||||||
|
|
||||||
- type: textarea
|
|
||||||
id: os-version
|
|
||||||
attributes:
|
|
||||||
label: OS versions/distros
|
|
||||||
description: |
|
|
||||||
Please provide the version number of your operating system (OS).
|
|
||||||
If you're using Linux, please provide the name of the distribution.
|
|
||||||
placeholder: |
|
|
||||||
- Windows 11
|
|
||||||
- macOS 15
|
|
||||||
- Ubuntu 24.04
|
|
||||||
- FreeBSD 14.0
|
|
||||||
validations:
|
|
||||||
required: true
|
|
||||||
|
|
||||||
- type: textarea
|
- type: textarea
|
||||||
id: config
|
id: config
|
||||||
attributes:
|
attributes:
|
||||||
label: Deskflow configuration
|
label: Deskflow configuration
|
||||||
description: |
|
description: |
|
||||||
Please provide a very brief description of your configuration.
|
Please provide a very brief description of your configuration.
|
||||||
Let us know what OS your server and client are running.
|
Let us know what OS your server and client are running, including all OS versions.
|
||||||
|
If you're using Linux, please provide the name of the distribution.
|
||||||
placeholder: |
|
placeholder: |
|
||||||
- Windows 11 server, macOS 15 client
|
- Windows 11 server, macOS 15 client
|
||||||
- Each computer has a single monitor
|
- Each computer has a single monitor
|
||||||
- Windows is on the left, macOS is on the right
|
- Windows is on the left, macOS is on the right
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
|
||||||
- type: textarea
|
- type: textarea
|
||||||
id: repro-steps
|
id: repro-steps
|
||||||
attributes:
|
attributes:
|
||||||
|
|||||||
10
.github/ISSUE_TEMPLATE/config.yml
vendored
@ -1 +1,11 @@
|
|||||||
blank_issues_enabled: false
|
blank_issues_enabled: false
|
||||||
|
contact_links:
|
||||||
|
- name: Ask a question
|
||||||
|
url: https://github.com/deskflow/deskflow/discussions/new?category=q-a
|
||||||
|
about: Where to ask general questions.
|
||||||
|
- name: Show and Tell
|
||||||
|
url: https://github.com/deskflow/deskflow/discussions/new?category=show-and-tell
|
||||||
|
about: Show off things you have done with Deskflow
|
||||||
|
- name: Chat with us
|
||||||
|
url: https://matrix.to/#/#deskflow:matrix.org
|
||||||
|
about: Join us in live chat.
|
||||||
|
|||||||
11
.github/ISSUE_TEMPLATE/feature_request.yml
vendored
@ -14,3 +14,14 @@ body:
|
|||||||
Please describe the feature you have in mind.
|
Please describe the feature you have in mind.
|
||||||
validations:
|
validations:
|
||||||
required: true
|
required: true
|
||||||
|
|
||||||
|
- type: textarea
|
||||||
|
id: votes
|
||||||
|
attributes:
|
||||||
|
label: Voting Instructions
|
||||||
|
description: Do not modify these instructions
|
||||||
|
value: |
|
||||||
|
React with :+1: or :-1: to vote on this request
|
||||||
|
validations:
|
||||||
|
required: true
|
||||||
|
|
||||||
|
|||||||
30
README.md → .github/README.md
vendored
@ -22,8 +22,14 @@ TLS encryption is enabled by default. Wayland is supported. Clipboard sharing is
|
|||||||
|
|
||||||
[](https://github.com/deskflow/deskflow/releases/latest) [](https://github.com/deskflow/deskflow/releases/continuous) [](https://flathub.org/apps/org.deskflow.deskflow)
|
[](https://github.com/deskflow/deskflow/releases/latest) [](https://github.com/deskflow/deskflow/releases/continuous) [](https://flathub.org/apps/org.deskflow.deskflow)
|
||||||
|
|
||||||
|
> [!NOTE]
|
||||||
|
> On Windows, you will need to install the
|
||||||
|
> [Microsoft Visual C++ Redistributable](https://learn.microsoft.com/en-us/cpp/windows/latest-supported-vc-redist?view=msvc-170#latest-microsoft-visual-c-redistributable-version).
|
||||||
|
> Download latest: [`vc_redist.x64.exe`](https://aka.ms/vc14/vc_redist.x64.exe) [`vc_redist.arm64.exe`](https://aka.ms/vc14/vc_redist.arm64.exe)
|
||||||
|
|
||||||
> [!TIP]
|
> [!TIP]
|
||||||
> For macOS users, the easiest way to install and stay up to date is to use [Homebrew](https://brew.sh) with our [homebrew-tap](https://github.com/deskflow/homebrew-tap).
|
> For macOS users, the easiest way to install and stay up to date is to use [Homebrew](https://brew.sh) with our [homebrew-tap](https://github.com/deskflow/homebrew-tap).
|
||||||
|
> macOS reports unsigned apps as damaged. This occurs because we do not use an Apple certificate for notarization. Clear the quarantine attribute to run the app: `xattr -c Deskflow.app`
|
||||||
|
|
||||||
To use Deskflow, download one of our [packages](https://github.com/deskflow/deskflow/releases), install `deskflow` (from your package repository), or [build it](https://github.com/deskflow/deskflow/wiki/Building) from source.
|
To use Deskflow, download one of our [packages](https://github.com/deskflow/deskflow/releases), install `deskflow` (from your package repository), or [build it](https://github.com/deskflow/deskflow/wiki/Building) from source.
|
||||||
|
|
||||||
@ -45,7 +51,7 @@ To use Deskflow, download one of our [packages](https://github.com/deskflow/desk
|
|||||||
|
|
||||||
## Contribute
|
## Contribute
|
||||||
|
|
||||||
[](https://github.com/deskflow/deskflow/labels/good%20first%20issue) [](https://github.com/deskflow/deskflow/issues?q=is%3Aissue%20state%3Aopen%20label%3A%22%F0%9F%92%8E%20bounty%22) [](https://github.com/deskflow/deskflow/issues?q=label%3A%22%F0%9F%92%B0%20rewarded%22%20sort%3Aupdated-desc)
|
[](https://github.com/deskflow/deskflow/labels/good%20first%20issue)
|
||||||
|
|
||||||
There are many ways to contribute to the Deskflow project.
|
There are many ways to contribute to the Deskflow project.
|
||||||
|
|
||||||
@ -59,14 +65,9 @@ For instructions on building Deskflow, use the wiki page: [Building](https://git
|
|||||||
|
|
||||||
We support all major operating systems, including Windows, macOS, Linux, and Unix-like BSD-derived.
|
We support all major operating systems, including Windows, macOS, Linux, and Unix-like BSD-derived.
|
||||||
|
|
||||||
> [!NOTE]
|
Windows 10 v1809 or higher is required.
|
||||||
> On Windows, you will need to install the
|
|
||||||
> [Microsoft Visual C++ Redistributable](https://learn.microsoft.com/en-us/cpp/windows/latest-supported-vc-redist?view=msvc-170#latest-microsoft-visual-c-redistributable-version).
|
|
||||||
> Download latest: [`vc_redist.x64.exe`](https://aka.ms/vs/17/release/vc_redist.x64.exe) [`vc_redist.arm64.exe`](https://aka.ms/vs/17/release/vc_redist.arm64.exe)
|
|
||||||
|
|
||||||
Windows 10 or higher is required.
|
macOS 13 or higher is required to use our CI builds for Apple Silicon machines. macOS 12 or higher is required for Intel macs or local builds.
|
||||||
|
|
||||||
macOS 12 or higher is required.
|
|
||||||
|
|
||||||
Linux requires libei 1.3+ and libportal 0.8+ for the server/client. Additionally, Qt 6.7+ is required for the GUI.
|
Linux requires libei 1.3+ and libportal 0.8+ for the server/client. Additionally, Qt 6.7+ is required for the GUI.
|
||||||
Linux users with systems not meeting these requirements should use flatpak in place of a native package.
|
Linux users with systems not meeting these requirements should use flatpak in place of a native package.
|
||||||
@ -80,8 +81,6 @@ versions across them and gathering other information.
|
|||||||
|
|
||||||
[](https://repology.org/project/deskflow/versions)
|
[](https://repology.org/project/deskflow/versions)
|
||||||
|
|
||||||
**Note:** We are working with package maintainers to have our new package name adopted.
|
|
||||||
|
|
||||||
## Installing on macOS
|
## Installing on macOS
|
||||||
|
|
||||||
When you install Deskflow on macOS, you need to allow accessibility access (Privacy & Security) to both the `Deskflow` app and the `deskflow` process.
|
When you install Deskflow on macOS, you need to allow accessibility access (Privacy & Security) to both the `Deskflow` app and the `deskflow` process.
|
||||||
@ -94,12 +93,12 @@ on the allowed list you will need to manually remove them before accessibility a
|
|||||||
|
|
||||||
macOS users who download directly from releases may need to run `xattr -c /Applications/Deskflow.app` after copying the app to the `Applications` dir.
|
macOS users who download directly from releases may need to run `xattr -c /Applications/Deskflow.app` after copying the app to the `Applications` dir.
|
||||||
|
|
||||||
It is recommend to install Deskflow using [Homebrew](https://brew.sh) from our [homebrew-tap](https://github.com/deskflow/homebrew-tap)
|
It is recommended to install Deskflow using [Homebrew](https://brew.sh) from our [homebrew-tap](https://github.com/deskflow/homebrew-tap)
|
||||||
|
|
||||||
To add our tap, run:
|
To add our tap, run:
|
||||||
|
|
||||||
```
|
```
|
||||||
brew tap deskflow/homebrew-tap
|
brew tap deskflow/tap
|
||||||
```
|
```
|
||||||
|
|
||||||
Then install either:
|
Then install either:
|
||||||
@ -115,11 +114,10 @@ mouse and keyboard sharing tools. We aim for idea sharing and interoperability.
|
|||||||
- [**Lan Mouse**](https://github.com/feschber/lan-mouse) -
|
- [**Lan Mouse**](https://github.com/feschber/lan-mouse) -
|
||||||
Rust implementation with the goal of having native front-ends and interoperability with
|
Rust implementation with the goal of having native front-ends and interoperability with
|
||||||
Deskflow/Synergy.
|
Deskflow/Synergy.
|
||||||
- [**Input Leap**](https://github.com/input-leap/input-leap) -
|
|
||||||
Deskflow/Synergy-derivative with the goal of continuing what Barrier started, after Barrier
|
|
||||||
became a dead fork.
|
|
||||||
- [**Synergy**](https://symless.com/synergy) -
|
- [**Synergy**](https://symless.com/synergy) -
|
||||||
Downstream commercial fork. Synergy sponsors Deskflow with financial support and contributes code ([learn more](https://github.com/deskflow/deskflow/wiki/Relationship-with-Synergy)).
|
Downstream commercial fork. Synergy sponsors Deskflow with financial support and contributes code ([learn more](https://github.com/deskflow/deskflow/wiki/Relationship-with-Synergy)).
|
||||||
|
- [**Input Leap**](https://github.com/input-leap/input-leap) -
|
||||||
|
Inactive Deskflow/Synergy-derivative with the goal continuing Barrier development (now a dead fork).
|
||||||
|
|
||||||
## FAQ
|
## FAQ
|
||||||
|
|
||||||
@ -186,4 +184,4 @@ Deskflow is made by possible by these contributors.
|
|||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
This project is licensed under [GPL-2.0](LICENSE) with an [OpenSSL exception](LICENSES/LicenseRef-OpenSSL-Exception.txt).
|
This project is licensed under [GPL-2.0](LICENSE) with an [OpenSSL exception](../LICENSES/LicenseRef-OpenSSL-Exception.txt).
|
||||||
34
.github/actions/add-kitware-repo/action.yml
vendored
@ -1,34 +0,0 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 Chris Rizzitello <sithlord48@gmail.com>
|
|
||||||
# SPDX-License-Identifier: MIT
|
|
||||||
|
|
||||||
name: "Add Kitware repo"
|
|
||||||
description: "Add Kitware repo for Debian-like distros"
|
|
||||||
|
|
||||||
inputs:
|
|
||||||
distro:
|
|
||||||
description: "Ubuntu codename, Kitware uses: noble, jammy, focal"
|
|
||||||
required: true
|
|
||||||
|
|
||||||
runs:
|
|
||||||
using: "composite"
|
|
||||||
|
|
||||||
steps:
|
|
||||||
|
|
||||||
# This mirrors instructions at https://apt.kitware.com
|
|
||||||
- name: Add repo
|
|
||||||
run: |
|
|
||||||
apt update -y -qqq
|
|
||||||
apt install ca-certificates gpg wget -y -qqq
|
|
||||||
|
|
||||||
wget -O - https://apt.kitware.com/keys/kitware-archive-latest.asc 2>/dev/null \
|
|
||||||
| gpg --dearmor - \
|
|
||||||
> /usr/share/keyrings/kitware-archive-keyring.gpg
|
|
||||||
|
|
||||||
echo 'deb [signed-by=/usr/share/keyrings/kitware-archive-keyring.gpg] https://apt.kitware.com/ubuntu/ ${{ inputs.distro }} main' \
|
|
||||||
> /etc/apt/sources.list.d/kitware.list
|
|
||||||
|
|
||||||
apt update -y -qqq
|
|
||||||
env:
|
|
||||||
# Prevent apt prompting for input.
|
|
||||||
DEBIAN_FRONTEND: noninteractive
|
|
||||||
shell: bash
|
|
||||||
40
.github/actions/install-dependencies/action.yml
vendored
@ -30,7 +30,7 @@ runs:
|
|||||||
if: ${{ runner.os != 'Windows' }}
|
if: ${{ runner.os != 'Windows' }}
|
||||||
run: |
|
run: |
|
||||||
if [ "$RUNNER_OS" == "macOS" ]; then
|
if [ "$RUNNER_OS" == "macOS" ]; then
|
||||||
brew install googletest openssl --quiet
|
brew install googletest openssl doxygen --quiet
|
||||||
elif [ "$RUNNER_OS" == "Linux" ]; then
|
elif [ "$RUNNER_OS" == "Linux" ]; then
|
||||||
if [ ${{inputs.like}} == "debian" ]; then
|
if [ ${{inputs.like}} == "debian" ]; then
|
||||||
apt update -qqq > /dev/null
|
apt update -qqq > /dev/null
|
||||||
@ -38,26 +38,22 @@ runs:
|
|||||||
xorg-dev libx11-dev libxtst-dev libssl-dev \
|
xorg-dev libx11-dev libxtst-dev libssl-dev \
|
||||||
libglib2.0-dev libxkbfile-dev qt6-base-dev qt6-tools-dev \
|
libglib2.0-dev libxkbfile-dev qt6-base-dev qt6-tools-dev \
|
||||||
libgtk-3-dev libgtest-dev libgmock-dev \
|
libgtk-3-dev libgtest-dev libgmock-dev \
|
||||||
libei-dev libportal-dev libtomlplusplus-dev libcli11-dev \
|
libei-dev libportal-dev help2man doxygen -y >/dev/null
|
||||||
help2man -y >/dev/null
|
|
||||||
elif [ ${{inputs.like}} == "fedora" ]; then
|
elif [ ${{inputs.like}} == "fedora" ]; then
|
||||||
dnf install -y cmake make ninja-build gcc-c++ \
|
dnf install -y cmake make ninja-build gcc-c++ rpm-build openssl-devel \
|
||||||
rpm-build openssl-devel glib2-devel \
|
glib2-devel libXtst-devel libxkbfile-devel qt6-qtbase-devel qt6-qttools-devel \
|
||||||
libXtst-devel libxkbfile-devel qt6-qtbase-devel qt6-qttools-devel \
|
gtk3-devel gtest-devel gmock-devel libei-devel libportal-devel help2man doxygen
|
||||||
gtk3-devel gtest-devel gmock-devel \
|
|
||||||
libei-devel libportal-devel tomlplusplus-devel \
|
|
||||||
cli11-devel help2man
|
|
||||||
elif [ ${{inputs.like}} == "suse" ]; then
|
elif [ ${{inputs.like}} == "suse" ]; then
|
||||||
zypper refresh
|
zypper refresh
|
||||||
zypper install -y --force-resolution \
|
zypper install -y --force-resolution \
|
||||||
cmake make ninja gcc-c++ rpm-build libopenssl-devel \
|
cmake make ninja gcc-c++ rpm-build libopenssl-devel \
|
||||||
glib2-devel libXtst-devel libxkbfile-devel qt6-base-devel qt6-tools-devel gtk3-devel \
|
glib2-devel libXtst-devel libxkbfile-devel qt6-base-devel qt6-tools-devel \
|
||||||
googletest-devel googlemock-devel libei-devel \
|
qt6-linguist-devel gtk3-devel doxygen \
|
||||||
libportal-devel tomlplusplus-devel cli11-devel help2man
|
googletest-devel googlemock-devel libei-devel libportal-devel help2man
|
||||||
elif [ ${{ inputs.like }} == "arch" ]; then
|
elif [ ${{ inputs.like }} == "arch" ]; then
|
||||||
pacman -Syu --noconfirm base-devel cmake ninja \
|
pacman -Syu --noconfirm base-devel cmake ninja \
|
||||||
gcc openssl glib2 libxtst libxkbfile gtest libei libportal \
|
gcc openssl glib2 libxtst libxkbfile gtest libei libportal \
|
||||||
qt6-base qt6-tools qt6-svg gtk3 tomlplusplus cli11 help2man doxygen graphviz rsync
|
qt6-base qt6-tools qt6-svg qt6-translations qt6-declarative gtk3 help2man doxygen graphviz rsync
|
||||||
else
|
else
|
||||||
echo "Unknown like"
|
echo "Unknown like"
|
||||||
fi
|
fi
|
||||||
@ -85,6 +81,23 @@ runs:
|
|||||||
extra-args: --classic --host-triplet=${{inputs.vcpkg-triplet}}
|
extra-args: --classic --host-triplet=${{inputs.vcpkg-triplet}}
|
||||||
triplet: ${{inputs.vcpkg-triplet}}
|
triplet: ${{inputs.vcpkg-triplet}}
|
||||||
token: ${{ github.token }}
|
token: ${{ github.token }}
|
||||||
|
revision: master
|
||||||
|
|
||||||
|
- name: Cache Chocolatey
|
||||||
|
id: cache-choco
|
||||||
|
if: (runner.os == 'Windows')
|
||||||
|
uses: actions/cache@v4
|
||||||
|
with:
|
||||||
|
path: |
|
||||||
|
C:/ProgramData/chocolatey/bin/
|
||||||
|
C:/ProgramData/chocolatey/lib/doxygen.install
|
||||||
|
C:/Program*/doxygen/
|
||||||
|
key: cache-chocolatey${{ matrix.config.arch }}-doxygen
|
||||||
|
|
||||||
|
- name: Install doxygen (windows)
|
||||||
|
if: ((runner.os == 'Windows') && (steps.cache-choco.outputs.cache-hit != 'true'))
|
||||||
|
shell: bash
|
||||||
|
run: choco install doxygen.install
|
||||||
|
|
||||||
- name: Install Wix
|
- name: Install Wix
|
||||||
if: ${{ runner.os == 'Windows' }}
|
if: ${{ runner.os == 'Windows' }}
|
||||||
@ -94,3 +107,4 @@ runs:
|
|||||||
wix extension add --global WixToolset.Util.wixext/5.0.2
|
wix extension add --global WixToolset.Util.wixext/5.0.2
|
||||||
wix extension add --global WixToolset.Firewall.wixext/5.0.2
|
wix extension add --global WixToolset.Firewall.wixext/5.0.2
|
||||||
shell: pwsh
|
shell: pwsh
|
||||||
|
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
name: "Lint Check"
|
name: "Lint Clang"
|
||||||
description: "Checks for lint errors and posts a helpful comment"
|
description: "Checks for Clang lint errors and posts a helpful comment"
|
||||||
|
|
||||||
runs:
|
runs:
|
||||||
using: "composite"
|
using: "composite"
|
||||||
@ -48,8 +48,10 @@ runs:
|
|||||||
run: |
|
run: |
|
||||||
code_block="\`\`\`"
|
code_block="\`\`\`"
|
||||||
|
|
||||||
summary=$(cat<<EOF
|
clang_version=$(clang-format --version | sed -n 's/^.*version //p')
|
||||||
❌ \`clang-format\`: It looks like your changes don't match our code style.
|
|
||||||
|
summary=$(cat <<EOF
|
||||||
|
❌ \`clang-format\` \`v${clang_version}\`: It looks like your changes don't match our code style.
|
||||||
|
|
||||||
🛠️ Please either run \`clang-format -i\` on the file or apply this patch with \`git apply\`:
|
🛠️ Please either run \`clang-format -i\` on the file or apply this patch with \`git apply\`:
|
||||||
|
|
||||||
@ -57,12 +59,21 @@ runs:
|
|||||||
$code_block diff
|
$code_block diff
|
||||||
${{ steps.changes.outputs.diff }}
|
${{ steps.changes.outputs.diff }}
|
||||||
$code_block
|
$code_block
|
||||||
|
|
||||||
|
Hint: Install the right version of \`clang-format\`, e.g.: \`pipx install --global clang-format==${clang_version}\`
|
||||||
EOF
|
EOF
|
||||||
)
|
)
|
||||||
echo "$summary" >> $GITHUB_STEP_SUMMARY
|
echo "$summary" >> $GITHUB_STEP_SUMMARY
|
||||||
|
|
||||||
file="ci_summary.md"
|
pr_comment=$(cat <<EOF
|
||||||
echo "❌🛠️ \`clang-format\`: Lint errors, fix available." >> $file
|
### Lint result
|
||||||
|
|
||||||
|
$summary
|
||||||
|
EOF
|
||||||
|
)
|
||||||
|
|
||||||
|
file="ci-summary.md"
|
||||||
|
echo "$pr_comment" | tee $file
|
||||||
echo "file=$file" >> $GITHUB_OUTPUT
|
echo "file=$file" >> $GITHUB_OUTPUT
|
||||||
shell: bash
|
shell: bash
|
||||||
|
|
||||||
22
.github/actions/run-tests/action.yml
vendored
@ -16,7 +16,7 @@ runs:
|
|||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Unit Tests
|
- name: Unit Tests
|
||||||
id: unittests
|
id: unit-tests
|
||||||
env:
|
env:
|
||||||
QT_QPA_PLATFORM: offscreen
|
QT_QPA_PLATFORM: offscreen
|
||||||
run: |
|
run: |
|
||||||
@ -30,7 +30,7 @@ runs:
|
|||||||
continue-on-error: true
|
continue-on-error: true
|
||||||
|
|
||||||
- name: Legacy Tests
|
- name: Legacy Tests
|
||||||
id: legacytests
|
id: legacy-tests
|
||||||
env:
|
env:
|
||||||
QT_QPA_PLATFORM: offscreen
|
QT_QPA_PLATFORM: offscreen
|
||||||
run: |
|
run: |
|
||||||
@ -48,12 +48,12 @@ runs:
|
|||||||
run: |
|
run: |
|
||||||
pass="✅ Pass"
|
pass="✅ Pass"
|
||||||
fail="❌ Fail"
|
fail="❌ Fail"
|
||||||
unittests_outcome="${{ steps.unittests.outcome }}"
|
unit_tests_outcome="${{ steps.unit-tests.outcome }}"
|
||||||
legacytests_outcome="${{ steps.legacytests.outcome }}"
|
legacy_tests_outcome="${{ steps.legacy-tests.outcome }}"
|
||||||
unittests=$( [ "$unittests_outcome" = "success" ] && echo $pass || echo $fail )
|
unit_tests=$( [ "$unit_tests_outcome" = "success" ] && echo $pass || echo $fail )
|
||||||
legacytests=$( [ "$legacytests_outcome" = "success" ] && echo $pass || echo $fail )
|
legacy_tests=$( [ "$legacy_tests_outcome" = "success" ] && echo $pass || echo $fail )
|
||||||
echo "unittests=$unittests" >> $GITHUB_OUTPUT
|
echo "unit-tests=$unit_tests" >> $GITHUB_OUTPUT
|
||||||
echo "legacytests=$legacytests" >> $GITHUB_OUTPUT
|
echo "legacy-tests=$legacy_tests" >> $GITHUB_OUTPUT
|
||||||
shell: bash
|
shell: bash
|
||||||
|
|
||||||
- name: Summary row
|
- name: Summary row
|
||||||
@ -63,8 +63,8 @@ runs:
|
|||||||
|
|
||||||
row=""
|
row=""
|
||||||
row+="| ${{ inputs.job }} "
|
row+="| ${{ inputs.job }} "
|
||||||
row+="| ${{ steps.results.outputs.unittests }} "
|
row+="| ${{ steps.results.outputs.unit-tests }} "
|
||||||
row+="| ${{ steps.results.outputs.legacytests }} "
|
row+="| ${{ steps.results.outputs.legacy-tests }} "
|
||||||
echo "$row" > $file
|
echo "$row" > $file
|
||||||
|
|
||||||
echo "file=$file" > $GITHUB_OUTPUT
|
echo "file=$file" > $GITHUB_OUTPUT
|
||||||
@ -77,7 +77,7 @@ runs:
|
|||||||
path: ${{ steps.row.outputs.file }}
|
path: ${{ steps.row.outputs.file }}
|
||||||
|
|
||||||
- name: Check test outcome
|
- name: Check test outcome
|
||||||
if: (steps.unittests.outcome != 'success' || steps.legacytests.outcome != 'success')
|
if: (steps.unit-tests.outcome != 'success' || steps.legacy-tests.outcome != 'success')
|
||||||
run: |
|
run: |
|
||||||
echo "Tests failed"
|
echo "Tests failed"
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
49
.github/actions/test-package/action.yml
vendored
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
name: "Test Package"
|
||||||
|
description: "Installs the built package and verifies the installed binaries can run"
|
||||||
|
|
||||||
|
inputs:
|
||||||
|
like:
|
||||||
|
description: "Used only on linux distro type: debian, fedora, suse, arch"
|
||||||
|
required: false
|
||||||
|
default: ""
|
||||||
|
|
||||||
|
runs:
|
||||||
|
using: "composite"
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Test package
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
if [ "$RUNNER_OS" == "macOS" ]; then
|
||||||
|
dmg=$(ls build/deskflow-*.dmg | head -1)
|
||||||
|
echo "Y" | hdiutil attach "$dmg" -nobrowse -mountpoint /tmp/deskflow-dmg
|
||||||
|
/tmp/deskflow-dmg/Deskflow.app/Contents/MacOS/deskflow-core --version
|
||||||
|
hdiutil detach /tmp/deskflow-dmg
|
||||||
|
|
||||||
|
elif [ "$RUNNER_OS" == "Windows" ]; then
|
||||||
|
7z x build/deskflow-*-portable.7z -otmp/deskflow-pkg
|
||||||
|
exe=$(find tmp/deskflow-pkg -name "deskflow-core.exe" -type f | head -1)
|
||||||
|
exe_dir=$(dirname "$exe")
|
||||||
|
pkg_root=$(dirname "$exe_dir")
|
||||||
|
export PATH="$exe_dir:$pkg_root:$pkg_root/lib:$PATH"
|
||||||
|
"$exe" --version
|
||||||
|
|
||||||
|
elif [ "$RUNNER_OS" == "Linux" ]; then
|
||||||
|
if [ "${{inputs.like}}" == "debian" ]; then
|
||||||
|
apt-get install -y ./build/deskflow-*.deb
|
||||||
|
elif [ "${{inputs.like}}" == "fedora" ]; then
|
||||||
|
dnf install -y build/deskflow-*.rpm
|
||||||
|
elif [ "${{inputs.like}}" == "suse" ]; then
|
||||||
|
zypper install -y --allow-unsigned-rpm build/deskflow-*.rpm
|
||||||
|
elif [ "${{inputs.like}}" == "arch" ]; then
|
||||||
|
pacman -U --noconfirm build/deskflow-*.pkg.tar.zst
|
||||||
|
else
|
||||||
|
echo "Unknown like: ${{inputs.like}}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
deskflow-core --version
|
||||||
|
|
||||||
|
else
|
||||||
|
echo "Unknown OS: $RUNNER_OS"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
23
.github/actions/test-summary/action.yml
vendored
@ -28,8 +28,7 @@ runs:
|
|||||||
# Builds a markdown table from the row artifacts.
|
# Builds a markdown table from the row artifacts.
|
||||||
|
|
||||||
header=$(cat <<EOF
|
header=$(cat <<EOF
|
||||||
# Test results
|
| OS | Unit tests | Legacy tests |
|
||||||
| Job name | Unit tests | Integration tests |
|
|
||||||
| --- | --- | --- |
|
| --- | --- | --- |
|
||||||
EOF
|
EOF
|
||||||
)
|
)
|
||||||
@ -57,15 +56,25 @@ runs:
|
|||||||
if [ -z "$table" ]; then
|
if [ -z "$table" ]; then
|
||||||
echo "No test results found" | tee $GITHUB_STEP_SUMMARY >&2
|
echo "No test results found" | tee $GITHUB_STEP_SUMMARY >&2
|
||||||
exit 1
|
exit 1
|
||||||
else
|
|
||||||
echo "$table" > $GITHUB_STEP_SUMMARY
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
count=$(echo "$table" | awk -v RS='' '{gsub(/[^❌]/, ""); print length}')
|
echo "$table" > $GITHUB_STEP_SUMMARY
|
||||||
file="ci-summary.md"
|
|
||||||
|
|
||||||
|
count=$(echo "$table" | { grep -o '❌' || true; } | wc -l)
|
||||||
|
|
||||||
|
# Keep at this indentation level for heredoc.
|
||||||
|
fail_summary=$(cat <<EOF
|
||||||
|
### Test result
|
||||||
|
|
||||||
|
❌🔬 Tests failed: $count
|
||||||
|
|
||||||
|
$table
|
||||||
|
EOF
|
||||||
|
)
|
||||||
|
|
||||||
|
file="ci-summary.md"
|
||||||
if [ $count -gt 0 ]; then
|
if [ $count -gt 0 ]; then
|
||||||
echo "❌🔬 Tests failed: $count" | tee $file
|
echo "$fail_summary" | tee $file
|
||||||
echo "file=$file" >> $GITHUB_OUTPUT
|
echo "file=$file" >> $GITHUB_OUTPUT
|
||||||
else
|
else
|
||||||
# For debugging; don't send success to CI summary (reduce noise).
|
# For debugging; don't send success to CI summary (reduce noise).
|
||||||
|
|||||||
33
.github/actions/winget-publish/action.yaml
vendored
@ -1,33 +0,0 @@
|
|||||||
name: Winget Publish
|
|
||||||
description: A composite action to publish packages to the Windows Package Manager (Winget) repository
|
|
||||||
|
|
||||||
inputs:
|
|
||||||
release-version:
|
|
||||||
description: "Version to publish to Winget package manager (without 'v' prefix)"
|
|
||||||
required: true
|
|
||||||
token:
|
|
||||||
description: "GitHub token with public read permissions on the source repo"
|
|
||||||
required: true
|
|
||||||
|
|
||||||
runs:
|
|
||||||
using: "composite"
|
|
||||||
steps:
|
|
||||||
- name: Submit package to Windows Package Manager Community Repository
|
|
||||||
if: ${{ runner.os == 'Windows' }}
|
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ inputs.token }}
|
|
||||||
run: |
|
|
||||||
# Download latest wingetcreate
|
|
||||||
Invoke-WebRequest https://aka.ms/wingetcreate/latest -OutFile wingetcreate.exe
|
|
||||||
|
|
||||||
$packageId = "Deskflow.Deskflow"
|
|
||||||
$x64Url = "https://github.com/deskflow/deskflow/releases/download/v${{ inputs.release-version }}/deskflow-${{ inputs.release-version }}-win-x64.msi"
|
|
||||||
$arm64Url = "https://github.com/deskflow/deskflow/releases/download/v${{ inputs.release-version }}/deskflow-${{ inputs.release-version }}-win-arm64.msi"
|
|
||||||
|
|
||||||
# Submit package update
|
|
||||||
.\wingetcreate.exe update "$packageId" `
|
|
||||||
--version "${{ inputs.release-version }}" `
|
|
||||||
--urls "$x64Url|x64" "$arm64Url|arm64"`
|
|
||||||
--submit `
|
|
||||||
--token "${{ inputs.token }}"
|
|
||||||
shell: pwsh
|
|
||||||
15
.github/pull_request_template.md
vendored
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
## Description
|
||||||
|
<!--- Describe your what your changes do -->
|
||||||
|
|
||||||
|
## Disclosure of AI use
|
||||||
|
<!--- Disclouse your use of AI Tools used to make this pr -->
|
||||||
|
<!--- If any AI tools were used to crate the code let us know -->
|
||||||
|
|
||||||
|
## Related Issue
|
||||||
|
<!--- If fixing an issue you must add a `fixes` line for each issues fixed-->
|
||||||
|
<!--- Example, if fixing Issues #1234 you would add -->
|
||||||
|
<!--- fixes: #1234 -->
|
||||||
|
|
||||||
|
## How Has This Been Tested?
|
||||||
|
<!--- Please describe how you tested your changes -->
|
||||||
|
<!--- Include details of your testing environment -->
|
||||||
16
.github/workflows/ci-comment.yml
vendored
@ -18,12 +18,15 @@ on:
|
|||||||
jobs:
|
jobs:
|
||||||
summary:
|
summary:
|
||||||
if: github.event.workflow_run.event == 'pull_request'
|
if: github.event.workflow_run.event == 'pull_request'
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-slim
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
|
# If the workflow fails before uploading summaries, no artifacts exist and this step fails.
|
||||||
|
# Allow failure so the "Delete PR comment" step still runs to clean up stale comments.
|
||||||
- name: Download summaries
|
- name: Download summaries
|
||||||
id: download
|
id: download
|
||||||
uses: actions/download-artifact@v4
|
uses: actions/download-artifact@v4
|
||||||
|
continue-on-error: true
|
||||||
with:
|
with:
|
||||||
run-id: ${{ github.event.workflow_run.id }}
|
run-id: ${{ github.event.workflow_run.id }}
|
||||||
pattern: summary-*
|
pattern: summary-*
|
||||||
@ -54,15 +57,16 @@ jobs:
|
|||||||
console.log("Found PR:", pr.number);
|
console.log("Found PR:", pr.number);
|
||||||
return pr.number;
|
return pr.number;
|
||||||
} else {
|
} else {
|
||||||
core.setFailed("PR not found");
|
core.warning("PR not found for SHA (maybe removed by force push)");
|
||||||
}
|
}
|
||||||
|
|
||||||
- name: Merge summaries
|
- name: Merge summaries
|
||||||
|
if: steps.get-pr-number.outputs.result
|
||||||
id: summary
|
id: summary
|
||||||
run: |
|
run: |
|
||||||
ls -R
|
ls -R
|
||||||
|
|
||||||
files=$(find $dir -type f)
|
files=$(find summaries -type f 2>/dev/null || true)
|
||||||
if [ -z "$files" ]; then
|
if [ -z "$files" ]; then
|
||||||
echo "No files found in dir: $dir"
|
echo "No files found in dir: $dir"
|
||||||
exit 0
|
exit 0
|
||||||
@ -76,7 +80,7 @@ jobs:
|
|||||||
echo "## CI Summary"
|
echo "## CI Summary"
|
||||||
|
|
||||||
for file in $files; do
|
for file in $files; do
|
||||||
echo $(cat $file)
|
cat $file
|
||||||
done
|
done
|
||||||
|
|
||||||
echo
|
echo
|
||||||
@ -85,7 +89,7 @@ jobs:
|
|||||||
} >> $GITHUB_OUTPUT
|
} >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
- name: Set PR comment
|
- name: Set PR comment
|
||||||
if: steps.summary.outputs.message
|
if: steps.get-pr-number.outputs.result && steps.summary.outputs.message
|
||||||
uses: marocchino/sticky-pull-request-comment@v2
|
uses: marocchino/sticky-pull-request-comment@v2
|
||||||
with:
|
with:
|
||||||
number: ${{ steps.get-pr-number.outputs.result }}
|
number: ${{ steps.get-pr-number.outputs.result }}
|
||||||
@ -93,7 +97,7 @@ jobs:
|
|||||||
message: ${{ steps.summary.outputs.message }}
|
message: ${{ steps.summary.outputs.message }}
|
||||||
|
|
||||||
- name: Delete PR comment
|
- name: Delete PR comment
|
||||||
if: ${{ !steps.summary.outputs.message }}
|
if: ${{ steps.get-pr-number.outputs.result && !steps.summary.outputs.message }}
|
||||||
uses: marocchino/sticky-pull-request-comment@v2
|
uses: marocchino/sticky-pull-request-comment@v2
|
||||||
with:
|
with:
|
||||||
number: ${{ steps.get-pr-number.outputs.result }}
|
number: ${{ steps.get-pr-number.outputs.result }}
|
||||||
|
|||||||
57
.github/workflows/codeql-analysis.yml
vendored
@ -1,42 +1,37 @@
|
|||||||
name: "CodeQL Analysis"
|
name: "CodeQL Analysis"
|
||||||
|
|
||||||
# According to the docs, the CodeQL workflow should be triggered directly by push to master
|
# This is best run as a standalone workflow, not as part of another workflow like CI
|
||||||
# and by pull requests (we only run this on open PRs as it's very slow). We also use the
|
# because of how GitHub understands the code scanning workflows in it's UI.
|
||||||
# `workflow_dispatch` event is also enabled to allow manual triggering of the workflow for testing.
|
|
||||||
#
|
|
||||||
# We should not trigger this workflow with `workflow_call` as this causes the error:
|
|
||||||
# "1 configuration present on `master` was not found"
|
|
||||||
#
|
|
||||||
# Sadly, this means we can't roll it into our monolithic CI workflow.
|
|
||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
pull_request:
|
pull_request:
|
||||||
types: [opened, synchronize, reopened, ready_for_review]
|
paths:
|
||||||
paths-ignore:
|
- '.github/workflows/codeql-analysis.yml'
|
||||||
- '**/*.md'
|
- 'cmake/Libraries.cmake'
|
||||||
- '.github/ISSUE_TEMPLATE/**'
|
- 'CMakeLists.txt'
|
||||||
- '.editorconfig'
|
- 'src/**'
|
||||||
- '.env-example'
|
- '!src/res/**'
|
||||||
- '.gitignore'
|
- '!src/unittests/**'
|
||||||
- '.gitattributes'
|
|
||||||
- 'cspell.json'
|
|
||||||
push:
|
push:
|
||||||
branches: [master]
|
branches: [master]
|
||||||
|
paths:
|
||||||
|
- '.github/workflows/codeql-analysis.yml'
|
||||||
|
- 'cmake/Libraries.cmake'
|
||||||
|
- 'CMakeLists.txt'
|
||||||
|
- 'src/**'
|
||||||
|
- '!src/res/**'
|
||||||
|
- '!src/unittests/**'
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
group: ${{ github.workflow }}-${{ github.ref }}
|
||||||
|
cancel-in-progress: true
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
analyze:
|
codeql:
|
||||||
if: ${{ !github.event.pull_request.draft }}
|
|
||||||
|
|
||||||
name: Analyze
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
container: debian:trixie-slim
|
container: debian:trixie-slim
|
||||||
timeout-minutes: 20
|
timeout-minutes: 20
|
||||||
|
|
||||||
strategy:
|
|
||||||
fail-fast: false
|
|
||||||
matrix:
|
|
||||||
language: ["cpp"]
|
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Install container dependencies
|
- name: Install container dependencies
|
||||||
run: |
|
run: |
|
||||||
@ -44,7 +39,7 @@ jobs:
|
|||||||
apt install -qqq git > /dev/null
|
apt install -qqq git > /dev/null
|
||||||
|
|
||||||
- name: Fancy Checkout
|
- name: Fancy Checkout
|
||||||
uses: sithlord48/fancy-checkout@v1
|
uses: sithlord48/fancy-checkout@v2
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
uses: ./.github/actions/install-dependencies
|
uses: ./.github/actions/install-dependencies
|
||||||
@ -52,12 +47,12 @@ jobs:
|
|||||||
like: "debian"
|
like: "debian"
|
||||||
|
|
||||||
- name: Initialize CodeQL
|
- name: Initialize CodeQL
|
||||||
uses: github/codeql-action/init@v3
|
uses: github/codeql-action/init@v4
|
||||||
with:
|
with:
|
||||||
languages: ${{ matrix.language }}
|
languages: cpp
|
||||||
|
|
||||||
- name: Autobuild
|
- name: Autobuild
|
||||||
uses: github/codeql-action/autobuild@v3
|
uses: github/codeql-action/autobuild@v4
|
||||||
|
|
||||||
- name: Perform CodeQL Analysis
|
- name: Perform CodeQL Analysis
|
||||||
uses: github/codeql-action/analyze@v3
|
uses: github/codeql-action/analyze@v4
|
||||||
|
|||||||
276
.github/workflows/continuous-integration.yml
vendored
@ -8,21 +8,12 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches: [master]
|
branches: [master]
|
||||||
tags:
|
tags:
|
||||||
- 'v*'
|
- "v*"
|
||||||
pull_request:
|
pull_request:
|
||||||
types:
|
|
||||||
- opened
|
concurrency:
|
||||||
- reopened
|
group: ${{ github.workflow }}-${{ github.ref }}
|
||||||
- synchronize
|
cancel-in-progress: true
|
||||||
- ready_for_review
|
|
||||||
paths-ignore:
|
|
||||||
- '**/*.md'
|
|
||||||
- '.github/ISSUE_TEMPLATE/**'
|
|
||||||
- '.editorconfig'
|
|
||||||
- '.env-example'
|
|
||||||
- '.gitignore'
|
|
||||||
- '.gitattributes'
|
|
||||||
- 'cspell.json'
|
|
||||||
|
|
||||||
env:
|
env:
|
||||||
GIT_SHA: ${{ github.event.pull_request.head.sha || github.sha }}
|
GIT_SHA: ${{ github.event.pull_request.head.sha || github.sha }}
|
||||||
@ -31,40 +22,20 @@ env:
|
|||||||
CMAKE_CONFIGURE: "cmake -Bbuild -DCMAKE_BUILD_TYPE=Release -DSKIP_BUILD_TESTS=ON -DCMAKE_COMPILE_WARNING_AS_ERROR=ON"
|
CMAKE_CONFIGURE: "cmake -Bbuild -DCMAKE_BUILD_TYPE=Release -DSKIP_BUILD_TESTS=ON -DCMAKE_COMPILE_WARNING_AS_ERROR=ON"
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
# Always run this job, even if not on PR, since other jobs need it.
|
|
||||||
pr-comment-flags:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
needs: lint-check
|
|
||||||
|
|
||||||
outputs:
|
|
||||||
no-sonar: ${{ steps.check.outputs.no-sonar }}
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- name: Checkout
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Check PR comment for flags
|
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
|
||||||
id: check
|
|
||||||
env:
|
|
||||||
PR_BODY: ${{ github.event.pull_request.body }}
|
|
||||||
run: |
|
|
||||||
no_sonar="{no-sonar}"
|
|
||||||
|
|
||||||
if echo $PR_BODY | grep -q "$no_sonar"; then
|
|
||||||
echo "Flag $no_sonar found in PR body."
|
|
||||||
echo "no-sonar=true" >> $GITHUB_OUTPUT
|
|
||||||
else
|
|
||||||
echo "No $no_sonar flag found in PR body."
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Quality gate to allow PR merge, used in the branch protection rules.
|
# Quality gate to allow PR merge, used in the branch protection rules.
|
||||||
ci-passed:
|
ci-passed:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: [test-results, unix, flatpak]
|
needs: [main-build, test-results, unix, flatpak]
|
||||||
|
if: always()
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- run: echo "✅ CI passed" > $GITHUB_STEP_SUMMARY
|
- name: Check all steps passed
|
||||||
|
run: |
|
||||||
|
if [[ ${{needs.main-build.result}} == 'success' && ${{needs.test-results.result}} == 'success' && ${{needs.unix.result}} == 'success' && ${{needs.flatpak.result}} == 'success' ]]; then
|
||||||
|
echo "✅ CI passed" > $GITHUB_STEP_SUMMARY
|
||||||
|
else
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
# Summary of test results, combined from test result artifacts.
|
# Summary of test results, combined from test result artifacts.
|
||||||
# Runs even if the tests fail to provide a summary of the failures.
|
# Runs even if the tests fail to provide a summary of the failures.
|
||||||
@ -72,52 +43,45 @@ jobs:
|
|||||||
needs: main-build
|
needs: main-build
|
||||||
if: always() && needs.main-build.result != 'skipped'
|
if: always() && needs.main-build.result != 'skipped'
|
||||||
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-slim
|
||||||
timeout-minutes: 5
|
timeout-minutes: 5
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v5
|
||||||
|
|
||||||
- name: Test summary
|
- name: Test summary
|
||||||
uses: ./.github/actions/test-summary
|
uses: ./.github/actions/test-summary
|
||||||
|
|
||||||
reuse-lint:
|
lint-reuse:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
timeout-minutes: 5
|
timeout-minutes: 5
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v5
|
||||||
|
|
||||||
- name: REUSE Compliance Check
|
- name: REUSE Compliance Check
|
||||||
uses: fsfe/reuse-action@v4
|
uses: fsfe/reuse-action@v5
|
||||||
|
|
||||||
lint-check:
|
lint-clang:
|
||||||
needs: [reuse-lint]
|
needs: [lint-reuse]
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-slim
|
||||||
timeout-minutes: 5
|
timeout-minutes: 5
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v5
|
||||||
|
|
||||||
- name: Lint Checker
|
- name: Lint Checker
|
||||||
uses: ./.github/actions/lint-check
|
uses: ./.github/actions/lint-clang
|
||||||
|
|
||||||
analyse-valgrind:
|
analyze-valgrind:
|
||||||
needs: lint-check
|
needs: lint-clang
|
||||||
if: ${{ github.event_name == 'pull_request' }}
|
if: ${{ github.event_name == 'pull_request' }}
|
||||||
uses: ./.github/workflows/valgrind-analysis.yml
|
uses: ./.github/workflows/valgrind-analysis.yml
|
||||||
|
|
||||||
analyse-sonarcloud:
|
|
||||||
needs: pr-comment-flags
|
|
||||||
if: ${{ needs.pr-comment-flags.outputs.no-sonar != 'true' }}
|
|
||||||
uses: ./.github/workflows/sonarcloud-analysis.yml
|
|
||||||
secrets:
|
|
||||||
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
|
|
||||||
|
|
||||||
main-build:
|
main-build:
|
||||||
needs: lint-check
|
needs: lint-clang
|
||||||
name: ${{ matrix.target.name }}
|
name: ${{ matrix.target.name }}
|
||||||
runs-on: ${{ matrix.target.runs-on }}
|
runs-on: ${{ matrix.target.runs-on }}
|
||||||
container: ${{ matrix.target.container }}
|
container: ${{ matrix.target.container }}
|
||||||
@ -133,40 +97,54 @@ jobs:
|
|||||||
runs-on: "windows-2022"
|
runs-on: "windows-2022"
|
||||||
timeout: 30
|
timeout: 30
|
||||||
config-args: "-G Ninja"
|
config-args: "-G Ninja"
|
||||||
qt-version: 6.9.0
|
|
||||||
vcpkg-triplet: x64-windows-release
|
vcpkg-triplet: x64-windows-release
|
||||||
arch: "amd64"
|
arch: "amd64"
|
||||||
|
qt-version: 6.10.2
|
||||||
|
|
||||||
- name: "windows-2022-arm64"
|
- name: "windows-2022-arm64"
|
||||||
runs-on: "windows-11-arm"
|
runs-on: "windows-11-arm"
|
||||||
timeout: 30
|
timeout: 30
|
||||||
config-args: "-G Ninja"
|
config-args: "-G Ninja"
|
||||||
qt-version: 6.9.1
|
|
||||||
vcpkg-triplet: arm64-windows
|
vcpkg-triplet: arm64-windows
|
||||||
arch: "arm64"
|
arch: "arm64"
|
||||||
|
qt-version: 6.10.2
|
||||||
|
|
||||||
- name: "macos-14-arm64"
|
- name: "macos-arm64"
|
||||||
runs-on: "macos-14"
|
runs-on: macos-15
|
||||||
timeout: 10
|
timeout: 10
|
||||||
config-args: "-DCMAKE_OSX_ARCHITECTURES=\"arm64\" -DCMAKE_OSX_SYSROOT=/Applications/Xcode_15.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk"
|
qt-version: 6.10.2
|
||||||
qt-version: 6.9.1
|
config-args: '-DCMAKE_OSX_ARCHITECTURES="arm64" -DCMAKE_OSX_DEPLOYMENT_TARGET=14 -DCMAKE_OSX_SYSROOT=/Applications/Xcode_16.4.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk'
|
||||||
|
|
||||||
- name: "macos-13-x64"
|
- name: "macos-x64"
|
||||||
runs-on: macos-13
|
runs-on: macos-15-intel
|
||||||
timeout: 20
|
timeout: 20
|
||||||
config-args: "-DCMAKE_OSX_ARCHITECTURES=\"x86_64\" -DCMAKE_OSX_SYSROOT=/Applications/Xcode_15.0.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk"
|
qt-version: 6.9.3
|
||||||
qt-version: 6.9.1
|
config-args: '-DCMAKE_OSX_ARCHITECTURES="x86_64" -DCMAKE_OSX_DEPLOYMENT_TARGET=12 -DCMAKE_OSX_SYSROOT=/Applications/Xcode_16.4.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk'
|
||||||
|
|
||||||
- name: "debian-13-x86_64"
|
- name: "debian-x86_64"
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
container: debian:trixie-slim
|
container: debian:stable-slim
|
||||||
like: "debian"
|
like: "debian"
|
||||||
timeout: 20
|
timeout: 20
|
||||||
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
||||||
|
|
||||||
- name: "debian-13-arm64"
|
- name: "debian-arm64"
|
||||||
runs-on: ubuntu-24.04-arm
|
runs-on: ubuntu-24.04-arm
|
||||||
container: debian:trixie-slim
|
container: debian:stable-slim
|
||||||
|
like: "debian"
|
||||||
|
timeout: 20
|
||||||
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
||||||
|
|
||||||
|
- name: "debian-testing-x86_64"
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container: debian:testing-slim
|
||||||
|
like: "debian"
|
||||||
|
timeout: 20
|
||||||
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
||||||
|
|
||||||
|
- name: "debian-testing-arm64"
|
||||||
|
runs-on: ubuntu-24.04-arm
|
||||||
|
container: debian:testing-slim
|
||||||
like: "debian"
|
like: "debian"
|
||||||
timeout: 20
|
timeout: 20
|
||||||
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
||||||
@ -185,21 +163,21 @@ jobs:
|
|||||||
timeout: 20
|
timeout: 20
|
||||||
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
||||||
|
|
||||||
- name: "fedora-41-x86_64"
|
- name: "fedora-43-x86_64"
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
container: fedora:41
|
container: fedora:43
|
||||||
like: "fedora"
|
like: "fedora"
|
||||||
timeout: 20
|
timeout: 20
|
||||||
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
||||||
|
|
||||||
- name: "fedora-41-arm64"
|
- name: "fedora-43-arm64"
|
||||||
runs-on: ubuntu-24.04-arm
|
runs-on: ubuntu-24.04-arm
|
||||||
container: fedora:41
|
container: fedora:43
|
||||||
like: "fedora"
|
like: "fedora"
|
||||||
timeout: 20
|
timeout: 20
|
||||||
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
||||||
|
|
||||||
- name: "opensuse-x86_84"
|
- name: "opensuse-x86_64"
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
container: opensuse/tumbleweed:latest
|
container: opensuse/tumbleweed:latest
|
||||||
like: "suse"
|
like: "suse"
|
||||||
@ -213,23 +191,37 @@ jobs:
|
|||||||
timeout: 20
|
timeout: 20
|
||||||
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
||||||
|
|
||||||
- name: "archlinux-x86_84"
|
- name: "archlinux-x86_64"
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
container: archlinux:latest
|
container: archlinux:latest
|
||||||
like: "arch"
|
like: "arch"
|
||||||
timeout: 20
|
timeout: 20
|
||||||
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr -DBUILD_DEV_DOCS=ON"
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr -DBUILD_DEV_DOCS=ON"
|
||||||
|
|
||||||
- name: "ubuntu-25.04-x86_64"
|
- name: "ubuntu-25.10-x86_64"
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
container: ubuntu:25.04
|
container: ubuntu:25.10
|
||||||
like: "debian"
|
like: "debian"
|
||||||
timeout: 20
|
timeout: 20
|
||||||
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
||||||
|
|
||||||
- name: "ubuntu-25.04-arm64"
|
- name: "ubuntu-25.10-arm64"
|
||||||
runs-on: ubuntu-24.04-arm
|
runs-on: ubuntu-24.04-arm
|
||||||
container: ubuntu:25.04
|
container: ubuntu:25.10
|
||||||
|
like: "debian"
|
||||||
|
timeout: 20
|
||||||
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
||||||
|
|
||||||
|
- name: "ubuntu-26.04-x86_64"
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container: ubuntu:26.04
|
||||||
|
like: "debian"
|
||||||
|
timeout: 20
|
||||||
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
||||||
|
|
||||||
|
- name: "ubuntu-26.04-arm64"
|
||||||
|
runs-on: ubuntu-24.04-arm
|
||||||
|
container: ubuntu:26.04
|
||||||
like: "debian"
|
like: "debian"
|
||||||
timeout: 20
|
timeout: 20
|
||||||
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
config-args: "-G Ninja -DCMAKE_INSTALL_PREFIX=/usr"
|
||||||
@ -239,23 +231,23 @@ jobs:
|
|||||||
- name: Install Git on Container
|
- name: Install Git on Container
|
||||||
if: ${{ matrix.target.container }}
|
if: ${{ matrix.target.container }}
|
||||||
shell: bash
|
shell: bash
|
||||||
run : |
|
run: |
|
||||||
if [ "${{matrix.target.like}}" == "debian" ]; then
|
if [ "${{matrix.target.like}}" == "debian" ]; then
|
||||||
apt update -qqq > /dev/null && apt install -qqq git devscripts > /dev/null
|
apt update -qqq > /dev/null && apt install -qqq git devscripts > /dev/null
|
||||||
elif [ "${{matrix.target.like}}" == "fedora" ]; then
|
elif [ "${{matrix.target.like}}" == "fedora" ]; then
|
||||||
dnf install -y git
|
dnf install -y git
|
||||||
elif [ "${{matrix.target.like}}" == "suse" ]; then
|
elif [ "${{matrix.target.like}}" == "suse" ]; then
|
||||||
zypper refresh
|
zypper refresh
|
||||||
zypper install -y --force-resolution git
|
zypper install -y --force-resolution git
|
||||||
elif [ "${{matrix.target.like}}" == "arch" ]; then
|
elif [ "${{matrix.target.like}}" == "arch" ]; then
|
||||||
pacman -Syu --noconfirm git
|
pacman -Syu --noconfirm git
|
||||||
else
|
else
|
||||||
echo "Unknown: ${{matrix.target.like}}"
|
echo "Unknown: ${{matrix.target.like}}"
|
||||||
fi
|
fi
|
||||||
# Fancy checkout gets all the tags
|
# Fancy checkout gets all the tags
|
||||||
# it also makes sure we can use git --describe correctly
|
# it also makes sure we can use git --describe correctly
|
||||||
- name: Fancy Checkout
|
- name: Fancy Checkout
|
||||||
uses: sithlord48/fancy-checkout@v1
|
uses: sithlord48/fancy-checkout@v2
|
||||||
|
|
||||||
# This effectively runs `vcvarsall.bat`, etc. It's not actually installing
|
# This effectively runs `vcvarsall.bat`, etc. It's not actually installing
|
||||||
# VC++ as that's already pre-installed on the Windows runner.
|
# VC++ as that's already pre-installed on the Windows runner.
|
||||||
@ -265,18 +257,22 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
arch: ${{matrix.target.arch}}
|
arch: ${{matrix.target.arch}}
|
||||||
|
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
id: get-deps
|
id: get-deps
|
||||||
uses: ./.github/actions/install-dependencies
|
uses: ./.github/actions/install-dependencies
|
||||||
with:
|
with:
|
||||||
qt-version: ${{ matrix.target.qt-version }}
|
qt-version: ${{matrix.target.qt-version}}
|
||||||
vcpkg-triplet: ${{matrix.target.vcpkg-triplet}}
|
vcpkg-triplet: ${{matrix.target.vcpkg-triplet}}
|
||||||
like: ${{ matrix.target.like }}
|
like: ${{ matrix.target.like }}
|
||||||
|
|
||||||
- name: Get version
|
- name: Get version
|
||||||
uses: ./.github/actions/get-version
|
uses: ./.github/actions/get-version
|
||||||
|
|
||||||
|
- name: Update Windows Paths
|
||||||
|
if: (runner.os == 'Windows')
|
||||||
|
shell: pwsh
|
||||||
|
run: echo "C:\Program Files\doxygen\bin" | Out-File -FilePath $env:GITHUB_PATH -Encoding utf8 -Append
|
||||||
|
|
||||||
- name: Configure
|
- name: Configure
|
||||||
run: ${{env.CMAKE_CONFIGURE}} ${{ matrix.target.config-args }} ${{ steps.get-deps.outputs.vcpkg-cmake-config }} -DPACKAGE_VERSION_LABEL="${{env.DESKFLOW_PACKAGE_VERSION}}"
|
run: ${{env.CMAKE_CONFIGURE}} ${{ matrix.target.config-args }} ${{ steps.get-deps.outputs.vcpkg-cmake-config }} -DPACKAGE_VERSION_LABEL="${{env.DESKFLOW_PACKAGE_VERSION}}"
|
||||||
|
|
||||||
@ -284,7 +280,21 @@ jobs:
|
|||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
if [[ "${{matrix.target.like}}" != "arch" ]]; then
|
if [[ "${{matrix.target.like}}" != "arch" ]]; then
|
||||||
cmake --build build --config Release -j8 --target package
|
if [ "$RUNNER_OS" != "macOS" ]; then
|
||||||
|
cmake --build build --config Release -j8 --target package
|
||||||
|
else
|
||||||
|
cmake --build build --config Release -j8
|
||||||
|
for i in $(seq 1 5); do
|
||||||
|
cmake --build build --config Release -j8 --target package 2>&1
|
||||||
|
if [ $? -eq 0 ]; then
|
||||||
|
echo "Package successful"
|
||||||
|
break
|
||||||
|
else
|
||||||
|
echo "Package attempt $i failed"
|
||||||
|
sleep 1
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
cmake --build build --config Release -j8
|
cmake --build build --config Release -j8
|
||||||
useradd -m build
|
useradd -m build
|
||||||
@ -297,18 +307,31 @@ jobs:
|
|||||||
cd ..
|
cd ..
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
- name: Check for unexpected repo changes
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
if [[ `git status --porcelain` ]]; then
|
||||||
|
echo "Unexpected changes to the repo, Often caused by forgetting to commit the updated translation files"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
- name: Tests
|
- name: Tests
|
||||||
uses: ./.github/actions/run-tests
|
uses: ./.github/actions/run-tests
|
||||||
timeout-minutes: 2
|
timeout-minutes: 2
|
||||||
with:
|
with:
|
||||||
job: ${{ matrix.target.name }}
|
job: ${{ matrix.target.name }}
|
||||||
|
|
||||||
|
- name: Test package
|
||||||
|
uses: ./.github/actions/test-package
|
||||||
|
with:
|
||||||
|
like: ${{ matrix.target.like }}
|
||||||
|
|
||||||
- name: Update Development Documentation
|
- name: Update Development Documentation
|
||||||
if: matrix.target.like == 'arch' && github.ref == 'refs/heads/master'
|
if: matrix.target.like == 'arch' && github.ref == 'refs/heads/master'
|
||||||
uses: JamesIves/github-pages-deploy-action@v4.7.3
|
uses: JamesIves/github-pages-deploy-action@v4.7.3
|
||||||
with:
|
with:
|
||||||
branch: gh-pages
|
branch: gh-pages
|
||||||
folder: build/doc/dev/html
|
folder: build/docs/dev/html
|
||||||
|
|
||||||
- name: Upload
|
- name: Upload
|
||||||
uses: actions/upload-artifact@v4
|
uses: actions/upload-artifact@v4
|
||||||
@ -318,7 +341,7 @@ jobs:
|
|||||||
|
|
||||||
# Technically, "unix" is a misnomer, but we use it here to mean "Unix-like BSD-derived".
|
# Technically, "unix" is a misnomer, but we use it here to mean "Unix-like BSD-derived".
|
||||||
unix:
|
unix:
|
||||||
needs: lint-check
|
needs: lint-clang
|
||||||
name: unix-${{ matrix.distro.name }}
|
name: unix-${{ matrix.distro.name }}
|
||||||
runs-on: ${{ vars.CI_UNIX_RUNNER || 'ubuntu-24.04' }}
|
runs-on: ${{ vars.CI_UNIX_RUNNER || 'ubuntu-24.04' }}
|
||||||
timeout-minutes: 20
|
timeout-minutes: 20
|
||||||
@ -334,7 +357,7 @@ jobs:
|
|||||||
# Fancy checkout gets all the tags
|
# Fancy checkout gets all the tags
|
||||||
# it also makes sure we can use git --describe correctly
|
# it also makes sure we can use git --describe correctly
|
||||||
- name: Fancy Checkout
|
- name: Fancy Checkout
|
||||||
uses: sithlord48/fancy-checkout@v1
|
uses: sithlord48/fancy-checkout@v2
|
||||||
- name: Build on FreeBSD
|
- name: Build on FreeBSD
|
||||||
if: ${{ matrix.distro.name == 'freebsd' }}
|
if: ${{ matrix.distro.name == 'freebsd' }}
|
||||||
uses: vmactions/freebsd-vm@v1
|
uses: vmactions/freebsd-vm@v1
|
||||||
@ -342,20 +365,20 @@ jobs:
|
|||||||
usesh: true
|
usesh: true
|
||||||
run: |
|
run: |
|
||||||
pkg install -y cmake ninja gmake gcc12 openssl glib \
|
pkg install -y cmake ninja gmake gcc12 openssl glib \
|
||||||
libX11 libXtst libxkbfile qt6-base qt6-tools gtk3 googletest \
|
libX11 libXtst libxkbfile qt6-base qt6-tools gtk3 \
|
||||||
tomlplusplus cli11 pkgconf libei libportal
|
googletest pkgconf libei libportal doxygen
|
||||||
${{env.CMAKE_CONFIGURE}} -G Ninja
|
${{env.CMAKE_CONFIGURE}} -G Ninja
|
||||||
cmake --build build -j16
|
cmake --build build -j16
|
||||||
# Integration tests are flakey by nature, make them optional.
|
# Integration tests are flakey by nature, make them optional.
|
||||||
export QT_QPA_PLATFORM=offscreen
|
export QT_QPA_PLATFORM=offscreen
|
||||||
./build/bin/unittests || true
|
./build/bin/unittests || true
|
||||||
flatpak:
|
flatpak:
|
||||||
needs: lint-check
|
needs: lint-clang
|
||||||
name: flatpak-${{matrix.flatpak.arch}}
|
name: flatpak-${{matrix.flatpak.arch}}
|
||||||
runs-on: ${{matrix.flatpak.runs-on}}
|
runs-on: ${{matrix.flatpak.runs-on}}
|
||||||
timeout-minutes: 60
|
timeout-minutes: 60
|
||||||
container:
|
container:
|
||||||
image: ghcr.io/flathub-infra/flatpak-github-actions:kde-6.8
|
image: ghcr.io/flathub-infra/flatpak-github-actions:kde-6.10
|
||||||
options: --privileged
|
options: --privileged
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
@ -367,7 +390,7 @@ jobs:
|
|||||||
arch: aarch64
|
arch: aarch64
|
||||||
steps:
|
steps:
|
||||||
- name: Check out repository
|
- name: Check out repository
|
||||||
uses: sithlord48/fancy-checkout@v1
|
uses: sithlord48/fancy-checkout@v2
|
||||||
|
|
||||||
- run: git config --global protocol.file.allow always
|
- run: git config --global protocol.file.allow always
|
||||||
|
|
||||||
@ -405,7 +428,7 @@ jobs:
|
|||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Fancy Checkout
|
- name: Fancy Checkout
|
||||||
uses: sithlord48/fancy-checkout@v1
|
uses: sithlord48/fancy-checkout@v2
|
||||||
|
|
||||||
- name: Get version
|
- name: Get version
|
||||||
uses: ./.github/actions/get-version
|
uses: ./.github/actions/get-version
|
||||||
@ -429,7 +452,7 @@ jobs:
|
|||||||
repo_token: "${{ secrets.GITHUB_TOKEN }}"
|
repo_token: "${{ secrets.GITHUB_TOKEN }}"
|
||||||
automatic_release_tag: "continuous"
|
automatic_release_tag: "continuous"
|
||||||
prerelease: true
|
prerelease: true
|
||||||
title: 'Continuous Build'
|
title: "Continuous v${{env.DESKFLOW_VERSION}}"
|
||||||
files: |
|
files: |
|
||||||
deskflow-*
|
deskflow-*
|
||||||
sums.txt
|
sums.txt
|
||||||
@ -443,20 +466,13 @@ jobs:
|
|||||||
files: |
|
files: |
|
||||||
deskflow-*
|
deskflow-*
|
||||||
sums.txt
|
sums.txt
|
||||||
|
|
||||||
winget-publish:
|
|
||||||
needs: release
|
|
||||||
if: contains(github.ref, 'tags/v')
|
|
||||||
runs-on: windows-latest
|
|
||||||
steps:
|
|
||||||
- name: Fancy Checkout
|
|
||||||
uses: sithlord48/fancy-checkout@v1
|
|
||||||
|
|
||||||
- name: Get version
|
- name: Update Homebrewtap
|
||||||
uses: ./.github/actions/get-version
|
shell: bash
|
||||||
|
run: |
|
||||||
- name: Submit
|
curl -L -X POST \
|
||||||
uses: ./.github/actions/winget-publish
|
-H "Accept: application/vnd.github+json" \
|
||||||
with:
|
-H "Authorization: Bearer ${{ secrets.DF_TAP_TOKEN }}" \
|
||||||
release-version: ${{env.DESKFLOW_PACKAGE_VERSION}}
|
-H "X-GitHub-Api-Version: 2022-11-28" \
|
||||||
token: ${{ secrets.WINGET_DEPLOY_TOKEN }}
|
https://api.github.com/repos/deskflow/homebrew-tap/dispatches \
|
||||||
|
-d '{"event_type":"update_tap"}'
|
||||||
|
|||||||
2
.github/workflows/issue-check-stale.yml
vendored
@ -5,7 +5,7 @@ on:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
stale-issues:
|
stale-issues:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-slim
|
||||||
timeout-minutes: 10
|
timeout-minutes: 10
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
|
|||||||
53
.github/workflows/sonarcloud-analysis.yml
vendored
@ -1,14 +1,36 @@
|
|||||||
name: "SonarCloud Analysis"
|
name: "SonarCloud Analysis"
|
||||||
|
|
||||||
|
# This is best run as a standalone workflow, not as part of another workflow like CI
|
||||||
|
# because of how GitHub understands the code scanning workflows in it's UI.
|
||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
workflow_call:
|
pull_request:
|
||||||
secrets:
|
paths:
|
||||||
SONAR_TOKEN:
|
- '.github/workflows/sonarcloud-analysis.yml'
|
||||||
required: true
|
- 'sonar-project.properties'
|
||||||
|
- 'cmake/Libraries.cmake'
|
||||||
|
- 'CMakeLists.txt'
|
||||||
|
- 'src/**'
|
||||||
|
- '!src/res/**'
|
||||||
|
- '!src/unittests/**'
|
||||||
|
push:
|
||||||
|
branches: [master]
|
||||||
|
paths:
|
||||||
|
- '.github/workflows/codeql-analysis.yml'
|
||||||
|
- 'cmake/Libraries.cmake'
|
||||||
|
- 'CMakeLists.txt'
|
||||||
|
- 'src/**'
|
||||||
|
- '!src/res/**'
|
||||||
|
- '!src/unittests/**'
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
group: ${{ github.workflow }}-${{ github.ref }}
|
||||||
|
cancel-in-progress: true
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
sonarcloud-analysis:
|
sonar:
|
||||||
|
# This job would fail for contributors who open PRs as the workflow runs outside of our repo
|
||||||
|
# in this scenario. Having a var that only we set to true prevents this job from running.
|
||||||
if: ${{ vars.SONAR_SCANNER_ENABLED }}
|
if: ${{ vars.SONAR_SCANNER_ENABLED }}
|
||||||
|
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
@ -16,10 +38,7 @@ jobs:
|
|||||||
timeout-minutes: 20
|
timeout-minutes: 20
|
||||||
|
|
||||||
env:
|
env:
|
||||||
SONAR_SCANNER_VERSION: 6.1.0.4477
|
CPU_CORE_COUNT: 4
|
||||||
SONAR_SCANNER_OPTS: -server
|
|
||||||
SONAR_SCANNER_URL_BASE: https://binaries.sonarsource.com/Distribution/sonar-scanner-cli
|
|
||||||
CPU_CORE_COUNT: ${{ vars.SONAR_SCANNER_CPU_COUNT || 4 }}
|
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Install container dependencies
|
- name: Install container dependencies
|
||||||
@ -28,15 +47,15 @@ jobs:
|
|||||||
apt install -qqq git curl unzip gcovr > /dev/null
|
apt install -qqq git curl unzip gcovr > /dev/null
|
||||||
|
|
||||||
- name: Fancy Checkout
|
- name: Fancy Checkout
|
||||||
uses: sithlord48/fancy-checkout@v1
|
uses: sithlord48/fancy-checkout@v2
|
||||||
|
|
||||||
- name: Install project dependencies
|
- name: Install project dependencies
|
||||||
uses: ./.github/actions/install-dependencies
|
uses: ./.github/actions/install-dependencies
|
||||||
with:
|
with:
|
||||||
like: "debian"
|
like: "debian"
|
||||||
|
|
||||||
- name: Install sonar-scanner and build-wrapper
|
- name: Install Build Wrapper
|
||||||
uses: sonarsource/sonarcloud-github-c-cpp@v3
|
uses: SonarSource/sonarqube-scan-action/install-build-wrapper@v6
|
||||||
|
|
||||||
- name: Configure
|
- name: Configure
|
||||||
run: |
|
run: |
|
||||||
@ -71,11 +90,11 @@ jobs:
|
|||||||
fi
|
fi
|
||||||
echo "csv=$paths" >> $GITHUB_OUTPUT
|
echo "csv=$paths" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
- name: Run SonarScanner
|
- name: SonarQube Scan
|
||||||
run: |
|
uses: SonarSource/sonarqube-scan-action@v6
|
||||||
export PATH=$HOME/.sonar/sonar-scanner-$SONAR_SCANNER_VERSION-linux-x64/bin:$PATH
|
with:
|
||||||
sonar-scanner \
|
args: >
|
||||||
-Dsonar.coverageReportPaths=${{ steps.coverage-paths.outputs.csv }} \
|
-Dsonar.coverageReportPaths=${{ steps.coverage-paths.outputs.csv }}
|
||||||
-Dsonar.cfamily.threads=${{ env.CPU_CORE_COUNT }}
|
-Dsonar.cfamily.threads=${{ env.CPU_CORE_COUNT }}
|
||||||
env:
|
env:
|
||||||
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
|
SONAR_TOKEN: ${{ secrets.SONAR_TOKEN }}
|
||||||
|
|||||||
2
.github/workflows/valgrind-analysis.yml
vendored
@ -17,7 +17,7 @@ jobs:
|
|||||||
apt install -qqq git valgrind > /dev/null
|
apt install -qqq git valgrind > /dev/null
|
||||||
|
|
||||||
- name: Fancy Checkout
|
- name: Fancy Checkout
|
||||||
uses: sithlord48/fancy-checkout@v1
|
uses: sithlord48/fancy-checkout@v2
|
||||||
|
|
||||||
- name: Install dependencies
|
- name: Install dependencies
|
||||||
uses: ./.github/actions/install-dependencies
|
uses: ./.github/actions/install-dependencies
|
||||||
|
|||||||
7
.gitignore
vendored
@ -25,6 +25,9 @@ deskflow-config.toml
|
|||||||
/*.user
|
/*.user
|
||||||
*.ui.autosave
|
*.ui.autosave
|
||||||
|
|
||||||
|
#Qt creator 18 user files
|
||||||
|
/.qtcreator
|
||||||
|
|
||||||
# generated vcpkg file
|
# generated vcpkg file
|
||||||
vcpkg.json
|
vcpkg.json
|
||||||
|
|
||||||
@ -42,3 +45,7 @@ CMakeFiles/*
|
|||||||
|
|
||||||
# scripts folder
|
# scripts folder
|
||||||
/scripts
|
/scripts
|
||||||
|
|
||||||
|
# Ai helperfilers
|
||||||
|
**/[cC]laude.[mM][dD]
|
||||||
|
**/CLAUDE.[mM][dD]
|
||||||
|
|||||||
141
CMakeLists.txt
@ -1,6 +1,6 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 - 2025 Deskflow Developers
|
# SPDX-FileCopyrightText: (C) 2024 - 2026 Deskflow Developers
|
||||||
# SPDX-FileCopyrightText: 2012 - 2024 Symless Ltd
|
# SPDX-FileCopyrightText: (C) 2012 - 2024 Symless Ltd
|
||||||
# SPDX-FileCopyrightText: 2009 - 2012 Nick Bolton
|
# SPDX-FileCopyrightText: (C) 2009 - 2012 Nick Bolton
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
cmake_minimum_required(VERSION 3.24)
|
cmake_minimum_required(VERSION 3.24)
|
||||||
@ -11,6 +11,11 @@ cmake_policy(SET CMP0003 NEW)
|
|||||||
# Fix define escaping
|
# Fix define escaping
|
||||||
cmake_policy(SET CMP0005 NEW)
|
cmake_policy(SET CMP0005 NEW)
|
||||||
|
|
||||||
|
# De-duplicate libraries on linker calls
|
||||||
|
if(POLICY CMP0156)
|
||||||
|
cmake_policy(SET CMP0156 NEW)
|
||||||
|
endif()
|
||||||
|
|
||||||
# Set CXX Requirements
|
# Set CXX Requirements
|
||||||
set(CMAKE_CXX_STANDARD 20)
|
set(CMAKE_CXX_STANDARD 20)
|
||||||
set(CMAKE_CXX_EXTENSIONS OFF)
|
set(CMAKE_CXX_EXTENSIONS OFF)
|
||||||
@ -18,7 +23,7 @@ set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
|||||||
|
|
||||||
# Fallback for when git can not be found
|
# Fallback for when git can not be found
|
||||||
set(DESKFLOW_VERSION_MAJOR 1)
|
set(DESKFLOW_VERSION_MAJOR 1)
|
||||||
set(DESKFLOW_VERSION_MINOR 23)
|
set(DESKFLOW_VERSION_MINOR 26)
|
||||||
set(DESKFLOW_VERSION_PATCH 0)
|
set(DESKFLOW_VERSION_PATCH 0)
|
||||||
set(DESKFLOW_VERSION_TWEAK 0)
|
set(DESKFLOW_VERSION_TWEAK 0)
|
||||||
|
|
||||||
@ -33,38 +38,28 @@ if(EXISTS ${CMAKE_CURRENT_SOURCE_DIR}/.git)
|
|||||||
ERROR_QUIET OUTPUT_STRIP_TRAILING_WHITESPACE
|
ERROR_QUIET OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||||
)
|
)
|
||||||
execute_process(
|
execute_process(
|
||||||
COMMAND ${GIT_EXECUTABLE} rev-list --tags --count
|
COMMAND ${GIT_EXECUTABLE} describe --long --match v* --always
|
||||||
WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
|
WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
|
||||||
OUTPUT_VARIABLE GIT_TAG_COUNT
|
OUTPUT_VARIABLE GITREV
|
||||||
ERROR_QUIET OUTPUT_STRIP_TRAILING_WHITESPACE
|
ERROR_QUIET OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||||
)
|
)
|
||||||
|
string(FIND "${GITREV}" "v" isRev)
|
||||||
if(GIT_TAG_COUNT EQUAL 0)
|
if(NOT ${isRev} EQUAL -1)
|
||||||
set(DESKFLOW_VERSION_TWEAK "9999")
|
string(REGEX MATCH [0-9]+ MAJOR ${GITREV})
|
||||||
|
string(REGEX MATCH \\.[0-9]+ MINOR ${GITREV})
|
||||||
|
string(REPLACE "." "" MINOR "${MINOR}")
|
||||||
|
string(REGEX MATCH [0-9]+\- PATCH ${GITREV})
|
||||||
|
string(REPLACE "-" "" PATCH "${PATCH}")
|
||||||
|
string(REGEX MATCH \-[0-9]+\- TWEAK ${GITREV})
|
||||||
|
string(REPLACE "-" "" TWEAK "${TWEAK}")
|
||||||
|
set(DESKFLOW_VERSION_MAJOR ${MAJOR})
|
||||||
|
set(DESKFLOW_VERSION_MINOR ${MINOR})
|
||||||
|
set(DESKFLOW_VERSION_PATCH ${PATCH})
|
||||||
|
set(DESKFLOW_VERSION_TWEAK ${TWEAK})
|
||||||
else()
|
else()
|
||||||
execute_process(
|
set(DESKFLOW_VERSION_TWEAK "9999")
|
||||||
COMMAND ${GIT_EXECUTABLE} describe --long --match v* --always
|
|
||||||
WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
|
|
||||||
OUTPUT_VARIABLE GITREV
|
|
||||||
ERROR_QUIET OUTPUT_STRIP_TRAILING_WHITESPACE
|
|
||||||
)
|
|
||||||
string(FIND ${GITREV} "v" isRev)
|
|
||||||
if(NOT ifRev EQUAL -1)
|
|
||||||
string(REGEX MATCH [0-9]+ MAJOR ${GITREV})
|
|
||||||
string(REGEX MATCH \\.[0-9]+ MINOR ${GITREV})
|
|
||||||
string(REPLACE "." "" MINOR "${MINOR}")
|
|
||||||
string(REGEX MATCH [0-9]+\- PATCH ${GITREV})
|
|
||||||
string(REPLACE "-" "" PATCH "${PATCH}")
|
|
||||||
string(REGEX MATCH \-[0-9]+\- TWEAK ${GITREV})
|
|
||||||
string(REPLACE "-" "" TWEAK "${TWEAK}")
|
|
||||||
set(DESKFLOW_VERSION_MAJOR ${MAJOR})
|
|
||||||
set(DESKFLOW_VERSION_MINOR ${MINOR})
|
|
||||||
set(DESKFLOW_VERSION_PATCH ${PATCH})
|
|
||||||
set(DESKFLOW_VERSION_TWEAK ${TWEAK})
|
|
||||||
elseif(NOT ${GITREV} STREQUAL "")
|
|
||||||
set(DESKFLOW_VERSION_TWEAK ${GITREV})
|
|
||||||
endif()
|
|
||||||
endif()
|
endif()
|
||||||
|
unset(GITREV)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
@ -82,13 +77,16 @@ project(
|
|||||||
deskflow
|
deskflow
|
||||||
VERSION "${DESKFLOW_VERSION_MAJOR}.${DESKFLOW_VERSION_MINOR}.${DESKFLOW_VERSION_PATCH}.${DESKFLOW_VERSION_TWEAK}"
|
VERSION "${DESKFLOW_VERSION_MAJOR}.${DESKFLOW_VERSION_MINOR}.${DESKFLOW_VERSION_PATCH}.${DESKFLOW_VERSION_TWEAK}"
|
||||||
DESCRIPTION "Keyboard and mouse sharing utility"
|
DESCRIPTION "Keyboard and mouse sharing utility"
|
||||||
LANGUAGES C CXX)
|
HOMEPAGE_URL "https://deskflow.org"
|
||||||
|
LANGUAGES C CXX
|
||||||
|
)
|
||||||
|
|
||||||
# Define Additional "PROJECT" vars for packaging and metadata
|
# Define Additional "PROJECT" vars for packaging and metadata
|
||||||
set(CMAKE_PROJECT_PROPER_NAME "Deskflow")
|
set(CMAKE_PROJECT_PROPER_NAME "Deskflow")
|
||||||
set(CMAKE_PROJECT_VENDOR "${CMAKE_PROJECT_PROPER_NAME} Devs")
|
set(CMAKE_PROJECT_VENDOR "${CMAKE_PROJECT_PROPER_NAME} Devs")
|
||||||
set(CMAKE_PROJECT_COPYRIGHT "(C) 2024-2025 ${CMAKE_PROJECT_VENDOR}")
|
set(CMAKE_PROJECT_COPYRIGHT "(C) 2024-2026 ${CMAKE_PROJECT_VENDOR}")
|
||||||
set(CMAKE_PROJECT_CONTACT "${CMAKE_PROJECT_PROPER_NAME} <maintainers@deskflow.org>")
|
set(CMAKE_PROJECT_CONTACT "${CMAKE_PROJECT_PROPER_NAME} <maintainers@deskflow.org>")
|
||||||
|
set(CMAKE_PROJECT_REV_FQDN "org.deskflow.deskflow")
|
||||||
|
|
||||||
#Unset the vars used in the project call
|
#Unset the vars used in the project call
|
||||||
unset(DESKFLOW_VERSION_MAJOR)
|
unset(DESKFLOW_VERSION_MAJOR)
|
||||||
@ -101,7 +99,7 @@ message(STATUS "Building ${CMAKE_PROJECT_NAME}-${CMAKE_PROJECT_VERSION}")
|
|||||||
# Set lib versions
|
# Set lib versions
|
||||||
set(REQUIRED_OPENSSL_VERSION 3.0)
|
set(REQUIRED_OPENSSL_VERSION 3.0)
|
||||||
set(REQUIRED_LIBEI_VERSION 1.3)
|
set(REQUIRED_LIBEI_VERSION 1.3)
|
||||||
set(REQUIRED_LIBPORTAL_VERSION 0.8)
|
set(REQUIRED_LIBPORTAL_VERSION 0.9.1)
|
||||||
set(REQUIRED_QT_VERSION 6.7.0)
|
set(REQUIRED_QT_VERSION 6.7.0)
|
||||||
|
|
||||||
if (WIN32)
|
if (WIN32)
|
||||||
@ -144,11 +142,6 @@ if(NOT CMAKE_BUILD_TYPE STREQUAL "Debug")
|
|||||||
add_definitions(-DNDEBUG)
|
add_definitions(-DNDEBUG)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Set required macOS SDK
|
|
||||||
if(APPLE)
|
|
||||||
set(CMAKE_OSX_DEPLOYMENT_TARGET 12)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
# Set Output Folders
|
# Set Output Folders
|
||||||
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY "${PROJECT_BINARY_DIR}/bin")
|
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY "${PROJECT_BINARY_DIR}/bin")
|
||||||
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY "${PROJECT_BINARY_DIR}/lib")
|
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY "${PROJECT_BINARY_DIR}/lib")
|
||||||
@ -157,38 +150,56 @@ set(CMAKE_LIBRARY_OUTPUT_DIRECTORY "${PROJECT_BINARY_DIR}/lib")
|
|||||||
# Instead use Q_SIGNAL, Q_SLOT and Q_EMIT
|
# Instead use Q_SIGNAL, Q_SLOT and Q_EMIT
|
||||||
# prevents issues when used with glib for libportal
|
# prevents issues when used with glib for libportal
|
||||||
add_definitions(-DQT_NO_KEYWORDS)
|
add_definitions(-DQT_NO_KEYWORDS)
|
||||||
include(cmake/Libraries.cmake)
|
|
||||||
include(GNUInstallDirs)
|
|
||||||
|
|
||||||
|
#Options for Linux platform support
|
||||||
|
if(UNIX AND NOT APPLE)
|
||||||
|
option(BUILD_X11_SUPPORT "Build with x11 support" ON)
|
||||||
|
elseif (APPLE)
|
||||||
|
option(BUILD_OSX_BUNDLE "Build mac os bundle" ON)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
include(cmake/Libraries.cmake)
|
||||||
configure_libs()
|
configure_libs()
|
||||||
|
|
||||||
add_subdirectory(doc)
|
if(BUILD_OSX_BUNDLE AND APPLE_CODESIGN_DEV)
|
||||||
add_subdirectory(src)
|
include(cmake/MacCodesign.cmake)
|
||||||
|
|
||||||
# Install License, License is in the App Bundle on mac os (src/gui)
|
|
||||||
if(WIN32)
|
|
||||||
install(
|
|
||||||
FILES ${PROJECT_SOURCE_DIR}/LICENSE
|
|
||||||
DESTINATION .
|
|
||||||
)
|
|
||||||
install(
|
|
||||||
FILES ${PROJECT_SOURCE_DIR}/LICENSES/LicenseRef-OpenSSL-Exception.txt
|
|
||||||
DESTINATION .
|
|
||||||
RENAME LICENSE_EXCEPTION
|
|
||||||
)
|
|
||||||
elseif(UNIX AND NOT APPLE)
|
|
||||||
install(
|
|
||||||
FILES ${PROJECT_SOURCE_DIR}/LICENSE
|
|
||||||
DESTINATION share/licenses/deskflow
|
|
||||||
)
|
|
||||||
install(
|
|
||||||
FILES ${PROJECT_SOURCE_DIR}/LICENSES/LicenseRef-OpenSSL-Exception.txt
|
|
||||||
DESTINATION share/licenses/deskflow
|
|
||||||
RENAME LICENSE_EXCEPTION
|
|
||||||
)
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# setup install paths
|
||||||
|
include(GNUInstallDirs)
|
||||||
|
if (WIN32)
|
||||||
|
set(CMAKE_INSTALL_BINDIR .)
|
||||||
|
set(CMAKE_INSTALL_LIBDIR .)
|
||||||
|
set(CMAKE_INSTALL_DOCDIR docs)
|
||||||
|
set(CMAKE_INSTALL_LICENSE_DIR .)
|
||||||
|
set(CMAKE_INSTALL_I18N_DIR translations)
|
||||||
|
elseif(BUILD_OSX_BUNDLE)
|
||||||
|
set(CMAKE_INSTALL_BINDIR ${CMAKE_PROJECT_PROPER_NAME}.app/Contents/MacOS)
|
||||||
|
set(CMAKE_INSTALL_LICENSE_DIR ${CMAKE_PROJECT_PROPER_NAME}.app/Contents/Resources)
|
||||||
|
else()
|
||||||
|
set(CMAKE_INSTALL_LICENSE_DIR ${CMAKE_INSTALL_DATADIR}/licenses/${CMAKE_PROJECT_NAME})
|
||||||
|
set(CMAKE_INSTALL_I18N_DIR ${CMAKE_INSTALL_DATADIR}/${CMAKE_PROJECT_NAME}/translations)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
add_subdirectory(docs)
|
||||||
|
|
||||||
|
# build translations before source, I18N unit tests fail if they are missing
|
||||||
|
add_subdirectory(translations)
|
||||||
|
|
||||||
|
add_subdirectory(src)
|
||||||
|
|
||||||
option(BUILD_INSTALLER "Build installer" ON)
|
option(BUILD_INSTALLER "Build installer" ON)
|
||||||
if(BUILD_INSTALLER)
|
if(BUILD_INSTALLER)
|
||||||
add_subdirectory(deploy)
|
add_subdirectory(deploy)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
install(
|
||||||
|
FILES ${PROJECT_SOURCE_DIR}/LICENSE
|
||||||
|
DESTINATION ${CMAKE_INSTALL_LICENSE_DIR}
|
||||||
|
)
|
||||||
|
|
||||||
|
install(
|
||||||
|
FILES ${PROJECT_SOURCE_DIR}/LICENSES/LicenseRef-OpenSSL-Exception.txt
|
||||||
|
DESTINATION ${CMAKE_INSTALL_LICENSE_DIR}
|
||||||
|
RENAME LICENSE_EXCEPTION
|
||||||
|
)
|
||||||
|
|||||||
11
REUSE.toml
@ -17,7 +17,7 @@ path = [
|
|||||||
, "sonar-project.properties"
|
, "sonar-project.properties"
|
||||||
, "cmake/vcpkg.json.in"
|
, "cmake/vcpkg.json.in"
|
||||||
, "**/*.md"
|
, "**/*.md"
|
||||||
, "doc/**"
|
, "docs/**"
|
||||||
, "deploy/linux/flatpak/**"
|
, "deploy/linux/flatpak/**"
|
||||||
, "deploy/linux/org.deskflow.deskflow.metainfo.xml"
|
, "deploy/linux/org.deskflow.deskflow.metainfo.xml"
|
||||||
, "deploy/windows/wix-patch.xml.in"
|
, "deploy/windows/wix-patch.xml.in"
|
||||||
@ -26,8 +26,9 @@ path = [
|
|||||||
, "src/apps/deskflow-server/deskflow-server.exe.manifest"
|
, "src/apps/deskflow-server/deskflow-server.exe.manifest"
|
||||||
, "src/apps/res/manpage.txt"
|
, "src/apps/res/manpage.txt"
|
||||||
, "src/apps/res/deskflow.plist.in"
|
, "src/apps/res/deskflow.plist.in"
|
||||||
|
, "src/apps/res/entitlements-dev.plist"
|
||||||
|
, "translations/*.ts"
|
||||||
]
|
]
|
||||||
precedence = "override"
|
|
||||||
SPDX-FileCopyrightText = "Deskflow Developers"
|
SPDX-FileCopyrightText = "Deskflow Developers"
|
||||||
SPDX-License-Identifier = "MIT"
|
SPDX-License-Identifier = "MIT"
|
||||||
|
|
||||||
@ -35,7 +36,7 @@ SPDX-License-Identifier = "MIT"
|
|||||||
path = [
|
path = [
|
||||||
"deploy/mac/dmg-background.tiff"
|
"deploy/mac/dmg-background.tiff"
|
||||||
, "deploy/mac/dmg-volume.icns"
|
, "deploy/mac/dmg-volume.icns"
|
||||||
, "deploy/linux/deskflow.png"
|
, "deploy/linux/org.deskflow.deskflow.png"
|
||||||
, "deploy/windows/wix-banner.png"
|
, "deploy/windows/wix-banner.png"
|
||||||
, "deploy/windows/wix-dialog.png"
|
, "deploy/windows/wix-dialog.png"
|
||||||
, "src/apps/res/icons/deskflow-**/apps/64/deskflow*.svg"
|
, "src/apps/res/icons/deskflow-**/apps/64/deskflow*.svg"
|
||||||
@ -44,19 +45,16 @@ path = [
|
|||||||
, "src/apps/res/deskflow.ico"
|
, "src/apps/res/deskflow.ico"
|
||||||
, "src/apps/res/deskflow.qrc"
|
, "src/apps/res/deskflow.qrc"
|
||||||
]
|
]
|
||||||
precedence = "override"
|
|
||||||
SPDX-FileCopyrightText = "Deskflow Developers"
|
SPDX-FileCopyrightText = "Deskflow Developers"
|
||||||
SPDX-License-Identifier = "GPL-2.0-only"
|
SPDX-License-Identifier = "GPL-2.0-only"
|
||||||
|
|
||||||
[[annotations]]
|
[[annotations]]
|
||||||
path = "src/apps/res/icons/deskflow-**/**/**/**.svg"
|
path = "src/apps/res/icons/deskflow-**/**/**/**.svg"
|
||||||
precedence = "override"
|
|
||||||
SPDX-FileCopyrightText = "Kde Breeze Icons"
|
SPDX-FileCopyrightText = "Kde Breeze Icons"
|
||||||
SPDX-License-Identifier = "LGPL-2.1-only"
|
SPDX-License-Identifier = "LGPL-2.1-only"
|
||||||
|
|
||||||
[[annotations]]
|
[[annotations]]
|
||||||
path = "src/apps/res/icons/deskflow-**/index.theme"
|
path = "src/apps/res/icons/deskflow-**/index.theme"
|
||||||
precedence = "override"
|
|
||||||
SPDX-FileCopyrightText = "Chris Rizzitello <sithlord48@gmail.com>"
|
SPDX-FileCopyrightText = "Chris Rizzitello <sithlord48@gmail.com>"
|
||||||
SPDX-License-Identifier = "LGPL-2.1-only"
|
SPDX-License-Identifier = "LGPL-2.1-only"
|
||||||
|
|
||||||
@ -65,6 +63,5 @@ path = [
|
|||||||
"src/lib/gui/MainWindow.ui"
|
"src/lib/gui/MainWindow.ui"
|
||||||
, "src/lib/gui/dialogs/*.ui"
|
, "src/lib/gui/dialogs/*.ui"
|
||||||
]
|
]
|
||||||
precedence = "override"
|
|
||||||
SPDX-FileCopyrightText = "Deskflow Developers"
|
SPDX-FileCopyrightText = "Deskflow Developers"
|
||||||
SPDX-License-Identifier = "GPL-2.0-only WITH LicenseRef-OpenSSL-Exception"
|
SPDX-License-Identifier = "GPL-2.0-only WITH LicenseRef-OpenSSL-Exception"
|
||||||
|
|||||||
@ -1,9 +1,9 @@
|
|||||||
# SOURCE https://github.com/bilke/cmake-modules/blob/master/CodeCoverage.cmake
|
# SOURCE https://github.com/bilke/cmake-modules/blob/master/CodeCoverage.cmake
|
||||||
# SPDX-FileCopyrightText: 2020 Bob Apthrope
|
# SPDX-FileCopyrightText: (C) 2020 Bob Apthrope
|
||||||
# SPDX-FileCopyrightText: 2019 Anatolii Kurotych
|
# SPDX-FileCopyrightText: (C) 2019 Anatolii Kurotych
|
||||||
# SPDX-FileCopyrightText: 2019 - 2020 Frank Dana
|
# SPDX-FileCopyrightText: (C) 2019 - 2020 Frank Dana
|
||||||
# SPDX-FileCopyrightText: 2013 Joakim Söderberg
|
# SPDX-FileCopyrightText: (C) 2013 Joakim Söderberg
|
||||||
# SPDX-FileCopyrightText: 2012 - 2017 Lars Bilke
|
# SPDX-FileCopyrightText: (C) 2012 - 2017 Lars Bilke
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
# USAGE:
|
# USAGE:
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 - 2025 Deskflow Developers
|
# SPDX-FileCopyrightText: (C) 2024 - 2025 Deskflow Developers
|
||||||
# SPDX-FileCopyrightText: 2024 Symless Ltd
|
# SPDX-FileCopyrightText: (C) 2024 Symless Ltd
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
macro(configure_libs)
|
macro(configure_libs)
|
||||||
@ -49,6 +49,20 @@ macro(configure_libs)
|
|||||||
|
|
||||||
message(STATUS "Qt version: ${Qt6_VERSION}")
|
message(STATUS "Qt version: ${Qt6_VERSION}")
|
||||||
|
|
||||||
|
# Check if <format> header is available
|
||||||
|
check_cxx_source_compiles("
|
||||||
|
#include <format>
|
||||||
|
int main() {
|
||||||
|
char buffer[100];
|
||||||
|
std::format_to_n(buffer, 100, \"test {}\", 42);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
" HAVE_FORMAT)
|
||||||
|
|
||||||
|
if(HAVE_FORMAT)
|
||||||
|
add_definitions(-DHAVE_FORMAT)
|
||||||
|
endif()
|
||||||
|
|
||||||
option(ENABLE_COVERAGE "Enable test coverage" OFF)
|
option(ENABLE_COVERAGE "Enable test coverage" OFF)
|
||||||
if(ENABLE_COVERAGE)
|
if(ENABLE_COVERAGE)
|
||||||
message(STATUS "Enabling code coverage")
|
message(STATUS "Enabling code coverage")
|
||||||
@ -89,6 +103,7 @@ macro(configure_unix_libs)
|
|||||||
include(CheckIncludeFileCXX)
|
include(CheckIncludeFileCXX)
|
||||||
include(CheckSymbolExists)
|
include(CheckSymbolExists)
|
||||||
include(CheckCSourceCompiles)
|
include(CheckCSourceCompiles)
|
||||||
|
include(CheckCXXSourceCompiles)
|
||||||
|
|
||||||
check_include_files(sys/socket.h HAVE_SYS_SOCKET_H)
|
check_include_files(sys/socket.h HAVE_SYS_SOCKET_H)
|
||||||
if (NOT HAVE_SYS_SOCKET_H)
|
if (NOT HAVE_SYS_SOCKET_H)
|
||||||
@ -102,30 +117,8 @@ macro(configure_unix_libs)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
check_function_exists(sigwait HAVE_POSIX_SIGWAIT)
|
check_function_exists(sigwait HAVE_POSIX_SIGWAIT)
|
||||||
check_function_exists(inet_aton HAVE_INET_ATON)
|
if (NOT HAVE_POSIX_SIGWAIT)
|
||||||
|
message(FATAL_ERROR "Missing posix sigwait")
|
||||||
# For some reason, the check_function_exists macro doesn't detect the
|
|
||||||
# inet_aton on some pure Unix platforms (e.g. sunos5). So we need to do a more
|
|
||||||
# detailed check and also include some extra libs.
|
|
||||||
if(NOT HAVE_INET_ATON)
|
|
||||||
set(CMAKE_REQUIRED_LIBRARIES nsl)
|
|
||||||
|
|
||||||
check_c_source_compiles(
|
|
||||||
"#include <arpa/inet.h>\n int main() { inet_aton (0, 0); }"
|
|
||||||
HAVE_INET_ATON_ADV)
|
|
||||||
|
|
||||||
set(CMAKE_REQUIRED_LIBRARIES)
|
|
||||||
|
|
||||||
if(HAVE_INET_ATON_ADV)
|
|
||||||
# Override the previous fail.
|
|
||||||
set(HAVE_INET_ATON 1)
|
|
||||||
|
|
||||||
# Assume that both nsl and socket will be needed, it seems safe to add
|
|
||||||
# socket on the back of nsl, since socket only ever needed when nsl is
|
|
||||||
# needed.
|
|
||||||
list(APPEND libs nsl socket)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# pthread is used on both Linux and Mac
|
# pthread is used on both Linux and Mac
|
||||||
@ -148,11 +141,11 @@ macro(configure_unix_libs)
|
|||||||
${lib_ScreenSaver} ${lib_IOKit} ${lib_ApplicationServices}
|
${lib_ScreenSaver} ${lib_IOKit} ${lib_ApplicationServices}
|
||||||
${lib_Foundation} ${lib_Carbon} ${lib_UserNotifications}
|
${lib_Foundation} ${lib_Carbon} ${lib_UserNotifications}
|
||||||
)
|
)
|
||||||
|
|
||||||
add_definitions(-DWINAPI_CARBON=1 -D_THREAD_SAFE)
|
|
||||||
else()
|
else()
|
||||||
|
|
||||||
configure_xorg_libs()
|
if (BUILD_X11_SUPPORT)
|
||||||
|
configure_xorg_libs()
|
||||||
|
endif()
|
||||||
|
|
||||||
include(FindPkgConfig)
|
include(FindPkgConfig)
|
||||||
find_package(PkgConfig)
|
find_package(PkgConfig)
|
||||||
@ -162,19 +155,12 @@ macro(configure_unix_libs)
|
|||||||
find_library(LIBM m)
|
find_library(LIBM m)
|
||||||
include_directories(${LIBXKBCOMMON_INCLUDE_DIRS} ${GLIB2_INCLUDE_DIRS}
|
include_directories(${LIBXKBCOMMON_INCLUDE_DIRS} ${GLIB2_INCLUDE_DIRS}
|
||||||
${LIBM_INCLUDE_DIRS})
|
${LIBM_INCLUDE_DIRS})
|
||||||
|
|
||||||
|
message(STATUS "xkbcommon version: ${LIBXKBCOMMON_VERSION}")
|
||||||
else()
|
else()
|
||||||
message(WARNING "pkg-config not found, skipping wayland libraries")
|
message(WARNING "pkg-config not found, skipping wayland libraries")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Unix only: For config.h, save the results based on a template (config.h.in).
|
|
||||||
# Note that this won't work on Windows because filenames are not case sensitive,
|
|
||||||
# and we have header files named "Config.h" (upper case 'C').
|
|
||||||
configure_file(${CMAKE_SOURCE_DIR}/src/lib/Config.h.in
|
|
||||||
${CMAKE_BINARY_DIR}/src/lib/Config.h @ONLY)
|
|
||||||
|
|
||||||
add_definitions(-DSYSAPI_UNIX=1 -DHAVE_CONFIG_H)
|
|
||||||
|
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|||||||
51
cmake/MacCodesign.cmake
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
# SPDX-FileCopyrightText: (C) 2025-2026 Deskflow Contributors
|
||||||
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
# Warning: Do not use for CI/production, as the `entitlements-dev.plist` file adds special
|
||||||
|
# entitlements that are only appropriate for local development.
|
||||||
|
#
|
||||||
|
# macOS made TCC stricter so that if you don't sign your local dev builds properly, macOS will
|
||||||
|
# nag you to remove and re-approve the app every time you make a change to the binary which is
|
||||||
|
# extremely annoying during development.
|
||||||
|
#
|
||||||
|
# If you were to use ad-hoc signing (i.e. not specify a certificate), TCC would still nag you
|
||||||
|
# because the binary identity is anchored not on the app ID, but on the CD hash (which changes
|
||||||
|
# based on the binary contents).
|
||||||
|
#
|
||||||
|
# To use, simply generate a personal certificate for free with Xcode and pass the ID to CMake.
|
||||||
|
# Full instructions are in the docs.
|
||||||
|
|
||||||
|
function(configure_mac_codesign target)
|
||||||
|
set_property(GLOBAL APPEND PROPERTY _MAC_CODESIGN_DEPENDS $<TARGET_FILE:${target}>)
|
||||||
|
|
||||||
|
get_property(deferred GLOBAL PROPERTY _MAC_CODESIGN_DEFERRED)
|
||||||
|
|
||||||
|
if(NOT deferred)
|
||||||
|
set_property(GLOBAL PROPERTY _MAC_CODESIGN_DEFERRED TRUE)
|
||||||
|
message(STATUS "Apple codesign ID for development only: ${APPLE_CODESIGN_DEV}")
|
||||||
|
cmake_language(DEFER DIRECTORY ${CMAKE_SOURCE_DIR} CALL _finalize_mac_codesign)
|
||||||
|
endif()
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
function(_finalize_mac_codesign)
|
||||||
|
get_property(depends GLOBAL PROPERTY _MAC_CODESIGN_DEPENDS)
|
||||||
|
|
||||||
|
set(stamp_file "${CMAKE_BINARY_DIR}/CMakeFiles/codesign-dev.stamp")
|
||||||
|
|
||||||
|
# Use a stamp file because codesign modifies the binaries it signs.
|
||||||
|
add_custom_command(
|
||||||
|
OUTPUT ${stamp_file}
|
||||||
|
COMMAND /usr/bin/codesign
|
||||||
|
--force
|
||||||
|
--options runtime
|
||||||
|
--entitlements "${CMAKE_SOURCE_DIR}/src/apps/res/entitlements-dev.plist"
|
||||||
|
--sign "${APPLE_CODESIGN_DEV}"
|
||||||
|
"$<TARGET_BUNDLE_DIR:${CMAKE_PROJECT_PROPER_NAME}>"
|
||||||
|
COMMAND ${CMAKE_COMMAND} -E touch ${stamp_file}
|
||||||
|
DEPENDS ${depends}
|
||||||
|
COMMENT "Codesigning ${CMAKE_PROJECT_PROPER_NAME}"
|
||||||
|
VERBATIM
|
||||||
|
)
|
||||||
|
|
||||||
|
add_custom_target(codesign-dev ALL DEPENDS ${stamp_file})
|
||||||
|
endfunction()
|
||||||
@ -21,6 +21,7 @@
|
|||||||
"dotenv",
|
"dotenv",
|
||||||
"Evenson",
|
"Evenson",
|
||||||
"Feder",
|
"Feder",
|
||||||
|
"Flatpaks",
|
||||||
"Fourdan",
|
"Fourdan",
|
||||||
"gdrive",
|
"gdrive",
|
||||||
"Hadzhylov",
|
"Hadzhylov",
|
||||||
@ -38,6 +39,7 @@
|
|||||||
"Kitware",
|
"Kitware",
|
||||||
"Kutytska",
|
"Kutytska",
|
||||||
"Lanz",
|
"Lanz",
|
||||||
|
"legacytests",
|
||||||
"libei",
|
"libei",
|
||||||
"Libera",
|
"Libera",
|
||||||
"libportal",
|
"libportal",
|
||||||
@ -45,6 +47,7 @@
|
|||||||
"logonui",
|
"logonui",
|
||||||
"Lysytsia",
|
"Lysytsia",
|
||||||
"macdeployqt",
|
"macdeployqt",
|
||||||
|
"mojibake",
|
||||||
"msvc",
|
"msvc",
|
||||||
"noquote",
|
"noquote",
|
||||||
"NOSONAR",
|
"NOSONAR",
|
||||||
@ -76,6 +79,8 @@
|
|||||||
"Serhii",
|
"Serhii",
|
||||||
"shemp",
|
"shemp",
|
||||||
"SNAPPROCESS",
|
"SNAPPROCESS",
|
||||||
|
"sonarcloud",
|
||||||
|
"sonarqube",
|
||||||
"Sorin",
|
"Sorin",
|
||||||
"subproject",
|
"subproject",
|
||||||
"subprojects",
|
"subprojects",
|
||||||
@ -91,7 +96,9 @@
|
|||||||
"Volker",
|
"Volker",
|
||||||
"whot",
|
"whot",
|
||||||
"winget",
|
"winget",
|
||||||
|
"wismill",
|
||||||
"writef",
|
"writef",
|
||||||
|
"xkbcommon",
|
||||||
"XWINDOWS"
|
"XWINDOWS"
|
||||||
],
|
],
|
||||||
"ignoreWords": [],
|
"ignoreWords": [],
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 Chris Rizzitello <sithlord48@gmail.com>
|
# SPDX-FileCopyrightText: (C) 2024 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
# Copy License with txt ext for picky package creation tools
|
# Copy License with txt ext for picky package creation tools
|
||||||
@ -8,7 +8,6 @@ file(COPY_FILE
|
|||||||
ONLY_IF_DIFFERENT
|
ONLY_IF_DIFFERENT
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
# Generic Package Items
|
# Generic Package Items
|
||||||
set(CPACK_STRIP_FILES TRUE)
|
set(CPACK_STRIP_FILES TRUE)
|
||||||
set(CPACK_PACKAGE_NAME ${CMAKE_PROJECT_NAME})
|
set(CPACK_PACKAGE_NAME ${CMAKE_PROJECT_NAME})
|
||||||
|
|||||||
@ -1,16 +1,17 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 Deskflow Developers
|
# SPDX-FileCopyrightText: (C) 2024 Deskflow Developers
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
# Maintainer: Deskflow Developers
|
# Maintainer: Deskflow Developers
|
||||||
|
|
||||||
pkgname=deskflow
|
_basename=@CMAKE_PROJECT_NAME@
|
||||||
|
pkgname=${_basename}-git
|
||||||
pkgver=@CMAKE_PROJECT_VERSION@
|
pkgver=@CMAKE_PROJECT_VERSION@
|
||||||
pkgrel=1
|
pkgrel=1
|
||||||
pkgdesc="Mouse and keyboard sharing utility"
|
pkgdesc="@CMAKE_PROJECT_DESCRIPTION@"
|
||||||
url='https://deskflow.org'
|
url="@CMAKE_PROJECT_HOMEPAGE_URL@"
|
||||||
arch=('i686' 'x86_64' 'armv7h' 'aarch64')
|
arch=('i686' 'x86_64' 'armv7h' 'aarch64')
|
||||||
license=(LicenseRef-GPL-2.0-only-WITH-OpenSSL-Exception)
|
license=(LicenseRef-GPL-2.0-only-WITH-OpenSSL-Exception)
|
||||||
conflicts=('synergy-git' 'synergy-1.6' 'synergy1-bin' 'synergy2-bin' 'synergy3-bin' 'synergy3-beta-bin' 'synergy3-stable-bin' 'barrier' 'barrier-git' 'barrier-headless' 'barrier-headless-git' 'input-leap' 'input-leap-git' 'input-leap-headless-git' 'input-leap-headless' 'waynergy' 'waynergy-git' 'qsynergy' 'slim-synergy' 'quicksynergy' 'deskflow')
|
conflicts=('synergy-git' 'synergy-1.6' 'synergy1-bin' 'synergy2-bin' 'synergy3-bin' 'synergy3-beta-bin' 'synergy3-stable-bin' 'barrier' 'barrier-git' 'barrier-headless' 'barrier-headless-git' 'input-leap' 'input-leap-git' 'input-leap-headless-git' 'input-leap-headless' 'waynergy' 'waynergy-git' 'qsynergy' 'slim-synergy' 'quicksynergy' 'deskflow')
|
||||||
provides=("deskflow-git${pkgver}")
|
provides=("$_basename")
|
||||||
depends=(
|
depends=(
|
||||||
gcc-libs
|
gcc-libs
|
||||||
glib2
|
glib2
|
||||||
@ -33,7 +34,7 @@ depends=(
|
|||||||
openssl
|
openssl
|
||||||
qt6-base
|
qt6-base
|
||||||
qt6-svg
|
qt6-svg
|
||||||
tomlplusplus
|
qt6-translations
|
||||||
)
|
)
|
||||||
|
|
||||||
options=('!debug')
|
options=('!debug')
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 Chris Rizzitello <sithlord48@gmail.com>
|
# SPDX-FileCopyrightText: (C) 2024 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
# HACK This is set when the files is included so its the real path
|
# HACK This is set when the files is included so its the real path
|
||||||
@ -7,21 +7,23 @@ set(MY_DIR ${CMAKE_CURRENT_LIST_DIR})
|
|||||||
|
|
||||||
# Install our desktop file
|
# Install our desktop file
|
||||||
install(
|
install(
|
||||||
FILES ${MY_DIR}/org.deskflow.deskflow.desktop
|
FILES ${MY_DIR}/${CMAKE_PROJECT_REV_FQDN}.desktop
|
||||||
DESTINATION share/applications
|
DESTINATION ${CMAKE_INSTALL_DATADIR}/applications
|
||||||
)
|
)
|
||||||
|
|
||||||
# Install our icon
|
# Install our icon
|
||||||
|
install(FILES ${MY_DIR}/org.deskflow.deskflow.png DESTINATION ${CMAKE_INSTALL_DATADIR}/icons/hicolor/512x512/apps/)
|
||||||
|
|
||||||
|
# Install our symbolic icon
|
||||||
install(
|
install(
|
||||||
FILES ${MY_DIR}/deskflow.png
|
FILES ${CMAKE_SOURCE_DIR}/src/apps/res/icons/deskflow-light/apps/64/org.deskflow.deskflow-symbolic.svg
|
||||||
DESTINATION share/icons/hicolor/512x512/apps/
|
DESTINATION ${CMAKE_INSTALL_DATADIR}/icons/hicolor/symbolic/apps/
|
||||||
RENAME org.deskflow.deskflow.png
|
|
||||||
)
|
)
|
||||||
|
|
||||||
# Install our metainfo
|
# Install our metainfo
|
||||||
install(
|
install(
|
||||||
FILES ${MY_DIR}/org.deskflow.deskflow.metainfo.xml
|
FILES ${MY_DIR}/${CMAKE_PROJECT_REV_FQDN}.metainfo.xml
|
||||||
DESTINATION share/metainfo/
|
DESTINATION ${CMAKE_INSTALL_DATADIR}/metainfo/
|
||||||
)
|
)
|
||||||
|
|
||||||
# Prepare PKGBUILD for Arch Linux
|
# Prepare PKGBUILD for Arch Linux
|
||||||
@ -31,9 +33,9 @@ configure_file(
|
|||||||
@ONLY
|
@ONLY
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
set(CPACK_DEBIAN_PACKAGE_SECTION "utils")
|
set(CPACK_DEBIAN_PACKAGE_SECTION "utils")
|
||||||
set(CPACK_DEBIAN_PACKAGE_SHLIBDEPS ON)
|
set(CPACK_DEBIAN_PACKAGE_SHLIBDEPS ON)
|
||||||
|
set(CPACK_DEBIAN_PACKAGE_RECOMMENDS "qt6-svg-plugins")
|
||||||
set(CPACK_RPM_PACKAGE_LICENSE "GPLv2")
|
set(CPACK_RPM_PACKAGE_LICENSE "GPLv2")
|
||||||
set(CPACK_RPM_PACKAGE_GROUP "Applications/System")
|
set(CPACK_RPM_PACKAGE_GROUP "Applications/System")
|
||||||
|
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
app-id: org.deskflow.deskflow
|
app-id: org.deskflow.deskflow
|
||||||
runtime: org.kde.Platform
|
runtime: org.kde.Platform
|
||||||
runtime-version: "6.9"
|
runtime-version: "6.10"
|
||||||
sdk: org.kde.Sdk
|
sdk: org.kde.Sdk
|
||||||
command: deskflow
|
command: deskflow
|
||||||
finish-args:
|
finish-args:
|
||||||
@ -17,7 +17,6 @@ cleanup:
|
|||||||
- /lib/cmake
|
- /lib/cmake
|
||||||
- /lib/pkgconfig
|
- /lib/pkgconfig
|
||||||
- /share/pkgconfig
|
- /share/pkgconfig
|
||||||
- /share/tomlplusplus
|
|
||||||
- /share/cmake
|
- /share/cmake
|
||||||
- /share/doc
|
- /share/doc
|
||||||
- /share/gir-1.0
|
- /share/gir-1.0
|
||||||
@ -30,8 +29,12 @@ modules:
|
|||||||
--prefix=${FLATPAK_DEST} --no-build-isolation Jinja2
|
--prefix=${FLATPAK_DEST} --no-build-isolation Jinja2
|
||||||
sources:
|
sources:
|
||||||
- type: file
|
- type: file
|
||||||
url: https://files.pythonhosted.org/packages/30/6d/6de6be2d02603ab56e72997708809e8a5b0fbfee080735109b40a3564843/Jinja2-3.1.3-py3-none-any.whl
|
url: https://files.pythonhosted.org/packages/62/a1/3d680cbfd5f4b8f15abc1d571870c5fc3e594bb582bc3b64ea099db13e56/jinja2-3.1.6-py3-none-any.whl
|
||||||
sha256: 7d6d50dd97d52cbc355597bd845fabfbac3f551e1f99619e39a35ce8c370b5fa
|
sha256: 85ece4451f492d0c13c5dd7c13a64681a86afae63a5f347908daf103ce6d2f67
|
||||||
|
x-checker-data:
|
||||||
|
type: pypi
|
||||||
|
name: Jinja2
|
||||||
|
packagetype: bdist_wheel
|
||||||
- type: file
|
- type: file
|
||||||
url: https://files.pythonhosted.org/packages/87/5b/aae44c6655f3801e81aa3eef09dbbf012431987ba564d7231722f68df02d/MarkupSafe-2.1.5.tar.gz
|
url: https://files.pythonhosted.org/packages/87/5b/aae44c6655f3801e81aa3eef09dbbf012431987ba564d7231722f68df02d/MarkupSafe-2.1.5.tar.gz
|
||||||
sha256: d283d37a890ba4c1ae73ffadf8046435c76e7bc2247bbb63c00bd1a709c6544b
|
sha256: d283d37a890ba4c1ae73ffadf8046435c76e7bc2247bbb63c00bd1a709c6544b
|
||||||
@ -46,8 +49,11 @@ modules:
|
|||||||
sources:
|
sources:
|
||||||
- type: git
|
- type: git
|
||||||
url: https://gitlab.freedesktop.org/libinput/libei
|
url: https://gitlab.freedesktop.org/libinput/libei
|
||||||
tag: 1.4.1
|
tag: 1.5.0
|
||||||
commit: 9e0413cbc7d3ae6656266890425f152589ddf74d
|
commit: 19b64535408aa47abbc8151bc2c925afd6583851
|
||||||
|
x-checker-data:
|
||||||
|
type: git
|
||||||
|
tag-pattern: ^([\\d.]+)$
|
||||||
- name: libportal
|
- name: libportal
|
||||||
buildsystem: meson
|
buildsystem: meson
|
||||||
config-opts:
|
config-opts:
|
||||||
@ -63,29 +69,16 @@ modules:
|
|||||||
commit: 8f5dc8d192f6e31dafe69e35219e3b707bde71ce
|
commit: 8f5dc8d192f6e31dafe69e35219e3b707bde71ce
|
||||||
- type: patch
|
- type: patch
|
||||||
path: libportal-qt69.patch
|
path: libportal-qt69.patch
|
||||||
- name: cli11
|
|
||||||
buildsystem: cmake-ninja
|
|
||||||
config-opts:
|
|
||||||
- -DCLI11_BUILD_TESTS=OFF
|
|
||||||
sources:
|
|
||||||
- type: git
|
|
||||||
url: https://github.com/CLIUtils/CLI11
|
|
||||||
tag: v2.5.0
|
|
||||||
commit: 4160d259d961cd393fd8d67590a8c7d210207348
|
|
||||||
- name: tomlplusplus
|
|
||||||
buildsystem: cmake-ninja
|
|
||||||
sources:
|
|
||||||
- type: git
|
|
||||||
url: https://github.com/marzer/tomlplusplus
|
|
||||||
tag: v3.4.0
|
|
||||||
commit: 30172438cee64926dc41fdd9c11fb3ba5b2ba9de
|
|
||||||
- name: gtest
|
- name: gtest
|
||||||
buildsystem: cmake-ninja
|
buildsystem: cmake-ninja
|
||||||
sources:
|
sources:
|
||||||
- type: git
|
- type: git
|
||||||
url: https://github.com/google/googletest.git
|
url: https://github.com/google/googletest.git
|
||||||
tag: v1.15.2
|
tag: v1.17.0
|
||||||
commit: b514bdc898e2951020cbdca1304b75f5950d1f59
|
commit: 52eb8108c5bdec04579160ae17225d66034bd723
|
||||||
|
x-checker-data:
|
||||||
|
type: git
|
||||||
|
tag-pattern: ^([\\d.]+)$
|
||||||
cleanup:
|
cleanup:
|
||||||
- '*'
|
- '*'
|
||||||
- name: deskflow
|
- name: deskflow
|
||||||
|
|||||||
@ -11,3 +11,12 @@ Icon=org.deskflow.deskflow
|
|||||||
Terminal=false
|
Terminal=false
|
||||||
Categories=Utility;
|
Categories=Utility;
|
||||||
Keywords=keyboard;mouse;sharing;network;share;
|
Keywords=keyboard;mouse;sharing;network;share;
|
||||||
|
Name[zh_CN]=Deskflow
|
||||||
|
Comment[zh_CN]=键鼠共享工具
|
||||||
|
Keywords[zh_CN]=键盘;鼠标;网络;共享;
|
||||||
|
Name[ru]=Deskflow
|
||||||
|
Comment[ru]=Приложения чтобы использовать одну мышку и клавиатуру с разными устройствами
|
||||||
|
Keywords[ru]=Передача;Трансляция;barrier;input-leap;
|
||||||
|
Name[ko]=Deskflow
|
||||||
|
Comment[ko]=마우스 및 키보드 공유 유틸리티
|
||||||
|
Keywords[ko]=키보드;마우스;공유;네트워크;
|
||||||
|
|||||||
@ -8,10 +8,18 @@
|
|||||||
<name>Deskflow Developers</name>
|
<name>Deskflow Developers</name>
|
||||||
</developer>
|
</developer>
|
||||||
<summary>Software Keyboard and mouse sharing</summary>
|
<summary>Software Keyboard and mouse sharing</summary>
|
||||||
|
<summary xml:lang="zh_CN">用软件共享键鼠</summary>
|
||||||
|
<summary xml:lang="ko">키보드 및 마우스 공유 소프트웨어</summary>
|
||||||
<description>
|
<description>
|
||||||
<p>
|
<p>
|
||||||
Use the keyboard, mouse, or trackpad of one computer to control nearby computers, and work seamlessly between them.
|
Use the keyboard, mouse, or trackpad of one computer to control nearby computers, and work seamlessly between them.
|
||||||
</p>
|
</p>
|
||||||
|
<p xml:lang="zh_CN">
|
||||||
|
使用一台计算机的键盘、鼠标或触控板来控制附近的其它计算机,并在它们之间无缝工作。
|
||||||
|
</p>
|
||||||
|
<p xml:lang="ko">
|
||||||
|
한 대의 컴퓨터에 연결된 키보드, 마우스 또는 트랙패드로 주변의 다른 컴퓨터를 제어하고, 컴퓨터 사이를 끊김 없이 오가며 작업할 수 있습니다.
|
||||||
|
</p>
|
||||||
</description>
|
</description>
|
||||||
<launchable type="desktop-id">org.deskflow.deskflow.desktop</launchable>
|
<launchable type="desktop-id">org.deskflow.deskflow.desktop</launchable>
|
||||||
<url type="homepage">https://deskflow.org</url>
|
<url type="homepage">https://deskflow.org</url>
|
||||||
@ -22,12 +30,28 @@
|
|||||||
<url type="contribute">https://github.com/deskflow/deskflow/wiki/Contributing</url>
|
<url type="contribute">https://github.com/deskflow/deskflow/wiki/Contributing</url>
|
||||||
<screenshots>
|
<screenshots>
|
||||||
<screenshot type="default">
|
<screenshot type="default">
|
||||||
<image>https://deskflow.org/screenshots/deskflow.png</image>
|
<image>https://deskflow.org/screenshots/deskflow-client.png</image>
|
||||||
<caption>Deskflow's mainwindow on KDE</caption>
|
<caption>Deskflow in client mode on KDE</caption>
|
||||||
</screenshot>
|
</screenshot>
|
||||||
<screenshot>
|
<screenshot>
|
||||||
<image>https://deskflow.org/screenshots/deskflow-dark.png</image>
|
<image>https://deskflow.org/screenshots/deskflow-server.png</image>
|
||||||
<caption>Deskflow's mainwindow on KDE (dark mode)</caption>
|
<caption>Deskflow in server mode on KDE</caption>
|
||||||
|
</screenshot>
|
||||||
|
<screenshot>
|
||||||
|
<image>https://deskflow.org/screenshots/deskflow-log.png</image>
|
||||||
|
<caption>Deskflow with the log visible on KDE</caption>
|
||||||
|
</screenshot>
|
||||||
|
<screenshot>
|
||||||
|
<image>https://deskflow.org/screenshots/deskflow-client-dark.png</image>
|
||||||
|
<caption>Deskflow in client mode on KDE (dark mode)</caption>
|
||||||
|
</screenshot>
|
||||||
|
<screenshot>
|
||||||
|
<image>https://deskflow.org/screenshots/deskflow-server-dark.png</image>
|
||||||
|
<caption>Deskflow in server mode on KDE (dark mode)</caption>
|
||||||
|
</screenshot>
|
||||||
|
<screenshot>
|
||||||
|
<image>https://deskflow.org/screenshots/deskflow-log-dark.png</image>
|
||||||
|
<caption>Deskflow with the log visible on KDE (dark mode)</caption>
|
||||||
</screenshot>
|
</screenshot>
|
||||||
</screenshots>
|
</screenshots>
|
||||||
<provides> <id>org.deskflow.deskflow.desktop</id> </provides>
|
<provides> <id>org.deskflow.deskflow.desktop</id> </provides>
|
||||||
@ -35,8 +59,12 @@
|
|||||||
<category>Utility</category>
|
<category>Utility</category>
|
||||||
</categories>
|
</categories>
|
||||||
<keywords>
|
<keywords>
|
||||||
<keyword translate="no">Input</keyword>
|
<keyword>Input</keyword>
|
||||||
<keyword translate="no">Sharing</keyword>
|
<keyword xml:lang="zh_CN">输入</keyword>
|
||||||
|
<keyword xml:lang="ko">입력</keyword>
|
||||||
|
<keyword>Sharing</keyword>
|
||||||
|
<keyword xml:lang="zh_CN">共享</keyword>
|
||||||
|
<keyword xml:lang="ko">공유</keyword>
|
||||||
<keyword translate="no">KVM</keyword>
|
<keyword translate="no">KVM</keyword>
|
||||||
<keyword translate="no">Synergy</keyword>
|
<keyword translate="no">Synergy</keyword>
|
||||||
</keywords>
|
</keywords>
|
||||||
@ -46,6 +74,97 @@
|
|||||||
</branding>
|
</branding>
|
||||||
<content_rating type="oars-1.0" />
|
<content_rating type="oars-1.0" />
|
||||||
<releases>
|
<releases>
|
||||||
|
<release version="1.26.0" date="2026-02-16" urgency="high">
|
||||||
|
<description>
|
||||||
|
<p>This stable release fixes known issues and adds a few new features, For the full changelog, see the release page.</p>
|
||||||
|
<ul>
|
||||||
|
<li>New: Korean(ko) translation</li>
|
||||||
|
<li>New: Option to start in the "locked to computer" state</li>
|
||||||
|
<li>New: Option to show the version in the windows title</li>
|
||||||
|
<li>New: Clients can now use a list hostnames or ips for the server address</li>
|
||||||
|
<li>New: Client options are in a new client configuration dialog</li>
|
||||||
|
<li>New: Provide a more accurate suggested IP, Update as network info changes if needed.</li>
|
||||||
|
<li>New: Add a simple search to the log</li>
|
||||||
|
<li>New: Lookup host name with IP4 or IP6</li>
|
||||||
|
<li>New: Replace broken scroll speed with a scroll scaling options</li>
|
||||||
|
<li>Fix: Horizontal scrolling is working again on all platforms</li>
|
||||||
|
<li>Fix: Key repeat events are now sent as repeat not press and release</li>
|
||||||
|
<li>Fix: Deskflow-core correctly blocks new instances when run without the `--new-instance` option</li>
|
||||||
|
<li>Fix: Server Mode, Only use the external config path if the option is enabled</li>
|
||||||
|
<li>Fix: Allow comma and semicolon to be used in the hotkey configuration</li>
|
||||||
|
<li>Fix: Gui can crash when clearing settings in debug mode</li>
|
||||||
|
<li>Fix: Mouse Back and Forward buttons are now working (again) on all platforms</li>
|
||||||
|
<li>Fix: macOS, crash when the log is opened and the gui minimized</li>
|
||||||
|
<li>Fix: macOS, restore Preferences menu entry when the application is using non english language</li>
|
||||||
|
<li>Fix: macOS, try icon was not showing when in `Colorful` mode</li>
|
||||||
|
<li>Fix: macOS, do not allow the os to kill deskflow for memory reasons</li>
|
||||||
|
<li>Fix: macOS, possible server crash when a client disconnects abruptly</li>
|
||||||
|
<li>Fix: macOS, possible crash on screen wake / screen saver activation</li>
|
||||||
|
<li>Fix: macOS, Wrong keys send when using "RIME" input method</li>
|
||||||
|
<li>Fix: Windows, possible crash when the daemon is started for the first time</li>
|
||||||
|
<li>Use `Computer` in place of `Screen` to indicate we work with Computers display layout and not individual screens attached</li>
|
||||||
|
<li>Clean and update the settings when starting up.</li>
|
||||||
|
<li>Do not show client connection error messages dialogs if the gui is hidden</li>
|
||||||
|
<li>Use Qt 6.9.3 for Intel Mac builds.</li>
|
||||||
|
<li>Windows: Use ICU dlls from the host system</li>
|
||||||
|
<li>Code continues to be cleaned of unused methods and updated to modern C++</li>
|
||||||
|
<li>Consolidate Debug levels to remove DEBUG3-5 levels</li>
|
||||||
|
</ul>
|
||||||
|
</description>
|
||||||
|
<url>https://github.com/deskflow/deskflow/releases/tag/v1.26.0</url>
|
||||||
|
</release>
|
||||||
|
<release version="1.25.0" date="2025-11-21" urgency="high">
|
||||||
|
<description>
|
||||||
|
<p>This stable release fixes known issues and adds a few new features. Most notable symbolic icon support, I18N support and experimental support for wl-clipboard to access clipboards on wayland. This release also continues our trend of cleaning up the codebase. For the full changelog, see the release page.</p>
|
||||||
|
<ul>
|
||||||
|
<li>Removed the ability to use toml config and env based config files</li>
|
||||||
|
<li>Set XDG app ID (app_id) on Wayland</li>
|
||||||
|
<li>Support symbolic icon deployment and recoloring</li>
|
||||||
|
<li>Added Spanish translation</li>
|
||||||
|
<li>Added Italian translation</li>
|
||||||
|
<li>Added Japanese translation</li>
|
||||||
|
<li>Added Simplified Chinese translation</li>
|
||||||
|
<li>Added Russian translation</li>
|
||||||
|
<li>Translate the GUI without needed to restart the application</li>
|
||||||
|
<li>Expose setting to adjust clients scroll speed</li>
|
||||||
|
<li>Expose setting to show the GUI debug messages in the log</li>
|
||||||
|
<li>Expose setting to allow use of wl-clipboard backend on Wayland</li>
|
||||||
|
<li>Fixed the port settings not being used from settings</li>
|
||||||
|
<li>Save the geometry info into a state file</li>
|
||||||
|
<li>The Core (deskflow-core) has a new CLI interface</li>
|
||||||
|
<li>Fixed Wayland sleep inhibit on client</li>
|
||||||
|
<li>Fixed XWindowsScreen: properly calculate xrandr/xinerama screens</li>
|
||||||
|
<li>Fixed XWindowsScreen: stop centering panned screens on client when leaving the screen</li>
|
||||||
|
<li>Fixed stop retying to launch the Core if its crashed</li>
|
||||||
|
<li>Fixed various input issues</li>
|
||||||
|
<li>Fixed apply scroll lock setting on initialization</li>
|
||||||
|
<li>Fixed crash caused by hostnames with invalid characters returned default value</li>
|
||||||
|
</ul>
|
||||||
|
</description>
|
||||||
|
<url>https://github.com/deskflow/deskflow/releases/tag/v1.25.0</url>
|
||||||
|
</release>
|
||||||
|
<release version="1.24.0" date="2025-09-11" urgency="high">
|
||||||
|
<description>
|
||||||
|
<p>This stable release fixes issues found in the previous version and adds a few new features. This release also uses more C++20 features. For the full changelog, see the release page.</p>
|
||||||
|
<ul>
|
||||||
|
<li>Fix: Less confusing fingerprint comparision dialog.</li>
|
||||||
|
<li>Fix: AltGr and other modifiers are generally detected better.</li>
|
||||||
|
<li>Fix: Big Endian test failures</li>
|
||||||
|
<li>Fix: Client scroll direction being ignored on wayland clients.</li>
|
||||||
|
<li>Feat: Unify deskflow-client and deskflow-server into one binary deskflow-core.</li>
|
||||||
|
<li>Feat: Prevent more than one instance of deskflow-core starting.</li>
|
||||||
|
<li>Feat: Remove defunct --no-xinitthreads option.</li>
|
||||||
|
<li>Feat: Ability to persist remote desktop access</li>
|
||||||
|
<li>Feat: Gui can show all log levels, upgrading users will want to reset their log level as the values have changed</li>
|
||||||
|
<li>Feat: Log can be detached or docked in the window</li>
|
||||||
|
<li>Refactor: Use more icons in places</li>
|
||||||
|
<li>Refactor: Update the Server Config Dialog's GUI</li>
|
||||||
|
<li>Chore: Continue to update codebase to use C++20 features.</li>
|
||||||
|
<li>Chore: Clean more sonar smells</li>
|
||||||
|
</ul>
|
||||||
|
</description>
|
||||||
|
<url>https://github.com/deskflow/deskflow/releases/tag/v1.24.0</url>
|
||||||
|
</release>
|
||||||
<release version="1.23.0" date="2025-07-23" urgency="high">
|
<release version="1.23.0" date="2025-07-23" urgency="high">
|
||||||
<description>
|
<description>
|
||||||
<p>This stable release fixes issues found in the previous version and adds a few new features. This release also uses more C++20 features. For the full changelog, see the release page.</p>
|
<p>This stable release fixes issues found in the previous version and adds a few new features. This release also uses more C++20 features. For the full changelog, see the release page.</p>
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 19 KiB After Width: | Height: | Size: 19 KiB |
@ -1,20 +1,23 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 Chris Rizzitello <sithlord48@gmail.com>
|
# SPDX-FileCopyrightText: (C) 2024 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
# HACK This is set when the files is included so its the real path
|
# HACK This is set when the files is included so its the real path
|
||||||
# calling CMAKE_CURRENT_LIST_DIR after include would return the wrong scope var
|
# calling CMAKE_CURRENT_LIST_DIR after include would return the wrong scope var
|
||||||
set(MY_DIR ${CMAKE_CURRENT_LIST_DIR})
|
set(MY_DIR ${CMAKE_CURRENT_LIST_DIR})
|
||||||
|
set(OSX_BUNDLE ${BUILD_OSX_BUNDLE})
|
||||||
install(CODE "execute_process(COMMAND
|
|
||||||
${DEPLOYQT}
|
|
||||||
\"\${CMAKE_INSTALL_PREFIX}/${CMAKE_PROJECT_PROPER_NAME}.app\"
|
|
||||||
-timestamp -codesign=-
|
|
||||||
)")
|
|
||||||
|
|
||||||
set(OS_STRING "macos-${BUILD_ARCHITECTURE}")
|
set(OS_STRING "macos-${BUILD_ARCHITECTURE}")
|
||||||
set(CPACK_PACKAGE_ICON "${MY_DIR}/dmg-volume.icns")
|
|
||||||
set(CPACK_DMG_BACKGROUND_IMAGE "${MY_DIR}/dmg-background.tiff")
|
if (OSX_BUNDLE)
|
||||||
set(CPACK_DMG_DS_STORE_SETUP_SCRIPT "${MY_DIR}/generate_ds_store.applescript")
|
install(CODE "execute_process(COMMAND
|
||||||
set(CPACK_DMG_VOLUME_NAME "${CMAKE_PROJECT_PROPER_NAME}")
|
${DEPLOYQT}
|
||||||
set(CPACK_DMG_SLA_USE_RESOURCE_FILE_LICENSE ON)
|
\"\${CMAKE_INSTALL_PREFIX}/${CMAKE_PROJECT_PROPER_NAME}.app\"
|
||||||
set(CPACK_GENERATOR "DragNDrop")
|
-timestamp -codesign=-
|
||||||
|
)")
|
||||||
|
set(CPACK_PACKAGE_ICON "${MY_DIR}/dmg-volume.icns")
|
||||||
|
set(CPACK_DMG_BACKGROUND_IMAGE "${MY_DIR}/dmg-background.tiff")
|
||||||
|
set(CPACK_DMG_DS_STORE_SETUP_SCRIPT "${MY_DIR}/generate_ds_store.applescript")
|
||||||
|
set(CPACK_DMG_VOLUME_NAME "${CMAKE_PROJECT_PROPER_NAME}")
|
||||||
|
set(CPACK_DMG_SLA_USE_RESOURCE_FILE_LICENSE ON)
|
||||||
|
set(CPACK_GENERATOR "DragNDrop")
|
||||||
|
endif()
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
#SPDX-FileCopyrightText: 2025 Chris Rizzitello <sithlord48@gmail.com>
|
#SPDX-FileCopyrightText: (C) 2025 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
#SPDX-License-Identifier: MIT
|
#SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
if(CPACK_GENERATOR MATCHES 7Z|ZIP)
|
if(CPACK_GENERATOR MATCHES 7Z|ZIP)
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 Chris Rizzitello <sithlord48@gmail.com>
|
# SPDX-FileCopyrightText: (C) 2024 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
# HACK This is set when the files is included so its the real path
|
# HACK This is set when the files is included so its the real path
|
||||||
@ -6,7 +6,7 @@
|
|||||||
set(MY_DIR ${CMAKE_CURRENT_LIST_DIR})
|
set(MY_DIR ${CMAKE_CURRENT_LIST_DIR})
|
||||||
|
|
||||||
set(CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_SKIP TRUE)
|
set(CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_SKIP TRUE)
|
||||||
set(CMAKE_INSTALL_SYSTEM_RUNTIME_DESTINATION .)
|
set(CMAKE_INSTALL_SYSTEM_RUNTIME_DESTINATION ${CMAKE_INSTALL_LIBDIR})
|
||||||
include(InstallRequiredSystemLibraries)
|
include(InstallRequiredSystemLibraries)
|
||||||
|
|
||||||
configure_file(${MY_DIR}/pre-cpack.cmake.in ${CMAKE_CURRENT_BINARY_DIR}/pre-cpack.cmake @ONLY)
|
configure_file(${MY_DIR}/pre-cpack.cmake.in ${CMAKE_CURRENT_BINARY_DIR}/pre-cpack.cmake @ONLY)
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
# SPDX-FileCopyrightText: 2025 Chris Rizzitello <sithlord48@gmail.com>
|
# SPDX-FileCopyrightText: (C) 2025 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
if(CPACK_GENERATOR MATCHES 7Z|ZIP)
|
if(CPACK_GENERATOR MATCHES 7Z|ZIP)
|
||||||
|
|||||||
@ -20,12 +20,9 @@
|
|||||||
<RemoveFile Id="RmOldLog" On="install" Name="deskflow-daemon.log"/>
|
<RemoveFile Id="RmOldLog" On="install" Name="deskflow-daemon.log"/>
|
||||||
</CPackWiXFragment>
|
</CPackWiXFragment>
|
||||||
|
|
||||||
<CPackWiXFragment Id="CM_CP_deskflow_server.exe">
|
<CPackWiXFragment Id="CM_CP_deskflow_core.exe">
|
||||||
<firewall:FirewallException Id="ServerFirewallException" Name="Deskflow Server" Program="[INSTALL_ROOT]deskflow-server.exe" Scope="any"/>
|
<firewall:FirewallException Id="ServerFirewallException" Name="Deskflow Server" Program="[INSTALL_ROOT]deskflow-core.exe" Scope="any"/>
|
||||||
</CPackWiXFragment>
|
<firewall:FirewallException Id="ClientFirewallException" Name="Deskflow Client" Program="[INSTALL_ROOT]deskflow-core.exe" Scope="any"/>
|
||||||
|
|
||||||
<CPackWiXFragment Id="CM_CP_deskflow_client.exe">
|
|
||||||
<firewall:FirewallException Id="ClientFirewallException" Name="Deskflow Client" Program="[INSTALL_ROOT]deskflow-client.exe" Scope="any"/>
|
|
||||||
</CPackWiXFragment>
|
</CPackWiXFragment>
|
||||||
|
|
||||||
<CPackWiXFragment Id="#PRODUCT">
|
<CPackWiXFragment Id="#PRODUCT">
|
||||||
|
|||||||
@ -1,198 +0,0 @@
|
|||||||
# GUI Config
|
|
||||||
|
|
||||||
Deskflow will automatically figure out where to save settings and other files.
|
|
||||||
|
|
||||||
|
|
||||||
## Unix Systems
|
|
||||||
The search order for a setting file is:
|
|
||||||
1. `<XDG_CONFIG_HOME>/Deskflow/Deskflow.conf`
|
|
||||||
1. A user settings file
|
|
||||||
1. A system settings file
|
|
||||||
|
|
||||||
A new settings file will be created in the user path if no settings file is found.
|
|
||||||
The path of the settings file will be used as the base for all other config files.
|
|
||||||
|
|
||||||
### Linux
|
|
||||||
- System: `/etc/Deskflow/Deskflow.conf`
|
|
||||||
- User: `~/.config/Deskflow/Deskflow.conf`
|
|
||||||
|
|
||||||
### macOS
|
|
||||||
- System: `/Library/Deskflow/Deskflow.conf`
|
|
||||||
- User: `~/Library/Deskflow/Deskflow.conf`
|
|
||||||
|
|
||||||
|
|
||||||
## Windows
|
|
||||||
|
|
||||||
The search order for a setting file is:
|
|
||||||
1. `<install-path>/settings/Deskflow.conf`
|
|
||||||
1. Windows Registry `HKCU\Software\Deskflow\Deskflow`
|
|
||||||
|
|
||||||
Windows will save to the install dir if settings are loaded from there. If not, it saves any other config files in: `C:\ProgramData\Deskflow\`
|
|
||||||
|
|
||||||
When using settings from the install dir, the service mode will not be available.
|
|
||||||
|
|
||||||
# Server Config Examples
|
|
||||||
|
|
||||||
The `deskflow-server` command accepts the `-c` or `--config` option, which takes one argument,
|
|
||||||
the path to a server configuration file. The format is non-standard but similar to YAML.
|
|
||||||
|
|
||||||
Comments begin with the `#` character and continue to the end of line.
|
|
||||||
Comments may appear anywhere the syntax permits.
|
|
||||||
|
|
||||||
Each `section` element must have a matching `end` element.
|
|
||||||
|
|
||||||
## Stacked Example
|
|
||||||
|
|
||||||
Stack one computer's screen on top of another's.
|
|
||||||
|
|
||||||
```
|
|
||||||
# +-------+
|
|
||||||
# | curly |
|
|
||||||
# | |
|
|
||||||
# +-------+
|
|
||||||
# +-------+ +-------+
|
|
||||||
# | moe | | larry |
|
|
||||||
# | | | |
|
|
||||||
# +-------+ +-------+
|
|
||||||
|
|
||||||
section: screens
|
|
||||||
# three hosts named: moe, larry, and curly
|
|
||||||
moe:
|
|
||||||
larry:
|
|
||||||
curly:
|
|
||||||
end
|
|
||||||
|
|
||||||
section: links
|
|
||||||
# larry is to the right of moe and curly is above moe.
|
|
||||||
moe:
|
|
||||||
right = larry
|
|
||||||
up = curly
|
|
||||||
|
|
||||||
# moe is to the left of larry and curly is above larry.
|
|
||||||
larry:
|
|
||||||
left = moe
|
|
||||||
up = curly
|
|
||||||
|
|
||||||
# larry is below curly.
|
|
||||||
curly:
|
|
||||||
down = larry
|
|
||||||
end
|
|
||||||
|
|
||||||
section: aliases
|
|
||||||
# curly is also known as shemp
|
|
||||||
curly:
|
|
||||||
shemp
|
|
||||||
end
|
|
||||||
```
|
|
||||||
|
|
||||||
## Horizontal Example
|
|
||||||
|
|
||||||
Align all screens horizontally.
|
|
||||||
|
|
||||||
```
|
|
||||||
# +-------+ +-------+ +-------+
|
|
||||||
# | moe | | larry | | curly |
|
|
||||||
# | | | | | |
|
|
||||||
# +-------+ +-------+ +-------+
|
|
||||||
|
|
||||||
section: screens
|
|
||||||
# three hosts named: moe, larry, and curly
|
|
||||||
moe:
|
|
||||||
larry:
|
|
||||||
curly:
|
|
||||||
end
|
|
||||||
|
|
||||||
section: links
|
|
||||||
# curly is to the right of larry and moe is to the left of larry.
|
|
||||||
larry:
|
|
||||||
right = curly
|
|
||||||
left = moe
|
|
||||||
|
|
||||||
# larry is to the right of moe.
|
|
||||||
moe:
|
|
||||||
right = larry
|
|
||||||
|
|
||||||
# larry is to the left of curly.
|
|
||||||
curly:
|
|
||||||
left = larry
|
|
||||||
end
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
||||||
## Span Example
|
|
||||||
|
|
||||||
Span two screens on one computer across the screens of two computers.
|
|
||||||
|
|
||||||
```
|
|
||||||
# +-------+ +-------+
|
|
||||||
# | curly | | curly |
|
|
||||||
# | | | |
|
|
||||||
# +-------+ +-------+
|
|
||||||
# +-------+ +-------+
|
|
||||||
# | moe | | larry |
|
|
||||||
# | | | |
|
|
||||||
# +-------+ +-------+
|
|
||||||
|
|
||||||
section: screens
|
|
||||||
# three hosts named: moe, larry, and curly
|
|
||||||
moe:
|
|
||||||
larry:
|
|
||||||
curly:
|
|
||||||
end
|
|
||||||
|
|
||||||
section: links
|
|
||||||
# larry is to the right of moe and curly is above moe.
|
|
||||||
moe:
|
|
||||||
right = larry
|
|
||||||
up = curly
|
|
||||||
|
|
||||||
# moe is to the left of larry and curly is above larry.
|
|
||||||
larry:
|
|
||||||
left = moe
|
|
||||||
up = curly
|
|
||||||
|
|
||||||
# larry is below curly.
|
|
||||||
curly:
|
|
||||||
down = larry
|
|
||||||
end
|
|
||||||
```
|
|
||||||
|
|
||||||
# Example file for `--config-toml` arg
|
|
||||||
|
|
||||||
```
|
|
||||||
[server.args]
|
|
||||||
no-daemon = true
|
|
||||||
no-tray = true
|
|
||||||
debug = "DEBUG"
|
|
||||||
name = "moe"
|
|
||||||
address = ":24800"
|
|
||||||
|
|
||||||
[client.args]
|
|
||||||
no-daemon = true
|
|
||||||
no-tray = true
|
|
||||||
debug = "DEBUG2"
|
|
||||||
name = "larry"
|
|
||||||
_last = "moe:24800"
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
# Example `.env` file
|
|
||||||
|
|
||||||
|
|
||||||
```
|
|
||||||
#
|
|
||||||
# App
|
|
||||||
#
|
|
||||||
|
|
||||||
# Shows the test menu in the GUI (on by default in debug mode)
|
|
||||||
# DESKFLOW_TEST_MENU=true
|
|
||||||
|
|
||||||
# Version checker URL to use (useful for testing)
|
|
||||||
# DESKFLOW_VERSION_URL="https://api.deskflow.org/version?fake=1.100.0"
|
|
||||||
|
|
||||||
# Enable debug logging in the GUI (on by default in debug mode)
|
|
||||||
# DESKFLOW_GUI_DEBUG=true
|
|
||||||
|
|
||||||
# Enable verbose logging in the GUI (always off by default)
|
|
||||||
# DESKFLOW_GUI_VERBOSE=true
|
|
||||||
```
|
|
||||||
@ -1,4 +1,4 @@
|
|||||||
# SPDX-FileCopyrightText: 2019 - 2025 Chris Rizzitello <sithlord48@gmail.com>
|
# SPDX-FileCopyrightText: (C) 2019 - 2025 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
find_package(Doxygen QUIET)
|
find_package(Doxygen QUIET)
|
||||||
@ -12,6 +12,8 @@ if (DOXYGEN_FOUND)
|
|||||||
set(DOXYGEN_STRIP_FROM_PATH ${CMAKE_SOURCE_DIR})
|
set(DOXYGEN_STRIP_FROM_PATH ${CMAKE_SOURCE_DIR})
|
||||||
set(DOXYGEN_QUIET YES)
|
set(DOXYGEN_QUIET YES)
|
||||||
set(DOXYGEN_PROJECT_NAME ${CMAKE_PROJECT_PROPER_NAME})
|
set(DOXYGEN_PROJECT_NAME ${CMAKE_PROJECT_PROPER_NAME})
|
||||||
|
set(DOXYGEN_PROJECT_ICON "${CMAKE_CURRENT_SOURCE_DIR}/deskflow-logo.png")
|
||||||
|
set(DOXYGEN_PROJECT_LOGO "${CMAKE_CURRENT_SOURCE_DIR}/deskflow-logo.png")
|
||||||
|
|
||||||
if (BUILD_USER_DOCS)
|
if (BUILD_USER_DOCS)
|
||||||
add_subdirectory(user)
|
add_subdirectory(user)
|
||||||
@ -22,3 +24,12 @@ if (DOXYGEN_FOUND)
|
|||||||
else()
|
else()
|
||||||
message(STATUS "Doxygen not found, skipping docs build")
|
message(STATUS "Doxygen not found, skipping docs build")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# Show our documents in the IDE
|
||||||
|
add_custom_target(docs
|
||||||
|
SOURCES
|
||||||
|
Readme.md
|
||||||
|
Security.md
|
||||||
|
)
|
||||||
|
|
||||||
|
install(FILES Security.md Readme.md DESTINATION ${CMAKE_INSTALL_DOCDIR})
|
||||||
18
docs/Readme.md
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
# Deskflow
|
||||||
|
|
||||||
|
Deskflow is a free and open source keyboard and mouse sharing app. Use the keyboard, mouse, or trackpad of one computer to control nearby computers, and work seamlessly between them.
|
||||||
|
|
||||||
|
[Homepage](https://deskflow.org) [Code](https://github.com/deskflow/deskflo)
|
||||||
|
|
||||||
|
## Getting help online
|
||||||
|
|
||||||
|
- View the [wiki](https://github.com/deskflow/deskflow/wiki) Online resource
|
||||||
|
|
||||||
|
### Chat with us
|
||||||
|
- Main discussion on Matrix: [`#deskflow:matrix.org`](https://matrix.to/#/#deskflow:matrix.org) ([Matrix clients](https://matrix.org/ecosystem/clients/))
|
||||||
|
- Discussion also happens on IRC: `#deskflow` or `#deskflow-dev` on [Libera Chat](https://libera.chat/)
|
||||||
|
- Start a [new discussion](https://github.com/deskflow/deskflow/discussions) on our GitHub project.
|
||||||
|
|
||||||
|
## Reporting security issues
|
||||||
|
|
||||||
|
Check [Security](Security.md) to find out how to report security issues.
|
||||||
BIN
docs/deskflow-logo.png
Normal file
|
After Width: | Height: | Size: 2.4 KiB |
@ -1,4 +1,4 @@
|
|||||||
# SPDX-FileCopyrightText: 2025 Chris Rizzitello <sithlord48@gmail.com>
|
# SPDX-FileCopyrightText: (C) 2025 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
set(DOXYGEN_USE_MDFILE_AS_MAINPAGE mainpage.md)
|
set(DOXYGEN_USE_MDFILE_AS_MAINPAGE mainpage.md)
|
||||||
@ -4,81 +4,107 @@ To build Deskflow you will a minimum of:
|
|||||||
- [cmake] 3.24+
|
- [cmake] 3.24+
|
||||||
- [Qt] 6.7.0+
|
- [Qt] 6.7.0+
|
||||||
- [openssl] 3.0+
|
- [openssl] 3.0+
|
||||||
- [libportal] 0.8+ (linux, bsd)
|
- [libportal] 0.9.1+ (linux, bsd)
|
||||||
- [libei] 1.3+ (linux, bsd)
|
- [libei] 1.3+ (linux, bsd)
|
||||||
- [google_test] ^
|
- [google_test] ^
|
||||||
- [tomlplusplus] ^
|
|
||||||
- [cli11] ^
|
|
||||||
|
|
||||||
> ^ Will be fetched if not found on the host system.
|
> ^ Will be fetched if not found on the host system.
|
||||||
|
|
||||||
By default a build of Deskflow will:
|
By default a build of Deskflow will:
|
||||||
- The GUI application deskflow
|
- The GUI application `deskflow`
|
||||||
- The Client application deskflow-client
|
- The Core application `deskflow-core`
|
||||||
- The Server application deskflow-server
|
|
||||||
- Documentation if [doxygen] was found on your system
|
- Documentation if [doxygen] was found on your system
|
||||||
- Tests that will be run as part of the build process.
|
- Tests that will be run as part of the build process
|
||||||
|
|
||||||
## Configuration
|
## Configuration
|
||||||
Deskflow supports the following build options
|
|
||||||
|
|
||||||
CMake options:
|
Deskflow supports the following CMake options:
|
||||||
|
|
||||||
| Option | Description | Default Value | Additional requirements |
|
| Option | Description | Default Value | Additional requirements |
|
||||||
:-------------------------:|:---------------------------------------:|:------------------:|:-----------------------:|
|
:-------------------------:|:---------------------------------------:|:------------------:|:-----------------------:|
|
||||||
| BUILD_GUI | Build GUI | ON | |
|
|
||||||
| BUILD_USER_DOCS | Build user documentation | DOXYGEN_FOUND | `Doxygen` |
|
| BUILD_USER_DOCS | Build user documentation | DOXYGEN_FOUND | `Doxygen` |
|
||||||
| BUILD_DEV_DOCS | Build development documentation | OFF | `Doxygen` |
|
| BUILD_DEV_DOCS | Build development documentation | OFF | `Doxygen` |
|
||||||
| BUILD_INSTALLER | Build installers/packages | ON | |
|
| BUILD_INSTALLER | Build installers/packages | ON | |
|
||||||
| BUILD_TESTS | Build unit tests and legacy tests | ON | `gtest`|
|
| BUILD_TESTS | Build unit tests and legacy tests | ON | `gtest`|
|
||||||
| BUILD_UNIFIED | Build unified binary (client+server) | OFF | |
|
| BUILD_X11_SUPPORT | Build X11 backend (Linux and BSD only) | ON | `x11 libs`|
|
||||||
|
| BUILD_OSX_BUNDLE | Build an app bundle (macOS only) | ON | |
|
||||||
| ENABLE_COVERAGE | Enable test coverage | OFF | `gcov` |
|
| ENABLE_COVERAGE | Enable test coverage | OFF | `gcov` |
|
||||||
| SKIP_BUILD_TESTS | Skip running of tests at build time | OFF | |
|
| SKIP_BUILD_TESTS | Skip running of tests at build time | OFF | |
|
||||||
| VCPKG_QT | Build Qt w/ vcpkg (windows only) | OFF | |
|
| VCPKG_QT | Build Qt w/ vcpkg (Windows only) | OFF | |
|
||||||
|
| CLEAN_TRS | Remove obsolete strings from tr files | OFF | |
|
||||||
|
| APPLE_CODESIGN_DEV | Apple codesign cert ID for development | Not set | |
|
||||||
|
|
||||||
Example cmake configuration.
|
Example cmake configuration:
|
||||||
`cmake -S. -Bbuild -DCMAKE_INSTALL_PREFIX=<INSTALLPREFIX>`
|
`cmake -S. -Bbuild -DCMAKE_INSTALL_PREFIX=<INSTALLPREFIX>`
|
||||||
|
|
||||||
### Windows Configuration
|
### Windows Configuration
|
||||||
|
|
||||||
It is recommended to use vcpkg to install the dependencies. The first time you configure Deskflow, all dependencies other than Qt will be built. If you don't want to use vcpkg, you must manually setup the dependencies. However, that will not be covered by this document.
|
It is recommended to use vcpkg to install the dependencies. The first time you configure Deskflow, all dependencies other than Qt will be built. If you don't want to use vcpkg, you must manually setup the dependencies. However, that will not be covered by this document.
|
||||||
|
|
||||||
#### Windows and Qt
|
#### Windows and Qt
|
||||||
|
|
||||||
There are two ways you can install [Qt] on Windows (vcpkg or Qt online installer). The default configuration expects you to use the Qt online installer. You should not install Qt in both ways, as having both can cause some weird things to happen, like Qt getting libs from one install and plugins from the other. When switching between them, remove the previous install first.
|
There are two ways you can install [Qt] on Windows (vcpkg or Qt online installer). The default configuration expects you to use the Qt online installer. You should not install Qt in both ways, as having both can cause some weird things to happen, like Qt getting libs from one install and plugins from the other. When switching between them, remove the previous install first.
|
||||||
|
|
||||||
##### System Qt
|
##### System Qt
|
||||||
|
|
||||||
1. Download and install the [Qt] online installer from their website.
|
1. Download and install the [Qt] online installer from their website.
|
||||||
2. Add the path of Qt's cmake files to your system path. (Skipping this may require you provide this path to cmake via `Qt6_DIR` at configure time)
|
2. Add the path of Qt's cmake files to your system path (skipping this may require you provide this path to cmake via `Qt6_DIR` at configure time).
|
||||||
- Often `C:\Qt\<version>\<msvcinfo>\lib\cmake`
|
- Often: `C:\Qt\<version>\<msvcinfo>\lib\cmake`
|
||||||
3. Add the path of Qt's binary tools to your system path.
|
3. Add the path of Qt's binary tools to your system path.
|
||||||
- Often `C:\Qt\<version>\<msvcinfo>\bin`
|
- Often: `C:\Qt\<version>\<msvcinfo>\bin`
|
||||||
|
|
||||||
|
##### vcpkg managed Qt
|
||||||
|
|
||||||
##### Vcpkg managed Qt
|
|
||||||
1. Add the option `-DVCPKG_QT=ON` to your cmake configuration command (i.e `cmake -S. -Bbuild -DVCPKG_QT=ON ...`) or if using an IDE, look for the option where you configure the project, have the IDE run cmake again.
|
1. Add the option `-DVCPKG_QT=ON` to your cmake configuration command (i.e `cmake -S. -Bbuild -DVCPKG_QT=ON ...`) or if using an IDE, look for the option where you configure the project, have the IDE run cmake again.
|
||||||
2. Once the configuration starts, you should see a lot more packages vcpkg will build. Building Qt takes a long time (potentially hours), so go find something else to do for a while.
|
2. Once the configuration starts, you should see a lot more packages vcpkg will build. Building Qt takes a long time (potentially hours), so go find something else to do for a while.
|
||||||
3. If you want to use the system Qt again, you must delete the `vcpkg.json` generated in the project root and the `build` folder and reconfigure the project from scratch.
|
3. If you want to use the system Qt again, you must delete the `vcpkg.json` generated in the project root and the `build` folder and reconfigure the project from scratch.
|
||||||
|
|
||||||
|
|
||||||
|
### macOS codesign
|
||||||
|
|
||||||
|
The code signing option `APPLE_CODESIGN_DEV` is only for local development and not intended for distributed bundles.
|
||||||
|
|
||||||
|
Signing for local development and signing for the distribution bundle must be different because of development entitlements which are unlikely to be safe for use in production. It is impractical (i.e. very slow and cumbersome) to use the distribution bundle for local development. When developing locally, the app bundle is partial and does not contain dependencies and uses external libs, e.g. installed with Homebrew; the entitlements allow those external libs to be loaded which is not allowed by default.
|
||||||
|
|
||||||
|
For development codesign:
|
||||||
|
|
||||||
|
1. Install Xcode
|
||||||
|
2. Go to Settings -> Accounts
|
||||||
|
3. Add your account (requires a free Apple Developer ID)
|
||||||
|
4. Manage certificates -> Add -> Apple Development
|
||||||
|
5. To get your ID, run: `security find-identity -v -p codesigning login.keychain-db`
|
||||||
|
6. Pass the ID to CMake, e.g. `-DAPPLE_CODESIGN_DEV=Apple Development: bob@exmaple.com (KLGSJHLFXY)`
|
||||||
|
7. Configure and build
|
||||||
|
8. To verify, run: `codesign -d -r- build/bin/Deskflow.app`
|
||||||
|
|
||||||
## Build
|
## Build
|
||||||
|
|
||||||
After configuring you should be able to run make to build all targets.
|
After configuring you should be able to run make to build all targets.
|
||||||
|
|
||||||
`cmake --build build`
|
`cmake --build build`
|
||||||
|
|
||||||
## Install
|
## Install
|
||||||
To test installation run `DESTDIR=<installDIR> cmake --install build` to install into `<installDir>/<CMAKE_INSTALL_PREFIX>` <br>
|
|
||||||
|
To test installation run `DESTDIR=<installDIR> cmake --install build` to install into `<installDir>/<CMAKE_INSTALL_PREFIX>`
|
||||||
|
|
||||||
Running `cmake --install build` will install to the `CMAKE_INSTALL_PREFIX`
|
Running `cmake --install build` will install to the `CMAKE_INSTALL_PREFIX`
|
||||||
|
|
||||||
## Making Deskflow packages
|
## Making Deskflow packages
|
||||||
Deskflow can generate several packages using cpack.
|
|
||||||
To generate packages build the `package` or `package_source` target.
|
|
||||||
Example: ` cmake --build build --target package package_source` would generate both package and package source packages.
|
|
||||||
Deskflow can generate several package types depending on the system. Archive-based packages should work on all platforms. On Linux deb and rpm info is set up, flatpaks can be generated from the included file in deploy/linux and a PKGBUILD for Arch linux is generated in the build folder. On macos a dmg file will be created and signed. For windows wix can be used to create an installer.
|
|
||||||
|
|
||||||
|
Deskflow can generate several packages using `cpack`.
|
||||||
|
|
||||||
|
To generate packages build the `package` or `package_source` target.
|
||||||
|
|
||||||
|
Example: ` cmake --build build --target package package_source` would generate both package and package source packages.
|
||||||
|
|
||||||
|
Deskflow can generate several package types depending on the system.
|
||||||
|
|
||||||
|
Archive-based packages should work on all platforms. On Linux deb and rpm info is set up, Flatpaks can be generated from the included file in deploy/linux and a `PKGBUILD` for Arch linux is generated in the build folder. On macos a dmg file will be created and signed. For windows WiX can be used to create an installer.
|
||||||
|
|
||||||
[Qt]:https://www.qt.io
|
[Qt]:https://www.qt.io
|
||||||
[doxygen]:http://www.stack.nl/~dimitri/doxygen/
|
[doxygen]:http://www.stack.nl/~dimitri/doxygen/
|
||||||
[cmake]:https://cmake.org/
|
[cmake]:https://cmake.org/
|
||||||
[openssl]:https://www.openssl.org/
|
[openssl]:https://www.openssl.org/
|
||||||
[google_test]:https://github.com/google/googletest
|
[google_test]:https://github.com/google/googletest
|
||||||
[tomlplusplus]:https://github.com/marzer/tomlplusplus
|
|
||||||
[cli11]:https://github.com/CLIUtils/CLI11
|
|
||||||
[libei]:https://gitlab.freedesktop.org/libinput/libei
|
[libei]:https://gitlab.freedesktop.org/libinput/libei
|
||||||
[libportal]:https://github.com/flatpak/libportal
|
[libportal]:https://github.com/flatpak/libportal
|
||||||
@ -1,4 +1,4 @@
|
|||||||
# SPDX-FileCopyrightText: 2025 Chris Rizzitello <sithlord48@gmail.com>
|
# SPDX-FileCopyrightText: (C) 2025 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
set(DOXYGEN_USE_MDFILE_AS_MAINPAGE mainpage.md)
|
set(DOXYGEN_USE_MDFILE_AS_MAINPAGE mainpage.md)
|
||||||
@ -16,5 +16,4 @@ target_sources(user-docs PRIVATE
|
|||||||
install(
|
install(
|
||||||
DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/html"
|
DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/html"
|
||||||
DESTINATION ${CMAKE_INSTALL_DOCDIR}
|
DESTINATION ${CMAKE_INSTALL_DOCDIR}
|
||||||
COMPONENT deskflow_user_docs
|
|
||||||
)
|
)
|
||||||
817
docs/user/configuration.md
Normal file
@ -0,0 +1,817 @@
|
|||||||
|
# GUI Config
|
||||||
|
|
||||||
|
Deskflow will automatically figure out where to save settings and other files.
|
||||||
|
|
||||||
|
|
||||||
|
## Search paths
|
||||||
|
|
||||||
|
Deskflow will look for settings in several places depending on your operating system.
|
||||||
|
The search order for a setting file depends on your operating system
|
||||||
|
|
||||||
|
### Linux
|
||||||
|
|
||||||
|
1. `<XDG_CONFIG_HOME>/Deskflow/Deskflow.conf`
|
||||||
|
2. `~/.config/Deskflow/Deskflow.conf`
|
||||||
|
3. `/etc/Deskflow/Deskflow.conf`
|
||||||
|
|
||||||
|
A new settings file will be created in the user path if no settings file is found.
|
||||||
|
The path of the settings file will be used as the base for all other config files.
|
||||||
|
|
||||||
|
### macOS
|
||||||
|
|
||||||
|
1. `~/Library/Deskflow/Deskflow.conf`
|
||||||
|
2. `/Library/Deskflow/Deskflow.conf`
|
||||||
|
|
||||||
|
A new settings file will be created in the user path if no settings file is found.
|
||||||
|
The path of the settings file will be used as the base for all other config files.
|
||||||
|
|
||||||
|
### Windows
|
||||||
|
|
||||||
|
1. `<install-path>/settings/Deskflow.conf`
|
||||||
|
2. Windows Registry `HKCU\Software\Deskflow\Deskflow`
|
||||||
|
|
||||||
|
Windows will save to the install dir if settings are loaded from there. If not, it saves any other config files in: `C:\ProgramData\Deskflow\`
|
||||||
|
|
||||||
|
When using settings from the install dir, the service mode will not be available.
|
||||||
|
|
||||||
|
## Valid GUI Keys
|
||||||
|
|
||||||
|
The GUI config file contains several sections.
|
||||||
|
Each section is formatted the same.
|
||||||
|
Option-value pairs are only written if the value is not the default value.
|
||||||
|
|
||||||
|
```
|
||||||
|
[section]
|
||||||
|
option=value
|
||||||
|
```
|
||||||
|
|
||||||
|
### Client
|
||||||
|
|
||||||
|
This section contains options used when in client mode.
|
||||||
|
It will begin with `[client]`
|
||||||
|
|
||||||
|
| Option | Valid Values | Description |
|
||||||
|
|:------------------|:------------------:|:-----------|
|
||||||
|
| languageSync | `true` or `false` | Sync to server language [default: true] |
|
||||||
|
| remoteHost | `IP` or `hostname` | The remote host(s) to connect to. Use a comma separated list when you want to try several hosts |
|
||||||
|
| yScrollScale | Double 0.1 - 10.0 | Vertical mouse scrolling will be scaled by this amount on the client [default: 1.0] |
|
||||||
|
| xScrollScale | Double 0.1 - 10.0 | Horizontal mouse scrolling will be scaled by this amount on the client [default: 1.0] |
|
||||||
|
| invertYScroll | `true` or `false` | Invert vertical scroll on this client [default: false] |
|
||||||
|
| invertXScroll | `true` or `false` | Invert horizontal scroll on this client [default: false] |
|
||||||
|
| xdpRestoreToken | UUID | Restore token provided by XDG portals |
|
||||||
|
|
||||||
|
### Core
|
||||||
|
|
||||||
|
This section contains general options it will begin with `[core]`
|
||||||
|
|
||||||
|
|Option | Valid Values|Description|
|
||||||
|
|:--------------|:-----------:|:-----------|
|
||||||
|
| coreMode | `0` or `1` or `2` | The mode to start in 0: None, 1: Client, 2: Server [default: 0]|
|
||||||
|
| display | int | The XWindow display to use [default: autodetected] |
|
||||||
|
| interface | IP Address | Preferred IP to use for network communication. By default the server board casts on any available address |
|
||||||
|
| lastVersion | M.m.p.t | The version last run used for checking for updates |
|
||||||
|
| port | port # | Port to use when connecting [default: 24800 |
|
||||||
|
| preventSleep | `true` or `false` | Prevent sleep when Deskflow is active [default: false] |
|
||||||
|
| processMode | `1` or `0` | The mode we use to start the process Service or Desktop |
|
||||||
|
| computerName | string | Name used to identify the computer [default: machine's hostname] |
|
||||||
|
| useHooks | `true` or `false` | If Windows uses hooks or not [default: true] |
|
||||||
|
| language | 639 language | The language to display the GUI in [default: en] |
|
||||||
|
| wlClipboard | `true` or `false` | When true the wl-clipboard backend will be enabled [default: false] |
|
||||||
|
| enableEnterCommand | `true` or `false` | Should the enter command be triggered when the screen is entered [defaut: false] |
|
||||||
|
| enterCommand | command | A command to run when the screen is entered. |
|
||||||
|
| enableExitCommand | `true` or `false` | Should the exit command be triggered when the screen is exited [defaut: false] |
|
||||||
|
| exitCommand | command | A command to run when the screen is exited. |
|
||||||
|
|
||||||
|
### Daemon
|
||||||
|
|
||||||
|
This section contains options used by the daemon on windows it will begin with `[daemon]`
|
||||||
|
|
||||||
|
|Option | Valid Values|Description|
|
||||||
|
|:----------|:-----------:|:-----------|
|
||||||
|
| command | Filename | The filename of the binary the daemon. This binary exists in the same path as the deskflow GUI |
|
||||||
|
| elevate | `true` or `false` | Elevate the daemon app [default: true unless portable mode ] |
|
||||||
|
| logFile | Filepath | Filepath of the daemon log |
|
||||||
|
| logLevel | valid log Level, | Log Level |
|
||||||
|
|
||||||
|
### GUI
|
||||||
|
|
||||||
|
This section contains options used by the GUI it will begin with `[gui]`
|
||||||
|
|
||||||
|
|Option | Valid Values |Description|
|
||||||
|
|:-------------------------------|:-----------------:|:-----------|
|
||||||
|
| autoHide | `true` or `false` | When true the app will hide itself on start up [default: false] |
|
||||||
|
| enableUpdateCheck | `true` or `false` | When true check the update URL to see if a new version was released on start up [default: false] |
|
||||||
|
| closeReminder | `true` or `false` | Used to track if we have shown the reminder that when you close the app it remain running in the background [default: true]|
|
||||||
|
| closeToTray | `true` or `false` | When `true` the gui will run in the systemTray when its closed [default: true] |
|
||||||
|
| logExpanded | `true` or `false` | Should the log section of the GUI be opened [default: false] |
|
||||||
|
| symbolicTrayIcon | `true` or `false` | When true use the monocolor (symbolic) icon false uses a colorful icon for the tray [default: true] |
|
||||||
|
| windowGeometry | QRect | Geometry of the window used to restore the window geometry after exiting the app |
|
||||||
|
| showGenericClientFailureDialog | `true` or `false` | When `true` client connection errors will not show popup error messages [default: true] |
|
||||||
|
| shownFirstConnectedMessage | `true` or `false` | When `true` GUI has shown the user the message for connecting the first time [default: false] |
|
||||||
|
| shownServerFirstStartMessage | `true` or `false` | When `true` GUI has shown the user the Deskflow server is now running message [default: false] |
|
||||||
|
| shownVerionInTitle | `true` or `false` | When `true` GUI will include the version in the window title [default: false] |
|
||||||
|
| startCoreWithGui | `true` or `false` | When true the Core will be started with the GUI. It is set to the Core's state on exit. |
|
||||||
|
| updateCheckUrl | URL | The URL to use when checking for a new version number, it should return a version [default: https://api.deskflow.org/version]|
|
||||||
|
|
||||||
|
### Log
|
||||||
|
|
||||||
|
This section contains options used by the application logging it will begin with `[log]`
|
||||||
|
|
||||||
|
|Option | Valid Values |Description|
|
||||||
|
|:---------|:-----------------:|:-----------|
|
||||||
|
| file | Filepath | The file to write the log into |
|
||||||
|
| level | Valid log level | Log level to use |
|
||||||
|
| toFile | `true` or `false` | When true the log will be written to the value of the `file` option |
|
||||||
|
| guiDebug | `true` or `false` | When true the log will show the Gui's internal debug messages |
|
||||||
|
|
||||||
|
### Security
|
||||||
|
|
||||||
|
This section contains options used by the application security it will begin with `[security]`
|
||||||
|
|
||||||
|
|Option | Valid Values |Description|
|
||||||
|
|:----------------------|:-----------------:|:-----------|
|
||||||
|
| checkPeerFingerprints | `true` or `false` | When true peers will have their fingerprints confirmed by the user and stored [default: true] |
|
||||||
|
| certificate | Filepath | Path to the certificate to use to encrypt messages.|
|
||||||
|
| keySize | `2048` OR `4096` | Size of the TLS key to use [default: 2048]|
|
||||||
|
| tlsEnabled | `true` or `false` | Are we using TLS encryption when communicating [default: true].|
|
||||||
|
|
||||||
|
### Server
|
||||||
|
|
||||||
|
This section contains options used when in server mode it will begin with `[server]`
|
||||||
|
|
||||||
|
|Option | Valid Values |Description|
|
||||||
|
|:-------------------|:-----------------:|:-----------|
|
||||||
|
| externalConfig | `true` or `false` | When true use the external config path |
|
||||||
|
| externalConfigFile | Filepath | Path the server config file if it does not exist the GUI will it generated based on the `internalConfig` section.|
|
||||||
|
|
||||||
|
### InternalConfig
|
||||||
|
|
||||||
|
This section contains options used when in server mode it will begin with `[internalConfig]`
|
||||||
|
block of a server config file as seen below. This section is used by the GUI to generate a server configuration
|
||||||
|
|
||||||
|
```
|
||||||
|
[internalConfig]
|
||||||
|
clipboardSharing=true
|
||||||
|
clipboardSharingSize=@Variant(\0\0\0\x84\0\0\0\0\0\0<\0)
|
||||||
|
defaultLockToScreenState=false
|
||||||
|
disableLockToScreen=false
|
||||||
|
hasHeartbeat=false
|
||||||
|
hasSwitchDelay=false
|
||||||
|
hasSwitchDoubleTap=false
|
||||||
|
heartbeat=5000
|
||||||
|
hotkeys\1\actions\1\activeOnRelease=false
|
||||||
|
hotkeys\1\actions\1\hasScreens=true
|
||||||
|
hotkeys\1\actions\1\keys\1\key=83
|
||||||
|
hotkeys\1\actions\1\keys\size=1
|
||||||
|
hotkeys\1\actions\1\lockCursorToScreen=0
|
||||||
|
hotkeys\1\actions\1\restartServer=false
|
||||||
|
hotkeys\1\actions\1\switchInDirection=0
|
||||||
|
hotkeys\1\actions\1\switchScreenName=void
|
||||||
|
hotkeys\1\actions\1\type=0
|
||||||
|
hotkeys\1\actions\1\typeScreenNames\size=0
|
||||||
|
hotkeys\1\actions\size=1
|
||||||
|
hotkeys\1\keys\1\key=83
|
||||||
|
hotkeys\1\keys\size=1
|
||||||
|
hotkeys\size=1
|
||||||
|
numColumns=5
|
||||||
|
numRows=3
|
||||||
|
protocol=1
|
||||||
|
relativeMouseMoves=false
|
||||||
|
screens\1\name=
|
||||||
|
screens\10\aliasArray\size=0
|
||||||
|
screens\10\fixArray\1\fix=false
|
||||||
|
screens\10\fixArray\2\fix=false
|
||||||
|
screens\10\fixArray\3\fix=false
|
||||||
|
screens\10\fixArray\4\fix=false
|
||||||
|
screens\10\fixArray\size=4
|
||||||
|
screens\10\modifierArray\1\modifier=0
|
||||||
|
screens\10\modifierArray\2\modifier=1
|
||||||
|
screens\10\modifierArray\3\modifier=2
|
||||||
|
screens\10\modifierArray\4\modifier=3
|
||||||
|
screens\10\modifierArray\5\modifier=4
|
||||||
|
screens\10\modifierArray\6\modifier=5
|
||||||
|
screens\10\modifierArray\size=6
|
||||||
|
screens\10\name=null
|
||||||
|
screens\10\switchCornerArray\1\switchCorner=false
|
||||||
|
screens\10\switchCornerArray\2\switchCorner=false
|
||||||
|
screens\10\switchCornerArray\3\switchCorner=false
|
||||||
|
screens\10\switchCornerArray\4\switchCorner=false
|
||||||
|
screens\10\switchCornerArray\size=4
|
||||||
|
screens\10\switchCornerSize=0
|
||||||
|
screens\11\name=
|
||||||
|
screens\12\name=
|
||||||
|
screens\13\name=
|
||||||
|
screens\14\name=
|
||||||
|
screens\15\name=
|
||||||
|
screens\2\name=
|
||||||
|
screens\3\name=
|
||||||
|
screens\4\name=
|
||||||
|
screens\5\name=
|
||||||
|
screens\6\name=
|
||||||
|
screens\7\aliasArray\size=0
|
||||||
|
screens\7\fixArray\1\fix=false
|
||||||
|
screens\7\fixArray\2\fix=false
|
||||||
|
screens\7\fixArray\3\fix=false
|
||||||
|
screens\7\fixArray\4\fix=false
|
||||||
|
screens\7\fixArray\size=4
|
||||||
|
screens\7\modifierArray\1\modifier=0
|
||||||
|
screens\7\modifierArray\2\modifier=1
|
||||||
|
screens\7\modifierArray\3\modifier=2
|
||||||
|
screens\7\modifierArray\4\modifier=3
|
||||||
|
screens\7\modifierArray\5\modifier=4
|
||||||
|
screens\7\modifierArray\6\modifier=5
|
||||||
|
screens\7\modifierArray\size=6
|
||||||
|
screens\7\name=void
|
||||||
|
screens\7\switchCornerArray\1\switchCorner=false
|
||||||
|
screens\7\switchCornerArray\2\switchCorner=false
|
||||||
|
screens\7\switchCornerArray\3\switchCorner=false
|
||||||
|
screens\7\switchCornerArray\4\switchCorner=false
|
||||||
|
screens\7\switchCornerArray\size=4
|
||||||
|
screens\7\switchCornerSize=0
|
||||||
|
screens\8\aliasArray\size=0
|
||||||
|
screens\8\fixArray\1\fix=false
|
||||||
|
screens\8\fixArray\2\fix=false
|
||||||
|
screens\8\fixArray\3\fix=false
|
||||||
|
screens\8\fixArray\4\fix=false
|
||||||
|
screens\8\fixArray\size=4
|
||||||
|
screens\8\modifierArray\1\modifier=0
|
||||||
|
screens\8\modifierArray\2\modifier=1
|
||||||
|
screens\8\modifierArray\3\modifier=2
|
||||||
|
screens\8\modifierArray\4\modifier=3
|
||||||
|
screens\8\modifierArray\5\modifier=4
|
||||||
|
screens\8\modifierArray\6\modifier=5
|
||||||
|
screens\8\modifierArray\size=6
|
||||||
|
screens\8\name=chris-Precision-5570
|
||||||
|
screens\8\switchCornerArray\1\switchCorner=false
|
||||||
|
screens\8\switchCornerArray\2\switchCorner=false
|
||||||
|
screens\8\switchCornerArray\3\switchCorner=false
|
||||||
|
screens\8\switchCornerArray\4\switchCorner=false
|
||||||
|
screens\8\switchCornerArray\size=4
|
||||||
|
screens\8\switchCornerSize=0
|
||||||
|
screens\9\aliasArray\size=0
|
||||||
|
screens\9\fixArray\1\fix=false
|
||||||
|
screens\9\fixArray\2\fix=false
|
||||||
|
screens\9\fixArray\3\fix=false
|
||||||
|
screens\9\fixArray\4\fix=false
|
||||||
|
screens\9\fixArray\size=4
|
||||||
|
screens\9\modifierArray\1\modifier=0
|
||||||
|
screens\9\modifierArray\2\modifier=1
|
||||||
|
screens\9\modifierArray\3\modifier=2
|
||||||
|
screens\9\modifierArray\4\modifier=3
|
||||||
|
screens\9\modifierArray\5\modifier=4
|
||||||
|
screens\9\modifierArray\6\modifier=5
|
||||||
|
screens\9\modifierArray\size=6
|
||||||
|
screens\9\name=abyss.lan
|
||||||
|
screens\9\switchCornerArray\1\switchCorner=false
|
||||||
|
screens\9\switchCornerArray\2\switchCorner=false
|
||||||
|
screens\9\switchCornerArray\3\switchCorner=false
|
||||||
|
screens\9\switchCornerArray\4\switchCorner=false
|
||||||
|
screens\9\switchCornerArray\size=4
|
||||||
|
screens\9\switchCornerSize=0
|
||||||
|
screens\size=15
|
||||||
|
switchCornerArray\1\switchCorner=false
|
||||||
|
switchCornerArray\2\switchCorner=false
|
||||||
|
switchCornerArray\3\switchCorner=false
|
||||||
|
switchCornerArray\4\switchCorner=false
|
||||||
|
switchCornerArray\size=4
|
||||||
|
switchCornerSize=0
|
||||||
|
switchDelay=250
|
||||||
|
switchDoubleTap=250
|
||||||
|
win32KeepForeground=false
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
# Server Config
|
||||||
|
|
||||||
|
The `deskflow-server` command accepts the `-c` or `--config` option, which takes one argument,
|
||||||
|
the path to a server configuration file. When using the GUI the `internalConfig` section of the GUI settings will be exported as the server configuration.
|
||||||
|
The configuration file is plain text and case-sensitive. The file is broken into sections, and each section has the form:
|
||||||
|
```
|
||||||
|
section: ''name''
|
||||||
|
''arg'' = ''value''
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
Comments are introduced by ''#'' and continue to the end of the line. ''name'' must be one of the following:
|
||||||
|
|
||||||
|
* ''screens''
|
||||||
|
* ''aliases''
|
||||||
|
* ''links''
|
||||||
|
* ''options''
|
||||||
|
|
||||||
|
The file is parsed top to bottom and names cannot be used before they've been defined in the <code>screens</code> or <code>aliases</code> sections. So the <code>links</code> and <code>aliases</code> must appear after the <code>screens</code> and <code>links</code> cannot refer to aliases unless the <code>aliases</code> appear before the <code>links</code>.
|
||||||
|
|
||||||
|
### The screens section
|
||||||
|
|
||||||
|
''args'' is a list of computer names, one name per line, each followed by a colon. Names are arbitrary strings but they must be unique. The hostname of each computer is recommended. (This is the computer's network name on win32 and the name reported by the program hostname on Unix and OS X. Note that OS X may append .local to the name you gave your computer; e.g. somehost.local.) There must be a computer name for the server and each client. Each computer can specify a number of options. Options have the form name = value and are listed one per line after the computer name.
|
||||||
|
|
||||||
|
```
|
||||||
|
section: screens
|
||||||
|
moe:
|
||||||
|
larry:
|
||||||
|
halfDuplexCapsLock = true
|
||||||
|
halfDuplexNumLock = true
|
||||||
|
curly:
|
||||||
|
meta = alt
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
This declares three computers named ''moe'', ''larry'', and ''curly''. Computer ''larry'' has half-duplex ''Caps Lock'' and ''Num Lock'' keys (see below) and computer ''curly'' converts the ''Meta'' modifier key to the ''Alt'' modifier key.
|
||||||
|
|
||||||
|
#### screen options
|
||||||
|
|
||||||
|
A computer can have the following options:
|
||||||
|
|Option | Valid Values| Description|
|
||||||
|
|:----------|:-----------:|:-----------|
|
||||||
|
|halfDuplexCapsLock| `true` or `false` | This computer has a ''Caps Lock'' key that doesn't report a press and a release event when the user presses it but instead reports a press event when it's turned on and a release event when it's turned off. If ''Caps Lock'' acts strangely on all computers then you may need to set this option to true on the server. If it acts strangely on one computer then that computer may need the option set to true.|
|
||||||
|
|halfDuplexNumLock | `true` or `false` | This computer has a ''Num Lock'' key that doesn't report a press and a release event when the user presses it but instead reports a press event when it's turned on and a release event when it's turned off. If ''Num Lock'' acts strangely on all computers then you may need to set this option to true on the server. If it acts strangely on one computer then that computer may need the option set to true.|
|
||||||
|
|halfDuplexScrollLock| `true` or `false`| This computer has a ''Scroll Lock'' key that doesn't report a press and a release event when the user presses it but instead reports a press event when it's turned on and a release event when it's turned off. If ''Scroll Lock'' acts strangely on all computers then you may need to set this option to true on the server. If it acts strangely on one computer then that computer may need the option set to true.|
|
||||||
|
|xtestIsXineramaUnaware| `true` or `false`| This option works around a bug in the XTest extension when used in combination with Xinerama. It affects X11 clients only. Not all versions of the XTest extension are aware of the Xinerama extension. As a result, they do not move the mouse correctly when using multiple Xinerama screens. This option is currently ''true'' by default. If you know your XTest extension is Xinerama aware then set this option to ''false''.|
|
||||||
|
|preserveFocus| `true` or `false` | When true don't drop focus when switching computers
|
||||||
|
|switchCorners| corners |See <a href="#switch-corners">switchCorners</a> below.|
|
||||||
|
|switchCornerSize | integer | see switchCornerSize below.|
|
||||||
|
|shift | shift ctrl alt meta super none | Map the server's shift modifer to different key on a client computer|
|
||||||
|
|ctrl | shift ctrl alt meta super none | Map the server's ctrl modifer to different key on a client computer|
|
||||||
|
|alt | shift ctrl alt meta super none | Map the server's alt modifer to different key on a client computer|
|
||||||
|
|meta| shift ctrl alt meta super none | Map the server's meta modifer to different key on a client computer|
|
||||||
|
|super| shift ctrl alt meta super none | Map the server's super modifer to different key on a client computer|
|
||||||
|
|
||||||
|
### aliases section
|
||||||
|
|
||||||
|
''args'' is a list of computer names just like in the ''screens'' section except each computer is followed by a list of aliases, one per line, not followed by a colon. An ''alias'' is a computer name and must be unique. When searching for computers each alias is equivalent to the computer name it aliases. So a client can connect using its canonical computer name or any of its aliases.
|
||||||
|
|
||||||
|
```
|
||||||
|
section: aliases
|
||||||
|
larry:
|
||||||
|
larry.stooges.com
|
||||||
|
curly:
|
||||||
|
shemp
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
Computer ''larry'' is also known as ''larry.stooges.com'' and can connect as either name. Computer ''curly'' is also known as ''shemp'' (hey, it's just an example).
|
||||||
|
|
||||||
|
### links secion
|
||||||
|
|
||||||
|
''args'' is a list of computer names just like in the ''screens'' section except each computer is followed by a list of links, one per line. Each link has the form:
|
||||||
|
```
|
||||||
|
{left|right|up|down}[<range>] = name[<range>]
|
||||||
|
```
|
||||||
|
|
||||||
|
A link indicates which computer is adjacent in the given direction.
|
||||||
|
|
||||||
|
Each side of a link can specify a range which defines a portion of an edge. A range on the direction is the portion of edge you can leave from while a range on the computer is the portion of edge you'll enter into. Ranges are optional and default to the entire edge. All ranges on a particular direction of a particular computer must not overlap.
|
||||||
|
|
||||||
|
A ''range'' is written as <code>(start,end)</code>. Both ''start'' and ''end'' are percentages in the range 0 to 100, inclusive. The start must be less than the end. 0 is the left or top of an edge and 100 is the right or bottom.
|
||||||
|
|
||||||
|
```
|
||||||
|
section: links
|
||||||
|
moe:
|
||||||
|
right = larry
|
||||||
|
up(50,100) = curly(0,50)
|
||||||
|
larry:
|
||||||
|
left = moe
|
||||||
|
up(0,50) = curly(50,100)
|
||||||
|
curly:
|
||||||
|
down(0,50) = moe
|
||||||
|
down(50,100) = larry(0,50)
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
This indicates that computer ''larry'' is to the right of computer ''moe'' (so moving the cursor off the right edge of ''moe'' would make it appear at the left edge of ''larry''), the left half of curly is above the right half of ''moe'', ''moe'' is to the left of ''larry'' (edges are not necessarily symmetric so you have to provide both directions), the right half of curly is above the left half of ''larry'', all of ''moe'' is below the left half of ''curly'', and the left half of ''larry'' is below the right half of ''curly''.
|
||||||
|
|
||||||
|
Note that links do not have to be symmetrical; for instance, here the edge between ''moe'' and ''curly'' maps to different ranges depending on if you're going up or down. In fact links don't have to be bidirectional. You can configure the right of ''moe'' to go to ''larry'' without a link from the left of ''larry'' to ''moe''. It's possible to configure a computer with no outgoing links; the cursor will get stuck on that computer unless you have a hot key configured to switch off of that computer.
|
||||||
|
|
||||||
|
### options section
|
||||||
|
|
||||||
|
''args'' is a list of lines of the form <code>name = value</code>. These set the global options.
|
||||||
|
|
||||||
|
```
|
||||||
|
section: options
|
||||||
|
protocol = barrier
|
||||||
|
heartbeat = 5000
|
||||||
|
switchDelay = 500
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
#### List of options allowed in options section
|
||||||
|
|
||||||
|
| Options | Value Values| Description|
|
||||||
|
|:--------|:-----------:|:-----------|
|
||||||
|
|protocol | barrier or synergy| The protocol to use when saying hello to clients. Can be set to barrier or synergy. If not set barrier is used as the default |
|
||||||
|
|heartbeat| integer (N) | The server will expect each client to send a message no less than every `N` milliseconds. If no message arrives from a client within `3N` seconds the server forces that client to disconnect. If deskflow fails to detect clients disconnecting while the server is sleeping or vice versa, try using this option. |
|
||||||
|
|switchCorners | none top-left top-right bottom-left bottom-right left right top bottom all | Deskflow won't switch computers when the mouse reaches the edge of the computer if it's in a listed corner. The size of all corners is given by the `switchCornerSize` option. The first name in the list is one of the above names and defines the initial set of corners. Subsequent names are prefixed with + or - to add the corner to or remove the corner from the set, respectively. For example: `all -left +top-left` starts will all corners, removes the left corners (top and bottom) then adds the top-left back in, resulting in the top-left, bottom-left and bottom-right corners.|
|
||||||
|
|switchCornerSize | integer (N) | Sets the size of all corners in pixels. The cursor must be within `N` pixels of the corner to be considered to be in the corner.|
|
||||||
|
|switchDelay | integer| Deskflow won't switch computers when the mouse reaches edge of a computer unless it stays on the edge for `N` milliseconds. This helps prevent unintentional switching when working near an edge.|
|
||||||
|
|switchDoubleTap| integer(N) | Deskflow won't switch computers when the mouse reaches the edge of a computer unless it's moved away from the edge and then back to the edge within `N` milliseconds. With the option you have to quickly tap the edge twice to switch. This helps prevent unintentional switching when working near the edge.|
|
||||||
|
|screenSaverSync| `true` or `false`| ''Note: Removed in v1.14.1'' If set to ''false'' then Deskflow won't synchronize screen savers. Client screen savers will start according to their individual configurations. The server screen saver won't start if there is input, even if that input is directed toward a client computer.|
|
||||||
|
|relativeMouseMoves| `true` or `false`| If set to ''true'' then secondary computers move the mouse using relative rather than absolute mouse moves when and only when the cursor is locked to the computer (by ''Scroll Lock'' or a configured hot key). This is intended to make Deskflow work better with certain games. If set to ''false'' or not set then all mouse moves are absolute.|
|
||||||
|
|clipboardSharing| `true` or `false`|If set to ''true'' then clipboard sharing will be enabled and the ''clipboardSharingSize'' setting will be used. If set to false, then clipboard sharing will be disabled and the the ''clipboardSharingSize'' setting will be ignored.|
|
||||||
|
|clipboardSharingSize| integer (N)| Deskflow will send a maximum of `N` kilobytes of clipboard data to another computer when the mouse transitions to that computer.|
|
||||||
|
|win32KeepForeground | `true` or `false`| If set to ''true'' (the default), Deskflow will grab the foreground focus on a Windows server (thereby putting all other windows in the background) upon switching to a client. If set to ''false'', it will leave the currently foreground window in the foreground. Deskflow grabs the focus to avoid issues with other apps interfering with Deskflow's ability to read the hardware inputs. |
|
||||||
|
|keystroke(key) | actions | Binds the ''key'' combination key to the given ''actions''. ''key'' is an optional list of modifiers (''shift'', ''control'', ''alt'', ''meta'' or ''super'') optionally followed by a character or a key name, all separated by + (plus signs). You must have either modifiers or a character/key name or both. See below for `valid key names` and `actions`. Keyboard hot keys are handled while the cursor any computer. Separate actions can be assigned to press and release.|
|
||||||
|
|mousebutton(button) | actions| Binds the modifier and mouse button combination ''button'' to the given ''actions''. ''button'' is an optional list of modifiers (''shift'', ''control'', ''alt'', ''meta'' or ''super'') followed by a button number. The primary button (the left button for right handed users) is button 1, the middle button is 2, etc. Actions can be found below. Mouse button actions are not handled while the cursor is on the server. You cannot use these to perform an action while on the server. Separate actions can be assigned to press and release.|
|
||||||
|
|
||||||
|
|
||||||
|
You can use both the ''switchDelay'' and ''switchDoubleTap'' options at the same time. Deskflow will switch when either requirement is satisfied.
|
||||||
|
|
||||||
|
##### Actions
|
||||||
|
|
||||||
|
Actions are two lists of individual actions separated by commas. The two lists are separated by a '';'' (semicolon). Either list can be empty and if the second list is empty then the semicolon is optional. The first list lists actions to take when the condition becomes true (e.g. the hot key or mouse button is pressed) and the second lists actions to take when the condition becomes false (e.g. the hot key or button is released). The condition becoming true is called activation and becoming false is called deactivation. Allowed individual actions are:
|
||||||
|
|
||||||
|
* `keystroke(key[,computers])`
|
||||||
|
|
||||||
|
* `keyDown(key[,computers])`
|
||||||
|
|
||||||
|
* `keyUp(key[,computers])`
|
||||||
|
|
||||||
|
|
||||||
|
: Synthesizes the modifiers and key given in ''key'' which has the same form as described in the ''keystroke'' option. If given, ''computers'' lists the computer or computers to direct the event to, regardless of the active computer. If not given then the event is directed to the active computer only.
|
||||||
|
: ''keyDown'' synthesizes a key press and ''keyUp'' synthesizes a key release. ''keystroke'' synthesizes a key press on activation and a release on deactivation and is equivalent to a ''keyDown'' on activation and ''keyUp'' on deactivation.
|
||||||
|
: ''computers'' is either ''*'' (asterisk) to indicate all computers or a '':'' (colon) separated list of computer names. (Note that the computer name must have already been encountered in the configuration file so you'll probably want to put ''actions'' at the bottom of the file.)
|
||||||
|
|
||||||
|
* `mousebutton(button)`
|
||||||
|
* `mouseDown(button)`
|
||||||
|
* `mouseUp(button)`
|
||||||
|
: Synthesizes the modifiers and mouse button given in ''button'' which has the same form as described in the ''mousebutton'' option.
|
||||||
|
: ''mouseDown'' synthesizes a mouse press and ''mouseUp'' synthesizes a mouse release. ''mousebutton'' synthesizes a mouse press on activation and a release on deactivation and is equivalent to a ''mouseDown'' on activation and ''mouseUp'' on deactivation.
|
||||||
|
|
||||||
|
* `lockCursorToScreen(mode)`
|
||||||
|
: Locks the cursor to or unlocks the cursor from the active computer. ''mode'' can be ''off'' to unlock the cursor, ''on'' to lock the cursor, or ''toggle'' to toggle the current state. The default is ''toggle''. If the configuration has no ''lockCursorToScreen'' action and ''Scroll Lock'' is not used as a hot key then ''Scroll Lock'' toggles cursor locking.
|
||||||
|
|
||||||
|
* `switchToScreen(computerName)`
|
||||||
|
: Jump to computer with name or alias ''computerName''.
|
||||||
|
|
||||||
|
* `switchInDirection(dir)`
|
||||||
|
: Switch to the computer in the direction ''dir'', which may be one of ''left'', ''right'', ''up'' or ''down''.
|
||||||
|
|
||||||
|
* `switchToNextScreen()`
|
||||||
|
: Cycle to the next computer in the configuration order. If at the last computer, cycles back to the first computer.
|
||||||
|
|
||||||
|
##### Keynames
|
||||||
|
Valid key names are:
|
||||||
|
|
||||||
|
<details><summary>Valid Key Names</summary>
|
||||||
|
* AppMail
|
||||||
|
* AppMedia
|
||||||
|
* AppUser1
|
||||||
|
* AppUser2
|
||||||
|
* AudioDown
|
||||||
|
* AudioMute
|
||||||
|
* AudioNext
|
||||||
|
* AudioPlay
|
||||||
|
* AudioPrev
|
||||||
|
* AudioStop
|
||||||
|
* AudioUp
|
||||||
|
* BackSpace
|
||||||
|
* Begin
|
||||||
|
* Break
|
||||||
|
* Cancel
|
||||||
|
* CapsLock
|
||||||
|
* Clear
|
||||||
|
* Delete
|
||||||
|
* Down
|
||||||
|
* Eject
|
||||||
|
* End
|
||||||
|
* Escape
|
||||||
|
* Execute
|
||||||
|
* F1
|
||||||
|
* F2
|
||||||
|
* F3
|
||||||
|
* F4
|
||||||
|
* F5
|
||||||
|
* F6
|
||||||
|
* F7
|
||||||
|
* F8
|
||||||
|
* F9
|
||||||
|
* F10
|
||||||
|
* F11
|
||||||
|
* F12
|
||||||
|
* F13
|
||||||
|
* F14
|
||||||
|
* F15
|
||||||
|
* F16
|
||||||
|
* F17
|
||||||
|
* F18
|
||||||
|
* F19
|
||||||
|
* F20
|
||||||
|
* F21
|
||||||
|
* F22
|
||||||
|
* F23
|
||||||
|
* F24
|
||||||
|
* F25
|
||||||
|
* F26
|
||||||
|
* F27
|
||||||
|
* F28
|
||||||
|
* F29
|
||||||
|
* F30
|
||||||
|
* F31
|
||||||
|
* F32
|
||||||
|
* F33
|
||||||
|
* F34
|
||||||
|
* F35
|
||||||
|
* Find
|
||||||
|
* Help
|
||||||
|
* Home
|
||||||
|
* Insert
|
||||||
|
* KP_0
|
||||||
|
* KP_1
|
||||||
|
* KP_2
|
||||||
|
* KP_3
|
||||||
|
* KP_4
|
||||||
|
* KP_5
|
||||||
|
* KP_6
|
||||||
|
* KP_7
|
||||||
|
* KP_8
|
||||||
|
* KP_9
|
||||||
|
* KP_Add
|
||||||
|
* KP_Begin
|
||||||
|
* KP_Decimal
|
||||||
|
* KP_Delete
|
||||||
|
* KP_Divide
|
||||||
|
* KP_Down
|
||||||
|
* KP_End
|
||||||
|
* KP_Enter
|
||||||
|
* KP_Equal
|
||||||
|
* KP_F1
|
||||||
|
* KP_F2
|
||||||
|
* KP_F3
|
||||||
|
* KP_F4
|
||||||
|
* KP_Home
|
||||||
|
* KP_Insert
|
||||||
|
* KP_Left
|
||||||
|
* KP_Multiply
|
||||||
|
* KP_PageDown
|
||||||
|
* KP_PageUp
|
||||||
|
* KP_Right
|
||||||
|
* KP_Separator
|
||||||
|
* KP_Space
|
||||||
|
* KP_Subtract
|
||||||
|
* KP_Tab
|
||||||
|
* KP_Up
|
||||||
|
* Left
|
||||||
|
* LeftTab
|
||||||
|
* Linefeed
|
||||||
|
* Menu
|
||||||
|
* NumLock
|
||||||
|
* PageDown
|
||||||
|
* PageUp
|
||||||
|
* Pause
|
||||||
|
* Print
|
||||||
|
* Redo
|
||||||
|
* Return
|
||||||
|
* Right
|
||||||
|
* ScrollLock
|
||||||
|
* Select
|
||||||
|
* Sleep
|
||||||
|
* Space
|
||||||
|
* SysReq
|
||||||
|
* Tab
|
||||||
|
* Undo
|
||||||
|
* Up
|
||||||
|
* WWWBack
|
||||||
|
* WWWFavorites
|
||||||
|
* WWWForward
|
||||||
|
* WWWHome
|
||||||
|
* WWWRefresh
|
||||||
|
* WWWSearch
|
||||||
|
* WWWStop
|
||||||
|
* Space
|
||||||
|
* Exclaim
|
||||||
|
* DoubleQuote
|
||||||
|
* Number
|
||||||
|
* Dollar
|
||||||
|
* Percent
|
||||||
|
* Ampersand
|
||||||
|
* Apostrophe
|
||||||
|
* ParenthesisL
|
||||||
|
* ParenthesisR
|
||||||
|
* Asterisk
|
||||||
|
* Plus
|
||||||
|
* Comma
|
||||||
|
* Minus
|
||||||
|
* Period
|
||||||
|
* Slash
|
||||||
|
* Colon
|
||||||
|
* Semicolon
|
||||||
|
* Less
|
||||||
|
* Equal
|
||||||
|
* Greater
|
||||||
|
* Question
|
||||||
|
* At
|
||||||
|
* BracketL
|
||||||
|
* Backslash
|
||||||
|
* BracketR
|
||||||
|
* Circumflex
|
||||||
|
* Underscore
|
||||||
|
* Grave
|
||||||
|
* BraceL
|
||||||
|
* Bar
|
||||||
|
* BraceR
|
||||||
|
* Tilde
|
||||||
|
</details>
|
||||||
|
|
||||||
|
Additionally, a name of the form `\uXXXX` where ''XXXX'' is a hexadecimal number is interpreted as a unicode character code. Key and modifier names are case-insensitive. Keys that don't exist on the keyboard or in the default keyboard layout will not work.
|
||||||
|
|
||||||
|
### Example textual configuration file
|
||||||
|
|
||||||
|
This example comes from doc/deskflow-basic.conf
|
||||||
|
|
||||||
|
```
|
||||||
|
# sample deskflow configuration file
|
||||||
|
#
|
||||||
|
# comments begin with the # character and continue to the end of
|
||||||
|
# line. comments may appear anywhere the syntax permits.
|
||||||
|
# +-------+ +--------+ +---------+
|
||||||
|
# |Laptop | |Desktop1| |iMac |
|
||||||
|
# | | | | | |
|
||||||
|
# +-------+ +--------+ +---------+
|
||||||
|
|
||||||
|
section: screens
|
||||||
|
# three hosts named: Laptop, Desktop1, and iMac
|
||||||
|
# These are the nice names of the hosts to make it easy to write the config file
|
||||||
|
# The aliases section below contain the "actual" names of the hosts (their hostnames)
|
||||||
|
Laptop:
|
||||||
|
Desktop1:
|
||||||
|
iMac:
|
||||||
|
end
|
||||||
|
|
||||||
|
section: links
|
||||||
|
# iMac is to the right of Desktop1
|
||||||
|
# Laptop is to the left of Desktop1
|
||||||
|
Desktop1:
|
||||||
|
right(0,100) = iMac # the numbers in parentheses indicate the percentage of the computer's edge to be considered active for switching)
|
||||||
|
left = Laptop
|
||||||
|
shift = shift (shift, alt, super, meta can be mapped to any of the others)
|
||||||
|
# Desktop1 is to the right of Laptop
|
||||||
|
Laptop:
|
||||||
|
right = Desktop1
|
||||||
|
# Desktop1 is to the left of iMac
|
||||||
|
iMac:
|
||||||
|
left = Desktop1
|
||||||
|
end
|
||||||
|
section: aliases
|
||||||
|
# The "real" name of iMac is John-Smiths-iMac-3.local.
|
||||||
|
# If we wanted we could remove this alias and instead use John-Smiths-iMac-3.local everywhere iMac is above.
|
||||||
|
# Hopefully it should be easy to see why using an alias is nicer
|
||||||
|
iMac:
|
||||||
|
John-Smiths-iMac-3.local
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Cursor Wrapping
|
||||||
|
|
||||||
|
The text config allows computers to be wrapped around. For example, with two machines (a server and a client), the mouse can go off the right of the server onto the left side of the client, then off the right side of the client back onto the left side of server. This config also uses ''Ctrl''+''Super''+(''left arrow''/''right arrow'') to switch between machines on keypress.
|
||||||
|
|
||||||
|
```
|
||||||
|
# Physical monitor arrangement, with machine names as used by Deskflow.
|
||||||
|
# +----------+----------+
|
||||||
|
# | syn-serv | syn-cli |
|
||||||
|
# | | |
|
||||||
|
# +----------+----------+
|
||||||
|
|
||||||
|
section: screens
|
||||||
|
syn-serv:
|
||||||
|
syn-cli:
|
||||||
|
end
|
||||||
|
section: links
|
||||||
|
syn-serv:
|
||||||
|
left = syn-cli # "wrapping" arrangement
|
||||||
|
right = syn-cli # "normal" arrangement
|
||||||
|
syn-cli:
|
||||||
|
left = syn-serv # "normal"
|
||||||
|
right = syn-serv # "wrapping"
|
||||||
|
end
|
||||||
|
section: options
|
||||||
|
keystroke(control+super+right) = switchInDirection(right) # Switch computers on keypress
|
||||||
|
<!-- keystroke(control+super+left) = switchInDirection(left) -->
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
### AltGr key
|
||||||
|
|
||||||
|
The following screen config allows the mapping for ''Alt'' to ''AltGr''. Although this may not work, see [https://github.com/deskflow/deskflow-core/issues/4411 bug #4411].
|
||||||
|
```
|
||||||
|
section: screens
|
||||||
|
client1:
|
||||||
|
altgr = alt # mapping to fix AltGr key not working on windows clients (e.g. @-Symbol etc.).
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
See also: the man page for ''deskflow-core''.
|
||||||
|
|
||||||
|
### Stacked Example
|
||||||
|
|
||||||
|
Stack one computer on top of another's.
|
||||||
|
|
||||||
|
```
|
||||||
|
# +-------+
|
||||||
|
# | curly |
|
||||||
|
# | |
|
||||||
|
# +-------+
|
||||||
|
# +-------+ +-------+
|
||||||
|
# | moe | | larry |
|
||||||
|
# | | | |
|
||||||
|
# +-------+ +-------+
|
||||||
|
|
||||||
|
section: screens
|
||||||
|
# three hosts named: moe, larry, and curly
|
||||||
|
moe:
|
||||||
|
larry:
|
||||||
|
curly:
|
||||||
|
end
|
||||||
|
|
||||||
|
section: links
|
||||||
|
# larry is to the right of moe and curly is above moe.
|
||||||
|
moe:
|
||||||
|
right = larry
|
||||||
|
up = curly
|
||||||
|
|
||||||
|
# moe is to the left of larry and curly is above larry.
|
||||||
|
larry:
|
||||||
|
left = moe
|
||||||
|
up = curly
|
||||||
|
|
||||||
|
# larry is below curly.
|
||||||
|
curly:
|
||||||
|
down = larry
|
||||||
|
end
|
||||||
|
|
||||||
|
section: aliases
|
||||||
|
# curly is also known as shemp
|
||||||
|
curly:
|
||||||
|
shemp
|
||||||
|
end
|
||||||
|
```
|
||||||
|
|
||||||
|
### Horizontal Example
|
||||||
|
|
||||||
|
Align all computers horizontally.
|
||||||
|
|
||||||
|
```
|
||||||
|
# +-------+ +-------+ +-------+
|
||||||
|
# | moe | | larry | | curly |
|
||||||
|
# | | | | | |
|
||||||
|
# +-------+ +-------+ +-------+
|
||||||
|
|
||||||
|
section: screens
|
||||||
|
# three hosts named: moe, larry, and curly
|
||||||
|
moe:
|
||||||
|
larry:
|
||||||
|
curly:
|
||||||
|
end
|
||||||
|
|
||||||
|
section: links
|
||||||
|
# curly is to the right of larry and moe is to the left of larry.
|
||||||
|
larry:
|
||||||
|
right = curly
|
||||||
|
left = moe
|
||||||
|
|
||||||
|
# larry is to the right of moe.
|
||||||
|
moe:
|
||||||
|
right = larry
|
||||||
|
|
||||||
|
# larry is to the left of curly.
|
||||||
|
curly:
|
||||||
|
left = larry
|
||||||
|
end
|
||||||
|
|
||||||
|
```
|
||||||
|
|
||||||
|
### Span Example
|
||||||
|
|
||||||
|
Span one computer across the two other computers.
|
||||||
|
|
||||||
|
```
|
||||||
|
# +-------+ +-------+
|
||||||
|
# | curly | | curly |
|
||||||
|
# | | | |
|
||||||
|
# +-------+ +-------+
|
||||||
|
# +-------+ +-------+
|
||||||
|
# | moe | | larry |
|
||||||
|
# | | | |
|
||||||
|
# +-------+ +-------+
|
||||||
|
|
||||||
|
section: screens
|
||||||
|
# three hosts named: moe, larry, and curly
|
||||||
|
moe:
|
||||||
|
larry:
|
||||||
|
curly:
|
||||||
|
end
|
||||||
|
|
||||||
|
section: links
|
||||||
|
# larry is to the right of moe and curly is above moe.
|
||||||
|
moe:
|
||||||
|
right = larry
|
||||||
|
up = curly
|
||||||
|
|
||||||
|
# moe is to the left of larry and curly is above larry.
|
||||||
|
larry:
|
||||||
|
left = moe
|
||||||
|
up = curly
|
||||||
|
|
||||||
|
# larry is below curly.
|
||||||
|
curly:
|
||||||
|
down = larry
|
||||||
|
end
|
||||||
|
```
|
||||||
@ -1,5 +1,3 @@
|
|||||||

|
|
||||||
|
|
||||||
**Deskflow** is a free and open source keyboard and mouse sharing app.
|
**Deskflow** is a free and open source keyboard and mouse sharing app.
|
||||||
Use the keyboard, mouse, or trackpad of one computer to control nearby computers,
|
Use the keyboard, mouse, or trackpad of one computer to control nearby computers,
|
||||||
and work seamlessly between them.
|
and work seamlessly between them.
|
||||||
@ -2,8 +2,8 @@ sonar.organization=deskflow
|
|||||||
sonar.projectKey=deskflow_deskflow
|
sonar.projectKey=deskflow_deskflow
|
||||||
sonar.sources=src/apps,src/lib
|
sonar.sources=src/apps,src/lib
|
||||||
sonar.tests=src/unittests
|
sonar.tests=src/unittests
|
||||||
sonar.exclusions=subprojects/**,build/**
|
sonar.exclusions=subprojects/**,build/**,translations/**
|
||||||
sonar.coverage.exclusions=subprojects/**,src/unittests/**,src/apps/deskflow-gui/**,src/apps/res/**
|
sonar.coverage.exclusions=subprojects/**,src/unittests/**,src/apps/deskflow-gui/**,src/apps/res/**,translations/**
|
||||||
sonar.cpd.exclusions=**/*Test*.cpp
|
sonar.cpd.exclusions=**/*Test*.cpp
|
||||||
sonar.host.url=https://sonarcloud.io
|
sonar.host.url=https://sonarcloud.io
|
||||||
sonar.cfamily.compile-commands=build/compile_commands.json
|
sonar.cfamily.compile-commands=build/compile_commands.json
|
||||||
|
|||||||
@ -1,10 +1,9 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 Deskflow Developers
|
# SPDX-FileCopyrightText: (C) 2024 Deskflow Developers
|
||||||
# SPDX-FileCopyrightText: 2012 - 2024 Symless Ltd
|
# SPDX-FileCopyrightText: (C) 2012 - 2024 Symless Ltd
|
||||||
# SPDX-FileCopyrightText: 2009 - 2012 Nick Bolton
|
# SPDX-FileCopyrightText: (C) 2009 - 2012 Nick Bolton
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
include_directories(./lib)
|
include_directories(./lib "${CMAKE_CURRENT_BINARY_DIR}/lib")
|
||||||
include_directories(${CMAKE_CURRENT_BINARY_DIR}/lib)
|
|
||||||
|
|
||||||
add_subdirectory(lib)
|
add_subdirectory(lib)
|
||||||
add_subdirectory(apps)
|
add_subdirectory(apps)
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 Deskflow Developers
|
# SPDX-FileCopyrightText: (C) 2024 Deskflow Developers
|
||||||
# SPDX-FileCopyrightText: 2012 - 2024 Symless Ltd
|
# SPDX-FileCopyrightText: (C) 2012 - 2024 Symless Ltd
|
||||||
# SPDX-FileCopyrightText: 2009 - 2012 Nick Bolton
|
# SPDX-FileCopyrightText: (C) 2009 - 2012 Nick Bolton
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
if(UNIX AND NOT APPLE)
|
if(UNIX AND NOT APPLE)
|
||||||
@ -28,18 +28,15 @@ function(generate_app_man TARGET NAME)
|
|||||||
endif()
|
endif()
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
option(BUILD_UNIFIED "Build unified binary" OFF)
|
set(WIN32_PRE_EXCLUDE_REGEXES
|
||||||
if(BUILD_UNIFIED)
|
"api-ms-win-.*"
|
||||||
add_subdirectory(deskflow-core)
|
"ext-ms-.*"
|
||||||
else()
|
"^hvsifiletrust\\.dll$"
|
||||||
add_subdirectory(deskflow-client)
|
"^icu.*\\.dll$"
|
||||||
add_subdirectory(deskflow-server)
|
)
|
||||||
endif(BUILD_UNIFIED)
|
|
||||||
|
|
||||||
## Only used on windows
|
set(WIN32_POST_EXCLUDE_REGEXES ".*system32.*")
|
||||||
add_subdirectory(deskflow-daemon)
|
|
||||||
|
|
||||||
option(BUILD_GUI "Build GUI" ON)
|
add_subdirectory(deskflow-core)
|
||||||
if(BUILD_GUI)
|
add_subdirectory(deskflow-daemon) #Only used on windows
|
||||||
add_subdirectory(deskflow-gui)
|
add_subdirectory(deskflow-gui)
|
||||||
endif(BUILD_GUI)
|
|
||||||
|
|||||||
@ -1,65 +0,0 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 - 2025 Chris Rizzitello <sithlord48@gmail.com>
|
|
||||||
# SPDX-FileCopyrightText: 2012 - 2024 Symless Ltd
|
|
||||||
# SPDX-FileCopyrightText: 2009 - 2012 Nick Bolton
|
|
||||||
# SPDX-License-Identifier: MIT
|
|
||||||
|
|
||||||
set(target ${CMAKE_PROJECT_NAME}-client)
|
|
||||||
|
|
||||||
if(WIN32)
|
|
||||||
# Generate rc file
|
|
||||||
set(EXE_DESCRIPTION "${CMAKE_PROJECT_PROPER_NAME} client application")
|
|
||||||
|
|
||||||
set(EXE_ICON "
|
|
||||||
IDI_DESKFLOW ICON DISCARDABLE \"${CMAKE_SOURCE_DIR}/src/apps/res/deskflow.ico\"
|
|
||||||
")
|
|
||||||
|
|
||||||
configure_file(${CMAKE_SOURCE_DIR}/src/apps/res/windows.rc.in ${target}.rc)
|
|
||||||
|
|
||||||
set(PLATFORM_SOURCES
|
|
||||||
${target}.exe.manifest
|
|
||||||
${PROJECT_SOURCE_DIR}/src/apps/res/deskflow.ico
|
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/${target}.rc
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_executable(${target} ${PLATFORM_SOURCES} ${target}.cpp)
|
|
||||||
|
|
||||||
target_link_libraries(
|
|
||||||
${target}
|
|
||||||
arch
|
|
||||||
base
|
|
||||||
client
|
|
||||||
io
|
|
||||||
mt
|
|
||||||
net
|
|
||||||
platform
|
|
||||||
server
|
|
||||||
app
|
|
||||||
${libs})
|
|
||||||
|
|
||||||
if(APPLE)
|
|
||||||
set_target_properties(${target} PROPERTIES
|
|
||||||
BUILD_WITH_INSTALL_RPATH TRUE
|
|
||||||
INSTALL_RPATH "@loader_path/../Libraries;@loader_path/../Frameworks"
|
|
||||||
RUNTIME_OUTPUT_DIRECTORY $<TARGET_BUNDLE_CONTENT_DIR:${CMAKE_PROJECT_PROPER_NAME}>/MacOS
|
|
||||||
)
|
|
||||||
elseif(UNIX)
|
|
||||||
install(TARGETS ${target} DESTINATION bin)
|
|
||||||
generate_app_man(${target} "${CMAKE_PROJECT_DESCRIPTION} \\(Client\\)")
|
|
||||||
elseif(WIN32)
|
|
||||||
install(
|
|
||||||
TARGETS ${target}
|
|
||||||
RUNTIME_DEPENDENCY_SET clientDeps
|
|
||||||
DESTINATION .
|
|
||||||
)
|
|
||||||
install(RUNTIME_DEPENDENCY_SET clientDeps
|
|
||||||
PRE_EXCLUDE_REGEXES
|
|
||||||
"api-ms-win-.*"
|
|
||||||
"ext-ms-.*"
|
|
||||||
"^hvsifiletrust\\.dll$"
|
|
||||||
POST_EXCLUDE_REGEXES
|
|
||||||
".*system32.*"
|
|
||||||
RUNTIME DESTINATION .
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
@ -1,40 +0,0 @@
|
|||||||
/*
|
|
||||||
* Deskflow -- mouse and keyboard sharing utility
|
|
||||||
* SPDX-FileCopyrightText: (C) 2025 Chris Rizzitello <sithlord48@gmail.com>
|
|
||||||
* SPDX-FileCopyrightText: (C) 2012 - 2016 Symless Ltd.
|
|
||||||
* SPDX-FileCopyrightText: (C) 2002 Chris Schoeneman
|
|
||||||
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "arch/Arch.h"
|
|
||||||
#include "base/EventQueue.h"
|
|
||||||
#include "base/Log.h"
|
|
||||||
#include "deskflow/ClientApp.h"
|
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
|
||||||
#include "arch/win32/ArchMiscWindows.h"
|
|
||||||
#include <QCoreApplication>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
|
||||||
{
|
|
||||||
#if SYSAPI_WIN32
|
|
||||||
// HACK to make sure settings gets the correct qApp path
|
|
||||||
QCoreApplication m(argc, argv);
|
|
||||||
m.deleteLater();
|
|
||||||
|
|
||||||
ArchMiscWindows::guardRuntimeVersion();
|
|
||||||
|
|
||||||
// record window instance for tray icon, etc
|
|
||||||
ArchMiscWindows::setInstanceWin32(GetModuleHandle(nullptr));
|
|
||||||
#endif
|
|
||||||
|
|
||||||
Arch arch;
|
|
||||||
arch.init();
|
|
||||||
|
|
||||||
Log log;
|
|
||||||
EventQueue events;
|
|
||||||
|
|
||||||
ClientApp app(&events);
|
|
||||||
return app.run(argc, argv);
|
|
||||||
}
|
|
||||||
@ -1,17 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
|
|
||||||
|
|
||||||
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
|
|
||||||
<trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
|
|
||||||
<security>
|
|
||||||
<requestedPrivileges>
|
|
||||||
<requestedExecutionLevel level="asInvoker" uiAccess="false"></requestedExecutionLevel>
|
|
||||||
</requestedPrivileges>
|
|
||||||
</security>
|
|
||||||
</trustInfo>
|
|
||||||
<application xmlns="urn:schemas-microsoft-com:asm.v3">
|
|
||||||
<windowsSettings>
|
|
||||||
<dpiAwareness xmlns="http://schemas.microsoft.com/SMI/2016/WindowsSettings">PerMonitor</dpiAwareness>
|
|
||||||
<dpiAware xmlns="http://schemas.microsoft.com/SMI/2005/WindowsSettings">true</dpiAware>
|
|
||||||
</windowsSettings>
|
|
||||||
</application>
|
|
||||||
</assembly>
|
|
||||||
@ -1,11 +1,17 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 - 2025 Chris Rizzitello <sithlord48@gmail.com>
|
# SPDX-FileCopyrightText: (C) 2024 - 2025 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
# SPDX-FileCopyrightText: 2012 - 2024 Symless Ltd
|
# SPDX-FileCopyrightText: (C) 2012 - 2024 Symless Ltd
|
||||||
# SPDX-FileCopyrightText: 2009 - 2012 Nick Bolton
|
# SPDX-FileCopyrightText: (C) 2009 - 2012 Nick Bolton
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
set(target ${CMAKE_PROJECT_NAME}-core)
|
set(target ${CMAKE_PROJECT_NAME}-core)
|
||||||
|
|
||||||
add_executable(${target} "${target}.cpp")
|
add_executable(${target}
|
||||||
|
"${target}.cpp"
|
||||||
|
CoreArgs.h
|
||||||
|
CoreArgParser.h
|
||||||
|
CoreArgParser.cpp
|
||||||
|
)
|
||||||
|
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
# Generate rc file
|
# Generate rc file
|
||||||
set(EXE_DESCRIPTION "${CMAKE_PROJECT_PROPER_NAME} combined server and client application")
|
set(EXE_DESCRIPTION "${CMAKE_PROJECT_PROPER_NAME} combined server and client application")
|
||||||
@ -32,28 +38,27 @@ target_link_libraries(
|
|||||||
app
|
app
|
||||||
${libs})
|
${libs})
|
||||||
|
|
||||||
if(APPLE)
|
install(
|
||||||
|
TARGETS ${target}
|
||||||
|
RUNTIME_DEPENDENCY_SET coreDeps
|
||||||
|
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
|
||||||
|
)
|
||||||
|
|
||||||
|
if(BUILD_OSX_BUNDLE)
|
||||||
set_target_properties(${target} PROPERTIES
|
set_target_properties(${target} PROPERTIES
|
||||||
BUILD_WITH_INSTALL_RPATH TRUE
|
BUILD_WITH_INSTALL_RPATH TRUE
|
||||||
INSTALL_RPATH "@loader_path/../Libraries;@loader_path/../Frameworks"
|
INSTALL_RPATH "@loader_path/../Libraries;@loader_path/../Frameworks"
|
||||||
RUNTIME_OUTPUT_DIRECTORY $<TARGET_BUNDLE_CONTENT_DIR:${CMAKE_PROJECT_PROPER_NAME}>/MacOS
|
RUNTIME_OUTPUT_DIRECTORY $<TARGET_BUNDLE_CONTENT_DIR:${CMAKE_PROJECT_PROPER_NAME}>/MacOS
|
||||||
)
|
)
|
||||||
elseif(UNIX)
|
if (APPLE_CODESIGN_DEV)
|
||||||
install(TARGETS ${target} DESTINATION bin)
|
configure_mac_codesign(${target})
|
||||||
generate_app_man(${target} "${CMAKE_PROJECT_DESCRIPTION}")
|
endif()
|
||||||
elseif(WIN32)
|
elseif (WIN32)
|
||||||
install(
|
|
||||||
TARGETS ${target}
|
|
||||||
RUNTIME_DEPENDENCY_SET coreDeps
|
|
||||||
DESTINATION .
|
|
||||||
)
|
|
||||||
install(RUNTIME_DEPENDENCY_SET coreDeps
|
install(RUNTIME_DEPENDENCY_SET coreDeps
|
||||||
PRE_EXCLUDE_REGEXES
|
PRE_EXCLUDE_REGEXES ${WIN32_PRE_EXCLUDE_REGEXES}
|
||||||
"api-ms-win-.*"
|
POST_EXCLUDE_REGEXES ${WIN32_POST_EXCLUDE_REGEXES}
|
||||||
"ext-ms-.*"
|
RUNTIME DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
||||||
"^hvsifiletrust\\.dll$"
|
|
||||||
POST_EXCLUDE_REGEXES
|
|
||||||
".*system32.*"
|
|
||||||
RUNTIME DESTINATION .
|
|
||||||
)
|
)
|
||||||
|
else()
|
||||||
|
generate_app_man(${target} "${CMAKE_PROJECT_DESCRIPTION}")
|
||||||
endif()
|
endif()
|
||||||
|
|||||||
104
src/apps/deskflow-core/CoreArgParser.cpp
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
/*
|
||||||
|
* Deskflow -- mouse and keyboard sharing utility
|
||||||
|
* SPDX-FileCopyrightText: (C) 2025 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
|
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "CoreArgParser.h"
|
||||||
|
#include "CoreArgs.h"
|
||||||
|
|
||||||
|
#include "common/Constants.h"
|
||||||
|
#include "common/ExitCodes.h"
|
||||||
|
#include "common/Settings.h"
|
||||||
|
#include "common/VersionInfo.h"
|
||||||
|
#include "deskflow/ProtocolTypes.h"
|
||||||
|
|
||||||
|
const QString CoreArgParser::s_headerText = QStringLiteral("%1: %2\n").arg(kCoreBinName, kDisplayVersion);
|
||||||
|
|
||||||
|
CoreArgParser::CoreArgParser(const QStringList &args)
|
||||||
|
{
|
||||||
|
m_parser.setApplicationDescription(kAppDescription);
|
||||||
|
m_parser.addPositionalArgument("coremode", "The mode to start in either: server or client", "coremode");
|
||||||
|
|
||||||
|
m_parser.addOptions(CoreArgs::options);
|
||||||
|
m_parser.setSingleDashWordOptionMode(QCommandLineParser::ParseAsLongOptions);
|
||||||
|
m_parser.setOptionsAfterPositionalArgumentsMode(QCommandLineParser::ParseAsOptions);
|
||||||
|
m_parser.parse(args);
|
||||||
|
|
||||||
|
m_helpText = m_parser.helpText().replace("<executable_name>", kCoreBinName);
|
||||||
|
m_helpText.replace("[options] coremode", "coremode [options]");
|
||||||
|
|
||||||
|
m_singleInstance = !m_parser.isSet(CoreArgs::multiInstanceOption);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CoreArgParser::parse()
|
||||||
|
{
|
||||||
|
auto posArgs = m_parser.positionalArguments();
|
||||||
|
if (posArgs.isEmpty()) {
|
||||||
|
showHelpText();
|
||||||
|
exit(s_exitSuccess);
|
||||||
|
}
|
||||||
|
|
||||||
|
const QString mode = posArgs.takeFirst();
|
||||||
|
m_serverMode = (mode.compare("server", Qt::CaseInsensitive) == 0);
|
||||||
|
m_clientMode = (mode.compare("client", Qt::CaseInsensitive) == 0);
|
||||||
|
|
||||||
|
if ((!m_clientMode && !m_serverMode) || mode.isEmpty()) {
|
||||||
|
showHelpText();
|
||||||
|
exit(s_exitSuccess);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (m_parser.isSet(CoreArgs::configOption)) {
|
||||||
|
Settings::setSettingsFile(m_parser.value(CoreArgs::configOption));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[[noreturn]] void CoreArgParser::showHelpText() const
|
||||||
|
{
|
||||||
|
QTextStream(stdout) << helpText();
|
||||||
|
exit(s_exitSuccess);
|
||||||
|
}
|
||||||
|
|
||||||
|
QString CoreArgParser::helpText() const
|
||||||
|
{
|
||||||
|
return QStringLiteral("%1%2").arg(s_headerText, m_helpText);
|
||||||
|
}
|
||||||
|
|
||||||
|
QString CoreArgParser::versionText() const
|
||||||
|
{
|
||||||
|
const static auto vString = QStringLiteral("%1 v%2, protocol v%3.%4\n%5\n");
|
||||||
|
return vString.arg(
|
||||||
|
kCoreBinName, kDisplayVersion, QString::number(kProtocolMajorVersion), QString::number(kProtocolMinorVersion),
|
||||||
|
kCopyright
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
QString CoreArgParser::errorText() const
|
||||||
|
{
|
||||||
|
return m_parser.errorText();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool CoreArgParser::help() const
|
||||||
|
{
|
||||||
|
return m_parser.isSet(CoreArgs::helpOption);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool CoreArgParser::version() const
|
||||||
|
{
|
||||||
|
return m_parser.isSet(CoreArgs::versionOption);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool CoreArgParser::serverMode() const
|
||||||
|
{
|
||||||
|
return m_serverMode;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool CoreArgParser::clientMode() const
|
||||||
|
{
|
||||||
|
return m_clientMode;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool CoreArgParser::singleInstanceOnly() const
|
||||||
|
{
|
||||||
|
return m_singleInstance;
|
||||||
|
}
|
||||||
46
src/apps/deskflow-core/CoreArgParser.h
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
/*
|
||||||
|
* Deskflow -- mouse and keyboard sharing utility
|
||||||
|
* SPDX-FileCopyrightText: (C) 2025 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
|
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
#include <QCommandLineParser>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief The CoreArgParser class
|
||||||
|
* This class processes the argments for the "core" app
|
||||||
|
*/
|
||||||
|
class CoreArgParser
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
* @brief CoreArgParser calling this funciton will parse apps and set the setting and version options
|
||||||
|
* For any other settings to be set you must call parse();
|
||||||
|
* @sa parse();
|
||||||
|
* @param args List of args to parse
|
||||||
|
*/
|
||||||
|
explicit CoreArgParser(const QStringList &args = {});
|
||||||
|
/**
|
||||||
|
* @brief parse
|
||||||
|
* This method will parse all options other then help and version
|
||||||
|
*/
|
||||||
|
void parse();
|
||||||
|
QString helpText() const;
|
||||||
|
QString versionText() const;
|
||||||
|
QString errorText() const;
|
||||||
|
bool help() const;
|
||||||
|
bool version() const;
|
||||||
|
bool serverMode() const;
|
||||||
|
bool clientMode() const;
|
||||||
|
bool singleInstanceOnly() const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
[[noreturn]] void showHelpText() const;
|
||||||
|
QCommandLineParser m_parser;
|
||||||
|
QString m_helpText;
|
||||||
|
bool m_clientMode = false;
|
||||||
|
bool m_serverMode = false;
|
||||||
|
bool m_singleInstance = true;
|
||||||
|
static const QString s_headerText;
|
||||||
|
};
|
||||||
24
src/apps/deskflow-core/CoreArgs.h
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
/*
|
||||||
|
* Deskflow -- mouse and keyboard sharing utility
|
||||||
|
* SPDX-FileCopyrightText: (C) 2025 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
|
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <QCommandLineOption>
|
||||||
|
/**
|
||||||
|
* @brief The CoreArgs class
|
||||||
|
* This class contains args for the CoreArgParser
|
||||||
|
*/
|
||||||
|
struct CoreArgs
|
||||||
|
{
|
||||||
|
inline static const auto helpOption = QCommandLineOption({"h", "help"}, "Display Help on the command line");
|
||||||
|
inline static const auto versionOption = QCommandLineOption({"v", "version"}, "Display version information");
|
||||||
|
inline static const auto multiInstanceOption =
|
||||||
|
QCommandLineOption("new-instance", "Skip the check for a running instance, always makes a new instance");
|
||||||
|
inline static const auto configOption =
|
||||||
|
QCommandLineOption({"s", "settings"}, "override configuration file to use", "configFile");
|
||||||
|
|
||||||
|
inline static const auto options = {helpOption, versionOption, multiInstanceOption, configOption};
|
||||||
|
};
|
||||||
@ -6,40 +6,33 @@
|
|||||||
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "CoreArgParser.h"
|
||||||
|
|
||||||
#include "arch/Arch.h"
|
#include "arch/Arch.h"
|
||||||
#include "base/EventQueue.h"
|
#include "base/EventQueue.h"
|
||||||
#include "base/Log.h"
|
#include "base/Log.h"
|
||||||
|
#include "common/Constants.h"
|
||||||
|
#include "common/ExitCodes.h"
|
||||||
#include "deskflow/ClientApp.h"
|
#include "deskflow/ClientApp.h"
|
||||||
#include "deskflow/ServerApp.h"
|
#include "deskflow/ServerApp.h"
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
#include "arch/win32/ArchMiscWindows.h"
|
#include "arch/win32/ArchMiscWindows.h"
|
||||||
#include <QCoreApplication>
|
#include <QCoreApplication>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <iostream>
|
#include <QFileInfo>
|
||||||
|
#include <QSharedMemory>
|
||||||
|
#include <QTextStream>
|
||||||
|
|
||||||
void showHelp()
|
void showHelp(const CoreArgParser &parser)
|
||||||
{
|
{
|
||||||
std::cout << "Usage: deskflow-core <server | client> [...options]" << std::endl;
|
QTextStream(stdout) << parser.helpText();
|
||||||
std::cout << "server - start as a server (deskflow-server)" << std::endl;
|
|
||||||
std::cout << "client - start as a client (deskflow-client)" << std::endl;
|
|
||||||
std::cout << "use deskflow-core <server|client> --help for more information." << std::endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool isServer(int argc, char **argv)
|
|
||||||
{
|
|
||||||
return (argc > 1 && argv[1] == std::string("server"));
|
|
||||||
}
|
|
||||||
|
|
||||||
bool isClient(int argc, char **argv)
|
|
||||||
{
|
|
||||||
return (argc > 1 && argv[1] == std::string("client"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
// HACK to make sure settings gets the correct qApp path
|
// HACK to make sure settings gets the correct qApp path
|
||||||
QCoreApplication m(argc, argv);
|
QCoreApplication m(argc, argv);
|
||||||
m.deleteLater();
|
m.deleteLater();
|
||||||
@ -51,17 +44,55 @@ int main(int argc, char **argv)
|
|||||||
arch.init();
|
arch.init();
|
||||||
|
|
||||||
Log log;
|
Log log;
|
||||||
EventQueue events;
|
|
||||||
|
|
||||||
if (isServer(argc, argv)) {
|
QStringList args;
|
||||||
ServerApp app(&events);
|
for (int i = 0; i < argc; i++)
|
||||||
return app.run(argc, argv);
|
args.append(argv[i]);
|
||||||
} else if (isClient(argc, argv)) {
|
|
||||||
ClientApp app(&events);
|
CoreArgParser parser(args);
|
||||||
return app.run(argc, argv);
|
|
||||||
} else {
|
// Print any parser errors
|
||||||
showHelp();
|
if (!parser.errorText().isEmpty()) {
|
||||||
|
QTextStream(stdout) << parser.errorText() << "\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
if (parser.help()) {
|
||||||
|
showHelp(parser);
|
||||||
|
return s_exitSuccess;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (parser.version()) {
|
||||||
|
QTextStream(stdout) << parser.versionText();
|
||||||
|
return s_exitSuccess;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Before we check any more args we need to check for a duplicate process.
|
||||||
|
// Create a shared memory segment with a unique key
|
||||||
|
// This is to prevent a new instance from running if one is already running
|
||||||
|
QSharedMemory sharedMemory(kCoreBinName);
|
||||||
|
|
||||||
|
// Attempt to attach first and detach in order to clean up stale shm chunks
|
||||||
|
// This can happen if the previous instance was killed or crashed
|
||||||
|
if (sharedMemory.attach())
|
||||||
|
sharedMemory.detach();
|
||||||
|
|
||||||
|
if (!sharedMemory.create(1) && parser.singleInstanceOnly()) {
|
||||||
|
LOG_WARN("an instance of deskflow core is already running");
|
||||||
|
return s_exitDuplicate;
|
||||||
|
}
|
||||||
|
|
||||||
|
parser.parse();
|
||||||
|
|
||||||
|
EventQueue events;
|
||||||
|
const auto processName = QFileInfo(argv[0]).fileName();
|
||||||
|
|
||||||
|
if (parser.serverMode()) {
|
||||||
|
ServerApp app(&events, processName);
|
||||||
|
return app.run();
|
||||||
|
} else if (parser.clientMode()) {
|
||||||
|
ClientApp app(&events, processName);
|
||||||
|
return app.run();
|
||||||
|
}
|
||||||
|
|
||||||
|
return s_exitSuccess;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,6 +1,6 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 Chris Rizzitello <sithlord48@gmail.com>
|
# SPDX-FileCopyrightText: (C) 2024 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
# SPDX-FileCopyrightText: 2012 - 2024 Symless Ltd
|
# SPDX-FileCopyrightText: (C) 2012 - 2024 Symless Ltd
|
||||||
# SPDX-FileCopyrightText: 2009 - 2012 Nick Bolton
|
# SPDX-FileCopyrightText: (C) 2009 - 2012 Nick Bolton
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
# Daemon is only needed on Windows for elevating processes to deal with UAC.
|
# Daemon is only needed on Windows for elevating processes to deal with UAC.
|
||||||
@ -12,7 +12,12 @@ if(WIN32)
|
|||||||
set(EXE_ICON "IDI_DESKFLOW ICON DISCARDABLE \"${CMAKE_SOURCE_DIR}/src/apps/res/deskflow.ico\"")
|
set(EXE_ICON "IDI_DESKFLOW ICON DISCARDABLE \"${CMAKE_SOURCE_DIR}/src/apps/res/deskflow.ico\"")
|
||||||
configure_file(${CMAKE_SOURCE_DIR}/src/apps/res/windows.rc.in ${target}.rc)
|
configure_file(${CMAKE_SOURCE_DIR}/src/apps/res/windows.rc.in ${target}.rc)
|
||||||
|
|
||||||
add_executable(${target} WIN32 ${target}.cpp ${CMAKE_CURRENT_BINARY_DIR}/${target}.rc)
|
add_executable(
|
||||||
|
${target} WIN32
|
||||||
|
${target}.cpp
|
||||||
|
DaemonApp.cpp
|
||||||
|
DaemonApp.h
|
||||||
|
${CMAKE_CURRENT_BINARY_DIR}/${target}.rc)
|
||||||
|
|
||||||
target_link_libraries(
|
target_link_libraries(
|
||||||
${target}
|
${target}
|
||||||
@ -29,16 +34,12 @@ if(WIN32)
|
|||||||
|
|
||||||
install(
|
install(
|
||||||
TARGETS ${target}
|
TARGETS ${target}
|
||||||
RUNTIME_DEPENDENCY_SET deamonDeps
|
RUNTIME_DEPENDENCY_SET daemonDeps
|
||||||
DESTINATION .
|
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
|
||||||
)
|
)
|
||||||
install(RUNTIME_DEPENDENCY_SET daemonDeps
|
install(RUNTIME_DEPENDENCY_SET daemonDeps
|
||||||
PRE_EXCLUDE_REGEXES
|
PRE_EXCLUDE_REGEXES ${WIN32_PRE_EXCLUDE_REGEXES}
|
||||||
"api-ms-win-.*"
|
POST_EXCLUDE_REGEXES ${WIN32_POST_EXCLUDE_REGEXES}
|
||||||
"ext-ms-.*"
|
RUNTIME DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
||||||
"^hvsifiletrust\\.dll$"
|
|
||||||
POST_EXCLUDE_REGEXES
|
|
||||||
".*system32.*"
|
|
||||||
RUNTIME DESTINATION .
|
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|||||||
@ -1,21 +1,22 @@
|
|||||||
/*
|
/*
|
||||||
* Deskflow -- mouse and keyboard sharing utility
|
* Deskflow -- mouse and keyboard sharing utility
|
||||||
|
* SPDX-FileCopyrightText: (C) 2026 Deskflow Developers
|
||||||
* SPDX-FileCopyrightText: (C) 2012 - 2025 Symless Ltd.
|
* SPDX-FileCopyrightText: (C) 2012 - 2025 Symless Ltd.
|
||||||
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "deskflow/DaemonApp.h"
|
#include "DaemonApp.h"
|
||||||
|
|
||||||
|
#include "arch/Arch.h"
|
||||||
#include "base/IEventQueue.h"
|
#include "base/IEventQueue.h"
|
||||||
#include "base/Log.h"
|
#include "base/Log.h"
|
||||||
#include "base/LogOutputters.h"
|
#include "base/LogOutputters.h"
|
||||||
|
#include "common/ExitCodes.h"
|
||||||
#include "common/Settings.h"
|
#include "common/Settings.h"
|
||||||
#include "deskflow/App.h"
|
|
||||||
#include "deskflow/ipc/DaemonIpcServer.h"
|
#include "deskflow/ipc/DaemonIpcServer.h"
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
|
#include "arch/win32/ArchDaemonWindows.h"
|
||||||
#include "arch/win32/ArchMiscWindows.h" // IWYU pragma: keep
|
|
||||||
#include "deskflow/Screen.h"
|
#include "deskflow/Screen.h"
|
||||||
#include "platform/MSWindowsDebugOutputter.h"
|
#include "platform/MSWindowsDebugOutputter.h"
|
||||||
#include "platform/MSWindowsEventQueueBuffer.h"
|
#include "platform/MSWindowsEventQueueBuffer.h"
|
||||||
@ -26,19 +27,10 @@
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <filesystem>
|
|
||||||
#include <iostream>
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
using namespace deskflow::core;
|
using namespace deskflow::core;
|
||||||
|
|
||||||
void showHelp(int argc, char **argv) // NOSONAR - CLI args
|
|
||||||
{
|
|
||||||
const auto binName = argc > 0 ? std::filesystem::path(argv[0]).filename().string() : kDaemonBinName;
|
|
||||||
std::cout << "Usage: " << binName << " [-f|--foreground] [--install] [--uninstall]" << std::endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
DaemonApp::DaemonApp(IEventQueue &events) : m_events(events)
|
DaemonApp::DaemonApp(IEventQueue &events) : m_events(events)
|
||||||
{
|
{
|
||||||
// do nothing
|
// do nothing
|
||||||
@ -71,7 +63,7 @@ void DaemonApp::applyWatchdogCommand() const
|
|||||||
{
|
{
|
||||||
LOG_DEBUG("applying watchdog command");
|
LOG_DEBUG("applying watchdog command");
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
m_pWatchdog->setProcessConfig(m_command, m_elevate);
|
m_pWatchdog->setProcessConfig(m_command, m_elevate);
|
||||||
#else
|
#else
|
||||||
LOG_ERR("applying watchdog command not implemented on this platform");
|
LOG_ERR("applying watchdog command not implemented on this platform");
|
||||||
@ -85,7 +77,7 @@ void DaemonApp::clearWatchdogCommand()
|
|||||||
// Clear the setting to prevent it from being next time the daemon starts.
|
// Clear the setting to prevent it from being next time the daemon starts.
|
||||||
setCommand("");
|
setCommand("");
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
m_pWatchdog->setProcessConfig("", false);
|
m_pWatchdog->setProcessConfig("", false);
|
||||||
#else
|
#else
|
||||||
LOG_ERR("clearing watchdog command not implemented on this platform");
|
LOG_ERR("clearing watchdog command not implemented on this platform");
|
||||||
@ -95,52 +87,30 @@ void DaemonApp::clearWatchdogCommand()
|
|||||||
void DaemonApp::clearSettings() const
|
void DaemonApp::clearSettings() const
|
||||||
{
|
{
|
||||||
LOG_INFO("clearing daemon settings");
|
LOG_INFO("clearing daemon settings");
|
||||||
Settings::setValue(Settings::Daemon::Command, QVariant());
|
Settings::setValue(Settings::Daemon::Command);
|
||||||
Settings::setValue(Settings::Daemon::Elevate, QVariant());
|
Settings::setValue(Settings::Daemon::Elevate);
|
||||||
Settings::setValue(Settings::Daemon::LogFile, QVariant());
|
Settings::setValue(Settings::Daemon::LogFile);
|
||||||
Settings::setValue(Settings::Daemon::LogLevel, QVariant());
|
Settings::setValue(Settings::Daemon::LogLevel);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DaemonApp::connectIpcServer(const ipc::DaemonIpcServer *ipcServer) const
|
void DaemonApp::connectIpcServer(const ipc::DaemonIpcServer *ipcServer) const
|
||||||
{
|
{
|
||||||
// Use direct connection as this object is on it's own thread,
|
// Use direct connection as this object is on it's own thread,
|
||||||
// and so is on a different event loop to the main Qt loop.
|
// and so is on a different event loop to the main Qt loop.
|
||||||
QObject::connect(
|
connect(ipcServer, &ipc::DaemonIpcServer::logLevelChanged, this, &DaemonApp::saveLogLevel, Qt::DirectConnection);
|
||||||
ipcServer, &ipc::DaemonIpcServer::logLevelChanged, this, &DaemonApp::saveLogLevel, //
|
connect(ipcServer, &ipc::DaemonIpcServer::elevateModeChanged, this, &DaemonApp::setElevate, Qt::DirectConnection);
|
||||||
|
connect(ipcServer, &ipc::DaemonIpcServer::commandChanged, this, &DaemonApp::setCommand, Qt::DirectConnection);
|
||||||
|
connect(
|
||||||
|
ipcServer, &ipc::DaemonIpcServer::startProcessRequested, this, &DaemonApp::applyWatchdogCommand,
|
||||||
Qt::DirectConnection
|
Qt::DirectConnection
|
||||||
);
|
);
|
||||||
QObject::connect(
|
connect(
|
||||||
ipcServer, &ipc::DaemonIpcServer::elevateModeChanged, this, &DaemonApp::setElevate, //
|
ipcServer, &ipc::DaemonIpcServer::stopProcessRequested, this, &DaemonApp::clearWatchdogCommand,
|
||||||
Qt::DirectConnection
|
Qt::DirectConnection
|
||||||
);
|
);
|
||||||
QObject::connect(
|
connect(
|
||||||
ipcServer, &ipc::DaemonIpcServer::commandChanged, this, &DaemonApp::setCommand, //
|
ipcServer, &ipc::DaemonIpcServer::clearSettingsRequested, this, &DaemonApp::clearSettings, Qt::DirectConnection
|
||||||
Qt::DirectConnection
|
|
||||||
);
|
);
|
||||||
QObject::connect(
|
|
||||||
ipcServer, &ipc::DaemonIpcServer::startProcessRequested, this, &DaemonApp::applyWatchdogCommand, //
|
|
||||||
Qt::DirectConnection
|
|
||||||
);
|
|
||||||
QObject::connect(
|
|
||||||
ipcServer, &ipc::DaemonIpcServer::stopProcessRequested, this, &DaemonApp::clearWatchdogCommand, //
|
|
||||||
Qt::DirectConnection
|
|
||||||
);
|
|
||||||
QObject::connect(
|
|
||||||
ipcServer, &ipc::DaemonIpcServer::clearSettingsRequested, this, &DaemonApp::clearSettings, //
|
|
||||||
Qt::DirectConnection
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
void DaemonApp::install() const
|
|
||||||
{
|
|
||||||
LOG_NOTE("installing windows daemon");
|
|
||||||
ARCH->installDaemon();
|
|
||||||
}
|
|
||||||
|
|
||||||
void DaemonApp::uninstall() const
|
|
||||||
{
|
|
||||||
LOG_NOTE("uninstalling windows daemon");
|
|
||||||
ARCH->uninstallDaemon();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void DaemonApp::run(QThread &daemonThread)
|
void DaemonApp::run(QThread &daemonThread)
|
||||||
@ -151,7 +121,7 @@ void DaemonApp::run(QThread &daemonThread)
|
|||||||
// owned by the daemon app, as they will be created on the daemon thread.
|
// owned by the daemon app, as they will be created on the daemon thread.
|
||||||
moveToThread(&daemonThread);
|
moveToThread(&daemonThread);
|
||||||
|
|
||||||
QObject::connect(&daemonThread, &QThread::started, [this, &daemonThread]() {
|
connect(&daemonThread, &QThread::started, this, [this, &daemonThread]() {
|
||||||
LOG_DEBUG("daemon thread started");
|
LOG_DEBUG("daemon thread started");
|
||||||
|
|
||||||
if (m_foreground) {
|
if (m_foreground) {
|
||||||
@ -159,14 +129,14 @@ void DaemonApp::run(QThread &daemonThread)
|
|||||||
mainLoop();
|
mainLoop();
|
||||||
} else {
|
} else {
|
||||||
LOG_DEBUG("running daemon in background (daemonizing)");
|
LOG_DEBUG("running daemon in background (daemonizing)");
|
||||||
ARCH->daemonize(kAppName, [this](int, const char **) { return daemonLoop(); });
|
ARCH->daemonize([this] { return daemonLoop(); });
|
||||||
}
|
}
|
||||||
|
|
||||||
daemonThread.quit();
|
daemonThread.quit();
|
||||||
LOG_DEBUG("daemon thread finished");
|
LOG_DEBUG("daemon thread finished");
|
||||||
});
|
});
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
m_pWatchdog = std::make_unique<MSWindowsWatchdog>(m_foreground, *m_pFileLogOutputter);
|
m_pWatchdog = std::make_unique<MSWindowsWatchdog>(m_foreground, *m_pFileLogOutputter);
|
||||||
|
|
||||||
auto command = Settings::value(Settings::Daemon::Command).toString().toStdString();
|
auto command = Settings::value(Settings::Daemon::Command).toString().toStdString();
|
||||||
@ -183,27 +153,26 @@ void DaemonApp::run(QThread &daemonThread)
|
|||||||
|
|
||||||
int DaemonApp::daemonLoop()
|
int DaemonApp::daemonLoop()
|
||||||
{
|
{
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
// Runs the daemon through the Windows service controller, which controls the program lifecycle.
|
// Runs the daemon through the Windows service controller, which controls the program lifecycle.
|
||||||
return ArchMiscWindows::runDaemon([this]() { return mainLoop(); });
|
return ArchDaemonWindows::runDaemon([this]() { return mainLoop(); });
|
||||||
#elif SYSAPI_UNIX
|
#else
|
||||||
return mainLoop();
|
return mainLoop();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
int DaemonApp::mainLoop()
|
int DaemonApp::mainLoop()
|
||||||
{
|
{
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
if (m_pWatchdog == nullptr) {
|
if (m_pWatchdog == nullptr) {
|
||||||
LOG_ERR("watchdog not initialized");
|
LOG_ERR("watchdog not initialized");
|
||||||
return s_exitFailed;
|
return s_exitFailed;
|
||||||
}
|
}
|
||||||
|
ArchDaemonWindows::daemonRunning(true);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
DAEMON_RUNNING(true);
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
// Install the platform event queue to handle service stop events.
|
// Install the platform event queue to handle service stop events.
|
||||||
// This must be done on the same thread as the event loop, otherwise the service stop
|
// This must be done on the same thread as the event loop, otherwise the service stop
|
||||||
// request will not add the quit event to the event queue, and the service won't stop.
|
// request will not add the quit event to the event queue, and the service won't stop.
|
||||||
@ -216,25 +185,25 @@ int DaemonApp::mainLoop()
|
|||||||
LOG_INFO("daemon is running");
|
LOG_INFO("daemon is running");
|
||||||
m_events.loop();
|
m_events.loop();
|
||||||
} catch (std::exception &e) { // NOSONAR - Catching all exceptions
|
} catch (std::exception &e) { // NOSONAR - Catching all exceptions
|
||||||
LOG((CLOG_CRIT "daemon error: %s", e.what()));
|
LOG_CRIT("daemon error: %s", e.what());
|
||||||
} catch (...) { // NOSONAR - Catching remaining exceptions
|
} catch (...) { // NOSONAR - Catching remaining exceptions
|
||||||
LOG((CLOG_CRIT "daemon unknown error"));
|
LOG_CRIT("daemon unknown error");
|
||||||
}
|
}
|
||||||
|
|
||||||
LOG_INFO("daemon is stopping");
|
LOG_INFO("daemon is stopping");
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
try {
|
try {
|
||||||
LOG_DEBUG("stopping process watchdog");
|
LOG_DEBUG("stopping process watchdog");
|
||||||
m_pWatchdog->stop();
|
m_pWatchdog->stop();
|
||||||
} catch (std::exception &e) { // NOSONAR - Catching all exceptions
|
} catch (std::exception &e) { // NOSONAR - Catching all exceptions
|
||||||
LOG((CLOG_CRIT "daemon stop watchdog error: %s", e.what()));
|
LOG_CRIT("daemon stop watchdog error: %s", e.what());
|
||||||
} catch (...) { // NOSONAR - Catching remaining exceptions
|
} catch (...) { // NOSONAR - Catching remaining exceptions
|
||||||
LOG((CLOG_CRIT "daemon stop watchdog unknown error"));
|
LOG_CRIT("daemon stop watchdog unknown error");
|
||||||
}
|
}
|
||||||
|
ArchDaemonWindows::daemonRunning(false);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
DAEMON_RUNNING(false);
|
|
||||||
return s_exitSuccess;
|
return s_exitSuccess;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -251,7 +220,7 @@ void DaemonApp::setForeground()
|
|||||||
|
|
||||||
void DaemonApp::initLogging()
|
void DaemonApp::initLogging()
|
||||||
{
|
{
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
if (!m_foreground) {
|
if (!m_foreground) {
|
||||||
// Only use MS debug outputter when the process is daemonized, since stdout won't be accessible
|
// Only use MS debug outputter when the process is daemonized, since stdout won't be accessible
|
||||||
// in that case, but is accessible when running in the foreground.
|
// in that case, but is accessible when running in the foreground.
|
||||||
@ -259,13 +228,13 @@ void DaemonApp::initLogging()
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
m_pFileLogOutputter = new FileLogOutputter(logFilename().toStdString().c_str()); // NOSONAR - Adopted by `Log`
|
m_pFileLogOutputter = new FileLogOutputter(qPrintable(logFilename())); // NOSONAR - Adopted by `Log`
|
||||||
CLOG->insert(m_pFileLogOutputter);
|
CLOG->insert(m_pFileLogOutputter);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DaemonApp::showConsole()
|
void DaemonApp::showConsole()
|
||||||
{
|
{
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
// The daemon bin is compiled using the Win32 subsystem which works best for Windows services,
|
// The daemon bin is compiled using the Win32 subsystem which works best for Windows services,
|
||||||
// so when running as a foreground process we need to allocate a console (or we won't see output).
|
// so when running as a foreground process we need to allocate a console (or we won't see output).
|
||||||
// It is important to do this inside the arg check loop so that we can attach console ahead
|
// It is important to do this inside the arg check loop so that we can attach console ahead
|
||||||
@ -6,8 +6,6 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "common/Common.h"
|
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
@ -23,7 +21,7 @@ namespace deskflow::core::ipc {
|
|||||||
class DaemonIpcServer;
|
class DaemonIpcServer;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
class MSWindowsWatchdog;
|
class MSWindowsWatchdog;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -34,22 +32,9 @@ class DaemonApp : public QObject
|
|||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
public:
|
public:
|
||||||
enum class InitResult
|
|
||||||
{
|
|
||||||
Installed,
|
|
||||||
Uninstalled,
|
|
||||||
StartDaemon,
|
|
||||||
ShowHelp,
|
|
||||||
ArgsError,
|
|
||||||
FatalError,
|
|
||||||
};
|
|
||||||
|
|
||||||
explicit DaemonApp(IEventQueue &events);
|
explicit DaemonApp(IEventQueue &events);
|
||||||
~DaemonApp() override;
|
~DaemonApp() override;
|
||||||
|
|
||||||
InitResult init(int argc, char **argv);
|
|
||||||
void install() const;
|
|
||||||
void uninstall() const;
|
|
||||||
void run(QThread &daemonThread);
|
void run(QThread &daemonThread);
|
||||||
void setForeground();
|
void setForeground();
|
||||||
void initLogging();
|
void initLogging();
|
||||||
@ -71,7 +56,7 @@ private:
|
|||||||
|
|
||||||
static void showConsole();
|
static void showConsole();
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
std::unique_ptr<MSWindowsWatchdog> m_pWatchdog;
|
std::unique_ptr<MSWindowsWatchdog> m_pWatchdog;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -5,21 +5,21 @@
|
|||||||
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "VersionInfo.h"
|
#include "DaemonApp.h"
|
||||||
|
|
||||||
#include "arch/Arch.h"
|
#include "arch/Arch.h"
|
||||||
#include "base/EventQueue.h"
|
#include "base/EventQueue.h"
|
||||||
#include "base/Log.h"
|
#include "base/Log.h"
|
||||||
|
#include "common/ExitCodes.h"
|
||||||
#include "common/Settings.h"
|
#include "common/Settings.h"
|
||||||
#include "deskflow/DaemonApp.h"
|
#include "common/VersionInfo.h"
|
||||||
#include "deskflow/ipc/DaemonIpcServer.h"
|
#include "deskflow/ipc/DaemonIpcServer.h"
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
|
|
||||||
#include "arch/win32/ArchMiscWindows.h"
|
#include "arch/win32/ArchMiscWindows.h"
|
||||||
|
|
||||||
#define WIN32_LEAN_AND_MEAN
|
#define WIN32_LEAN_AND_MEAN
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <QCommandLineParser>
|
#include <QCommandLineParser>
|
||||||
@ -32,7 +32,7 @@ void handleError(const char *message = "Unrecognized error.");
|
|||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
ArchMiscWindows::guardRuntimeVersion();
|
ArchMiscWindows::guardRuntimeVersion();
|
||||||
|
|
||||||
// Save window instance for later use, e.g. `GetModuleFileName` which is used when installing the daemon.
|
// Save window instance for later use, e.g. `GetModuleFileName` which is used when installing the daemon.
|
||||||
@ -58,12 +58,6 @@ int main(int argc, char **argv)
|
|||||||
const auto foregroundOption = QCommandLineOption({"f", "foreground"}, "Run in the foreground (show console)");
|
const auto foregroundOption = QCommandLineOption({"f", "foreground"}, "Run in the foreground (show console)");
|
||||||
parser.addOption(foregroundOption);
|
parser.addOption(foregroundOption);
|
||||||
|
|
||||||
const auto installOption = QCommandLineOption({"i", "install"}, "Install as a Windows service");
|
|
||||||
parser.addOption(installOption);
|
|
||||||
|
|
||||||
const auto uninstallOption = QCommandLineOption({"u", "uninstall"}, "Uninstall the Windows service");
|
|
||||||
parser.addOption(uninstallOption);
|
|
||||||
|
|
||||||
parser.process(app);
|
parser.process(app);
|
||||||
|
|
||||||
if (parser.isSet(foregroundOption)) {
|
if (parser.isSet(foregroundOption)) {
|
||||||
@ -78,34 +72,25 @@ int main(int argc, char **argv)
|
|||||||
// useful for troubleshooting Windows services.
|
// useful for troubleshooting Windows services.
|
||||||
// It's important to write the version number to the log file so we can be certain the old daemon
|
// It's important to write the version number to the log file so we can be certain the old daemon
|
||||||
// was uninstalled, since sometimes Windows services can get stuck and fail to be removed.
|
// was uninstalled, since sometimes Windows services can get stuck and fail to be removed.
|
||||||
LOG_PRINT("%s v%s", QCoreApplication::applicationName().toStdString().c_str(), kDisplayVersion);
|
LOG_PRINT("%s v%s", qPrintable(QCoreApplication::applicationName()), kDisplayVersion);
|
||||||
|
|
||||||
// Default log level to system setting (found in Registry).
|
// Default log level to system setting (found in Registry).
|
||||||
auto logLevel = Settings::value(Settings::Daemon::LogLevel).toString().toStdString();
|
auto logLevel = Settings::value(Settings::Daemon::LogLevel).toString().toStdString();
|
||||||
if (logLevel != "") {
|
if (!logLevel.empty()) {
|
||||||
CLOG->setFilter(logLevel.c_str());
|
CLOG->setFilter(logLevel.c_str());
|
||||||
LOG_DEBUG("log level: %s", logLevel.c_str());
|
LOG_DEBUG("log level: %s", logLevel.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
// Show warning if not running as admin as daemon will behave differently.
|
// Show warning if not running as admin as daemon will behave differently.
|
||||||
if (!ArchMiscWindows::isProcessElevated()) {
|
if (!ArchMiscWindows::isProcessElevated()) {
|
||||||
LOG_WARN("not running as admin, some features may not work");
|
LOG_WARN("not running as admin, some features may not work");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (parser.isSet(installOption)) {
|
const auto ipcServer = new ipc::DaemonIpcServer(&app, qPrintable(DaemonApp::logFilename())); // NOSONAR - Qt managed
|
||||||
daemon.install();
|
|
||||||
return s_exitSuccess;
|
|
||||||
} else if (parser.isSet(uninstallOption)) {
|
|
||||||
daemon.uninstall();
|
|
||||||
return s_exitSuccess;
|
|
||||||
}
|
|
||||||
|
|
||||||
const auto ipcServer =
|
|
||||||
new ipc::DaemonIpcServer(&app, DaemonApp::logFilename().toStdString().c_str()); // NOSONAR - Qt managed
|
|
||||||
ipcServer->listen();
|
ipcServer->listen();
|
||||||
daemon.connectIpcServer(ipcServer);
|
daemon.connectIpcServer(ipcServer);
|
||||||
|
|
||||||
@ -128,8 +113,7 @@ int main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
|
|
||||||
// Win32 subsystem entry point (simply forwards to main).
|
// Win32 subsystem entry point (simply forwards to main).
|
||||||
// We need this because using regular main under the Win32 subsystem results in empty args.
|
// We need this because using regular main under the Win32 subsystem results in empty args.
|
||||||
int WINAPI WinMain(HINSTANCE, HINSTANCE, LPSTR, int)
|
int WINAPI WinMain(HINSTANCE, HINSTANCE, LPSTR, int)
|
||||||
@ -144,7 +128,7 @@ void handleError(const char *message)
|
|||||||
// Always print error to stdout in case run as CLI program.
|
// Always print error to stdout in case run as CLI program.
|
||||||
LOG_ERR("%s", message);
|
LOG_ERR("%s", message);
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
#if defined(Q_OS_WIN)
|
||||||
// Show a message box for when run from MSI in Win32 subsystem.
|
// Show a message box for when run from MSI in Win32 subsystem.
|
||||||
MessageBoxA(nullptr, message, "Deskflow daemon error", MB_OK | MB_ICONERROR);
|
MessageBoxA(nullptr, message, "Deskflow daemon error", MB_OK | MB_ICONERROR);
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 - 2025 Chris Rizzitello <sithlord48@gmail.com>
|
# SPDX-FileCopyrightText: (C) 2024 - 2025 Chris Rizzitello <sithlord48@gmail.com>
|
||||||
# SPDX-FileCopyrightText: 2024 Symless Ltd
|
# SPDX-FileCopyrightText: (C) 2024 Symless Ltd
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
@ -15,12 +15,12 @@ if(WIN32)
|
|||||||
set(EXE_ICON "IDI_ICON1 ICON DISCARDABLE \"${CMAKE_SOURCE_DIR}/src/apps/res/deskflow.ico\" ")
|
set(EXE_ICON "IDI_ICON1 ICON DISCARDABLE \"${CMAKE_SOURCE_DIR}/src/apps/res/deskflow.ico\" ")
|
||||||
configure_file(${CMAKE_SOURCE_DIR}/src/apps/res/windows.rc.in deskflow.rc)
|
configure_file(${CMAKE_SOURCE_DIR}/src/apps/res/windows.rc.in deskflow.rc)
|
||||||
set(platform_extra deskflow.rc)
|
set(platform_extra deskflow.rc)
|
||||||
elseif(APPLE)
|
elseif(BUILD_OSX_BUNDLE)
|
||||||
#setup our bundle plist file
|
#setup our bundle plist file
|
||||||
set(BUNDLE_EXECUTABLE_NAME "${target}")
|
set(BUNDLE_EXECUTABLE_NAME "${target}")
|
||||||
set(BUNDLE_BUNDLE_NAME "${target}")
|
set(BUNDLE_BUNDLE_NAME "${target}")
|
||||||
set(BUNDLE_DISPLAY_NAME "${target}")
|
set(BUNDLE_DISPLAY_NAME "${target}")
|
||||||
set(BUNDLE_GUI_IDENTIFIER "org.deskflow.deskflow")
|
set(BUNDLE_GUI_IDENTIFIER "${CMAKE_PROJECT_REV_FQDN}")
|
||||||
set(BUNDLE_ICON_FILE ${target}.icns)
|
set(BUNDLE_ICON_FILE ${target}.icns)
|
||||||
set(BUNDLE_INFO_STRING "${CMAKE_PROJECT_DESCRIPTION}")
|
set(BUNDLE_INFO_STRING "${CMAKE_PROJECT_DESCRIPTION}")
|
||||||
set(BUNDLE_COPYRIGHT "${CMAKE_PROJECT_COPYRIGHT}")
|
set(BUNDLE_COPYRIGHT "${CMAKE_PROJECT_COPYRIGHT}")
|
||||||
@ -31,13 +31,7 @@ elseif(APPLE)
|
|||||||
@ONLY
|
@ONLY
|
||||||
)
|
)
|
||||||
|
|
||||||
file(COPY_FILE
|
set(platform_extra ../res/Deskflow.icns)
|
||||||
${PROJECT_SOURCE_DIR}/LICENSES/LicenseRef-OpenSSL-Exception.txt
|
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/LICENSE_EXCEPTION
|
|
||||||
ONLY_IF_DIFFERENT
|
|
||||||
)
|
|
||||||
|
|
||||||
set(platform_extra ../res/Deskflow.icns ${CMAKE_SOURCE_DIR}/LICENSE ${CMAKE_CURRENT_BINARY_DIR}/LICENSE_EXCEPTION)
|
|
||||||
set_source_files_properties(${platform_extra} PROPERTIES MACOSX_PACKAGE_LOCATION "Resources")
|
set_source_files_properties(${platform_extra} PROPERTIES MACOSX_PACKAGE_LOCATION "Resources")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
@ -55,21 +49,20 @@ target_link_libraries(
|
|||||||
Qt6::Widgets
|
Qt6::Widgets
|
||||||
Qt6::Network)
|
Qt6::Network)
|
||||||
|
|
||||||
|
install(
|
||||||
|
TARGETS ${target}
|
||||||
|
RUNTIME_DEPENDENCY_SET guiDeps
|
||||||
|
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
|
||||||
|
BUNDLE DESTINATION .
|
||||||
|
)
|
||||||
|
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
set_target_properties(${target} PROPERTIES LINK_FLAGS "/NODEFAULTLIB:LIBCMT")
|
set_target_properties(${target} PROPERTIES LINK_FLAGS "/NODEFAULTLIB:LIBCMT")
|
||||||
install(
|
|
||||||
TARGETS ${target}
|
|
||||||
RUNTIME_DEPENDENCY_SET guiDeps
|
|
||||||
DESTINATION .
|
|
||||||
)
|
|
||||||
install(RUNTIME_DEPENDENCY_SET guiDeps
|
install(RUNTIME_DEPENDENCY_SET guiDeps
|
||||||
PRE_EXCLUDE_REGEXES
|
PRE_EXCLUDE_REGEXES ${WIN32_PRE_EXCLUDE_REGEXES}
|
||||||
"api-ms-win-.*"
|
POST_EXCLUDE_REGEXES ${WIN32_POST_EXCLUDE_REGEXES}
|
||||||
"ext-ms-.*"
|
RUNTIME DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
||||||
"^hvsifiletrust\\.dll$"
|
|
||||||
POST_EXCLUDE_REGEXES
|
|
||||||
".*system32.*"
|
|
||||||
RUNTIME DESTINATION .
|
|
||||||
)
|
)
|
||||||
|
|
||||||
set(QT_DEPENDS_DIR ${CMAKE_BINARY_DIR}/qt-depends)
|
set(QT_DEPENDS_DIR ${CMAKE_BINARY_DIR}/qt-depends)
|
||||||
@ -91,17 +84,23 @@ if(WIN32)
|
|||||||
|
|
||||||
install(
|
install(
|
||||||
DIRECTORY ${QT_DEPENDS_DIR}/
|
DIRECTORY ${QT_DEPENDS_DIR}/
|
||||||
DESTINATION .
|
DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
||||||
PATTERN "dx*.dll" EXCLUDE
|
PATTERN "dx*.dll" EXCLUDE
|
||||||
|
PATTERN "icu*.dll" EXCLUDE
|
||||||
)
|
)
|
||||||
|
|
||||||
elseif(APPLE)
|
elseif(APPLE)
|
||||||
set_target_properties(${target} PROPERTIES
|
if (BUILD_OSX_BUNDLE)
|
||||||
INSTALL_RPATH "@loader_path/../Libraries;@loader_path/../Frameworks"
|
set_target_properties(${target} PROPERTIES
|
||||||
MACOSX_BUNDLE_INFO_PLIST "${CMAKE_CURRENT_BINARY_DIR}/deskflow.plist"
|
INSTALL_RPATH "@loader_path/../Libraries;@loader_path/../Frameworks"
|
||||||
)
|
MACOSX_BUNDLE_INFO_PLIST "${CMAKE_CURRENT_BINARY_DIR}/deskflow.plist"
|
||||||
install(TARGETS ${target} BUNDLE DESTINATION .)
|
)
|
||||||
|
if (APPLE_CODESIGN_DEV)
|
||||||
|
configure_mac_codesign(${target})
|
||||||
|
endif()
|
||||||
|
else()
|
||||||
|
set_target_properties(${target} PROPERTIES MACOSX_BUNDLE FALSE)
|
||||||
|
endif()
|
||||||
else()
|
else()
|
||||||
install(TARGETS ${target} DESTINATION bin)
|
|
||||||
generate_app_man(${target} "${CMAKE_PROJECT_DESCRIPTION} \\(GUI\\)")
|
generate_app_man(${target} "${CMAKE_PROJECT_DESCRIPTION} \\(GUI\\)")
|
||||||
endif()
|
endif()
|
||||||
|
|||||||
@ -6,12 +6,13 @@
|
|||||||
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "VersionInfo.h"
|
|
||||||
#include "common/Constants.h"
|
#include "common/Constants.h"
|
||||||
|
#include "common/ExitCodes.h"
|
||||||
|
#include "common/I18N.h"
|
||||||
|
#include "common/PlatformInfo.h"
|
||||||
#include "common/UrlConstants.h"
|
#include "common/UrlConstants.h"
|
||||||
|
#include "common/VersionInfo.h"
|
||||||
#include "gui/Diagnostic.h"
|
#include "gui/Diagnostic.h"
|
||||||
#include "gui/DotEnv.h"
|
|
||||||
#include "gui/Logger.h"
|
|
||||||
#include "gui/MainWindow.h"
|
#include "gui/MainWindow.h"
|
||||||
#include "gui/Messages.h"
|
#include "gui/Messages.h"
|
||||||
#include "gui/StyleUtils.h"
|
#include "gui/StyleUtils.h"
|
||||||
@ -22,7 +23,7 @@
|
|||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QSharedMemory>
|
#include <QSharedMemory>
|
||||||
|
|
||||||
#if defined(Q_OS_MAC)
|
#if defined(Q_OS_MACOS)
|
||||||
#include <Carbon/Carbon.h>
|
#include <Carbon/Carbon.h>
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
#endif
|
#endif
|
||||||
@ -31,9 +32,13 @@
|
|||||||
#include <QLoggingCategory>
|
#include <QLoggingCategory>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if !defined(Q_OS_MAC) && !defined(Q_OS_WIN)
|
||||||
|
#include "platform/XDGPortalRegistry.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
using namespace deskflow::gui;
|
using namespace deskflow::gui;
|
||||||
|
|
||||||
#if defined(Q_OS_MAC)
|
#if defined(Q_OS_MACOS)
|
||||||
bool checkMacAssistiveDevices();
|
bool checkMacAssistiveDevices();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -46,14 +51,21 @@ int main(int argc, char *argv[])
|
|||||||
QLoggingCategory::setFilterRules(QStringLiteral("*.debug=true\nqt.*=false"));
|
QLoggingCategory::setFilterRules(QStringLiteral("*.debug=true\nqt.*=false"));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if !defined(Q_OS_MAC) && !defined(Q_OS_WIN)
|
||||||
|
deskflow::platform::setAppId();
|
||||||
|
#endif
|
||||||
|
|
||||||
QCoreApplication::setApplicationName(kAppName);
|
QCoreApplication::setApplicationName(kAppName);
|
||||||
QCoreApplication::setOrganizationName(kAppName);
|
QCoreApplication::setOrganizationName(kAppName);
|
||||||
QCoreApplication::setApplicationVersion(kVersion);
|
QCoreApplication::setApplicationVersion(kVersion);
|
||||||
QCoreApplication::setOrganizationDomain(kOrgDomain); // used in prefix, can't be a url
|
QCoreApplication::setOrganizationDomain(kOrgDomain); // used in prefix, can't be a url
|
||||||
QGuiApplication::setDesktopFileName(QStringLiteral("org.deskflow.deskflow"));
|
QGuiApplication::setDesktopFileName(kRevFqdnName);
|
||||||
|
|
||||||
QApplication app(argc, argv);
|
QApplication app(argc, argv);
|
||||||
|
|
||||||
|
// Ensure the I18N object is made before strings
|
||||||
|
QTextStream(stdout) << "initial language: " << I18N::currentLanguage() << '\n';
|
||||||
|
|
||||||
// Add Command Line Options
|
// Add Command Line Options
|
||||||
auto helpOption = QCommandLineOption({"h", "help"}, "Display Help on the command line");
|
auto helpOption = QCommandLineOption({"h", "help"}, "Display Help on the command line");
|
||||||
auto versionOption = QCommandLineOption({"v", "version"}, "Display version information");
|
auto versionOption = QCommandLineOption({"v", "version"}, "Display version information");
|
||||||
@ -68,23 +80,24 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
if (!parser.errorText().isEmpty()) {
|
if (!parser.errorText().isEmpty()) {
|
||||||
qCritical().noquote() << parser.errorText() << "\nUse --help for more information.";
|
qCritical().noquote() << parser.errorText() << "\nUse --help for more information.";
|
||||||
return 1;
|
return s_exitArgs;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (parser.isSet(helpOption)) {
|
if (parser.isSet(helpOption)) {
|
||||||
QTextStream(stdout) << kHeader << QStringLiteral(" %1\n\n").arg(kAppDescription)
|
QTextStream(stdout) << kHeader << QStringLiteral(" %1\n\n").arg(kAppDescription)
|
||||||
<< parser.helpText().replace(QApplication::applicationFilePath(), kAppId);
|
<< parser.helpText().replace(QApplication::applicationFilePath(), kAppId);
|
||||||
return 0;
|
return s_exitSuccess;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (parser.isSet(versionOption)) {
|
if (parser.isSet(versionOption)) {
|
||||||
QTextStream(stdout) << kHeader << kCopyright << Qt::endl;
|
QTextStream(stdout) << kHeader << kCopyright << Qt::endl;
|
||||||
return 0;
|
return s_exitSuccess;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const auto shmId = QStringLiteral("%1-gui").arg(kAppId);
|
||||||
// Create a shared memory segment with a unique key
|
// Create a shared memory segment with a unique key
|
||||||
// This is to prevent a new instance from running if one is already running
|
// This is to prevent a new instance from running if one is already running
|
||||||
QSharedMemory sharedMemory("deskflow-gui");
|
QSharedMemory sharedMemory(shmId);
|
||||||
|
|
||||||
// Attempt to attach first and detach in order to clean up stale shm chunks
|
// Attempt to attach first and detach in order to clean up stale shm chunks
|
||||||
// This can happen if the previous instance was killed or crashed
|
// This can happen if the previous instance was killed or crashed
|
||||||
@ -95,38 +108,27 @@ int main(int argc, char *argv[])
|
|||||||
if (!sharedMemory.create(1)) {
|
if (!sharedMemory.create(1)) {
|
||||||
// Ping the running instance to have it show itself
|
// Ping the running instance to have it show itself
|
||||||
QLocalSocket socket;
|
QLocalSocket socket;
|
||||||
socket.connectToServer("deskflow-gui", QLocalSocket::ReadOnly);
|
socket.connectToServer(shmId, QLocalSocket::ReadOnly);
|
||||||
if (!socket.waitForConnected()) {
|
if (!socket.waitForConnected()) {
|
||||||
// If we can't connect to the other instance tell the user its running.
|
// If we can't connect to the other instance tell the user its running.
|
||||||
// This should never happen but just incase we should show something
|
// This should never happen but just incase we should show something
|
||||||
QMessageBox::information(nullptr, QObject::tr("Deskflow"), QObject::tr("Deskflow is already running"));
|
QMessageBox::information(nullptr, kAppName, QObject::tr("%1 is already running").arg(kAppName));
|
||||||
}
|
}
|
||||||
socket.disconnectFromServer();
|
socket.disconnectFromServer();
|
||||||
return 0;
|
return s_exitDuplicate;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !defined(Q_OS_MAC)
|
if (!deskflow::platform::isMac() && qEnvironmentVariable("XDG_CURRENT_DESKTOP") != QLatin1String("KDE")) {
|
||||||
// causes dark mode to be used on some DE's
|
|
||||||
if (qEnvironmentVariable("XDG_CURRENT_DESKTOP") != QLatin1String("KDE")) {
|
|
||||||
QApplication::setStyle("fusion");
|
QApplication::setStyle("fusion");
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
// Sets the fallback icon path and fallback theme
|
// Sets the fallback icon path and fallback theme
|
||||||
const auto themeName = QStringLiteral("deskflow-%1").arg(iconMode());
|
updateIconTheme();
|
||||||
if (QIcon::themeName().isEmpty())
|
|
||||||
QIcon::setThemeName(themeName);
|
|
||||||
else
|
|
||||||
QIcon::setFallbackThemeName(themeName);
|
|
||||||
QIcon::setFallbackSearchPaths({QStringLiteral(":/icons/%1").arg(themeName)});
|
|
||||||
|
|
||||||
qInstallMessageHandler(deskflow::gui::messages::messageHandler);
|
qInstallMessageHandler(deskflow::gui::messages::messageHandler);
|
||||||
qInfo("%s v%s", kAppName, qPrintable(kVersion));
|
qInfo("%s v%s", kAppName, kDisplayVersion);
|
||||||
|
|
||||||
dotenv();
|
#if defined(Q_OS_MACOS)
|
||||||
Logger::instance().loadEnvVars();
|
|
||||||
|
|
||||||
#if defined(Q_OS_MAC)
|
|
||||||
|
|
||||||
if (app.applicationDirPath().startsWith("/Volumes/")) {
|
if (app.applicationDirPath().startsWith("/Volumes/")) {
|
||||||
QString msgBody = QStringLiteral(
|
QString msgBody = QStringLiteral(
|
||||||
@ -153,7 +155,7 @@ int main(int argc, char *argv[])
|
|||||||
return QApplication::exec();
|
return QApplication::exec();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(Q_OS_MAC)
|
#if defined(Q_OS_MACOS)
|
||||||
bool checkMacAssistiveDevices()
|
bool checkMacAssistiveDevices()
|
||||||
{
|
{
|
||||||
// new in mavericks, applications are trusted individually
|
// new in mavericks, applications are trusted individually
|
||||||
|
|||||||
@ -1,64 +0,0 @@
|
|||||||
# SPDX-FileCopyrightText: 2024 - 2025 Chris Rizzitello <sithlord48@gmail.com>
|
|
||||||
# SPDX-FileCopyrightText: 2012 - 2024 Symless Ltd
|
|
||||||
# SPDX-FileCopyrightText: 2009 - 2012 Nick Bolton
|
|
||||||
# SPDX-License-Identifier: MIT
|
|
||||||
|
|
||||||
set(target ${CMAKE_PROJECT_NAME}-server)
|
|
||||||
|
|
||||||
if(WIN32)
|
|
||||||
# Generate rc file
|
|
||||||
set(EXE_DESCRIPTION "${CMAKE_PROJECT_PROPER_NAME} server application")
|
|
||||||
|
|
||||||
set(EXE_ICON "
|
|
||||||
IDI_DESKFLOW ICON DISCARDABLE \"${CMAKE_SOURCE_DIR}/src/apps/res/deskflow.ico\"
|
|
||||||
")
|
|
||||||
|
|
||||||
configure_file(${CMAKE_SOURCE_DIR}/src/apps/res/windows.rc.in ${target}.rc)
|
|
||||||
|
|
||||||
set(PLATFORM_SOURCES
|
|
||||||
${target}.exe.manifest
|
|
||||||
${PROJECT_SOURCE_DIR}/src/apps/res/deskflow.ico
|
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/${target}.rc
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
add_executable(${target} ${PLATFORM_SOURCES} ${target}.cpp)
|
|
||||||
|
|
||||||
target_link_libraries(
|
|
||||||
${target}
|
|
||||||
arch
|
|
||||||
base
|
|
||||||
client
|
|
||||||
io
|
|
||||||
mt
|
|
||||||
net
|
|
||||||
platform
|
|
||||||
server
|
|
||||||
app
|
|
||||||
${libs})
|
|
||||||
|
|
||||||
if(APPLE)
|
|
||||||
set_target_properties(${target} PROPERTIES
|
|
||||||
BUILD_WITH_INSTALL_RPATH TRUE
|
|
||||||
INSTALL_RPATH "@loader_path/../Libraries;@loader_path/../Frameworks"
|
|
||||||
RUNTIME_OUTPUT_DIRECTORY $<TARGET_BUNDLE_CONTENT_DIR:${CMAKE_PROJECT_PROPER_NAME}>/MacOS
|
|
||||||
)
|
|
||||||
elseif(UNIX)
|
|
||||||
install(TARGETS ${target} DESTINATION bin)
|
|
||||||
generate_app_man(${target} "${CMAKE_PROJECT_DESCRIPTION} \\(Server\\)")
|
|
||||||
elseif(WIN32)
|
|
||||||
install(
|
|
||||||
TARGETS ${target}
|
|
||||||
RUNTIME_DEPENDENCY_SET serverDeps
|
|
||||||
DESTINATION .
|
|
||||||
)
|
|
||||||
install(RUNTIME_DEPENDENCY_SET serverDeps
|
|
||||||
PRE_EXCLUDE_REGEXES
|
|
||||||
"api-ms-win-.*"
|
|
||||||
"ext-ms-.*"
|
|
||||||
"^hvsifiletrust\\.dll$"
|
|
||||||
POST_EXCLUDE_REGEXES
|
|
||||||
".*system32.*"
|
|
||||||
RUNTIME DESTINATION .
|
|
||||||
)
|
|
||||||
endif()
|
|
||||||
@ -1,40 +0,0 @@
|
|||||||
/*
|
|
||||||
* Deskflow -- mouse and keyboard sharing utility
|
|
||||||
* SPDX-FileCopyrightText: (C) 2025 Chris Rizzitello <sithlord48@gmail.com>
|
|
||||||
* SPDX-FileCopyrightText: (C) 2012-2016 Symless Ltd.
|
|
||||||
* SPDX-FileCopyrightText: (C) 2002 Chris Schoeneman
|
|
||||||
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "arch/Arch.h"
|
|
||||||
#include "base/EventQueue.h"
|
|
||||||
#include "base/Log.h"
|
|
||||||
#include "deskflow/ServerApp.h"
|
|
||||||
|
|
||||||
#if SYSAPI_WIN32
|
|
||||||
#include "arch/win32/ArchMiscWindows.h"
|
|
||||||
#include <QCoreApplication>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
|
||||||
{
|
|
||||||
#if SYSAPI_WIN32
|
|
||||||
// HACK to make sure settings gets the correct qApp path
|
|
||||||
QCoreApplication m(argc, argv);
|
|
||||||
m.deleteLater();
|
|
||||||
|
|
||||||
ArchMiscWindows::guardRuntimeVersion();
|
|
||||||
|
|
||||||
// record window instance for tray icon, etc
|
|
||||||
ArchMiscWindows::setInstanceWin32(GetModuleHandle(nullptr));
|
|
||||||
#endif
|
|
||||||
|
|
||||||
Arch arch;
|
|
||||||
arch.init();
|
|
||||||
|
|
||||||
Log log;
|
|
||||||
EventQueue events;
|
|
||||||
|
|
||||||
ServerApp app(&events);
|
|
||||||
return app.run(argc, argv);
|
|
||||||
}
|
|
||||||
@ -1,17 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
|
|
||||||
|
|
||||||
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
|
|
||||||
<trustInfo xmlns="urn:schemas-microsoft-com:asm.v3">
|
|
||||||
<security>
|
|
||||||
<requestedPrivileges>
|
|
||||||
<requestedExecutionLevel level="asInvoker" uiAccess="false"></requestedExecutionLevel>
|
|
||||||
</requestedPrivileges>
|
|
||||||
</security>
|
|
||||||
</trustInfo>
|
|
||||||
<application xmlns="urn:schemas-microsoft-com:asm.v3">
|
|
||||||
<windowsSettings>
|
|
||||||
<dpiAwareness xmlns="http://schemas.microsoft.com/SMI/2016/WindowsSettings">PerMonitor</dpiAwareness>
|
|
||||||
<dpiAware xmlns="http://schemas.microsoft.com/SMI/2005/WindowsSettings">true</dpiAware>
|
|
||||||
</windowsSettings>
|
|
||||||
</application>
|
|
||||||
</assembly>
|
|
||||||
@ -30,8 +30,12 @@
|
|||||||
<true/>
|
<true/>
|
||||||
<key>NSHumanReadableCopyright</key>
|
<key>NSHumanReadableCopyright</key>
|
||||||
<string>@BUNDLE_COPYRIGHT@</string>
|
<string>@BUNDLE_COPYRIGHT@</string>
|
||||||
|
<key>LSApplicationCategoryType</key>
|
||||||
|
<string>public.app-category.utilities</string>
|
||||||
|
|
||||||
<!-- Don't Allow Os to kill for memory -->
|
<!-- Prevent macOS from terminating during memory pressure -->
|
||||||
|
<key>NSSupportsAutomaticTermination</key>
|
||||||
|
<false/>
|
||||||
<key>NSSupportsSuddenTermination</key>
|
<key>NSSupportsSuddenTermination</key>
|
||||||
<false/>
|
<false/>
|
||||||
|
|
||||||
|
|||||||
@ -5,34 +5,58 @@
|
|||||||
<file>icons/deskflow-dark/actions/16/document-edit.svg</file>
|
<file>icons/deskflow-dark/actions/16/document-edit.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/16/document-open.svg</file>
|
<file>icons/deskflow-dark/actions/16/document-open.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/16/document-save-as.svg</file>
|
<file>icons/deskflow-dark/actions/16/document-save-as.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/16/go-down.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/16/go-up.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/16/help-about.svg</file>
|
<file>icons/deskflow-dark/actions/16/help-about.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/16/network-connect.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/16/network-disconnect.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/16/process-stop.svg</file>
|
<file>icons/deskflow-dark/actions/16/process-stop.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/16/system-run.svg</file>
|
<file>icons/deskflow-dark/actions/16/system-run.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/16/system-search.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/16/tools-report-bug.svg</file>
|
<file>icons/deskflow-dark/actions/16/tools-report-bug.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/16/view-close.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/16/view-refresh.svg</file>
|
<file>icons/deskflow-dark/actions/16/view-refresh.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/16/window-minimize-pip.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/16/window-restore-pip.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/22/configure.svg</file>
|
<file>icons/deskflow-dark/actions/22/configure.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/22/edit-copy.svg</file>
|
<file>icons/deskflow-dark/actions/22/edit-copy.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/22/document-edit.svg</file>
|
<file>icons/deskflow-dark/actions/22/document-edit.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/22/document-open.svg</file>
|
<file>icons/deskflow-dark/actions/22/document-open.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/22/document-save-as.svg</file>
|
<file>icons/deskflow-dark/actions/22/document-save-as.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/22/fingerprint.svg</file>
|
<file>icons/deskflow-dark/actions/22/fingerprint.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/22/go-down.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/22/go-up.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/22/help-about.svg</file>
|
<file>icons/deskflow-dark/actions/22/help-about.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/22/network-connect.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/22/network-disconnect.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/22/process-stop.svg</file>
|
<file>icons/deskflow-dark/actions/22/process-stop.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/22/system-run.svg</file>
|
<file>icons/deskflow-dark/actions/22/system-run.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/22/system-search.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/22/tools-report-bug.svg</file>
|
<file>icons/deskflow-dark/actions/22/tools-report-bug.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/22/view-close.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/22/view-refresh.svg</file>
|
<file>icons/deskflow-dark/actions/22/view-refresh.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/22/window-minimize-pip.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/22/window-restore-pip.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/24/configure.svg</file>
|
<file>icons/deskflow-dark/actions/24/configure.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/24/edit-copy.svg</file>
|
<file>icons/deskflow-dark/actions/24/edit-copy.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/24/document-edit.svg</file>
|
<file>icons/deskflow-dark/actions/24/document-edit.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/24/document-open.svg</file>
|
<file>icons/deskflow-dark/actions/24/document-open.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/24/document-save-as.svg</file>
|
<file>icons/deskflow-dark/actions/24/document-save-as.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/24/go-down.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/24/go-up.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/24/edit-clear-all.svg</file>
|
<file>icons/deskflow-dark/actions/24/edit-clear-all.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/24/fingerprint.svg</file>
|
<file>icons/deskflow-dark/actions/24/fingerprint.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/24/help-about.svg</file>
|
<file>icons/deskflow-dark/actions/24/help-about.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/24/network-connect.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/24/network-disconnect.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/24/process-stop.svg</file>
|
<file>icons/deskflow-dark/actions/24/process-stop.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/24/system-run.svg</file>
|
<file>icons/deskflow-dark/actions/24/system-run.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/24/system-search.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/24/tools-report-bug.svg</file>
|
<file>icons/deskflow-dark/actions/24/tools-report-bug.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/24/view-close.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/24/view-refresh.svg</file>
|
<file>icons/deskflow-dark/actions/24/view-refresh.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/24/window-minimize-pip.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/24/window-restore-pip.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/32/configure.svg</file>
|
<file>icons/deskflow-dark/actions/32/configure.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/32/application-exit.svg</file>
|
<file>icons/deskflow-dark/actions/32/application-exit.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/32/dialog-cancel.svg</file>
|
<file>icons/deskflow-dark/actions/32/dialog-cancel.svg</file>
|
||||||
@ -40,10 +64,13 @@
|
|||||||
<file>icons/deskflow-dark/actions/32/dialog-ok-apply.svg</file>
|
<file>icons/deskflow-dark/actions/32/dialog-ok-apply.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/32/document-open.svg</file>
|
<file>icons/deskflow-dark/actions/32/document-open.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/32/document-save-as.svg</file>
|
<file>icons/deskflow-dark/actions/32/document-save-as.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/32/go-down.svg</file>
|
||||||
|
<file>icons/deskflow-dark/actions/32/go-up.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/32/help-about.svg</file>
|
<file>icons/deskflow-dark/actions/32/help-about.svg</file>
|
||||||
<file>icons/deskflow-dark/actions/32/view-refresh.svg</file>
|
<file>icons/deskflow-dark/actions/32/view-refresh.svg</file>
|
||||||
<file>icons/deskflow-dark/apps/64/deskflow.svg</file>
|
<file>icons/deskflow-dark/actions/32/system-search.svg</file>
|
||||||
<file>icons/deskflow-dark/apps/64/deskflow-symbolic.svg</file>
|
<file>icons/deskflow-dark/apps/64/org.deskflow.deskflow.svg</file>
|
||||||
|
<file>icons/deskflow-dark/apps/64/org.deskflow.deskflow-symbolic.svg</file>
|
||||||
<file>icons/deskflow-dark/devices/64/video-display.svg</file>
|
<file>icons/deskflow-dark/devices/64/video-display.svg</file>
|
||||||
<file>icons/deskflow-dark/places/64/user-trash.svg</file>
|
<file>icons/deskflow-dark/places/64/user-trash.svg</file>
|
||||||
<file>icons/deskflow-dark/status/32/software-updates-release.svg</file>
|
<file>icons/deskflow-dark/status/32/software-updates-release.svg</file>
|
||||||
@ -62,11 +89,19 @@
|
|||||||
<file>icons/deskflow-light/actions/16/document-edit.svg</file>
|
<file>icons/deskflow-light/actions/16/document-edit.svg</file>
|
||||||
<file>icons/deskflow-light/actions/16/document-open.svg</file>
|
<file>icons/deskflow-light/actions/16/document-open.svg</file>
|
||||||
<file>icons/deskflow-light/actions/16/document-save-as.svg</file>
|
<file>icons/deskflow-light/actions/16/document-save-as.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/16/go-down.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/16/go-up.svg</file>
|
||||||
<file>icons/deskflow-light/actions/16/help-about.svg</file>
|
<file>icons/deskflow-light/actions/16/help-about.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/16/network-connect.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/16/network-disconnect.svg</file>
|
||||||
<file>icons/deskflow-light/actions/16/process-stop.svg</file>
|
<file>icons/deskflow-light/actions/16/process-stop.svg</file>
|
||||||
<file>icons/deskflow-light/actions/16/system-run.svg</file>
|
<file>icons/deskflow-light/actions/16/system-run.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/16/system-search.svg</file>
|
||||||
<file>icons/deskflow-light/actions/16/tools-report-bug.svg</file>
|
<file>icons/deskflow-light/actions/16/tools-report-bug.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/16/view-close.svg</file>
|
||||||
<file>icons/deskflow-light/actions/16/view-refresh.svg</file>
|
<file>icons/deskflow-light/actions/16/view-refresh.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/16/window-minimize-pip.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/16/window-restore-pip.svg</file>
|
||||||
<file>icons/deskflow-light/actions/22/configure.svg</file>
|
<file>icons/deskflow-light/actions/22/configure.svg</file>
|
||||||
<file>icons/deskflow-light/actions/22/edit-clear-all.svg</file>
|
<file>icons/deskflow-light/actions/22/edit-clear-all.svg</file>
|
||||||
<file>icons/deskflow-light/actions/22/edit-copy.svg</file>
|
<file>icons/deskflow-light/actions/22/edit-copy.svg</file>
|
||||||
@ -74,11 +109,19 @@
|
|||||||
<file>icons/deskflow-light/actions/22/document-open.svg</file>
|
<file>icons/deskflow-light/actions/22/document-open.svg</file>
|
||||||
<file>icons/deskflow-light/actions/22/document-save-as.svg</file>
|
<file>icons/deskflow-light/actions/22/document-save-as.svg</file>
|
||||||
<file>icons/deskflow-light/actions/22/fingerprint.svg</file>
|
<file>icons/deskflow-light/actions/22/fingerprint.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/22/go-down.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/22/go-up.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/22/network-connect.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/22/network-disconnect.svg</file>
|
||||||
<file>icons/deskflow-light/actions/22/help-about.svg</file>
|
<file>icons/deskflow-light/actions/22/help-about.svg</file>
|
||||||
<file>icons/deskflow-light/actions/22/process-stop.svg</file>
|
<file>icons/deskflow-light/actions/22/process-stop.svg</file>
|
||||||
<file>icons/deskflow-light/actions/22/system-run.svg</file>
|
<file>icons/deskflow-light/actions/22/system-run.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/22/system-search.svg</file>
|
||||||
<file>icons/deskflow-light/actions/22/tools-report-bug.svg</file>
|
<file>icons/deskflow-light/actions/22/tools-report-bug.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/22/view-close.svg</file>
|
||||||
<file>icons/deskflow-light/actions/22/view-refresh.svg</file>
|
<file>icons/deskflow-light/actions/22/view-refresh.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/22/window-minimize-pip.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/22/window-restore-pip.svg</file>
|
||||||
<file>icons/deskflow-light/actions/24/configure.svg</file>
|
<file>icons/deskflow-light/actions/24/configure.svg</file>
|
||||||
<file>icons/deskflow-light/actions/24/edit-clear-all.svg</file>
|
<file>icons/deskflow-light/actions/24/edit-clear-all.svg</file>
|
||||||
<file>icons/deskflow-light/actions/24/edit-copy.svg</file>
|
<file>icons/deskflow-light/actions/24/edit-copy.svg</file>
|
||||||
@ -86,11 +129,19 @@
|
|||||||
<file>icons/deskflow-light/actions/24/document-edit.svg</file>
|
<file>icons/deskflow-light/actions/24/document-edit.svg</file>
|
||||||
<file>icons/deskflow-light/actions/24/document-open.svg</file>
|
<file>icons/deskflow-light/actions/24/document-open.svg</file>
|
||||||
<file>icons/deskflow-light/actions/24/document-save-as.svg</file>
|
<file>icons/deskflow-light/actions/24/document-save-as.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/24/go-down.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/24/go-up.svg</file>
|
||||||
<file>icons/deskflow-light/actions/24/help-about.svg</file>
|
<file>icons/deskflow-light/actions/24/help-about.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/24/network-connect.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/24/network-disconnect.svg</file>
|
||||||
<file>icons/deskflow-light/actions/24/process-stop.svg</file>
|
<file>icons/deskflow-light/actions/24/process-stop.svg</file>
|
||||||
<file>icons/deskflow-light/actions/24/system-run.svg</file>
|
<file>icons/deskflow-light/actions/24/system-run.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/24/system-search.svg</file>
|
||||||
<file>icons/deskflow-light/actions/24/tools-report-bug.svg</file>
|
<file>icons/deskflow-light/actions/24/tools-report-bug.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/24/view-close.svg</file>
|
||||||
<file>icons/deskflow-light/actions/24/view-refresh.svg</file>
|
<file>icons/deskflow-light/actions/24/view-refresh.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/24/window-minimize-pip.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/24/window-restore-pip.svg</file>
|
||||||
<file>icons/deskflow-light/actions/32/configure.svg</file>
|
<file>icons/deskflow-light/actions/32/configure.svg</file>
|
||||||
<file>icons/deskflow-light/actions/32/application-exit.svg</file>
|
<file>icons/deskflow-light/actions/32/application-exit.svg</file>
|
||||||
<file>icons/deskflow-light/actions/32/dialog-cancel.svg</file>
|
<file>icons/deskflow-light/actions/32/dialog-cancel.svg</file>
|
||||||
@ -98,10 +149,13 @@
|
|||||||
<file>icons/deskflow-light/actions/32/dialog-ok-apply.svg</file>
|
<file>icons/deskflow-light/actions/32/dialog-ok-apply.svg</file>
|
||||||
<file>icons/deskflow-light/actions/32/document-open.svg</file>
|
<file>icons/deskflow-light/actions/32/document-open.svg</file>
|
||||||
<file>icons/deskflow-light/actions/32/document-save-as.svg</file>
|
<file>icons/deskflow-light/actions/32/document-save-as.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/32/go-down.svg</file>
|
||||||
|
<file>icons/deskflow-light/actions/32/go-up.svg</file>
|
||||||
<file>icons/deskflow-light/actions/32/help-about.svg</file>
|
<file>icons/deskflow-light/actions/32/help-about.svg</file>
|
||||||
<file>icons/deskflow-light/actions/32/view-refresh.svg</file>
|
<file>icons/deskflow-light/actions/32/view-refresh.svg</file>
|
||||||
<file>icons/deskflow-light/apps/64/deskflow.svg</file>
|
<file>icons/deskflow-light/actions/32/system-search.svg</file>
|
||||||
<file>icons/deskflow-light/apps/64/deskflow-symbolic.svg</file>
|
<file>icons/deskflow-light/apps/64/org.deskflow.deskflow.svg</file>
|
||||||
|
<file>icons/deskflow-light/apps/64/org.deskflow.deskflow-symbolic.svg</file>
|
||||||
<file>icons/deskflow-light/devices/64/video-display.svg</file>
|
<file>icons/deskflow-light/devices/64/video-display.svg</file>
|
||||||
<file>icons/deskflow-light/status/32/software-updates-release.svg</file>
|
<file>icons/deskflow-light/status/32/software-updates-release.svg</file>
|
||||||
<file>icons/deskflow-light/status/64/dialog-error.svg</file>
|
<file>icons/deskflow-light/status/64/dialog-error.svg</file>
|
||||||
|
|||||||
7
src/apps/res/entitlements-dev.plist
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
||||||
|
<plist version="1.0"><dict>
|
||||||
|
<key>com.apple.security.cs.disable-library-validation</key><true/>
|
||||||
|
<key>com.apple.security.get-task-allow</key><true/>
|
||||||
|
<key>com.apple.security.cs.allow-jit</key><true/>
|
||||||
|
</dict></plist>
|
||||||
5
src/apps/res/icons/deskflow-dark/actions/16/go-down.svg
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg viewBox="0 0 16 16" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
<path d="M8 11.707l-6-6L2.707 5 8 10.293 13.293 5l.707.707-6 6z" class="ColorScheme-Text" fill="currentColor"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 323 B |
5
src/apps/res/icons/deskflow-dark/actions/16/go-up.svg
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg viewBox="0 0 16 16" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
<path d="M8 4.293l-6 6 .707.707L8 5.707 13.293 11l.707-.707-6-6z" class="ColorScheme-Text" fill="currentColor"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 324 B |
@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 13.300781 2 L 10.650391 4.6503906 L 9.5859375 3.5859375 L 3.5859375 9.5859375 L 4.6503906 10.650391 L 2 13.300781 L 2.6992188 14 L 5.3496094 11.349609 L 6.4140625 12.414062 L 12.414062 6.4140625 L 11.349609 5.3496094 L 14 2.6992188 L 13.300781 2 z " class="ColorScheme-Text"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 582 B |
@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-NegativeText { color: #da4453; } .ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 13.300781 2 L 10.650391 4.6503906 L 9.5859375 3.5859375 L 6.5859375 6.5859375 L 9.4140625 9.4140625 L 12.414062 6.4140625 L 11.349609 5.3496094 L 14 2.6992188 L 13.300781 2 z M 5.5859375 7.5859375 L 3.5859375 9.5859375 L 4.6503906 10.650391 L 2 13.300781 L 2.6992188 14 L 5.3496094 11.349609 L 6.4140625 12.414062 L 8.4140625 10.414062 L 5.5859375 7.5859375 z " class="ColorScheme-Text"/>
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 9,9.83 10.667,11.497 9,13.164 9.833,13.997 11.5,12.33 13.167,13.997 14,13.164 12.333,11.497 14,9.83 13.167,8.997 11.5,10.664 9.833,8.997 Z" class="ColorScheme-NegativeText"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 982 B |
@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 6.5 2 C 4.007 2 2 4.01 2 6.5 C 2 8.993 4.01 11 6.5 11 C 7.5636432 11 8.5263409 10.618801 9.2949219 10.005859 L 13.292969 14.003906 L 14 13.296875 L 10.001953 9.2988281 C 10.617604 8.529048 11 7.565338 11 6.5 C 11 4.007 8.99 2 6.5 2 z M 6.5 3 C 8.439 3 10 4.561 10 6.5 C 10 8.439 8.439 10 6.5 10 C 4.561 10 3 8.439 3 6.5 C 3 4.561 4.561 3 6.5 3 z " class="ColorScheme-Text"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 680 B |
@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 16 16">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-NegativeText { color: #da4453; } .ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="m2 2v12h12v-12h-12m1 2h10v9h-10v-9" class="ColorScheme-Text"/>
|
||||||
|
<path d="m6.2 6l-.707.707 1.793 1.793-1.793 1.793.707.707 1.793-1.793 1.793 1.793.707-.707-1.793-1.793 1.793-1.793-.707-.707-1.793 1.793" style="fill:currentColor;fill-opacity:1;stroke:none" class="ColorScheme-NegativeText"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 639 B |
@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg version="1.1" viewBox="0 0 16 16" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<defs>
|
||||||
|
<style id="current-color-scheme" type="text/css">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path class="ColorScheme-Text" d="m2 2v12h6v-1h-5v-9h10v4h1v-6zm7 7v6h6v-6zm1 2h4v3h-4z" fill="currentColor"/>
|
||||||
|
<path class="ColorScheme-Text" d="m7.9999465 5.0002137-0.999893 2e-7v1.3423975l1e-6 0.9501754-2.8926898-2.882958-0.707107 0.7071067 2.8887423 2.8831185-0.9501364-7e-7 -1.3390969 7e-7 4.666e-4 0.9998928h1.3386313l2.6606688 5.32e-5 4.131e-4 -2.6573881z" fill="currentColor"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 641 B |
@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg version="1.1" viewBox="0 0 16 16" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<defs>
|
||||||
|
<style id="current-color-scheme" type="text/css">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path class="ColorScheme-Text" d="m2 2v12h6v-1h-5v-9h10v4h1v-6zm7 7v6h6v-6zm1 2h4v3h-4z" fill="currentColor"/>
|
||||||
|
<path class="ColorScheme-Text" d="M 4,8.999786 H 4.9999606 V 7.657389 L 4.9999596,6.707213 7.8928452,9.590171 8.6,8.883065 5.7110623,5.999946 l 0.9502006,1e-6 1.3391875,-1e-6 -4.666e-4,-0.999893 H 6.6612619 L 4.0004131,5 4,7.657388 Z" fill="currentColor"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 624 B |
7
src/apps/res/icons/deskflow-dark/actions/22/go-down.svg
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 22 22">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="m3.707031 7l-.707031.707031 6.125 6.125 1.875 1.875 1.875-1.875 6.125-6.125-.707031-.707031-6.125 6.125-1.167969 1.167969-1.167969-1.167969-6.125-6.125" class="ColorScheme-Text"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 485 B |
5
src/apps/res/icons/deskflow-dark/actions/22/go-up.svg
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg viewBox="0 0 22 22" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
<path d="M3.707 15L3 14.293l6.125-6.125L11 6.293l1.875 1.875L19 14.293l-.707.707-6.125-6.125L11 7.707 9.832 8.875 3.707 15" class="ColorScheme-Text" fill="currentColor"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 382 B |
@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 22 22">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 18.292969 3 L 14.792969 6.5 L 13.292969 5 L 11.292969 7 L 8 10.292969 L 6 12.292969 L 7.5 13.792969 L 3 18.292969 L 3.7070312 19 L 8.2070312 14.5 L 9.7070312 16 L 11.707031 14 L 15 10.707031 L 17 8.7070312 L 15.5 7.2070312 L 19 3.7070312 L 18.292969 3 z " class="ColorScheme-Text"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 588 B |
@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 22 22">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-NegativeText { color: #da4453; } .ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 18.292969 3 L 14.792969 6.5 L 13.292969 5 L 11.292969 7 L 9.5 8.7929688 L 11 10.292969 L 11.707031 11 L 13.207031 12.5 L 15 10.707031 L 17 8.7070312 L 15.5 7.2070312 L 19 3.7070312 L 18.292969 3 z M 8.7929688 9.5 L 8 10.292969 L 6 12.292969 L 7.5 13.792969 L 3 18.292969 L 3.7070312 19 L 8.2070312 14.5 L 9.7070312 16 L 11.707031 14 L 12.5 13.207031 L 11 11.707031 L 10.292969 11 L 8.7929688 9.5 z " class="ColorScheme-Text"/>
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 14.833984 14 L 14 14.833984 L 15.666016 16.5 L 14 18.166016 L 14.833984 19 L 16.5 17.333984 L 18.166016 19 L 19 18.166016 L 17.333984 16.5 L 19 14.833984 L 18.166016 14 L 16.5 15.666016 L 14.833984 14 z " class="ColorScheme-NegativeText"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 1.1 KiB |
@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 22 22">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 9 3 C 5.6759952 3 3 5.6759952 3 9 C 3 12.324005 5.6759952 15 9 15 C 10.481205 15 11.830584 14.465318 12.875 13.582031 L 18.292969 19 L 19 18.292969 L 13.582031 12.875 C 14.465318 11.830584 15 10.481205 15 9 C 15 5.6759952 12.324005 3 9 3 z M 9 4 C 11.770005 4 14 6.2299952 14 9 C 14 11.770005 11.770005 14 9 14 C 6.2299952 14 4 11.770005 4 9 C 4 6.2299952 6.2299952 4 9 4 z " class="ColorScheme-Text"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 710 B |
@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 22 22">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Accent { color: #3daee9; } .ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 3 3 L 3 19 L 19 19 L 19 3 L 3 3 z M 4 7 L 18 7 L 18 18 L 4 18 L 4 7 z " class="ColorScheme-Text"/>
|
||||||
|
<path style="fill:#da4453;fill-opacity:1;stroke:none" d="M 8.7070312 9 L 8 9.7070312 L 10.292969 12 L 8 14.292969 L 8.7070312 15 L 11 12.707031 L 13.292969 15 L 14 14.292969 L 11.707031 12 L 14 9.7070312 L 13.292969 9 L 11 11.292969 L 8.7070312 9 z "/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 698 B |
@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg version="1.1" viewBox="0 0 22 22" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<defs>
|
||||||
|
<style id="current-color-scheme" type="text/css">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path class="ColorScheme-Text" d="m9.93907 8.0718026-0.999892 2e-7v3.2427472l-3.0355875-3.035587-0.707107 0.7071068 3.0355875 3.0355872h-3.2427475v0.999893h4.9497465v-0.292787z" fill="currentColor"/>
|
||||||
|
<path class="ColorScheme-Text" d="m3 3v16h8v-1h-7v-11h14v4h1v-8h-1zm9 9v4-1 5h8v-8h-3zm1 3h6v4h-6v-5z" fill="currentColor"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 581 B |
@ -0,0 +1,8 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg version="1.1" viewBox="0 0 22 22" xmlns="http://www.w3.org/2000/svg">
|
||||||
|
<defs>
|
||||||
|
<style id="current-color-scheme" type="text/css">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<path class="ColorScheme-Text" d="M 5,12.949747 H 5.999892 V 9.707 L 9.03548,12.742587 9.7425869,12.03548 6.706999,8.999893 H 9.9497469 V 8 H 5 v 0.292787 z" fill="currentColor"/>
|
||||||
|
<path class="ColorScheme-Text" d="m3 3v16h8v-1h-7v-11h14v4h1v-8h-1zm9 9v4-1 5h8v-8h-3zm1 3h6v4h-6v-5z" fill="currentColor"/>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 561 B |
9
src/apps/res/icons/deskflow-dark/actions/24/go-down.svg
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<g transform="translate(1,1)">
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="m3.707031 7l-.707031.707031 6.125 6.125 1.875 1.875 1.875-1.875 6.125-6.125-.707031-.707031-6.125 6.125-1.167969 1.167969-1.167969-1.167969-6.125-6.125" class="ColorScheme-Text"/>
|
||||||
|
</g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 549 B |
7
src/apps/res/icons/deskflow-dark/actions/24/go-up.svg
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
<g transform="translate(1,1)">
|
||||||
|
<path d="M3.707 15L3 14.293l6.125-6.125L11 6.293l1.875 1.875L19 14.293l-.707.707-6.125-6.125L11 7.707 9.832 8.875 3.707 15" class="ColorScheme-Text" fill="currentColor"/>
|
||||||
|
</g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 443 B |
@ -0,0 +1,8 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<g transform="translate(1,1)">
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 18.292969 3 L 14.792969 6.5 L 13.292969 5 L 11.292969 7 L 8 10.292969 L 6 12.292969 L 7.5 13.792969 L 3 18.292969 L 3.7070312 19 L 8.2070312 14.5 L 9.7070312 16 L 11.707031 14 L 15 10.707031 L 17 8.7070312 L 15.5 7.2070312 L 19 3.7070312 L 18.292969 3 z " class="ColorScheme-Text"/>
|
||||||
|
</g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 615 B |
@ -0,0 +1,9 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-NegativeText { color: #da4453; } .ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<g transform="translate(1,1)">
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 18.292969 3 L 14.792969 6.5 L 13.292969 5 L 11.292969 7 L 9.5 8.7929688 L 11 10.292969 L 11.707031 11 L 13.207031 12.5 L 15 10.707031 L 17 8.7070312 L 15.5 7.2070312 L 19 3.7070312 L 18.292969 3 z M 8.7929688 9.5 L 8 10.292969 L 6 12.292969 L 7.5 13.792969 L 3 18.292969 L 3.7070312 19 L 8.2070312 14.5 L 9.7070312 16 L 11.707031 14 L 12.5 13.207031 L 11 11.707031 L 10.292969 11 L 8.7929688 9.5 z " class="ColorScheme-Text"/>
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 14.833984 14 L 14 14.833984 L 15.666016 16.5 L 14 18.166016 L 14.833984 19 L 16.5 17.333984 L 18.166016 19 L 19 18.166016 L 17.333984 16.5 L 19 14.833984 L 18.166016 14 L 16.5 15.666016 L 14.833984 14 z " class="ColorScheme-NegativeText"/>
|
||||||
|
</g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 1.1 KiB |
@ -0,0 +1,9 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<g transform="translate(1,1)">
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 9 3 C 5.6759952 3 3 5.6759952 3 9 C 3 12.324005 5.6759952 15 9 15 C 10.481205 15 11.830584 14.465318 12.875 13.582031 L 18.292969 19 L 19 18.292969 L 13.582031 12.875 C 14.465318 11.830584 15 10.481205 15 9 C 15 5.6759952 12.324005 3 9 3 z M 9 4 C 11.770005 4 14 6.2299952 14 9 C 14 11.770005 11.770005 14 9 14 C 6.2299952 14 4 11.770005 4 9 C 4 6.2299952 6.2299952 4 9 4 z " class="ColorScheme-Text"/>
|
||||||
|
</g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 774 B |
@ -0,0 +1,9 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24">
|
||||||
|
<defs id="defs3051">
|
||||||
|
<style type="text/css" id="current-color-scheme">.ColorScheme-Accent { color: #3daee9; } .ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<g transform="translate(1,1)">
|
||||||
|
<path style="fill:currentColor;fill-opacity:1;stroke:none" d="M 3 3 L 3 19 L 19 19 L 19 3 L 3 3 z M 4 7 L 18 7 L 18 18 L 4 18 L 4 7 z " class="ColorScheme-Text"/>
|
||||||
|
<path style="fill:#da4453;fill-opacity:1;stroke:none" d="M 8.7070312 9 L 8 9.7070312 L 10.292969 12 L 8 14.292969 L 8.7070312 15 L 11 12.707031 L 13.292969 15 L 14 14.292969 L 11.707031 12 L 14 9.7070312 L 13.292969 9 L 11 11.292969 L 8.7070312 9 z "/>
|
||||||
|
</g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 728 B |
@ -0,0 +1,9 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" version="1.1" viewBox="0 0 24 24" width="24" height="24">
|
||||||
|
<defs>
|
||||||
|
<style id="current-color-scheme" type="text/css">.ColorScheme-Text { color: #fcfcfc; } </style>
|
||||||
|
</defs>
|
||||||
|
<g transform="translate(1,1)">
|
||||||
|
<path class="ColorScheme-Text" d="m9.93907 8.0718026-0.999892 2e-7v3.2427472l-3.0355875-3.035587-0.707107 0.7071068 3.0355875 3.0355872h-3.2427475v0.999893h4.9497465v-0.292787z" fill="currentColor"/>
|
||||||
|
<path class="ColorScheme-Text" d="m3 3v16h8v-1h-7v-11h14v4h1v-8h-1zm9 9v4-1 5h8v-8h-3zm1 3h6v4h-6v-5z" fill="currentColor"/>
|
||||||
|
</g>
|
||||||
|
</svg>
|
||||||
|
After Width: | Height: | Size: 597 B |