Compare commits
1 Commits
Author | SHA1 | Date | |
---|---|---|---|
b3ecef1dcc |
@ -1,16 +1,12 @@
|
|||||||
{ stdenv, lib, hugo, fetchgit, pkgs, nodejs, ruby }:
|
{ blog-source, blog-source-localized, stdenv, lib, hugo, fetchgit, pkgs, nodejs, ruby }:
|
||||||
|
|
||||||
let
|
let
|
||||||
url = "https://dev.danilafe.com/Web-Projects/blog-static.git";
|
url = "https://dev.danilafe.com/Web-Projects/blog-static.git";
|
||||||
requiredPackages = import ./required-packages.nix { inherit pkgs nodejs; };
|
requiredPackages = import ./required-packages.nix { inherit pkgs nodejs; };
|
||||||
website = settings: stdenv.mkDerivation {
|
website = settings: stdenv.mkDerivation {
|
||||||
name = "blog-static";
|
name = "blog-static";
|
||||||
version = settings.rev;
|
version = settings.source.rev;
|
||||||
src = fetchgit {
|
src = settings.source;
|
||||||
inherit url;
|
|
||||||
inherit (settings) rev sha256;
|
|
||||||
fetchSubmodules = true;
|
|
||||||
};
|
|
||||||
urlSub =
|
urlSub =
|
||||||
let
|
let
|
||||||
regexEscape = lib.escape [ "/" "(" ")" "[" "]" "+" "*" "\\" ];
|
regexEscape = lib.escape [ "/" "(" ")" "[" "]" "+" "*" "\\" ];
|
||||||
@ -29,20 +25,20 @@ let
|
|||||||
(ruby.withPackages (ps: [ ps.nokogiri ]))
|
(ruby.withPackages (ps: [ ps.nokogiri ]))
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
rev = "b3ff2fe135fd57a646d5d3271db64886d745ff8c";
|
rev = "60eb50737d535e8ec506b877250d0e4bbfbf1bda";
|
||||||
sha256 = "1nljx2wsc25fciwc5ixmwvf8sx4v9n9brx37dhlr4knsadcp89jy";
|
sha256 = "1xyppzim3kvawr1bkizwmkbgvb4pxhgnc7gxwjv8sdfcyvbfgz8p";
|
||||||
localizationRev = "0b5748cc5a19b5d1d78bfcfa58d4027cc10524dd";
|
localizationRev = "0b5748cc5a19b5d1d78bfcfa58d4027cc10524dd";
|
||||||
localizationSha256 = "12pqh534z3ppvgzy0a77s9j1qzzmiyxwvlmh5y76pccf32wvi9wz";
|
localizationSha256 = "12pqh534z3ppvgzy0a77s9j1qzzmiyxwvlmh5y76pccf32wvi9wz";
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
english = website {
|
english = website {
|
||||||
inherit rev sha256;
|
source = blog-source;
|
||||||
path = ".";
|
path = ".";
|
||||||
drafts = false;
|
drafts = false;
|
||||||
};
|
};
|
||||||
drafts = {
|
drafts = {
|
||||||
english = website {
|
english = website {
|
||||||
inherit rev sha256;
|
source = blog-source;
|
||||||
path = ".";
|
path = ".";
|
||||||
drafts = true;
|
drafts = true;
|
||||||
replaceUrl = {
|
replaceUrl = {
|
||||||
@ -51,8 +47,7 @@ in
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
russian = website {
|
russian = website {
|
||||||
rev = localizationRev;
|
source = blog-source-localized;
|
||||||
sha256 = localizationSha256;
|
|
||||||
path = "ru";
|
path = "ru";
|
||||||
drafts = true;
|
drafts = true;
|
||||||
replaceUrl = {
|
replaceUrl = {
|
||||||
|
@ -1 +1 @@
|
|||||||
nix-prefetch-git --rev refs/heads/master https://dev.danilafe.com/Web-Projects/blog-static.git --quiet --fetch-submodules | jq '.rev,.sha256' | xargs ./change_blog_nix.sh
|
nix-prefetch-git --rev refs/heads/master https://dev.danilafe.com/Web-Projects/blog-static.git --quiet | jq '.rev,.sha256' | xargs ./change_blog_nix.sh
|
||||||
|
49
flake.nix
Normal file
49
flake.nix
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
{
|
||||||
|
inputs = {
|
||||||
|
nixpkgs.url = "github:nixos/nixpkgs";
|
||||||
|
flake-utils.url = "github:numtide/flake-utils";
|
||||||
|
blog-source = {
|
||||||
|
flake = false;
|
||||||
|
url = "https://dev.danilafe.com/Web-Projects/blog-static.git";
|
||||||
|
type = "git";
|
||||||
|
submodules = true;
|
||||||
|
};
|
||||||
|
blog-source-localized = {
|
||||||
|
flake = false;
|
||||||
|
url = "https://dev.danilafe.com/Web-Projects/blog-static.git";
|
||||||
|
ref = "localization";
|
||||||
|
type = "git";
|
||||||
|
submodules = true;
|
||||||
|
};
|
||||||
|
pegasus-source = {
|
||||||
|
url = "github:DanilaFe/pegasus";
|
||||||
|
flake = false;
|
||||||
|
};
|
||||||
|
pupper-bot-source = {
|
||||||
|
url = "git+https://dev.danilafe.com/Crystal-Bots/joann-pupper-bot";
|
||||||
|
flake = false;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
outputs = { self, pupper-bot-source, pegasus-source, blog-source, blog-source-localized, nixpkgs, flake-utils }:
|
||||||
|
flake-utils.lib.eachDefaultSystem
|
||||||
|
(system:
|
||||||
|
let
|
||||||
|
pkgs = import nixpkgs { inherit system; };
|
||||||
|
pegasus = pkgs.callPackage ./pegasus/default.nix {
|
||||||
|
inherit pegasus-source;
|
||||||
|
};
|
||||||
|
blog = pkgs.callPackage ./blog/default.nix {
|
||||||
|
inherit blog-source blog-source-localized;
|
||||||
|
};
|
||||||
|
in
|
||||||
|
{
|
||||||
|
packages = {
|
||||||
|
inherit pegasus;
|
||||||
|
blogEnglish = blog.english;
|
||||||
|
blogEnglishDrafts = blog.drafts.english;
|
||||||
|
blogRussianDrafts = blog.drafts.russian;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
@ -1,18 +1,12 @@
|
|||||||
{ stdenv, crystal, fetchFromGitHub }:
|
{ pegasus-source, stdenv, crystal, fetchFromGitHub }:
|
||||||
|
|
||||||
let
|
|
||||||
version = "0489d47b191ecf8501787355b948801506e7c70f";
|
|
||||||
src = fetchFromGitHub {
|
|
||||||
owner = "DanilaFe";
|
|
||||||
repo = "pegasus";
|
|
||||||
rev = version;
|
|
||||||
sha256 = "097m7l16byis07xlg97wn5hdsz9k6c3h1ybzd2i7xhkj24kx230s";
|
|
||||||
};
|
|
||||||
in
|
|
||||||
crystal.buildCrystalPackage {
|
crystal.buildCrystalPackage {
|
||||||
pname = "pegasus";
|
pname = "pegasus";
|
||||||
inherit version;
|
src = pegasus-source;
|
||||||
inherit src;
|
version = pegasus-source.rev;
|
||||||
|
format = "crystal";
|
||||||
|
|
||||||
|
# Programs don't do so well when running --help
|
||||||
|
installCheckPhase = "";
|
||||||
|
|
||||||
crystalBinaries.pegasus.src = "src/pegasus.cr";
|
crystalBinaries.pegasus.src = "src/pegasus.cr";
|
||||||
crystalBinaries.pegasus-dot.src = "src/tools/dot/pegasus_dot.cr";
|
crystalBinaries.pegasus-dot.src = "src/tools/dot/pegasus_dot.cr";
|
||||||
|
Reference in New Issue
Block a user