build(nix): format nix files, fix git lfs error

This commit is contained in:
Yusuf Bera Ertan 2022-04-28 20:35:27 +03:00
parent b9586673d5
commit a0b7446f58
No known key found for this signature in database
GPG Key ID: 1D8F8FAF2294D6EA
4 changed files with 121 additions and 99 deletions

View File

@ -11,17 +11,18 @@
app = "veloren-voxygen"; app = "veloren-voxygen";
}; };
overrides = { overrides = {
crates = common: prev: crates = common: prev: let
let
pkgs = common.pkgs; pkgs = common.pkgs;
lib = common.lib; lib = common.lib;
gitLfsCheckFile = ./assets/voxygen/background/bg_main.jpg; gitLfsCheckFile = ./assets/voxygen/background/bg_main.jpg;
utils = import ./nix/utils.nix { inherit pkgs; }; utils = import ./nix/utils.nix {inherit pkgs;};
sourceInfo = sourceInfo =
if inputs.self.sourceInfo ? rev if inputs.self.sourceInfo ? rev
then inputs.self.sourceInfo // { then
inputs.self.sourceInfo
// {
# Tag would have to be set manually for stable releases flake # Tag would have to be set manually for stable releases flake
# because there's currently no way to get the tag via the interface. # because there's currently no way to get the tag via the interface.
# tag = v0.9.0; # tag = v0.9.0;
@ -40,16 +41,17 @@
# have it the build fails. # have it the build fails.
# Must be in format f4987672/2020-12-10-12:00 # Must be in format f4987672/2020-12-10-12:00
version = version =
if tag != "" then tag if tag != ""
else if prettyRev != "" then prettyRev then tag
else if prettyRev != ""
then prettyRev
else throw "Need a tag or pretty revision in order to determine version"; else throw "Need a tag or pretty revision in order to determine version";
veloren-assets = pkgs.runCommand "makeAssetsDir" { } '' veloren-assets = pkgs.runCommand "makeAssetsDir" {} ''
mkdir $out mkdir $out
ln -sf ${./assets} $out/assets ln -sf ${./assets} $out/assets
''; '';
in in {
{
veloren-common = oldAttrs: { veloren-common = oldAttrs: {
# Disable `git-lfs` check here since we check it ourselves # Disable `git-lfs` check here since we check it ourselves
# We have to include the command output here, otherwise Nix won't run it # We have to include the command output here, otherwise Nix won't run it
@ -59,7 +61,7 @@
NIX_GIT_TAG = tag; NIX_GIT_TAG = tag;
}; };
veloren-voxygen = oldAttrs: { veloren-voxygen = oldAttrs: {
nativeBuildInputs = (oldAttrs.nativeBuildInputs or []) ++ [ pkgs.makeWrapper ]; nativeBuildInputs = (oldAttrs.nativeBuildInputs or []) ++ [pkgs.makeWrapper];
VELOREN_USERDATA_STRATEGY = "system"; VELOREN_USERDATA_STRATEGY = "system";
preConfigure = '' preConfigure = ''
substituteInPlace src/audio/soundcache.rs \ substituteInPlace src/audio/soundcache.rs \
@ -76,7 +78,7 @@
''; '';
}; };
veloren-server-cli = oldAttrs: { veloren-server-cli = oldAttrs: {
nativeBuildInputs = (oldAttrs.nativeBuildInputs or []) ++ [ pkgs.makeWrapper ]; nativeBuildInputs = (oldAttrs.nativeBuildInputs or []) ++ [pkgs.makeWrapper];
VELOREN_USERDATA_STRATEGY = "system"; VELOREN_USERDATA_STRATEGY = "system";
postInstall = '' postInstall = ''
if [ -f $out/bin/veloren-server-cli ]; then if [ -f $out/bin/veloren-server-cli ]; then

View File

@ -3,4 +3,5 @@
url = "https://github.com/edolstra/flake-compat/archive/99f1c2157fba4bfe6211a321fd0ee43199025dbf.tar.gz"; url = "https://github.com/edolstra/flake-compat/archive/99f1c2157fba4bfe6211a321fd0ee43199025dbf.tar.gz";
sha256 = "sha256:0x2jn3vrawwv9xp15674wjz9pixwjyj3j771izayl962zziivbx2"; sha256 = "sha256:0x2jn3vrawwv9xp15674wjz9pixwjyj3j771izayl962zziivbx2";
}) })
{ src = ../.; }).defaultNix {src = ../.;})
.defaultNix

