nginx-doc-unstable: init at 2022-05-05
Build documentation of nginx (which is maintained separately from webserver itself) and make it available both as "nginx-doc" attribute and as "doc" output of "nginx" derivation.
This commit is contained in:
parent
c92ef7a135
commit
aa9eb4509c
40
pkgs/data/documentation/nginx-doc/default.nix
Normal file
40
pkgs/data/documentation/nginx-doc/default.nix
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
{ lib, stdenv, libxml2, libxslt, fetchhg }:
|
||||||
|
|
||||||
|
# Upstream maintains documentation (sources of https://nginx.org) in separate
|
||||||
|
# mercurial repository, which do not correspond to particular git commit, but at
|
||||||
|
# least has "introduced in version X.Y" comments.
|
||||||
|
#
|
||||||
|
# In other words, documentation does not necessary matches capabilities of
|
||||||
|
# $out/bin/nginx, but we have no better options.
|
||||||
|
stdenv.mkDerivation {
|
||||||
|
pname = "nginx-doc-unstable";
|
||||||
|
version = "2022-05-05";
|
||||||
|
src = fetchhg {
|
||||||
|
url = "https://hg.nginx.org/nginx.org";
|
||||||
|
rev = "a3aee2697d4e";
|
||||||
|
sha256 = "029n4mnmjw94h01qalmjgf1c2h3h7wm798xv5knk3padxiy4m28b";
|
||||||
|
};
|
||||||
|
patches = [ ./exclude-google-analytics.patch ];
|
||||||
|
nativeBuildInputs = [ libxslt libxml2 ];
|
||||||
|
|
||||||
|
# Generated documentation is not local-friendly, since it assumes that link to directory
|
||||||
|
# is the same as link to index.html in that directory, which is not how browsers behave
|
||||||
|
# with local filesystem.
|
||||||
|
#
|
||||||
|
# TODO: patch all relative links that do not end with .html.
|
||||||
|
|
||||||
|
# /en subdirectory must exist, relative links expect it.
|
||||||
|
installPhase = ''
|
||||||
|
mkdir -p $out/share/doc/nginx
|
||||||
|
mv libxslt/en $out/share/doc/nginx
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "A reverse proxy and lightweight webserver (documentation)";
|
||||||
|
homepage = "https://nginx.org/";
|
||||||
|
license = licenses.bsd2;
|
||||||
|
platforms = platforms.all;
|
||||||
|
priority = 6;
|
||||||
|
maintainers = with maintainers; [ kaction ];
|
||||||
|
};
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
{ lib, stdenv, fetchurl, fetchpatch, openssl, zlib, pcre, libxml2, libxslt
|
outer@{ lib, stdenv, fetchurl, fetchpatch, openssl, zlib, pcre, libxml2, libxslt
|
||||||
, fetchhg
|
, nginx-doc
|
||||||
|
|
||||||
, nixosTests
|
, nixosTests
|
||||||
, substituteAll, gd, geoip, perl
|
, substituteAll, gd, geoip, perl
|
||||||
@ -17,19 +17,6 @@
|
|||||||
, nginxVersion ? version
|
, nginxVersion ? version
|
||||||
, src ? null # defaults to upstream nginx ${version}
|
, src ? null # defaults to upstream nginx ${version}
|
||||||
, sha256 ? null # when not specifying src
|
, sha256 ? null # when not specifying src
|
||||||
|
|
||||||
# Upstream maintains documentation (sources of https://nginx.org) in separate
|
|
||||||
# mercurial repository, which do not correspond to particular git commit, but at
|
|
||||||
# least has "introduced in version X.Y" comments.
|
|
||||||
#
|
|
||||||
# In other words, documentation does not necessary matches capabilities of
|
|
||||||
# $out/bin/nginx, but we have no better options.
|
|
||||||
, srcDoc ? fetchhg {
|
|
||||||
url = "https://hg.nginx.org/nginx.org";
|
|
||||||
sha256 = "029n4mnmjw94h01qalmjgf1c2h3h7wm798xv5knk3padxiy4m28b";
|
|
||||||
rev = "a3aee2697d4e";
|
|
||||||
}
|
|
||||||
, extraPatchesDoc ? [ ./nginx-doc.patch ]
|
|
||||||
, configureFlags ? []
|
, configureFlags ? []
|
||||||
, buildInputs ? []
|
, buildInputs ? []
|
||||||
, extraPatches ? []
|
, extraPatches ? []
|
||||||
@ -52,31 +39,6 @@ let
|
|||||||
if supports nginxVersion then mod.${attrPath} or []
|
if supports nginxVersion then mod.${attrPath} or []
|
||||||
else throw "Module at ${toString mod.src} does not support nginx version ${nginxVersion}!");
|
else throw "Module at ${toString mod.src} does not support nginx version ${nginxVersion}!");
|
||||||
|
|
||||||
# Output of this derivation is copied into $doc of resulting nginx to save on
|
|
||||||
# building time, since we have multiple nginx versions, but only one version
|
|
||||||
# of documentation.
|
|
||||||
#
|
|
||||||
# As such, this derivation never appears in user profile, so its name and
|
|
||||||
# compliance to conventions is not important.
|
|
||||||
documentation = stdenv.mkDerivation {
|
|
||||||
name = "nginx-doc";
|
|
||||||
src = srcDoc;
|
|
||||||
patches = extraPatchesDoc;
|
|
||||||
nativeBuildInputs = [ libxslt libxml2 ];
|
|
||||||
|
|
||||||
# Generated documentation is not local-friendly, since it assumes that link to directory
|
|
||||||
# is the same as link to index.html in that directory, which is not how browsers behave
|
|
||||||
# with local filesystem.
|
|
||||||
#
|
|
||||||
# TODO: patch all relative links that do not end with .html.
|
|
||||||
|
|
||||||
# /en subdirectory must exist, relative links expect it.
|
|
||||||
installPhase = ''
|
|
||||||
mkdir -p $out/share/doc/nginx
|
|
||||||
mv libxslt/en $out/share/doc/nginx
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
in
|
in
|
||||||
|
|
||||||
stdenv.mkDerivation {
|
stdenv.mkDerivation {
|
||||||
@ -193,7 +155,7 @@ stdenv.mkDerivation {
|
|||||||
|
|
||||||
preInstall = ''
|
preInstall = ''
|
||||||
mkdir -p $doc
|
mkdir -p $doc
|
||||||
cp -r ${documentation}/* $doc
|
cp -r ${nginx-doc}/* $doc
|
||||||
'';
|
'';
|
||||||
|
|
||||||
postInstall = if postInstall != null then postInstall else ''
|
postInstall = if postInstall != null then postInstall else ''
|
||||||
|
@ -21984,6 +21984,8 @@ with pkgs;
|
|||||||
|
|
||||||
nginx = nginxStable;
|
nginx = nginxStable;
|
||||||
|
|
||||||
|
nginx-doc = callPackage ../data/documentation/nginx-doc { };
|
||||||
|
|
||||||
nginxQuic = callPackage ../servers/http/nginx/quic.nix {
|
nginxQuic = callPackage ../servers/http/nginx/quic.nix {
|
||||||
zlib = zlib-ng.override { withZlibCompat = true; };
|
zlib = zlib-ng.override { withZlibCompat = true; };
|
||||||
withPerl = false;
|
withPerl = false;
|
||||||
|
Loading…
Reference in New Issue
Block a user