120 lines
3.9 KiB
Nix
120 lines
3.9 KiB
Nix
{ lib, stdenv
|
|
, cmake
|
|
, fetchurl
|
|
, git
|
|
, makeWrapper
|
|
, fetchFromGitHub
|
|
, dpkg
|
|
, glib
|
|
, gnutar
|
|
, gtk3-x11
|
|
, luajit
|
|
, sdcv
|
|
, SDL2
|
|
}:
|
|
let
|
|
luajit_lua52 = luajit.override { enable52Compat = true; };
|
|
in
|
|
stdenv.mkDerivation rec {
|
|
pname = "koreader-from-src";
|
|
version = "2023.06";
|
|
srcs = [
|
|
(fetchFromGitHub {
|
|
owner = "koreader";
|
|
repo = "koreader";
|
|
fetchSubmodules = true;
|
|
rev = "d350418367ddf39d752d05e0587e562d7d4af2c4"; # master
|
|
hash = "sha256-ri5ckf21xDKf/X0p2c9wePTa6jh5u0BoUwpVdgpYpZw=";
|
|
# rev = "v${version}";
|
|
# hash = "sha256-gdf7AUTpIJ6T4H915YqRG1WzxYHrGmzX6X4dMriWzRA=";
|
|
name = "koreader";
|
|
})
|
|
(fetchFromGitHub {
|
|
repo = "LuaJIT";
|
|
owner = "LuaJIT";
|
|
rev = "8635cbabf3094c4d8bd00578c7d812bea87bb2d3";
|
|
hash = "sha256-os10rjBacalpDw2TkF/LEFL6xiQJkWCr+yqrY6XgSZo=";
|
|
# rev = "224129a8e64bfa219d35cd03055bf03952f167f6";
|
|
# hash = "sha256-ZxGRpUO9NYjC2fL0P24FOxui27xSvN4TA8r9Gukvfn8=";
|
|
name = "thirdparty-luajit";
|
|
leaveDotGit = true; # maybe not needed, but we'd need another way to query the rev during build process below
|
|
deepClone = true; # probably not needed
|
|
})
|
|
];
|
|
|
|
sourceRoot = "koreader";
|
|
|
|
nativeBuildInputs = [
|
|
cmake
|
|
dpkg
|
|
git
|
|
makeWrapper
|
|
# luajit_lua52.pkgs.luarocks
|
|
];
|
|
buildInputs = [
|
|
glib
|
|
gnutar
|
|
gtk3-x11
|
|
luajit_lua52
|
|
sdcv
|
|
SDL2
|
|
];
|
|
|
|
dontConfigure = true;
|
|
buildPhase = ''
|
|
for l in $(ls .. | grep thirdparty- | sed 's/thirdparty-//')
|
|
do
|
|
lib_src="../thirdparty-$l"
|
|
|
|
# link the nix clone into the directory koreader would use for checkout
|
|
# ref="base/thirdparty/$l/build/git_checkout"
|
|
# echo "linking thirdparty library $l $ref -> $deref"
|
|
# mkdir -p "$ref"
|
|
# ln -s "$deref" "$ref/$l"
|
|
# mv "$deref" "$ref/$l"
|
|
# cp -R "$deref" "$ref/$l"
|
|
# needs to be writable for koreader to checkout it specific revision
|
|
# chmod u+w -R "$ref/$l/.git"
|
|
|
|
# koreader wants to clone each library into this git_checkout dir,
|
|
# then checkout a specific revision,
|
|
# and then copy that checkout into the build/working directory further down.
|
|
# instead, we replicate that effect here, and by creating these "stamp" files
|
|
# koreader will know to skip the `git clone` and `git checkout` calls.
|
|
# the logic we're spoofing lives in koreader/base/thirdparty/cmake_modules/koreader_thirdparty_git.cmake
|
|
stamp_dir="base/thirdparty/$l/build/x86_64-unknown-linux-gnu/git_checkout/stamp"
|
|
rev=$(cat "$lib_src/.git/shallow")
|
|
echo "creating stamp in $stamp_dir for rev $rev"
|
|
mkdir -p "$stamp_dir"
|
|
# koreader-base decides whether to redo the git checkout based on a timestamp compare of these two stamp files
|
|
touch -d "last week" "$stamp_dir/$l-gitinfo-$rev.txt"
|
|
touch -d "next week" "$stamp_dir/$l-gitclone-lastrun.txt"
|
|
|
|
# koreader would copy the checkout into this build/working directory,
|
|
# but because we spoof the stamps to work around other git errors,
|
|
# copy it there on koreader's behalf
|
|
prefix="base/thirdparty/$l/build/x86_64-unknown-linux-gnu/$l-prefix"
|
|
mkdir -p "$prefix/src"
|
|
cp -R "$lib_src" "$prefix/src/$l"
|
|
# src dir needs to be writable for koreader to apply its own patches
|
|
chmod u+w -R "$prefix/src/$l"
|
|
done
|
|
|
|
make TARGET=debian DEBIAN=1 INSTALL_DIR="$out" SHELL=sh VERBOSE=1
|
|
'';
|
|
|
|
installPhase = ''
|
|
make TARGET=debian DEBIAN=1 INSTALL_DIR="$out" update
|
|
'';
|
|
|
|
meta = with lib; {
|
|
homepage = "https://github.com/koreader/koreader";
|
|
description =
|
|
"An ebook reader application supporting PDF, DjVu, EPUB, FB2 and many more formats, running on Cervantes, Kindle, Kobo, PocketBook and Android devices";
|
|
sourceProvenance = with sourceTypes; [ fromSource ];
|
|
platforms = platforms.linux;
|
|
license = licenses.agpl3Only;
|
|
maintainers = with maintainers; [ colinsane contrun neonfuz];
|
|
};
|
|
}
|