mirror of
https://github.com/basecamp/omarchy.git
synced 2026-02-17 15:25:37 +00:00
Compare commits
615 Commits
refactor-p
...
revert-458
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
2453ca6ea4 | ||
|
|
b3dd14a038 | ||
|
|
7dc638358b | ||
|
|
3e07255fbc | ||
|
|
02fd1961b9 | ||
|
|
40bff09c84 | ||
|
|
6ff13fc071 | ||
|
|
a33cf4f287 | ||
|
|
2e2d78088a | ||
|
|
b1af966819 | ||
|
|
e055358721 | ||
|
|
8b6e2466a3 | ||
|
|
560500d8ec | ||
|
|
463417a281 | ||
|
|
bbb57e98c1 | ||
|
|
e38dd063a6 | ||
|
|
a4d6e3ab03 | ||
|
|
fc529b368d | ||
|
|
ce01b6e0d6 | ||
|
|
450d4dd82b | ||
|
|
8895384b0e | ||
|
|
e4b7372666 | ||
|
|
a30448ceec | ||
|
|
4fadf666e6 | ||
|
|
07ede07193 | ||
|
|
527819b750 | ||
|
|
98bfe20839 | ||
|
|
4d48409926 | ||
|
|
ffafe1727e | ||
|
|
f2f306269a | ||
|
|
e4913ca2db | ||
|
|
ff234bba1f | ||
|
|
ecf48a3b4c | ||
|
|
74eea9e716 | ||
|
|
66cb888a2e | ||
|
|
0a5755e51f | ||
|
|
7bd5bf25cd | ||
|
|
0c9b38e507 | ||
|
|
0e2ed5439e | ||
|
|
75a0ee6149 | ||
|
|
2c9c0f883a | ||
|
|
8a58b8153c | ||
|
|
badd1f8495 | ||
|
|
67ee1450f0 | ||
|
|
c289cd0730 | ||
|
|
cbcd0e49be | ||
|
|
ae45f06847 | ||
|
|
1070a87a47 | ||
|
|
9741b29a7c | ||
|
|
ea24b0dc68 | ||
|
|
3bbb57b54d | ||
|
|
ebfb7f16e8 | ||
|
|
347afae8c0 | ||
|
|
ebfcefa553 | ||
|
|
2087d96ad8 | ||
|
|
b638cbc57a | ||
|
|
636a7cefda | ||
|
|
f7e22fcfd8 | ||
|
|
b0e8a4dcea | ||
|
|
f57234b991 | ||
|
|
be7f316371 | ||
|
|
b1553d3b31 | ||
|
|
055e969a56 | ||
|
|
050899e5b3 | ||
|
|
bd8b12b23b | ||
|
|
c268fb6c9b | ||
|
|
248a7a611b | ||
|
|
e487dace43 | ||
|
|
ba14cd36dd | ||
|
|
34b22a23f6 | ||
|
|
f0d5c35271 | ||
|
|
63fc96a541 | ||
|
|
4ba39ba73c | ||
|
|
1a14938382 | ||
|
|
9581cce1af | ||
|
|
cf72c02ea5 | ||
|
|
a8ce084460 | ||
|
|
4b3e21445b | ||
|
|
8878478103 | ||
|
|
74ff475693 | ||
|
|
22f64160f5 | ||
|
|
ea76f8196c | ||
|
|
49a2941e2b | ||
|
|
6a5b64b4bc | ||
|
|
c484b66bcb | ||
|
|
87da28a965 | ||
|
|
23b74c6212 | ||
|
|
69dbee75cd | ||
|
|
d9c5df29d1 | ||
|
|
7c9708d647 | ||
|
|
5a9f0318e8 | ||
|
|
ab4694e3f5 | ||
|
|
bebf14a18c | ||
|
|
ff2a47c67e | ||
|
|
d9bd4a8db3 | ||
|
|
8fc5b6e346 | ||
|
|
7265c22728 | ||
|
|
32d187eab0 | ||
|
|
c19fc1593a | ||
|
|
7ffdfdbda9 | ||
|
|
161fa3f313 | ||
|
|
d6c28f317d | ||
|
|
4348ab6ef1 | ||
|
|
9d07cc884c | ||
|
|
ba31e3073c | ||
|
|
2df5f231cb | ||
|
|
26afde34ff | ||
|
|
3b94207ba7 | ||
|
|
e567020e1b | ||
|
|
f78f5b2c2c | ||
|
|
ec305459f8 | ||
|
|
55231e9726 | ||
|
|
a8e0762fbe | ||
|
|
bb91f90839 | ||
|
|
a7995efac2 | ||
|
|
5b534de6a0 | ||
|
|
4fe357972e | ||
|
|
7015601d77 | ||
|
|
532f4310d0 | ||
|
|
56b02f62b5 | ||
|
|
83628ab3bd | ||
|
|
d89614248b | ||
|
|
77a57aa838 | ||
|
|
e455d1bd68 | ||
|
|
adfe182984 | ||
|
|
febd18ce84 | ||
|
|
768c553c4c | ||
|
|
bf99a2ddc0 | ||
|
|
0930583526 | ||
|
|
4a6baafd05 | ||
|
|
c1bf6c4694 | ||
|
|
66daacb30d | ||
|
|
5b2c0dafbf | ||
|
|
988418aea1 | ||
|
|
25451f4a03 | ||
|
|
d884265d46 | ||
|
|
5e1ce16358 | ||
|
|
713b6e3a36 | ||
|
|
2c7b283aef | ||
|
|
4701726c83 | ||
|
|
bfc3c69cf1 | ||
|
|
21514dc577 | ||
|
|
5ff76df5e4 | ||
|
|
bab0004d08 | ||
|
|
93079858f1 | ||
|
|
4287472e02 | ||
|
|
291786d36a | ||
|
|
ed9a4a45ba | ||
|
|
05b82cbee5 | ||
|
|
697d09022a | ||
|
|
1ff31cfe41 | ||
|
|
cd995319bf | ||
|
|
281f0b86d2 | ||
|
|
55668f4c6d | ||
|
|
9c71962a16 | ||
|
|
7d77500c33 | ||
|
|
fb1d9ccfa3 | ||
|
|
2f75e9c7ec | ||
|
|
b22ed8448a | ||
|
|
a0d2f007fd | ||
|
|
955844cb5d | ||
|
|
295c7c91fc | ||
|
|
bc1a531534 | ||
|
|
4cec214a53 | ||
|
|
0b5ba427b2 | ||
|
|
53b8fc4257 | ||
|
|
dcb9527770 | ||
|
|
6c35e840f5 | ||
|
|
da984ce243 | ||
|
|
65bafa4f3b | ||
|
|
f5a35a1afe | ||
|
|
c9b3e13df8 | ||
|
|
9775b01070 | ||
|
|
b42dcf098b | ||
|
|
6ae31aedae | ||
|
|
63b0cd64bd | ||
|
|
bf779a6bbc | ||
|
|
774b4700ef | ||
|
|
400a87955e | ||
|
|
fe48a16a90 | ||
|
|
78ef351269 | ||
|
|
558cd68810 | ||
|
|
067ec2bd71 | ||
|
|
ec4cd81e63 | ||
|
|
7c0a05cc70 | ||
|
|
70bdbfe545 | ||
|
|
72b3b930c7 | ||
|
|
e08301dee2 | ||
|
|
9fc65dd2de | ||
|
|
5603fb50fd | ||
|
|
037f034ece | ||
|
|
e95f8f2847 | ||
|
|
8826aa10ca | ||
|
|
2851687bbb | ||
|
|
e25a00a38c | ||
|
|
7d9858a013 | ||
|
|
95bfb16cd4 | ||
|
|
8873f03cb1 | ||
|
|
a5f8ab3194 | ||
|
|
17968cb2d3 | ||
|
|
6cbca7825b | ||
|
|
eb8bd24d83 | ||
|
|
4bb8bfc44c | ||
|
|
f3b9a90120 | ||
|
|
2855712158 | ||
|
|
3489bf5ceb | ||
|
|
bc198c7270 | ||
|
|
2063680c82 | ||
|
|
d20e8351fc | ||
|
|
cd8a6430e2 | ||
|
|
cfded08b94 | ||
|
|
76b3e68c97 | ||
|
|
f7f28bb655 | ||
|
|
ab5544ad61 | ||
|
|
96479adbcd | ||
|
|
d207d505f5 | ||
|
|
ed935bedef | ||
|
|
1409cd7831 | ||
|
|
5800a0f4a1 | ||
|
|
eb904062f5 | ||
|
|
4a88ec876b | ||
|
|
59a7153d02 | ||
|
|
7cafdfcef3 | ||
|
|
9c4a0c2abd | ||
|
|
68ca8d8083 | ||
|
|
a01ce9b563 | ||
|
|
3dbebd7a4d | ||
|
|
3a4536059a | ||
|
|
9ae225a15a | ||
|
|
0b8bbdf01d | ||
|
|
df3d07e41f | ||
|
|
3da77ffc36 | ||
|
|
e08ef5866a | ||
|
|
41c6048758 | ||
|
|
ebc8a9ef62 | ||
|
|
0d42f1bafe | ||
|
|
e3cd567f6f | ||
|
|
103fc09dcf | ||
|
|
3da8c2a023 | ||
|
|
ee37be1124 | ||
|
|
7118ef6b19 | ||
|
|
e8880b5154 | ||
|
|
a41cb03ac5 | ||
|
|
09f696aea4 | ||
|
|
54e5be18ea | ||
|
|
503e4c765c | ||
|
|
37c37c0a87 | ||
|
|
40028a7fa9 | ||
|
|
8533d7ff3b | ||
|
|
923d5fb0cd | ||
|
|
88603ea9d6 | ||
|
|
b9b5de4751 | ||
|
|
1a5fdbc294 | ||
|
|
78b05bcc54 | ||
|
|
3631695a7f | ||
|
|
11d2d2f70e | ||
|
|
24a557ac7f | ||
|
|
2fcaf4b6ff | ||
|
|
13149f5fc9 | ||
|
|
59b83b3585 | ||
|
|
f8f3dcb3ef | ||
|
|
3ed8e8e3c4 | ||
|
|
e2573b41c1 | ||
|
|
2dca78cd83 | ||
|
|
60b7e4900f | ||
|
|
df3b1cbb82 | ||
|
|
ca40676657 | ||
|
|
3801e0e633 | ||
|
|
f4def40181 | ||
|
|
e8d063ef27 | ||
|
|
4d81a8aaa7 | ||
|
|
e02925f257 | ||
|
|
ef4ecdbfcf | ||
|
|
7bf1c38937 | ||
|
|
4a07b94cb6 | ||
|
|
de2757466b | ||
|
|
6dfa5f0807 | ||
|
|
4e802d8058 | ||
|
|
5e75c2d3a9 | ||
|
|
d20ad9032f | ||
|
|
9e2ff7be1d | ||
|
|
e1b3a88126 | ||
|
|
16a9bc295c | ||
|
|
fdee76e2d2 | ||
|
|
941e1c2dd8 | ||
|
|
c723411049 | ||
|
|
c82b1bfb7e | ||
|
|
36095c1ac8 | ||
|
|
57bbe425df | ||
|
|
d90bc6d3f3 | ||
|
|
dbc3c006dd | ||
|
|
807c74d405 | ||
|
|
a9cea21463 | ||
|
|
c832b7dc75 | ||
|
|
b08b419bfc | ||
|
|
2643967424 | ||
|
|
64f254653f | ||
|
|
687ac4567e | ||
|
|
72cecc600d | ||
|
|
7fbc139cb5 | ||
|
|
7c213db46d | ||
|
|
5dd4bec68a | ||
|
|
4311a00ca4 | ||
|
|
cd224e7ecd | ||
|
|
7e12473f80 | ||
|
|
2c7480135a | ||
|
|
df0a019c6a | ||
|
|
083715c8c6 | ||
|
|
d0aabc162a | ||
|
|
e416988d4e | ||
|
|
314abce4e8 | ||
|
|
fe8927b351 | ||
|
|
13390441a9 | ||
|
|
65a238d805 | ||
|
|
c535b19235 | ||
|
|
9c8c789453 | ||
|
|
2bc88ebf25 | ||
|
|
2573da8f5e | ||
|
|
e44e937284 | ||
|
|
fd952c2323 | ||
|
|
4e09523127 | ||
|
|
643cf35448 | ||
|
|
1fd1b65cd0 | ||
|
|
9a704fdadb | ||
|
|
a252a42772 | ||
|
|
c59089e9f3 | ||
|
|
ca8f25fba1 | ||
|
|
dae89574dd | ||
|
|
49a9ce14b8 | ||
|
|
d2ea6ad183 | ||
|
|
d5066561ca | ||
|
|
fe9493bd86 | ||
|
|
f578880bc8 | ||
|
|
7ce838565c | ||
|
|
aacc40c954 | ||
|
|
f3b9ca2149 | ||
|
|
ee8f62d967 | ||
|
|
32592e2e28 | ||
|
|
adf7fba2b3 | ||
|
|
021d66f9b6 | ||
|
|
1a34be257c | ||
|
|
1f4c50eddf | ||
|
|
92af9f41f2 | ||
|
|
8ed20d0524 | ||
|
|
2d00b2a02f | ||
|
|
97396f5fb2 | ||
|
|
46c85e49a3 | ||
|
|
8357dd3da2 | ||
|
|
860624d3f4 | ||
|
|
a15d3740a9 | ||
|
|
7b05dcfe0c | ||
|
|
df8b69bf27 | ||
|
|
f39c2a91a5 | ||
|
|
906baa8fee | ||
|
|
457b954db5 | ||
|
|
9b78e3c571 | ||
|
|
88e9c9db49 | ||
|
|
64a8d7bb04 | ||
|
|
c11a1c7989 | ||
|
|
c37ef6d78c | ||
|
|
4d5dab3e32 | ||
|
|
133d54f600 | ||
|
|
4194c649a1 | ||
|
|
33eabb0c88 | ||
|
|
573cbd8ec3 | ||
|
|
fec0731c17 | ||
|
|
abffb0abfe | ||
|
|
5789c0a1fb | ||
|
|
4e37a766ac | ||
|
|
ccc147229e | ||
|
|
6bd9d510d6 | ||
|
|
a22668fe17 | ||
|
|
1c59f1ae62 | ||
|
|
c67856b9b6 | ||
|
|
12cba29e2e | ||
|
|
20fde4d71a | ||
|
|
8780db4bf0 | ||
|
|
b2bd95197a | ||
|
|
c90e93b5fc | ||
|
|
3af42f6be1 | ||
|
|
03f04386ec | ||
|
|
9dc8e0c051 | ||
|
|
c5ebad0b67 | ||
|
|
9691e638b2 | ||
|
|
fef12b6c0e | ||
|
|
fc04525f03 | ||
|
|
cfbfb2ffed | ||
|
|
ddf0d1e8e0 | ||
|
|
029000abb0 | ||
|
|
0a9e7205c3 | ||
|
|
a810b8058b | ||
|
|
b9792f7ba1 | ||
|
|
9450ac868e | ||
|
|
add215c464 | ||
|
|
306714f825 | ||
|
|
8a37f3dce7 | ||
|
|
03be87b42c | ||
|
|
d6aa65d03c | ||
|
|
1514e4e501 | ||
|
|
91cf593b76 | ||
|
|
7327f95aa1 | ||
|
|
a8b8eb6f5e | ||
|
|
16d0133037 | ||
|
|
68c3917386 | ||
|
|
2cfc3b0f9e | ||
|
|
96f140b93f | ||
|
|
c97995b9ea | ||
|
|
8d61c73465 | ||
|
|
2b3c48b725 | ||
|
|
e15b2ae78c | ||
|
|
30a5f5846c | ||
|
|
7e44ab33ac | ||
|
|
6a181adf0d | ||
|
|
930246aee5 | ||
|
|
d7841e30b5 | ||
|
|
bc54b97117 | ||
|
|
a8106085aa | ||
|
|
a996438eaf | ||
|
|
9524259765 | ||
|
|
77fd86ae93 | ||
|
|
8cca056b90 | ||
|
|
a522a47f70 | ||
|
|
97382274f6 | ||
|
|
55692e0893 | ||
|
|
aa98e9307c | ||
|
|
14b1ee317f | ||
|
|
8f3f89fdfd | ||
|
|
3765417d9a | ||
|
|
a6c2576a3c | ||
|
|
0d7fbbce02 | ||
|
|
602d60d3d9 | ||
|
|
e3b8016e26 | ||
|
|
c86614039e | ||
|
|
aadb4fae08 | ||
|
|
e864c2da43 | ||
|
|
88a1141301 | ||
|
|
f6cd5e076d | ||
|
|
49f33169c1 | ||
|
|
04d2f10840 | ||
|
|
45e3272e25 | ||
|
|
934b22d4c2 | ||
|
|
ba7ffc39ad | ||
|
|
cb8d42ba26 | ||
|
|
d725058d33 | ||
|
|
128a6125a9 | ||
|
|
cb869457c4 | ||
|
|
a606b53cd9 | ||
|
|
f968f2012a | ||
|
|
033afbbc00 | ||
|
|
4fae366a5b | ||
|
|
63df15c967 | ||
|
|
6385b966e8 | ||
|
|
70fa03dbb3 | ||
|
|
06de54559d | ||
|
|
2bdf3fd450 | ||
|
|
d87f0aaa19 | ||
|
|
3e91190e50 | ||
|
|
fc7feda70f | ||
|
|
8007e38d88 | ||
|
|
292ac8318f | ||
|
|
597fcb8db8 | ||
|
|
db7070f9d6 | ||
|
|
385df32daa | ||
|
|
50ec3cec42 | ||
|
|
8b6fd9eed9 | ||
|
|
328c26efa2 | ||
|
|
2c4a9275d1 | ||
|
|
4efdcc62c6 | ||
|
|
62665abd0e | ||
|
|
f9450e1fb7 | ||
|
|
7ebe9fd7ab | ||
|
|
cf6a8476c5 | ||
|
|
bdb97195d8 | ||
|
|
a5ceb3f860 | ||
|
|
9d8961915e | ||
|
|
661e4f5add | ||
|
|
f6786e4c23 | ||
|
|
9626408259 | ||
|
|
4c8ee6cc1a | ||
|
|
37e5ed0d9d | ||
|
|
ec59388634 | ||
|
|
b5002b1f1d | ||
|
|
4c414f8dc2 | ||
|
|
5ea1ae260e | ||
|
|
4dbaf5e35f | ||
|
|
0fc901d4fc | ||
|
|
fef7efc841 | ||
|
|
cd2a4e416b | ||
|
|
c298823af4 | ||
|
|
a1b1eb5920 | ||
|
|
08143c5cbc | ||
|
|
261a7dcc1f | ||
|
|
44b37dafce | ||
|
|
20a3c469ed | ||
|
|
8c4bf65727 | ||
|
|
3e4421a37f | ||
|
|
f77f107b7e | ||
|
|
da8c3d9c64 | ||
|
|
8f19806742 | ||
|
|
8fe1d627f4 | ||
|
|
1b7fca5fa4 | ||
|
|
6e83c4f661 | ||
|
|
8174dc7df9 | ||
|
|
f8dcc7e190 | ||
|
|
13c3973c7a | ||
|
|
489ddc7fb0 | ||
|
|
2c1a761b88 | ||
|
|
c50003a996 | ||
|
|
e4a3d5e3ad | ||
|
|
9af41afd06 | ||
|
|
335845bd26 | ||
|
|
eec075bdf9 | ||
|
|
438fa96291 | ||
|
|
42e181054a | ||
|
|
c1fca69de5 | ||
|
|
367eb5b871 | ||
|
|
5ab2a69722 | ||
|
|
854b14029c | ||
|
|
72dc352c1a | ||
|
|
83a8740fc8 | ||
|
|
b2b65d55a7 | ||
|
|
1ec9ccd1b1 | ||
|
|
c17bd85c38 | ||
|
|
e1745d7ff9 | ||
|
|
88684b6dd0 | ||
|
|
d833b45e8b | ||
|
|
4b2ff4f329 | ||
|
|
279259d547 | ||
|
|
9b849fc824 | ||
|
|
bea57919b6 | ||
|
|
03cbbd2f7f | ||
|
|
8840af8df9 | ||
|
|
a54ec3a9cb | ||
|
|
42f47195ea | ||
|
|
89b1029588 | ||
|
|
29aae9a93e | ||
|
|
a6d49196d0 | ||
|
|
b7989ac89b | ||
|
|
3c19e4e12c | ||
|
|
94f29f3cba | ||
|
|
2fcc4e9c47 | ||
|
|
d81f6de211 | ||
|
|
e97ae0d842 | ||
|
|
2290152fb9 | ||
|
|
f364ee1167 | ||
|
|
6e1f1cae1b | ||
|
|
e354df3143 | ||
|
|
c981dda55a | ||
|
|
b6ba588fa3 | ||
|
|
bf3a5b0a36 | ||
|
|
9e1a70488b | ||
|
|
a43d090596 | ||
|
|
fceb7106d9 | ||
|
|
d2aeb520fc | ||
|
|
61678986fc | ||
|
|
2425f4d3e0 | ||
|
|
c6918e637b | ||
|
|
6f334868d6 | ||
|
|
79207160e6 | ||
|
|
a9d6a77ee6 | ||
|
|
a304b32cc1 | ||
|
|
3a744e0f78 | ||
|
|
88b13e6899 | ||
|
|
70d15921b9 | ||
|
|
283a41c494 | ||
|
|
3d10b38054 | ||
|
|
d33e947b99 | ||
|
|
79d48b4d8a | ||
|
|
4d3c02c69d | ||
|
|
e96bd085a5 | ||
|
|
64e581e5aa | ||
|
|
694c83f518 | ||
|
|
49308eb12a | ||
|
|
26d37ca2e0 | ||
|
|
c92362937a | ||
|
|
7a0fa07454 | ||
|
|
917279bff7 | ||
|
|
8350b84eee | ||
|
|
d9acd35ef4 | ||
|
|
044e826bb7 | ||
|
|
57e726f0c5 | ||
|
|
06fc4db4db | ||
|
|
15b5ee92d7 | ||
|
|
f6aa97350e | ||
|
|
5192c9b687 | ||
|
|
e263b5d00a | ||
|
|
26821c9b34 | ||
|
|
7cd5661f89 | ||
|
|
6cdf4a3790 | ||
|
|
c92a7eab81 | ||
|
|
8aa2d295e5 | ||
|
|
5fb29c199a | ||
|
|
962aca303d | ||
|
|
870356ecc3 | ||
|
|
cb03d7d84b | ||
|
|
7a0bdaafa4 | ||
|
|
638e35fcac | ||
|
|
904d253b4d | ||
|
|
a40ff463c9 | ||
|
|
8e210088c1 | ||
|
|
bf26366be4 | ||
|
|
4391df6853 | ||
|
|
2498216a4f | ||
|
|
33dde26902 | ||
|
|
b1b6e5d2a7 | ||
|
|
fc8e4c0400 | ||
|
|
f9557177dc | ||
|
|
3065ca9f2a | ||
|
|
ba5343ca11 | ||
|
|
a7d76bfc24 | ||
|
|
f5d0c16f85 | ||
|
|
1388a2558a | ||
|
|
d6dc1c7b86 | ||
|
|
e39269f9f0 | ||
|
|
74f2900db1 |
62
AGENTS.md
Normal file
62
AGENTS.md
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
# Style
|
||||||
|
|
||||||
|
- Two spaces for indentation, no tabs
|
||||||
|
- Use Bash syntax for conditionals: `[[ -f $file ]]`, not `[ -f "$file" ]`
|
||||||
|
|
||||||
|
# Command Naming
|
||||||
|
|
||||||
|
All commands start with `omarchy-`. Prefixes indicate purpose:
|
||||||
|
|
||||||
|
- `cmd-` - check if commands exist, misc utility commands
|
||||||
|
- `pkg-` - package management helpers
|
||||||
|
- `hw-` - hardware detection (return exit codes for use in conditionals)
|
||||||
|
- `refresh-` - copy default config to user's `~/.config/`
|
||||||
|
- `restart-` - restart a component
|
||||||
|
- `launch-` - open applications
|
||||||
|
- `install-` - install optional software
|
||||||
|
- `setup-` - interactive setup wizards
|
||||||
|
- `toggle-` - toggle features on/off
|
||||||
|
- `theme-` - theme management
|
||||||
|
- `update-` - update components
|
||||||
|
|
||||||
|
# Helper Commands
|
||||||
|
|
||||||
|
Use these instead of raw shell commands:
|
||||||
|
|
||||||
|
- `omarchy-cmd-missing` / `omarchy-cmd-present` - check for commands
|
||||||
|
- `omarchy-pkg-missing` / `omarchy-pkg-present` - check for packages
|
||||||
|
- `omarchy-pkg-add` - install packages (handles both pacman and AUR)
|
||||||
|
- `omarchy-hw-asus-rog` - detect ASUS ROG hardware (and similar `hw-*` commands)
|
||||||
|
|
||||||
|
# Config Structure
|
||||||
|
|
||||||
|
- `config/` - default configs copied to `~/.config/`
|
||||||
|
- `default/themed/*.tpl` - templates with `{{ variable }}` placeholders for theme colors
|
||||||
|
- `themes/*/colors.toml` - theme color definitions (accent, background, foreground, color0-15)
|
||||||
|
|
||||||
|
# Refresh Pattern
|
||||||
|
|
||||||
|
To copy a default config to user config with automatic backup:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
omarchy-refresh-config hypr/hyprlock.conf
|
||||||
|
```
|
||||||
|
|
||||||
|
This copies `~/.local/share/omarchy/config/hypr/hyprlock.conf` to `~/.config/hypr/hyprlock.conf`.
|
||||||
|
|
||||||
|
# Migrations
|
||||||
|
|
||||||
|
To create a new migration, run `omarchy-dev-add-migration --no-edit`. This creates a migration file named after the unix timestamp of the last commit.
|
||||||
|
|
||||||
|
Migration format:
|
||||||
|
- No shebang line
|
||||||
|
- Start with an `echo` describing what the migration does
|
||||||
|
|
||||||
|
Example:
|
||||||
|
```bash
|
||||||
|
echo "Disable fingerprint in hyprlock if fingerprint auth is not configured"
|
||||||
|
|
||||||
|
if omarchy-cmd-missing fprintd-list || ! fprintd-list "$USER" 2>/dev/null | grep -q "finger"; then
|
||||||
|
sed -i 's/fingerprint:enabled = .*/fingerprint:enabled = false/' ~/.config/hypr/hyprlock.conf
|
||||||
|
fi
|
||||||
|
```
|
||||||
BIN
applications/icons/Fizzy.png
Normal file
BIN
applications/icons/Fizzy.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 53 KiB |
BIN
applications/icons/Google Maps.png
Normal file
BIN
applications/icons/Google Maps.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 21 KiB |
13
bin/omarchy-battery-present
Executable file
13
bin/omarchy-battery-present
Executable file
@@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Returns true if a battery is present on the system.
|
||||||
|
# Used by the battery monitor and other battery-related checks.
|
||||||
|
|
||||||
|
for bat in /sys/class/power_supply/BAT*; do
|
||||||
|
[[ -r "$bat/present" ]] &&
|
||||||
|
[[ "$(cat "$bat/present")" == "1" ]] &&
|
||||||
|
[[ "$(cat "$bat/type")" == "Battery" ]] &&
|
||||||
|
exit 0
|
||||||
|
done
|
||||||
|
|
||||||
|
exit 1
|
||||||
@@ -1,6 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Returns the battery percentage remaining as an integer.
|
# Returns the battery percentage remaining as an integer.
|
||||||
|
# Used by the battery monitor and the Ctrl + Shift + Super + B hotkey.
|
||||||
|
|
||||||
upower -i $(upower -e | grep BAT) \
|
upower -i $(upower -e | grep BAT) \
|
||||||
| awk -F: '/percentage/ {
|
| awk -F: '/percentage/ {
|
||||||
|
|||||||
17
bin/omarchy-branch-set
Executable file
17
bin/omarchy-branch-set
Executable file
@@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Set the branch for Omarchy's git repository.
|
||||||
|
|
||||||
|
if (($# == 0)); then
|
||||||
|
echo "Usage: omarchy-branch-set [master|rc|dev]"
|
||||||
|
exit 1
|
||||||
|
else
|
||||||
|
branch="$1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "$branch" != "master" && "$branch" != "rc" && "$branch" != "dev" ]]; then
|
||||||
|
echo "Error: Invalid branch '$branch'. Must be one of: master, rc, dev"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
git -C $OMARCHY_PATH switch $branch
|
||||||
21
bin/omarchy-brightness-display
Executable file
21
bin/omarchy-brightness-display
Executable file
@@ -0,0 +1,21 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Adjust brightness on the most likely display device.
|
||||||
|
# Usage: omarchy-brightness-display <step>
|
||||||
|
|
||||||
|
step="${1:-+5%}"
|
||||||
|
|
||||||
|
# Start with the first possible output, then refine to the most likely given an order heuristic.
|
||||||
|
device="$(ls -1 /sys/class/backlight 2>/dev/null | head -n1)"
|
||||||
|
for candidate in amdgpu_bl* intel_backlight acpi_video*; do
|
||||||
|
if [[ -e "/sys/class/backlight/$candidate" ]]; then
|
||||||
|
device="$candidate"
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# Set the actual brightness of the display device.
|
||||||
|
brightnessctl -d "$device" set "$step" >/dev/null
|
||||||
|
|
||||||
|
# Use SwayOSD to display the new brightness setting.
|
||||||
|
omarchy-swayosd-brightness "$(brightnessctl -d "$device" -m | cut -d',' -f4 | tr -d '%')"
|
||||||
12
bin/omarchy-brightness-display-apple
Executable file
12
bin/omarchy-brightness-display-apple
Executable file
@@ -0,0 +1,12 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Adjust the brightness on Apple Studio Displays and Apple XDR Displays using asdcontrol.
|
||||||
|
|
||||||
|
if [[ $# -eq 0 ]]; then
|
||||||
|
echo "Adjust Apple Display Brightness by passing +5000 or -5000 (or any range from 0-60000)"
|
||||||
|
else
|
||||||
|
device="$(sudo asdcontrol --detect /dev/usb/hiddev* | grep ^/dev/usb/hiddev | cut -d: -f1)"
|
||||||
|
sudo asdcontrol "$device" -- "$1" >/dev/null
|
||||||
|
value="$(sudo asdcontrol "$device" | awk -F= '/BRIGHTNESS=/{print $2+0}')"
|
||||||
|
omarchy-swayosd-brightness "$(( value * 100 / 60000 ))"
|
||||||
|
fi
|
||||||
40
bin/omarchy-brightness-keyboard
Executable file
40
bin/omarchy-brightness-keyboard
Executable file
@@ -0,0 +1,40 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Adjust keyboard backlight brightness using available steps.
|
||||||
|
# Usage: omarchy-brightness-keyboard <up|down>
|
||||||
|
|
||||||
|
direction="${1:-up}"
|
||||||
|
|
||||||
|
# Find keyboard backlight device (look for *kbd_backlight* pattern in leds class).
|
||||||
|
device=""
|
||||||
|
for candidate in /sys/class/leds/*kbd_backlight*; do
|
||||||
|
if [[ -e "$candidate" ]]; then
|
||||||
|
device="$(basename "$candidate")"
|
||||||
|
break
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
if [[ -z "$device" ]]; then
|
||||||
|
echo "No keyboard backlight device found" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Get current and max brightness to determine step size.
|
||||||
|
max_brightness="$(brightnessctl -d "$device" max)"
|
||||||
|
current_brightness="$(brightnessctl -d "$device" get)"
|
||||||
|
|
||||||
|
# Calculate step as one unit (keyboards typically have discrete levels like 0-3).
|
||||||
|
if [[ "$direction" == "up" ]]; then
|
||||||
|
new_brightness=$((current_brightness + 1))
|
||||||
|
[[ $new_brightness -gt $max_brightness ]] && new_brightness=$max_brightness
|
||||||
|
else
|
||||||
|
new_brightness=$((current_brightness - 1))
|
||||||
|
[[ $new_brightness -lt 0 ]] && new_brightness=0
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Set the new brightness.
|
||||||
|
brightnessctl -d "$device" set "$new_brightness" >/dev/null
|
||||||
|
|
||||||
|
# Use SwayOSD to display the new brightness setting.
|
||||||
|
percent=$((new_brightness * 100 / max_brightness))
|
||||||
|
omarchy-swayosd-brightness "$percent"
|
||||||
31
bin/omarchy-channel-set
Executable file
31
bin/omarchy-channel-set
Executable file
@@ -0,0 +1,31 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Set the Omarchy channel, which dictates what git branch and package repository is used.
|
||||||
|
#
|
||||||
|
# Stable uses the master branch, which only sees updates on official releases, and
|
||||||
|
# the stable package repository, which typically lags the edge by a month to ensure
|
||||||
|
# better compatibility.
|
||||||
|
#
|
||||||
|
# Edge tracks the latest package repository, but still relies on the master branch,
|
||||||
|
# so new packages which require config changes may cause conflicts or errors.
|
||||||
|
#
|
||||||
|
# Dev tracks the active development dev branch, which may include partial or broken updates,
|
||||||
|
# as well as the latest package repository. This should only be used by Omarchy developers
|
||||||
|
# and people with a lot of experience managing Linux systems.
|
||||||
|
|
||||||
|
if (($# == 0)); then
|
||||||
|
echo "Usage: omarchy-channel-set [stable|rc|edge|dev]"
|
||||||
|
exit 1
|
||||||
|
else
|
||||||
|
channel="$1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$channel" in
|
||||||
|
"stable") omarchy-branch-set "master" && omarchy-refresh-pacman "stable" && sudo pacman -Suu --noconfirm ;;
|
||||||
|
"rc") omarchy-branch-set "rc" && omarchy-refresh-pacman "rc" && sudo pacman -Suu --noconfirm ;;
|
||||||
|
"edge") omarchy-branch-set "master" && omarchy-refresh-pacman "edge" ;;
|
||||||
|
"dev") omarchy-branch-set "dev" && omarchy-refresh-pacman "edge" ;;
|
||||||
|
*) echo "Unknown channel: $channel"; exit 1; ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
omarchy-update -y
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
if [[ $# -eq 0 ]]; then
|
|
||||||
echo "Adjust Apple Display Brightness by passing +5000 or -5000 (or any range from 0-60000)"
|
|
||||||
else
|
|
||||||
DEVICE="$(sudo asdcontrol --detect /dev/usb/hiddev* | grep ^/dev/usb/hiddev | cut -d: -f1)"
|
|
||||||
sudo asdcontrol "$DEVICE" -- "$1" >/dev/null
|
|
||||||
VALUE="$(sudo asdcontrol "$DEVICE" | awk -F= '/BRIGHTNESS=/{print $2+0}')"
|
|
||||||
swayosd-client \
|
|
||||||
--monitor "$(hyprctl monitors -j | jq -r '.[]|select(.focused==true).name')" \
|
|
||||||
--custom-icon display-brightness \
|
|
||||||
--custom-progress "$(awk -v v="$VALUE" 'BEGIN{printf "%.2f", v/60000}')" \
|
|
||||||
--custom-progress-text "$(( VALUE * 100 / 60000 ))%"
|
|
||||||
fi
|
|
||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Switch between audio outputs while preserving the mute status. By default mapped to Super + Mute.
|
||||||
|
|
||||||
focused_monitor="$(hyprctl monitors -j | jq -r '.[] | select(.focused == true).name')"
|
focused_monitor="$(hyprctl monitors -j | jq -r '.[] | select(.focused == true).name')"
|
||||||
|
|
||||||
sinks=$(pactl -f json list sinks | jq '[.[] | select((.ports | length == 0) or ([.ports[]? | .availability != "not available"] | any))]')
|
sinks=$(pactl -f json list sinks | jq '[.[] | select((.ports | length == 0) or ([.ports[]? | .availability != "not available"] | any))]')
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Finish the installation of Omarchy with items that can only be done after logging in.
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
FIRST_RUN_MODE=~/.local/state/omarchy/first-run.mode
|
FIRST_RUN_MODE=~/.local/state/omarchy/first-run.mode
|
||||||
@@ -12,6 +14,7 @@ if [[ -f "$FIRST_RUN_MODE" ]]; then
|
|||||||
bash "$OMARCHY_PATH/install/first-run/firewall.sh"
|
bash "$OMARCHY_PATH/install/first-run/firewall.sh"
|
||||||
bash "$OMARCHY_PATH/install/first-run/dns-resolver.sh"
|
bash "$OMARCHY_PATH/install/first-run/dns-resolver.sh"
|
||||||
bash "$OMARCHY_PATH/install/first-run/gnome-theme.sh"
|
bash "$OMARCHY_PATH/install/first-run/gnome-theme.sh"
|
||||||
|
bash "$OMARCHY_PATH/install/first-run/elephant.sh"
|
||||||
sudo rm -f /etc/sudoers.d/first-run
|
sudo rm -f /etc/sudoers.d/first-run
|
||||||
|
|
||||||
bash "$OMARCHY_PATH/install/first-run/welcome.sh"
|
bash "$OMARCHY_PATH/install/first-run/welcome.sh"
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Returns true if any of the commands passed in as arguments are missing on the system.
|
||||||
|
|
||||||
for cmd in "$@"; do
|
for cmd in "$@"; do
|
||||||
if ! command -v "$cmd" &>/dev/null; then
|
if ! command -v "$cmd" &>/dev/null; then
|
||||||
exit 0
|
exit 0
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Returns true if all the commands passed in as arguments exit on the system.
|
||||||
|
|
||||||
for cmd in "$@"; do
|
for cmd in "$@"; do
|
||||||
command -v "$cmd" &>/dev/null || exit 1
|
command -v "$cmd" &>/dev/null || exit 1
|
||||||
done
|
done
|
||||||
|
|||||||
13
bin/omarchy-cmd-reboot
Executable file
13
bin/omarchy-cmd-reboot
Executable file
@@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Reboot command that first closes all application windows (thus giving them a chance to save state).
|
||||||
|
# This is particularly helpful for applications like Chromium that otherwise won't shutdown cleanly.
|
||||||
|
|
||||||
|
omarchy-state clear re*-required
|
||||||
|
|
||||||
|
# Schedule the reboot to happen after closing windows (detached from terminal)
|
||||||
|
nohup bash -c "sleep 2 && systemctl reboot --no-wall" >/dev/null 2>&1 &
|
||||||
|
|
||||||
|
# Now close all windows
|
||||||
|
omarchy-hyprland-window-close-all
|
||||||
|
sleep 1 # Allow apps like Chrome to shutdown correctly
|
||||||
@@ -1,5 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Start and stop a screenrecording, which will be saved to ~/Videos by default.
|
||||||
|
# Alternative location can be set via OMARCHY_SCREENRECORD_DIR or XDG_VIDEOS_DIR ENVs.
|
||||||
|
|
||||||
[[ -f ~/.config/user-dirs.dirs ]] && source ~/.config/user-dirs.dirs
|
[[ -f ~/.config/user-dirs.dirs ]] && source ~/.config/user-dirs.dirs
|
||||||
OUTPUT_DIR="${OMARCHY_SCREENRECORD_DIR:-${XDG_VIDEOS_DIR:-$HOME/Videos}}"
|
OUTPUT_DIR="${OMARCHY_SCREENRECORD_DIR:-${XDG_VIDEOS_DIR:-$HOME/Videos}}"
|
||||||
|
|
||||||
@@ -8,15 +11,19 @@ if [[ ! -d "$OUTPUT_DIR" ]]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
SCOPE=""
|
DESKTOP_AUDIO="false"
|
||||||
AUDIO="false"
|
MICROPHONE_AUDIO="false"
|
||||||
WEBCAM="false"
|
WEBCAM="false"
|
||||||
|
WEBCAM_DEVICE=""
|
||||||
|
STOP_RECORDING="false"
|
||||||
|
|
||||||
for arg in "$@"; do
|
for arg in "$@"; do
|
||||||
case "$arg" in
|
case "$arg" in
|
||||||
--with-audio) AUDIO="true" ;;
|
--with-desktop-audio) DESKTOP_AUDIO="true" ;;
|
||||||
|
--with-microphone-audio) MICROPHONE_AUDIO="true" ;;
|
||||||
--with-webcam) WEBCAM="true" ;;
|
--with-webcam) WEBCAM="true" ;;
|
||||||
output|region) SCOPE="$arg" ;;
|
--webcam-device=*) WEBCAM_DEVICE="${arg#*=}" ;;
|
||||||
|
--stop-recording) STOP_RECORDING="true"
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
@@ -27,6 +34,15 @@ cleanup_webcam() {
|
|||||||
start_webcam_overlay() {
|
start_webcam_overlay() {
|
||||||
cleanup_webcam
|
cleanup_webcam
|
||||||
|
|
||||||
|
# Auto-detect first available webcam if none specified
|
||||||
|
if [[ -z "$WEBCAM_DEVICE" ]]; then
|
||||||
|
WEBCAM_DEVICE=$(v4l2-ctl --list-devices 2>/dev/null | grep -m1 "^\s*/dev/video" | tr -d '\t')
|
||||||
|
if [[ -z "$WEBCAM_DEVICE" ]]; then
|
||||||
|
notify-send "No webcam devices found" -u critical -t 3000
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
# Get monitor scale
|
# Get monitor scale
|
||||||
local scale=$(hyprctl monitors -j | jq -r '.[] | select(.focused == true) | .scale')
|
local scale=$(hyprctl monitors -j | jq -r '.[] | select(.focused == true) | .scale')
|
||||||
|
|
||||||
@@ -36,7 +52,7 @@ start_webcam_overlay() {
|
|||||||
# Try preferred 16:9 resolutions in order, use first available
|
# Try preferred 16:9 resolutions in order, use first available
|
||||||
local preferred_resolutions=("640x360" "1280x720" "1920x1080")
|
local preferred_resolutions=("640x360" "1280x720" "1920x1080")
|
||||||
local video_size_arg=""
|
local video_size_arg=""
|
||||||
local available_formats=$(v4l2-ctl --list-formats-ext -d /dev/video0 2>/dev/null)
|
local available_formats=$(v4l2-ctl --list-formats-ext -d "$WEBCAM_DEVICE" 2>/dev/null)
|
||||||
|
|
||||||
for resolution in "${preferred_resolutions[@]}"; do
|
for resolution in "${preferred_resolutions[@]}"; do
|
||||||
if echo "$available_formats" | grep -q "$resolution"; then
|
if echo "$available_formats" | grep -q "$resolution"; then
|
||||||
@@ -45,7 +61,7 @@ start_webcam_overlay() {
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
ffplay -f v4l2 $video_size_arg -framerate 30 /dev/video0 \
|
ffplay -f v4l2 $video_size_arg -framerate 30 "$WEBCAM_DEVICE" \
|
||||||
-vf "scale=${target_width}:-1" \
|
-vf "scale=${target_width}:-1" \
|
||||||
-window_title "WebcamOverlay" \
|
-window_title "WebcamOverlay" \
|
||||||
-noborder \
|
-noborder \
|
||||||
@@ -57,27 +73,35 @@ start_webcam_overlay() {
|
|||||||
|
|
||||||
start_screenrecording() {
|
start_screenrecording() {
|
||||||
local filename="$OUTPUT_DIR/screenrecording-$(date +'%Y-%m-%d_%H-%M-%S').mp4"
|
local filename="$OUTPUT_DIR/screenrecording-$(date +'%Y-%m-%d_%H-%M-%S').mp4"
|
||||||
|
local audio_devices=""
|
||||||
local audio_args=""
|
local audio_args=""
|
||||||
|
|
||||||
# Merge audio tracks into one - separate tracks only play one at a time in most players
|
[[ "$DESKTOP_AUDIO" == "true" ]] && audio_devices+="default_output"
|
||||||
[[ "$AUDIO" == "true" ]] && audio_args="-a default_output|default_input"
|
|
||||||
|
|
||||||
gpu-screen-recorder -w "$@" -f 60 -c mp4 -o "$filename" $audio_args &
|
if [[ "$MICROPHONE_AUDIO" == "true" ]]; then
|
||||||
|
# Merge audio tracks into one - separate tracks only play one at a time in most players
|
||||||
|
[[ -n "$audio_devices" ]] && audio_devices+="|"
|
||||||
|
audio_devices+="default_input"
|
||||||
|
fi
|
||||||
|
|
||||||
|
[[ -n "$audio_devices" ]] && audio_args+="-a $audio_devices"
|
||||||
|
|
||||||
|
gpu-screen-recorder -w portal -f 60 -fallback-cpu-encoding yes -o "$filename" $audio_args -ac aac &
|
||||||
toggle_screenrecording_indicator
|
toggle_screenrecording_indicator
|
||||||
}
|
}
|
||||||
|
|
||||||
stop_screenrecording() {
|
stop_screenrecording() {
|
||||||
pkill -SIGINT -f "gpu-screen-recorder" # SIGINT required to save video properly
|
pkill -SIGINT -f "^gpu-screen-recorder" # SIGINT required to save video properly
|
||||||
|
|
||||||
# Wait a maximum of 5 seconds to finish before hard killing
|
# Wait a maximum of 5 seconds to finish before hard killing
|
||||||
local count=0
|
local count=0
|
||||||
while pgrep -f "gpu-screen-recorder" >/dev/null && [ $count -lt 50 ]; do
|
while pgrep -f "^gpu-screen-recorder" >/dev/null && [ $count -lt 50 ]; do
|
||||||
sleep 0.1
|
sleep 0.1
|
||||||
count=$((count + 1))
|
count=$((count + 1))
|
||||||
done
|
done
|
||||||
|
|
||||||
if pgrep -f "gpu-screen-recorder" >/dev/null; then
|
if pgrep -f "^gpu-screen-recorder" >/dev/null; then
|
||||||
pkill -9 -f "gpu-screen-recorder"
|
pkill -9 -f "^gpu-screen-recorder"
|
||||||
cleanup_webcam
|
cleanup_webcam
|
||||||
notify-send "Screen recording error" "Recording process had to be force-killed. Video may be corrupted." -u critical -t 5000
|
notify-send "Screen recording error" "Recording process had to be force-killed. Video may be corrupted." -u critical -t 5000
|
||||||
else
|
else
|
||||||
@@ -92,51 +116,19 @@ toggle_screenrecording_indicator() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
screenrecording_active() {
|
screenrecording_active() {
|
||||||
pgrep -f "gpu-screen-recorder" >/dev/null || pgrep -x slurp >/dev/null || pgrep -f "WebcamOverlay" >/dev/null
|
pgrep -f "^gpu-screen-recorder" >/dev/null || pgrep -f "WebcamOverlay" >/dev/null
|
||||||
}
|
}
|
||||||
|
|
||||||
if screenrecording_active; then
|
if screenrecording_active; then
|
||||||
if pgrep -x slurp >/dev/null; then
|
if pgrep -f "WebcamOverlay" >/dev/null && ! pgrep -f "^gpu-screen-recorder" >/dev/null; then
|
||||||
pkill -x slurp 2>/dev/null
|
|
||||||
elif pgrep -f "WebcamOverlay" >/dev/null && ! pgrep -f "gpu-screen-recorder" >/dev/null; then
|
|
||||||
cleanup_webcam
|
cleanup_webcam
|
||||||
else
|
else
|
||||||
stop_screenrecording
|
stop_screenrecording
|
||||||
fi
|
fi
|
||||||
elif [[ "$SCOPE" == "output" ]]; then
|
elif [[ "$STOP_RECORDING" == "false" ]]; then
|
||||||
[[ "$WEBCAM" == "true" ]] && start_webcam_overlay
|
[[ "$WEBCAM" == "true" ]] && start_webcam_overlay
|
||||||
|
|
||||||
if ! output=$(slurp -o -f "%o"); then
|
start_screenrecording || cleanup_webcam
|
||||||
[[ "$WEBCAM" == "true" ]] && cleanup_webcam
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -z "$output" ]]; then
|
|
||||||
notify-send "Error" "Could not detect monitor" -u critical
|
|
||||||
[[ "$WEBCAM" == "true" ]] && cleanup_webcam
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
start_screenrecording "$output"
|
|
||||||
else
|
else
|
||||||
[[ "$WEBCAM" == "true" ]] && start_webcam_overlay
|
|
||||||
|
|
||||||
scale=$(hyprctl monitors -j | jq -r '.[] | select(.focused == true) | .scale')
|
|
||||||
|
|
||||||
if ! region=$(slurp -f "%wx%h+%x+%y"); then
|
|
||||||
[[ "$WEBCAM" == "true" ]] && cleanup_webcam
|
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "$region" =~ ^([0-9]+)x([0-9]+)\+([0-9]+)\+([0-9]+)$ ]]; then
|
|
||||||
w=$(awk "BEGIN {printf \"%.0f\", ${BASH_REMATCH[1]} * $scale}")
|
|
||||||
h=$(awk "BEGIN {printf \"%.0f\", ${BASH_REMATCH[2]} * $scale}")
|
|
||||||
x=$(awk "BEGIN {printf \"%.0f\", ${BASH_REMATCH[3]} * $scale}")
|
|
||||||
y=$(awk "BEGIN {printf \"%.0f\", ${BASH_REMATCH[4]} * $scale}")
|
|
||||||
scaled_region="${w}x${h}+${x}+${y}"
|
|
||||||
else
|
|
||||||
scaled_region="$region"
|
|
||||||
fi
|
|
||||||
|
|
||||||
start_screenrecording region -region "$scaled_region"
|
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,28 +1,35 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Run the Omarchy screensaver using random effects from TTE.
|
||||||
|
|
||||||
screensaver_in_focus() {
|
screensaver_in_focus() {
|
||||||
hyprctl activewindow -j | jq -e '.class == "Screensaver"' >/dev/null 2>&1
|
hyprctl activewindow -j | jq -e '.class == "org.omarchy.screensaver"' >/dev/null 2>&1
|
||||||
}
|
}
|
||||||
|
|
||||||
exit_screensaver() {
|
exit_screensaver() {
|
||||||
hyprctl keyword cursor:invisible false
|
hyprctl keyword cursor:invisible false &>/dev/null || true
|
||||||
pkill -x tte 2>/dev/null
|
pkill -x tte 2>/dev/null
|
||||||
pkill -f "alacritty --class Screensaver" 2>/dev/null
|
pkill -f org.omarchy.screensaver 2>/dev/null
|
||||||
exit 0
|
exit 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Exit the screensaver on signals and input from keyboard and mouse
|
||||||
trap exit_screensaver SIGINT SIGTERM SIGHUP SIGQUIT
|
trap exit_screensaver SIGINT SIGTERM SIGHUP SIGQUIT
|
||||||
|
|
||||||
|
printf '\033]11;rgb:00/00/00\007' # Set background color to black
|
||||||
|
|
||||||
hyprctl keyword cursor:invisible true &>/dev/null
|
hyprctl keyword cursor:invisible true &>/dev/null
|
||||||
|
|
||||||
while true; do
|
tty=$(tty 2>/dev/null)
|
||||||
effect=$(tte 2>&1 | grep -oP '{\K[^}]+' | tr ',' ' ' | tr ' ' '\n' | sed -n '/^beams$/,$p' | sort -u | shuf -n1)
|
|
||||||
tte -i ~/.config/omarchy/branding/screensaver.txt \
|
|
||||||
--frame-rate 240 --canvas-width 0 --canvas-height $(($(tput lines) - 2)) --anchor-canvas c --anchor-text c \
|
|
||||||
"$effect" &
|
|
||||||
|
|
||||||
while pgrep -x tte >/dev/null; do
|
while true; do
|
||||||
if read -n 1 -t 3 || ! screensaver_in_focus; then
|
tte -i ~/.config/omarchy/branding/screensaver.txt \
|
||||||
|
--frame-rate 120 --canvas-width 0 --canvas-height 0 --reuse-canvas --anchor-canvas c --anchor-text c\
|
||||||
|
--random-effect --exclude-effects dev_worm \
|
||||||
|
--no-eol --no-restore-cursor &
|
||||||
|
|
||||||
|
while pgrep -t "${tty#/dev/}" -x tte >/dev/null; do
|
||||||
|
if read -n1 -t 1 || ! screensaver_in_focus; then
|
||||||
exit_screensaver
|
exit_screensaver
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|||||||
@@ -1,5 +1,9 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Take a screenshot of the whole screen, a specific window, or a user-drawn region.
|
||||||
|
# Saves to ~/Pictures by default, but that can be changed via OMARCHY_SCREENSHOT_DIR or XDG_PICTURES_DIR ENVs.
|
||||||
|
# Editor defaults to Satty but can be changed via --editor=<name> or OMARCHY_SCREENSHOT_EDITOR env
|
||||||
|
|
||||||
[[ -f ~/.config/user-dirs.dirs ]] && source ~/.config/user-dirs.dirs
|
[[ -f ~/.config/user-dirs.dirs ]] && source ~/.config/user-dirs.dirs
|
||||||
OUTPUT_DIR="${OMARCHY_SCREENSHOT_DIR:-${XDG_PICTURES_DIR:-$HOME/Pictures}}"
|
OUTPUT_DIR="${OMARCHY_SCREENSHOT_DIR:-${XDG_PICTURES_DIR:-$HOME/Pictures}}"
|
||||||
|
|
||||||
@@ -10,6 +14,33 @@ fi
|
|||||||
|
|
||||||
pkill slurp && exit 0
|
pkill slurp && exit 0
|
||||||
|
|
||||||
|
SCREENSHOT_EDITOR="${OMARCHY_SCREENSHOT_EDITOR:-satty}"
|
||||||
|
|
||||||
|
# Parse --editor flag from any position
|
||||||
|
ARGS=()
|
||||||
|
for arg in "$@"; do
|
||||||
|
if [[ "$arg" == --editor=* ]]; then
|
||||||
|
SCREENSHOT_EDITOR="${arg#--editor=}"
|
||||||
|
else
|
||||||
|
ARGS+=("$arg")
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
set -- "${ARGS[@]}"
|
||||||
|
|
||||||
|
open_editor() {
|
||||||
|
local filepath="$1"
|
||||||
|
if [[ "$SCREENSHOT_EDITOR" == "satty" ]]; then
|
||||||
|
satty --filename "$filepath" \
|
||||||
|
--output-filename "$filepath" \
|
||||||
|
--early-exit \
|
||||||
|
--actions-on-enter save-to-clipboard \
|
||||||
|
--save-after-copy \
|
||||||
|
--copy-command 'wl-copy'
|
||||||
|
else
|
||||||
|
$SCREENSHOT_EDITOR "$filepath"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
MODE="${1:-smart}"
|
MODE="${1:-smart}"
|
||||||
PROCESSING="${2:-slurp}"
|
PROCESSING="${2:-slurp}"
|
||||||
|
|
||||||
@@ -43,7 +74,7 @@ case "$MODE" in
|
|||||||
SELECTION=$(echo "$RECTS" | slurp 2>/dev/null)
|
SELECTION=$(echo "$RECTS" | slurp 2>/dev/null)
|
||||||
kill $PID 2>/dev/null
|
kill $PID 2>/dev/null
|
||||||
|
|
||||||
# If the selction area is L * W < 20, we'll assume you were trying to select whichever
|
# If the selection area is L * W < 20, we'll assume you were trying to select whichever
|
||||||
# window or output it was inside of to prevent accidental 2px snapshots
|
# window or output it was inside of to prevent accidental 2px snapshots
|
||||||
if [[ "$SELECTION" =~ ^([0-9]+),([0-9]+)[[:space:]]([0-9]+)x([0-9]+)$ ]]; then
|
if [[ "$SELECTION" =~ ^([0-9]+),([0-9]+)[[:space:]]([0-9]+)x([0-9]+)$ ]]; then
|
||||||
if (( ${BASH_REMATCH[3]} * ${BASH_REMATCH[4]} < 20 )); then
|
if (( ${BASH_REMATCH[3]} * ${BASH_REMATCH[4]} < 20 )); then
|
||||||
@@ -68,16 +99,19 @@ case "$MODE" in
|
|||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
[ -z "$SELECTION" ] && exit 0
|
[[ -z $SELECTION ]] && exit 0
|
||||||
|
|
||||||
|
FILENAME="screenshot-$(date +'%Y-%m-%d_%H-%M-%S').png"
|
||||||
|
FILEPATH="$OUTPUT_DIR/$FILENAME"
|
||||||
|
|
||||||
if [[ $PROCESSING == "slurp" ]]; then
|
if [[ $PROCESSING == "slurp" ]]; then
|
||||||
grim -g "$SELECTION" - |
|
grim -g "$SELECTION" "$FILEPATH" || exit 1
|
||||||
satty --filename - \
|
wl-copy < "$FILEPATH"
|
||||||
--output-filename "$OUTPUT_DIR/screenshot-$(date +'%Y-%m-%d_%H-%M-%S').png" \
|
|
||||||
--early-exit \
|
(
|
||||||
--actions-on-enter save-to-clipboard \
|
ACTION=$(notify-send "Screenshot copied & saved" "Click to edit" -t 10000 -i "$FILEPATH" -A "default=edit")
|
||||||
--save-after-copy \
|
[[ "$ACTION" == "default" ]] && open_editor "$FILEPATH"
|
||||||
--copy-command 'wl-copy'
|
) &
|
||||||
else
|
else
|
||||||
grim -g "$SELECTION" - | wl-copy
|
grim -g "$SELECTION" - | wl-copy
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Share clipboard, file, or folder using LocalSend. Bound to Super + Ctrl + S by default.
|
||||||
|
|
||||||
if (($# == 0)); then
|
if (($# == 0)); then
|
||||||
echo "Usage: omarchy-cmd-share [clipboard|file|folder]"
|
echo "Usage: omarchy-cmd-share [clipboard|file|folder]"
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
13
bin/omarchy-cmd-shutdown
Executable file
13
bin/omarchy-cmd-shutdown
Executable file
@@ -0,0 +1,13 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Shutdown command that first closes all application windows (thus giving them a chance to save state).
|
||||||
|
# This is particularly helpful for applications like Chromium that otherwise won't shutdown cleanly.
|
||||||
|
|
||||||
|
omarchy-state clear re*-required
|
||||||
|
|
||||||
|
# Schedule the shutdown to happen after closing windows (detached from terminal)
|
||||||
|
nohup bash -c "sleep 2 && systemctl poweroff --no-wall" >/dev/null 2>&1 &
|
||||||
|
|
||||||
|
# Now close all windows
|
||||||
|
omarchy-hyprland-window-close-all
|
||||||
|
sleep 1 # Allow apps like Chrome to shutdown correctly
|
||||||
@@ -1,13 +1,18 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Returns the current working directory of the active terminal window,
|
||||||
|
# so a new terminal window can be started in the same directory.
|
||||||
|
|
||||||
# Go from current active terminal to its child shell process and run cwd there
|
# Go from current active terminal to its child shell process and run cwd there
|
||||||
terminal_pid=$(hyprctl activewindow | awk '/pid:/ {print $2}')
|
terminal_pid=$(hyprctl activewindow | awk '/pid:/ {print $2}')
|
||||||
shell_pid=$(pgrep -P "$terminal_pid" | tail -n1)
|
shell_pid=$(pgrep -P "$terminal_pid" | tail -n1)
|
||||||
|
|
||||||
if [[ -n $shell_pid ]]; then
|
if [[ -n $shell_pid ]]; then
|
||||||
cwd=$(readlink -f "/proc/$shell_pid/cwd" 2>/dev/null)
|
cwd=$(readlink -f "/proc/$shell_pid/cwd" 2>/dev/null)
|
||||||
|
shell=$(readlink -f "/proc/$shell_pid/exe" 2>/dev/null)
|
||||||
|
|
||||||
if [[ -d $cwd ]]; then
|
# Check if $shell is a valid shell and $cwd is a directory.
|
||||||
|
if grep -qs "$shell" /etc/shells && [[ -d $cwd ]]; then
|
||||||
echo "$cwd"
|
echo "$cwd"
|
||||||
else
|
else
|
||||||
echo "$HOME"
|
echo "$HOME"
|
||||||
|
|||||||
@@ -1,7 +1,36 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Return exhaustive debugging information about the system to help diagnose problems.
|
||||||
|
|
||||||
|
NO_SUDO=false
|
||||||
|
PRINT_ONLY=false
|
||||||
|
|
||||||
|
while [[ $# -gt 0 ]]; do
|
||||||
|
case "$1" in
|
||||||
|
--no-sudo)
|
||||||
|
NO_SUDO=true
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
--print)
|
||||||
|
PRINT_ONLY=true
|
||||||
|
shift
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Unknown option: $1"
|
||||||
|
echo "Usage: omarchy-debug [--no-sudo] [--print]"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
LOG_FILE="/tmp/omarchy-debug.log"
|
LOG_FILE="/tmp/omarchy-debug.log"
|
||||||
|
|
||||||
|
if [ "$NO_SUDO" = true ]; then
|
||||||
|
DMESG_OUTPUT="(skipped - --no-sudo flag used)"
|
||||||
|
else
|
||||||
|
DMESG_OUTPUT="$(sudo dmesg)"
|
||||||
|
fi
|
||||||
|
|
||||||
cat > "$LOG_FILE" <<EOF
|
cat > "$LOG_FILE" <<EOF
|
||||||
Date: $(date)
|
Date: $(date)
|
||||||
Hostname: $(hostname)
|
Hostname: $(hostname)
|
||||||
@@ -15,7 +44,7 @@ $(inxi -Farz)
|
|||||||
=========================================
|
=========================================
|
||||||
DMESG
|
DMESG
|
||||||
=========================================
|
=========================================
|
||||||
$(sudo dmesg)
|
$DMESG_OUTPUT
|
||||||
|
|
||||||
=========================================
|
=========================================
|
||||||
JOURNALCTL (CURRENT BOOT, ERRORS ONLY)
|
JOURNALCTL (CURRENT BOOT, ERRORS ONLY)
|
||||||
@@ -28,6 +57,11 @@ INSTALLED PACKAGES
|
|||||||
$({ expac -S '%n %v (%r)' $(pacman -Qqe) 2>/dev/null; comm -13 <(pacman -Sql | sort) <(pacman -Qqe | sort) | xargs -r expac -Q '%n %v (AUR)'; } | sort)
|
$({ expac -S '%n %v (%r)' $(pacman -Qqe) 2>/dev/null; comm -13 <(pacman -Sql | sort) <(pacman -Qqe | sort) | xargs -r expac -Q '%n %v (AUR)'; } | sort)
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
if [ "$PRINT_ONLY" = true ]; then
|
||||||
|
cat "$LOG_FILE"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
OPTIONS=("View log" "Save in current directory")
|
OPTIONS=("View log" "Save in current directory")
|
||||||
if ping -c 1 8.8.8.8 >/dev/null 2>&1; then
|
if ping -c 1 8.8.8.8 >/dev/null 2>&1; then
|
||||||
OPTIONS=("Upload log" "${OPTIONS[@]}")
|
OPTIONS=("Upload log" "${OPTIONS[@]}")
|
||||||
|
|||||||
@@ -1,7 +1,14 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# FIXME: Update behavior
|
# Creates a new Omarchy migration named after the unix timestamp of the last commit.
|
||||||
|
# Only intended for Omarchy developers.
|
||||||
|
|
||||||
cd ~/.local/share/omarchy
|
cd ~/.local/share/omarchy
|
||||||
migration_file="$HOME/.local/share/omarchy/migrations/$(git log -1 --format=%cd --date=unix).sh"
|
migration_file="$HOME/.local/share/omarchy/migrations/$(git log -1 --format=%cd --date=unix).sh"
|
||||||
touch $migration_file
|
touch $migration_file
|
||||||
nvim $migration_file
|
|
||||||
|
if [[ "$1" != "--no-edit" ]]; then
|
||||||
|
nvim $migration_file
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo $migration_file
|
||||||
|
|||||||
@@ -1,344 +0,0 @@
|
|||||||
#!/usr/bin/env python3
|
|
||||||
"""
|
|
||||||
Omarchy Disk Configuration Tool
|
|
||||||
|
|
||||||
Interactive partition editor and validator for Omarchy installations.
|
|
||||||
"""
|
|
||||||
|
|
||||||
import json
|
|
||||||
import sys
|
|
||||||
from pathlib import Path
|
|
||||||
|
|
||||||
|
|
||||||
def _find_root_partition(disk_config):
|
|
||||||
for dev_mod in disk_config.device_modifications:
|
|
||||||
for part in dev_mod.partitions:
|
|
||||||
if part.mountpoint == Path('/'):
|
|
||||||
return part
|
|
||||||
|
|
||||||
if part.btrfs_subvols:
|
|
||||||
for subvol in part.btrfs_subvols:
|
|
||||||
if subvol.mountpoint == Path('/'):
|
|
||||||
return part
|
|
||||||
|
|
||||||
return None
|
|
||||||
|
|
||||||
|
|
||||||
def validate_disk_config(config, interactive=True):
|
|
||||||
from archinstall.lib.models.device import FilesystemType, Size, Unit, EncryptionType
|
|
||||||
from archinstall.lib.output import info, warn
|
|
||||||
|
|
||||||
if not config.disk_config:
|
|
||||||
return 'CONTINUE'
|
|
||||||
|
|
||||||
validation_warnings = []
|
|
||||||
|
|
||||||
boot_partition = None
|
|
||||||
for dev_mod in config.disk_config.device_modifications:
|
|
||||||
for part in dev_mod.partitions:
|
|
||||||
if part.mountpoint == Path('/boot') or part.mountpoint == Path('/efi'):
|
|
||||||
boot_partition = part
|
|
||||||
break
|
|
||||||
|
|
||||||
if boot_partition:
|
|
||||||
min_boot_size = Size(2, Unit.GiB, boot_partition.length.sector_size)
|
|
||||||
if boot_partition.length >= min_boot_size:
|
|
||||||
size_gb = boot_partition.length.convert(Unit.GiB).value
|
|
||||||
info(f'✓ Boot partition size: {size_gb:.1f} GiB')
|
|
||||||
else:
|
|
||||||
size_mb = boot_partition.length.convert(Unit.MiB).value
|
|
||||||
warn(f'⚠ Boot partition is only {size_mb:.0f} MiB')
|
|
||||||
warn(' Omarchy recommends at least 2 GiB for boot partition')
|
|
||||||
warn(' Multiple kernels may not fit')
|
|
||||||
validation_warnings.append('boot_size')
|
|
||||||
else:
|
|
||||||
warn('⚠ Could not find boot partition (/boot or /efi)')
|
|
||||||
warn(' System may not boot correctly')
|
|
||||||
validation_warnings.append('no_boot')
|
|
||||||
|
|
||||||
root_partition = _find_root_partition(config.disk_config)
|
|
||||||
|
|
||||||
if root_partition:
|
|
||||||
if root_partition.fs_type == FilesystemType.Btrfs:
|
|
||||||
info('✓ Root filesystem is btrfs')
|
|
||||||
|
|
||||||
if root_partition.btrfs_subvols:
|
|
||||||
subvol_names = [str(sv.name) for sv in root_partition.btrfs_subvols]
|
|
||||||
subvol_mounts = {str(sv.mountpoint): str(sv.name) for sv in root_partition.btrfs_subvols}
|
|
||||||
|
|
||||||
required_subvols = {
|
|
||||||
'/': '@',
|
|
||||||
'/home': '@home',
|
|
||||||
'/var/log': '@log',
|
|
||||||
'/var/cache/pacman/pkg': '@pkg',
|
|
||||||
}
|
|
||||||
|
|
||||||
missing_subvols = []
|
|
||||||
for mount, expected_name in required_subvols.items():
|
|
||||||
if mount not in subvol_mounts:
|
|
||||||
missing_subvols.append(f'{expected_name} → {mount}')
|
|
||||||
elif subvol_mounts[mount] != expected_name:
|
|
||||||
warn(f'⚠ Subvolume at {mount} is named "{subvol_mounts[mount]}" not "{expected_name}"')
|
|
||||||
|
|
||||||
if missing_subvols:
|
|
||||||
warn(f'⚠ Missing recommended subvolumes: {", ".join(missing_subvols)}')
|
|
||||||
warn(' Omarchy recommends: @, @home, @log, @pkg')
|
|
||||||
warn(' Some features (like Snapper) may not work optimally')
|
|
||||||
info(f' Current subvolumes: {", ".join(subvol_names)}')
|
|
||||||
validation_warnings.append('missing_subvols')
|
|
||||||
else:
|
|
||||||
info(f'✓ Btrfs subvolumes: {", ".join(subvol_names)}')
|
|
||||||
else:
|
|
||||||
warn('⚠ Btrfs partition has no subvolumes defined')
|
|
||||||
warn(' Omarchy recommends subvolumes for snapshots')
|
|
||||||
warn(' Required: @ (root), @home, @log, @pkg')
|
|
||||||
validation_warnings.append('no_subvols')
|
|
||||||
else:
|
|
||||||
fs_name = root_partition.fs_type.value if root_partition.fs_type else 'unknown'
|
|
||||||
warn(f'⚠ Root filesystem is {fs_name}, not btrfs')
|
|
||||||
warn(' Omarchy is designed for btrfs with snapshots')
|
|
||||||
warn(' Some features may not work correctly')
|
|
||||||
validation_warnings.append('not_btrfs')
|
|
||||||
|
|
||||||
is_encrypted = False
|
|
||||||
if config.disk_config.disk_encryption:
|
|
||||||
enc = config.disk_config.disk_encryption
|
|
||||||
if enc.encryption_type != EncryptionType.NoEncryption:
|
|
||||||
is_encrypted = root_partition in enc.partitions
|
|
||||||
|
|
||||||
if is_encrypted:
|
|
||||||
info('✓ Root partition is encrypted with LUKS')
|
|
||||||
|
|
||||||
if config.disk_config.disk_encryption.iter_time != 2000:
|
|
||||||
old_time = config.disk_config.disk_encryption.iter_time
|
|
||||||
config.disk_config.disk_encryption.iter_time = 2000
|
|
||||||
info(f'✓ Adjusted iteration time: {old_time}ms → 2000ms')
|
|
||||||
else:
|
|
||||||
info('✓ Iteration time: 2000ms (optimal)')
|
|
||||||
else:
|
|
||||||
warn('⚠ Root partition is NOT encrypted')
|
|
||||||
warn(' Omarchy recommends LUKS encryption for security')
|
|
||||||
validation_warnings.append('no_encryption')
|
|
||||||
else:
|
|
||||||
warn('⚠ Could not identify root partition')
|
|
||||||
validation_warnings.append('no_root')
|
|
||||||
|
|
||||||
if validation_warnings and interactive:
|
|
||||||
import subprocess
|
|
||||||
import shutil
|
|
||||||
|
|
||||||
gum_path = shutil.which('gum')
|
|
||||||
if gum_path:
|
|
||||||
warn('')
|
|
||||||
|
|
||||||
try:
|
|
||||||
result = subprocess.run(
|
|
||||||
['gum', 'choose', '--header', 'Validation warnings detected. What would you like to do?',
|
|
||||||
'Re-edit partitions', 'Continue anyway', 'Abort'],
|
|
||||||
capture_output=True,
|
|
||||||
text=True,
|
|
||||||
)
|
|
||||||
|
|
||||||
choice = result.stdout.strip() if result.stdout else ''
|
|
||||||
|
|
||||||
if choice == 'Re-edit partitions':
|
|
||||||
return 'RE_EDIT'
|
|
||||||
elif choice == 'Abort':
|
|
||||||
return 'ABORT'
|
|
||||||
else:
|
|
||||||
info('Continuing despite warnings')
|
|
||||||
return 'CONTINUE'
|
|
||||||
|
|
||||||
except (subprocess.CalledProcessError, KeyboardInterrupt):
|
|
||||||
return 'ABORT'
|
|
||||||
|
|
||||||
return 'CONTINUE'
|
|
||||||
|
|
||||||
|
|
||||||
def apply_omarchy_partition_defaults():
|
|
||||||
import archinstall.lib.interactions.disk_conf as disk_conf_module
|
|
||||||
from archinstall.lib.models.device import (
|
|
||||||
PartitionModification, ModificationStatus, PartitionType,
|
|
||||||
Size, Unit, SectorSize, FilesystemType, PartitionFlag,
|
|
||||||
DeviceModification, BDevice
|
|
||||||
)
|
|
||||||
from archinstall.lib.interactions.disk_conf import get_default_btrfs_subvols
|
|
||||||
from archinstall.lib.disk.device_handler import device_handler
|
|
||||||
|
|
||||||
def _boot_partition_2gib(sector_size: SectorSize, using_gpt: bool) -> PartitionModification:
|
|
||||||
flags = [PartitionFlag.BOOT]
|
|
||||||
size = Size(2, Unit.GiB, sector_size)
|
|
||||||
start = Size(1, Unit.MiB, sector_size)
|
|
||||||
if using_gpt:
|
|
||||||
flags.append(PartitionFlag.ESP)
|
|
||||||
|
|
||||||
return PartitionModification(
|
|
||||||
status=ModificationStatus.Create,
|
|
||||||
type=PartitionType.Primary,
|
|
||||||
start=start,
|
|
||||||
length=size,
|
|
||||||
mountpoint=Path('/boot'),
|
|
||||||
fs_type=FilesystemType.Fat32,
|
|
||||||
flags=flags,
|
|
||||||
)
|
|
||||||
|
|
||||||
def _select_main_filesystem_btrfs() -> FilesystemType:
|
|
||||||
return FilesystemType.Btrfs
|
|
||||||
|
|
||||||
def _select_mount_options_compressed() -> list[str]:
|
|
||||||
return ['compress=zstd']
|
|
||||||
|
|
||||||
def _suggest_single_disk_auto_subvolumes(
|
|
||||||
device: BDevice,
|
|
||||||
filesystem_type: FilesystemType | None = None,
|
|
||||||
separate_home: bool | None = None,
|
|
||||||
):
|
|
||||||
if not filesystem_type:
|
|
||||||
filesystem_type = FilesystemType.Btrfs
|
|
||||||
|
|
||||||
if filesystem_type == FilesystemType.Btrfs:
|
|
||||||
using_subvolumes = True
|
|
||||||
mount_options = ['compress=zstd']
|
|
||||||
else:
|
|
||||||
using_subvolumes = False
|
|
||||||
mount_options = []
|
|
||||||
|
|
||||||
sector_size = device.device_info.sector_size
|
|
||||||
device_modification = DeviceModification(device, wipe=True)
|
|
||||||
using_gpt = device_handler.partition_table.is_gpt()
|
|
||||||
|
|
||||||
boot_partition = _boot_partition_2gib(sector_size, using_gpt)
|
|
||||||
device_modification.add_partition(boot_partition)
|
|
||||||
|
|
||||||
total_size = device.device_info.total_size
|
|
||||||
available_space = total_size - boot_partition.length - Size(1, Unit.MiB, sector_size)
|
|
||||||
|
|
||||||
root_partition = PartitionModification(
|
|
||||||
status=ModificationStatus.Create,
|
|
||||||
type=PartitionType.Primary,
|
|
||||||
start=boot_partition.start + boot_partition.length,
|
|
||||||
length=available_space,
|
|
||||||
mountpoint=None if using_subvolumes else Path('/'),
|
|
||||||
fs_type=filesystem_type,
|
|
||||||
mount_options=mount_options,
|
|
||||||
)
|
|
||||||
|
|
||||||
if using_subvolumes:
|
|
||||||
root_partition.btrfs_subvols = get_default_btrfs_subvols()
|
|
||||||
|
|
||||||
device_modification.add_partition(root_partition)
|
|
||||||
return device_modification
|
|
||||||
|
|
||||||
disk_conf_module._boot_partition = _boot_partition_2gib
|
|
||||||
disk_conf_module.select_main_filesystem_format = _select_main_filesystem_btrfs
|
|
||||||
disk_conf_module.select_mount_options = _select_mount_options_compressed
|
|
||||||
disk_conf_module.suggest_single_disk_layout = _suggest_single_disk_auto_subvolumes
|
|
||||||
|
|
||||||
|
|
||||||
def load_config(config_file: Path, creds_file: Path | None = None):
|
|
||||||
from archinstall.lib.args import ArchConfig, Arguments
|
|
||||||
|
|
||||||
with open(config_file) as f:
|
|
||||||
config_data = json.load(f)
|
|
||||||
|
|
||||||
if creds_file and creds_file.exists():
|
|
||||||
with open(creds_file) as f:
|
|
||||||
creds_data = json.load(f)
|
|
||||||
config_data.update(creds_data)
|
|
||||||
|
|
||||||
args = Arguments(
|
|
||||||
config=config_file,
|
|
||||||
creds=creds_file,
|
|
||||||
mountpoint=Path('/mnt'),
|
|
||||||
silent=True,
|
|
||||||
)
|
|
||||||
|
|
||||||
return ArchConfig.from_config(config_data, args)
|
|
||||||
|
|
||||||
|
|
||||||
def save_config(config, output_file: Path):
|
|
||||||
from archinstall.lib.output import info
|
|
||||||
|
|
||||||
try:
|
|
||||||
config_dict = config.safe_json()
|
|
||||||
with open(output_file, 'w') as f:
|
|
||||||
json.dump(config_dict, f, indent=2, default=str)
|
|
||||||
info(f'✓ Configuration saved to: {output_file}')
|
|
||||||
except Exception as e:
|
|
||||||
from archinstall.lib.output import error
|
|
||||||
error(f'Failed to save config: {e}')
|
|
||||||
raise
|
|
||||||
|
|
||||||
|
|
||||||
def main():
|
|
||||||
import argparse
|
|
||||||
|
|
||||||
parser = argparse.ArgumentParser(description='Omarchy Disk Configuration Tool')
|
|
||||||
parser.add_argument('--config', type=Path, required=True, help='Path to config file')
|
|
||||||
parser.add_argument('--creds', type=Path, help='Path to credentials file')
|
|
||||||
parser.add_argument('--output', type=Path, help='Output path (default: overwrites input)')
|
|
||||||
parser.add_argument('--non-interactive', action='store_true', help='Skip interactive prompts')
|
|
||||||
|
|
||||||
args = parser.parse_args()
|
|
||||||
|
|
||||||
output_file = args.output or args.config
|
|
||||||
|
|
||||||
if not args.config.exists():
|
|
||||||
print(f'ERROR: Config file not found: {args.config}', file=sys.stderr)
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
if args.creds and not args.creds.exists():
|
|
||||||
print(f'ERROR: Credentials file not found: {args.creds}', file=sys.stderr)
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
try:
|
|
||||||
from archinstall.lib.output import info, error
|
|
||||||
from archinstall.lib.disk.disk_menu import DiskLayoutConfigurationMenu
|
|
||||||
from archinstall.tui.curses_menu import Tui
|
|
||||||
|
|
||||||
apply_omarchy_partition_defaults()
|
|
||||||
|
|
||||||
info('Loading configuration...')
|
|
||||||
config = load_config(args.config, args.creds)
|
|
||||||
|
|
||||||
if not config.disk_config:
|
|
||||||
error('No disk configuration found in config file')
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
while True:
|
|
||||||
info('Launching partition editor...')
|
|
||||||
|
|
||||||
with Tui():
|
|
||||||
edited_disk_config = DiskLayoutConfigurationMenu(config.disk_config).run()
|
|
||||||
if edited_disk_config:
|
|
||||||
config.disk_config = edited_disk_config
|
|
||||||
info('✓ Partition configuration updated')
|
|
||||||
else:
|
|
||||||
info('No changes made in partition editor')
|
|
||||||
|
|
||||||
interactive = not args.non_interactive
|
|
||||||
validation_result = validate_disk_config(config, interactive=interactive)
|
|
||||||
|
|
||||||
if validation_result == 'RE_EDIT':
|
|
||||||
continue
|
|
||||||
elif validation_result == 'ABORT':
|
|
||||||
info('Disk configuration cancelled by user')
|
|
||||||
sys.exit(1)
|
|
||||||
else:
|
|
||||||
break
|
|
||||||
|
|
||||||
save_config(config, output_file)
|
|
||||||
info('✓ Disk configuration complete!')
|
|
||||||
|
|
||||||
except KeyboardInterrupt:
|
|
||||||
print('\nCancelled by user', file=sys.stderr)
|
|
||||||
sys.exit(1)
|
|
||||||
except Exception as e:
|
|
||||||
print(f'ERROR: {e}', file=sys.stderr)
|
|
||||||
import traceback
|
|
||||||
traceback.print_exc()
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
main()
|
|
||||||
@@ -1,6 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Drive, like /dev/nvme0, to display information about
|
# Returns drive information about a given volumne, like /dev/nvme0, which is used by omarchy-drive-select.
|
||||||
|
|
||||||
if (($# == 0)); then
|
if (($# == 0)); then
|
||||||
echo "Usage: omarchy-drive-info [/dev/drive]"
|
echo "Usage: omarchy-drive-info [/dev/drive]"
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# Select a drive from a list with info that includes space and brand
|
# Select a drive from a list with info that includes space and brand. Used by omarchy-drive-set-password.
|
||||||
|
|
||||||
if (($# == 0)); then
|
if (($# == 0)); then
|
||||||
drives=$(lsblk -dpno NAME | grep -E '/dev/(sd|hd|vd|nvme|mmcblk|xv)')
|
drives=$(lsblk -dpno NAME | grep -E '/dev/(sd|hd|vd|nvme|mmcblk|xv)')
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Set a new encryption password for a drive selected.
|
||||||
|
|
||||||
encrypted_drives=$(blkid -t TYPE=crypto_LUKS -o device)
|
encrypted_drives=$(blkid -t TYPE=crypto_LUKS -o device)
|
||||||
|
|
||||||
if [[ -n $encrypted_drives ]]; then
|
if [[ -n $encrypted_drives ]]; then
|
||||||
|
|||||||
@@ -1,3 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Returns the name of the current monospace font being used by extracting it from the Waybar stylesheet.
|
||||||
|
# This can be changed using omarchy-font-set.
|
||||||
|
|
||||||
grep -oP 'font-family:\s*["'\'']?\K[^;"'\'']+' ~/.config/waybar/style.css | head -n1
|
grep -oP 'font-family:\s*["'\'']?\K[^;"'\'']+' ~/.config/waybar/style.css | head -n1
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Returns a list of all the monospace fonts available on the system that can be set using omarchy-font-set.
|
||||||
|
|
||||||
fc-list :spacing=100 -f "%{family[0]}\n" | grep -v -i -E 'emoji|signwriting|omarchy' | sort -u
|
fc-list :spacing=100 -f "%{family[0]}\n" | grep -v -i -E 'emoji|signwriting|omarchy' | sort -u
|
||||||
|
|||||||
@@ -1,8 +1,11 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Set the system-wide monospace font that should be used by the terminal, hyprlock, waybar, swayosd, etc.
|
||||||
|
# The font name must be one of the ones returned by omarchy-font-list.
|
||||||
|
|
||||||
font_name="$1"
|
font_name="$1"
|
||||||
|
|
||||||
if [[ -n "$font_name" && "$font_name" != "CNCLD" ]]; then
|
if [[ -n "$font_name" ]]; then
|
||||||
if fc-list | grep -iq "$font_name"; then
|
if fc-list | grep -iq "$font_name"; then
|
||||||
if [[ -f ~/.config/alacritty/alacritty.toml ]]; then
|
if [[ -f ~/.config/alacritty/alacritty.toml ]]; then
|
||||||
sed -i "s/family = \".*\"/family = \"$font_name\"/g" ~/.config/alacritty/alacritty.toml
|
sed -i "s/family = \".*\"/family = \"$font_name\"/g" ~/.config/alacritty/alacritty.toml
|
||||||
@@ -18,6 +21,7 @@ if [[ -n "$font_name" && "$font_name" != "CNCLD" ]]; then
|
|||||||
pkill -SIGUSR2 ghostty
|
pkill -SIGUSR2 ghostty
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
sed -i "s/font_family = .*/font_family = $font_name/g" ~/.config/hypr/hyprlock.conf
|
||||||
sed -i "s/font-family: .*/font-family: '$font_name';/g" ~/.config/waybar/style.css
|
sed -i "s/font-family: .*/font-family: '$font_name';/g" ~/.config/waybar/style.css
|
||||||
sed -i "s/font-family: .*/font-family: '$font_name';/g" ~/.config/swayosd/style.css
|
sed -i "s/font-family: .*/font-family: '$font_name';/g" ~/.config/swayosd/style.css
|
||||||
xmlstarlet ed -L \
|
xmlstarlet ed -L \
|
||||||
@@ -27,7 +31,10 @@ if [[ -n "$font_name" && "$font_name" != "CNCLD" ]]; then
|
|||||||
|
|
||||||
omarchy-restart-waybar
|
omarchy-restart-waybar
|
||||||
omarchy-restart-swayosd
|
omarchy-restart-swayosd
|
||||||
omarchy-restart-walker
|
|
||||||
|
if pgrep -x ghostty; then
|
||||||
|
notify-send " You must restart Ghostty to see font change"
|
||||||
|
fi
|
||||||
|
|
||||||
omarchy-hook font-set "$font_name"
|
omarchy-hook font-set "$font_name"
|
||||||
else
|
else
|
||||||
|
|||||||
18
bin/omarchy-hibernation-available
Executable file
18
bin/omarchy-hibernation-available
Executable file
@@ -0,0 +1,18 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Check if hibernation is supported
|
||||||
|
if [[ ! -f /sys/power/image_size ]]; then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Sum all swap sizes (excluding zram)
|
||||||
|
SWAPSIZE_KB=$(awk '!/Filename|zram/ {sum += $3} END {print sum+0}' /proc/swaps)
|
||||||
|
SWAPSIZE=$(( 1024 * ${SWAPSIZE_KB:-0} ))
|
||||||
|
|
||||||
|
HIBERNATION_IMAGE_SIZE=$(cat /sys/power/image_size)
|
||||||
|
|
||||||
|
if [[ "$SWAPSIZE" -gt "$HIBERNATION_IMAGE_SIZE" ]] && [[ -f /etc/mkinitcpio.conf.d/omarchy_resume.conf ]]; then
|
||||||
|
exit 0
|
||||||
|
else
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
59
bin/omarchy-hibernation-remove
Executable file
59
bin/omarchy-hibernation-remove
Executable file
@@ -0,0 +1,59 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Removes hibernation setup: disables swap, removes swapfile, removes fstab entry,
|
||||||
|
# removes resume hook, and removes suspend-then-hibernate configuration.
|
||||||
|
|
||||||
|
MKINITCPIO_CONF="/etc/mkinitcpio.conf.d/omarchy_resume.conf"
|
||||||
|
|
||||||
|
# Check if hibernation is configured
|
||||||
|
if [ ! -f "$MKINITCPIO_CONF" ] || ! grep -q "^HOOKS+=(resume)$" "$MKINITCPIO_CONF"; then
|
||||||
|
echo "Hibernation is not set up"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if ! gum confirm "Remove hibernation setup?"; then
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
SWAP_SUBVOLUME="/swap"
|
||||||
|
SWAP_FILE="$SWAP_SUBVOLUME/swapfile"
|
||||||
|
|
||||||
|
# Disable swap if active
|
||||||
|
if swapon --show | grep -q "$SWAP_FILE"; then
|
||||||
|
echo "Disabling swap on $SWAP_FILE"
|
||||||
|
sudo swapoff "$SWAP_FILE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Remove swapfile
|
||||||
|
if [ -f "$SWAP_FILE" ]; then
|
||||||
|
echo "Removing swapfile"
|
||||||
|
sudo rm "$SWAP_FILE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Remove swap subvolume
|
||||||
|
if sudo btrfs subvolume show "$SWAP_SUBVOLUME" &>/dev/null; then
|
||||||
|
echo "Removing Btrfs subvolume $SWAP_SUBVOLUME"
|
||||||
|
sudo btrfs subvolume delete "$SWAP_SUBVOLUME"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Remove fstab entry
|
||||||
|
if grep -Fq "$SWAP_FILE" /etc/fstab; then
|
||||||
|
echo "Removing swapfile from /etc/fstab"
|
||||||
|
sudo cp -a /etc/fstab "/etc/fstab.$(date +%Y%m%d%H%M%S).back"
|
||||||
|
sudo sed -i "\|$SWAP_FILE|d" /etc/fstab
|
||||||
|
sudo sed -i '/^# Btrfs swapfile for system hibernation$/d' /etc/fstab
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Remove suspend-then-hibernate configuration
|
||||||
|
echo "Removing suspend-then-hibernate configuration"
|
||||||
|
sudo rm -f /etc/systemd/logind.conf.d/lid.conf
|
||||||
|
sudo rm -f /etc/systemd/sleep.conf.d/hibernate.conf
|
||||||
|
|
||||||
|
# Remove mkinitcpio resume hook
|
||||||
|
echo "Removing resume hook"
|
||||||
|
sudo rm "$MKINITCPIO_CONF"
|
||||||
|
|
||||||
|
echo "Regenerating initramfs..."
|
||||||
|
sudo limine-mkinitcpio
|
||||||
|
|
||||||
|
echo "Hibernation removed"
|
||||||
84
bin/omarchy-hibernation-setup
Executable file
84
bin/omarchy-hibernation-setup
Executable file
@@ -0,0 +1,84 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Creates a swap file in the btrfs subvolume, adds the swap file to /etc/fstab,
|
||||||
|
# adds a resume hook to mkinitcpio, and configures suspend-then-hibernate.
|
||||||
|
|
||||||
|
if [[ ! -f /sys/power/image_size ]]; then
|
||||||
|
echo -e "\033[31mError: Hibernation is not supported on your system\033[0m" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
MKINITCPIO_CONF="/etc/mkinitcpio.conf.d/omarchy_resume.conf"
|
||||||
|
|
||||||
|
# Check if hibernation is already configured
|
||||||
|
if [ -f "$MKINITCPIO_CONF" ] && grep -q "^HOOKS+=(resume)$" "$MKINITCPIO_CONF"; then
|
||||||
|
echo "Hibernation is already set up"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ $1 != "--force" ]]; then
|
||||||
|
MEM_TOTAL_HUMAN=$(free --human | awk '/Mem/ {print $2}')
|
||||||
|
if ! gum confirm "Use $MEM_TOTAL_HUMAN on boot drive to make hibernation available?"; then
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
SWAP_SUBVOLUME="/swap"
|
||||||
|
SWAP_FILE="$SWAP_SUBVOLUME/swapfile"
|
||||||
|
|
||||||
|
# Create btrfs subvolume for swap
|
||||||
|
if ! sudo btrfs subvolume show "$SWAP_SUBVOLUME" &>/dev/null; then
|
||||||
|
echo "Creating Btrfs subvolume"
|
||||||
|
sudo btrfs subvolume create "$SWAP_SUBVOLUME"
|
||||||
|
sudo chattr +C "$SWAP_SUBVOLUME"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Create swapfile
|
||||||
|
if ! sudo swaplabel "$SWAP_FILE" &>/dev/null; then
|
||||||
|
echo "Creating swapfile in Btrfs subvolume"
|
||||||
|
MEM_TOTAL_KB="$(awk '/MemTotal/ {print $2}' /proc/meminfo)k"
|
||||||
|
sudo btrfs filesystem mkswapfile -s "$MEM_TOTAL_KB" "$SWAP_FILE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Add swapfile to fstab
|
||||||
|
if ! grep -Fq "$SWAP_FILE" /etc/fstab; then
|
||||||
|
echo "Adding swapfile to /etc/fstab"
|
||||||
|
sudo cp -a /etc/fstab "/etc/fstab.$(date +%Y%m%d%H%M%S).back"
|
||||||
|
printf "\n# Btrfs swapfile for system hibernation\n%s none swap defaults,pri=0 0 0\n" "$SWAP_FILE" | sudo tee -a /etc/fstab >/dev/null
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Enable swap
|
||||||
|
if ! swapon --show | grep -q "$SWAP_FILE"; then
|
||||||
|
echo "Enabling swap on $SWAP_FILE"
|
||||||
|
sudo swapon -p 0 "$SWAP_FILE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Add resume hook to mkinitcpio
|
||||||
|
sudo mkdir -p /etc/mkinitcpio.conf.d
|
||||||
|
echo "Adding resume hook to $MKINITCPIO_CONF"
|
||||||
|
echo "HOOKS+=(resume)" | sudo tee "$MKINITCPIO_CONF" >/dev/null
|
||||||
|
|
||||||
|
# Ensure keyboard backlight doesn't prevent sleep
|
||||||
|
sudo cp -p "$OMARCHY_PATH/default/systemd/system-sleep/keyboard-backlight" /usr/lib/systemd/system-sleep/
|
||||||
|
|
||||||
|
# Use ACPI alarm for RTC wakeup on s2idle systems (needed for suspend-then-hibernate)
|
||||||
|
if grep -q "\[s2idle\]" /sys/power/mem_sleep 2>/dev/null; then
|
||||||
|
LIMINE_DROP_IN="/etc/limine-entry-tool.d/rtc-alarm.conf"
|
||||||
|
if [[ ! -f "$LIMINE_DROP_IN" ]]; then
|
||||||
|
echo "Enabling ACPI RTC alarm for s2idle suspend"
|
||||||
|
sudo mkdir -p /etc/limine-entry-tool.d
|
||||||
|
echo 'KERNEL_CMDLINE[default]+="rtc_cmos.use_acpi_alarm=1"' | sudo tee "$LIMINE_DROP_IN" >/dev/null
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Regenerate initramfs and boot entry
|
||||||
|
echo "Regenerating initramfs..."
|
||||||
|
sudo limine-mkinitcpio
|
||||||
|
sudo limine-update
|
||||||
|
|
||||||
|
echo
|
||||||
|
|
||||||
|
if [[ $1 != "--force" ]] && gum confirm "Reboot to enable hibernation?"; then
|
||||||
|
omarchy-cmd-reboot
|
||||||
|
fi
|
||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Run a named hook, like post-update (available in ~/.config/omarchy/hooks/post-update).
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
if [[ $# -lt 1 ]]; then
|
if [[ $# -lt 1 ]]; then
|
||||||
|
|||||||
6
bin/omarchy-hw-asus-rog
Executable file
6
bin/omarchy-hw-asus-rog
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Detect whether the computer is an Asus ROG machine.
|
||||||
|
|
||||||
|
[[ "$(cat /sys/class/dmi/id/sys_vendor 2>/dev/null)" == "ASUSTeK COMPUTER INC." ]] &&
|
||||||
|
grep -q "ROG" /sys/class/dmi/id/product_family 2>/dev/null
|
||||||
@@ -2,20 +2,44 @@
|
|||||||
|
|
||||||
# Toggle to pop-out a tile to stay fixed on a display basis.
|
# Toggle to pop-out a tile to stay fixed on a display basis.
|
||||||
|
|
||||||
active=$(hyprctl activewindow -j)
|
# Usage:
|
||||||
pinned=$(echo "$active" | jq .pinned)
|
# omarchy-hyprland-window-pop [width height [x y]]
|
||||||
addr=$(echo "$active" | jq -r ".address")
|
#
|
||||||
[ -z "$addr" ] && { echo "No active window"; exit 0; }
|
# Arguments:
|
||||||
|
# width Optional. Width of the floating window. Default: 1300
|
||||||
|
# height Optional. Height of the floating window. Default: 900
|
||||||
|
# x Optional. X position of the window. Must provide both X and Y to take effect.
|
||||||
|
# y Optional. Y position of the window. Must provide both X and Y to take effect.
|
||||||
|
#
|
||||||
|
# Behavior:
|
||||||
|
# - If the window is already pinned, it will be unpinned and removed from the pop layer.
|
||||||
|
# - If the window is not pinned, it will be floated, resized, moved/centered, pinned, brought to top, and popped.
|
||||||
|
|
||||||
if [ "$pinned" = "true" ]; then
|
width=${1:-1300}
|
||||||
|
height=${2:-900}
|
||||||
|
x=${3:-}
|
||||||
|
y=${4:-}
|
||||||
|
|
||||||
|
active=$(hyprctl activewindow -j)
|
||||||
|
pinned=$(echo "$active" | jq ".pinned")
|
||||||
|
addr=$(echo "$active" | jq -r ".address")
|
||||||
|
|
||||||
|
if [[ $pinned == "true" ]]; then
|
||||||
hyprctl -q --batch \
|
hyprctl -q --batch \
|
||||||
"dispatch pin address:$addr;" \
|
"dispatch pin address:$addr;" \
|
||||||
"dispatch togglefloating address:$addr;" \
|
"dispatch togglefloating address:$addr;" \
|
||||||
"dispatch tagwindow -pop address:$addr;"
|
"dispatch tagwindow -pop address:$addr;"
|
||||||
else
|
elif [[ -n $addr ]]; then
|
||||||
|
hyprctl dispatch togglefloating address:$addr
|
||||||
|
hyprctl dispatch resizeactive exact $width $height address:$addr
|
||||||
|
|
||||||
|
if [[ -n $x && -n $y ]]; then
|
||||||
|
hyprctl dispatch moveactive $x $y address:$addr
|
||||||
|
else
|
||||||
|
hyprctl dispatch centerwindow address:$addr
|
||||||
|
fi
|
||||||
|
|
||||||
hyprctl -q --batch \
|
hyprctl -q --batch \
|
||||||
"dispatch togglefloating address:$addr;" \
|
|
||||||
"dispatch centerwindow address:$addr;" \
|
|
||||||
"dispatch pin address:$addr;" \
|
"dispatch pin address:$addr;" \
|
||||||
"dispatch alterzorder top address:$addr;" \
|
"dispatch alterzorder top address:$addr;" \
|
||||||
"dispatch tagwindow +pop address:$addr;"
|
"dispatch tagwindow +pop address:$addr;"
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Toggles the window gaps on the active workspace between no gaps and the default 10/5/2.
|
||||||
|
|
||||||
workspace_id=$(hyprctl activeworkspace -j | jq -r .id)
|
workspace_id=$(hyprctl activeworkspace -j | jq -r .id)
|
||||||
gaps=$(hyprctl workspacerules -j | jq -r ".[] | select(.workspaceString==\"$workspace_id\") | .gapsOut[0] // 0")
|
gaps=$(hyprctl workspacerules -j | jq -r ".[] | select(.workspaceString==\"$workspace_id\") | .gapsOut[0] // 0")
|
||||||
|
|
||||||
|
|||||||
@@ -1,258 +0,0 @@
|
|||||||
#!/usr/bin/env python3
|
|
||||||
"""
|
|
||||||
Omarchy Install
|
|
||||||
|
|
||||||
Installs Arch Linux with Omarchy customizations using archinstall as a library.
|
|
||||||
For disk configuration, use omarchy-disk-config.
|
|
||||||
"""
|
|
||||||
|
|
||||||
import json
|
|
||||||
import sys
|
|
||||||
import time
|
|
||||||
from pathlib import Path
|
|
||||||
|
|
||||||
|
|
||||||
def load_config(config_file: Path, creds_file: Path | None = None):
|
|
||||||
from archinstall.lib.args import ArchConfig, Arguments
|
|
||||||
|
|
||||||
with open(config_file) as f:
|
|
||||||
config_data = json.load(f)
|
|
||||||
|
|
||||||
if creds_file and creds_file.exists():
|
|
||||||
with open(creds_file) as f:
|
|
||||||
creds_data = json.load(f)
|
|
||||||
config_data.update(creds_data)
|
|
||||||
|
|
||||||
args = Arguments(
|
|
||||||
config=config_file,
|
|
||||||
creds=creds_file,
|
|
||||||
mountpoint=Path('/mnt'),
|
|
||||||
silent=True,
|
|
||||||
skip_ntp=True,
|
|
||||||
skip_wkd=True,
|
|
||||||
)
|
|
||||||
|
|
||||||
return ArchConfig.from_config(config_data, args)
|
|
||||||
|
|
||||||
|
|
||||||
def load_omarchy_packages() -> list[str]:
|
|
||||||
omarchy_path = Path('/usr/share/omarchy/install')
|
|
||||||
packages = []
|
|
||||||
|
|
||||||
base_packages_file = omarchy_path / 'omarchy-base.packages'
|
|
||||||
if base_packages_file.exists():
|
|
||||||
with open(base_packages_file) as f:
|
|
||||||
packages.extend([line.strip() for line in f if line.strip() and not line.startswith('#')])
|
|
||||||
|
|
||||||
return packages
|
|
||||||
|
|
||||||
|
|
||||||
def perform_installation(config_file: Path, creds_file: Path | None = None) -> None:
|
|
||||||
from archinstall.lib.disk.filesystem import FilesystemHandler
|
|
||||||
from archinstall.lib.installer import Installer
|
|
||||||
from archinstall.lib.models.device import DiskLayoutType, EncryptionType
|
|
||||||
from archinstall.lib.output import error, info
|
|
||||||
from archinstall.lib.profile.profiles_handler import profile_handler
|
|
||||||
from archinstall.lib.authentication.authentication_handler import auth_handler
|
|
||||||
|
|
||||||
start_time = time.time()
|
|
||||||
|
|
||||||
info('Loading configuration...')
|
|
||||||
config = load_config(config_file, creds_file)
|
|
||||||
|
|
||||||
if not config.disk_config:
|
|
||||||
error('No disk configuration found in config file')
|
|
||||||
error('Use omarchy-disk-config to configure disk layout first')
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
disk_config = config.disk_config
|
|
||||||
|
|
||||||
if disk_config.config_type != DiskLayoutType.Pre_mount:
|
|
||||||
info('Performing filesystem operations...')
|
|
||||||
fs_handler = FilesystemHandler(disk_config)
|
|
||||||
fs_handler.perform_filesystem_operations()
|
|
||||||
|
|
||||||
mountpoint = Path('/mnt')
|
|
||||||
|
|
||||||
info('Loading Omarchy base packages...')
|
|
||||||
omarchy_packages = load_omarchy_packages()
|
|
||||||
|
|
||||||
info('Starting Omarchy installation...')
|
|
||||||
|
|
||||||
with Installer(
|
|
||||||
mountpoint,
|
|
||||||
disk_config,
|
|
||||||
kernels=config.kernels or ['linux'],
|
|
||||||
) as installation:
|
|
||||||
|
|
||||||
info('Mounting filesystems...')
|
|
||||||
if disk_config.config_type != DiskLayoutType.Pre_mount:
|
|
||||||
installation.mount_ordered_layout()
|
|
||||||
|
|
||||||
installation.sanity_check()
|
|
||||||
|
|
||||||
if disk_config.disk_encryption and disk_config.disk_encryption.encryption_type != EncryptionType.NoEncryption:
|
|
||||||
info('Generating encryption keys...')
|
|
||||||
installation.generate_key_files()
|
|
||||||
|
|
||||||
if config.mirror_config:
|
|
||||||
info('Configuring mirrors...')
|
|
||||||
installation.set_mirrors(config.mirror_config, on_target=False)
|
|
||||||
|
|
||||||
info('Installing base system...')
|
|
||||||
installation.minimal_installation(
|
|
||||||
optional_repositories=config.mirror_config.optional_repositories if config.mirror_config else [],
|
|
||||||
mkinitcpio=not config.uki,
|
|
||||||
hostname=config.hostname,
|
|
||||||
locale_config=config.locale_config,
|
|
||||||
)
|
|
||||||
|
|
||||||
if config.mirror_config:
|
|
||||||
installation.set_mirrors(config.mirror_config, on_target=True)
|
|
||||||
|
|
||||||
if config.swap:
|
|
||||||
info('Setting up swap...')
|
|
||||||
installation.setup_swap('zram')
|
|
||||||
|
|
||||||
all_packages = omarchy_packages + (config.packages or [])
|
|
||||||
if all_packages:
|
|
||||||
info(f'Installing {len(all_packages)} packages...')
|
|
||||||
installation.add_additional_packages(all_packages)
|
|
||||||
|
|
||||||
if config.bootloader:
|
|
||||||
info(f'Installing bootloader: {config.bootloader.value}...')
|
|
||||||
installation.add_bootloader(config.bootloader, config.uki)
|
|
||||||
|
|
||||||
if config.network_config:
|
|
||||||
info('Configuring network...')
|
|
||||||
config.network_config.install_network_config(installation, config.profile_config)
|
|
||||||
|
|
||||||
if config.auth_config and config.auth_config.users:
|
|
||||||
info('Creating users...')
|
|
||||||
installation.create_users(config.auth_config.users)
|
|
||||||
auth_handler.setup_auth(installation, config.auth_config, config.hostname)
|
|
||||||
|
|
||||||
if config.app_config:
|
|
||||||
info('Installing applications...')
|
|
||||||
from archinstall.lib.applications.application_handler import application_handler
|
|
||||||
application_handler.install_applications(installation, config.app_config)
|
|
||||||
|
|
||||||
if config.profile_config:
|
|
||||||
info('Installing profile...')
|
|
||||||
profile_handler.install_profile_config(installation, config.profile_config)
|
|
||||||
|
|
||||||
if config.timezone:
|
|
||||||
installation.set_timezone(config.timezone)
|
|
||||||
|
|
||||||
if config.ntp:
|
|
||||||
installation.activate_time_synchronization()
|
|
||||||
|
|
||||||
from archinstall.lib.installer import accessibility_tools_in_use
|
|
||||||
if accessibility_tools_in_use():
|
|
||||||
installation.enable_espeakup()
|
|
||||||
|
|
||||||
if config.auth_config and config.auth_config.root_enc_password:
|
|
||||||
from archinstall.lib.models.users import User
|
|
||||||
root_user = User('root', config.auth_config.root_enc_password, False)
|
|
||||||
installation.set_user_password(root_user)
|
|
||||||
|
|
||||||
if config.profile_config and config.profile_config.profile:
|
|
||||||
config.profile_config.profile.post_install(installation)
|
|
||||||
|
|
||||||
if config.services:
|
|
||||||
info('Enabling services...')
|
|
||||||
installation.enable_service(config.services)
|
|
||||||
|
|
||||||
if disk_config.has_default_btrfs_vols():
|
|
||||||
btrfs_options = disk_config.btrfs_options
|
|
||||||
snapshot_config = btrfs_options.snapshot_config if btrfs_options else None
|
|
||||||
snapshot_type = snapshot_config.snapshot_type if snapshot_config else None
|
|
||||||
if snapshot_type:
|
|
||||||
installation.setup_btrfs_snapshot(snapshot_type, config.bootloader)
|
|
||||||
|
|
||||||
info('Mounting offline resources for chroot access...')
|
|
||||||
from archinstall.lib.general import SysCommand
|
|
||||||
import os
|
|
||||||
import shutil
|
|
||||||
|
|
||||||
offline_mirror_src = Path('/var/cache/omarchy/mirror/offline')
|
|
||||||
offline_mirror_dst = mountpoint / 'var/cache/omarchy/mirror/offline'
|
|
||||||
packages_src = Path('/opt/packages')
|
|
||||||
packages_dst = mountpoint / 'opt/packages'
|
|
||||||
|
|
||||||
os.makedirs(offline_mirror_dst, exist_ok=True)
|
|
||||||
os.makedirs(packages_dst, exist_ok=True)
|
|
||||||
|
|
||||||
if offline_mirror_src.exists():
|
|
||||||
SysCommand(f'mount --bind {offline_mirror_src} {offline_mirror_dst}')
|
|
||||||
|
|
||||||
if packages_src.exists():
|
|
||||||
SysCommand(f'mount --bind {packages_src} {packages_dst}')
|
|
||||||
|
|
||||||
pacman_conf_src = Path('/etc/pacman.conf')
|
|
||||||
pacman_conf_dst = mountpoint / 'etc/pacman.conf'
|
|
||||||
if pacman_conf_src.exists():
|
|
||||||
shutil.copy(pacman_conf_src, pacman_conf_dst)
|
|
||||||
|
|
||||||
info('Copying user info to chroot...')
|
|
||||||
os.makedirs(mountpoint / 'tmp', exist_ok=True)
|
|
||||||
|
|
||||||
if os.path.exists('/tmp/omarchy-user-name.txt'):
|
|
||||||
shutil.copy('/tmp/omarchy-user-name.txt', mountpoint / 'tmp/omarchy-user-name.txt')
|
|
||||||
if os.path.exists('/tmp/omarchy-user-email.txt'):
|
|
||||||
shutil.copy('/tmp/omarchy-user-email.txt', mountpoint / 'tmp/omarchy-user-email.txt')
|
|
||||||
|
|
||||||
if config.custom_commands:
|
|
||||||
info('Running Omarchy custom commands...')
|
|
||||||
from archinstall.lib.installer import run_custom_user_commands
|
|
||||||
run_custom_user_commands(config.custom_commands, installation)
|
|
||||||
|
|
||||||
info('Generating fstab...')
|
|
||||||
installation.genfstab()
|
|
||||||
|
|
||||||
end_time = time.time()
|
|
||||||
duration_seconds = int(end_time - start_time)
|
|
||||||
duration_mins = duration_seconds // 60
|
|
||||||
duration_secs = duration_seconds % 60
|
|
||||||
|
|
||||||
timing_file = mountpoint / 'tmp/omarchy-install-time.txt'
|
|
||||||
with open(timing_file, 'w') as f:
|
|
||||||
f.write(f"{duration_mins}m {duration_secs}s\n")
|
|
||||||
|
|
||||||
info(f'Installation complete! Total time: {duration_mins}m {duration_secs}s')
|
|
||||||
|
|
||||||
|
|
||||||
def main():
|
|
||||||
import argparse
|
|
||||||
|
|
||||||
parser = argparse.ArgumentParser(description='Omarchy Install')
|
|
||||||
parser.add_argument('--config', type=Path, required=True, help='Path to config file')
|
|
||||||
parser.add_argument('--creds', type=Path, help='Path to credentials file')
|
|
||||||
|
|
||||||
args = parser.parse_args()
|
|
||||||
|
|
||||||
if not args.config.exists():
|
|
||||||
print(f'ERROR: Config file not found: {args.config}', file=sys.stderr)
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
if args.creds and not args.creds.exists():
|
|
||||||
print(f'ERROR: Credentials file not found: {args.creds}', file=sys.stderr)
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
try:
|
|
||||||
perform_installation(
|
|
||||||
config_file=args.config,
|
|
||||||
creds_file=args.creds,
|
|
||||||
)
|
|
||||||
except KeyboardInterrupt:
|
|
||||||
print('\nInstallation cancelled by user', file=sys.stderr)
|
|
||||||
sys.exit(1)
|
|
||||||
except Exception as e:
|
|
||||||
print(f'ERROR: Installation failed: {e}', file=sys.stderr)
|
|
||||||
import traceback
|
|
||||||
traceback.print_exc()
|
|
||||||
sys.exit(1)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
|
||||||
main()
|
|
||||||
@@ -1,5 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Allow Chromium to sign in to Google accounts by adding the correct
|
||||||
|
# oauth client id and secret to ~/.config/chromium-flags.conf.
|
||||||
|
|
||||||
if [[ -f ~/.config/chromium-flags.conf ]]; then
|
if [[ -f ~/.config/chromium-flags.conf ]]; then
|
||||||
CONF=~/.config/chromium-flags.conf
|
CONF=~/.config/chromium-flags.conf
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Install one of the supported development environments. Usually called via Install > Development > * in the Omarchy Menu.
|
||||||
|
|
||||||
if [[ -z "$1" ]]; then
|
if [[ -z "$1" ]]; then
|
||||||
echo "Usage: omarchy-install-dev-env <ruby|node|bun|go|laravel|symfony|php|python|elixir|phoenix|rust|java|ocaml|dotnet|clojure>" >&2
|
echo "Usage: omarchy-install-dev-env <ruby|node|bun|go|laravel|symfony|php|python|elixir|phoenix|rust|java|ocaml|dotnet|clojure>" >&2
|
||||||
exit 1
|
exit 1
|
||||||
@@ -41,7 +43,7 @@ install_php() {
|
|||||||
|
|
||||||
install_node() {
|
install_node() {
|
||||||
echo -e "Installing Node.js...\n"
|
echo -e "Installing Node.js...\n"
|
||||||
mise use --global node@lts
|
mise use --global node
|
||||||
}
|
}
|
||||||
|
|
||||||
case "$1" in
|
case "$1" in
|
||||||
@@ -50,6 +52,7 @@ ruby)
|
|||||||
omarchy-pkg-add libyaml
|
omarchy-pkg-add libyaml
|
||||||
mise use --global ruby@latest
|
mise use --global ruby@latest
|
||||||
mise settings add idiomatic_version_file_enable_tools ruby
|
mise settings add idiomatic_version_file_enable_tools ruby
|
||||||
|
echo "gem: --no-document" > ~/.gemrc
|
||||||
mise x ruby -- gem install rails --no-document
|
mise x ruby -- gem install rails --no-document
|
||||||
echo -e "\nYou can now run: rails new myproject"
|
echo -e "\nYou can now run: rails new myproject"
|
||||||
;;
|
;;
|
||||||
|
|||||||
@@ -1,5 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Install one of the supported databases in a Docker container with the suitable development options.
|
||||||
|
# Usually called via Install > Development > Docker DB from the Omarchy Menu.
|
||||||
|
|
||||||
options=("MySQL" "PostgreSQL" "Redis" "MongoDB" "MariaDB" "MSSQL")
|
options=("MySQL" "PostgreSQL" "Redis" "MongoDB" "MariaDB" "MSSQL")
|
||||||
|
|
||||||
if [[ "$#" -eq 0 ]]; then
|
if [[ "$#" -eq 0 ]]; then
|
||||||
@@ -12,7 +15,7 @@ if [[ -n "$choices" ]]; then
|
|||||||
for db in $choices; do
|
for db in $choices; do
|
||||||
case $db in
|
case $db in
|
||||||
MySQL) sudo docker run -d --restart unless-stopped -p "127.0.0.1:3306:3306" --name=mysql8 -e MYSQL_ROOT_PASSWORD= -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql:8.4 ;;
|
MySQL) sudo docker run -d --restart unless-stopped -p "127.0.0.1:3306:3306" --name=mysql8 -e MYSQL_ROOT_PASSWORD= -e MYSQL_ALLOW_EMPTY_PASSWORD=true mysql:8.4 ;;
|
||||||
PostgreSQL) sudo docker run -d --restart unless-stopped -p "127.0.0.1:5432:5432" --name=postgres17 -e POSTGRES_HOST_AUTH_METHOD=trust postgres:17 ;;
|
PostgreSQL) sudo docker run -d --restart unless-stopped -p "127.0.0.1:5432:5432" --name=postgres18 -e POSTGRES_HOST_AUTH_METHOD=trust postgres:18 ;;
|
||||||
MariaDB) sudo docker run -d --restart unless-stopped -p "127.0.0.1:3306:3306" --name=mariadb11 -e MARIADB_ROOT_PASSWORD= -e MARIADB_ALLOW_EMPTY_ROOT_PASSWORD=true mariadb:11.8 ;;
|
MariaDB) sudo docker run -d --restart unless-stopped -p "127.0.0.1:3306:3306" --name=mariadb11 -e MARIADB_ROOT_PASSWORD= -e MARIADB_ALLOW_EMPTY_ROOT_PASSWORD=true mariadb:11.8 ;;
|
||||||
Redis) sudo docker run -d --restart unless-stopped -p "127.0.0.1:6379:6379" --name=redis redis:7 ;;
|
Redis) sudo docker run -d --restart unless-stopped -p "127.0.0.1:6379:6379" --name=redis redis:7 ;;
|
||||||
MongoDB) sudo docker run -d --restart unless-stopped -p "127.0.0.1:27017:27017" --name mongodb -e MONGO_INITDB_ROOT_USERNAME=admin -e MONGO_INITDB_ROOT_PASSWORD=admin123 mongo:noble ;;
|
MongoDB) sudo docker run -d --restart unless-stopped -p "127.0.0.1:27017:27017" --name mongodb -e MONGO_INITDB_ROOT_USERNAME=admin -e MONGO_INITDB_ROOT_PASSWORD=admin123 mongo:noble ;;
|
||||||
|
|||||||
@@ -1,8 +1,10 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Install and start the Dropbox service. Must then be authenticated via the web.
|
||||||
|
|
||||||
echo "Installing all dependencies..."
|
echo "Installing all dependencies..."
|
||||||
omarchy-pkg-add dropbox dropbox-cli libappindicator-gtk3 python-gpgme nautilus-dropbox
|
omarchy-pkg-add dropbox dropbox-cli libappindicator-gtk3 python-gpgme nautilus-dropbox
|
||||||
|
|
||||||
echo "Starting Dropbox..."
|
echo "Starting Dropbox..."
|
||||||
uwsm-app -- dropbox-cli start &>/dev/null &
|
uwsm-app -- dropbox-cli start &>/dev/null &
|
||||||
echo "See Dropbox icon behind hover tray in top right and right-click for setup."
|
echo "See Dropbox icon behind hover tray in top right and right-click for setup."
|
||||||
|
|||||||
@@ -1,110 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
#
|
|
||||||
# Omarchy Final Configurations Installer
|
|
||||||
#
|
|
||||||
# This script runs from archinstall's custom_commands after base packages
|
|
||||||
# and user creation. It switches to the created user and runs install.sh
|
|
||||||
# to complete package installation and system configuration.
|
|
||||||
#
|
|
||||||
# archinstall runs custom_commands as root via:
|
|
||||||
# arch-chroot -S /mnt bash /var/tmp/user-command.0.sh
|
|
||||||
#
|
|
||||||
|
|
||||||
set -eEo pipefail
|
|
||||||
|
|
||||||
# Setup comprehensive logging for chroot execution
|
|
||||||
# This ensures all output is captured even though we're running inside chroot
|
|
||||||
CHROOT_LOG_FILE="/var/log/omarchy-install-chroot.log"
|
|
||||||
mkdir -p "$(dirname "$CHROOT_LOG_FILE")"
|
|
||||||
touch "$CHROOT_LOG_FILE"
|
|
||||||
|
|
||||||
# Redirect all output to both the log file and stdout
|
|
||||||
# This way:
|
|
||||||
# 1. Output is saved to /var/log/omarchy-install-chroot.log (inside chroot = /mnt/var/log on ISO)
|
|
||||||
# 2. Output still goes to stdout so arch-chroot can potentially capture it
|
|
||||||
# 3. We use exec to redirect the entire script's output from this point forward
|
|
||||||
exec > >(tee -a "$CHROOT_LOG_FILE") 2>&1
|
|
||||||
|
|
||||||
# Log script start with timestamp
|
|
||||||
echo "========================================"
|
|
||||||
echo "Omarchy Chroot Install Starting"
|
|
||||||
echo "Started at: $(date '+%Y-%m-%d %H:%M:%S')"
|
|
||||||
echo "Log file: $CHROOT_LOG_FILE"
|
|
||||||
echo "========================================"
|
|
||||||
echo
|
|
||||||
|
|
||||||
# Find the first non-root user (UID >= 1000, < 60000)
|
|
||||||
OMARCHY_USER=$(getent passwd | awk -F: '$3 >= 1000 && $3 < 60000 {print $1; exit}')
|
|
||||||
|
|
||||||
if [[ -z "$OMARCHY_USER" ]]; then
|
|
||||||
echo "ERROR: No non-root user found!"
|
|
||||||
echo "Users created:"
|
|
||||||
getent passwd | awk -F: '$3 >= 1000 {print $1, $3}'
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Setting up Omarchy for user: $OMARCHY_USER"
|
|
||||||
|
|
||||||
# Setup passwordless sudo (will be removed by post-install)
|
|
||||||
echo "Setting up passwordless sudo..."
|
|
||||||
mkdir -p /etc/sudoers.d
|
|
||||||
cat >/etc/sudoers.d/99-omarchy-installer <<EOF
|
|
||||||
root ALL=(ALL:ALL) NOPASSWD: ALL
|
|
||||||
%wheel ALL=(ALL:ALL) NOPASSWD: ALL
|
|
||||||
$OMARCHY_USER ALL=(ALL:ALL) NOPASSWD: ALL
|
|
||||||
EOF
|
|
||||||
chmod 440 /etc/sudoers.d/99-omarchy-installer
|
|
||||||
|
|
||||||
# Get user info from /tmp (written by configurator)
|
|
||||||
if [[ -f /tmp/omarchy-user-name.txt ]]; then
|
|
||||||
OMARCHY_USER_NAME=$(cat /tmp/omarchy-user-name.txt)
|
|
||||||
else
|
|
||||||
OMARCHY_USER_NAME=""
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -f /tmp/omarchy-user-email.txt ]]; then
|
|
||||||
OMARCHY_USER_EMAIL=$(cat /tmp/omarchy-user-email.txt)
|
|
||||||
else
|
|
||||||
OMARCHY_USER_EMAIL=""
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Run install.sh as the user
|
|
||||||
echo "========================================"
|
|
||||||
echo "Running Omarchy installation as user: $OMARCHY_USER"
|
|
||||||
echo "========================================"
|
|
||||||
echo
|
|
||||||
|
|
||||||
# Use runuser instead of su for better output handling
|
|
||||||
# runuser doesn't go through PAM and preserves stdout/stderr better
|
|
||||||
runuser -u "$OMARCHY_USER" -- bash -c "
|
|
||||||
set -eEo pipefail
|
|
||||||
export PYTHONUNBUFFERED=1
|
|
||||||
export OMARCHY_CHROOT_INSTALL=1
|
|
||||||
export OMARCHY_ARCHINSTALL_WRAPPER=1
|
|
||||||
export OMARCHY_USER='$OMARCHY_USER'
|
|
||||||
export OMARCHY_USER_NAME='$OMARCHY_USER_NAME'
|
|
||||||
export OMARCHY_USER_EMAIL='$OMARCHY_USER_EMAIL'
|
|
||||||
cd ~
|
|
||||||
source /usr/share/omarchy/install.sh
|
|
||||||
"
|
|
||||||
|
|
||||||
exit_code=$?
|
|
||||||
|
|
||||||
if [[ $exit_code -eq 0 ]]; then
|
|
||||||
echo
|
|
||||||
echo "========================================"
|
|
||||||
echo "Omarchy install.sh completed successfully!"
|
|
||||||
echo "========================================"
|
|
||||||
echo
|
|
||||||
echo "========================================"
|
|
||||||
echo "Omarchy Chroot Install Completed"
|
|
||||||
echo "Finished at: $(date '+%Y-%m-%d %H:%M:%S')"
|
|
||||||
echo "Log file: $CHROOT_LOG_FILE"
|
|
||||||
echo "========================================"
|
|
||||||
else
|
|
||||||
echo
|
|
||||||
echo "========================================"
|
|
||||||
echo "ERROR: Omarchy install.sh exited with code $exit_code"
|
|
||||||
echo "========================================"
|
|
||||||
exit $exit_code
|
|
||||||
fi
|
|
||||||
17
bin/omarchy-install-geforce-now
Executable file
17
bin/omarchy-install-geforce-now
Executable file
@@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Install and launch Geforce Now.
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
omarchy-pkg-add flatpak
|
||||||
|
cd /tmp
|
||||||
|
|
||||||
|
# Download and run GeForce NOW
|
||||||
|
curl -LO https://international.download.nvidia.com/GFNLinux/GeForceNOWSetup.bin
|
||||||
|
chmod +x GeForceNOWSetup.bin
|
||||||
|
./GeForceNOWSetup.bin
|
||||||
|
|
||||||
|
# Ensure a separate browser process not started by GFN is available.
|
||||||
|
# If not, it seems like GFN has a tendency to hang on login.
|
||||||
|
setsid omarchy-launch-browser
|
||||||
@@ -1,5 +1,9 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Install and launch Steam after first letting the user pick the correct grahics card drivers.
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
echo "Now pick dependencies matching your graphics card"
|
echo "Now pick dependencies matching your graphics card"
|
||||||
sudo pacman -Syu --noconfirm steam
|
sudo pacman -S steam
|
||||||
setsid gtk-launch steam >/dev/null 2>&1 &
|
setsid gtk-launch steam >/dev/null 2>&1 &
|
||||||
|
|||||||
@@ -1,13 +1,10 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Install the Tailscale mesh VPN service and a web app for the Tailscale Admin Console.
|
||||||
|
|
||||||
curl -fsSL https://tailscale.com/install.sh | sh
|
curl -fsSL https://tailscale.com/install.sh | sh
|
||||||
curl -fsSL https://neuralink.com/tsui/install.sh | bash
|
|
||||||
|
|
||||||
echo -e "\nStarting Tailscale..."
|
echo -e "\nStarting Tailscale..."
|
||||||
sudo tailscale up --accept-routes
|
sudo tailscale up --accept-routes
|
||||||
|
|
||||||
echo -e "\nAdd tsui to sudoers..."
|
omarchy-webapp-install "Tailscale" "https://login.tailscale.com/admin/machines" https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/tailscale-light.png
|
||||||
echo "$USER ALL=(ALL) NOPASSWD: $(which tsui)" | sudo tee /etc/sudoers.d/tsui
|
|
||||||
|
|
||||||
omarchy-tui-install "Tailscale" "sudo tsui" float https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/tailscale-light.png
|
|
||||||
omarchy-webapp-install "Tailscale Admin Console" "https://login.tailscale.com/admin/machines" https://cdn.jsdelivr.net/gh/homarr-labs/dashboard-icons/png/tailscale-light.png
|
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Install one of the approved terminals and set it as the default for Omarchy (Super + Return etc).
|
||||||
|
|
||||||
if (($# == 0)); then
|
if (($# == 0)); then
|
||||||
echo "Usage: omarchy-install-terminal [alacritty|ghostty|kitty]"
|
echo "Usage: omarchy-install-terminal [alacritty|ghostty|kitty]"
|
||||||
exit 1
|
exit 1
|
||||||
@@ -9,16 +11,10 @@ package="$1"
|
|||||||
|
|
||||||
# Map package name to desktop entry ID
|
# Map package name to desktop entry ID
|
||||||
case "$package" in
|
case "$package" in
|
||||||
alacritty)
|
alacritty) desktop_id="Alacritty.desktop" ;;
|
||||||
desktop_id="Alacritty.desktop"
|
ghostty) desktop_id="com.mitchellh.ghostty.desktop" ;;
|
||||||
;;
|
kitty) desktop_id="kitty.desktop" ;;
|
||||||
ghostty)
|
*)
|
||||||
desktop_id="com.mitchellh.ghostty.desktop"
|
|
||||||
;;
|
|
||||||
kitty)
|
|
||||||
desktop_id="kitty.desktop"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Unknown terminal: $package"
|
echo "Unknown terminal: $package"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
@@ -26,14 +22,32 @@ esac
|
|||||||
|
|
||||||
# Install package
|
# Install package
|
||||||
if omarchy-pkg-add $package; then
|
if omarchy-pkg-add $package; then
|
||||||
# Set as default terminal
|
|
||||||
echo "Setting $package as new default terminal..."
|
|
||||||
sed -i "/export TERMINAL=/ c\export TERMINAL=$package" ~/.config/uwsm/default
|
|
||||||
|
|
||||||
# Copy custom desktop entry for alacritty with X-TerminalArg* keys
|
# Copy custom desktop entry for alacritty with X-TerminalArg* keys
|
||||||
if [ "$package" = "alacritty" ]; then
|
if [[ $package == "alacritty" ]]; then
|
||||||
mkdir -p ~/.local/share/applications
|
mkdir -p ~/.local/share/applications
|
||||||
cp "$OMARCHY_PATH/applications/Alacritty.desktop" ~/.local/share/applications/
|
cat > ~/.local/share/applications/Alacritty.desktop << EOF
|
||||||
|
[Desktop Entry]
|
||||||
|
Type=Application
|
||||||
|
TryExec=alacritty
|
||||||
|
Exec=alacritty
|
||||||
|
Icon=Alacritty
|
||||||
|
Terminal=false
|
||||||
|
Categories=System;TerminalEmulator;
|
||||||
|
Name=Alacritty
|
||||||
|
GenericName=Terminal
|
||||||
|
Comment=A fast, cross-platform, OpenGL terminal emulator
|
||||||
|
StartupNotify=true
|
||||||
|
StartupWMClass=Alacritty
|
||||||
|
Actions=New;
|
||||||
|
X-TerminalArgExec=-e
|
||||||
|
X-TerminalArgAppId=--class=
|
||||||
|
X-TerminalArgTitle=--title=
|
||||||
|
X-TerminalArgDir=--working-directory=
|
||||||
|
|
||||||
|
[Desktop Action New]
|
||||||
|
Name=New Terminal
|
||||||
|
Exec=alacritty
|
||||||
|
EOF
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Update xdg-terminals.list to prioritize the proper terminal
|
# Update xdg-terminals.list to prioritize the proper terminal
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Install VSCode and configure it to use the gnome-libsecret password store, not to update automatically, and to use the current Omarchy theme.
|
||||||
|
|
||||||
echo "Installing VSCode..."
|
echo "Installing VSCode..."
|
||||||
omarchy-pkg-add visual-studio-code-bin
|
omarchy-pkg-add visual-studio-code-bin
|
||||||
|
|
||||||
|
|||||||
19
bin/omarchy-install-xbox-controllers
Executable file
19
bin/omarchy-install-xbox-controllers
Executable file
@@ -0,0 +1,19 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Install support for using Xbox controllers with Steam/RetroArch/etc.
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# Install xpadneo to ensure controllers work out of the box
|
||||||
|
sudo pacman -S --noconfirm --needed linux-headers
|
||||||
|
yay -S --noconfirm xpadneo-dkms
|
||||||
|
|
||||||
|
# Prevent xpad/xpadneo driver conflict
|
||||||
|
echo blacklist xpad | sudo tee /etc/modprobe.d/blacklist-xpad.conf >/dev/null
|
||||||
|
echo hid_xpadneo | sudo tee /etc/modules-load.d/xpadneo.conf >/dev/null
|
||||||
|
|
||||||
|
# Give user access to game controllers
|
||||||
|
sudo usermod -a -G input $USER
|
||||||
|
|
||||||
|
# Modules need to be loaded
|
||||||
|
gum confirm "Install requires reboot. Ready?" && sudo reboot now
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
exec setsid uwsm-app -- xdg-terminal-exec --app-id=com.omarchy.Omarchy -e bash -c 'fastfetch; read -n 1 -s'
|
# Launch the fastfetch TUI that gives information about the current system.
|
||||||
|
|
||||||
|
exec omarchy-launch-or-focus-tui "bash -c 'fastfetch; read -n 1 -s'"
|
||||||
|
|||||||
5
bin/omarchy-launch-audio
Executable file
5
bin/omarchy-launch-audio
Executable file
@@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch the Omarchy audio controls TUI (provided by wiremix).
|
||||||
|
|
||||||
|
omarchy-launch-or-focus-tui wiremix
|
||||||
7
bin/omarchy-launch-bluetooth
Executable file
7
bin/omarchy-launch-bluetooth
Executable file
@@ -0,0 +1,7 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch the Omarchy bluetooth controls TUI (provided by bluetui).
|
||||||
|
# Also attempts to unblock bluetooth service if rfkill had blocked it.
|
||||||
|
|
||||||
|
rfkill unblock bluetooth
|
||||||
|
exec omarchy-launch-or-focus-tui bluetui
|
||||||
@@ -1,10 +1,15 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch the default browser as determined by xdg-settings.
|
||||||
|
# Automatically converts --private into the correct flag for the given browser.
|
||||||
|
|
||||||
default_browser=$(xdg-settings get default-web-browser)
|
default_browser=$(xdg-settings get default-web-browser)
|
||||||
browser_exec=$(sed -n 's/^Exec=\([^ ]*\).*/\1/p' {~/.local,~/.nix-profile,/usr}/share/applications/$default_browser 2>/dev/null | head -1)
|
browser_exec=$(sed -n 's/^Exec=\([^ ]*\).*/\1/p' {~/.local,~/.nix-profile,/usr}/share/applications/$default_browser 2>/dev/null | head -1)
|
||||||
|
|
||||||
if [[ $browser_exec =~ (firefox|zen|librewolf) ]]; then
|
if [[ $browser_exec =~ (firefox|zen|librewolf|mullvad) ]]; then
|
||||||
private_flag="--private-window"
|
private_flag="--private-window"
|
||||||
|
elif [[ $browser_exec =~ edge ]]; then
|
||||||
|
private_flag="--inprivate"
|
||||||
else
|
else
|
||||||
private_flag="--incognito"
|
private_flag="--incognito"
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,10 +1,13 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch the default editor as determined by $EDITOR (set via ~/.config/uwsm/default) (or nvim if missing).
|
||||||
|
# Starts suitable editors in a terminal window and otherwise as a regular application.
|
||||||
|
|
||||||
omarchy-cmd-present "$EDITOR" || EDITOR=nvim
|
omarchy-cmd-present "$EDITOR" || EDITOR=nvim
|
||||||
|
|
||||||
case "$EDITOR" in
|
case "$EDITOR" in
|
||||||
nvim | vim | nano | micro | hx | helix)
|
nvim | vim | nano | micro | hx | helix | fresh)
|
||||||
exec setsid uwsm-app -- xdg-terminal-exec "$EDITOR" "$@"
|
exec omarchy-launch-tui "$EDITOR" "$@"
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
exec setsid uwsm-app -- "$EDITOR" "$@"
|
exec setsid uwsm-app -- "$EDITOR" "$@"
|
||||||
|
|||||||
@@ -1,4 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch a floating terminal with the Omarchy logo presentation, then execute the command passed in, and finally end with the omarchy-show-done presentation.
|
||||||
|
# Used by actions such as Update System.
|
||||||
|
|
||||||
cmd="$*"
|
cmd="$*"
|
||||||
exec setsid uwsm-app -- xdg-terminal-exec --app-id=com.omarchy.Omarchy --title=Omarchy -e bash -c "omarchy-show-logo; $cmd; omarchy-show-done"
|
exec setsid uwsm-app -- xdg-terminal-exec --app-id=org.omarchy.terminal --title=Omarchy -e bash -c "omarchy-show-logo; $cmd; if [ \$? -ne 130 ]; then omarchy-show-done; fi"
|
||||||
|
|||||||
@@ -1,5 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch or focus on a given command identified by the passed in window-pattern.
|
||||||
|
# Use by some default bindings, like the one for Spotify, to ensure there is only one instance of the application open.
|
||||||
|
|
||||||
if (($# == 0)); then
|
if (($# == 0)); then
|
||||||
echo "Usage: omarchy-launch-or-focus [window-pattern] [launch-command]"
|
echo "Usage: omarchy-launch-or-focus [window-pattern] [launch-command]"
|
||||||
exit 1
|
exit 1
|
||||||
@@ -12,5 +15,5 @@ WINDOW_ADDRESS=$(hyprctl clients -j | jq -r --arg p "$WINDOW_PATTERN" '.[]|selec
|
|||||||
if [[ -n $WINDOW_ADDRESS ]]; then
|
if [[ -n $WINDOW_ADDRESS ]]; then
|
||||||
hyprctl dispatch focuswindow "address:$WINDOW_ADDRESS"
|
hyprctl dispatch focuswindow "address:$WINDOW_ADDRESS"
|
||||||
else
|
else
|
||||||
eval exec $LAUNCH_COMMAND
|
eval exec setsid $LAUNCH_COMMAND
|
||||||
fi
|
fi
|
||||||
|
|||||||
9
bin/omarchy-launch-or-focus-tui
Executable file
9
bin/omarchy-launch-or-focus-tui
Executable file
@@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch or focus on a given TUI identified by the passed in as the command.
|
||||||
|
# Use by commands like omarchy-launch-wifi to ensure there is only one wifi configuration screen open.
|
||||||
|
|
||||||
|
APP_ID="org.omarchy.$(basename "$1")"
|
||||||
|
LAUNCH_COMMAND="omarchy-launch-tui $@"
|
||||||
|
|
||||||
|
exec omarchy-launch-or-focus "$APP_ID" "$LAUNCH_COMMAND"
|
||||||
@@ -1,5 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch or focus on a given web app identified by the window-pattern.
|
||||||
|
# Use by some default bindings, like the one for WhatsApp, to ensure there is only one instance of the application open.
|
||||||
|
|
||||||
if (($# == 0)); then
|
if (($# == 0)); then
|
||||||
echo "Usage: omarchy-launch-or-focus-webapp [window-pattern] [url-and-flags...]"
|
echo "Usage: omarchy-launch-or-focus-webapp [window-pattern] [url-and-flags...]"
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
@@ -1,28 +1,54 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch the Omarchy screensaver in the default terminal on the system with the correct font configuration.
|
||||||
|
|
||||||
# Exit early if we don't have the tte show
|
# Exit early if we don't have the tte show
|
||||||
if ! command -v tte &>/dev/null; then
|
if ! command -v tte &>/dev/null; then
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Exit early if screensave is already running
|
# Exit early if screensave is already running
|
||||||
pgrep -f "alacritty --class Screensaver" && exit 0
|
pgrep -f org.omarchy.screensaver && exit 0
|
||||||
|
|
||||||
# Allow screensaver to be turned off but also force started
|
# Allow screensaver to be turned off but also force started
|
||||||
if [[ -f ~/.local/state/omarchy/toggles/screensaver-off ]] && [[ $1 != "force" ]]; then
|
if [[ -f ~/.local/state/omarchy/toggles/screensaver-off ]] && [[ $1 != "force" ]]; then
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# Silently quit Walker on overlay
|
||||||
|
walker -q
|
||||||
|
|
||||||
focused=$(hyprctl monitors -j | jq -r '.[] | select(.focused == true).name')
|
focused=$(hyprctl monitors -j | jq -r '.[] | select(.focused == true).name')
|
||||||
|
terminal=$(xdg-terminal-exec --print-id)
|
||||||
|
|
||||||
for m in $(hyprctl monitors -j | jq -r '.[] | .name'); do
|
for m in $(hyprctl monitors -j | jq -r '.[] | .name'); do
|
||||||
hyprctl dispatch focusmonitor $m
|
hyprctl dispatch focusmonitor $m
|
||||||
|
|
||||||
# FIXME: Find a way to make this generic where we it can work for kitty + ghostty
|
case $terminal in
|
||||||
|
*Alacritty*)
|
||||||
hyprctl dispatch exec -- \
|
hyprctl dispatch exec -- \
|
||||||
alacritty --class Screensaver \
|
alacritty --class=org.omarchy.screensaver \
|
||||||
--config-file ~/.local/share/omarchy/default/alacritty/screensaver.toml \
|
--config-file ~/.local/share/omarchy/default/alacritty/screensaver.toml \
|
||||||
-e omarchy-cmd-screensaver
|
-e omarchy-cmd-screensaver
|
||||||
|
;;
|
||||||
|
*ghostty*)
|
||||||
|
hyprctl dispatch exec -- \
|
||||||
|
ghostty --class=org.omarchy.screensaver \
|
||||||
|
--config-file=~/.local/share/omarchy/default/ghostty/screensaver \
|
||||||
|
--font-size=18 \
|
||||||
|
-e omarchy-cmd-screensaver
|
||||||
|
;;
|
||||||
|
*kitty*)
|
||||||
|
hyprctl dispatch exec -- \
|
||||||
|
kitty --class=org.omarchy.screensaver \
|
||||||
|
--override font_size=18 \
|
||||||
|
--override window_padding_width=0 \
|
||||||
|
-e omarchy-cmd-screensaver
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
notify-send "✋ Screensaver only runs in Alacritty, Ghostty, or Kitty"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
hyprctl dispatch focusmonitor $focused
|
hyprctl dispatch focusmonitor $focused
|
||||||
|
|||||||
5
bin/omarchy-launch-tui
Executable file
5
bin/omarchy-launch-tui
Executable file
@@ -0,0 +1,5 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch the TUI command passed in as an argument in the default terminal with an org.omarchy.COMMAND app id for styling.
|
||||||
|
|
||||||
|
exec setsid uwsm-app -- xdg-terminal-exec --app-id=org.omarchy.$(basename $1) -e "$1" "${@:2}"
|
||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch the Walker application launcher while ensuring that it's data provider (called elephant) is running first.
|
||||||
|
|
||||||
# Ensure elephant is running before launching walker
|
# Ensure elephant is running before launching walker
|
||||||
if ! pgrep -x elephant > /dev/null; then
|
if ! pgrep -x elephant > /dev/null; then
|
||||||
setsid uwsm-app -- elephant &
|
setsid uwsm-app -- elephant &
|
||||||
|
|||||||
@@ -1,9 +1,11 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch the passed in URL as a web app in the default browser (or chromium if the default doesn't support --app).
|
||||||
|
|
||||||
browser=$(xdg-settings get default-web-browser)
|
browser=$(xdg-settings get default-web-browser)
|
||||||
|
|
||||||
case $browser in
|
case $browser in
|
||||||
google-chrome* | brave-browser* | microsoft-edge* | opera* | vivaldi* | helium-browser*) ;;
|
google-chrome* | brave-browser* | microsoft-edge* | opera* | vivaldi* | helium*) ;;
|
||||||
*) browser="chromium.desktop" ;;
|
*) browser="chromium.desktop" ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
|||||||
@@ -1,3 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
exec setsid uwsm-app -- xdg-terminal-exec --app-id=com.omarchy.Impala -e impala "$@"
|
# Launch the Omarchy wifi controls (provided by the Impala TUI).
|
||||||
|
# Attempts to unblock the wifi service first in case it should be been blocked.
|
||||||
|
|
||||||
|
rfkill unblock wifi
|
||||||
|
omarchy-launch-or-focus-tui impala
|
||||||
|
|||||||
@@ -1,12 +1,17 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Locks the system using hyprlock, but not before ensuring 1password has also been locked, and the screensaver stopped.
|
||||||
|
|
||||||
# Lock the screen
|
# Lock the screen
|
||||||
pidof hyprlock || hyprlock &
|
pidof hyprlock || hyprlock &
|
||||||
|
|
||||||
|
# Set keyboard layout to default (first layout)
|
||||||
|
hyprctl switchxkblayout all 0 > /dev/null 2>&1
|
||||||
|
|
||||||
# Ensure 1password is locked
|
# Ensure 1password is locked
|
||||||
if pgrep -x "1password" >/dev/null; then
|
if pgrep -x "1password" >/dev/null; then
|
||||||
1password --lock &
|
1password --lock &
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Avoid running screensaver when locked
|
# Avoid running screensaver when locked
|
||||||
pkill -f "alacritty --class Screensaver"
|
pkill -f org.omarchy.screensaver
|
||||||
|
|||||||
232
bin/omarchy-menu
232
bin/omarchy-menu
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Launch the Omarchy Menu or takes a parameter to jump straight to a submenu.
|
||||||
|
|
||||||
export PATH="$HOME/.local/share/omarchy/bin:$PATH"
|
export PATH="$HOME/.local/share/omarchy/bin:$PATH"
|
||||||
|
|
||||||
# Set to true when going directly to a submenu, so we can exit directly
|
# Set to true when going directly to a submenu, so we can exit directly
|
||||||
@@ -33,11 +35,11 @@ menu() {
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -e "$options" | omarchy-launch-walker --dmenu --width 295 --minheight 1 --maxheight 600 -p "$prompt…" "${args[@]}" 2>/dev/null
|
echo -e "$options" | omarchy-launch-walker --dmenu --width 295 --minheight 1 --maxheight 630 -p "$prompt…" "${args[@]}" 2>/dev/null
|
||||||
}
|
}
|
||||||
|
|
||||||
terminal() {
|
terminal() {
|
||||||
xdg-terminal-exec --app-id=com.omarchy.Omarchy "$@"
|
xdg-terminal-exec --app-id=org.omarchy.terminal "$@"
|
||||||
}
|
}
|
||||||
|
|
||||||
present_terminal() {
|
present_terminal() {
|
||||||
@@ -86,45 +88,71 @@ show_learn_menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
show_trigger_menu() {
|
show_trigger_menu() {
|
||||||
case $(menu "Trigger" " Capture\n Share\n Toggle") in
|
case $(menu "Trigger" " Capture\n Share\n Toggle\n Hardware") in
|
||||||
*Capture*) show_capture_menu ;;
|
*Capture*) show_capture_menu ;;
|
||||||
*Share*) show_share_menu ;;
|
*Share*) show_share_menu ;;
|
||||||
*Toggle*) show_toggle_menu ;;
|
*Toggle*) show_toggle_menu ;;
|
||||||
|
*Hardware*) show_hardware_menu ;;
|
||||||
*) show_main_menu ;;
|
*) show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_capture_menu() {
|
show_capture_menu() {
|
||||||
case $(menu "Capture" " Screenshot\n Screenrecord\n Color") in
|
case $(menu "Capture" " Screenshot\n Screenrecord\n Color") in
|
||||||
*Screenshot*) show_screenshot_menu ;;
|
*Screenshot*) omarchy-cmd-screenshot ;;
|
||||||
*Screenrecord*) show_screenrecord_menu ;;
|
*Screenrecord*) show_screenrecord_menu ;;
|
||||||
*Color*) pkill hyprpicker || hyprpicker -a ;;
|
*Color*) pkill hyprpicker || hyprpicker -a ;;
|
||||||
*) show_trigger_menu ;;
|
*) show_trigger_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_screenshot_menu() {
|
get_webcam_list() {
|
||||||
case $(menu "Screenshot" " Snap with Editing\n Straight to Clipboard") in
|
v4l2-ctl --list-devices 2>/dev/null | while IFS= read -r line; do
|
||||||
*Editing*) omarchy-cmd-screenshot smart ;;
|
if [[ "$line" != $'\t'* && -n "$line" ]]; then
|
||||||
*Clipboard*) omarchy-cmd-screenshot smart clipboard ;;
|
local name="$line"
|
||||||
*) show_capture_menu ;;
|
IFS= read -r device || break
|
||||||
esac
|
device=$(echo "$device" | tr -d '\t' | head -1)
|
||||||
|
[[ -n "$device" ]] && echo "$device $name"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
show_webcam_select_menu() {
|
||||||
|
local devices=$(get_webcam_list)
|
||||||
|
local count=$(echo "$devices" | grep -c . 2>/dev/null || echo 0)
|
||||||
|
|
||||||
|
if [[ -z "$devices" || "$count" -eq 0 ]]; then
|
||||||
|
notify-send "No webcam devices found" -u critical -t 3000
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "$count" -eq 1 ]]; then
|
||||||
|
echo "$devices" | awk '{print $1}'
|
||||||
|
else
|
||||||
|
menu "Select Webcam" "$devices" | awk '{print $1}'
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
show_screenrecord_menu() {
|
show_screenrecord_menu() {
|
||||||
case $(menu "Screenrecord" " Region\n Region + Audio\n Display\n Display + Audio\n Display + Webcam") in
|
omarchy-cmd-screenrecord --stop-recording && exit 0
|
||||||
*"Region + Audio"*) omarchy-cmd-screenrecord region --with-audio ;;
|
|
||||||
*Region*) omarchy-cmd-screenrecord ;;
|
case $(menu "Screenrecord" " With desktop audio\n With desktop + microphone audio\n With desktop + microphone audio + webcam") in
|
||||||
*"Display + Audio"*) omarchy-cmd-screenrecord output --with-audio ;;
|
*"With desktop audio") omarchy-cmd-screenrecord --with-desktop-audio ;;
|
||||||
*"Display + Webcam"*) omarchy-cmd-screenrecord output --with-audio --with-webcam ;;
|
*"With desktop + microphone audio") omarchy-cmd-screenrecord --with-desktop-audio --with-microphone-audio ;;
|
||||||
*Display*) omarchy-cmd-screenrecord output ;;
|
*"With desktop + microphone audio + webcam")
|
||||||
|
local device=$(show_webcam_select_menu) || {
|
||||||
|
back_to show_capture_menu
|
||||||
|
return
|
||||||
|
}
|
||||||
|
omarchy-cmd-screenrecord --with-desktop-audio --with-microphone-audio --with-webcam --webcam-device="$device"
|
||||||
|
;;
|
||||||
*) back_to show_capture_menu ;;
|
*) back_to show_capture_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_share_menu() {
|
show_share_menu() {
|
||||||
case $(menu "Share" " Clipboard\n File \n Folder") in
|
case $(menu "Share" " Clipboard\n File \n Folder") in
|
||||||
*Clipboard*) terminal bash -c "omarchy-cmd-share clipboard" ;;
|
*Clipboard*) omarchy-cmd-share clipboard ;;
|
||||||
*File*) terminal bash -c "omarchy-cmd-share file" ;;
|
*File*) terminal bash -c "omarchy-cmd-share file" ;;
|
||||||
*Folder*) terminal bash -c "omarchy-cmd-share folder" ;;
|
*Folder*) terminal bash -c "omarchy-cmd-share folder" ;;
|
||||||
*) back_to show_trigger_menu ;;
|
*) back_to show_trigger_menu ;;
|
||||||
@@ -141,6 +169,13 @@ show_toggle_menu() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
show_hardware_menu() {
|
||||||
|
case $(menu "Toggle" " Hybrid GPU") in
|
||||||
|
*"Hybrid GPU"*) present_terminal omarchy-toggle-hybrid-gpu ;;
|
||||||
|
*) show_trigger_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
show_style_menu() {
|
show_style_menu() {
|
||||||
case $(menu "Style" " Theme\n Font\n Background\n Hyprland\n Screensaver\n About") in
|
case $(menu "Style" " Theme\n Font\n Background\n Hyprland\n Screensaver\n About") in
|
||||||
*Theme*) show_theme_menu ;;
|
*Theme*) show_theme_menu ;;
|
||||||
@@ -154,12 +189,7 @@ show_style_menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
show_theme_menu() {
|
show_theme_menu() {
|
||||||
theme=$(menu "Theme" "$(omarchy-theme-list)" "" "$(omarchy-theme-current)")
|
omarchy-launch-walker -m menus:omarchythemes --width 800 --minheight 400
|
||||||
if [[ "$theme" == "CNCLD" || -z "$theme" ]]; then
|
|
||||||
back_to show_style_menu
|
|
||||||
else
|
|
||||||
omarchy-theme-set "$theme"
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
show_font_menu() {
|
show_font_menu() {
|
||||||
@@ -172,26 +202,20 @@ show_font_menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
show_setup_menu() {
|
show_setup_menu() {
|
||||||
local options=" Audio\n Wifi\n Bluetooth\n Power Profile\n Monitors"
|
local options=" Audio\n Wifi\n Bluetooth\n Power Profile\n System Sleep\n Monitors"
|
||||||
[ -f ~/.config/hypr/bindings.conf ] && options="$options\n Keybindings"
|
[ -f ~/.config/hypr/bindings.conf ] && options="$options\n Keybindings"
|
||||||
[ -f ~/.config/hypr/input.conf ] && options="$options\n Input"
|
[ -f ~/.config/hypr/input.conf ] && options="$options\n Input"
|
||||||
options="$options\n Defaults\n DNS\n Security\n Config"
|
options="$options\n DNS\n Security\n Config"
|
||||||
|
|
||||||
case $(menu "Setup" "$options") in
|
case $(menu "Setup" "$options") in
|
||||||
*Audio*) xdg-terminal-exec --app-id=com.omarchy.Wiremix -e wiremix ;;
|
*Audio*) omarchy-launch-audio ;;
|
||||||
*Wifi*)
|
*Wifi*) omarchy-launch-wifi ;;
|
||||||
rfkill unblock wifi
|
*Bluetooth*) omarchy-launch-bluetooth ;;
|
||||||
omarchy-launch-wifi
|
|
||||||
;;
|
|
||||||
*Bluetooth*)
|
|
||||||
rfkill unblock bluetooth
|
|
||||||
blueberry
|
|
||||||
;;
|
|
||||||
*Power*) show_setup_power_menu ;;
|
*Power*) show_setup_power_menu ;;
|
||||||
|
*System*) show_setup_system_menu ;;
|
||||||
*Monitors*) open_in_editor ~/.config/hypr/monitors.conf ;;
|
*Monitors*) open_in_editor ~/.config/hypr/monitors.conf ;;
|
||||||
*Keybindings*) open_in_editor ~/.config/hypr/bindings.conf ;;
|
*Keybindings*) open_in_editor ~/.config/hypr/bindings.conf ;;
|
||||||
*Input*) open_in_editor ~/.config/hypr/input.conf ;;
|
*Input*) open_in_editor ~/.config/hypr/input.conf ;;
|
||||||
*Defaults*) open_in_editor ~/.config/uwsm/default ;;
|
|
||||||
*DNS*) present_terminal omarchy-setup-dns ;;
|
*DNS*) present_terminal omarchy-setup-dns ;;
|
||||||
*Security*) show_setup_security_menu ;;
|
*Security*) show_setup_security_menu ;;
|
||||||
*Config*) show_setup_config_menu ;;
|
*Config*) show_setup_config_menu ;;
|
||||||
@@ -209,8 +233,17 @@ show_setup_power_menu() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
show_setup_security_menu() {
|
||||||
|
case $(menu "Setup" " Fingerprint\n Fido2") in
|
||||||
|
*Fingerprint*) present_terminal omarchy-setup-fingerprint ;;
|
||||||
|
*Fido2*) present_terminal omarchy-setup-fido2 ;;
|
||||||
|
*) show_setup_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
show_setup_config_menu() {
|
show_setup_config_menu() {
|
||||||
case $(menu "Setup" " Hyprland\n Hypridle\n Hyprlock\n Hyprsunset\n Swayosd\n Walker\n Waybar\n XCompose") in
|
case $(menu "Setup" " Defaults\n Hyprland\n Hypridle\n Hyprlock\n Hyprsunset\n Swayosd\n Walker\n Waybar\n XCompose") in
|
||||||
|
*Defaults*) open_in_editor ~/.config/uwsm/default ;;
|
||||||
*Hyprland*) open_in_editor ~/.config/hypr/hyprland.conf ;;
|
*Hyprland*) open_in_editor ~/.config/hypr/hyprland.conf ;;
|
||||||
*Hypridle*) open_in_editor ~/.config/hypr/hypridle.conf && omarchy-restart-hypridle ;;
|
*Hypridle*) open_in_editor ~/.config/hypr/hypridle.conf && omarchy-restart-hypridle ;;
|
||||||
*Hyprlock*) open_in_editor ~/.config/hypr/hyprlock.conf ;;
|
*Hyprlock*) open_in_editor ~/.config/hypr/hyprlock.conf ;;
|
||||||
@@ -219,14 +252,29 @@ show_setup_config_menu() {
|
|||||||
*Walker*) open_in_editor ~/.config/walker/config.toml && omarchy-restart-walker ;;
|
*Walker*) open_in_editor ~/.config/walker/config.toml && omarchy-restart-walker ;;
|
||||||
*Waybar*) open_in_editor ~/.config/waybar/config.jsonc && omarchy-restart-waybar ;;
|
*Waybar*) open_in_editor ~/.config/waybar/config.jsonc && omarchy-restart-waybar ;;
|
||||||
*XCompose*) open_in_editor ~/.XCompose && omarchy-restart-xcompose ;;
|
*XCompose*) open_in_editor ~/.XCompose && omarchy-restart-xcompose ;;
|
||||||
*) show_main_menu ;;
|
*) show_setup_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_setup_security_menu() {
|
show_setup_system_menu() {
|
||||||
case $(menu "Setup" " Fingerprint\n Fido2") in
|
local options=""
|
||||||
*Fingerprint*) present_terminal omarchy-setup-fingerprint ;;
|
|
||||||
*Fido2*) present_terminal omarchy-setup-fido2 ;;
|
if [ -f ~/.local/state/omarchy/toggles/suspend-on ]; then
|
||||||
|
options="$options Disable Suspend"
|
||||||
|
else
|
||||||
|
options="$options Enable Suspend"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if omarchy-hibernation-available; then
|
||||||
|
options="$options\n Disable Hibernate"
|
||||||
|
else
|
||||||
|
options="$options\n Enable Hibernate"
|
||||||
|
fi
|
||||||
|
|
||||||
|
case $(menu "System" "$options") in
|
||||||
|
*Suspend*) omarchy-toggle-suspend ;;
|
||||||
|
*"Enable Hibernate"*) present_terminal omarchy-hibernation-setup ;;
|
||||||
|
*"Disable Hibernate"*) present_terminal omarchy-hibernation-remove ;;
|
||||||
*) show_setup_menu ;;
|
*) show_setup_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
@@ -263,7 +311,7 @@ show_install_editor_menu() {
|
|||||||
case $(menu "Install" " VSCode\n Cursor\n Zed\n Sublime Text\n Helix\n Emacs") in
|
case $(menu "Install" " VSCode\n Cursor\n Zed\n Sublime Text\n Helix\n Emacs") in
|
||||||
*VSCode*) present_terminal omarchy-install-vscode ;;
|
*VSCode*) present_terminal omarchy-install-vscode ;;
|
||||||
*Cursor*) install_and_launch "Cursor" "cursor-bin" "cursor" ;;
|
*Cursor*) install_and_launch "Cursor" "cursor-bin" "cursor" ;;
|
||||||
*Zed*) install_and_launch "Zed" "zed" "dev.zed.Zed" ;;
|
*Zed*) present_terminal "echo 'Installing Zed...'; sudo pacman -S zed && setsid gtk-launch dev.zed.Zed" ;;
|
||||||
*Sublime*) install_and_launch "Sublime Text" "sublime-text-4" "sublime_text" ;;
|
*Sublime*) install_and_launch "Sublime Text" "sublime-text-4" "sublime_text" ;;
|
||||||
*Helix*) install "Helix" "helix" ;;
|
*Helix*) install "Helix" "helix" ;;
|
||||||
*Emacs*) install "Emacs" "emacs-wayland" && systemctl --user enable --now emacs.service ;;
|
*Emacs*) install "Emacs" "emacs-wayland" && systemctl --user enable --now emacs.service ;;
|
||||||
@@ -287,24 +335,27 @@ show_install_ai_menu() {
|
|||||||
echo ollama
|
echo ollama
|
||||||
)
|
)
|
||||||
|
|
||||||
case $(menu "Install" " Claude Code\n Cursor CLI\n Gemini\n OpenAI Codex\n LM Studio\n Ollama\n Crush\n opencode") in
|
case $(menu "Install" " Dictation\n Claude Code\n Copilot CLI\n Cursor CLI\n Gemini\n OpenAI Codex\n LM Studio\n Ollama\n Crush") in
|
||||||
|
*Dictation*) present_terminal omarchy-voxtype-install ;;
|
||||||
*Claude*) install "Claude Code" "claude-code" ;;
|
*Claude*) install "Claude Code" "claude-code" ;;
|
||||||
|
*Copilot*) install "Copilot CLI" "github-copilot-cli" ;;
|
||||||
*Cursor*) install "Cursor CLI" "cursor-cli" ;;
|
*Cursor*) install "Cursor CLI" "cursor-cli" ;;
|
||||||
*OpenAI*) install "OpenAI Codex" "openai-codex-bin" ;;
|
|
||||||
*Gemini*) install "Gemini" "gemini-cli" ;;
|
*Gemini*) install "Gemini" "gemini-cli" ;;
|
||||||
|
*OpenAI*) install "OpenAI Codex" "openai-codex" ;;
|
||||||
*Studio*) install "LM Studio" "lmstudio" ;;
|
*Studio*) install "LM Studio" "lmstudio" ;;
|
||||||
*Ollama*) install "Ollama" $ollama_pkg ;;
|
*Ollama*) install "Ollama" $ollama_pkg ;;
|
||||||
*Crush*) install "Crush" "crush-bin" ;;
|
*Crush*) install "Crush" "crush-bin" ;;
|
||||||
*opencode*) install "opencode" "opencode" ;;
|
|
||||||
*) show_install_menu ;;
|
*) show_install_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_install_gaming_menu() {
|
show_install_gaming_menu() {
|
||||||
case $(menu "Install" " Steam\n RetroArch [AUR]\n Minecraft") in
|
case $(menu "Install" " Steam\n NVIDIA GeForce NOW\n RetroArch [AUR]\n Minecraft\n Xbox Controller [AUR]") in
|
||||||
*Steam*) present_terminal omarchy-install-steam ;;
|
*Steam*) present_terminal omarchy-install-steam ;;
|
||||||
|
*GeForce*) present_terminal omarchy-install-geforce-now ;;
|
||||||
*RetroArch*) aur_install_and_launch "RetroArch" "retroarch retroarch-assets libretro libretro-fbneo" "com.libretro.RetroArch.desktop" ;;
|
*RetroArch*) aur_install_and_launch "RetroArch" "retroarch retroarch-assets libretro libretro-fbneo" "com.libretro.RetroArch.desktop" ;;
|
||||||
*Minecraft*) install_and_launch "Minecraft" "minecraft-launcher" "minecraft-launcher" ;;
|
*Minecraft*) install_and_launch "Minecraft" "minecraft-launcher" "minecraft-launcher" ;;
|
||||||
|
*Xbox*) present_terminal omarchy-install-xbox-controllers ;;
|
||||||
*) show_install_menu ;;
|
*) show_install_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
@@ -312,18 +363,19 @@ show_install_gaming_menu() {
|
|||||||
show_install_style_menu() {
|
show_install_style_menu() {
|
||||||
case $(menu "Install" " Theme\n Background\n Font") in
|
case $(menu "Install" " Theme\n Background\n Font") in
|
||||||
*Theme*) present_terminal omarchy-theme-install ;;
|
*Theme*) present_terminal omarchy-theme-install ;;
|
||||||
*Background*) nautilus ~/.config/omarchy/current/theme/backgrounds ;;
|
*Background*) omarchy-theme-bg-install ;;
|
||||||
*Font*) show_install_font_menu ;;
|
*Font*) show_install_font_menu ;;
|
||||||
*) show_install_menu ;;
|
*) show_install_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_install_font_menu() {
|
show_install_font_menu() {
|
||||||
case $(menu "Install" " Meslo LG Mono\n Fira Code\n Victor Code\n Bistream Vera Mono" "--width 350") in
|
case $(menu "Install" " Meslo LG Mono\n Fira Code\n Victor Code\n Bistream Vera Mono\n Iosevka" "--width 350") in
|
||||||
*Meslo*) install_font "Meslo LG Mono" "ttf-meslo-nerd" "MesloLGL Nerd Font" ;;
|
*Meslo*) install_font "Meslo LG Mono" "ttf-meslo-nerd" "MesloLGL Nerd Font" ;;
|
||||||
*Fira*) install_font "Fira Code" "ttf-firacode-nerd" "FiraCode Nerd Font" ;;
|
*Fira*) install_font "Fira Code" "ttf-firacode-nerd" "FiraCode Nerd Font" ;;
|
||||||
*Victor*) install_font "Victor Code" "ttf-victor-mono-nerd" "VictorMono Nerd Font" ;;
|
*Victor*) install_font "Victor Code" "ttf-victor-mono-nerd" "VictorMono Nerd Font" ;;
|
||||||
*Bistream*) install_font "Bistream Vera Code" "ttf-bitstream-vera-mono-nerd" "BitstromWera Nerd Font" ;;
|
*Bistream*) install_font "Bistream Vera Code" "ttf-bitstream-vera-mono-nerd" "BitstromWera Nerd Font" ;;
|
||||||
|
*Iosevka*) install_font "Iosevka" "ttf-iosevka-nerd" "Iosevka Nerd Font Mono" ;;
|
||||||
*) show_install_menu ;;
|
*) show_install_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
@@ -374,10 +426,13 @@ show_install_elixir_menu() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
show_remove_menu() {
|
show_remove_menu() {
|
||||||
case $(menu "Remove" " Package\n Web App\n TUI\n Theme\n Windows\n Fingerprint\n Fido2") in
|
case $(menu "Remove" " Package\n Web App\n TUI\n Development\n Preinstalls\n Dictation\n Theme\n Windows\n Fingerprint\n Fido2") in
|
||||||
*Package*) terminal omarchy-pkg-remove ;;
|
*Package*) terminal omarchy-pkg-remove ;;
|
||||||
*Web*) present_terminal omarchy-webapp-remove ;;
|
*Web*) present_terminal omarchy-webapp-remove ;;
|
||||||
*TUI*) present_terminal omarchy-tui-remove ;;
|
*TUI*) present_terminal omarchy-tui-remove ;;
|
||||||
|
*Development*) show_remove_development_menu ;;
|
||||||
|
*Preinstalls*) present_terminal omarchy-remove-all ;;
|
||||||
|
*Dictation*) present_terminal omarchy-voxtype-remove ;;
|
||||||
*Theme*) present_terminal omarchy-theme-remove ;;
|
*Theme*) present_terminal omarchy-theme-remove ;;
|
||||||
*Windows*) present_terminal "omarchy-windows-vm remove" ;;
|
*Windows*) present_terminal "omarchy-windows-vm remove" ;;
|
||||||
*Fingerprint*) present_terminal "omarchy-setup-fingerprint --remove" ;;
|
*Fingerprint*) present_terminal "omarchy-setup-fingerprint --remove" ;;
|
||||||
@@ -386,9 +441,54 @@ show_remove_menu() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
show_remove_development_menu() {
|
||||||
|
case $(menu "Remove" " Ruby on Rails\n JavaScript\n Go\n PHP\n Python\n Elixir\n Zig\n Rust\n Java\n .NET\n OCaml\n Clojure") in
|
||||||
|
*Rails*) present_terminal "omarchy-remove-dev-env ruby" ;;
|
||||||
|
*JavaScript*) show_remove_javascript_menu ;;
|
||||||
|
*Go*) present_terminal "omarchy-remove-dev-env go" ;;
|
||||||
|
*PHP*) show_remove_php_menu ;;
|
||||||
|
*Python*) present_terminal "omarchy-remove-dev-env python" ;;
|
||||||
|
*Elixir*) show_remove_elixir_menu ;;
|
||||||
|
*Zig*) present_terminal "omarchy-remove-dev-env zig" ;;
|
||||||
|
*Rust*) present_terminal "omarchy-remove-dev-env rust" ;;
|
||||||
|
*Java*) present_terminal "omarchy-remove-dev-env java" ;;
|
||||||
|
*NET*) present_terminal "omarchy-remove-dev-env dotnet" ;;
|
||||||
|
*OCaml*) present_terminal "omarchy-remove-dev-env ocaml" ;;
|
||||||
|
*Clojure*) present_terminal "omarchy-remove-dev-env clojure" ;;
|
||||||
|
*) show_remove_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_remove_javascript_menu() {
|
||||||
|
case $(menu "Remove" " Node.js\n Bun\n Deno") in
|
||||||
|
*Node*) present_terminal "omarchy-remove-dev-env node" ;;
|
||||||
|
*Bun*) present_terminal "omarchy-remove-dev-env bun" ;;
|
||||||
|
*Deno*) present_terminal "omarchy-remove-dev-env deno" ;;
|
||||||
|
*) show_remove_development_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_remove_php_menu() {
|
||||||
|
case $(menu "Remove" " PHP\n Laravel\n Symfony") in
|
||||||
|
*PHP*) present_terminal "omarchy-remove-dev-env php" ;;
|
||||||
|
*Laravel*) present_terminal "omarchy-remove-dev-env laravel" ;;
|
||||||
|
*Symfony*) present_terminal "omarchy-remove-dev-env symfony" ;;
|
||||||
|
*) show_remove_development_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
show_remove_elixir_menu() {
|
||||||
|
case $(menu "Remove" " Elixir\n Phoenix") in
|
||||||
|
*Elixir*) present_terminal "omarchy-remove-dev-env elixir" ;;
|
||||||
|
*Phoenix*) present_terminal "omarchy-remove-dev-env phoenix" ;;
|
||||||
|
*) show_remove_development_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
show_update_menu() {
|
show_update_menu() {
|
||||||
case $(menu "Update" " Omarchy\n Config\n Extra Themes\n Process\n Hardware\n Firmware\n Password\n Timezone\n Time") in
|
case $(menu "Update" " Omarchy\n Channel\n Config\n Extra Themes\n Process\n Hardware\n Firmware\n Password\n Timezone\n Time") in
|
||||||
*Omarchy*) present_terminal omarchy-update ;;
|
*Omarchy*) present_terminal omarchy-update ;;
|
||||||
|
*Channel*) show_update_channel_menu ;;
|
||||||
*Config*) show_update_config_menu ;;
|
*Config*) show_update_config_menu ;;
|
||||||
*Themes*) present_terminal omarchy-theme-update ;;
|
*Themes*) present_terminal omarchy-theme-update ;;
|
||||||
*Process*) show_update_process_menu ;;
|
*Process*) show_update_process_menu ;;
|
||||||
@@ -401,6 +501,15 @@ show_update_menu() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
show_update_channel_menu() {
|
||||||
|
case $(menu "Update channel" "🟢 Stable\n🟡 RC\n🟠 Edge\n🔴 Dev") in
|
||||||
|
*Stable*) present_terminal "omarchy-channel-set stable" ;;
|
||||||
|
*RC*) present_terminal "omarchy-channel-set rc" ;;
|
||||||
|
*Edge*) present_terminal "omarchy-channel-set edge" ;;
|
||||||
|
*Dev*) present_terminal "omarchy-channel-set dev" ;;
|
||||||
|
*) show_update_menu ;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
show_update_process_menu() {
|
show_update_process_menu() {
|
||||||
case $(menu "Restart" " Hypridle\n Hyprsunset\n Swayosd\n Walker\n Waybar") in
|
case $(menu "Restart" " Hypridle\n Hyprsunset\n Swayosd\n Walker\n Waybar") in
|
||||||
*Hypridle*) omarchy-restart-hypridle ;;
|
*Hypridle*) omarchy-restart-hypridle ;;
|
||||||
@@ -443,13 +552,23 @@ show_update_password_menu() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
show_about() {
|
||||||
|
omarchy-launch-about
|
||||||
|
}
|
||||||
|
|
||||||
show_system_menu() {
|
show_system_menu() {
|
||||||
case $(menu "System" " Lock\n Screensaver\n Suspend\n Restart\n Shutdown") in
|
local options=" Lock\n Screensaver"
|
||||||
|
[ -f ~/.local/state/omarchy/toggles/suspend-on ] && options="$options\n Suspend"
|
||||||
|
omarchy-hibernation-available && options="$options\n Hibernate"
|
||||||
|
options="$options\n Restart\n Shutdown"
|
||||||
|
|
||||||
|
case $(menu "System" "$options") in
|
||||||
*Lock*) omarchy-lock-screen ;;
|
*Lock*) omarchy-lock-screen ;;
|
||||||
*Screensaver*) omarchy-launch-screensaver force ;;
|
*Screensaver*) omarchy-launch-screensaver force ;;
|
||||||
*Suspend*) systemctl suspend ;;
|
*Suspend*) systemctl suspend ;;
|
||||||
*Restart*) omarchy-state clear re*-required && systemctl reboot --no-wall ;;
|
*Hibernate*) systemctl hibernate ;;
|
||||||
*Shutdown*) omarchy-state clear re*-required && systemctl poweroff --no-wall ;;
|
*Restart*) omarchy-cmd-reboot ;;
|
||||||
|
*Shutdown*) omarchy-cmd-shutdown ;;
|
||||||
*) back_to show_main_menu ;;
|
*) back_to show_main_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
@@ -464,6 +583,7 @@ go_to_menu() {
|
|||||||
*learn*) show_learn_menu ;;
|
*learn*) show_learn_menu ;;
|
||||||
*trigger*) show_trigger_menu ;;
|
*trigger*) show_trigger_menu ;;
|
||||||
*share*) show_share_menu ;;
|
*share*) show_share_menu ;;
|
||||||
|
*capture*) show_capture_menu ;;
|
||||||
*style*) show_style_menu ;;
|
*style*) show_style_menu ;;
|
||||||
*theme*) show_theme_menu ;;
|
*theme*) show_theme_menu ;;
|
||||||
*screenshot*) show_screenshot_menu ;;
|
*screenshot*) show_screenshot_menu ;;
|
||||||
@@ -473,11 +593,15 @@ go_to_menu() {
|
|||||||
*install*) show_install_menu ;;
|
*install*) show_install_menu ;;
|
||||||
*remove*) show_remove_menu ;;
|
*remove*) show_remove_menu ;;
|
||||||
*update*) show_update_menu ;;
|
*update*) show_update_menu ;;
|
||||||
*about*) omarchy-launch-about ;;
|
*about*) show_about ;;
|
||||||
*system*) show_system_menu ;;
|
*system*) show_system_menu ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Allow user extensions and overrides
|
||||||
|
USER_EXTENSIONS="$HOME/.config/omarchy/extensions/menu.sh"
|
||||||
|
[[ -f $USER_EXTENSIONS ]] && source "$USER_EXTENSIONS"
|
||||||
|
|
||||||
if [[ -n "$1" ]]; then
|
if [[ -n "$1" ]]; then
|
||||||
BACK_TO_EXIT=true
|
BACK_TO_EXIT=true
|
||||||
go_to_menu "$1"
|
go_to_menu "$1"
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# A script to display Hyprland keybindings defined in your configuration
|
# Display Hyprland keybindings defined in your configuration using walker for an interactive search menu.
|
||||||
# using walker for an interactive search menu.
|
|
||||||
|
|
||||||
declare -A KEYCODE_SYM_MAP
|
declare -A KEYCODE_SYM_MAP
|
||||||
|
|
||||||
@@ -89,6 +88,7 @@ dynamic_bindings() {
|
|||||||
jq -r '.[] | {modmask, key, keycode, description, dispatcher, arg} | "\(.modmask),\(.key)@\(.keycode),\(.description),\(.dispatcher),\(.arg)"' |
|
jq -r '.[] | {modmask, key, keycode, description, dispatcher, arg} | "\(.modmask),\(.key)@\(.keycode),\(.description),\(.dispatcher),\(.arg)"' |
|
||||||
sed -r \
|
sed -r \
|
||||||
-e 's/null//' \
|
-e 's/null//' \
|
||||||
|
-e 's,~/.local/share/omarchy/bin/,,' \
|
||||||
-e 's,uwsm app -- ,,' \
|
-e 's,uwsm app -- ,,' \
|
||||||
-e 's,uwsm-app -- ,,' \
|
-e 's,uwsm-app -- ,,' \
|
||||||
-e 's/@0//' \
|
-e 's/@0//' \
|
||||||
@@ -175,28 +175,37 @@ prioritize_entries() {
|
|||||||
if (match(line, /System menu/)) prio = 5
|
if (match(line, /System menu/)) prio = 5
|
||||||
if (match(line, /Theme menu/)) prio = 6
|
if (match(line, /Theme menu/)) prio = 6
|
||||||
if (match(line, /Full screen/)) prio = 7
|
if (match(line, /Full screen/)) prio = 7
|
||||||
if (match(line, /Close window/)) prio = 8
|
if (match(line, /Full width/)) prio = 8
|
||||||
if (match(line, /Toggle window floating/)) prio = 9
|
if (match(line, /Close window/)) prio = 9
|
||||||
if (match(line, /Toggle window split/)) prio = 10
|
if (match(line, /Close all windows/)) prio = 10
|
||||||
if (match(line, /Universal/)) prio = 11
|
if (match(line, /Lock system/)) prio = 11
|
||||||
if (match(line, /Clipboard/)) prio = 12
|
if (match(line, /Toggle window floating/)) prio = 12
|
||||||
if (match(line, /Emoji picker/)) prio = 13
|
if (match(line, /Toggle window split/)) prio = 13
|
||||||
if (match(line, /Color picker/)) prio = 14
|
if (match(line, /Pop window/)) prio = 14
|
||||||
if (match(line, /Screenshot/)) prio = 15
|
if (match(line, /Universal/)) prio = 15
|
||||||
if (match(line, /Screenrecording/)) prio = 16
|
if (match(line, /Clipboard/)) prio = 16
|
||||||
if (match(line, /(Switch|Next|Former|Previous).*workspace/)) prio = 17
|
if (match(line, /Audio controls/)) prio = 17
|
||||||
if (match(line, /Move window to workspace/)) prio = 18
|
if (match(line, /Bluetooth controls/)) prio = 18
|
||||||
if (match(line, /Swap window/)) prio = 19
|
if (match(line, /Wifi controls/)) prio = 19
|
||||||
if (match(line, /Move window focus/)) prio = 20
|
if (match(line, /Emoji picker/)) prio = 20
|
||||||
if (match(line, /Move window$/)) prio = 21
|
if (match(line, /Color picker/)) prio = 21
|
||||||
if (match(line, /Resize window/)) prio = 22
|
if (match(line, /Screenshot/)) prio = 22
|
||||||
if (match(line, /Expand window/)) prio = 23
|
if (match(line, /Screenrecording/)) prio = 23
|
||||||
if (match(line, /Shrink window/)) prio = 24
|
if (match(line, /(Switch|Next|Former|Previous).*workspace/)) prio = 24
|
||||||
if (match(line, /scratchpad/)) prio = 25
|
if (match(line, /Move window to workspace/)) prio = 25
|
||||||
if (match(line, /notification/)) prio = 26
|
if (match(line, /Move window silently to workspace/)) prio = 26
|
||||||
if (match(line, /Toggle window transparency/)) prio = 27
|
if (match(line, /Swap window/)) prio = 27
|
||||||
if (match(line, /Toggle workspace gaps/)) prio = 28
|
if (match(line, /Move window focus/)) prio = 28
|
||||||
if (match(line, /Toggle nightlight/)) prio = 29
|
if (match(line, /Move window$/)) prio = 29
|
||||||
|
if (match(line, /Resize window/)) prio = 30
|
||||||
|
if (match(line, /Expand window/)) prio = 31
|
||||||
|
if (match(line, /Shrink window/)) prio = 32
|
||||||
|
if (match(line, /scratchpad/)) prio = 33
|
||||||
|
if (match(line, /notification/)) prio = 34
|
||||||
|
if (match(line, /Toggle window transparency/)) prio = 35
|
||||||
|
if (match(line, /Toggle workspace gaps/)) prio = 36
|
||||||
|
if (match(line, /Toggle nightlight/)) prio = 37
|
||||||
|
if (match(line, /Toggle locking/)) prio = 38
|
||||||
if (match(line, /group/)) prio = 94
|
if (match(line, /group/)) prio = 94
|
||||||
if (match(line, /Scroll active workspace/)) prio = 95
|
if (match(line, /Scroll active workspace/)) prio = 95
|
||||||
if (match(line, /Cycle to/)) prio = 96
|
if (match(line, /Cycle to/)) prio = 96
|
||||||
@@ -211,18 +220,26 @@ prioritize_entries() {
|
|||||||
cut -f2-
|
cut -f2-
|
||||||
}
|
}
|
||||||
|
|
||||||
monitor_height=$(hyprctl monitors -j | jq -r '.[] | select(.focused == true) | .height')
|
output_keybindings() {
|
||||||
menu_height=$((monitor_height * 40 / 100))
|
build_keymap_cache
|
||||||
|
|
||||||
build_keymap_cache
|
{
|
||||||
|
|
||||||
{
|
|
||||||
dynamic_bindings
|
dynamic_bindings
|
||||||
static_bindings
|
static_bindings
|
||||||
} |
|
} |
|
||||||
sort -u |
|
sort -u |
|
||||||
parse_keycodes |
|
parse_keycodes |
|
||||||
parse_bindings |
|
parse_bindings |
|
||||||
prioritize_entries |
|
prioritize_entries
|
||||||
walker --dmenu -p 'Keybindings' --width 800 --height "$menu_height"
|
}
|
||||||
|
|
||||||
|
if [[ "$1" == "--print" || "$1" == "-p" ]]; then
|
||||||
|
output_keybindings
|
||||||
|
else
|
||||||
|
monitor_height=$(hyprctl monitors -j | jq -r '.[] | select(.focused == true) | .height')
|
||||||
|
menu_height=$((monitor_height * 40 / 100))
|
||||||
|
|
||||||
|
output_keybindings |
|
||||||
|
walker --dmenu -p 'Keybindings' --width 800 --height "$menu_height"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Run all pending migrations to bring the system in line with the installed version.
|
||||||
|
|
||||||
# Where we store an empty file for each migration that has already been performed.
|
# Where we store an empty file for each migration that has already been performed.
|
||||||
STATE_DIR="$HOME/.local/state/omarchy/migrations"
|
STATE_DIR="$HOME/.local/state/omarchy/migrations"
|
||||||
mkdir -p "$STATE_DIR"
|
mkdir -p "$STATE_DIR"
|
||||||
@@ -8,7 +10,7 @@ mkdir -p "$STATE_DIR"
|
|||||||
mkdir -p "$STATE_DIR/skipped"
|
mkdir -p "$STATE_DIR/skipped"
|
||||||
|
|
||||||
# Run any pending migrations
|
# Run any pending migrations
|
||||||
for file in /usr/share/omarchy/migrations/*.sh; do
|
for file in ~/.local/share/omarchy/migrations/*.sh; do
|
||||||
filename=$(basename "$file")
|
filename=$(basename "$file")
|
||||||
|
|
||||||
if [[ ! -f "$STATE_DIR/$filename" && ! -f "$STATE_DIR/skipped/$filename" ]]; then
|
if [[ ! -f "$STATE_DIR/$filename" && ! -f "$STATE_DIR/skipped/$filename" ]]; then
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Dismiss a mako notification on the basis of its summary. Used by the first-run notifications to dismiss them after clicking for action.
|
||||||
|
|
||||||
if (($# == 0)); then
|
if (($# == 0)); then
|
||||||
echo "Usage: omarchy-notification-dismiss <summary>"
|
echo "Usage: omarchy-notification-dismiss <summary>"
|
||||||
exit 1
|
exit 1
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Add the named packages to the system if they're missing. Returns false if it couldn't be done.
|
||||||
|
|
||||||
if omarchy-pkg-missing "$@"; then
|
if omarchy-pkg-missing "$@"; then
|
||||||
sudo pacman -S --noconfirm --needed "$@" || exit 1
|
sudo pacman -S --noconfirm --needed "$@" || exit 1
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,4 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Returns true if the AUR is up and available.
|
||||||
|
# Used by omarchy-update-system-pkgs to ensure the AUR is available before updating packages from it.
|
||||||
|
|
||||||
curl -sf --connect-timeout 30 --retry 3 --retry-delay 3 -A "omarchy-update" \
|
curl -sf --connect-timeout 30 --retry 3 --retry-delay 3 -A "omarchy-update" \
|
||||||
"https://aur.archlinux.org/rpc/?v=5&type=info&arg=base" >/dev/null
|
"https://aur.archlinux.org/rpc/?v=5&type=info&arg=base" >/dev/null
|
||||||
|
|||||||
17
bin/omarchy-pkg-aur-add
Executable file
17
bin/omarchy-pkg-aur-add
Executable file
@@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Add the named packages to the system from the AUR if they're missing. Returns false if it couldn't be done.
|
||||||
|
|
||||||
|
if omarchy-pkg-missing "$@"; then
|
||||||
|
yay -S --noconfirm --needed "$@" || exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
for pkg in "$@"; do
|
||||||
|
# Secondary check to handle states where pacman doesn't actually register an error
|
||||||
|
if ! pacman -Q "$pkg" &>/dev/null; then
|
||||||
|
echo -e "\033[31mError: Package '$pkg' did not install\033[0m" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
exit 0
|
||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Show a fuzzy-finder TUI for picking new AUR packages to install.
|
||||||
|
|
||||||
fzf_args=(
|
fzf_args=(
|
||||||
--multi
|
--multi
|
||||||
--preview 'yay -Siia {1}'
|
--preview 'yay -Siia {1}'
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Remove all the named packages from the system if they're installed (otherwise ignore).
|
||||||
|
|
||||||
for pkg in "$@"; do
|
for pkg in "$@"; do
|
||||||
if pacman -Q "$pkg" &>/dev/null; then
|
if pacman -Q "$pkg" &>/dev/null; then
|
||||||
sudo pacman -Rns --noconfirm "$pkg"
|
sudo pacman -Rns --noconfirm "$pkg"
|
||||||
|
|||||||
@@ -1,7 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
IGNORED_PACKAGES_FILE="$OMARCHY_PATH/install/packages.ignored"
|
|
||||||
|
|
||||||
if [[ -f $IGNORED_PACKAGES_FILE ]]; then
|
|
||||||
tr '\r\n' ',' <"$IGNORED_PACKAGES_FILE" | sed 's/,$//'
|
|
||||||
fi
|
|
||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Show a fuzzy-finder TUI for picking new Arch and OPR packages to install.
|
||||||
|
|
||||||
fzf_args=(
|
fzf_args=(
|
||||||
--multi
|
--multi
|
||||||
--preview 'pacman -Sii {1}'
|
--preview 'pacman -Sii {1}'
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Returns true if any of the named packages are missing from the system (or false if they're all there).
|
||||||
|
|
||||||
for pkg in "$@"; do
|
for pkg in "$@"; do
|
||||||
if ! pacman -Q "$pkg" &>/dev/null; then
|
if ! pacman -Q "$pkg" &>/dev/null; then
|
||||||
exit 0
|
exit 0
|
||||||
|
|||||||
@@ -1,7 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
PINNED_PACKAGES_FILE="$OMARCHY_PATH/install/packages.pinned"
|
|
||||||
|
|
||||||
if [[ -f $PINNED_PACKAGES_FILE ]]; then
|
|
||||||
tr '\r\n' ',' <"$PINNED_PACKAGES_FILE" | sed 's/,$//'
|
|
||||||
fi
|
|
||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Returns true if all of the named packages are installed on the system (or false if any of them are missing).
|
||||||
|
|
||||||
for pkg in "$@"; do
|
for pkg in "$@"; do
|
||||||
pacman -Q "$pkg" &>/dev/null || exit 1
|
pacman -Q "$pkg" &>/dev/null || exit 1
|
||||||
done
|
done
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Show a fuzzy-finder TUI for picking packages installed on the system to be removed.
|
||||||
|
|
||||||
fzf_args=(
|
fzf_args=(
|
||||||
--multi
|
--multi
|
||||||
--preview 'yay -Qi {1}'
|
--preview 'yay -Qi {1}'
|
||||||
|
|||||||
@@ -1,5 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Returns a list of all the available power profiles on the system.
|
||||||
|
# Used by the Omarchy Menu under Setup > Power Profile.
|
||||||
|
|
||||||
powerprofilesctl list |
|
powerprofilesctl list |
|
||||||
awk '/^\s*[* ]\s*[a-zA-Z0-9\-]+:$/ { gsub(/^[*[:space:]]+|:$/,""); print }' |
|
awk '/^\s*[* ]\s*[a-zA-Z0-9\-]+:$/ { gsub(/^[*[:space:]]+|:$/,""); print }' |
|
||||||
tac
|
tac
|
||||||
|
|||||||
@@ -1,13 +1,20 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Ensure all default .desktop, web apps, and TUIs are installed.
|
||||||
|
|
||||||
# Copy and sync icon files
|
# Copy and sync icon files
|
||||||
mkdir -p ~/.local/share/icons/hicolor/48x48/apps/
|
mkdir -p ~/.local/share/icons/hicolor/48x48/apps/
|
||||||
cp /usr/share/omarchy/applications/icons/*.png ~/.local/share/icons/hicolor/48x48/apps/
|
cp ~/.local/share/omarchy/applications/icons/*.png ~/.local/share/icons/hicolor/48x48/apps/
|
||||||
gtk-update-icon-cache ~/.local/share/icons/hicolor &>/dev/null
|
gtk-update-icon-cache ~/.local/share/icons/hicolor &>/dev/null
|
||||||
|
|
||||||
# Copy .desktop declarations
|
# Copy .desktop declarations
|
||||||
mkdir -p ~/.local/share/applications
|
mkdir -p ~/.local/share/applications
|
||||||
cp /usr/share/omarchy/applications/*.desktop ~/.local/share/applications/
|
cp ~/.local/share/omarchy/applications/*.desktop ~/.local/share/applications/
|
||||||
cp /usr/share/omarchy/applications/hidden/*.desktop ~/.local/share/applications/
|
cp ~/.local/share/omarchy/applications/hidden/*.desktop ~/.local/share/applications/
|
||||||
|
|
||||||
|
# Refresh the webapps and TUIs
|
||||||
|
bash $OMARCHY_PATH/install/packaging/icons.sh
|
||||||
|
bash $OMARCHY_PATH/install/packaging/webapps.sh
|
||||||
|
bash $OMARCHY_PATH/install/packaging/tuis.sh
|
||||||
|
|
||||||
update-desktop-database ~/.local/share/applications
|
update-desktop-database ~/.local/share/applications
|
||||||
|
|||||||
21
bin/omarchy-refresh-chromium
Executable file
21
bin/omarchy-refresh-chromium
Executable file
@@ -0,0 +1,21 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Refresh the ~/.config/chromium-flags.conf file from the Omarchy defaults.
|
||||||
|
|
||||||
|
CONFIG_FILE="$HOME/.config/chromium-flags.conf"
|
||||||
|
INSTALL_GOOGLE_ACCOUNTS=false
|
||||||
|
|
||||||
|
# Check if google accounts were installed
|
||||||
|
if [[ -f "$CONFIG_FILE" ]] && \
|
||||||
|
grep -q -- "--oauth2-client-id" "$CONFIG_FILE" && \
|
||||||
|
grep -q -- "--oauth2-client-secret" "$CONFIG_FILE"; then
|
||||||
|
INSTALL_GOOGLE_ACCOUNTS=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Refresh the Chromium configuration
|
||||||
|
omarchy-refresh-config chromium-flags.conf
|
||||||
|
|
||||||
|
# Re-install Google accounts if previously configured
|
||||||
|
if [[ "$INSTALL_GOOGLE_ACCOUNTS" == true ]]; then
|
||||||
|
omarchy-install-chromium-google-account
|
||||||
|
fi
|
||||||
@@ -1,6 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# This script deploys /etc/skel/.config/X/Y/Z -> ~/.config/X/Y/Z
|
# Copies the named config from ~/.local/share/omarchy/config/X/Y/Z -> ~/.config/X/Y/Z.
|
||||||
|
# If the config already exists, a backup of the existing will be taken as .bak.TIMESTAMP.
|
||||||
|
|
||||||
config_file=$1
|
config_file=$1
|
||||||
|
|
||||||
if [[ -z "$config_file" ]]; then
|
if [[ -z "$config_file" ]]; then
|
||||||
@@ -8,7 +10,7 @@ if [[ -z "$config_file" ]]; then
|
|||||||
Usage: $0 [config_file]
|
Usage: $0 [config_file]
|
||||||
|
|
||||||
Must provide a file path from the .config directory to be refreshed.
|
Must provide a file path from the .config directory to be refreshed.
|
||||||
To copy /etc/skel/.config/hypr/hyprlock.conf to ~/.config/hypr/hyprlock.conf
|
To copy ~/.local/share/omarchy/config/hypr/hyprlock.conf to ~/.config/hypr/hyprlock.conf
|
||||||
|
|
||||||
$0 hypr/hyprlock.conf
|
$0 hypr/hyprlock.conf
|
||||||
USAGE
|
USAGE
|
||||||
@@ -17,7 +19,7 @@ fi
|
|||||||
|
|
||||||
# Backup the destination file (with timestamp) to avoid clobbering (Ex: hyprlock.conf.bak.1753817951)
|
# Backup the destination file (with timestamp) to avoid clobbering (Ex: hyprlock.conf.bak.1753817951)
|
||||||
user_config_file="${HOME}/.config/$config_file"
|
user_config_file="${HOME}/.config/$config_file"
|
||||||
default_config_file="/etc/skel/.config/$config_file"
|
default_config_file="${HOME}/.local/share/omarchy/config/$config_file"
|
||||||
backup_config_file="$user_config_file.bak.$(date +%s)"
|
backup_config_file="$user_config_file.bak.$(date +%s)"
|
||||||
|
|
||||||
if [[ -f "$user_config_file" ]]; then
|
if [[ -f "$user_config_file" ]]; then
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Overwrite the user config for fastfetch with the Omarchy default.
|
||||||
|
|
||||||
omarchy-refresh-config fastfetch/config.jsonc
|
omarchy-refresh-config fastfetch/config.jsonc
|
||||||
|
|||||||
@@ -1,4 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Overwrite the user config for hypridle with the Omarchy default and restart the service.
|
||||||
|
|
||||||
omarchy-refresh-config hypr/hypridle.conf
|
omarchy-refresh-config hypr/hypridle.conf
|
||||||
omarchy-restart-hypridle
|
omarchy-restart-hypridle
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Overwrite all the user configs in ~/.config/hypr with the Omarchy defaults.
|
||||||
|
|
||||||
omarchy-refresh-config hypr/autostart.conf
|
omarchy-refresh-config hypr/autostart.conf
|
||||||
omarchy-refresh-config hypr/bindings.conf
|
omarchy-refresh-config hypr/bindings.conf
|
||||||
omarchy-refresh-config hypr/envs.conf
|
|
||||||
omarchy-refresh-config hypr/input.conf
|
omarchy-refresh-config hypr/input.conf
|
||||||
|
omarchy-refresh-config hypr/looknfeel.conf
|
||||||
omarchy-refresh-config hypr/hyprland.conf
|
omarchy-refresh-config hypr/hyprland.conf
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Overwrite the user config for hyprlock with the Omarchy default.
|
||||||
|
|
||||||
omarchy-refresh-config hypr/hyprlock.conf
|
omarchy-refresh-config hypr/hyprlock.conf
|
||||||
|
|||||||
@@ -1,4 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Overwrite the user config for hyprsunset with the Omarchy default and restart the service.
|
||||||
|
#
|
||||||
omarchy-refresh-config hypr/hyprsunset.conf
|
omarchy-refresh-config hypr/hyprsunset.conf
|
||||||
omarchy-restart-hyprsunset
|
omarchy-restart-hyprsunset
|
||||||
|
|||||||
@@ -1,6 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
if [[ -f /boot/EFI/linux/omarchy_linux.efi ]] && [[ -f /boot/EFI/linux/$(cat /etc/machine-id)_linux.efi ]]; then
|
# Overwrite the user config for the Limine bootloader and rebuild it.
|
||||||
|
|
||||||
|
if [[ -f /boot/EFI/Linux/omarchy_linux.efi ]] && [[ -f /boot/EFI/Linux/$(cat /etc/machine-id)_linux.efi ]]; then
|
||||||
echo "Cleanup extra UKI"
|
echo "Cleanup extra UKI"
|
||||||
sudo rm -f /boot/EFI/Linux/$(cat /etc/machine-id)_linux.efi
|
sudo rm -f /boot/EFI/Linux/$(cat /etc/machine-id)_linux.efi
|
||||||
fi
|
fi
|
||||||
@@ -8,27 +10,7 @@ echo "Resetting limine config"
|
|||||||
|
|
||||||
sudo mv /boot/limine.conf /boot/limine.conf.bak
|
sudo mv /boot/limine.conf /boot/limine.conf.bak
|
||||||
|
|
||||||
sudo tee /boot/limine.conf <<EOF >/dev/null
|
sudo cp ~/.local/share/omarchy/default/limine/limine.conf /boot/limine.conf
|
||||||
### Read more at config document: https://github.com/limine-bootloader/limine/blob/trunk/CONFIG.md
|
|
||||||
#timeout: 3
|
|
||||||
default_entry: 2
|
|
||||||
interface_branding: Omarchy Bootloader
|
|
||||||
interface_branding_color: 2
|
|
||||||
hash_mismatch_panic: no
|
|
||||||
|
|
||||||
term_background: 1a1b26
|
|
||||||
backdrop: 1a1b26
|
|
||||||
|
|
||||||
# Terminal colors (Tokyo Night palette)
|
|
||||||
term_palette: 15161e;f7768e;9ece6a;e0af68;7aa2f7;bb9af7;7dcfff;a9b1d6
|
|
||||||
term_palette_bright: 414868;f7768e;9ece6a;e0af68;7aa2f7;bb9af7;7dcfff;c0caf5
|
|
||||||
|
|
||||||
# Text colors
|
|
||||||
term_foreground: c0caf5
|
|
||||||
term_foreground_bright: c0caf5
|
|
||||||
term_background_bright: 24283b
|
|
||||||
|
|
||||||
EOF
|
|
||||||
|
|
||||||
sudo limine-update
|
sudo limine-update
|
||||||
sudo limine-snapper-sync
|
sudo limine-snapper-sync
|
||||||
|
|||||||
24
bin/omarchy-refresh-pacman
Executable file
24
bin/omarchy-refresh-pacman
Executable file
@@ -0,0 +1,24 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Overwrite the package configuration for /etc/pacman with the Omarchy default of using its dedicated mirrors and repositories, then update all packages.
|
||||||
|
# This is used after switching between Omarchy release channels to ensure the right packages for the right channel are available.
|
||||||
|
|
||||||
|
# Take backup of existing files
|
||||||
|
sudo cp -f /etc/pacman.conf /etc/pacman.conf.bak
|
||||||
|
sudo cp -f /etc/pacman.d/mirrorlist /etc/pacman.d/mirrorlist.bak
|
||||||
|
|
||||||
|
channel="${1:-stable}"
|
||||||
|
|
||||||
|
if [[ "$channel" != "stable" && "$channel" != "rc" && "$channel" != "edge" ]]; then
|
||||||
|
echo "Error: Invalid channel '$channel'. Must be one of: stable, rc, edge"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Setting channel to $channel"
|
||||||
|
echo
|
||||||
|
|
||||||
|
sudo cp -f "$OMARCHY_PATH/default/pacman/pacman-$channel.conf" /etc/pacman.conf
|
||||||
|
sudo cp -f "$OMARCHY_PATH/default/pacman/mirrorlist-$channel" /etc/pacman.d/mirrorlist
|
||||||
|
|
||||||
|
# Reset all package DBs and then update
|
||||||
|
sudo pacman -Syyu --noconfirm
|
||||||
@@ -1,3 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
sudo cp -f /usr/share/omarchy/default/pacman/mirrorlist /etc/pacman.d/mirrorlist
|
|
||||||
@@ -1,6 +1,8 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
sudo cp /usr/share/omarchy/default/plymouth/* /usr/share/plymouth/themes/omarchy/
|
# Overwrite the user config for the Plymouth drive decryption and boot sequence with the Omarchy default and rebuild it.
|
||||||
|
|
||||||
|
sudo cp ~/.local/share/omarchy/default/plymouth/* /usr/share/plymouth/themes/omarchy/
|
||||||
sudo plymouth-set-default-theme omarchy
|
sudo plymouth-set-default-theme omarchy
|
||||||
|
|
||||||
if command -v limine-mkinitcpio &>/dev/null; then
|
if command -v limine-mkinitcpio &>/dev/null; then
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Overwrite the user configs for swayosd (controls on-screen feedback for changing volume/songs etc) with the Omarchy defaults and restart the service.
|
||||||
|
|
||||||
omarchy-refresh-config swayosd/config.toml
|
omarchy-refresh-config swayosd/config.toml
|
||||||
omarchy-refresh-config swayosd/style.css
|
omarchy-refresh-config swayosd/style.css
|
||||||
omarchy-restart-swayosd
|
omarchy-restart-swayosd
|
||||||
|
|||||||
6
bin/omarchy-refresh-tmux
Executable file
6
bin/omarchy-refresh-tmux
Executable file
@@ -0,0 +1,6 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Overwrite the user tmux config with the Omarchy default and reload tmux.
|
||||||
|
|
||||||
|
omarchy-refresh-config tmux/tmux.conf
|
||||||
|
tmux source-file ~/.config/tmux/tmux.conf
|
||||||
@@ -1,6 +1,21 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Overwrite the user configs for the Walker application launcher (which also powers the Omarchy Menu) and restart the services.
|
||||||
|
|
||||||
|
# Ensure walker is set to autostart
|
||||||
|
mkdir -p ~/.config/autostart/
|
||||||
|
cp $OMARCHY_PATH/default/walker/walker.desktop ~/.config/autostart/
|
||||||
|
|
||||||
|
# And restarts if it crashes or is killed
|
||||||
|
mkdir -p ~/.config/systemd/user/app-walker@autostart.service.d/
|
||||||
|
cp $OMARCHY_PATH/default/walker/restart.conf ~/.config/systemd/user/app-walker@autostart.service.d/restart.conf
|
||||||
|
|
||||||
|
systemctl --user daemon-reload
|
||||||
|
|
||||||
|
# Refresh configs
|
||||||
omarchy-refresh-config walker/config.toml
|
omarchy-refresh-config walker/config.toml
|
||||||
omarchy-refresh-config elephant/calc.toml
|
omarchy-refresh-config elephant/calc.toml
|
||||||
omarchy-refresh-config elephant/desktopapplications.toml
|
omarchy-refresh-config elephant/desktopapplications.toml
|
||||||
|
|
||||||
|
# Restart service
|
||||||
omarchy-restart-walker
|
omarchy-restart-walker
|
||||||
|
|||||||
@@ -1,5 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Overwrite the user configs for the Waybar menu bar with the Omarchy defaults and restart the service.
|
||||||
|
|
||||||
omarchy-refresh-config waybar/config.jsonc
|
omarchy-refresh-config waybar/config.jsonc
|
||||||
omarchy-refresh-config waybar/style.css
|
omarchy-refresh-config waybar/style.css
|
||||||
omarchy-restart-waybar
|
omarchy-restart-waybar
|
||||||
|
|||||||
@@ -1,29 +1,14 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
if [ "$EUID" -eq 0 ]; then
|
# Attempt to reinstall all default Omarchy packages and reset all the default configs.
|
||||||
echo "Error: This script should not be run as root"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo -e "This will reinstall all the default Omarchy packages and reset all default configs.\nWarning: All changes to configs will be lost.\n"
|
echo -e "This will reinstall all the default Omarchy packages and reset all default configs.\nWarning: All user changes to configs will be lost.\n"
|
||||||
|
|
||||||
if gum confirm "Are you sure you want to reinstall and lose all config changes?"; then
|
if gum confirm "Are you sure you want to reinstall and lose all config changes?"; then
|
||||||
echo "Reinstalling Omarchy Package"
|
omarchy-reinstall-git
|
||||||
sudo pacman -Syu --noconfirm --needed omarchy
|
omarchy-reinstall-pkgs
|
||||||
|
omarchy-reinstall-configs
|
||||||
|
|
||||||
echo "Reinstalling missing Omarchy packages"
|
gum confirm "System has been reinstalled. Reboot?" && omarchy-cmd-reboot
|
||||||
mapfile -t packages < <(grep -v '^#' "$OMARCHY_PATH/install/omarchy-base.packages" | grep -v '^$')
|
|
||||||
sudo pacman -Syu --noconfirm --needed "${packages[@]}"
|
|
||||||
|
|
||||||
echo "Resetting all Omarchy configs"
|
|
||||||
cp -R /etc/skel/.config/* ~/.config/
|
|
||||||
|
|
||||||
$(bash $OMARCHY_PATH/install/config/theme.sh)
|
|
||||||
$(bash $OMARCHY_PATH/install/config/git.sh)
|
|
||||||
|
|
||||||
omarchy-refresh-limine
|
|
||||||
omarchy-refresh-plymouth
|
|
||||||
omarchy-nvim-setup
|
|
||||||
fi
|
fi
|
||||||
|
|||||||
20
bin/omarchy-reinstall-configs
Executable file
20
bin/omarchy-reinstall-configs
Executable file
@@ -0,0 +1,20 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# Overwrite all user configs with the Omarchy defaults.
|
||||||
|
|
||||||
|
if [ "$EUID" -eq 0 ]; then
|
||||||
|
echo "Error: This script should not be run as root"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Resetting all Omarchy configs"
|
||||||
|
cp -R ~/.local/share/omarchy/config/* ~/.config/
|
||||||
|
cp ~/.local/share/omarchy/default/bashrc ~/.bashrc
|
||||||
|
echo '[[ -f ~/.bashrc ]] && . ~/.bashrc' | tee ~/.bash_profile >/dev/null
|
||||||
|
|
||||||
|
$(bash $OMARCHY_PATH/install/config/theme.sh)
|
||||||
|
|
||||||
|
omarchy-refresh-limine
|
||||||
|
omarchy-refresh-plymouth
|
||||||
|
omarchy-nvim-setup
|
||||||
8
bin/omarchy-reinstall-git
Executable file
8
bin/omarchy-reinstall-git
Executable file
@@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# Reinstall the Omarchy configuration directory from the git source.
|
||||||
|
|
||||||
|
git clone "https://github.com/basecamp/omarchy.git" ~/.local/share/omarchy-new >/dev/null
|
||||||
|
mv $OMARCHY_PATH ~/.local/share/omarchy-old
|
||||||
|
mv ~/.local/share/omarchy-new $OMARCHY_PATH
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user