View File

@ -3,4 +3,5 @@
url = "https://github.com/edolstra/flake-compat/archive/99f1c2157fba4bfe6211a321fd0ee43199025dbf.tar.gz"; url = "https://github.com/edolstra/flake-compat/archive/99f1c2157fba4bfe6211a321fd0ee43199025dbf.tar.gz";
sha256 = "sha256:0x2jn3vrawwv9xp15674wjz9pixwjyj3j771izayl962zziivbx2"; sha256 = "sha256:0x2jn3vrawwv9xp15674wjz9pixwjyj3j771izayl962zziivbx2";
}) })
{ src = ../.; }).shellNix {src = ../.;})
.shellNix

View File

@ -1,15 +1,14 @@
{ pkgs }: { {pkgs}: {
isGitLfsSetup = checkFile: isGitLfsSetup = checkFile: let
let gitLfsCheckOutput = builtins.readFile (pkgs.runCommand "gitLfsCheck" {} ''
gitLfsCheckOutput = result="$(${pkgs.file}/bin/file --mime-type ${checkFile})"
builtins.readFile (pkgs.runCommand "gitLfsCheck" { } '' (if [ "$result" = "${checkFile}: image/jpeg" ]; then printf "0"; else printf "1"; fi) > $out
([ "$(${pkgs.file}/bin/file --mime-type ${checkFile})" = "${checkFile}: image/jpeg" ] && printf "0" || printf "1") > $out
''); '');
in in
if gitLfsCheckOutput == "0" then if gitLfsCheckOutput == "0"
true then true
else else
abort '' throw ''
Git Large File Storage (`git-lfs`) has not been set up correctly. Git Large File Storage (`git-lfs`) has not been set up correctly.
Most common reasons: Most common reasons:
- `git-lfs` was not installed before cloning this repository. - `git-lfs` was not installed before cloning this repository.
@ -21,8 +20,7 @@
''; '';
# Format number of seconds in the Unix epoch as %Y-%m-%d-%H:%M. # Format number of seconds in the Unix epoch as %Y-%m-%d-%H:%M.
dateTimeFormat = t: dateTimeFormat = t: let
let
rem = x: y: x - x / y * y; rem = x: y: x - x / y * y;
days = t / 86400; days = t / 86400;
secondsInDay = rem t 86400; secondsInDay = rem t 86400;
@ -32,17 +30,37 @@
# Courtesy of https://stackoverflow.com/a/32158604. # Courtesy of https://stackoverflow.com/a/32158604.
z = days + 719468; z = days + 719468;
era = (if z >= 0 then z else z - 146096) / 146097; era =
(
if z >= 0
then z
else z - 146096
)
/ 146097;
doe = z - era * 146097; doe = z - era * 146097;
yoe = (doe - doe / 1460 + doe / 36524 - doe / 146096) / 365; yoe = (doe - doe / 1460 + doe / 36524 - doe / 146096) / 365;
y = yoe + era * 400; y = yoe + era * 400;
doy = doe - (365 * yoe + yoe / 4 - yoe / 100); doy = doe - (365 * yoe + yoe / 4 - yoe / 100);
mp = (5 * doy + 2) / 153; mp = (5 * doy + 2) / 153;
d = doy - (153 * mp + 2) / 5 + 1; d = doy - (153 * mp + 2) / 5 + 1;
m = mp + (if mp < 10 then 3 else -9); m =
y' = y + (if m <= 2 then 1 else 0); mp
+ (
if mp < 10
then 3
else -9
);
y' =
y
+ (
if m <= 2
then 1
else 0
);
pad = s: if builtins.stringLength s < 2 then "0" + s else s; pad = s:
in if builtins.stringLength s < 2
"${toString y'}-${pad (toString m)}-${pad (toString d)}-${pad (toString hours)}:${pad (toString minutes)}"; then "0" + s
else s;
in "${toString y'}-${pad (toString m)}-${pad (toString d)}-${pad (toString hours)}:${pad (toString minutes)}";
} }