nixpkgs/pkgs/development/python-modules/mkdocs/default.nix
2023-01-05 01:10:14 +01:00

89 lines
1.7 KiB
Nix

{
# eval time deps
lib
, buildPythonPackage
, fetchFromGitHub
, pythonOlder
# buildtime
, hatchling
# runtime deps
, click
, ghp-import
, importlib-metadata
, jinja2
, markdown
, mergedeep
, packaging
, pyyaml
, pyyaml-env-tag
, watchdog
# testing deps
, babel
, mock
, unittestCheckHook
}:
buildPythonPackage rec {
pname = "mkdocs";
version = "1.4.2";
format = "pyproject";
disabled = pythonOlder "3.6";
src = fetchFromGitHub {
owner = pname;
repo = pname;
rev = "refs/tags/${version}";
hash = "sha256-/NxiKbCd2acYcNe5ww3voM9SGVE2IDqknngqApkDbNs=";
};
postPatch = ''
substituteInPlace pyproject.toml \
--replace "Markdown >=3.2.1, <3.4" "Markdown"
'';
nativeBuildInputs = [
hatchling
];
propagatedBuildInputs = [
click
jinja2
markdown
mergedeep
pyyaml
pyyaml-env-tag
ghp-import
importlib-metadata
watchdog
packaging
];
checkInputs = [
unittestCheckHook
babel
mock
];
unittestFlagsArray = [ "-v" "-p" "'*tests.py'" "mkdocs" ];
pythonImportsCheck = [ "mkdocs" ];
meta = with lib; {
description = "Project documentation with Markdown / static website generator";
longDescription = ''
MkDocs is a fast, simple and downright gorgeous static site generator that's
geared towards building project documentation. Documentation source files
are written in Markdown, and configured with a single YAML configuration file.
MkDocs can also be used to generate general-purpose websites.
'';
homepage = "http://mkdocs.org/";
license = licenses.bsd2;
platforms = platforms.unix;
maintainers = with maintainers; [ rkoe ];
};
}