Compare commits
45 Commits
60376586a2
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| b4ca7cc870 | |||
| 2376a12f54 | |||
| ea0f3eb82c | |||
| 020bec1aa0 | |||
| 64073f18c0 | |||
| 9584a00673 | |||
| c9f2d4eccf | |||
| 434f14707c | |||
| f94f6e63b1 | |||
| ca285c92f7 | |||
| bcf0c17c51 | |||
| 5b9b48fede | |||
| fe2730b673 | |||
| 31b70d4221 | |||
| b9c0ab5f85 | |||
| 09f39d1537 | |||
| b696672f11 | |||
| 1ed32e29b0 | |||
| f04a72f19d | |||
| 3cf1f4f11f | |||
| dbf7c1cd2e | |||
| 134fc441a5 | |||
| d989792774 | |||
| 275d07f6e2 | |||
| 8357053c2a | |||
| 09585ce7ea | |||
| 1221a3a984 | |||
| 89a2eb335e | |||
| efca1819b4 | |||
| d94e534ee4 | |||
| 6b60113552 | |||
| b04faa3602 | |||
| 60dcf24b80 | |||
| 5f2eedbc53 | |||
| 9285f2f3ef | |||
| 978e7b4b62 | |||
| 4e27abcb70 | |||
| 97670b5b48 | |||
| 9a3e50be1f | |||
| 0eaf7a718f | |||
| dcece454e1 | |||
| 234b126da2 | |||
| 74c14e48b4 | |||
| a62b187832 | |||
| 1991a88884 |
254
flake.lock
generated
@ -1,5 +1,27 @@
|
|||||||
{
|
{
|
||||||
"nodes": {
|
"nodes": {
|
||||||
|
"aagl": {
|
||||||
|
"inputs": {
|
||||||
|
"flake-compat": "flake-compat",
|
||||||
|
"nixpkgs": [
|
||||||
|
"nixpkgs"
|
||||||
|
],
|
||||||
|
"rust-overlay": "rust-overlay"
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1779290455,
|
||||||
|
"narHash": "sha256-FsCEzxL4NotctEIiQnzvIGDcANWasc+RZ/2d6QJVD+Q=",
|
||||||
|
"owner": "ezKEa",
|
||||||
|
"repo": "aagl-gtk-on-nix",
|
||||||
|
"rev": "1e9a8def348c046a626d087998782c2ae7779434",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "ezKEa",
|
||||||
|
"repo": "aagl-gtk-on-nix",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"alejandra": {
|
"alejandra": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"fenix": "fenix",
|
"fenix": "fenix",
|
||||||
@ -23,6 +45,28 @@
|
|||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"awww": {
|
||||||
|
"inputs": {
|
||||||
|
"flake-compat": "flake-compat_2",
|
||||||
|
"nixpkgs": [
|
||||||
|
"nixpkgs"
|
||||||
|
],
|
||||||
|
"rust-overlay": "rust-overlay_2"
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1779666993,
|
||||||
|
"narHash": "sha256-W0yA7Y37oj5BBzl4ojO8dtv9MuOvdrIZDxtRjs7kpdg=",
|
||||||
|
"ref": "refs/heads/main",
|
||||||
|
"rev": "9b7f47f7f394dce0a17a7b161e0d2fe391ce72b3",
|
||||||
|
"revCount": 1366,
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://codeberg.org/LGFae/awww"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://codeberg.org/LGFae/awww"
|
||||||
|
}
|
||||||
|
},
|
||||||
"base16": {
|
"base16": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"fromYaml": "fromYaml"
|
"fromYaml": "fromYaml"
|
||||||
@ -91,6 +135,26 @@
|
|||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"cookiez-assets": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1776155298,
|
||||||
|
"lfs": true,
|
||||||
|
"narHash": "sha256-cOiaPp5vRLc6LglqgMoXXBHLCqixVM5YuJsI1Zj+kv4=",
|
||||||
|
"ref": "main",
|
||||||
|
"rev": "10e02d22a16707548897047323fe78ccf5d58dc1",
|
||||||
|
"shallow": true,
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://gitea.cookiee.org/cookiez/Nix-Assets.git"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"lfs": true,
|
||||||
|
"ref": "main",
|
||||||
|
"shallow": true,
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://gitea.cookiee.org/cookiez/Nix-Assets.git"
|
||||||
|
}
|
||||||
|
},
|
||||||
"fenix": {
|
"fenix": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
@ -129,6 +193,38 @@
|
|||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"flake-compat": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1767039857,
|
||||||
|
"narHash": "sha256-vNpUSpF5Nuw8xvDLj2KCwwksIbjua2LZCqhV1LNRDns=",
|
||||||
|
"owner": "edolstra",
|
||||||
|
"repo": "flake-compat",
|
||||||
|
"rev": "5edf11c44bc78a0d334f6334cdaf7d60d732daab",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "edolstra",
|
||||||
|
"repo": "flake-compat",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"flake-compat_2": {
|
||||||
|
"flake": false,
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1761588595,
|
||||||
|
"narHash": "sha256-XKUZz9zewJNUj46b4AJdiRZJAvSZ0Dqj2BNfXvFlJC4=",
|
||||||
|
"owner": "edolstra",
|
||||||
|
"repo": "flake-compat",
|
||||||
|
"rev": "f387cd2afec9419c8ee37694406ca490c3f34ee5",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "edolstra",
|
||||||
|
"repo": "flake-compat",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"flake-parts": {
|
"flake-parts": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"nixpkgs-lib": [
|
"nixpkgs-lib": [
|
||||||
@ -137,11 +233,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1777932387,
|
"lastModified": 1778716662,
|
||||||
"narHash": "sha256-nUYVPiqrzr36ThiQOAr5MKeGHDBSDM3OFWkz0uDjOvc=",
|
"narHash": "sha256-m1Yf0wZ8j1OHjTc2UwHwyQRSnNeSgLJOd7q5Y45hzi4=",
|
||||||
"owner": "hercules-ci",
|
"owner": "hercules-ci",
|
||||||
"repo": "flake-parts",
|
"repo": "flake-parts",
|
||||||
"rev": "71a3a77326609675e9f8b51084cf23d5d1945899",
|
"rev": "f7c1a2d347e4c52d5fb8d10cb4d94b5884e546fb",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -245,11 +341,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1778009629,
|
"lastModified": 1779678629,
|
||||||
"narHash": "sha256-nUoQtf4Zq7DRYJrfv904hjrxjAlWVP6a1pNNFKx3FCg=",
|
"narHash": "sha256-gHcIFg0mm+KFsg7iZQt67kni3+qR5U3PhEC9P7vKlZ4=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "home-manager",
|
"repo": "home-manager",
|
||||||
"rev": "00ed86e58bb6979a7921859fd1615d19382eac5c",
|
"rev": "612bbe3b405ad5f71d7bf9edecc04b678a061652",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -271,11 +367,11 @@
|
|||||||
"xwayland-satellite-unstable": "xwayland-satellite-unstable"
|
"xwayland-satellite-unstable": "xwayland-satellite-unstable"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1778022358,
|
"lastModified": 1779622619,
|
||||||
"narHash": "sha256-M/FR4z0m6KyN1wJpHbUKrF1T/EJKP1qSXdJOujkS5SE=",
|
"narHash": "sha256-CoyW4Uy3DEpI252S6vTV6/UeQ+6wsIHvi94ggC1Ev/E=",
|
||||||
"owner": "sodiboo",
|
"owner": "sodiboo",
|
||||||
"repo": "niri-flake",
|
"repo": "niri-flake",
|
||||||
"rev": "6e900d2d23f32b88a1d97c38d1f24413cce66c90",
|
"rev": "f9e8b871f11137d4b9e15296ea134522dc7a7cb4",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -304,11 +400,11 @@
|
|||||||
"niri-unstable": {
|
"niri-unstable": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1778009434,
|
"lastModified": 1779374863,
|
||||||
"narHash": "sha256-kbT+bAdT8U1KRPVwwXpTCLQuRzER2yIkiv2E9/F/jhw=",
|
"narHash": "sha256-qKWgJ2MUODpg+b8tOwWMdMKREvs8TdGBz63SHaQZCeA=",
|
||||||
"owner": "YaLTeR",
|
"owner": "YaLTeR",
|
||||||
"repo": "niri",
|
"repo": "niri",
|
||||||
"rev": "56654034e9a9b74f6fcf268ebfe114a8c74a8c0b",
|
"rev": "4294948cf1c70c50e938383c2c865d7ca455ac7e",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -332,13 +428,33 @@
|
|||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"nix-index-database": {
|
||||||
|
"inputs": {
|
||||||
|
"nixpkgs": [
|
||||||
|
"nixpkgs"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1779604987,
|
||||||
|
"narHash": "sha256-ZQ5z+fVhxYKtIFwtqGp5O0PD84BM1riASvqDaN5Xs+s=",
|
||||||
|
"owner": "nix-community",
|
||||||
|
"repo": "nix-index-database",
|
||||||
|
"rev": "8fba98c80b48fa013820e0163c5096922fea4ddd",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "nix-community",
|
||||||
|
"repo": "nix-index-database",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"nixos-hardware": {
|
"nixos-hardware": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1777917524,
|
"lastModified": 1779258371,
|
||||||
"narHash": "sha256-k+LVe9YaO2BEPB9AaCtTtOMCeGi4dxDo6gt4Un3qoPY=",
|
"narHash": "sha256-j1iZsLy6oFApqR1oiDmHhvkwxXqcNi0aoSJj643LuwU=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixos-hardware",
|
"repo": "nixos-hardware",
|
||||||
"rev": "df7783100babf59001340a7a874ba3824e441ecb",
|
"rev": "c97bc4d15bd3473dd095e8e8ba57330ab1943a77",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -349,11 +465,11 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1778076718,
|
"lastModified": 1779700212,
|
||||||
"narHash": "sha256-SdLqBFaW391MUpG+ptxUoFEjE8GPHH4dxjjHsOF1Aec=",
|
"narHash": "sha256-1pEdBfcjgfrSoYfP06BXC/ypGhwONP+PMO44yEb2Aqc=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "d79d8c526190fef1ae1d098750a75850fff120d2",
|
"rev": "415536cd2b4165c658dd130f53fbd316333b182b",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -365,11 +481,11 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs-stable": {
|
"nixpkgs-stable": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1778003029,
|
"lastModified": 1779467186,
|
||||||
"narHash": "sha256-q/nkKLDtHIyLjZpKhWk3cSK5IYsFqtMd6UtXF3ddjgA=",
|
"narHash": "sha256-nOesoDCiXcUftqbRBMz9tt4blI5PvljMWbm3kuCA+0s=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "0c88e1f2bdb93d5999019e99cb0e61e1fe2af4c5",
|
"rev": "b77b3de8775677f84492abe84635f87b0e153f0f",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -381,11 +497,11 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs_2": {
|
"nixpkgs_2": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1777954456,
|
"lastModified": 1779508470,
|
||||||
"narHash": "sha256-hGdgeU2Nk87RAuZyYjyDjFL6LK7dAZN5RE9+hrDTkDU=",
|
"narHash": "sha256-Ap9KJX+5xHIn3bPIpfNgT6MEXdAECECwo4/rmlQD74M=",
|
||||||
"owner": "nixos",
|
"owner": "nixos",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "549bd84d6279f9852cae6225e372cc67fb91a4c1",
|
"rev": "29916453413845e54a65b8a1cf996842300cd299",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -395,20 +511,34 @@
|
|||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"nixpkgs_3": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1779259093,
|
||||||
|
"narHash": "sha256-7DKWmH23hL2eYdkxCKeqj2i+yljTKuU+3Nk1UPHOnxc=",
|
||||||
|
"owner": "NixOS",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"rev": "d99b013d5d1931ad77fe3912ed218170dec5d9a4",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "NixOS",
|
||||||
|
"ref": "nixpkgs-unstable",
|
||||||
|
"repo": "nixpkgs",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"nixvim": {
|
"nixvim": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"flake-parts": "flake-parts",
|
"flake-parts": "flake-parts",
|
||||||
"nixpkgs": [
|
"nixpkgs": "nixpkgs_3",
|
||||||
"nixpkgs"
|
|
||||||
],
|
|
||||||
"systems": "systems"
|
"systems": "systems"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1777991353,
|
"lastModified": 1779683452,
|
||||||
"narHash": "sha256-DFwjggMV+nzCZpwK6Obxj9F+P59rbLVowGqHETfctBk=",
|
"narHash": "sha256-Ksx8jghpDBCPDiTaTyGhYUXG1BUwqPjf5pajl0q0cqA=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "nixvim",
|
"repo": "nixvim",
|
||||||
"rev": "7986a276960b4dfaed9bb2c3c438b5ba71ae08f1",
|
"rev": "afec1bae0e6f7983a5c03ec559f7ed2ec0e714a9",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -509,11 +639,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1777871389,
|
"lastModified": 1779430452,
|
||||||
"narHash": "sha256-gU+VGpwGJ2vvg0mtYqVvj5u+2LteuHlpokH6JSAtueY=",
|
"narHash": "sha256-zTslhsxLqUlRTML506iougTGzyR38Fzhzn7t4KDEuuE=",
|
||||||
"owner": "outfoxxed",
|
"owner": "outfoxxed",
|
||||||
"repo": "quickshell",
|
"repo": "quickshell",
|
||||||
"rev": "59e9c47b0eb48a9e4bcf9631fa062ee939bd2e83",
|
"rev": "4b4fca3224ab977dc515ac0bb78d00b3dfa71e00",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -524,11 +654,15 @@
|
|||||||
},
|
},
|
||||||
"root": {
|
"root": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
|
"aagl": "aagl",
|
||||||
"alejandra": "alejandra",
|
"alejandra": "alejandra",
|
||||||
|
"awww": "awww",
|
||||||
|
"cookiez-assets": "cookiez-assets",
|
||||||
"grub2-themes": "grub2-themes",
|
"grub2-themes": "grub2-themes",
|
||||||
"home-manager": "home-manager",
|
"home-manager": "home-manager",
|
||||||
"niri": "niri",
|
"niri": "niri",
|
||||||
"nix-flatpak": "nix-flatpak",
|
"nix-flatpak": "nix-flatpak",
|
||||||
|
"nix-index-database": "nix-index-database",
|
||||||
"nixos-hardware": "nixos-hardware",
|
"nixos-hardware": "nixos-hardware",
|
||||||
"nixpkgs": "nixpkgs_2",
|
"nixpkgs": "nixpkgs_2",
|
||||||
"nixvim": "nixvim",
|
"nixvim": "nixvim",
|
||||||
@ -555,6 +689,48 @@
|
|||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"rust-overlay": {
|
||||||
|
"inputs": {
|
||||||
|
"nixpkgs": [
|
||||||
|
"aagl",
|
||||||
|
"nixpkgs"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1777605393,
|
||||||
|
"narHash": "sha256-Hjp0VOOHgHcTrX23iVvnfAudPcuCmfkfpQNFwv2v/ks=",
|
||||||
|
"owner": "oxalica",
|
||||||
|
"repo": "rust-overlay",
|
||||||
|
"rev": "ff88db34cfa486fc4964a6991cab1678d82eee8c",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "oxalica",
|
||||||
|
"repo": "rust-overlay",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"rust-overlay_2": {
|
||||||
|
"inputs": {
|
||||||
|
"nixpkgs": [
|
||||||
|
"awww",
|
||||||
|
"nixpkgs"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1764038373,
|
||||||
|
"narHash": "sha256-M6w2wNBRelcavoDAyFL2iO4NeWknD40ASkH1S3C0YGM=",
|
||||||
|
"owner": "oxalica",
|
||||||
|
"repo": "rust-overlay",
|
||||||
|
"rev": "ab3536fe850211a96673c6ffb2cb88aab8071cc9",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "oxalica",
|
||||||
|
"repo": "rust-overlay",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
"stylix": {
|
"stylix": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"base16": "base16",
|
"base16": "base16",
|
||||||
@ -575,11 +751,11 @@
|
|||||||
"tinted-zed": "tinted-zed"
|
"tinted-zed": "tinted-zed"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1777835090,
|
"lastModified": 1779378391,
|
||||||
"narHash": "sha256-VLH8zPweblCOvpnQXp4fVs7f6Q79YhXF5XFKlOrvIFk=",
|
"narHash": "sha256-IsDb9erotvx9npI94UDosvMeYQK17p7/vmU2v9batrY=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "stylix",
|
"repo": "stylix",
|
||||||
"rev": "7989a1054b01153212dede6005abfd1576b8328c",
|
"rev": "c1456cc4ba3c9485e7b4158c909eeca5a752cd59",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -703,11 +879,11 @@
|
|||||||
"xwayland-satellite-unstable": {
|
"xwayland-satellite-unstable": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1773622265,
|
"lastModified": 1779591853,
|
||||||
"narHash": "sha256-wToKwH7IgWdGLMSIWksEDs4eumR6UbbsuPQ42r0oTXQ=",
|
"narHash": "sha256-osTG6d7BfV5CchHjETh3jcmZwDYrHpNcpAIyh1KyIs0=",
|
||||||
"owner": "Supreeeme",
|
"owner": "Supreeeme",
|
||||||
"repo": "xwayland-satellite",
|
"repo": "xwayland-satellite",
|
||||||
"rev": "a879e5e0896a326adc79c474bf457b8b99011027",
|
"rev": "3273a0fccd71da21c6362c74f3b1d1c0a89ff3ba",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|||||||
49
flake.nix
@ -4,10 +4,25 @@
|
|||||||
inputs = {
|
inputs = {
|
||||||
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
|
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
|
||||||
|
|
||||||
|
pinned-kernel.url = "github:NixOS/nixpkgs/3b5ec87c520b3f3f890c439da30b9fc3f7e173d3";
|
||||||
|
#To pin Kernel versin 7.0.10 because others have bluetooth issues
|
||||||
|
|
||||||
|
nix-index-database = {
|
||||||
|
url = "github:nix-community/nix-index-database";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
|
||||||
|
aagl = {
|
||||||
|
url = "github:ezKEa/aagl-gtk-on-nix";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
|
||||||
nixos-hardware.url = "github:NixOS/nixos-hardware"; #To Provide Framework13 hardware modules
|
nixos-hardware.url = "github:NixOS/nixos-hardware"; #To Provide Framework13 hardware modules
|
||||||
|
|
||||||
home-manager.url = "github:nix-community/home-manager/master";
|
home-manager = {
|
||||||
home-manager.inputs.nixpkgs.follows = "nixpkgs";
|
url = "github:nix-community/home-manager/master";
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
|
||||||
plasma-manager = {
|
plasma-manager = {
|
||||||
url = "github:nix-community/plasma-manager";
|
url = "github:nix-community/plasma-manager";
|
||||||
@ -15,12 +30,18 @@
|
|||||||
inputs.home-manager.follows = "home-manager";
|
inputs.home-manager.follows = "home-manager";
|
||||||
};
|
};
|
||||||
|
|
||||||
#stylix.url = "github:nix-community/stylix/";
|
mangowm = {
|
||||||
stylix.url = "github:nix-community/stylix/master"; #Had to use branch or it would not build corrently
|
url = "github:mangowm/mango";
|
||||||
stylix.inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
|
||||||
quickshell = {
|
stylix = {
|
||||||
url = "github:outfoxxed/quickshell";
|
url = "github:nix-community/stylix/master"; #Had to use branch or it would not build corrently
|
||||||
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
|
};
|
||||||
|
|
||||||
|
noctalia = {
|
||||||
|
url = "github:noctalia-dev/noctalia-shell/v5";
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -31,7 +52,7 @@
|
|||||||
|
|
||||||
nixvim = {
|
nixvim = {
|
||||||
url = "github:nix-community/nixvim";
|
url = "github:nix-community/nixvim";
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
#Do not use follows here as it will throw warnings with nixvim's built-in source
|
||||||
};
|
};
|
||||||
|
|
||||||
alejandra = {
|
alejandra = {
|
||||||
@ -44,6 +65,11 @@
|
|||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
cookiez-assets = {
|
||||||
|
url = "git+https://gitea.cookiee.org/cookiez/Nix-Assets.git?ref=main&lfs=1&shallow=1";
|
||||||
|
flake = false;
|
||||||
|
};
|
||||||
|
|
||||||
nix-flatpak.url = "github:gmodena/nix-flatpak";
|
nix-flatpak.url = "github:gmodena/nix-flatpak";
|
||||||
|
|
||||||
grub2-themes.url = "github:vinceliuice/grub2-themes";
|
grub2-themes.url = "github:vinceliuice/grub2-themes";
|
||||||
@ -53,13 +79,19 @@
|
|||||||
nixpkgs,
|
nixpkgs,
|
||||||
alejandra,
|
alejandra,
|
||||||
pam-fprint-grosshack,
|
pam-fprint-grosshack,
|
||||||
|
pinned-kernel,
|
||||||
|
cookiez-assets,
|
||||||
home-manager,
|
home-manager,
|
||||||
plasma-manager,
|
plasma-manager,
|
||||||
|
noctalia,
|
||||||
|
mangowm,
|
||||||
nixos-hardware,
|
nixos-hardware,
|
||||||
|
aagl,
|
||||||
stylix,
|
stylix,
|
||||||
niri,
|
niri,
|
||||||
grub2-themes,
|
grub2-themes,
|
||||||
nix-flatpak,
|
nix-flatpak,
|
||||||
|
nix-index-database,
|
||||||
...
|
...
|
||||||
}: let
|
}: let
|
||||||
username = "cookiez";
|
username = "cookiez";
|
||||||
@ -83,6 +115,7 @@
|
|||||||
inherit system;
|
inherit system;
|
||||||
inherit project;
|
inherit project;
|
||||||
inherit alejandra;
|
inherit alejandra;
|
||||||
|
inherit cookiez-assets;
|
||||||
pam-fprint-grosshack-pkg = pam-fprint-grosshack.packages.${system}.default;
|
pam-fprint-grosshack-pkg = pam-fprint-grosshack.packages.${system}.default;
|
||||||
host = hostname;
|
host = hostname;
|
||||||
};
|
};
|
||||||
|
|||||||
20
mango/default.nix
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
{
|
||||||
|
inputs,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
imports = [
|
||||||
|
inputs.mangowm.nixosModules.mango
|
||||||
|
../modules/hyprlock
|
||||||
|
];
|
||||||
|
|
||||||
|
environment.systemPackages = with pkgs; [
|
||||||
|
libnotify #Needed to send notifications myself (Like when reloading the config)
|
||||||
|
];
|
||||||
|
|
||||||
|
home-manager.sharedModules = [
|
||||||
|
./home.nix
|
||||||
|
];
|
||||||
|
|
||||||
|
programs.mango.enable = true;
|
||||||
|
}
|
||||||
208
mango/home.nix
Normal file
@ -0,0 +1,208 @@
|
|||||||
|
{
|
||||||
|
pkgs,
|
||||||
|
inputs,
|
||||||
|
lib,
|
||||||
|
...
|
||||||
|
}: let
|
||||||
|
# ── External scripts ──
|
||||||
|
resizeScript = pkgs.writeShellScriptBin "resize.sh" (builtins.readFile ./scripts/resize.sh);
|
||||||
|
layoutCmdScript = pkgs.writeShellScriptBin "layout-cmd.sh" (builtins.readFile ./scripts/layout-cmd.sh);
|
||||||
|
|
||||||
|
# Helper to get the bin path
|
||||||
|
resizePath = "${resizeScript}/bin/resize.sh";
|
||||||
|
layoutCmdPath = "${layoutCmdScript}/bin/layout-cmd.sh";
|
||||||
|
|
||||||
|
tagBinds = lib.concatLists (
|
||||||
|
builtins.genList (i: let
|
||||||
|
n = toString (i + 1);
|
||||||
|
in [
|
||||||
|
"SUPER,${n},view,${n}"
|
||||||
|
"SUPER+CTRL,${n},tag,${n}"
|
||||||
|
])
|
||||||
|
9
|
||||||
|
);
|
||||||
|
|
||||||
|
# All key bindings
|
||||||
|
defaultBinds =
|
||||||
|
# --- Common/Session ---
|
||||||
|
[
|
||||||
|
"SUPER+SHIFT,E,quit"
|
||||||
|
#"SUPER+CTRL,R,reload_config"
|
||||||
|
"SUPER+CTRL,R,spawn_shell,mmsg dispatch reload_config && notify-send -u low -t 500 \"MangoWM\" \"Reloaded ✓\""
|
||||||
|
]
|
||||||
|
# --- Screenshot ---
|
||||||
|
++ [
|
||||||
|
"SUPER+SHIFT,S,spawn,noctalia msg screenshot-region"
|
||||||
|
]
|
||||||
|
# --- Launchers ---
|
||||||
|
++ [
|
||||||
|
"SUPER,T,spawn,kitty" # Mod+T → terminal
|
||||||
|
"SUPER,D,spawn,noctalia msg panel-toggle launcher" # Mod+D → launcher
|
||||||
|
#"SUPER+SHIFT,L,spawn,noctalia msg session lock" # Super+L → lock
|
||||||
|
"SUPER+SHIFT,L,spawn,hyprlock"
|
||||||
|
]
|
||||||
|
# --- Media keys ---
|
||||||
|
++ [
|
||||||
|
"NONE,XF86AudioRaiseVolume,spawn,noctalia msg volume-up"
|
||||||
|
"NONE,XF86AudioLowerVolume,spawn,noctalia msg volume-down"
|
||||||
|
"NONE,XF86AudioMute,spawn,noctalia msg volume-mute"
|
||||||
|
"NONE,XF86AudioMicMute,spawn,noctalia msg mic-mute"
|
||||||
|
"NONE,XF86AudioPlay,spawn,playerctl play-pause"
|
||||||
|
"NONE,XF86AudioStop,spawn,playerctl stop"
|
||||||
|
"NONE,XF86AudioPrev,spawn,playerctl previous"
|
||||||
|
"NONE,XF86AudioNext,spawn,playerctl next"
|
||||||
|
]
|
||||||
|
# --- Brightness ---
|
||||||
|
++ [
|
||||||
|
"NONE,XF86MonBrightnessUp,spawn,noctalia msg brightness-up"
|
||||||
|
"NONE,XF86MonBrightnessDown,spawn,noctalia msg brightness-down"
|
||||||
|
]
|
||||||
|
# --- Focus (directional) ---
|
||||||
|
++ [
|
||||||
|
"SUPER,Left,focusdir,left"
|
||||||
|
"SUPER,Down,focusdir,down"
|
||||||
|
"SUPER,Up,focusdir,up"
|
||||||
|
"SUPER,Right,focusdir,right"
|
||||||
|
# vim bindings
|
||||||
|
"SUPER,H,focusdir,left"
|
||||||
|
"SUPER,J,focusdir,down"
|
||||||
|
"SUPER,K,focusdir,up"
|
||||||
|
"SUPER,L,focusdir,right"
|
||||||
|
]
|
||||||
|
# --- Move windows (swap with neighbor) ---
|
||||||
|
++ [
|
||||||
|
"SUPER+CTRL,Left,exchange_client,left"
|
||||||
|
"SUPER+CTRL,Down,exchange_client,down"
|
||||||
|
"SUPER+CTRL,Up,exchange_client,up"
|
||||||
|
"SUPER+CTRL,Right,exchange_client,right"
|
||||||
|
# vim bindings
|
||||||
|
"SUPER+CTRL,H,exchange_client,left"
|
||||||
|
"SUPER+CTRL,J,exchange_client,down"
|
||||||
|
"SUPER+CTRL,K,exchange_client,up"
|
||||||
|
"SUPER+CTRL,L,exchange_client,right"
|
||||||
|
]
|
||||||
|
# --- Tags (workspaces) 1-9 ---
|
||||||
|
++ tagBinds # Generated list of binds for tags 1-9
|
||||||
|
++ [
|
||||||
|
"SUPER,U,viewtoleft_have_client"
|
||||||
|
"SUPER,I,viewtoright_have_client"
|
||||||
|
"SUPER+SHIFT,U,tagtoleft"
|
||||||
|
"SUPER+SHIFT,I,tagtoright"
|
||||||
|
]
|
||||||
|
# --- Close window ---
|
||||||
|
++ [
|
||||||
|
"SUPER,Q,killclient"
|
||||||
|
]
|
||||||
|
# --- Layout / sizing ---
|
||||||
|
++ [
|
||||||
|
"SUPER+SHIFT,R,switch_layout" # Cycle layouts
|
||||||
|
"SUPER,F,spawn_shell,${layoutCmdPath} 'S:${resizePath} fullscreen' 'mmsg dispatch togglemaximizescreen'"
|
||||||
|
"SUPER+SHIFT,F,togglefullscreen"
|
||||||
|
"SUPER,C,centerwin" # Center floating window
|
||||||
|
|
||||||
|
# For Scroller
|
||||||
|
"SUPER,ssharp,spawn_shell,${layoutCmdPath} 'S:${resizePath} down' 'notify-send \"Title\" \"Down\"'"
|
||||||
|
#"SUPER,ssharp,spawn_shell,${resizePath} down"
|
||||||
|
"SUPER,dead_acute,spawn_shell,${layoutCmdPath} 'S:${resizePath} up' 'notify-send \"Title\" \"Up\"'"
|
||||||
|
#"SUPER,dead_acute,spawn_shell,${resizePath} up"
|
||||||
|
]
|
||||||
|
# --- Floating ---
|
||||||
|
++ [
|
||||||
|
"SUPER,V,togglefloating"
|
||||||
|
]
|
||||||
|
# --- Power off monitors ---
|
||||||
|
++ [
|
||||||
|
"SUPER+SHIFT,P,spawn,mmsg dispatch toggle_monitor,eDP-1"
|
||||||
|
];
|
||||||
|
|
||||||
|
# Extra config for settings that don't have structured Nix attrs
|
||||||
|
extraConf = ''
|
||||||
|
# ── Input ──
|
||||||
|
xkb_rules_layout=de
|
||||||
|
numlockon=1
|
||||||
|
mouse_accel_profile=1
|
||||||
|
mouse_accel_speed=-0.4
|
||||||
|
|
||||||
|
# ── Appearance / Theming ──
|
||||||
|
focuscolor=0xffc87faa
|
||||||
|
bordercolor=0x505050ff
|
||||||
|
urgentcolor=0x9b0000ff
|
||||||
|
borderpx=2
|
||||||
|
|
||||||
|
# ── Blur ──
|
||||||
|
blur=1
|
||||||
|
|
||||||
|
blur_params_num_passes=2
|
||||||
|
blur_params_radius=5
|
||||||
|
blur_params_noise=0.02
|
||||||
|
blur_params_brightness=1
|
||||||
|
blur_params_contrast=1
|
||||||
|
blur_params_saturation=1
|
||||||
|
|
||||||
|
# window-rule geometry-corner-radius 12
|
||||||
|
border_radius=12
|
||||||
|
|
||||||
|
# Opacity
|
||||||
|
focused_opacity=1.0
|
||||||
|
unfocused_opacity=0.95
|
||||||
|
|
||||||
|
# ── Layout ──
|
||||||
|
gappih=10
|
||||||
|
gappiv=10
|
||||||
|
gappoh=10
|
||||||
|
gappov=10
|
||||||
|
|
||||||
|
# Master-stack settings (tile layout)
|
||||||
|
default_mfact=0.5
|
||||||
|
default_nmaster=1
|
||||||
|
new_is_master=1
|
||||||
|
|
||||||
|
# Scroller
|
||||||
|
scroller_default_proportion=0.5
|
||||||
|
scroller_focus_center=0
|
||||||
|
scroller_default_proportion_single=1.0
|
||||||
|
|
||||||
|
# Layout cycling order (Mod+R)
|
||||||
|
circle_layout=scroller,tile,center_tile,grid
|
||||||
|
|
||||||
|
# ── Monitor ──
|
||||||
|
monitorrule=name:^eDP-1$,width:2880,height:1920,refresh:120,x:0,y:0,scale:2
|
||||||
|
|
||||||
|
# ── Autostart ──
|
||||||
|
exec-once=noctalia
|
||||||
|
exec-once=lxpolkit
|
||||||
|
exec-once = ${pkgs.kdePackages.kwallet-pam}/libexec/pam_kwallet_init
|
||||||
|
|
||||||
|
exec-once="rm -rf ''${XDG_RUNTIME_DIR:-/tmp}/mango-resize"
|
||||||
|
|
||||||
|
tagrule=id:1,layout_name:scroller
|
||||||
|
tagrule=id:2,layout_name:scroller
|
||||||
|
tagrule=id:3,layout_name:scroller
|
||||||
|
tagrule=id:4,layout_name:scroller
|
||||||
|
tagrule=id:5,layout_name:scroller
|
||||||
|
tagrule=id:6,layout_name:scroller
|
||||||
|
tagrule=id:7,layout_name:scroller
|
||||||
|
tagrule=id:8,layout_name:scroller
|
||||||
|
tagrule=id:9,layout_name:scroller
|
||||||
|
'';
|
||||||
|
in {
|
||||||
|
imports = [
|
||||||
|
inputs.mangowm.hmModules.mango
|
||||||
|
../modules/noctalia/home.nix
|
||||||
|
];
|
||||||
|
|
||||||
|
wayland.windowManager.mango = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
# Additional autostart (most handled in extraConfig exec-once)
|
||||||
|
autostart_sh = "";
|
||||||
|
|
||||||
|
settings = {
|
||||||
|
# Key bindings (flat list; keymode for submaps below if needed)
|
||||||
|
bind = defaultBinds;
|
||||||
|
};
|
||||||
|
|
||||||
|
# Raw config lines for options without structured Nix attrs
|
||||||
|
extraConfig = extraConf;
|
||||||
|
};
|
||||||
|
}
|
||||||
21
mango/scripts/layout-cmd.sh
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
set -eu
|
||||||
|
|
||||||
|
tag_json=$(mmsg get all-tags)
|
||||||
|
symbol=$(printf '%s' "$tag_json" | jq -r '
|
||||||
|
.all_tags[0].tags[] | select(.is_active == true) | .layout
|
||||||
|
' | head -1)
|
||||||
|
|
||||||
|
arg1="$1"
|
||||||
|
target_layout="${arg1%%:*}"
|
||||||
|
|
||||||
|
for arg in "${@:1:$#-1}"; do
|
||||||
|
layout="${arg%%:*}"
|
||||||
|
cmd="${arg#*:}"
|
||||||
|
if [ "$symbol" = "$layout" ]; then
|
||||||
|
eval "$cmd"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
eval "${@: -1}"
|
||||||
130
mango/scripts/resize.sh
Normal file
@ -0,0 +1,130 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
set -eu
|
||||||
|
|
||||||
|
# 1️⃣ Presets
|
||||||
|
PRESETS=" 0.15 0.30 0.40 0.50 0.60 0.70 0.80 0.90 1.00"
|
||||||
|
|
||||||
|
# Per-window saved-proportion directory
|
||||||
|
PROPORTION_DIR="${XDG_RUNTIME_DIR:-/tmp}/mango-resize"
|
||||||
|
|
||||||
|
# 2️⃣ Helper: abort with a clear message if a required binary is missing
|
||||||
|
need_cmd() {
|
||||||
|
command -v "$1" >/dev/null 2>&1 || {
|
||||||
|
printf "❌ Required command '%s' not found in PATH. Install it first.\n" "$1" >&2
|
||||||
|
exit 127
|
||||||
|
}
|
||||||
|
}
|
||||||
|
need_cmd mmsg
|
||||||
|
need_cmd jq
|
||||||
|
need_cmd awk
|
||||||
|
need_cmd wc
|
||||||
|
need_cmd sed
|
||||||
|
|
||||||
|
# 3️⃣ Get the *currently focused* client.
|
||||||
|
client_json=$(mmsg get focusing-client || true)
|
||||||
|
|
||||||
|
# 3a️⃣ Extract the window's unique id (used as the per-window state key)
|
||||||
|
win_id=$(printf '%s' "$client_json" | jq -r '.id // empty' || true)
|
||||||
|
if [ -z "$win_id" ]; then
|
||||||
|
printf "⚠️ Could not determine window id – aborting.\n" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Per-window state file
|
||||||
|
PROPORTION_FILE="$PROPORTION_DIR/$win_id"
|
||||||
|
|
||||||
|
# 3b️⃣ Extract current client width
|
||||||
|
current=$(printf '%s' "$client_json" | jq -r '.width // empty' || true)
|
||||||
|
|
||||||
|
if [ -z "$current" ]; then
|
||||||
|
printf "⚠️ No focusing client reported – using monitor width as current size.\n"
|
||||||
|
current=$(mmsg get all-monitors | jq -r '
|
||||||
|
if type == "array" then
|
||||||
|
(map(select(.active == true))[0].width)
|
||||||
|
else
|
||||||
|
(.monitors | map(select(.active == true))[0].width)
|
||||||
|
end
|
||||||
|
' || true)
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 4️⃣ Get the *usable* work‑area width
|
||||||
|
usable_width=$(mmsg get workarea 2>/dev/null || true)
|
||||||
|
if [ -n "$usable_width" ]; then
|
||||||
|
usable_width=$(printf '%s' "$usable_width" | jq -r '.width // empty')
|
||||||
|
fi
|
||||||
|
if [ -z "$usable_width" ]; then
|
||||||
|
usable_width=$(mmsg get all-monitors | jq -r '
|
||||||
|
if type == "array" then
|
||||||
|
(map(select(.active == true))[0].width)
|
||||||
|
else
|
||||||
|
(.monitors | map(select(.active == true))[0].width)
|
||||||
|
end
|
||||||
|
')
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 5️⃣ Compute the proportion
|
||||||
|
approx=$(awk -v cw="$current" -v uw="$usable_width" '
|
||||||
|
BEGIN {
|
||||||
|
if (uw <= 0) { print "0.50"; exit }
|
||||||
|
printf "%.4f\n", cw / uw
|
||||||
|
}')
|
||||||
|
|
||||||
|
# 6️⃣ Find the nearest preset index
|
||||||
|
nearest_index=$(awk -v target="$approx" '
|
||||||
|
BEGIN {
|
||||||
|
split("'"$PRESETS"'", a, " ");
|
||||||
|
best_i = 1;
|
||||||
|
best_d = 999;
|
||||||
|
for (i = 1; i <= length(a); i++) {
|
||||||
|
d = a[i] - target;
|
||||||
|
if (d < 0) d = -d;
|
||||||
|
if (d < best_d) {
|
||||||
|
best_d = d;
|
||||||
|
best_i = i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
print best_i;
|
||||||
|
}')
|
||||||
|
|
||||||
|
# 7️⃣ Apply the direction argument
|
||||||
|
case "${1:-}" in
|
||||||
|
up) new_index=$((nearest_index + 1)) ;;
|
||||||
|
down) new_index=$((nearest_index - 1)) ;;
|
||||||
|
fullscreen)
|
||||||
|
# Check if currently fullscreen (approx >= 0.95 → treat as fullscreen)
|
||||||
|
is_fullscreen=$(awk -v a="$approx" 'BEGIN { print (a >= 0.95) ? "1" : "0" }')
|
||||||
|
if [ "$is_fullscreen" = "1" ]; then
|
||||||
|
# Currently fullscreen → restore this window's saved proportion
|
||||||
|
if [ -f "$PROPORTION_FILE" ]; then
|
||||||
|
saved=$(cat "$PROPORTION_FILE")
|
||||||
|
mmsg dispatch "set_proportion,$saved"
|
||||||
|
printf "✅ [win %s] Restored proportion to %s (fullscreen toggle off)\n" "$win_id" "$saved"
|
||||||
|
rm -f "$PROPORTION_FILE"
|
||||||
|
else
|
||||||
|
printf "⚠️ [win %s] No saved proportion – defaulting to 0.50\n" "$win_id" >&2
|
||||||
|
mmsg dispatch "set_proportion,0.50"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
# Not fullscreen → save this window's proportion & go fullscreen
|
||||||
|
saved=$(printf '%s\n' $PRESETS | sed -n "${nearest_index}p")
|
||||||
|
mkdir -p "$PROPORTION_DIR"
|
||||||
|
printf '%s' "$saved" > "$PROPORTION_FILE"
|
||||||
|
mmsg dispatch "set_proportion,1.00"
|
||||||
|
printf "✅ [win %s] Saved proportion %s, set to 1.00 (fullscreen toggle on)\n" "$win_id" "$saved"
|
||||||
|
fi
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
*) printf "❌ Usage: %s [up|down|fullscreen]\n" "$0" >&2; exit 1 ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
# 8️⃣ Clamp
|
||||||
|
count=$(printf '%s\n' $PRESETS | wc -l)
|
||||||
|
if [ "$new_index" -lt 1 ]; then new_index=1; fi
|
||||||
|
if [ "$new_index" -gt "$count" ]; then new_index=$count; fi
|
||||||
|
|
||||||
|
# 9️⃣ Resolve the new preset value
|
||||||
|
new_value=$(printf '%s\n' $PRESETS | sed -n "${new_index}p")
|
||||||
|
|
||||||
|
# 🔟 Dispatch
|
||||||
|
mmsg dispatch "set_proportion,$new_value"
|
||||||
|
printf "✅ Set proportion to %s (preset %s of %s)\n" "$new_value" "$new_index" "$count"
|
||||||
@ -15,17 +15,36 @@
|
|||||||
system,
|
system,
|
||||||
pam-fprint-grosshack-pkg,
|
pam-fprint-grosshack-pkg,
|
||||||
...
|
...
|
||||||
}: {
|
}: let
|
||||||
|
kernel-pinned = import inputs.pinned-kernel {inherit system;};
|
||||||
|
in {
|
||||||
#Assign Swap to the PC
|
#Assign Swap to the PC
|
||||||
#swapDevices = [{
|
swapDevices = [
|
||||||
# device = "/swapfile";
|
{
|
||||||
# size = 16 * 1024; # 16GB
|
device = "/swapfile";
|
||||||
#}];
|
size = 34 * 1024; # 34GB
|
||||||
|
#randomEncryption.enable = true; #Doesnt work with hybernation
|
||||||
|
}
|
||||||
|
];
|
||||||
|
nix = {
|
||||||
|
gc = {
|
||||||
|
automatic = true;
|
||||||
|
dates = "weekly";
|
||||||
|
options = "--delete-older-than 14d";
|
||||||
|
};
|
||||||
|
settings = {
|
||||||
|
auto-optimise-store = true;
|
||||||
|
nix-path = config.nix.nixPath;
|
||||||
|
};
|
||||||
|
nixPath = ["nixpkgs=${inputs.nixpkgs}"];
|
||||||
|
};
|
||||||
|
|
||||||
imports = [
|
imports = [
|
||||||
|
inputs.nix-index-database.nixosModules.nix-index
|
||||||
inputs.home-manager.nixosModules.home-manager
|
inputs.home-manager.nixosModules.home-manager
|
||||||
inputs.grub2-themes.nixosModules.default
|
inputs.grub2-themes.nixosModules.default
|
||||||
inputs.nix-flatpak.nixosModules.nix-flatpak
|
inputs.nix-flatpak.nixosModules.nix-flatpak
|
||||||
|
inputs.aagl.nixosModules.default
|
||||||
./hardware-configuration.nix
|
./hardware-configuration.nix
|
||||||
|
|
||||||
./firefox
|
./firefox
|
||||||
@ -37,9 +56,10 @@
|
|||||||
|
|
||||||
# Bootloader.
|
# Bootloader.
|
||||||
boot = {
|
boot = {
|
||||||
kernelPackages = pkgs.linuxPackages_latest;
|
kernelPackages = kernel-pinned.linuxPackages_latest;
|
||||||
kernelParams = ["quiet" "splash"];
|
kernelParams = ["quiet" "splash"];
|
||||||
initrd = {
|
initrd = {
|
||||||
|
systemd.enable = true; #For swap to automatically work
|
||||||
verbose = false;
|
verbose = false;
|
||||||
kernelModules = ["amdgpu"];
|
kernelModules = ["amdgpu"];
|
||||||
};
|
};
|
||||||
@ -124,26 +144,12 @@
|
|||||||
|
|
||||||
# List services that you want to enable:
|
# List services that you want to enable:
|
||||||
services = {
|
services = {
|
||||||
ollama = {
|
fprintd = {
|
||||||
enable = false;
|
|
||||||
# Optional: load models on startup
|
|
||||||
#loadModels = [ ... ];
|
|
||||||
};
|
|
||||||
|
|
||||||
open-webui = {
|
|
||||||
enable = true;
|
enable = true;
|
||||||
package = pkgs.open-webui;
|
tod.enable = true;
|
||||||
#environment = {
|
tod.driver = pkgs.libfprint-2-tod1-goodix;
|
||||||
# DATA_DIR = "/var/lib/open-webui"; # System-wide writable dir
|
|
||||||
# OLLAMA_API_BASE_URL = "http://127.0.0.1:11434";
|
|
||||||
#};
|
|
||||||
#openFirewall = true;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
fprintd.enable = true;
|
|
||||||
fprintd.tod.enable = true;
|
|
||||||
fprintd.tod.driver = pkgs.libfprint-2-tod1-goodix;
|
|
||||||
|
|
||||||
fwupd.enable = true; #Allows BIOS updates
|
fwupd.enable = true; #Allows BIOS updates
|
||||||
|
|
||||||
locate = {
|
locate = {
|
||||||
@ -171,13 +177,15 @@
|
|||||||
pipewire.wireplumber = {
|
pipewire.wireplumber = {
|
||||||
enable = true;
|
enable = true;
|
||||||
extraConfig = {
|
extraConfig = {
|
||||||
"10-bluez-monitor.properties" = {
|
"10-disable-hfp" = {
|
||||||
"bluez5.msbc-support" = false;
|
"monitor.bluez.properties" = {
|
||||||
"bluez5.hfphsp-support" = false;
|
"bluez5.enable-msbc" = false;
|
||||||
"bluez5.hfphsp-backend" = "none"; # Key addition: no backend
|
"bluez5.roles" = ["a2dp_sink" "a2dp_source"];
|
||||||
"bluez5.roles" = ["a2dp_sink"];
|
"bluez5.enable-hw-volume" = true;
|
||||||
|
"bluez5.enable-sbc-xq" = true;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
"11-bluetooth-policy" = {
|
"11-no-autoswitch" = {
|
||||||
"wireplumber.settings" = {
|
"wireplumber.settings" = {
|
||||||
"bluetooth.autoswitch-to-headset-profile" = false;
|
"bluetooth.autoswitch-to-headset-profile" = false;
|
||||||
};
|
};
|
||||||
@ -192,12 +200,19 @@
|
|||||||
openssh.enable = true;
|
openssh.enable = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
systemd.services.fprintd = {
|
systemd = {
|
||||||
wantedBy = ["multi-user.target"];
|
tmpfiles.rules = [
|
||||||
serviceConfig.Type = "simple";
|
"L+ /var/lib/assets - - - - ${inputs.cookiez-assets}"
|
||||||
|
];
|
||||||
|
services.fprintd = {
|
||||||
|
wantedBy = ["multi-user.target"];
|
||||||
|
serviceConfig.Type = "simple";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
fonts = {
|
fonts = {
|
||||||
|
fontDir.enable = true;
|
||||||
|
|
||||||
packages = with pkgs; [
|
packages = with pkgs; [
|
||||||
font-awesome
|
font-awesome
|
||||||
nerd-fonts.jetbrains-mono
|
nerd-fonts.jetbrains-mono
|
||||||
@ -222,6 +237,12 @@
|
|||||||
programs = {
|
programs = {
|
||||||
steam.enable = true;
|
steam.enable = true;
|
||||||
|
|
||||||
|
gamemode.enable = true;
|
||||||
|
|
||||||
|
gamescope.enable = true;
|
||||||
|
|
||||||
|
nix-index-database.comma.enable = true;
|
||||||
|
|
||||||
direnv = {
|
direnv = {
|
||||||
enable = true;
|
enable = true;
|
||||||
silent = true; # Suppresses direnv's output in the terminal
|
silent = true; # Suppresses direnv's output in the terminal
|
||||||
@ -230,8 +251,28 @@
|
|||||||
|
|
||||||
ssh.askPassword = lib.mkForce "${pkgs.kdePackages.ksshaskpass}/bin/ksshaskpass";
|
ssh.askPassword = lib.mkForce "${pkgs.kdePackages.ksshaskpass}/bin/ksshaskpass";
|
||||||
|
|
||||||
|
sleepy-launcher.enable = true; #Zenless zone zero launcher
|
||||||
|
|
||||||
#In order for dynamically linked executables to work
|
#In order for dynamically linked executables to work
|
||||||
nix-ld.enable = true;
|
nix-ld = {
|
||||||
|
enable = true;
|
||||||
|
#To ensure that the neccesary libraries are included in the wrapper
|
||||||
|
libraries = with pkgs; [
|
||||||
|
wayland
|
||||||
|
libadwaita
|
||||||
|
gtk4
|
||||||
|
gtk3
|
||||||
|
glib
|
||||||
|
gdk-pixbuf
|
||||||
|
pango
|
||||||
|
cairo
|
||||||
|
libGL
|
||||||
|
openssl
|
||||||
|
dbus
|
||||||
|
fontconfig
|
||||||
|
freetype
|
||||||
|
];
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
# Configure console keymap
|
# Configure console keymap
|
||||||
@ -282,7 +323,7 @@
|
|||||||
users.users.${username} = {
|
users.users.${username} = {
|
||||||
isNormalUser = true;
|
isNormalUser = true;
|
||||||
description = "Cookiez";
|
description = "Cookiez";
|
||||||
extraGroups = ["networkmanager" "wheel" "docker"];
|
extraGroups = ["networkmanager" "wheel" "docker" "gamemode" "dialout" "tty"];
|
||||||
packages = with pkgs; [
|
packages = with pkgs; [
|
||||||
#User Packages Here
|
#User Packages Here
|
||||||
];
|
];
|
||||||
@ -296,7 +337,7 @@
|
|||||||
# dockerCompat = true;
|
# dockerCompat = true;
|
||||||
#};
|
#};
|
||||||
|
|
||||||
waydroid.enable = true;
|
waydroid.enable = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
environment = {
|
environment = {
|
||||||
@ -320,34 +361,45 @@
|
|||||||
security = {
|
security = {
|
||||||
sudo.wheelNeedsPassword = false;
|
sudo.wheelNeedsPassword = false;
|
||||||
|
|
||||||
pam.services = {
|
pam.services = let
|
||||||
|
fprintPam = ''
|
||||||
|
auth sufficient ${pam-fprint-grosshack-pkg}/lib/security/pam_fprintd_grosshack.so
|
||||||
|
auth sufficient pam_unix.so try_first_pass nullok
|
||||||
|
auth sufficient ${pkgs.fprintd}/lib/security/pam_fprintd.so timeout=0
|
||||||
|
account required pam_unix.so
|
||||||
|
password required pam_deny.so
|
||||||
|
|
||||||
|
session required pam_unix.so
|
||||||
|
session optional ${pkgs.systemd}/lib/security/pam_systemd.so
|
||||||
|
'';
|
||||||
|
in {
|
||||||
login.fprintAuth = false;
|
login.fprintAuth = false;
|
||||||
sudo.fprintAuth = false; #Disabled because of security risk: https://nvd.nist.gov/vuln/detail/cve-2024-37408
|
sudo.fprintAuth = false; #Disabled because of security risk: https://nvd.nist.gov/vuln/detail/cve-2024-37408
|
||||||
kscreenlocker.fprintAuth = true;
|
kscreenlocker.fprintAuth = true;
|
||||||
polkit-1.fprintAuth = false; #Disabled because of security risk: https://nvd.nist.gov/vuln/detail/cve-2024-37408
|
polkit-1.fprintAuth = false; #Disabled because of security risk: https://nvd.nist.gov/vuln/detail/cve-2024-37408
|
||||||
kde.fprintAuth = false;
|
kde.fprintAuth = false;
|
||||||
hyprlock = {};
|
hyprlock = {
|
||||||
|
text = lib.mkForce fprintPam;
|
||||||
|
};
|
||||||
|
|
||||||
sddm = {
|
sddm = {
|
||||||
fprintAuth = false; # prevent NixOS from adding its own pam_fprintd block
|
fprintAuth = false; # prevent NixOS from adding its own pam_fprintd block
|
||||||
|
|
||||||
text = lib.mkForce ''
|
text = lib.mkForce fprintPam;
|
||||||
auth sufficient ${pam-fprint-grosshack-pkg}/lib/security/pam_fprintd_grosshack.so
|
|
||||||
auth sufficient pam_unix.so try_first_pass nullok
|
|
||||||
auth sufficient ${pkgs.fprintd}/lib/security/pam_fprintd.so
|
|
||||||
|
|
||||||
account required pam_unix.so
|
|
||||||
password required pam_deny.so
|
|
||||||
|
|
||||||
session required pam_unix.so
|
|
||||||
session optional ${pkgs.systemd}/lib/security/pam_systemd.so
|
|
||||||
'';
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
#Allow Nix Commands
|
#Allow Nix Commands
|
||||||
nix.settings.experimental-features = ["nix-command" "flakes"];
|
nix.settings = {
|
||||||
|
experimental-features = ["nix-command" "flakes"];
|
||||||
|
|
||||||
|
max-substitution-jobs = 32;
|
||||||
|
http-connections = 50;
|
||||||
|
|
||||||
|
extra-substituters = ["https://ezkea.cachix.org" "https://noctalia.cachix.org" "https://nix-community.cachix.org"];
|
||||||
|
extra-trusted-public-keys = ["ezkea.cachix.org-1:ioBmUbJTZIKsHmWWXPe1FSFbeVe+afhfgqgTSNd34eI=" "noctalia.cachix.org-1:pCOR47nnMEo5thcxNDtzWpOxNFQsBRglJzxWPp3dkU4=" "nix-community.cachix.org-1:mB9FSh9qf2dCimDSUo8Zy7bkq5CX+/rkCWyvRCYg3Fs="];
|
||||||
|
};
|
||||||
|
|
||||||
# Allow unfree packages
|
# Allow unfree packages
|
||||||
nixpkgs.config.allowUnfree = true;
|
nixpkgs.config.allowUnfree = true;
|
||||||
|
|||||||
@ -3,44 +3,45 @@
|
|||||||
./configuration.nix
|
./configuration.nix
|
||||||
|
|
||||||
#./hardware-configuration.nix
|
#./hardware-configuration.nix
|
||||||
|
../mango
|
||||||
../plasma
|
../plasma
|
||||||
../niri
|
#../niri
|
||||||
];
|
];
|
||||||
|
|
||||||
specialisation = {
|
#specialisation = {
|
||||||
"plasma" = {
|
# "plasma" = {
|
||||||
inheritParentConfig = false;
|
# inheritParentConfig = false;
|
||||||
configuration = {
|
# configuration = {
|
||||||
imports = [
|
# imports = [
|
||||||
../plasma
|
# ../plasma
|
||||||
./configuration.nix
|
# ./configuration.nix
|
||||||
];
|
# ];
|
||||||
|
#
|
||||||
|
# environment.etc."nixos-tags".text = "plasma";
|
||||||
|
# };
|
||||||
|
# };
|
||||||
|
|
||||||
environment.etc."nixos-tags".text = "plasma";
|
# "minimal" = {
|
||||||
};
|
# inheritParentConfig = false;
|
||||||
};
|
# configuration = {
|
||||||
|
# imports = [
|
||||||
|
# ./minimal.nix
|
||||||
|
# ];
|
||||||
|
#
|
||||||
|
# environment.etc."nixos-tags".text = "minimal";
|
||||||
|
# };
|
||||||
|
# };
|
||||||
|
|
||||||
# "minimal" = {
|
# "niri" = {
|
||||||
# inheritParentConfig = false;
|
# inheritParentConfig = false;
|
||||||
# configuration = {
|
# configuration = {
|
||||||
# imports = [
|
# imports = [
|
||||||
# ./minimal.nix
|
# ../niri
|
||||||
# ];
|
# ./configuration.nix
|
||||||
#
|
# ];
|
||||||
# environment.etc."nixos-tags".text = "minimal";
|
#
|
||||||
# };
|
# environment.etc."nixos-tags".text = "niri";
|
||||||
# };
|
# };
|
||||||
|
# };
|
||||||
"niri" = {
|
#};
|
||||||
inheritParentConfig = false;
|
|
||||||
configuration = {
|
|
||||||
imports = [
|
|
||||||
../niri
|
|
||||||
./configuration.nix
|
|
||||||
];
|
|
||||||
|
|
||||||
environment.etc."nixos-tags".text = "niri";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,5 +1,6 @@
|
|||||||
{
|
{
|
||||||
pkgs,
|
pkgs,
|
||||||
|
inputs,
|
||||||
username,
|
username,
|
||||||
project,
|
project,
|
||||||
...
|
...
|
||||||
@ -19,11 +20,13 @@
|
|||||||
noDisplay = true;
|
noDisplay = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
dataFile."icons/hicolor/256x256/apps/vencord-custom.png".source = "${inputs.cookiez-assets}/apps/discord.png";
|
||||||
|
|
||||||
desktopEntries."discord" = {
|
desktopEntries."discord" = {
|
||||||
categories = ["Network" "InstantMessaging" "Chat"];
|
categories = ["Network" "InstantMessaging" "Chat"];
|
||||||
exec = "vesktop %U";
|
exec = "vesktop %U";
|
||||||
genericName = "Internet Messenger";
|
genericName = "Internet Messenger";
|
||||||
icon = "/home/${username}/${project}/other/discord.app.png";
|
icon = "vencord-custom";
|
||||||
name = "Discord";
|
name = "Discord";
|
||||||
type = "Application";
|
type = "Application";
|
||||||
};
|
};
|
||||||
@ -37,6 +40,8 @@
|
|||||||
type = "Application";
|
type = "Application";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
dataFile."icons/hicolor/256x256/apps/kitty-custom.png".source = "${inputs.cookiez-assets}/apps/kitty.png";
|
||||||
|
|
||||||
desktopEntries.kitty = {
|
desktopEntries.kitty = {
|
||||||
name = "kitty";
|
name = "kitty";
|
||||||
genericName = "Terminal emulator";
|
genericName = "Terminal emulator";
|
||||||
@ -45,7 +50,8 @@
|
|||||||
terminal = false;
|
terminal = false;
|
||||||
categories = ["System" "TerminalEmulator"];
|
categories = ["System" "TerminalEmulator"];
|
||||||
|
|
||||||
icon = "/home/${username}/${project}/other/kitty.app.png";
|
#icon = "${inputs.cookiez-assets}/apps/kitty.png";
|
||||||
|
icon = "kitty-custom";
|
||||||
};
|
};
|
||||||
|
|
||||||
desktopEntries."org.kde.kinfocenter" = {
|
desktopEntries."org.kde.kinfocenter" = {
|
||||||
@ -58,11 +64,6 @@
|
|||||||
noDisplay = true;
|
noDisplay = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
desktopEntries."org.kde.kmenuedit" = {
|
|
||||||
name = "Menu Editor";
|
|
||||||
noDisplay = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
desktopEntries."micro" = {
|
desktopEntries."micro" = {
|
||||||
name = "Micro";
|
name = "Micro";
|
||||||
noDisplay = true;
|
noDisplay = true;
|
||||||
@ -106,10 +107,5 @@
|
|||||||
name = "KWrite";
|
name = "KWrite";
|
||||||
noDisplay = true;
|
noDisplay = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
desktopEntries."org.kde.discover" = {
|
|
||||||
name = "Discover";
|
|
||||||
noDisplay = true;
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@ -3,6 +3,7 @@
|
|||||||
enable = true;
|
enable = true;
|
||||||
profiles = {
|
profiles = {
|
||||||
"${username}" = {
|
"${username}" = {
|
||||||
|
isDefault = true;
|
||||||
extensions.force = true;
|
extensions.force = true;
|
||||||
|
|
||||||
#Create multiple containers, like "work" "social media" ..., for cookies to reside in so they dont cross leak
|
#Create multiple containers, like "work" "social media" ..., for cookies to reside in so they dont cross leak
|
||||||
|
|||||||
@ -7,6 +7,7 @@
|
|||||||
project,
|
project,
|
||||||
host,
|
host,
|
||||||
version,
|
version,
|
||||||
|
cookiez-assets,
|
||||||
...
|
...
|
||||||
}: {
|
}: {
|
||||||
# Home Manager needs a bit of information about you and the
|
# Home Manager needs a bit of information about you and the
|
||||||
@ -14,7 +15,7 @@
|
|||||||
home.username = username;
|
home.username = username;
|
||||||
home.homeDirectory = "/home/${username}";
|
home.homeDirectory = "/home/${username}";
|
||||||
home.packages = [
|
home.packages = [
|
||||||
(import ./ncli.nix {
|
(import ./ncli/default.nix {
|
||||||
inherit pkgs host project;
|
inherit pkgs host project;
|
||||||
backupFiles = [
|
backupFiles = [
|
||||||
".gtkrc-2.0.backup"
|
".gtkrc-2.0.backup"
|
||||||
@ -73,6 +74,7 @@
|
|||||||
|
|
||||||
git = {
|
git = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
lfs.enable = true;
|
||||||
settings = {
|
settings = {
|
||||||
user = {
|
user = {
|
||||||
name = "Cookiez";
|
name = "Cookiez";
|
||||||
|
|||||||
@ -1,32 +0,0 @@
|
|||||||
{
|
|
||||||
pkgs,
|
|
||||||
inputs,
|
|
||||||
username,
|
|
||||||
project,
|
|
||||||
...
|
|
||||||
}: {
|
|
||||||
imports = [
|
|
||||||
];
|
|
||||||
|
|
||||||
services = {
|
|
||||||
hyprpaper = {
|
|
||||||
enable = false;
|
|
||||||
|
|
||||||
settings = {
|
|
||||||
preload = [
|
|
||||||
#"/home/${username}/${project}/other/wallpaper1.png"
|
|
||||||
#"/home/${username}/${project}/other/wallpaper2.png"
|
|
||||||
#"/home/${username}/${project}/other/wallpaper3.png"
|
|
||||||
"/home/${username}/${project}/other/wallpaper4.png"
|
|
||||||
];
|
|
||||||
|
|
||||||
wallpaper = [
|
|
||||||
#"eDP-1,/home/${username}/${project}/other/wallpaper1.png"
|
|
||||||
#"eDP-1,/home/${username}/${project}/other/wallpaper2.png"
|
|
||||||
#"eDP-1,/home/${username}/${project}/other/wallpaper3.png"
|
|
||||||
"eDP-1,/home/${username}/${project}/other/wallpaper4.png"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
732
modules/ncli.nix
@ -1,732 +0,0 @@
|
|||||||
{
|
|
||||||
pkgs,
|
|
||||||
host,
|
|
||||||
backupFiles ? [".config/mimeapps.list.backup"],
|
|
||||||
project,
|
|
||||||
...
|
|
||||||
}: let
|
|
||||||
backupFilesString = pkgs.lib.strings.concatStringsSep " " backupFiles;
|
|
||||||
in
|
|
||||||
pkgs.writeShellScriptBin "ncli" ''
|
|
||||||
#!${pkgs.bash}/bin/bash
|
|
||||||
set -euo pipefail
|
|
||||||
|
|
||||||
# --- Configuration ---
|
|
||||||
PROJECT="${project}"
|
|
||||||
HOST="${host}"
|
|
||||||
BACKUP_FILES_STR="${backupFilesString}"
|
|
||||||
VERSION="2.1.3"
|
|
||||||
FLAKE_NIX_PATH="$HOME/$PROJECT/flake.nix"
|
|
||||||
|
|
||||||
read -r -a BACKUP_FILES <<< "$BACKUP_FILES_STR"
|
|
||||||
|
|
||||||
# --- Read Colors file ---
|
|
||||||
source /$HOME/$PROJECT/other/colors.sh
|
|
||||||
|
|
||||||
# --- Helper Functions ---
|
|
||||||
print_help() {
|
|
||||||
echo "NixOS CLI Utility -- version $VERSION"
|
|
||||||
echo ""
|
|
||||||
echo "Usage: ncli [command]"
|
|
||||||
echo ""
|
|
||||||
echo "System Commands:"
|
|
||||||
echo " rebuild - Rebuild the NixOS system configuration."
|
|
||||||
echo " update - Update the flake and rebuild the system."
|
|
||||||
echo ""
|
|
||||||
echo "Maintenance Commands:"
|
|
||||||
echo " cleanup - Clean up old system generations. Can specify a number to keep."
|
|
||||||
echo " diag - Create a system diagnostic report (saves to ~/diag.txt)."
|
|
||||||
echo " list-gens - List user and system generations."
|
|
||||||
echo " trim - Trim filesystems to improve SSD performance."
|
|
||||||
echo ""
|
|
||||||
echo "Git Commands:"
|
|
||||||
echo " commit [msg] - Add all changes and commit with message."
|
|
||||||
echo " push - Push changes to origin."
|
|
||||||
echo " pull - Pull latest changes from origin."
|
|
||||||
echo " status - Show git status."
|
|
||||||
echo ""
|
|
||||||
echo "Development Commands:"
|
|
||||||
echo " dev - Initialize a Nix development environment (flake.nix + direnv)."
|
|
||||||
echo " dev track - Remove assume-unchanged flag from flake files."
|
|
||||||
echo " dev untrack - Mark flake files as assume-unchanged in a directory."
|
|
||||||
echo ""
|
|
||||||
echo " help - Show this help message."
|
|
||||||
echo ""
|
|
||||||
}
|
|
||||||
|
|
||||||
handle_backups() {
|
|
||||||
if [ ''${#BACKUP_FILES[@]} -eq 0 ]; then
|
|
||||||
echo "No backup files configured to check."
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Checking for backup files to remove..."
|
|
||||||
for file_path in "''${BACKUP_FILES[@]}"; do
|
|
||||||
full_path="$HOME/$file_path"
|
|
||||||
if [ -f "$full_path" ]; then
|
|
||||||
echo "Removing stale backup file: $full_path"
|
|
||||||
rm "$full_path"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
# --- Dev Init Helper Functions ---
|
|
||||||
print_header() {
|
|
||||||
echo ""
|
|
||||||
echo -e "''${BLUE}==============================================''${NOCOLOR}"
|
|
||||||
echo -e "''${BLUE} Nix Flake Development Environment Initializer''${NOCOLOR}"
|
|
||||||
echo -e "''${BLUE}==============================================''${NOCOLOR}"
|
|
||||||
echo ""
|
|
||||||
}
|
|
||||||
|
|
||||||
print_success() {
|
|
||||||
echo -e "''${GREEN}[OK]''${NOCOLOR} $1"
|
|
||||||
}
|
|
||||||
|
|
||||||
print_error() {
|
|
||||||
echo -e "''${RED}[ERR]''${NOCOLOR} $1"
|
|
||||||
}
|
|
||||||
|
|
||||||
print_info() {
|
|
||||||
echo -e "''${YELLOW}[->]''${NOCOLOR} $1"
|
|
||||||
}
|
|
||||||
|
|
||||||
# --- Main Logic ---
|
|
||||||
if [ "$#" -eq 0 ]; then
|
|
||||||
echo "Error: No command provided." >&2
|
|
||||||
print_help
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$1" in
|
|
||||||
cleanup)
|
|
||||||
echo "Warning! This will remove old generations of your system."
|
|
||||||
read -p "How many generations to keep (default: all)? " keep_count
|
|
||||||
|
|
||||||
if [ -z "$keep_count" ]; then
|
|
||||||
read -p "This will remove all but the current generation. Continue (y/N)? " -n 1 -r
|
|
||||||
echo
|
|
||||||
if [[ $REPLY =~ ^[Yy]$ ]]; then
|
|
||||||
nh clean all -v
|
|
||||||
else
|
|
||||||
echo "Cleanup cancelled."
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
read -p "This will keep the last $keep_count generations. Continue (y/N)? " -n 1 -r
|
|
||||||
echo
|
|
||||||
if [[ $REPLY =~ ^[Yy]$ ]]; then
|
|
||||||
nh clean all -k "$keep_count" -v
|
|
||||||
else
|
|
||||||
echo "Cleanup cancelled."
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
LOG_DIR="$HOME/ncli-cleanup-logs"
|
|
||||||
mkdir -p "$LOG_DIR"
|
|
||||||
LOG_FILE="$LOG_DIR/ncli-cleanup-$(date +%Y-%m-%d_%H-%M-%S).log"
|
|
||||||
echo "Cleaning up old log files..." >> "$LOG_FILE"
|
|
||||||
find "$LOG_DIR" -type f -mtime +3 -name "*.log" -delete >> "$LOG_FILE" 2>&1
|
|
||||||
echo "Cleanup process logged to $LOG_FILE"
|
|
||||||
;;
|
|
||||||
diag)
|
|
||||||
echo "Generating system diagnostic report..."
|
|
||||||
{
|
|
||||||
echo "=== NixOS System Diagnostic Report ==="
|
|
||||||
echo "Generated: $(date)"
|
|
||||||
echo ""
|
|
||||||
echo "=== System Information ==="
|
|
||||||
inxi --full 2>/dev/null || echo "inxi not available"
|
|
||||||
echo ""
|
|
||||||
echo "=== Git Status ==="
|
|
||||||
cd "$HOME/$PROJECT" 2>/dev/null && git status 2>/dev/null || echo "Git status not available"
|
|
||||||
echo ""
|
|
||||||
} > "$HOME/diag.txt"
|
|
||||||
echo "Diagnostic report saved to $HOME/diag.txt"
|
|
||||||
;;
|
|
||||||
help)
|
|
||||||
print_help
|
|
||||||
;;
|
|
||||||
list-gens)
|
|
||||||
echo "--- User Generations ---"
|
|
||||||
nix-env --list-generations | cat || echo "Could not list user generations."
|
|
||||||
echo ""
|
|
||||||
echo "--- System Generations ---"
|
|
||||||
nix profile history --profile /nix/var/nix/profiles/system | cat || echo "Could not list system generations."
|
|
||||||
;;
|
|
||||||
rebuild)
|
|
||||||
handle_backups
|
|
||||||
geno=$(sudo nix-env --list-generations --profile /nix/var/nix/profiles/system | grep current | awk '{print $1}')
|
|
||||||
echo -e "Starting NixOS rebuild for current host: $HOST on generation: $YELLOW$geno$NOCOLOR"
|
|
||||||
cd "$HOME/$PROJECT" || { echo "Error: Could not change to $HOME/$PROJECT"; exit 1; }
|
|
||||||
|
|
||||||
current=""
|
|
||||||
if [ -f /etc/nixos-tags ]; then
|
|
||||||
current=$(cat /etc/nixos-tags)
|
|
||||||
fi
|
|
||||||
|
|
||||||
if sudo nixos-rebuild switch --flake .; then
|
|
||||||
echo "✓ Rebuild finished successfully for $HOST"
|
|
||||||
|
|
||||||
if [ -n "$current" ]; then
|
|
||||||
sudo /run/current-system/specialisation/$current/bin/switch-to-configuration test
|
|
||||||
else
|
|
||||||
echo "No specialization tag found, staying on default system."
|
|
||||||
fi
|
|
||||||
|
|
||||||
genn=$(sudo nix-env --list-generations --profile /nix/var/nix/profiles/system | grep current | awk '{print $1}')
|
|
||||||
echo -e "Running on new generation: $YELLOW $geno $NOCOLOR-> $GREEN$genn$NOCOLOR"
|
|
||||||
|
|
||||||
else
|
|
||||||
echo "✗ Rebuild failed for $HOST" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
update)
|
|
||||||
handle_backups
|
|
||||||
geno=$(sudo nix-env --list-generations --profile /nix/var/nix/profiles/system | grep current | awk '{print $1}')
|
|
||||||
echo -e "Updating flake and rebuilding system for current host: $HOST on generation: $YELLOW$geno$NOCOLOR"
|
|
||||||
cd "$HOME/$PROJECT" || { echo "Error: Could not change to $HOME/$PROJECT"; exit 1; }
|
|
||||||
|
|
||||||
# --- Selective flake update ---
|
|
||||||
read -rp "Update [a]ll inputs or [s]elect manually? (a/s): " choice
|
|
||||||
|
|
||||||
case "$choice" in
|
|
||||||
a|A)
|
|
||||||
echo "Updating all inputs..."
|
|
||||||
if nix flake update --flake .; then
|
|
||||||
echo "✓ Flake updated successfully"
|
|
||||||
else
|
|
||||||
echo "✗ Flake update failed" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
s|S)
|
|
||||||
echo "Fetching available updates (this may take a moment)..."
|
|
||||||
TEMP_LOCK=$(mktemp)
|
|
||||||
trap 'rm -f "$TEMP_LOCK"' EXIT
|
|
||||||
|
|
||||||
nix flake update --output-lock-file "$TEMP_LOCK" --flake . 2>/dev/null
|
|
||||||
|
|
||||||
outdated=$(jq -r --slurpfile new "$TEMP_LOCK" '
|
|
||||||
.nodes as $old |
|
|
||||||
$new[0].nodes as $newn |
|
|
||||||
($old | keys[]) |
|
|
||||||
select(. != "root") |
|
|
||||||
select(
|
|
||||||
($old[.].locked.lastModified // 0) !=
|
|
||||||
($newn[.].locked.lastModified // 0)
|
|
||||||
)
|
|
||||||
' flake.lock)
|
|
||||||
|
|
||||||
if [[ -z "$outdated" ]]; then
|
|
||||||
echo "✓ All inputs are already up to date, skipping flake update."
|
|
||||||
else
|
|
||||||
echo
|
|
||||||
echo "Updates available for:"
|
|
||||||
printf '%s\n' "$outdated"
|
|
||||||
echo
|
|
||||||
echo "Tab to select, Enter to update, Esc to cancel."
|
|
||||||
selected=$(printf '%s\n' "$outdated" | fzf --multi) || {
|
|
||||||
echo "No inputs selected, skipping flake update."
|
|
||||||
selected=""
|
|
||||||
}
|
|
||||||
if [[ -n "$selected" ]]; then
|
|
||||||
if nix flake update --flake . $selected; then
|
|
||||||
echo "✓ Flake updated successfully"
|
|
||||||
else
|
|
||||||
echo "✗ Flake update failed" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Invalid choice, skipping flake update."
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
# --- End selective flake update ---
|
|
||||||
|
|
||||||
|
|
||||||
current=""
|
|
||||||
if [ -f /etc/nixos-tags ]; then
|
|
||||||
current=$(cat /etc/nixos-tags)
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "$current" ]; then
|
|
||||||
echo "Rebuilding system... Current specialization: $current"
|
|
||||||
else
|
|
||||||
echo "Rebuilding system... Staying on current specialization"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if sudo nixos-rebuild switch --flake .; then
|
|
||||||
echo "✓ Update and rebuild finished successfully for $HOST"
|
|
||||||
|
|
||||||
if [ -n "$current" ]; then
|
|
||||||
sudo /run/current-system/specialisation/$current/bin/switch-to-configuration test
|
|
||||||
else
|
|
||||||
echo "No specialization tag found, staying on default system."
|
|
||||||
fi
|
|
||||||
|
|
||||||
genn=$(sudo nix-env --list-generations --profile /nix/var/nix/profiles/system | grep current | awk '{print $1}')
|
|
||||||
echo -e "Running on new generation: $YELLOW $geno $NOCOLOR-> $GREEN$genn$NOCOLOR"
|
|
||||||
|
|
||||||
else
|
|
||||||
echo "✗ Update and rebuild failed for $HOST" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
commit)
|
|
||||||
cd "$HOME/$PROJECT" || { echo "Error: Could not change to $HOME/$PROJECT"; exit 1; }
|
|
||||||
if [ "$#" -lt 2 ]; then
|
|
||||||
read -p "Enter commit message: " commit_msg
|
|
||||||
else
|
|
||||||
shift
|
|
||||||
commit_msg="$*"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$commit_msg" ]; then
|
|
||||||
echo "Error: Commit message cannot be empty" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
git add -A && git commit -m "$commit_msg"
|
|
||||||
;;
|
|
||||||
home-backups)
|
|
||||||
ls -a ~ | grep backup
|
|
||||||
;;
|
|
||||||
switch)
|
|
||||||
current=""
|
|
||||||
if [ -f /etc/nixos-tags ]; then
|
|
||||||
current=$(cat /etc/nixos-tags)
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$#" -ge 2 ]; then
|
|
||||||
spec_name="$2"
|
|
||||||
if [ -n "$current" ]; then
|
|
||||||
echo "Already on specialization: $current. Cannot switch directly to '$spec_name'. Please reboot or return to default first."
|
|
||||||
else
|
|
||||||
if [ -d "/run/current-system/specialisation/$spec_name" ]; then
|
|
||||||
echo "Switching to specialization: $spec_name"
|
|
||||||
sudo /run/current-system/specialisation/$spec_name/bin/switch-to-configuration test
|
|
||||||
else
|
|
||||||
echo "Error: Specialization '$spec_name' not found."
|
|
||||||
echo "Available specializations:"
|
|
||||||
ls /run/current-system/specialisation/
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
if [ -n "$current" ]; then
|
|
||||||
echo "Already on a specialization: $current. To switch, please reboot, or use 'sudo nixos-rebuild switch --flake .' to get back to default, and then switch after."
|
|
||||||
else
|
|
||||||
specs=$(ls /run/current-system/specialisation/)
|
|
||||||
echo "Specializations available:"
|
|
||||||
echo "$specs"
|
|
||||||
echo ""
|
|
||||||
echo "To switch to a specialization, run: 'ncli switch <tag>'"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
push)
|
|
||||||
cd "$HOME/$PROJECT" || { echo "Error: Could not change to $HOME/$PROJECT"; exit 1; }
|
|
||||||
git push origin $(git branch --show-current)
|
|
||||||
;;
|
|
||||||
pull)
|
|
||||||
cd "$HOME/$PROJECT" || { echo "Error: Could not change to $HOME/$PROJECT"; exit 1; }
|
|
||||||
git pull origin $(git branch --show-current)
|
|
||||||
;;
|
|
||||||
status)
|
|
||||||
cd "$HOME/$PROJECT" || { echo "Error: Could not change to $HOME/$PROJECT"; exit 1; }
|
|
||||||
git status
|
|
||||||
;;
|
|
||||||
format)
|
|
||||||
nix fmt .
|
|
||||||
;;
|
|
||||||
trim)
|
|
||||||
echo "Running 'sudo fstrim -v /' may take a few minutes and impact system performance."
|
|
||||||
read -p "Enter to run now or enter to exit (y/N): " -n 1 -r
|
|
||||||
echo # move to a new line
|
|
||||||
if [[ $REPLY =~ ^[Yy]$ ]]; then
|
|
||||||
echo "Running fstrim..."
|
|
||||||
sudo fstrim -v /
|
|
||||||
echo "fstrim complete."
|
|
||||||
else
|
|
||||||
echo "Trim operation cancelled."
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
dev)
|
|
||||||
# Only flake files need assume-unchanged (Nix requires them in the index).
|
|
||||||
# .envrc and .direnv are handled via .git/info/exclude instead.
|
|
||||||
DEV_FILES=(flake.nix flake.lock)
|
|
||||||
DIRENV_LOCAL_FILES=(.envrc .direnv)
|
|
||||||
|
|
||||||
_dev_resolve_dir() {
|
|
||||||
read -rp " Enter target directory [./]: " TARGET_DIR
|
|
||||||
TARGET_DIR="''${TARGET_DIR:-./}"
|
|
||||||
if [[ ! -d "$TARGET_DIR" ]]; then
|
|
||||||
print_error "Directory '$TARGET_DIR' does not exist."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
TARGET_ABS="$(cd "$TARGET_DIR" && pwd)"
|
|
||||||
if ! git -C "$TARGET_ABS" rev-parse --git-dir > /dev/null 2>&1; then
|
|
||||||
print_error "No Git repository found at '$TARGET_ABS'."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Add .envrc and .direnv to .git/info/exclude (local-only, never committed).
|
|
||||||
_add_local_excludes() {
|
|
||||||
local repo_abs="$1"
|
|
||||||
local git_dir exclude_file
|
|
||||||
git_dir="$(git -C "$repo_abs" rev-parse --git-dir)"
|
|
||||||
exclude_file="$git_dir/info/exclude"
|
|
||||||
mkdir -p "$(dirname "$exclude_file")"
|
|
||||||
touch "$exclude_file"
|
|
||||||
|
|
||||||
for entry in "''${DIRENV_LOCAL_FILES[@]}"; do
|
|
||||||
if ! grep -qxF "$entry" "$exclude_file" 2>/dev/null; then
|
|
||||||
echo "$entry" >> "$exclude_file"
|
|
||||||
print_success "$entry → ignored via .git/info/exclude (local only)"
|
|
||||||
else
|
|
||||||
print_info "$entry already in .git/info/exclude, skipping."
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
_remove_local_excludes() {
|
|
||||||
local repo_abs="$1"
|
|
||||||
local git_dir exclude_file tmp_file
|
|
||||||
git_dir="$(git -C "$repo_abs" rev-parse --git-dir)"
|
|
||||||
exclude_file="$git_dir/info/exclude"
|
|
||||||
|
|
||||||
[[ -f "$exclude_file" ]] || return 0
|
|
||||||
|
|
||||||
tmp_file="$(mktemp)"
|
|
||||||
cp "$exclude_file" "$tmp_file"
|
|
||||||
|
|
||||||
for entry in "''${DIRENV_LOCAL_FILES[@]}"; do
|
|
||||||
if grep -qxF "$entry" "$tmp_file" 2>/dev/null; then
|
|
||||||
grep -vxF "$entry" "$tmp_file" > "''${tmp_file}.new" || true
|
|
||||||
mv "''${tmp_file}.new" "$tmp_file"
|
|
||||||
print_success "$entry → removed from .git/info/exclude"
|
|
||||||
else
|
|
||||||
print_info "$entry not present in .git/info/exclude, skipping."
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
mv "$tmp_file" "$exclude_file"
|
|
||||||
}
|
|
||||||
|
|
||||||
case "''${2:-init}" in
|
|
||||||
|
|
||||||
untrack)
|
|
||||||
echo ""
|
|
||||||
echo -e "''${BLUE}--- Dev: Track Files (assume-unchanged) ---''${NOCOLOR}"
|
|
||||||
echo ""
|
|
||||||
_dev_resolve_dir
|
|
||||||
|
|
||||||
acted=false
|
|
||||||
for f in "''${DEV_FILES[@]}"; do
|
|
||||||
full="$TARGET_ABS/$f"
|
|
||||||
if [[ ! -f "$full" ]]; then
|
|
||||||
print_info "$f not found in $TARGET_ABS — skipping."
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
if ! git -C "$TARGET_ABS" ls-files --error-unmatch "$f" > /dev/null 2>&1; then
|
|
||||||
git -C "$TARGET_ABS" add --intent-to-add "$f"
|
|
||||||
fi
|
|
||||||
git -C "$TARGET_ABS" update-index --assume-unchanged "$f"
|
|
||||||
print_success "$f → untracked (assume-unchanged)"
|
|
||||||
acted=true
|
|
||||||
done
|
|
||||||
|
|
||||||
_add_local_excludes "$TARGET_ABS"
|
|
||||||
|
|
||||||
if ! $acted; then
|
|
||||||
print_info "No dev files found in '$TARGET_ABS' to track."
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
track)
|
|
||||||
echo ""
|
|
||||||
echo -e "''${BLUE}--- Dev: Untrack Files (remove assume-unchanged) ---''${NOCOLOR}"
|
|
||||||
echo ""
|
|
||||||
_dev_resolve_dir
|
|
||||||
|
|
||||||
acted=false
|
|
||||||
for f in "''${DEV_FILES[@]}"; do
|
|
||||||
if git -C "$TARGET_ABS" ls-files -v "$f" 2>/dev/null | grep -q "^h "; then
|
|
||||||
git -C "$TARGET_ABS" update-index --no-assume-unchanged "$f"
|
|
||||||
print_success "$f → tracked (assume-unchanged removed)"
|
|
||||||
acted=true
|
|
||||||
else
|
|
||||||
print_info "$f is not marked assume-unchanged — skipping."
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
_remove_local_excludes "$TARGET_ABS"
|
|
||||||
|
|
||||||
if ! $acted; then
|
|
||||||
print_info "No files in '$TARGET_ABS' had the assume-unchanged bit set."
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
init|*)
|
|
||||||
# ---- Defaults -----
|
|
||||||
SOURCE_FLAKE="$HOME/$PROJECT/other/dev-template.nix"
|
|
||||||
|
|
||||||
# ---- Check source flake exists ------------------------------
|
|
||||||
if [[ ! -f "$SOURCE_FLAKE" ]]; then
|
|
||||||
print_error "Source flake template not found: $SOURCE_FLAKE"
|
|
||||||
echo "Please ensure dev-template.nix exists in $HOME/$PROJECT/other/"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
print_header
|
|
||||||
|
|
||||||
# ---- Step 1: Target Directory -----------------------------------
|
|
||||||
echo -e "''${YELLOW}Step 1/5: Target Directory''${NOCOLOR}"
|
|
||||||
echo ""
|
|
||||||
read -p " Enter target directory [./]: " TARGET_DIR
|
|
||||||
|
|
||||||
if [[ -z "$TARGET_DIR" ]]; then
|
|
||||||
TARGET_DIR="./"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ ! -d "$TARGET_DIR" ]]; then
|
|
||||||
print_error "Directory '$TARGET_DIR' does not exist. Exiting."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
print_success "Target directory: $TARGET_DIR"
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
# ---- Check for existing flake ----------------------------------
|
|
||||||
if [[ -f "$TARGET_DIR/flake.nix" ]]; then
|
|
||||||
echo ""
|
|
||||||
print_error "A flake.nix already exists in '$TARGET_DIR'!"
|
|
||||||
echo ""
|
|
||||||
read -p " Would you like to just place the .envrc instead? [y/N]: " ENVRC_ONLY
|
|
||||||
ENVRC_ONLY="''${ENVRC_ONLY:-N}"
|
|
||||||
|
|
||||||
if [[ "$ENVRC_ONLY" =~ ^[Yy]$ ]]; then
|
|
||||||
TARGET_ABS="$(cd "$TARGET_DIR" && pwd)"
|
|
||||||
echo ""
|
|
||||||
print_info "Placing .envrc only..."
|
|
||||||
if ! grep -qxF "use flake" "$TARGET_ABS/.envrc" 2>/dev/null; then
|
|
||||||
echo "use flake" >> "$TARGET_ABS/.envrc"
|
|
||||||
print_success ".envrc created at $TARGET_ABS/"
|
|
||||||
else
|
|
||||||
print_info ".envrc already contains 'use flake', nothing to do."
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo ""
|
|
||||||
print_info "Next steps:"
|
|
||||||
echo " cd $TARGET_DIR"
|
|
||||||
echo " direnv allow"
|
|
||||||
echo ""
|
|
||||||
exit 0
|
|
||||||
else
|
|
||||||
print_info "Aborting. No files were changed."
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# ---- Step 2: Project Name ---------------------------------------
|
|
||||||
echo -e "''${YELLOW}Step 2/5: Project Name''${NOCOLOR}"
|
|
||||||
echo ""
|
|
||||||
read -p " Enter development environment name [devShell]: " PROJECT_NAME
|
|
||||||
|
|
||||||
if [[ -z "$PROJECT_NAME" ]]; then
|
|
||||||
PROJECT_NAME="devShell"
|
|
||||||
fi
|
|
||||||
|
|
||||||
print_success "Project name: $PROJECT_NAME"
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
# ---- Step 3: Select template ----------------------------------------
|
|
||||||
echo -e "''${YELLOW}Step 3/5: Select Template''${NOCOLOR}"
|
|
||||||
echo ""
|
|
||||||
echo " 1) Empty - Basic shell, add packages yourself"
|
|
||||||
echo " 2) Python - Python 3, pip, venv setup"
|
|
||||||
echo " 3) Node.js - Node.js, npm"
|
|
||||||
echo " 4) Rust - Rustc, cargo, rust-analyzer"
|
|
||||||
echo " 5) Go - Go, gopls, golangci-lint"
|
|
||||||
echo " 6) C/C++ - GCC, CMake, GDB, pkg-config"
|
|
||||||
echo " 7) Java - JDK 21, Maven"
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
read -p " Select template [1-7] (default: 1): " TEMPLATE_CHOICE
|
|
||||||
|
|
||||||
case "$TEMPLATE_CHOICE" in
|
|
||||||
2)
|
|
||||||
TEMPLATE="python3"
|
|
||||||
PACKAGES="python3 python3Packages.pip python3Packages.virtualenv"
|
|
||||||
BUILD_INPUTS=""
|
|
||||||
SHELL_HOOK_EXTRA="
|
|
||||||
# Create venv if it doesn't exist
|
|
||||||
if [ ! -d .venv ]; then
|
|
||||||
echo 'Creating Python virtual environment...'
|
|
||||||
python3 -m venv .venv
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Activate venv
|
|
||||||
source .venv/bin/activate
|
|
||||||
|
|
||||||
echo 'Python venv activated.'
|
|
||||||
"
|
|
||||||
;;
|
|
||||||
3)
|
|
||||||
TEMPLATE="node"
|
|
||||||
PACKAGES="nodejs_22"
|
|
||||||
BUILD_INPUTS=""
|
|
||||||
SHELL_HOOK_EXTRA='echo "Node.js $(node --version) ready."'
|
|
||||||
;;
|
|
||||||
4)
|
|
||||||
TEMPLATE="rust"
|
|
||||||
PACKAGES="rustc cargo rust-analyzer"
|
|
||||||
BUILD_INPUTS="openssl pkg-config"
|
|
||||||
SHELL_HOOK_EXTRA='echo "Rust $(rustc --version) ready."'
|
|
||||||
;;
|
|
||||||
5)
|
|
||||||
TEMPLATE="go"
|
|
||||||
PACKAGES="go gopls golangci-lint"
|
|
||||||
BUILD_INPUTS=""
|
|
||||||
SHELL_HOOK_EXTRA='
|
|
||||||
export GOPATH="$PWD/.gopath"
|
|
||||||
export PATH="$GOPATH/bin:$PATH"
|
|
||||||
mkdir -p "$GOPATH"
|
|
||||||
echo "Go $(go version) ready. GOPATH: $GOPATH"
|
|
||||||
'
|
|
||||||
;;
|
|
||||||
6)
|
|
||||||
TEMPLATE="cpp"
|
|
||||||
PACKAGES="gcc gdb cmake gnumake"
|
|
||||||
BUILD_INPUTS="pkg-config"
|
|
||||||
SHELL_HOOK_EXTRA='echo "GCC $(gcc --version | head -1) ready."'
|
|
||||||
;;
|
|
||||||
7)
|
|
||||||
TEMPLATE="java"
|
|
||||||
PACKAGES="jdk21 maven"
|
|
||||||
BUILD_INPUTS=""
|
|
||||||
SHELL_HOOK_EXTRA='echo "Java $(java --version | head -1) ready."'
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
TEMPLATE="empty"
|
|
||||||
PACKAGES=""
|
|
||||||
BUILD_INPUTS=""
|
|
||||||
SHELL_HOOK_EXTRA=""
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
print_success "Selected template: $TEMPLATE"
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
# ---- Step 4: Copy and modify flake ----------------------------------
|
|
||||||
echo -e "''${YELLOW}Step 4/5: Generating flake.nix''${NOCOLOR}"
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
cp "$SOURCE_FLAKE" "$TARGET_DIR/flake.nix"
|
|
||||||
print_success "Copied flake.nix to $TARGET_DIR/"
|
|
||||||
|
|
||||||
sed -i "s|name = \"replaceNameHere\";|name = \"''${PROJECT_NAME}\";|" "$TARGET_DIR/flake.nix"
|
|
||||||
print_success "Set project name: $PROJECT_NAME"
|
|
||||||
|
|
||||||
if [[ -n "$PACKAGES" ]]; then
|
|
||||||
sed -i "s|# replacePackagesHere|$PACKAGES|" "$TARGET_DIR/flake.nix"
|
|
||||||
print_success "Added packages: $PACKAGES"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -n "$BUILD_INPUTS" ]]; then
|
|
||||||
BUILD_INPUTS_LINE="buildInputs = with pkgs; [ $BUILD_INPUTS ];"
|
|
||||||
sed -i "s|# replaceBuildInputsHere|$BUILD_INPUTS_LINE|" "$TARGET_DIR/flake.nix"
|
|
||||||
print_success "Added build inputs: $BUILD_INPUTS"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -n "$SHELL_HOOK_EXTRA" ]]; then
|
|
||||||
awk -v hook="$SHELL_HOOK_EXTRA" '/# replaceShellHookHere/ { print hook; next } { print }' \
|
|
||||||
"$TARGET_DIR/flake.nix" > "$TARGET_DIR/flake.nix.tmp" \
|
|
||||||
&& mv "$TARGET_DIR/flake.nix.tmp" "$TARGET_DIR/flake.nix"
|
|
||||||
print_success "Added template-specific shell hook"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# ---- Step 5: Git Integration & .envrc --------------------------------
|
|
||||||
echo -e "''${YELLOW}Step 5/5: Git Integration''${NOCOLOR}"
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
TARGET_ABS="$(cd "$TARGET_DIR" && pwd)"
|
|
||||||
|
|
||||||
echo "Creating .envrc for direnv to automatically work!"
|
|
||||||
if ! grep -qxF "use flake" "$TARGET_ABS/.envrc" 2>/dev/null; then
|
|
||||||
echo "use flake" >> "$TARGET_ABS/.envrc"
|
|
||||||
print_success ".envrc created at $TARGET_ABS/"
|
|
||||||
else
|
|
||||||
print_info ".envrc already contains 'use flake', skipping."
|
|
||||||
fi
|
|
||||||
|
|
||||||
if git -C "$TARGET_ABS" rev-parse --git-dir > /dev/null 2>&1; then
|
|
||||||
echo " A Git repository was detected at:"
|
|
||||||
echo " $(git -C "$TARGET_ABS" rev-parse --show-toplevel)"
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
# Always add .envrc and .direnv to local exclude — no prompt needed,
|
|
||||||
# these should never be committed regardless.
|
|
||||||
_add_local_excludes "$TARGET_ABS"
|
|
||||||
echo ""
|
|
||||||
|
|
||||||
echo " Nix flakes require flake.nix (and flake.lock) to be Git-tracked."
|
|
||||||
echo " This script can stage them as 'assume-unchanged' so Nix sees them,"
|
|
||||||
echo " but they will NEVER be committed or show up in git status."
|
|
||||||
echo ""
|
|
||||||
read -p " Set up flake files as tracked-but-invisible to Git? [y/N]: " GIT_CHOICE
|
|
||||||
|
|
||||||
GIT_CHOICE="''${GIT_CHOICE:-N}"
|
|
||||||
|
|
||||||
if [[ "$GIT_CHOICE" =~ ^[Yy]$ ]]; then
|
|
||||||
cat > "$TARGET_ABS/flake.lock" << 'EOF'
|
|
||||||
{
|
|
||||||
"nodes": {
|
|
||||||
"root": {}
|
|
||||||
},
|
|
||||||
"root": "root",
|
|
||||||
"version": 7
|
|
||||||
}
|
|
||||||
EOF
|
|
||||||
print_success "flake.lock ready (Nix will populate it on first run if empty)"
|
|
||||||
|
|
||||||
git -C "$TARGET_ABS" add --intent-to-add flake.nix flake.lock
|
|
||||||
git -C "$TARGET_ABS" update-index --assume-unchanged flake.nix flake.lock
|
|
||||||
print_success "flake.nix + flake.lock → tracked (assume-unchanged)"
|
|
||||||
else
|
|
||||||
print_info "Skipped. You can do this manually later:"
|
|
||||||
echo ""
|
|
||||||
echo " git -C \"$TARGET_ABS\" add --intent-to-add flake.nix flake.lock"
|
|
||||||
echo " git -C \"$TARGET_ABS\" update-index --assume-unchanged flake.nix flake.lock"
|
|
||||||
echo ""
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
print_info "No Git repository detected — skipping Git integration."
|
|
||||||
echo ""
|
|
||||||
fi
|
|
||||||
|
|
||||||
# ---- Done ---------------------------------------------------
|
|
||||||
echo -e "''${GREEN}==============================================''${NOCOLOR}"
|
|
||||||
echo -e "''${GREEN} Done! Your flake is ready at:''${NOCOLOR}"
|
|
||||||
echo -e "''${GREEN} $TARGET_DIR/flake.nix''${NOCOLOR}"
|
|
||||||
echo -e "''${GREEN}==============================================''${NOCOLOR}"
|
|
||||||
echo ""
|
|
||||||
print_info "Next steps:"
|
|
||||||
echo " cd $TARGET_DIR"
|
|
||||||
echo " direnv allow # Trust the .envrc so direnv auto-activates"
|
|
||||||
echo " nix develop # Or just: cd out and back in"
|
|
||||||
echo ""
|
|
||||||
;;
|
|
||||||
|
|
||||||
esac
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Error: Invalid command '$1'" >&2
|
|
||||||
print_help
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
''
|
|
||||||
136
modules/ncli/builder.nix
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
# ncli/builder.nix — Assembles all modules into the final script
|
||||||
|
{
|
||||||
|
pkgs,
|
||||||
|
host,
|
||||||
|
backupFiles ? [".config/mimeapps.list.backup"],
|
||||||
|
project,
|
||||||
|
...
|
||||||
|
}: let
|
||||||
|
# --- Shared library ---
|
||||||
|
lib = import ./lib.nix {inherit pkgs host project backupFiles;};
|
||||||
|
|
||||||
|
# --- Command modules ---
|
||||||
|
rebuild = import ./commands/rebuild.nix lib;
|
||||||
|
maintenance = import ./commands/maintenance.nix lib;
|
||||||
|
git = import ./commands/git.nix lib;
|
||||||
|
switch = import ./commands/switch.nix lib;
|
||||||
|
dev = import ./commands/dev.nix lib;
|
||||||
|
|
||||||
|
# --- Help text ---
|
||||||
|
print_help = ''
|
||||||
|
print_help() {
|
||||||
|
echo "NixOS CLI Utility"
|
||||||
|
echo ""
|
||||||
|
echo "Usage: ncli [command]"
|
||||||
|
echo ""
|
||||||
|
echo "System Commands:"
|
||||||
|
echo " rebuild - Rebuild the NixOS system configuration."
|
||||||
|
echo " update - Update the flake and rebuild the system."
|
||||||
|
echo ""
|
||||||
|
echo "Maintenance Commands:"
|
||||||
|
echo " cleanup - Clean up old system generations. Can specify a number to keep."
|
||||||
|
echo " diag - Create a system diagnostic report (saves to ~/diag.txt)."
|
||||||
|
echo " list-gens - List user and system generations."
|
||||||
|
echo " trim - Trim filesystems to improve SSD performance."
|
||||||
|
echo ""
|
||||||
|
echo "Git Commands:"
|
||||||
|
echo " commit [msg] - Add all changes and commit with message."
|
||||||
|
echo " push - Push changes to origin."
|
||||||
|
echo " pull - Pull latest changes from origin."
|
||||||
|
echo " status - Show git status."
|
||||||
|
echo ""
|
||||||
|
echo "Development Commands:"
|
||||||
|
echo " dev - Initialize a Nix development environment (flake.nix + direnv)."
|
||||||
|
echo " dev track - Remove assume-unchanged flag from flake files."
|
||||||
|
echo " dev untrack - Mark flake files as assume-unchanged in a directory."
|
||||||
|
echo ""
|
||||||
|
echo " help - Show this help message."
|
||||||
|
echo ""
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
in
|
||||||
|
pkgs.writeShellScriptBin "ncli" ''
|
||||||
|
#!${pkgs.bash}/bin/bash
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
# --- Configuration ---
|
||||||
|
PROJECT="${project}"
|
||||||
|
HOST="${host}"
|
||||||
|
BACKUP_FILES_STR="${lib.backupFilesString}"
|
||||||
|
VERSION="2.2.0"
|
||||||
|
FLAKE_NIX_PATH="$HOME/$PROJECT/flake.nix"
|
||||||
|
|
||||||
|
read -r -a BACKUP_FILES <<< "$BACKUP_FILES_STR"
|
||||||
|
|
||||||
|
# --- Read Colors file ---
|
||||||
|
source ${lib.colorsSource}
|
||||||
|
|
||||||
|
# --- Helper Functions ---
|
||||||
|
${lib.handle_backups}
|
||||||
|
${lib.handle_build_error}
|
||||||
|
${lib.print_header}
|
||||||
|
${lib.print_success}
|
||||||
|
${lib.print_error}
|
||||||
|
${lib.print_info}
|
||||||
|
${print_help}
|
||||||
|
|
||||||
|
# --- Main Logic ---
|
||||||
|
if [ "$#" -eq 0 ]; then
|
||||||
|
echo "Error: No command provided." >&2
|
||||||
|
print_help
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
rebuild)
|
||||||
|
${rebuild.rebuild_case}
|
||||||
|
;;
|
||||||
|
update)
|
||||||
|
${rebuild.update_case}
|
||||||
|
;;
|
||||||
|
cleanup)
|
||||||
|
${maintenance.cleanup_case}
|
||||||
|
;;
|
||||||
|
diag)
|
||||||
|
${maintenance.diag_case}
|
||||||
|
;;
|
||||||
|
list-gens)
|
||||||
|
${maintenance.list_gens_case}
|
||||||
|
;;
|
||||||
|
trim)
|
||||||
|
${maintenance.trim_case}
|
||||||
|
;;
|
||||||
|
home-backups)
|
||||||
|
${maintenance.home_backups_case}
|
||||||
|
;;
|
||||||
|
commit)
|
||||||
|
${git.commit_case}
|
||||||
|
;;
|
||||||
|
push)
|
||||||
|
${git.push_case}
|
||||||
|
;;
|
||||||
|
pull)
|
||||||
|
${git.pull_case}
|
||||||
|
;;
|
||||||
|
status)
|
||||||
|
${git.status_case}
|
||||||
|
;;
|
||||||
|
format)
|
||||||
|
${git.format_case}
|
||||||
|
;;
|
||||||
|
switch)
|
||||||
|
${switch.switch_case}
|
||||||
|
;;
|
||||||
|
dev)
|
||||||
|
${dev.dev_case}
|
||||||
|
;;
|
||||||
|
help)
|
||||||
|
print_help
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Error: Invalid command '$1'" >&2
|
||||||
|
print_help
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
''
|
||||||
364
modules/ncli/commands/dev.nix
Normal file
@ -0,0 +1,364 @@
|
|||||||
|
# ncli/commands/dev.nix — dev init / track / untrack
|
||||||
|
lib: {
|
||||||
|
dev_case = ''
|
||||||
|
# Only flake files need assume-unchanged (Nix requires them in the index).
|
||||||
|
# .envrc and .direnv are handled via .git/info/exclude instead.
|
||||||
|
DEV_FILES=(flake.nix flake.lock)
|
||||||
|
DIRENV_LOCAL_FILES=(.envrc .direnv)
|
||||||
|
|
||||||
|
_dev_resolve_dir() {
|
||||||
|
read -rp " Enter target directory [./]: " TARGET_DIR
|
||||||
|
TARGET_DIR="''${TARGET_DIR:-./}"
|
||||||
|
if [[ ! -d "$TARGET_DIR" ]]; then
|
||||||
|
print_error "Directory '$TARGET_DIR' does not exist."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
TARGET_ABS="$(cd "$TARGET_DIR" && pwd)"
|
||||||
|
if ! git -C "$TARGET_ABS" rev-parse --git-dir > /dev/null 2>&1; then
|
||||||
|
print_error "No Git repository found at '$TARGET_ABS'."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
_add_local_excludes() {
|
||||||
|
local repo_abs="$1"
|
||||||
|
local git_dir exclude_file
|
||||||
|
git_dir="$(git -C "$repo_abs" rev-parse --git-dir)"
|
||||||
|
exclude_file="$git_dir/info/exclude"
|
||||||
|
mkdir -p "$(dirname "$exclude_file")"
|
||||||
|
touch "$exclude_file"
|
||||||
|
|
||||||
|
for entry in "''${DIRENV_LOCAL_FILES[@]}"; do
|
||||||
|
if ! grep -qxF "$entry" "$exclude_file" 2>/dev/null; then
|
||||||
|
echo "$entry" >> "$exclude_file"
|
||||||
|
print_success "$entry → ignored via .git/info/exclude (local only)"
|
||||||
|
else
|
||||||
|
print_info "$entry already in .git/info/exclude, skipping."
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
_remove_local_excludes() {
|
||||||
|
local repo_abs="$1"
|
||||||
|
local git_dir exclude_file tmp_file
|
||||||
|
git_dir="$(git -C "$repo_abs" rev-parse --git-dir)"
|
||||||
|
exclude_file="$git_dir/info/exclude"
|
||||||
|
|
||||||
|
[[ -f "$exclude_file" ]] || return 0
|
||||||
|
|
||||||
|
tmp_file="$(mktemp)"
|
||||||
|
cp "$exclude_file" "$tmp_file"
|
||||||
|
|
||||||
|
for entry in "''${DIRENV_LOCAL_FILES[@]}"; do
|
||||||
|
if grep -qxF "$entry" "$tmp_file" 2>/dev/null; then
|
||||||
|
grep -vxF "$entry" "$tmp_file" > "''${tmp_file}.new" || true
|
||||||
|
mv "''${tmp_file}.new" "$tmp_file"
|
||||||
|
print_success "$entry → removed from .git/info/exclude"
|
||||||
|
else
|
||||||
|
print_info "$entry not present in .git/info/exclude, skipping."
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
mv "$tmp_file" "$exclude_file"
|
||||||
|
}
|
||||||
|
|
||||||
|
case "''${2:-init}" in
|
||||||
|
|
||||||
|
untrack)
|
||||||
|
echo ""
|
||||||
|
echo -e "''${BLUE}--- Dev: Track Files (assume-unchanged) ---''${NOCOLOR}"
|
||||||
|
echo ""
|
||||||
|
_dev_resolve_dir
|
||||||
|
|
||||||
|
acted=false
|
||||||
|
for f in "''${DEV_FILES[@]}"; do
|
||||||
|
full="$TARGET_ABS/$f"
|
||||||
|
if [[ ! -f "$full" ]]; then
|
||||||
|
print_info "$f not found in $TARGET_ABS — skipping."
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
if ! git -C "$TARGET_ABS" ls-files --error-unmatch "$f" > /dev/null 2>&1; then
|
||||||
|
git -C "$TARGET_ABS" add --intent-to-add "$f"
|
||||||
|
fi
|
||||||
|
git -C "$TARGET_ABS" update-index --assume-unchanged "$f"
|
||||||
|
print_success "$f → untracked (assume-unchanged)"
|
||||||
|
acted=true
|
||||||
|
done
|
||||||
|
|
||||||
|
_add_local_excludes "$TARGET_ABS"
|
||||||
|
|
||||||
|
if ! $acted; then
|
||||||
|
print_info "No dev files found in '$TARGET_ABS' to track."
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
track)
|
||||||
|
echo ""
|
||||||
|
echo -e "''${BLUE}--- Dev: Untrack Files (remove assume-unchanged) ---''${NOCOLOR}"
|
||||||
|
echo ""
|
||||||
|
_dev_resolve_dir
|
||||||
|
|
||||||
|
acted=false
|
||||||
|
for f in "''${DEV_FILES[@]}"; do
|
||||||
|
if git -C "$TARGET_ABS" ls-files -v "$f" 2>/dev/null | grep -q "^h "; then
|
||||||
|
git -C "$TARGET_ABS" update-index --no-assume-unchanged "$f"
|
||||||
|
print_success "$f → tracked (assume-unchanged removed)"
|
||||||
|
acted=true
|
||||||
|
else
|
||||||
|
print_info "$f is not marked assume-unchanged — skipping."
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
_remove_local_excludes "$TARGET_ABS"
|
||||||
|
|
||||||
|
if ! $acted; then
|
||||||
|
print_info "No files in '$TARGET_ABS' had the assume-unchanged bit set."
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
init|*)
|
||||||
|
SOURCE_FLAKE="$HOME/${lib.project}/other/dev-template.nix"
|
||||||
|
|
||||||
|
if [[ ! -f "$SOURCE_FLAKE" ]]; then
|
||||||
|
print_error "Source flake template not found: $SOURCE_FLAKE"
|
||||||
|
echo "Please ensure dev-template.nix exists in $HOME/${lib.project}/other/"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
print_header
|
||||||
|
|
||||||
|
# ---- Step 1: Target Directory ----
|
||||||
|
echo -e "''${YELLOW}Step 1/5: Target Directory''${NOCOLOR}"
|
||||||
|
echo ""
|
||||||
|
read -p " Enter target directory [./]: " TARGET_DIR
|
||||||
|
|
||||||
|
if [[ -z "$TARGET_DIR" ]]; then
|
||||||
|
TARGET_DIR="./"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ ! -d "$TARGET_DIR" ]]; then
|
||||||
|
print_error "Directory '$TARGET_DIR' does not exist. Exiting."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
print_success "Target directory: $TARGET_DIR"
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
# ---- Check for existing flake ----
|
||||||
|
if [[ -f "$TARGET_DIR/flake.nix" ]]; then
|
||||||
|
echo ""
|
||||||
|
print_error "A flake.nix already exists in '$TARGET_DIR'!"
|
||||||
|
echo ""
|
||||||
|
read -p " Would you like to just place the .envrc instead? [y/N]: " ENVRC_ONLY
|
||||||
|
ENVRC_ONLY="''${ENVRC_ONLY:-N}"
|
||||||
|
|
||||||
|
if [[ "$ENVRC_ONLY" =~ ^[Yy]$ ]]; then
|
||||||
|
TARGET_ABS="$(cd "$TARGET_DIR" && pwd)"
|
||||||
|
echo ""
|
||||||
|
print_info "Placing .envrc only..."
|
||||||
|
if ! grep -qxF "use flake" "$TARGET_ABS/.envrc" 2>/dev/null; then
|
||||||
|
echo "use flake" >> "$TARGET_ABS/.envrc"
|
||||||
|
print_success ".envrc created at $TARGET_ABS/"
|
||||||
|
else
|
||||||
|
print_info ".envrc already contains 'use flake', nothing to do."
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo ""
|
||||||
|
print_info "Next steps:"
|
||||||
|
echo " cd $TARGET_DIR"
|
||||||
|
echo " direnv allow"
|
||||||
|
echo ""
|
||||||
|
exit 0
|
||||||
|
else
|
||||||
|
print_info "Aborting. No files were changed."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
# ---- Step 2: Project Name ----
|
||||||
|
echo -e "''${YELLOW}Step 2/5: Project Name''${NOCOLOR}"
|
||||||
|
echo ""
|
||||||
|
read -p " Enter development environment name [devShell]: " PROJECT_NAME
|
||||||
|
|
||||||
|
if [[ -z "$PROJECT_NAME" ]]; then
|
||||||
|
PROJECT_NAME="devShell"
|
||||||
|
fi
|
||||||
|
|
||||||
|
print_success "Project name: $PROJECT_NAME"
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
# ---- Step 3: Select template ----
|
||||||
|
echo -e "''${YELLOW}Step 3/5: Select Template''${NOCOLOR}"
|
||||||
|
echo ""
|
||||||
|
echo " 1) Empty - Basic shell, add packages yourself"
|
||||||
|
echo " 2) Python - Python 3, pip, venv setup"
|
||||||
|
echo " 3) Node.js - Node.js, npm"
|
||||||
|
echo " 4) Rust - Rustc, cargo, rust-analyzer"
|
||||||
|
echo " 5) Go - Go, gopls, golangci-lint"
|
||||||
|
echo " 6) C/C++ - GCC, CMake, GDB, pkg-config"
|
||||||
|
echo " 7) Java - JDK 21, Maven"
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
read -p " Select template [1-7] (default: 1): " TEMPLATE_CHOICE
|
||||||
|
|
||||||
|
case "$TEMPLATE_CHOICE" in
|
||||||
|
2)
|
||||||
|
TEMPLATE="python3"
|
||||||
|
PACKAGES="python3 python3Packages.pip python3Packages.virtualenv"
|
||||||
|
BUILD_INPUTS=""
|
||||||
|
SHELL_HOOK_EXTRA="
|
||||||
|
if [ ! -d .venv ]; then
|
||||||
|
echo 'Creating Python virtual environment...'
|
||||||
|
python3 -m venv .venv
|
||||||
|
fi
|
||||||
|
source .venv/bin/activate
|
||||||
|
echo 'Python venv activated.'
|
||||||
|
"
|
||||||
|
;;
|
||||||
|
3)
|
||||||
|
TEMPLATE="node"
|
||||||
|
PACKAGES="nodejs_22"
|
||||||
|
BUILD_INPUTS=""
|
||||||
|
SHELL_HOOK_EXTRA='echo "Node.js $(node --version) ready."'
|
||||||
|
;;
|
||||||
|
4)
|
||||||
|
TEMPLATE="rust"
|
||||||
|
PACKAGES="rustc cargo rust-analyzer"
|
||||||
|
BUILD_INPUTS="openssl pkg-config"
|
||||||
|
SHELL_HOOK_EXTRA='echo "Rust $(rustc --version) ready."'
|
||||||
|
;;
|
||||||
|
5)
|
||||||
|
TEMPLATE="go"
|
||||||
|
PACKAGES="go gopls golangci-lint"
|
||||||
|
BUILD_INPUTS=""
|
||||||
|
SHELL_HOOK_EXTRA='
|
||||||
|
export GOPATH="$PWD/.gopath"
|
||||||
|
export PATH="$GOPATH/bin:$PATH"
|
||||||
|
mkdir -p "$GOPATH"
|
||||||
|
echo "Go $(go version) ready. GOPATH: $GOPATH"
|
||||||
|
'
|
||||||
|
;;
|
||||||
|
6)
|
||||||
|
TEMPLATE="cpp"
|
||||||
|
PACKAGES="gcc gdb cmake gnumake"
|
||||||
|
BUILD_INPUTS="pkg-config"
|
||||||
|
SHELL_HOOK_EXTRA='echo "GCC $(gcc --version | head -1) ready."'
|
||||||
|
;;
|
||||||
|
7)
|
||||||
|
TEMPLATE="java"
|
||||||
|
PACKAGES="jdk21 maven"
|
||||||
|
BUILD_INPUTS=""
|
||||||
|
SHELL_HOOK_EXTRA='echo "Java $(java --version | head -1) ready."'
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
TEMPLATE="empty"
|
||||||
|
PACKAGES=""
|
||||||
|
BUILD_INPUTS=""
|
||||||
|
SHELL_HOOK_EXTRA=""
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
print_success "Selected template: $TEMPLATE"
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
# ---- Step 4: Copy and modify flake ----
|
||||||
|
echo -e "''${YELLOW}Step 4/5: Generating flake.nix''${NOCOLOR}"
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
cp "$SOURCE_FLAKE" "$TARGET_DIR/flake.nix"
|
||||||
|
print_success "Copied flake.nix to $TARGET_DIR/"
|
||||||
|
|
||||||
|
sed -i "s|name = \"replaceNameHere\";|name = \"''${PROJECT_NAME}\";|" "$TARGET_DIR/flake.nix"
|
||||||
|
print_success "Set project name: $PROJECT_NAME"
|
||||||
|
|
||||||
|
if [[ -n "$PACKAGES" ]]; then
|
||||||
|
sed -i "s|# replacePackagesHere|$PACKAGES|" "$TARGET_DIR/flake.nix"
|
||||||
|
print_success "Added packages: $PACKAGES"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n "$BUILD_INPUTS" ]]; then
|
||||||
|
BUILD_INPUTS_LINE="buildInputs = with pkgs; [ $BUILD_INPUTS ];"
|
||||||
|
sed -i "s|# replaceBuildInputsHere|$BUILD_INPUTS_LINE|" "$TARGET_DIR/flake.nix"
|
||||||
|
print_success "Added build inputs: $BUILD_INPUTS"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -n "$SHELL_HOOK_EXTRA" ]]; then
|
||||||
|
awk -v hook="$SHELL_HOOK_EXTRA" '/# replaceShellHookHere/ { print hook; next } { print }' \
|
||||||
|
"$TARGET_DIR/flake.nix" > "$TARGET_DIR/flake.nix.tmp" \
|
||||||
|
&& mv "$TARGET_DIR/flake.nix.tmp" "$TARGET_DIR/flake.nix"
|
||||||
|
print_success "Added template-specific shell hook"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# ---- Step 5: Git Integration & .envrc ----
|
||||||
|
echo -e "''${YELLOW}Step 5/5: Git Integration''${NOCOLOR}"
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
TARGET_ABS="$(cd "$TARGET_DIR" && pwd)"
|
||||||
|
|
||||||
|
echo "Creating .envrc for direnv to automatically work!"
|
||||||
|
if ! grep -qxF "use flake" "$TARGET_ABS/.envrc" 2>/dev/null; then
|
||||||
|
echo "use flake" >> "$TARGET_ABS/.envrc"
|
||||||
|
print_success ".envrc created at $TARGET_ABS/"
|
||||||
|
else
|
||||||
|
print_info ".envrc already contains 'use flake', skipping."
|
||||||
|
fi
|
||||||
|
|
||||||
|
if git -C "$TARGET_ABS" rev-parse --git-dir > /dev/null 2>&1; then
|
||||||
|
echo " A Git repository was detected at:"
|
||||||
|
echo " $(git -C "$TARGET_ABS" rev-parse --show-toplevel)"
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
_add_local_excludes "$TARGET_ABS"
|
||||||
|
echo ""
|
||||||
|
|
||||||
|
echo " Nix flakes require flake.nix (and flake.lock) to be Git-tracked."
|
||||||
|
echo " This script can stage them as 'assume-unchanged' so Nix sees them,"
|
||||||
|
echo " but they will NEVER be committed or show up in git status."
|
||||||
|
echo ""
|
||||||
|
read -p " Set up flake files as tracked-but-invisible to Git? [y/N]: " GIT_CHOICE
|
||||||
|
|
||||||
|
GIT_CHOICE="''${GIT_CHOICE:-N}"
|
||||||
|
|
||||||
|
if [[ "$GIT_CHOICE" =~ ^[Yy]$ ]]; then
|
||||||
|
cat > "$TARGET_ABS/flake.lock" << 'FLAKE_LOCK_EOF'
|
||||||
|
{
|
||||||
|
"nodes": {
|
||||||
|
"root": {}
|
||||||
|
},
|
||||||
|
"root": "root",
|
||||||
|
"version": 7
|
||||||
|
}
|
||||||
|
FLAKE_LOCK_EOF
|
||||||
|
print_success "flake.lock ready (Nix will populate it on first run if empty)"
|
||||||
|
|
||||||
|
git -C "$TARGET_ABS" add --intent-to-add flake.nix flake.lock
|
||||||
|
git -C "$TARGET_ABS" update-index --assume-unchanged flake.nix flake.lock
|
||||||
|
print_success "flake.nix + flake.lock → tracked (assume-unchanged)"
|
||||||
|
else
|
||||||
|
print_info "Skipped. You can do this manually later:"
|
||||||
|
echo ""
|
||||||
|
echo " git -C \"$TARGET_ABS\" add --intent-to-add flake.nix flake.lock"
|
||||||
|
echo " git -C \"$TARGET_ABS\" update-index --assume-unchanged flake.nix flake.lock"
|
||||||
|
echo ""
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
print_info "No Git repository detected — skipping Git integration."
|
||||||
|
echo ""
|
||||||
|
fi
|
||||||
|
|
||||||
|
# ---- Done ----
|
||||||
|
echo -e "''${GREEN}==============================================''${NOCOLOR}"
|
||||||
|
echo -e "''${GREEN} Done! Your flake is ready at:''${NOCOLOR}"
|
||||||
|
echo -e "''${GREEN} $TARGET_DIR/flake.nix''${NOCOLOR}"
|
||||||
|
echo -e "''${GREEN}==============================================''${NOCOLOR}"
|
||||||
|
echo ""
|
||||||
|
print_info "Next steps:"
|
||||||
|
echo " cd $TARGET_DIR"
|
||||||
|
echo " direnv allow # Trust the .envrc so direnv auto-activates"
|
||||||
|
echo " nix develop # Or just: cd out and back in"
|
||||||
|
echo ""
|
||||||
|
;;
|
||||||
|
|
||||||
|
esac
|
||||||
|
'';
|
||||||
|
}
|
||||||
40
modules/ncli/commands/git.nix
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
# ncli/commands/git.nix — commit, push, pull, status, format
|
||||||
|
lib: let
|
||||||
|
inherit (lib) project;
|
||||||
|
in {
|
||||||
|
commit_case = ''
|
||||||
|
cd "$HOME/${project}" || { echo "Error: Could not change to $HOME/${project}"; exit 1; }
|
||||||
|
if [ "$#" -lt 2 ]; then
|
||||||
|
read -p "Enter commit message: " commit_msg
|
||||||
|
else
|
||||||
|
shift
|
||||||
|
commit_msg="$*"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$commit_msg" ]; then
|
||||||
|
echo "Error: Commit message cannot be empty" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
git add -A && git commit -m "$commit_msg"
|
||||||
|
'';
|
||||||
|
|
||||||
|
push_case = ''
|
||||||
|
cd "$HOME/${project}" || { echo "Error: Could not change to $HOME/${project}"; exit 1; }
|
||||||
|
git push origin $(git branch --show-current)
|
||||||
|
'';
|
||||||
|
|
||||||
|
pull_case = ''
|
||||||
|
cd "$HOME/${project}" || { echo "Error: Could not change to $HOME/${project}"; exit 1; }
|
||||||
|
git pull origin $(git branch --show-current)
|
||||||
|
'';
|
||||||
|
|
||||||
|
status_case = ''
|
||||||
|
cd "$HOME/${project}" || { echo "Error: Could not change to $HOME/${project}"; exit 1; }
|
||||||
|
git status
|
||||||
|
'';
|
||||||
|
|
||||||
|
format_case = ''
|
||||||
|
nix fmt .
|
||||||
|
'';
|
||||||
|
}
|
||||||
75
modules/ncli/commands/maintenance.nix
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
# ncli/commands/maintenance.nix — cleanup, diag, list-gens, trim, home-backups
|
||||||
|
lib: let
|
||||||
|
inherit (lib) project;
|
||||||
|
in {
|
||||||
|
cleanup_case = ''
|
||||||
|
echo "Warning! This will remove old generations of your system."
|
||||||
|
read -p "How many generations to keep (default: all)? " keep_count
|
||||||
|
|
||||||
|
if [ -z "$keep_count" ]; then
|
||||||
|
read -p "This will remove all but the current generation. Continue (y/N)? " -n 1 -r
|
||||||
|
echo
|
||||||
|
if [[ $REPLY =~ ^[Yy]$ ]]; then
|
||||||
|
nh clean all -v
|
||||||
|
else
|
||||||
|
echo "Cleanup cancelled."
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
read -p "This will keep the last $keep_count generations. Continue (y/N)? " -n 1 -r
|
||||||
|
echo
|
||||||
|
if [[ $REPLY =~ ^[Yy]$ ]]; then
|
||||||
|
nh clean all -k "$keep_count" -v
|
||||||
|
else
|
||||||
|
echo "Cleanup cancelled."
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
LOG_DIR="$HOME/ncli-cleanup-logs"
|
||||||
|
mkdir -p "$LOG_DIR"
|
||||||
|
LOG_FILE="$LOG_DIR/ncli-cleanup-$(date +%Y-%m-%d_%H-%M-%S).log"
|
||||||
|
echo "Cleaning up old log files..." >> "$LOG_FILE"
|
||||||
|
find "$LOG_DIR" -type f -mtime +3 -name "*.log" -delete >> "$LOG_FILE" 2>&1
|
||||||
|
echo "Cleanup process logged to $LOG_FILE"
|
||||||
|
'';
|
||||||
|
|
||||||
|
diag_case = ''
|
||||||
|
echo "Generating system diagnostic report..."
|
||||||
|
{
|
||||||
|
echo "=== NixOS System Diagnostic Report ==="
|
||||||
|
echo "Generated: $(date)"
|
||||||
|
echo ""
|
||||||
|
echo "=== System Information ==="
|
||||||
|
inxi --full 2>/dev/null || echo "inxi not available"
|
||||||
|
echo ""
|
||||||
|
echo "=== Git Status ==="
|
||||||
|
cd "$HOME/${project}" 2>/dev/null && git status 2>/dev/null || echo "Git status not available"
|
||||||
|
echo ""
|
||||||
|
} > "$HOME/diag.txt"
|
||||||
|
echo "Diagnostic report saved to $HOME/diag.txt"
|
||||||
|
'';
|
||||||
|
|
||||||
|
list_gens_case = ''
|
||||||
|
echo "--- User Generations ---"
|
||||||
|
nix-env --list-generations | cat || echo "Could not list user generations."
|
||||||
|
echo ""
|
||||||
|
echo "--- System Generations ---"
|
||||||
|
nix profile history --profile /nix/var/nix/profiles/system | cat || echo "Could not list system generations."
|
||||||
|
'';
|
||||||
|
|
||||||
|
trim_case = ''
|
||||||
|
echo "Running 'sudo fstrim -v /' may take a few minutes and impact system performance."
|
||||||
|
read -p "Enter to run now or enter to exit (y/N): " -n 1 -r
|
||||||
|
echo
|
||||||
|
if [[ $REPLY =~ ^[Yy]$ ]]; then
|
||||||
|
echo "Running fstrim..."
|
||||||
|
sudo fstrim -v /
|
||||||
|
echo "fstrim complete."
|
||||||
|
else
|
||||||
|
echo "Trim operation cancelled."
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
|
||||||
|
home_backups_case = ''
|
||||||
|
ls -a ~ | grep backup
|
||||||
|
'';
|
||||||
|
}
|
||||||
145
modules/ncli/commands/rebuild.nix
Normal file
@ -0,0 +1,145 @@
|
|||||||
|
# ncli/commands/rebuild.nix — Rebuild + Update logic
|
||||||
|
lib: let
|
||||||
|
inherit (lib) host project handle_backups handle_build_error;
|
||||||
|
in rec {
|
||||||
|
# Shared rebuild snippet used by both `rebuild` and `update`
|
||||||
|
rebuild_logic = ''
|
||||||
|
handle_backups
|
||||||
|
geno=$(sudo nix-env --list-generations --profile /nix/var/nix/profiles/system | grep current | awk '{print $1}')
|
||||||
|
cd "$HOME/${project}" || { echo "Error: Could not change to $HOME/${project}"; exit 1; }
|
||||||
|
|
||||||
|
current=""
|
||||||
|
if [ -f /etc/nixos-tags ]; then
|
||||||
|
current=$(cat /etc/nixos-tags)
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
|
||||||
|
rebuild_case = ''
|
||||||
|
${rebuild_logic}
|
||||||
|
echo -e "Starting NixOS rebuild for current host: ${host} on generation: $YELLOW$geno$NOCOLOR"
|
||||||
|
|
||||||
|
# Step 1: Build the configuration and safely update the bootloader first
|
||||||
|
set +e
|
||||||
|
sudo nixos-rebuild boot --flake .
|
||||||
|
_rebuild_exit=$?
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if [ "$_rebuild_exit" -eq 0 ]; then
|
||||||
|
echo "✓ Rebuild and bootloader update finished successfully for ${host}"
|
||||||
|
|
||||||
|
# Step 2: Now that boot entries are safe, activate the system live
|
||||||
|
echo "Activating new configuration..."
|
||||||
|
sudo /nix/var/nix/profiles/system/bin/switch-to-configuration switch
|
||||||
|
|
||||||
|
if [ -n "$current" ]; then
|
||||||
|
sudo /nix/var/nix/profiles/system/specialisation/"$current"/bin/switch-to-configuration test
|
||||||
|
else
|
||||||
|
echo "No specialization tag found, staying on default system."
|
||||||
|
fi
|
||||||
|
|
||||||
|
genn=$(sudo nix-env --list-generations --profile /nix/var/nix/profiles/system | grep current | awk '{print $1}')
|
||||||
|
echo -e "Running on new generation: $YELLOW $geno $NOCOLOR-> $GREEN$genn$NOCOLOR"
|
||||||
|
else
|
||||||
|
( exit "$_rebuild_exit" ); handle_build_error
|
||||||
|
echo "✗ Rebuild failed for ${host}" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
|
||||||
|
update_case = ''
|
||||||
|
${rebuild_logic}
|
||||||
|
echo -e "Updating flake and rebuilding system for current host: ${host} on generation: $YELLOW$geno$NOCOLOR"
|
||||||
|
|
||||||
|
# --- Selective flake update ---
|
||||||
|
read -rp "Update [a]ll inputs or [s]elect manually? (a/s): " choice
|
||||||
|
|
||||||
|
case "$choice" in
|
||||||
|
a|A)
|
||||||
|
echo "Updating all inputs..."
|
||||||
|
if nix flake update --flake .; then
|
||||||
|
echo "✓ Flake updated successfully"
|
||||||
|
else
|
||||||
|
echo "✗ Flake update failed" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
s|S)
|
||||||
|
echo "Fetching available updates (this may take a moment)..."
|
||||||
|
TEMP_LOCK=$(mktemp)
|
||||||
|
trap 'rm -f "$TEMP_LOCK"' EXIT
|
||||||
|
|
||||||
|
nix flake update --output-lock-file "$TEMP_LOCK" --flake . 2>/dev/null
|
||||||
|
|
||||||
|
outdated=$(jq -r --slurpfile new "$TEMP_LOCK" '
|
||||||
|
.nodes as $old |
|
||||||
|
$new[0].nodes as $newn |
|
||||||
|
($old | keys[]) |
|
||||||
|
select(. != "root") |
|
||||||
|
select(
|
||||||
|
($old[.].locked.lastModified // 0) !=
|
||||||
|
($newn[.].locked.lastModified // 0)
|
||||||
|
)
|
||||||
|
' flake.lock)
|
||||||
|
|
||||||
|
if [[ -z "$outdated" ]]; then
|
||||||
|
echo "✓ All inputs are already up to date, skipping flake update."
|
||||||
|
else
|
||||||
|
echo
|
||||||
|
echo "Updates available for:"
|
||||||
|
printf '%s\n' "$outdated"
|
||||||
|
echo
|
||||||
|
echo "Tab to select, Enter to update, Esc to cancel."
|
||||||
|
selected=$(printf '%s\n' "$outdated" | fzf --multi) || {
|
||||||
|
echo "No inputs selected, skipping flake update."
|
||||||
|
selected=""
|
||||||
|
}
|
||||||
|
if [[ -n "$selected" ]]; then
|
||||||
|
if nix flake update --flake . $selected; then
|
||||||
|
echo "✓ Flake updated successfully"
|
||||||
|
else
|
||||||
|
echo "✗ Flake update failed" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Invalid choice, skipping flake update."
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
# --- End selective flake update ---
|
||||||
|
|
||||||
|
if [ -n "$current" ]; then
|
||||||
|
echo "Rebuilding system... Current specialization: $current"
|
||||||
|
else
|
||||||
|
echo "Rebuilding system... Staying on current specialization"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Step 1: Build the configuration and safely update the bootloader first
|
||||||
|
set +e
|
||||||
|
sudo nixos-rebuild boot --flake .
|
||||||
|
_rebuild_exit=$?
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if [ "$_rebuild_exit" -eq 0 ]; then
|
||||||
|
echo "✓ Update, rebuild and bootloader update finished successfully for ${host}"
|
||||||
|
|
||||||
|
# Step 2: Now that boot entries are safe, activate the system live
|
||||||
|
echo "Activating new configuration..."
|
||||||
|
sudo /nix/var/nix/profiles/system/bin/switch-to-configuration switch
|
||||||
|
|
||||||
|
if [ -n "$current" ]; then
|
||||||
|
sudo /nix/var/nix/profiles/system/specialisation/"$current"/bin/switch-to-configuration test
|
||||||
|
else
|
||||||
|
echo "No specialization tag found, staying on default system."
|
||||||
|
fi
|
||||||
|
|
||||||
|
genn=$(sudo nix-env --list-generations --profile /nix/var/nix/profiles/system | grep current | awk '{print $1}')
|
||||||
|
echo -e "Running on new generation: $YELLOW $geno $NOCOLOR-> $GREEN$genn$NOCOLOR"
|
||||||
|
else
|
||||||
|
( exit "$_rebuild_exit" ); handle_build_error
|
||||||
|
echo "✗ Update and rebuild failed for ${host}" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
}
|
||||||
35
modules/ncli/commands/switch.nix
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
# ncli/commands/switch.nix — Specialization switching
|
||||||
|
lib: {
|
||||||
|
switch_case = ''
|
||||||
|
current=""
|
||||||
|
if [ -f /etc/nixos-tags ]; then
|
||||||
|
current=$(cat /etc/nixos-tags)
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$#" -ge 2 ]; then
|
||||||
|
spec_name="$2"
|
||||||
|
if [ -n "$current" ]; then
|
||||||
|
echo "Already on specialization: $current. Cannot switch directly to '$spec_name'. Please reboot or return to default first."
|
||||||
|
else
|
||||||
|
if [ -d "/run/current-system/specialisation/$spec_name" ]; then
|
||||||
|
echo "Switching to specialization: $spec_name"
|
||||||
|
sudo /run/current-system/specialisation/"$spec_name"/bin/switch-to-configuration test
|
||||||
|
else
|
||||||
|
echo "Error: Specialization '$spec_name' not found."
|
||||||
|
echo "Available specializations:"
|
||||||
|
ls /run/current-system/specialisation/
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
if [ -n "$current" ]; then
|
||||||
|
echo "Already on a specialization: $current. To switch, please reboot, or use 'sudo nixos-rebuild switch --flake .' to get back to default, and then switch after."
|
||||||
|
else
|
||||||
|
specs=$(ls /run/current-system/specialisation/)
|
||||||
|
echo "Specializations available:"
|
||||||
|
echo "$specs"
|
||||||
|
echo ""
|
||||||
|
echo "To switch to a specialization, run: 'ncli switch <tag>'"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
'';
|
||||||
|
}
|
||||||
8
modules/ncli/default.nix
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
pkgs,
|
||||||
|
host,
|
||||||
|
backupFiles ? [".config/mimeapps.list.backup"],
|
||||||
|
project,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
import ./builder.nix {inherit pkgs host backupFiles project;}
|
||||||
88
modules/ncli/lib.nix
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
# ncli/lib.nix — Shared helpers and utilities
|
||||||
|
{ pkgs, host, project, backupFiles }:
|
||||||
|
|
||||||
|
let
|
||||||
|
backupFilesString = pkgs.lib.strings.concatStringsSep " " backupFiles;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
# --- Injected config ---
|
||||||
|
inherit pkgs host project backupFiles backupFilesString;
|
||||||
|
|
||||||
|
# --- Color / banner source ---
|
||||||
|
colorsSource = "$HOME/${project}/other/colors.sh";
|
||||||
|
|
||||||
|
# --- Backup helper ---
|
||||||
|
handle_backups = ''
|
||||||
|
handle_backups() {
|
||||||
|
echo "Checking for backup files to remove..."
|
||||||
|
found=0
|
||||||
|
for file_path in "''${BACKUP_FILES[@]}"; do
|
||||||
|
full_path="$HOME/$file_path"
|
||||||
|
if [ -f "$full_path" ]; then
|
||||||
|
echo "Removing stale backup file: $full_path"
|
||||||
|
rm "$full_path"
|
||||||
|
found=1
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
if [ "$found" -eq 0 ]; then
|
||||||
|
echo "No stale backup files found."
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
|
||||||
|
# --- OOM / build error handler ---
|
||||||
|
handle_build_error = ''
|
||||||
|
handle_build_error() {
|
||||||
|
local exit_code=$?
|
||||||
|
if [ "$exit_code" -eq 137 ]; then
|
||||||
|
echo ""
|
||||||
|
echo -e "''${RED}╔══════════════════════════════════════════════════════════╗''${NOCOLOR}"
|
||||||
|
echo -e "''${RED}║ BUILD KILLED — Signal 9 (SIGKILL) detected ║''${NOCOLOR}"
|
||||||
|
echo -e "''${RED}╚══════════════════════════════════════════════════════════╝''${NOCOLOR}"
|
||||||
|
echo ""
|
||||||
|
echo -e "''${YELLOW}What happened:''${NOCOLOR}"
|
||||||
|
echo " The build process was forcefully terminated by the OS."
|
||||||
|
echo " This is almost always the Linux kernel OOM killer running out"
|
||||||
|
echo " of RAM + swap during Nix evaluation or compilation."
|
||||||
|
echo ""
|
||||||
|
echo -e "''${YELLOW}Suggested fixes (try in order):''${NOCOLOR}"
|
||||||
|
echo ""
|
||||||
|
echo -e " ''${GREEN}1. Reduce parallel jobs''${NOCOLOR} (lowest RAM usage):"
|
||||||
|
echo " sudo nixos-rebuild switch --flake . --max-jobs 1 --cores 1"
|
||||||
|
echo ""
|
||||||
|
echo -e " ''${GREEN}2. Confirm OOM killer fired:''${NOCOLOR}"
|
||||||
|
echo " journalctl -k --since '5 minutes ago' | grep -i oom"
|
||||||
|
echo ""
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
|
||||||
|
# --- Print helpers (used by dev init) ---
|
||||||
|
print_header = ''
|
||||||
|
print_header() {
|
||||||
|
echo ""
|
||||||
|
echo -e "''${BLUE}==============================================''${NOCOLOR}"
|
||||||
|
echo -e "''${BLUE} Nix Flake Development Environment Initializer''${NOCOLOR}"
|
||||||
|
echo -e "''${BLUE}==============================================''${NOCOLOR}"
|
||||||
|
echo ""
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
|
||||||
|
print_success = ''
|
||||||
|
print_success() {
|
||||||
|
echo -e "''${GREEN}[OK]''${NOCOLOR} $1"
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
|
||||||
|
print_error = ''
|
||||||
|
print_error() {
|
||||||
|
echo -e "''${RED}[ERR]''${NOCOLOR} $1"
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
|
||||||
|
print_info = ''
|
||||||
|
print_info() {
|
||||||
|
echo -e "''${YELLOW}[->]''${NOCOLOR} $1"
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
}
|
||||||
@ -1,5 +1,4 @@
|
|||||||
{
|
{
|
||||||
config,
|
|
||||||
inputs,
|
inputs,
|
||||||
pkgs,
|
pkgs,
|
||||||
...
|
...
|
||||||
@ -7,11 +6,7 @@
|
|||||||
imports = [
|
imports = [
|
||||||
];
|
];
|
||||||
|
|
||||||
home-manager.sharedModules = [
|
|
||||||
./home.nix
|
|
||||||
];
|
|
||||||
|
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
hyprpaper
|
inputs.noctalia.packages.${pkgs.stdenv.hostPlatform.system}.default
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
9
modules/noctalia/home.nix
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
{inputs, ...}: {
|
||||||
|
imports = [
|
||||||
|
inputs.noctalia.homeModules.default
|
||||||
|
];
|
||||||
|
|
||||||
|
programs.noctalia = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
|
}
|
||||||
@ -7,12 +7,12 @@
|
|||||||
}: {
|
}: {
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
#CLI tools
|
#CLI tools
|
||||||
|
imagemagick #Used as a dependency for Zenless Zone Zero
|
||||||
#pdftk #PDF toolkit
|
#pdftk #PDF toolkit
|
||||||
#yt-dlp #YouTube and others video downloader
|
#yt-dlp #YouTube and others video downloader
|
||||||
tailscale #VPN
|
tailscale #VPN
|
||||||
#speedtest-cli #Internet speed tester
|
#speedtest-cli #Internet speed tester
|
||||||
#duplicati
|
#duplicati
|
||||||
#ollama-rocm
|
|
||||||
#open-webui
|
#open-webui
|
||||||
#cloudflare-warp
|
#cloudflare-warp
|
||||||
#ddrescue
|
#ddrescue
|
||||||
|
|||||||
@ -26,6 +26,8 @@
|
|||||||
#sqlite #Lightweight Database system
|
#sqlite #Lightweight Database system
|
||||||
|
|
||||||
#Desktop Applications
|
#Desktop Applications
|
||||||
|
mangohud
|
||||||
|
protonup-qt #For managing proton versions
|
||||||
drawio
|
drawio
|
||||||
ryubing #Nintendo Switch Emulator
|
ryubing #Nintendo Switch Emulator
|
||||||
vlc #VLC Media Player
|
vlc #VLC Media Player
|
||||||
|
|||||||
@ -11,15 +11,14 @@
|
|||||||
#Essentials (CLI Only)
|
#Essentials (CLI Only)
|
||||||
wget #A tool for quickly downloading things from the Web
|
wget #A tool for quickly downloading things from the Web
|
||||||
#javaPackages.compiler.openjdk25 #Java Development Kit 25
|
#javaPackages.compiler.openjdk25 #Java Development Kit 25
|
||||||
#python314 #Python
|
python3 #Python
|
||||||
#python314Packages.pip #Pip for Python 3.12
|
|
||||||
#python314Packages.cmake #The CMake tool to manage project build configurations
|
|
||||||
fastfetch #A utility to see information about your machine
|
fastfetch #A utility to see information about your machine
|
||||||
btop #A replacement for htop to see your machines resources
|
btop #A replacement for htop to see your machines resources
|
||||||
git #Git ... no need to explain
|
git #Git ... no need to explain
|
||||||
#efibootmgr #A tool to manage UEFI boot entries
|
#efibootmgr #A tool to manage UEFI boot entries
|
||||||
zip #A utility for ZIP archives
|
zip #A utility for ZIP archives
|
||||||
unzip #A utility for ZIP archives
|
unzip #A utility for ZIP archives
|
||||||
|
p7zip
|
||||||
rar #A utility for RAR archives
|
rar #A utility for RAR archives
|
||||||
gnutar #A utility for .tar archives
|
gnutar #A utility for .tar archives
|
||||||
cron #A tool to set up commands to run scheduled
|
cron #A tool to set up commands to run scheduled
|
||||||
|
|||||||
@ -1,10 +1,9 @@
|
|||||||
{...}: {
|
{...}: {
|
||||||
nixpkgs.overlays = [
|
nixpkgs.overlays = [
|
||||||
|
#Skip checks of openldap (dependency for Lutris) as it is already tested enough upstream and is not needed directly
|
||||||
(final: prev: {
|
(final: prev: {
|
||||||
openldap = prev.openldap.overrideAttrs (_: {doCheck = false;});
|
openldap = prev.openldap.overrideAttrs (old: {
|
||||||
# Also covers 32-bit builds pulled in by lutris
|
doCheck = false;
|
||||||
pkgsi686Linux = prev.pkgsi686Linux.extend (_: p: {
|
|
||||||
openldap = p.openldap.overrideAttrs (_: {doCheck = false;});
|
|
||||||
});
|
});
|
||||||
})
|
})
|
||||||
];
|
];
|
||||||
|
|||||||
@ -15,9 +15,15 @@
|
|||||||
stylix = {
|
stylix = {
|
||||||
enable = true;
|
enable = true;
|
||||||
autoEnable = false; #So I can choose my programs it targets myself!
|
autoEnable = false; #So I can choose my programs it targets myself!
|
||||||
#image = ../../other/wallpaper2.png;
|
#image = "${inputs.cookiez-assets}/wallpapers/beach-forest.png";
|
||||||
#autoEnable = true; #Auto generate theme based on wallpaper
|
#polarity = "dark"; # "dark" or "light"
|
||||||
base16Scheme = "${pkgs.base16-schemes}/share/themes/dracula.yaml";
|
base16Scheme = "${pkgs.base16-schemes}/share/themes/dracula.yaml";
|
||||||
|
#override = {
|
||||||
|
# base05 = "e0e0e0"; # default text — light grey (no # prefix!)
|
||||||
|
# base04 = "b0b0b0"; # secondary/muted text
|
||||||
|
# base06 = "f5f5f5"; # lighter text variant
|
||||||
|
#};
|
||||||
|
|
||||||
opacity = {
|
opacity = {
|
||||||
desktop = 0.5;
|
desktop = 0.5;
|
||||||
terminal = 0.9;
|
terminal = 0.9;
|
||||||
@ -43,7 +49,8 @@
|
|||||||
plymouth.logoAnimated = true;
|
plymouth.logoAnimated = true;
|
||||||
console.enable = true; #Default console without desktop environment! (NOT KITTY!)
|
console.enable = true; #Default console without desktop environment! (NOT KITTY!)
|
||||||
grub.enable = false;
|
grub.enable = false;
|
||||||
#qt.enable = false;
|
qt.enable = true;
|
||||||
|
gtk.enable = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@ -5,6 +5,7 @@
|
|||||||
...
|
...
|
||||||
}: {
|
}: {
|
||||||
imports = [
|
imports = [
|
||||||
|
#inputs.niri.homeModules.stylix
|
||||||
];
|
];
|
||||||
|
|
||||||
services = {
|
services = {
|
||||||
@ -16,10 +17,9 @@
|
|||||||
#firefox = {
|
#firefox = {
|
||||||
# enable = true;
|
# enable = true;
|
||||||
# colorTheme.enable = true;
|
# colorTheme.enable = true;
|
||||||
# profileNames = [ "${username}" ];
|
# profileNames = ["${username}"];
|
||||||
#};
|
#};
|
||||||
qt.enable = true;
|
#niri.enable = true;
|
||||||
qt.platform = "kde";
|
|
||||||
#kde.enable = false;
|
#kde.enable = false;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|||||||
@ -1,153 +0,0 @@
|
|||||||
{
|
|
||||||
"layer": "top",
|
|
||||||
"position": "top",
|
|
||||||
"modules-left": [
|
|
||||||
"custom/launcher",
|
|
||||||
"hyprland/workspaces",
|
|
||||||
"cpu",
|
|
||||||
"memory"
|
|
||||||
|
|
||||||
],
|
|
||||||
"modules-center": [
|
|
||||||
"hyprland/window"
|
|
||||||
],
|
|
||||||
"spacing": 4,
|
|
||||||
"modules-right": [
|
|
||||||
"tray",
|
|
||||||
"wireplumber",
|
|
||||||
"network",
|
|
||||||
"backlight",
|
|
||||||
"clock",
|
|
||||||
"battery",
|
|
||||||
"custom/power"
|
|
||||||
],
|
|
||||||
"backlight": {
|
|
||||||
"device": "intel_backlight",
|
|
||||||
"format": "{percent}% {icon}",
|
|
||||||
"format-icons": ["", ""]
|
|
||||||
},
|
|
||||||
"hyprland/workspaces": {
|
|
||||||
"format": "{name}",
|
|
||||||
"persistent-workspaces": {
|
|
||||||
"1": [],
|
|
||||||
"2": [],
|
|
||||||
"3": []
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"hyprland/window": {
|
|
||||||
"icon": false,
|
|
||||||
"separate-outputs": true,
|
|
||||||
"format": "{}"
|
|
||||||
},
|
|
||||||
"tray": {
|
|
||||||
"icon-size": 15,
|
|
||||||
"spacing": 7
|
|
||||||
},
|
|
||||||
"clock": {
|
|
||||||
"format": "{:%H:%M} ",
|
|
||||||
"format-alt": "{:%A, %B %d, %Y (%R)}",
|
|
||||||
"tooltip-format": "<tt><small>{calendar}</small></tt>",
|
|
||||||
"calendar": {
|
|
||||||
"mode": "year",
|
|
||||||
"mode-mon-col": 3,
|
|
||||||
"weeks-pos": "right",
|
|
||||||
"on-scroll": 1,
|
|
||||||
"on-click-right": "mode",
|
|
||||||
"format": {
|
|
||||||
"months": "<span color='#f5e0dc'><b>{}</b></span>",
|
|
||||||
"days": "<span color='#cdd6f4'><b>{}</b></span>",
|
|
||||||
"weeks": "<span color='#fab387'><b>W{}</b></span>",
|
|
||||||
"weekdays": "<span color='#f5c2e7'><b>{}</b></span>",
|
|
||||||
"today": "<span color='#cba6f7'><b><u>{}</u></b></span>"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"actions": {
|
|
||||||
"on-click-right": "mode",
|
|
||||||
"on-click-forward": "tz_up",
|
|
||||||
"on-click-backward": "tz_down",
|
|
||||||
"on-scroll-up": "shift_up",
|
|
||||||
"on-scroll-down": "shift_down"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"cpu": {
|
|
||||||
"interval": 1,
|
|
||||||
"format": "CPU {usage:>2}% {icon0}{icon1}{icon2}{icon3}",
|
|
||||||
"format-icons": [
|
|
||||||
"▁",
|
|
||||||
"▂",
|
|
||||||
"▃",
|
|
||||||
"▄",
|
|
||||||
"▅",
|
|
||||||
"▆",
|
|
||||||
"▇",
|
|
||||||
"█"
|
|
||||||
],
|
|
||||||
"on-click": "kitty -e btop"
|
|
||||||
},
|
|
||||||
"memory": {
|
|
||||||
"interval": 30,
|
|
||||||
"format": "MEM {used:0.1f}G/{total:0.1f}G"
|
|
||||||
},
|
|
||||||
"network": {
|
|
||||||
"format": " Disabled",
|
|
||||||
"format-wifi": " ",
|
|
||||||
"format-ethernet": " ",
|
|
||||||
"format-disconnected": "⚠",
|
|
||||||
"tooltip": true,
|
|
||||||
"tooltip-format": "{ifname}\n{ipaddr}",
|
|
||||||
"tooltip-format-wifi": "{essid} {ifname}\n{ipaddr}\nstrength: {signalStrength}%",
|
|
||||||
"on-click": "networkmanager_dmenu"
|
|
||||||
},
|
|
||||||
"custom/launcher": {
|
|
||||||
"format": " ",
|
|
||||||
"tooltip": false,
|
|
||||||
"on-click": "wofi -c ~/.config/wofi/config -I"
|
|
||||||
},
|
|
||||||
"custom/power": {
|
|
||||||
"format": " ",
|
|
||||||
"on-click": "~/.config/wofi/scripts/power.sh",
|
|
||||||
"tooltip": false
|
|
||||||
},
|
|
||||||
"wireplumber": {
|
|
||||||
"scroll-step": 10,
|
|
||||||
"format": "{volume}% {icon} ",
|
|
||||||
"format-bluetooth": "{icon} {volume}%",
|
|
||||||
"format-muted": "muted ",
|
|
||||||
"on-click": "pavucontrol",
|
|
||||||
"format-icons": {
|
|
||||||
"headphones": "",
|
|
||||||
"handsfree": "",
|
|
||||||
"headset": "",
|
|
||||||
"phone": "",
|
|
||||||
"portable": "",
|
|
||||||
"car": "",
|
|
||||||
"default": [
|
|
||||||
"",
|
|
||||||
""
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"battery": {
|
|
||||||
"states": {
|
|
||||||
"warning": 30,
|
|
||||||
"critical": 15
|
|
||||||
},
|
|
||||||
"format": "{capacity}% {icon}",
|
|
||||||
"format-charging": " {capacity}%",
|
|
||||||
"format-pluged": " {capacity}%",
|
|
||||||
"format-full": " {capacity}%",
|
|
||||||
"format-icons": [
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
"",
|
|
||||||
""
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,4 +0,0 @@
|
|||||||
{...}: {
|
|
||||||
# xdg.configFile."waybar/config.jsonc".source = ./config.jsonc;
|
|
||||||
# xdg.configFile."waybar/style.css".source = ./style.css;
|
|
||||||
}
|
|
||||||
@ -1,167 +0,0 @@
|
|||||||
* {
|
|
||||||
font-family: "JetBrainsMono Nerd Font", sans-serif;
|
|
||||||
font-size: 13px;
|
|
||||||
}
|
|
||||||
|
|
||||||
window#waybar {
|
|
||||||
background-color: transparent;
|
|
||||||
}
|
|
||||||
|
|
||||||
window > box {
|
|
||||||
margin-top: 0px;
|
|
||||||
margin-left: 10px;
|
|
||||||
margin-right: 10px;
|
|
||||||
padding-left: 4px;
|
|
||||||
padding-right: 4px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#window {
|
|
||||||
background-color: #202020;
|
|
||||||
border-radius: 20px;
|
|
||||||
padding: 8px 12px 8px 8px;
|
|
||||||
margin: 0px 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
window#waybar.empty #window {
|
|
||||||
background: rgba(12, 12, 12, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
.modules-left {
|
|
||||||
padding: 3px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.modules-right {
|
|
||||||
padding: 3px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.modules-center {
|
|
||||||
padding: 3px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#workspaces {
|
|
||||||
background-color: #202020;
|
|
||||||
border-radius: 20px;
|
|
||||||
padding: 4px 4px 4px 6px;
|
|
||||||
margin: 4px 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#workspaces button {
|
|
||||||
min-height: 0;
|
|
||||||
padding: 0 7px;
|
|
||||||
margin-right: 2px;
|
|
||||||
color: #f5e0dc;
|
|
||||||
}
|
|
||||||
|
|
||||||
#workspaces button.urgent {
|
|
||||||
color: #f5e0dc;
|
|
||||||
animation-name: blink;
|
|
||||||
animation-duration: 0.5s;
|
|
||||||
animation-timing-function: linear;
|
|
||||||
animation-iteration-count: infinite;
|
|
||||||
animation-direction: alternate;
|
|
||||||
}
|
|
||||||
|
|
||||||
#workspaces button.empty {
|
|
||||||
color: #cdd6f4;
|
|
||||||
}
|
|
||||||
|
|
||||||
#workspaces button.visible {
|
|
||||||
color: #89dceb;
|
|
||||||
}
|
|
||||||
|
|
||||||
#workspaces button.active {
|
|
||||||
color: #fab387;
|
|
||||||
}
|
|
||||||
|
|
||||||
@keyframes blink {
|
|
||||||
to {
|
|
||||||
color: #202020;
|
|
||||||
background-color: #dcf5f3;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#custom-launcher {
|
|
||||||
background-color: #202020;
|
|
||||||
border-radius: 20px;
|
|
||||||
padding: 8px 8px 8px 4px;
|
|
||||||
margin: 4px 0;
|
|
||||||
color: #89dceb;
|
|
||||||
}
|
|
||||||
|
|
||||||
#custom-power {
|
|
||||||
background-color: #202020;
|
|
||||||
border-radius: 20px;
|
|
||||||
padding: 8px 12px 8px 8px;
|
|
||||||
margin: 4px 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#cpu {
|
|
||||||
background-color: #202020;
|
|
||||||
border-radius: 20px;
|
|
||||||
padding: 8px 8px 8px 20px;
|
|
||||||
margin: 4px 0;
|
|
||||||
color: #f2cdcd;
|
|
||||||
}
|
|
||||||
|
|
||||||
#memory {
|
|
||||||
background-color: #202020;
|
|
||||||
border-radius: 20px;
|
|
||||||
padding: 8px 8px 8px 20px;
|
|
||||||
margin: 4px 0;
|
|
||||||
color: #fab387;
|
|
||||||
}
|
|
||||||
|
|
||||||
#wireplumber {
|
|
||||||
background-color: #202020;
|
|
||||||
border-radius: 20px;
|
|
||||||
padding: 8px 8px 8px 20px;
|
|
||||||
margin: 4px 0;
|
|
||||||
color: #f9e2af;
|
|
||||||
}
|
|
||||||
|
|
||||||
#wireplumber.muted {
|
|
||||||
color: #f38ba8;
|
|
||||||
}
|
|
||||||
|
|
||||||
#clock {
|
|
||||||
background-color: #202020;
|
|
||||||
border-radius: 20px;
|
|
||||||
padding: 8px 10px 10px 10px;
|
|
||||||
margin: 4px 0;
|
|
||||||
color: #94e2d5;
|
|
||||||
}
|
|
||||||
|
|
||||||
#network {
|
|
||||||
background-color: #202020;
|
|
||||||
color: #cdd6f4;
|
|
||||||
border-radius: 20px;
|
|
||||||
padding: 8px;
|
|
||||||
margin: 4px 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#network.disabled {
|
|
||||||
color: #f38ba8;
|
|
||||||
}
|
|
||||||
|
|
||||||
#tray {
|
|
||||||
background-color: #202020;
|
|
||||||
border-radius: 20px;
|
|
||||||
padding: 8px 12px 8px 12px;
|
|
||||||
margin: 4px 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#battery {
|
|
||||||
background-color: #202020;
|
|
||||||
color: #cdd6f4;
|
|
||||||
border-radius: 20px;
|
|
||||||
padding: 8px;
|
|
||||||
margin: 4px 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
#backlight {
|
|
||||||
background-color: #202020;
|
|
||||||
color: #cdd6f4;
|
|
||||||
border-radius: 20px;
|
|
||||||
padding: 8px;
|
|
||||||
margin: 4px 0;
|
|
||||||
}
|
|
||||||
@ -1,5 +1,6 @@
|
|||||||
{
|
{
|
||||||
config,
|
config,
|
||||||
|
inputs,
|
||||||
pkgs,
|
pkgs,
|
||||||
username,
|
username,
|
||||||
project,
|
project,
|
||||||
@ -7,31 +8,8 @@
|
|||||||
}: {
|
}: {
|
||||||
#To show logs of services run:
|
#To show logs of services run:
|
||||||
#journalctl --user-unit={service-name} --user
|
#journalctl --user-unit={service-name} --user
|
||||||
systemd.user.services.niri-waybar = {
|
|
||||||
description = "Waybar status bar for Niri";
|
|
||||||
|
|
||||||
# "wantedBy" replaces the [Install] section
|
# The Niri Session Cleanup Service
|
||||||
wantedBy = ["graphical-session.target"];
|
|
||||||
|
|
||||||
# "partOf" and "after" replace the [Unit] section dependencies
|
|
||||||
partOf = ["graphical-session.target"];
|
|
||||||
after = ["graphical-session.target"];
|
|
||||||
|
|
||||||
# [Unit] configuration goes here
|
|
||||||
unitConfig = {
|
|
||||||
# This checks the environment variable to ensure we are in Niri
|
|
||||||
ConditionEnvironment = "XDG_CURRENT_DESKTOP=niri";
|
|
||||||
};
|
|
||||||
|
|
||||||
# [Service] configuration goes here
|
|
||||||
serviceConfig = {
|
|
||||||
ExecStart = "${pkgs.waybar}/bin/waybar";
|
|
||||||
Restart = "on-failure";
|
|
||||||
RestartSec = "1s";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
# 2. The Niri Session Cleanup Service
|
|
||||||
# This service starts when the graphical session starts, and when it stops,
|
# This service starts when the graphical session starts, and when it stops,
|
||||||
# it forcibly stops the graphical-session.target to ensure a clean state for the next login.
|
# it forcibly stops the graphical-session.target to ensure a clean state for the next login.
|
||||||
systemd.user.services.niri-session-manager = {
|
systemd.user.services.niri-session-manager = {
|
||||||
|
|||||||
@ -2,12 +2,12 @@
|
|||||||
config,
|
config,
|
||||||
inputs,
|
inputs,
|
||||||
pkgs,
|
pkgs,
|
||||||
|
system,
|
||||||
...
|
...
|
||||||
}: {
|
}: {
|
||||||
imports = [
|
imports = [
|
||||||
./autostart.nix
|
./autostart.nix
|
||||||
../modules/hyprlock
|
../modules/hyprlock
|
||||||
../modules/hyprpaper
|
|
||||||
../modules/stylix
|
../modules/stylix
|
||||||
];
|
];
|
||||||
|
|
||||||
@ -16,10 +16,8 @@
|
|||||||
];
|
];
|
||||||
|
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
#mako
|
|
||||||
fuzzel
|
|
||||||
waybar
|
|
||||||
xwayland-satellite
|
xwayland-satellite
|
||||||
|
lxsession #Needed for things like gparted
|
||||||
];
|
];
|
||||||
|
|
||||||
programs = {
|
programs = {
|
||||||
@ -33,7 +31,6 @@
|
|||||||
#services.xserver.displayManager.sddm.enable = true;
|
#services.xserver.displayManager.sddm.enable = true;
|
||||||
|
|
||||||
xdg.portal = {
|
xdg.portal = {
|
||||||
#Needed for waybar
|
|
||||||
enable = true;
|
enable = true;
|
||||||
extraPortals = [pkgs.xdg-desktop-portal-gtk pkgs.xdg-desktop-portal-wlr];
|
extraPortals = [pkgs.xdg-desktop-portal-gtk pkgs.xdg-desktop-portal-wlr];
|
||||||
config.common.default = "*";
|
config.common.default = "*";
|
||||||
|
|||||||
@ -5,31 +5,13 @@
|
|||||||
}: {
|
}: {
|
||||||
imports = [
|
imports = [
|
||||||
inputs.niri.homeModules.niri
|
inputs.niri.homeModules.niri
|
||||||
../modules/waybar/home.nix
|
../modules/noctalia/home.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
xdg.configFile."mako/config".text = ''
|
|
||||||
default-timeout=5000
|
|
||||||
ignore-timeout=1
|
|
||||||
'';
|
|
||||||
|
|
||||||
programs.niri = {
|
programs.niri = {
|
||||||
package = pkgs.niri;
|
package = pkgs.niri;
|
||||||
enable = true;
|
enable = true;
|
||||||
#xwayland.enable = true;
|
|
||||||
# config = ''
|
|
||||||
# binds {
|
|
||||||
# Super+Return { spawn "kitty"; }
|
|
||||||
# Super+Space { spawn "fuzzel"; }
|
|
||||||
# Super+Q { close-window; }
|
|
||||||
# Super+Left { focus-column-left; }
|
|
||||||
# Super+Right { focus-column-right; }
|
|
||||||
# Super+Up { focus-workspace-up; }
|
|
||||||
# Super+Down { focus-workspace-down; }
|
|
||||||
# Super+L { spawn "hyprlock"; }
|
|
||||||
# Super+Shift+E { "quit"; }
|
|
||||||
# }
|
|
||||||
# '';
|
|
||||||
config = ''
|
config = ''
|
||||||
input {
|
input {
|
||||||
keyboard {
|
keyboard {
|
||||||
@ -38,6 +20,10 @@
|
|||||||
}
|
}
|
||||||
numlock
|
numlock
|
||||||
}
|
}
|
||||||
|
mouse {
|
||||||
|
accel-profile "flat"
|
||||||
|
accel-speed -0.4
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
prefer-no-csd
|
prefer-no-csd
|
||||||
@ -83,11 +69,8 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// spawn-at-startup "waybar"
|
spawn-at-startup "noctalia"
|
||||||
spawn-at-startup "hyprpaper"
|
spawn-at-startup "lxpolkit"
|
||||||
spawn-at-startup "${pkgs.mako}/bin/mako"
|
|
||||||
|
|
||||||
// spawn-sh-at-startup "qs -c ~/source/qs/MyAwesomeShell"
|
|
||||||
|
|
||||||
hotkey-overlay {
|
hotkey-overlay {
|
||||||
// Uncomment this line to disable the "Important Hotkeys" pop-up at startup.
|
// Uncomment this line to disable the "Important Hotkeys" pop-up at startup.
|
||||||
@ -102,6 +85,11 @@
|
|||||||
draw-border-with-background false
|
draw-border-with-background false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// layer-rule {
|
||||||
|
// match namespace="^awww-daemonbackdrop$"
|
||||||
|
// place-within-backdrop true
|
||||||
|
// }
|
||||||
|
|
||||||
output "eDP-1" {
|
output "eDP-1" {
|
||||||
mode "2880x1920@120.000"
|
mode "2880x1920@120.000"
|
||||||
scale 2
|
scale 2
|
||||||
@ -111,24 +99,26 @@
|
|||||||
binds {
|
binds {
|
||||||
Mod+Shift+Minus { show-hotkey-overlay; }
|
Mod+Shift+Minus { show-hotkey-overlay; }
|
||||||
|
|
||||||
|
Mod+Shift+S hotkey-overlay-title="Make a screenshot selection" { spawn-sh "noctalia msg screenshot-region";}
|
||||||
|
|
||||||
Mod+T hotkey-overlay-title="Open a Terminal: kitty" { spawn "kitty"; }
|
Mod+T hotkey-overlay-title="Open a Terminal: kitty" { spawn "kitty"; }
|
||||||
Mod+D hotkey-overlay-title="Run an Application: fuzzel" { spawn "fuzzel"; }
|
Mod+D hotkey-overlay-title="Run an Application" { spawn-sh "noctalia msg panel-toggle launcher"; }
|
||||||
Super+L hotkey-overlay-title="Lock the Screen: hyprlock" { spawn "hyprlock"; }
|
Super+L hotkey-overlay-title="Lock the Screen" { spawn-sh "noctalia msg session lock"; }
|
||||||
|
|
||||||
Super+Alt+S allow-when-locked=true hotkey-overlay-title=null { spawn-sh "pkill orca || exec orca"; }
|
Super+Alt+S allow-when-locked=true hotkey-overlay-title=null { spawn-sh "pkill orca || exec orca"; }
|
||||||
|
|
||||||
XF86AudioRaiseVolume allow-when-locked=true { spawn-sh "wpctl set-volume @DEFAULT_AUDIO_SINK@ 0.1+ -l 1.0"; }
|
XF86AudioRaiseVolume allow-when-locked=true { spawn-sh "noctalia msg volume-up"; }
|
||||||
XF86AudioLowerVolume allow-when-locked=true { spawn-sh "wpctl set-volume @DEFAULT_AUDIO_SINK@ 0.1-"; }
|
XF86AudioLowerVolume allow-when-locked=true { spawn-sh "noctalia msg volume-down"; }
|
||||||
XF86AudioMute allow-when-locked=true { spawn-sh "wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle"; }
|
XF86AudioMute allow-when-locked=true { spawn-sh "noctalia msg volume-mute"; }
|
||||||
XF86AudioMicMute allow-when-locked=true { spawn-sh "wpctl set-mute @DEFAULT_AUDIO_SOURCE@ toggle"; }
|
XF86AudioMicMute allow-when-locked=true { spawn-sh "noctalia msg mic-mute"; }
|
||||||
|
|
||||||
XF86AudioPlay allow-when-locked=true { spawn-sh "playerctl play-pause"; }
|
XF86AudioPlay allow-when-locked=true { spawn-sh "playerctl play-pause"; }
|
||||||
XF86AudioStop allow-when-locked=true { spawn-sh "playerctl stop"; }
|
XF86AudioStop allow-when-locked=true { spawn-sh "playerctl stop"; }
|
||||||
XF86AudioPrev allow-when-locked=true { spawn-sh "playerctl previous"; }
|
XF86AudioPrev allow-when-locked=true { spawn-sh "playerctl previous"; }
|
||||||
XF86AudioNext allow-when-locked=true { spawn-sh "playerctl next"; }
|
XF86AudioNext allow-when-locked=true { spawn-sh "playerctl next"; }
|
||||||
|
|
||||||
XF86MonBrightnessUp allow-when-locked=true { spawn "brightnessctl" "--class=backlight" "set" "+10%"; }
|
XF86MonBrightnessUp allow-when-locked=true { spawn-sh "noctalia msg brightness-up"; }
|
||||||
XF86MonBrightnessDown allow-when-locked=true { spawn "brightnessctl" "--class=backlight" "set" "10%-"; }
|
XF86MonBrightnessDown allow-when-locked=true { spawn-sh "noctalia msg brightness-down"; }
|
||||||
|
|
||||||
Mod+O repeat=false { toggle-overview; }
|
Mod+O repeat=false { toggle-overview; }
|
||||||
|
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 2.0 KiB |
|
Before Width: | Height: | Size: 18 KiB |
BIN
other/pfp.png
|
Before Width: | Height: | Size: 211 KiB |
@ -1,9 +0,0 @@
|
|||||||
mkdir -p /var/lib/AccountsService/{icons,users}
|
|
||||||
cp /home/cookiez/NixOS/other/pfp.png /var/lib/AccountsService/icons/cookiez
|
|
||||||
echo -e "[User]\nIcon=/var/lib/AccountsService/icons/cookiez\n" > /var/lib/AccountsService/users/cookiez
|
|
||||||
|
|
||||||
chown root:root /var/lib/AccountsService/users/cookiez
|
|
||||||
chmod 0600 /var/lib/AccountsService/users/cookiez
|
|
||||||
|
|
||||||
chown root:root /var/lib/AccountsService/icons/cookiez
|
|
||||||
chmod 0444 /var/lib/AccountsService/icons/cookiez
|
|
||||||
|
Before Width: | Height: | Size: 134 KiB |
|
Before Width: | Height: | Size: 2.8 MiB |
|
Before Width: | Height: | Size: 2.7 MiB |
|
Before Width: | Height: | Size: 3.1 MiB |
@ -12,10 +12,15 @@
|
|||||||
description = "Automatically start Yakuake";
|
description = "Automatically start Yakuake";
|
||||||
after = ["graphical-session.target"];
|
after = ["graphical-session.target"];
|
||||||
wantedBy = ["graphical-session.target"];
|
wantedBy = ["graphical-session.target"];
|
||||||
|
|
||||||
|
unitConfig = {
|
||||||
|
ConditionEnvironment = "XDG_CURRENT_DESKTOP=KDE";
|
||||||
|
};
|
||||||
|
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
ExecStart = ["${pkgs.kdePackages.yakuake}/bin/yakuake"];
|
ExecStart = ["${pkgs.kdePackages.yakuake}/bin/yakuake"];
|
||||||
|
|
||||||
Type = "oneshot";
|
Type = "simple";
|
||||||
Restart = "on-failure";
|
Restart = "on-failure";
|
||||||
RestartSec = "5s";
|
RestartSec = "5s";
|
||||||
Environment = "PATH=/run/current-system/sw/bin:/etc/profiles/per-user/$USER/bin";
|
Environment = "PATH=/run/current-system/sw/bin:/etc/profiles/per-user/$USER/bin";
|
||||||
@ -30,7 +35,7 @@
|
|||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
ExecStart = ["${pkgs.trayscale}/bin/trayscale --hide-window"];
|
ExecStart = ["${pkgs.trayscale}/bin/trayscale --hide-window"];
|
||||||
|
|
||||||
Type = "oneshot";
|
Type = "simple";
|
||||||
Restart = "on-failure";
|
Restart = "on-failure";
|
||||||
RestartSec = "5s";
|
RestartSec = "5s";
|
||||||
};
|
};
|
||||||
|
|||||||
@ -1,5 +1,6 @@
|
|||||||
{
|
{
|
||||||
config,
|
config,
|
||||||
|
inputs,
|
||||||
pkgs,
|
pkgs,
|
||||||
username,
|
username,
|
||||||
project,
|
project,
|
||||||
@ -8,13 +9,12 @@
|
|||||||
# Define the custom background package with the correct relative path
|
# Define the custom background package with the correct relative path
|
||||||
background-package = pkgs.stdenvNoCC.mkDerivation {
|
background-package = pkgs.stdenvNoCC.mkDerivation {
|
||||||
name = "background-image";
|
name = "background-image";
|
||||||
src = ../other/wallpaper4.png; # Place wallpaper.jpg in the same directory as this config file
|
src = "${inputs.cookiez-assets}/wallpapers/forest-cat.png"; # Place wallpaper.jpg in the same directory as this config file
|
||||||
dontUnpack = true;
|
dontUnpack = true;
|
||||||
installPhase = ''
|
installPhase = ''
|
||||||
cp $src $out
|
cp $src $out
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
plasmaTheme = "desktop"; #Possible values are "laptop" or "desktop"
|
plasmaTheme = "desktop"; #Possible values are "laptop" or "desktop"
|
||||||
powerProfile = "laptop"; #Possible values are "laptop" or "desktop"
|
powerProfile = "laptop"; #Possible values are "laptop" or "desktop"
|
||||||
in {
|
in {
|
||||||
@ -38,8 +38,6 @@ in {
|
|||||||
"sddm".serviceConfig.KillMode = "mixed";
|
"sddm".serviceConfig.KillMode = "mixed";
|
||||||
};
|
};
|
||||||
|
|
||||||
programs.gamemode.enable = true;
|
|
||||||
|
|
||||||
services = {
|
services = {
|
||||||
xserver = {
|
xserver = {
|
||||||
enable = true;
|
enable = true;
|
||||||
@ -74,7 +72,6 @@ in {
|
|||||||
|
|
||||||
system.activationScripts.script.text = ''
|
system.activationScripts.script.text = ''
|
||||||
source /home/${username}/${project}/other/colors.sh
|
source /home/${username}/${project}/other/colors.sh
|
||||||
source /home/${username}/${project}/other/pfp.sh
|
|
||||||
'';
|
'';
|
||||||
|
|
||||||
environment = {
|
environment = {
|
||||||
|
|||||||
@ -14,4 +14,7 @@
|
|||||||
]
|
]
|
||||||
++ lib.optionals (plasmaTheme == "laptop") [./settings/laptop.nix]
|
++ lib.optionals (plasmaTheme == "laptop") [./settings/laptop.nix]
|
||||||
++ lib.optionals (plasmaTheme == "desktop") [./settings/desktop.nix];
|
++ lib.optionals (plasmaTheme == "desktop") [./settings/desktop.nix];
|
||||||
|
|
||||||
|
#Add the wallpapers to be available to KDE wallpaper settings page
|
||||||
|
xdg.dataFile."wallpapers/cookiez".source = "${inputs.cookiez-assets}/wallpapers";
|
||||||
}
|
}
|
||||||
|
|||||||
@ -123,7 +123,7 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
configFile = {
|
configFile = {
|
||||||
plasmarc.Wallpapers.usersWallpapers = "/home/cookiez/NixOS/other/wallpaper1.png";
|
plasmarc.Wallpapers.usersWallpapers = "${inputs.cookiez-assets}/wallpapers/pixel-desert.png";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|||||||
@ -8,8 +8,8 @@
|
|||||||
}: let
|
}: let
|
||||||
profiles = {
|
profiles = {
|
||||||
laptop = {
|
laptop = {
|
||||||
AC.powerProfile = "powerSaving";
|
AC.powerProfile = null; #Set to null so it doesnt change on plugging it in.
|
||||||
battery.powerProfile = "powerSaving";
|
battery.powerProfile = null;
|
||||||
lowBattery.powerProfile = "powerSaving";
|
lowBattery.powerProfile = "powerSaving";
|
||||||
};
|
};
|
||||||
desktop = {
|
desktop = {
|
||||||
|
|||||||