diff --git a/doc/doc-support/default.nix b/doc/doc-support/default.nix
index e9cb96e37fdd..bea3e12a70b3 100644
--- a/doc/doc-support/default.nix
+++ b/doc/doc-support/default.nix
@@ -75,7 +75,7 @@ in pkgs.runCommand "doc-support" {}
ln -s ${epub-xsl} ./epub.xsl
ln -s ${xhtml-xsl} ./xhtml.xsl
- ln -s ${../../nixos/doc/xmlformat.conf} ./xmlformat.conf
+ ln -s ${./xmlformat.conf} ./xmlformat.conf
ln -s ${pkgs.documentation-highlighter} ./highlightjs
echo -n "${version}" > ./version
diff --git a/nixos/doc/xmlformat.conf b/doc/doc-support/xmlformat.conf
similarity index 100%
rename from nixos/doc/xmlformat.conf
rename to doc/doc-support/xmlformat.conf
diff --git a/maintainers/maintainer-list.nix b/maintainers/maintainer-list.nix
index 36762361d104..04658beb7f81 100644
--- a/maintainers/maintainer-list.nix
+++ b/maintainers/maintainer-list.nix
@@ -3762,12 +3762,6 @@
githubId = 14034137;
name = "Mostly Void";
};
- dizfer = {
- email = "david@izquierdofernandez.com";
- github = "DIzFer";
- githubId = 8852888;
- name = "David Izquierdo";
- };
djacu = {
email = "daniel.n.baker@gmail.com";
github = "djacu";
diff --git a/nixos/doc/manual/.gitignore b/nixos/doc/manual/.gitignore
deleted file mode 100644
index 879282624217..000000000000
--- a/nixos/doc/manual/.gitignore
+++ /dev/null
@@ -1,2 +0,0 @@
-generated
-manual-combined.xml
diff --git a/nixos/doc/manual/Makefile b/nixos/doc/manual/Makefile
deleted file mode 100644
index b2b6481b20c7..000000000000
--- a/nixos/doc/manual/Makefile
+++ /dev/null
@@ -1,30 +0,0 @@
-.PHONY: all
-all: manual-combined.xml
-
-.PHONY: debug
-debug: generated manual-combined.xml
-
-manual-combined.xml: generated *.xml **/*.xml
- rm -f ./manual-combined.xml
- nix-shell --pure -Q --packages xmloscopy \
- --run "xmloscopy --docbook5 ./manual.xml ./manual-combined.xml"
-
-.PHONY: format
-format:
- nix-shell --pure -Q --packages xmlformat \
- --run "find ../../ -iname '*.xml' -type f -print0 | xargs -0 -I{} -n1 \
- xmlformat --config-file '../xmlformat.conf' -i {}"
-
-.PHONY: fix-misc-xml
-fix-misc-xml:
- find . -iname '*.xml' -type f \
- -exec ../varlistentry-fixer.rb {} ';'
-
-.PHONY: clean
-clean:
- rm -f manual-combined.xml generated
-
-generated:
- nix-build ../../release.nix \
- --attr manualGeneratedSources.x86_64-linux \
- --out-link ./generated
diff --git a/nixos/doc/manual/administration/containers.chapter.md b/nixos/doc/manual/administration/containers.chapter.md
index ea51f91f698f..50493b562b54 100644
--- a/nixos/doc/manual/administration/containers.chapter.md
+++ b/nixos/doc/manual/administration/containers.chapter.md
@@ -21,8 +21,8 @@ which is often not what you want. By contrast, in the imperative
approach, containers are configured and updated independently from the
host system.
-```{=docbook}
-
-
-
+```{=include=} sections
+imperative-containers.section.md
+declarative-containers.section.md
+container-networking.section.md
```
diff --git a/nixos/doc/manual/administration/running.md b/nixos/doc/manual/administration/running.md
new file mode 100644
index 000000000000..48e8c7c6668b
--- /dev/null
+++ b/nixos/doc/manual/administration/running.md
@@ -0,0 +1,14 @@
+# Administration {#ch-running}
+
+This chapter describes various aspects of managing a running NixOS system, such as how to use the {command}`systemd` service manager.
+
+```{=include=} chapters
+service-mgmt.chapter.md
+rebooting.chapter.md
+user-sessions.chapter.md
+control-groups.chapter.md
+logging.chapter.md
+cleaning-store.chapter.md
+containers.chapter.md
+troubleshooting.chapter.md
+```
diff --git a/nixos/doc/manual/administration/running.xml b/nixos/doc/manual/administration/running.xml
deleted file mode 100644
index d9fcc1aee263..000000000000
--- a/nixos/doc/manual/administration/running.xml
+++ /dev/null
@@ -1,21 +0,0 @@
-
- Administration
-
-
- This chapter describes various aspects of managing a running NixOS system,
- such as how to use the systemd service manager.
-
-
-
-
-
-
-
-
-
-
-
diff --git a/nixos/doc/manual/administration/troubleshooting.chapter.md b/nixos/doc/manual/administration/troubleshooting.chapter.md
index 548456eaf6d6..1253607f8efc 100644
--- a/nixos/doc/manual/administration/troubleshooting.chapter.md
+++ b/nixos/doc/manual/administration/troubleshooting.chapter.md
@@ -3,10 +3,10 @@
This chapter describes solutions to common problems you might encounter
when you manage your NixOS system.
-```{=docbook}
-
-
-
-
-
+```{=include=} sections
+boot-problems.section.md
+maintenance-mode.section.md
+rollback.section.md
+store-corruption.section.md
+network-problems.section.md
```
diff --git a/nixos/doc/manual/configuration/config-syntax.chapter.md b/nixos/doc/manual/configuration/config-syntax.chapter.md
index 9f8d45d58899..9e606b2b82af 100644
--- a/nixos/doc/manual/configuration/config-syntax.chapter.md
+++ b/nixos/doc/manual/configuration/config-syntax.chapter.md
@@ -11,8 +11,8 @@ manual](https://nixos.org/nix/manual/#chap-writing-nix-expressions), but
here we give a short overview of the most important constructs useful in
NixOS configuration files.
-```{=docbook}
-
-
-
+```{=include=} sections
+config-file.section.md
+abstractions.section.md
+modularity.section.md
```
diff --git a/nixos/doc/manual/configuration/configuration.md b/nixos/doc/manual/configuration/configuration.md
new file mode 100644
index 000000000000..4c966f3325b9
--- /dev/null
+++ b/nixos/doc/manual/configuration/configuration.md
@@ -0,0 +1,27 @@
+# Configuration {#ch-configuration}
+
+This chapter describes how to configure various aspects of a NixOS machine through the configuration file {file}`/etc/nixos/configuration.nix`. As described in [](#sec-changing-config), changes to this file only take effect after you run {command}`nixos-rebuild`.
+
+```{=include=} chapters
+config-syntax.chapter.md
+package-mgmt.chapter.md
+user-mgmt.chapter.md
+file-systems.chapter.md
+x-windows.chapter.md
+wayland.chapter.md
+gpu-accel.chapter.md
+xfce.chapter.md
+networking.chapter.md
+linux-kernel.chapter.md
+subversion.chapter.md
+```
+
+```{=include=} chapters
+@MODULE_CHAPTERS@
+```
+
+```{=include=} chapters
+profiles.chapter.md
+kubernetes.chapter.md
+```
+
diff --git a/nixos/doc/manual/configuration/configuration.xml b/nixos/doc/manual/configuration/configuration.xml
deleted file mode 100644
index b04316cfa48e..000000000000
--- a/nixos/doc/manual/configuration/configuration.xml
+++ /dev/null
@@ -1,31 +0,0 @@
-
- Configuration
-
-
- This chapter describes how to configure various aspects of a NixOS machine
- through the configuration file
- /etc/nixos/configuration.nix. As described in
- , changes to this file only take
- effect after you run nixos-rebuild.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/nixos/doc/manual/configuration/declarative-packages.section.md b/nixos/doc/manual/configuration/declarative-packages.section.md
index 337cdf8472e4..02eaa56192e4 100644
--- a/nixos/doc/manual/configuration/declarative-packages.section.md
+++ b/nixos/doc/manual/configuration/declarative-packages.section.md
@@ -40,7 +40,7 @@ configuration use `pkgs` prefix (variable).
To "uninstall" a package, simply remove it from
[](#opt-environment.systemPackages) and run `nixos-rebuild switch`.
-```{=docbook}
-
-
+```{=include=} sections
+customizing-packages.section.md
+adding-custom-packages.section.md
```
diff --git a/nixos/doc/manual/configuration/file-systems.chapter.md b/nixos/doc/manual/configuration/file-systems.chapter.md
index 901e2e4f181b..aca978be064d 100644
--- a/nixos/doc/manual/configuration/file-systems.chapter.md
+++ b/nixos/doc/manual/configuration/file-systems.chapter.md
@@ -36,7 +36,7 @@ dropping you to the emergency shell. You can make a mount asynchronous
and non-critical by adding `options = [ "nofail" ];`.
:::
-```{=docbook}
-
-
+```{=include=} sections
+luks-file-systems.section.md
+sshfs-file-systems.section.md
```
diff --git a/nixos/doc/manual/configuration/networking.chapter.md b/nixos/doc/manual/configuration/networking.chapter.md
index 529dc0610bda..abbd9766f173 100644
--- a/nixos/doc/manual/configuration/networking.chapter.md
+++ b/nixos/doc/manual/configuration/networking.chapter.md
@@ -3,14 +3,14 @@
This section describes how to configure networking components
on your NixOS machine.
-```{=docbook}
-
-
-
-
-
-
-
-
+```{=include=} sections
+network-manager.section.md
+ssh.section.md
+ipv4-config.section.md
+ipv6-config.section.md
+firewall.section.md
+wireless.section.md
+ad-hoc-network-config.section.md
+renaming-interfaces.section.md
```
diff --git a/nixos/doc/manual/configuration/package-mgmt.chapter.md b/nixos/doc/manual/configuration/package-mgmt.chapter.md
index a6c414be59a9..1148bbe84740 100644
--- a/nixos/doc/manual/configuration/package-mgmt.chapter.md
+++ b/nixos/doc/manual/configuration/package-mgmt.chapter.md
@@ -12,7 +12,7 @@ NixOS has two distinct styles of package management:
`nix-env` command. This style allows mixing packages from different
Nixpkgs versions. It's the only choice for non-root users.
-```{=docbook}
-
-
+```{=include=} sections
+declarative-packages.section.md
+ad-hoc-packages.section.md
```
diff --git a/nixos/doc/manual/configuration/profiles.chapter.md b/nixos/doc/manual/configuration/profiles.chapter.md
index 2c3dea27c181..9f1f48f742ac 100644
--- a/nixos/doc/manual/configuration/profiles.chapter.md
+++ b/nixos/doc/manual/configuration/profiles.chapter.md
@@ -19,16 +19,16 @@ install media, many are actually intended to be used in real installs.
What follows is a brief explanation on the purpose and use-case for each
profile. Detailing each option configured by each one is out of scope.
-```{=docbook}
-
-
-
-
-
-
-
-
-
-
-
+```{=include=} sections
+profiles/all-hardware.section.md
+profiles/base.section.md
+profiles/clone-config.section.md
+profiles/demo.section.md
+profiles/docker-container.section.md
+profiles/graphical.section.md
+profiles/hardened.section.md
+profiles/headless.section.md
+profiles/installation-device.section.md
+profiles/minimal.section.md
+profiles/qemu-guest.section.md
```
diff --git a/nixos/doc/manual/default.nix b/nixos/doc/manual/default.nix
index e0bcec1ea6b5..8c71e5108799 100644
--- a/nixos/doc/manual/default.nix
+++ b/nixos/doc/manual/default.nix
@@ -68,56 +68,6 @@ let
optionIdPrefix = "test-opt-";
};
- sources = runCommand "manual-sources" {
- inputs = lib.sourceFilesBySuffices ./. [ ".xml" ".md" ];
- nativeBuildInputs = [ pkgs.nixos-render-docs ];
- } ''
- mkdir $out
- cd $out
- cp -r --no-preserve=all $inputs/* .
-
- declare -a convert_args
- while read -r mf; do
- if [[ "$mf" = *.chapter.md ]]; then
- convert_args+=("--chapter")
- else
- convert_args+=("--section")
- fi
-
- convert_args+=("from_md/''${mf%.md}.xml" "$mf")
- done < <(find . -type f -name '*.md')
-
- nixos-render-docs manual docbook-fragment \
- --manpage-urls ${manpageUrls} \
- "''${convert_args[@]}"
- '';
-
- modulesDoc = runCommand "modules.xml" {
- nativeBuildInputs = [ pkgs.nixos-render-docs ];
- } ''
- nixos-render-docs manual docbook-section \
- --manpage-urls ${manpageUrls} \
- "$out" \
- --section \
- --section-id modules \
- --chapters ${lib.concatMapStrings (p: "${p.value} ") config.meta.doc}
- '';
-
- generatedSources = runCommand "generated-docbook" {} ''
- mkdir $out
- ln -s ${modulesDoc} $out/modules.xml
- ln -s ${optionsDoc.optionsDocBook} $out/options-db.xml
- ln -s ${testOptionsDoc.optionsDocBook} $out/test-options-db.xml
- printf "%s" "${version}" > $out/version
- '';
-
- copySources =
- ''
- cp -prd $sources/* . # */
- ln -s ${generatedSources} ./generated
- chmod -R u+w .
- '';
-
toc = builtins.toFile "toc.xml"
''
@@ -148,70 +98,102 @@ let
"--stringparam chunk.toc ${toc}"
];
+ linterFunctions = ''
+ # outputs the context of an xmllint error output
+ # LEN lines around the failing line are printed
+ function context {
+ # length of context
+ local LEN=6
+ # lines to print before error line
+ local BEFORE=4
+
+ # xmllint output lines are:
+ # file.xml:1234: there was an error on line 1234
+ while IFS=':' read -r file line rest; do
+ echo
+ if [[ -n "$rest" ]]; then
+ echo "$file:$line:$rest"
+ local FROM=$(($line>$BEFORE ? $line - $BEFORE : 1))
+ # number lines & filter context
+ nl --body-numbering=a "$file" | sed -n "$FROM,+$LEN p"
+ else
+ if [[ -n "$line" ]]; then
+ echo "$file:$line"
+ else
+ echo "$file"
+ fi
+ fi
+ done
+ }
+
+ function lintrng {
+ xmllint --debug --noout --nonet \
+ --relaxng ${docbook5}/xml/rng/docbook/docbook.rng \
+ "$1" \
+ 2>&1 | context 1>&2
+ # ^ redirect assumes xmllint doesn’t print to stdout
+ }
+ '';
+
manual-combined = runCommand "nixos-manual-combined"
- { inherit sources;
- nativeBuildInputs = [ buildPackages.libxml2.bin buildPackages.libxslt.bin ];
+ { inputs = lib.sourceFilesBySuffices ./. [ ".xml" ".md" ];
+ nativeBuildInputs = [ pkgs.nixos-render-docs pkgs.libxml2.bin pkgs.libxslt.bin ];
meta.description = "The NixOS manual as plain docbook XML";
}
''
- ${copySources}
+ cp -r --no-preserve=all $inputs/* .
- xmllint --xinclude --output ./manual-combined.xml ./manual.xml
- xmllint --xinclude --noxincludenode \
- --output ./man-pages-combined.xml ./man-pages.xml
+ substituteInPlace ./manual.md \
+ --replace '@NIXOS_VERSION@' "${version}"
+ substituteInPlace ./configuration/configuration.md \
+ --replace \
+ '@MODULE_CHAPTERS@' \
+ ${lib.escapeShellArg (lib.concatMapStringsSep "\n" (p: "${p.value}") config.meta.doc)}
+ substituteInPlace ./nixos-options.md \
+ --replace \
+ '@NIXOS_OPTIONS_JSON@' \
+ ${optionsDoc.optionsJSON}/share/doc/nixos/options.json
+ substituteInPlace ./development/writing-nixos-tests.section.md \
+ --replace \
+ '@NIXOS_TEST_OPTIONS_JSON@' \
+ ${testOptionsDoc.optionsJSON}/share/doc/nixos/options.json
- # outputs the context of an xmllint error output
- # LEN lines around the failing line are printed
- function context {
- # length of context
- local LEN=6
- # lines to print before error line
- local BEFORE=4
+ nixos-render-docs manual docbook \
+ --manpage-urls ${manpageUrls} \
+ --revision ${lib.escapeShellArg revision} \
+ ./manual.md \
+ ./manual-combined.xml
- # xmllint output lines are:
- # file.xml:1234: there was an error on line 1234
- while IFS=':' read -r file line rest; do
- echo
- if [[ -n "$rest" ]]; then
- echo "$file:$line:$rest"
- local FROM=$(($line>$BEFORE ? $line - $BEFORE : 1))
- # number lines & filter context
- nl --body-numbering=a "$file" | sed -n "$FROM,+$LEN p"
- else
- if [[ -n "$line" ]]; then
- echo "$file:$line"
- else
- echo "$file"
- fi
- fi
- done
- }
-
- function lintrng {
- xmllint --debug --noout --nonet \
- --relaxng ${docbook5}/xml/rng/docbook/docbook.rng \
- "$1" \
- 2>&1 | context 1>&2
- # ^ redirect assumes xmllint doesn’t print to stdout
- }
+ ${linterFunctions}
mkdir $out
cp manual-combined.xml $out/
- cp man-pages-combined.xml $out/
lintrng $out/manual-combined.xml
- lintrng $out/man-pages-combined.xml
+ '';
+
+ manpages-combined = runCommand "nixos-manpages-combined.xml"
+ { nativeBuildInputs = [ buildPackages.libxml2.bin buildPackages.libxslt.bin ];
+ meta.description = "The NixOS manpages as plain docbook XML";
+ }
+ ''
+ mkdir generated
+ cp -prd ${./man-pages.xml} man-pages.xml
+ ln -s ${optionsDoc.optionsDocBook} generated/options-db.xml
+
+ xmllint --xinclude --noxincludenode --output $out ./man-pages.xml
+
+ ${linterFunctions}
+
+ lintrng $out
'';
in rec {
- inherit generatedSources;
-
inherit (optionsDoc) optionsJSON optionsNix optionsDocBook optionsUsedDocbook;
# Generate the NixOS manual.
manualHTML = runCommand "nixos-manual-html"
- { inherit sources;
- nativeBuildInputs = [ buildPackages.libxml2.bin buildPackages.libxslt.bin ];
+ { nativeBuildInputs = [ buildPackages.libxml2.bin buildPackages.libxslt.bin ];
meta.description = "The NixOS manual in HTML format";
allowedReferences = ["out"];
}
@@ -248,8 +230,7 @@ in rec {
manualHTMLIndex = "${manualHTML}/share/doc/nixos/index.html";
manualEpub = runCommand "nixos-manual-epub"
- { inherit sources;
- nativeBuildInputs = [ buildPackages.libxml2.bin buildPackages.libxslt.bin buildPackages.zip ];
+ { nativeBuildInputs = [ buildPackages.libxml2.bin buildPackages.libxslt.bin buildPackages.zip ];
}
''
# Generate the epub manual.
@@ -300,7 +281,7 @@ in rec {
--param man.endnotes.are.numbered 0 \
--param man.break.after.slash 1 \
${docbook_xsl_ns}/xml/xsl/docbook/manpages/docbook.xsl \
- ${manual-combined}/man-pages-combined.xml
+ ${manpages-combined}
''
else ''
mkdir -p $out/share/man/man5
diff --git a/nixos/doc/manual/development/development.md b/nixos/doc/manual/development/development.md
new file mode 100644
index 000000000000..6a0dd091b129
--- /dev/null
+++ b/nixos/doc/manual/development/development.md
@@ -0,0 +1,14 @@
+# Development {#ch-development}
+
+This chapter describes how you can modify and extend NixOS.
+
+```{=include=} chapters
+sources.chapter.md
+writing-modules.chapter.md
+building-parts.chapter.md
+bootspec.chapter.md
+what-happens-during-a-system-switch.chapter.md
+writing-documentation.chapter.md
+nixos-tests.chapter.md
+testing-installer.chapter.md
+```
diff --git a/nixos/doc/manual/development/development.xml b/nixos/doc/manual/development/development.xml
deleted file mode 100644
index 949468c9021d..000000000000
--- a/nixos/doc/manual/development/development.xml
+++ /dev/null
@@ -1,20 +0,0 @@
-
- Development
-
-
- This chapter describes how you can modify and extend NixOS.
-
-
-
-
-
-
-
-
-
-
-
diff --git a/nixos/doc/manual/development/nixos-tests.chapter.md b/nixos/doc/manual/development/nixos-tests.chapter.md
index 2a4fdddeaa66..ec0e4b9f076a 100644
--- a/nixos/doc/manual/development/nixos-tests.chapter.md
+++ b/nixos/doc/manual/development/nixos-tests.chapter.md
@@ -5,9 +5,9 @@ NixOS tests are kept in the directory `nixos/tests`, and are executed
(using Nix) by a testing framework that automatically starts one or more
virtual machines containing the NixOS system(s) required for the test.
-```{=docbook}
-
-
-
-
+```{=include=} sections
+writing-nixos-tests.section.md
+running-nixos-tests.section.md
+running-nixos-tests-interactively.section.md
+linking-nixos-tests-to-packages.section.md
```
diff --git a/nixos/doc/manual/development/what-happens-during-a-system-switch.chapter.md b/nixos/doc/manual/development/what-happens-during-a-system-switch.chapter.md
index aad82831a3c2..9cbec729803a 100644
--- a/nixos/doc/manual/development/what-happens-during-a-system-switch.chapter.md
+++ b/nixos/doc/manual/development/what-happens-during-a-system-switch.chapter.md
@@ -47,7 +47,7 @@ Most of these actions are either self-explaining but some of them have to do
with our units or the activation script. For this reason, these topics are
explained in the next sections.
-```{=docbook}
-
-
+```{=include=} sections
+unit-handling.section.md
+activation-script.section.md
```
diff --git a/nixos/doc/manual/development/writing-documentation.chapter.md b/nixos/doc/manual/development/writing-documentation.chapter.md
index 4986c9f0a81b..8d504dfb0b0a 100644
--- a/nixos/doc/manual/development/writing-documentation.chapter.md
+++ b/nixos/doc/manual/development/writing-documentation.chapter.md
@@ -83,7 +83,7 @@ Keep the following guidelines in mind when you create and add a topic:
## Adding a Topic to the Book {#sec-writing-docs-adding-a-topic}
-Open the parent XML file and add an `xi:include` element to the list of
+Open the parent CommonMark file and add a line to the list of
chapters with the file name of the topic that you created. If you
created a `section`, you add the file to the `chapter` file. If you created
a `chapter`, you add the file to the `part` file.
diff --git a/nixos/doc/manual/development/writing-modules.chapter.md b/nixos/doc/manual/development/writing-modules.chapter.md
index a0ec4a5df96e..ae657458d768 100644
--- a/nixos/doc/manual/development/writing-modules.chapter.md
+++ b/nixos/doc/manual/development/writing-modules.chapter.md
@@ -189,14 +189,14 @@ in {
```
:::
-```{=docbook}
-
-
-
-
-
-
-
-
-
+```{=include=} sections
+option-declarations.section.md
+option-types.section.md
+option-def.section.md
+assertions.section.md
+meta-attributes.section.md
+importing-modules.section.md
+replace-modules.section.md
+freeform-modules.section.md
+settings-options.section.md
```
diff --git a/nixos/doc/manual/development/writing-nixos-tests.section.md b/nixos/doc/manual/development/writing-nixos-tests.section.md
index d80e314e6251..3de46fda3df6 100644
--- a/nixos/doc/manual/development/writing-nixos-tests.section.md
+++ b/nixos/doc/manual/development/writing-nixos-tests.section.md
@@ -470,6 +470,8 @@ In that case, `numpy` is chosen from the generic `python3Packages`.
The following options can be used when writing tests.
-```{=docbook}
-
+```{=include=} options
+id-prefix: test-opt-
+list-id: test-options-list
+source: @NIXOS_TEST_OPTIONS_JSON@
```
diff --git a/nixos/doc/manual/installation/installation.md b/nixos/doc/manual/installation/installation.md
new file mode 100644
index 000000000000..140594256609
--- /dev/null
+++ b/nixos/doc/manual/installation/installation.md
@@ -0,0 +1,11 @@
+# Installation {#ch-installation}
+
+This section describes how to obtain, install, and configure NixOS for first-time use.
+
+```{=include=} chapters
+obtaining.chapter.md
+installing.chapter.md
+changing-config.chapter.md
+upgrading.chapter.md
+building-nixos.chapter.md
+```
diff --git a/nixos/doc/manual/installation/installation.xml b/nixos/doc/manual/installation/installation.xml
deleted file mode 100644
index ba07d71d0ca3..000000000000
--- a/nixos/doc/manual/installation/installation.xml
+++ /dev/null
@@ -1,18 +0,0 @@
-
- Installation
-
-
- This section describes how to obtain, install, and configure NixOS for
- first-time use.
-
-
-
-
-
-
-
-
diff --git a/nixos/doc/manual/installation/installing.chapter.md b/nixos/doc/manual/installation/installing.chapter.md
index e1908017a7e4..cf783c2d22b6 100644
--- a/nixos/doc/manual/installation/installing.chapter.md
+++ b/nixos/doc/manual/installation/installing.chapter.md
@@ -602,11 +602,11 @@ With a partitioned disk.
## Additional installation notes {#sec-installation-additional-notes}
-```{=docbook}
-
-
-
-
-
-
+```{=include=} sections
+installing-usb.section.md
+installing-pxe.section.md
+installing-kexec.section.md
+installing-virtualbox-guest.section.md
+installing-from-other-distro.section.md
+installing-behind-a-proxy.section.md
```
diff --git a/nixos/doc/manual/man-configuration.xml b/nixos/doc/manual/man-configuration.xml
deleted file mode 100644
index ddb1408fdcf5..000000000000
--- a/nixos/doc/manual/man-configuration.xml
+++ /dev/null
@@ -1,31 +0,0 @@
-
-
- configuration.nix
- 5
- NixOS
-
-
-
- configuration.nix
- NixOS system configuration specification
-
-
- Description
-
- The file /etc/nixos/configuration.nix contains the
- declarative specification of your NixOS system configuration. The command
- nixos-rebuild takes this file and realises the system
- configuration specified therein.
-
-
-
- Options
-
- You can use the following options in configuration.nix.
-
-
-
-
diff --git a/nixos/doc/manual/man-pages.xml b/nixos/doc/manual/man-pages.xml
index 0186221bddce..52183f1f9ee0 100644
--- a/nixos/doc/manual/man-pages.xml
+++ b/nixos/doc/manual/man-pages.xml
@@ -14,5 +14,33 @@
2007-2022Eelco Dolstra and the Nixpkgs/NixOS contributors
-
+
+
+ configuration.nix
+ 5
+ NixOS
+
+
+
+ configuration.nix
+ NixOS system configuration specification
+
+
+ Description
+
+ The file /etc/nixos/configuration.nix contains the
+ declarative specification of your NixOS system configuration. The command
+ nixos-rebuild takes this file and realises the system
+ configuration specified therein.
+
+
+
+ Options
+
+ You can use the following options in configuration.nix.
+
+
+
+
diff --git a/nixos/doc/manual/manual.md b/nixos/doc/manual/manual.md
new file mode 100644
index 000000000000..1972eaeda872
--- /dev/null
+++ b/nixos/doc/manual/manual.md
@@ -0,0 +1,53 @@
+# NixOS Manual {#book-nixos-manual}
+## Version @NIXOS_VERSION@
+
+
+
+```{=include=} preface
+preface.md
+```
+
+```{=include=} parts
+installation/installation.md
+configuration/configuration.md
+administration/running.md
+development/development.md
+```
+
+```{=include=} chapters
+contributing-to-this-manual.chapter.md
+```
+
+```{=include=} appendix
+nixos-options.md
+release-notes/release-notes.md
+```
diff --git a/nixos/doc/manual/manual.xml b/nixos/doc/manual/manual.xml
deleted file mode 100644
index 4440f8e04baa..000000000000
--- a/nixos/doc/manual/manual.xml
+++ /dev/null
@@ -1,23 +0,0 @@
-
-
- NixOS Manual
- Version
-
-
-
-
-
-
-
-
-
- Configuration Options
-
-
-
-
diff --git a/nixos/doc/manual/nixos-options.md b/nixos/doc/manual/nixos-options.md
new file mode 100644
index 000000000000..33b487c95a2e
--- /dev/null
+++ b/nixos/doc/manual/nixos-options.md
@@ -0,0 +1,7 @@
+# Configuration Options {#ch-options}
+
+```{=include=} options
+id-prefix: opt-
+list-id: configuration-variable-list
+source: @NIXOS_OPTIONS_JSON@
+```
diff --git a/nixos/doc/manual/preface.md b/nixos/doc/manual/preface.md
new file mode 100644
index 000000000000..d5e6364780a7
--- /dev/null
+++ b/nixos/doc/manual/preface.md
@@ -0,0 +1,11 @@
+# Preface {#preface}
+
+This manual describes how to install, use and extend NixOS, a Linux distribution based on the purely functional package management system [Nix](https://nixos.org/nix), that is composed using modules and packages defined in the [Nixpkgs](https://nixos.org/nixpkgs) project.
+
+Additional information regarding the Nix package manager and the Nixpkgs project can be found in respectively the [Nix manual](https://nixos.org/nix/manual) and the [Nixpkgs manual](https://nixos.org/nixpkgs/manual).
+
+If you encounter problems, please report them on the [`Discourse`](https://discourse.nixos.org), the [Matrix room](https://matrix.to/#nix:nixos.org), or on the [`#nixos` channel on Libera.Chat](irc://irc.libera.chat/#nixos). Alternatively, consider [contributing to this manual](#chap-contributing). Bugs should be reported in [NixOS’ GitHub issue tracker](https://github.com/NixOS/nixpkgs/issues).
+
+::: {.note}
+Commands prefixed with `#` have to be run as root, either requiring to login as root user or temporarily switching to it using `sudo` for example.
+:::
diff --git a/nixos/doc/manual/preface.xml b/nixos/doc/manual/preface.xml
deleted file mode 100644
index c0d530c3d1b5..000000000000
--- a/nixos/doc/manual/preface.xml
+++ /dev/null
@@ -1,42 +0,0 @@
-
- Preface
-
- This manual describes how to install, use and extend NixOS, a Linux
- distribution based on the purely functional package management system
- Nix, that is composed
- using modules and packages defined in the
- Nixpkgs project.
-
-
- Additional information regarding the Nix package manager and the Nixpkgs
- project can be found in respectively the
- Nix manual and the
- Nixpkgs manual.
-
-
- If you encounter problems, please report them on the
- Discourse,
- the Matrix room,
- or on the
- #nixos channel on Libera.Chat.
- Alternatively, consider
- contributing to this manual. Bugs should be
- reported in
- NixOS’
- GitHub issue tracker.
-
-
-
- Commands prefixed with # have to be run as root, either
- requiring to login as root user or temporarily switching to it using
- sudo for example.
-
-
-
diff --git a/nixos/doc/manual/release-notes/release-notes.md b/nixos/doc/manual/release-notes/release-notes.md
new file mode 100644
index 000000000000..ac61de3793e8
--- /dev/null
+++ b/nixos/doc/manual/release-notes/release-notes.md
@@ -0,0 +1,25 @@
+# Release Notes {#ch-release-notes}
+
+This section lists the release notes for each stable version of NixOS and current unstable revision.
+
+```{=include=} sections
+rl-2305.section.md
+rl-2211.section.md
+rl-2205.section.md
+rl-2111.section.md
+rl-2105.section.md
+rl-2009.section.md
+rl-2003.section.md
+rl-1909.section.md
+rl-1903.section.md
+rl-1809.section.md
+rl-1803.section.md
+rl-1709.section.md
+rl-1703.section.md
+rl-1609.section.md
+rl-1603.section.md
+rl-1509.section.md
+rl-1412.section.md
+rl-1404.section.md
+rl-1310.section.md
+```
diff --git a/nixos/doc/manual/release-notes/release-notes.xml b/nixos/doc/manual/release-notes/release-notes.xml
deleted file mode 100644
index bb5cc677afb8..000000000000
--- a/nixos/doc/manual/release-notes/release-notes.xml
+++ /dev/null
@@ -1,30 +0,0 @@
-
- Release Notes
-
- This section lists the release notes for each stable version of NixOS and
- current unstable revision.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/nixos/doc/manual/shell.nix b/nixos/doc/manual/shell.nix
deleted file mode 100644
index e5ec9b8f97f7..000000000000
--- a/nixos/doc/manual/shell.nix
+++ /dev/null
@@ -1,8 +0,0 @@
-let
- pkgs = import ../../.. { };
-in
-pkgs.mkShell {
- name = "nixos-manual";
-
- packages = with pkgs; [ xmlformat jing xmloscopy ruby ];
-}
diff --git a/nixos/doc/varlistentry-fixer.rb b/nixos/doc/varlistentry-fixer.rb
deleted file mode 100755
index 02168016b554..000000000000
--- a/nixos/doc/varlistentry-fixer.rb
+++ /dev/null
@@ -1,124 +0,0 @@
-#!/usr/bin/env ruby
-
-# This script is written intended as a living, evolving tooling
-# to fix oopsies within the docbook documentation.
-#
-# This is *not* a formatter. It, instead, handles some known cases
-# where something bad happened, and fixing it manually is tedious.
-#
-# Read the code to see the different cases it handles.
-#
-# ALWAYS `make format` after fixing with this!
-# ALWAYS read the changes, this tool isn't yet proven to be always right.
-
-require "rexml/document"
-include REXML
-
-if ARGV.length < 1 then
- $stderr.puts "Needs a filename."
- exit 1
-end
-
-filename = ARGV.shift
-doc = Document.new(File.open(filename))
-
-$touched = false
-
-# Fixing varnames having a sibling element without spacing.
-# This is to fix an initial `xmlformat` issue where `term`
-# would mangle as spaces.
-#
-#
-# types.separatedStringsep <----
-#
-# ...
-#
-# Generates: types.separatedStringsep
-# ^^^^
-#
-#
-#
-# makeWrapperexecutablewrapperfileargs <----
-#
-#
-# Generates: makeWrapperexecutablewrapperfileargs
-# ^^^^ ^^^^ ^^ ^^
-#
-#
-# namevalue <-----
-#
-#
-# Generates: --optionnamevalue
-# ^^ ^^
-doc.elements.each("//varlistentry/term") do |term|
- ["varname", "function", "option", "replaceable"].each do |prev_name|
- term.elements.each(prev_name) do |el|
- if el.next_element and
- el.next_element.name == "replaceable" and
- el.next_sibling_node.class == Element
- then
- $touched = true
- term.insert_after(el, Text.new(" "))
- end
- end
- end
-end
-
-
-
-#
-# nixos-option
-#
-# path <------
-#
-#
-# Generates: -Ipath
-# ^^
-doc.elements.each("//cmdsynopsis/arg") do |term|
- ["option", "replaceable"].each do |prev_name|
- term.elements.each(prev_name) do |el|
- if el.next_element and
- el.next_element.name == "replaceable" and
- el.next_sibling_node.class == Element
- then
- $touched = true
- term.insert_after(el, Text.new(" "))
- end
- end
- end
-end
-
-#
-#
-#
-#
-#
-#
-#
-#
-#
-#
-# name <----
-#
-#
-# Generates: [{--profile-name | -p }name]
-# ^^^^
-doc.elements.each("//cmdsynopsis/arg") do |term|
- ["group"].each do |prev_name|
- term.elements.each(prev_name) do |el|
- if el.next_element and
- el.next_element.name == "replaceable" and
- el.next_sibling_node.class == Element
- then
- $touched = true
- term.insert_after(el, Text.new(" "))
- end
- end
- end
-end
-
-
-if $touched then
- doc.context[:attribute_quote] = :quote
- doc.write(output: File.open(filename, "w"))
-end
diff --git a/nixos/modules/services/web-apps/onlyoffice.nix b/nixos/modules/services/web-apps/onlyoffice.nix
index 6a8a28185b5b..3494f2fa21f0 100644
--- a/nixos/modules/services/web-apps/onlyoffice.nix
+++ b/nixos/modules/services/web-apps/onlyoffice.nix
@@ -270,7 +270,7 @@ in
wantedBy = [ "multi-user.target" ];
serviceConfig = {
ExecStart = "${cfg.package.fhs}/bin/onlyoffice-wrapper DocService/docservice /run/onlyoffice/config";
- ExecStartPre = onlyoffice-prestart;
+ ExecStartPre = [ onlyoffice-prestart ];
Group = "onlyoffice";
Restart = "always";
RuntimeDirectory = "onlyoffice";
diff --git a/nixos/release.nix b/nixos/release.nix
index 946379bcd661..78a74af41242 100644
--- a/nixos/release.nix
+++ b/nixos/release.nix
@@ -144,7 +144,6 @@ in rec {
manual = manualHTML; # TODO(@oxij): remove eventually
manualEpub = (buildFromConfig ({ ... }: { }) (config: config.system.build.manual.manualEpub));
manpages = buildFromConfig ({ ... }: { }) (config: config.system.build.manual.manpages);
- manualGeneratedSources = buildFromConfig ({ ... }: { }) (config: config.system.build.manual.generatedSources);
options = (buildFromConfig ({ ... }: { }) (config: config.system.build.manual.optionsJSON)).x86_64-linux;
diff --git a/pkgs/applications/misc/protonup-qt/default.nix b/pkgs/applications/misc/protonup-qt/default.nix
new file mode 100644
index 000000000000..72997d1e09a3
--- /dev/null
+++ b/pkgs/applications/misc/protonup-qt/default.nix
@@ -0,0 +1,33 @@
+{ appimageTools, fetchurl, lib }:
+let
+ pname = "protonup-qt";
+ version = "2.7.4";
+ src = fetchurl {
+ url = "https://github.com/DavidoTek/ProtonUp-Qt/releases/download/v${version}/ProtonUp-Qt-${version}-x86_64.AppImage";
+ sha256 = "yKc+KOQfqciqULnChVLf6y9npoSYM6Fmu7mYGEKmpkA=";
+ };
+ appimageContents = appimageTools.extractType2 { inherit pname version src; };
+in
+appimageTools.wrapType2 rec {
+ inherit pname version src;
+
+ extraInstallCommands = ''
+ mv $out/bin/{${pname}-${version},${pname}}
+ mkdir -p $out/share/{applications,pixmaps}
+ cp ${appimageContents}/net.davidotek.pupgui2.desktop $out/share/applications/${pname}.desktop
+ cp ${appimageContents}/net.davidotek.pupgui2.png $out/share/pixmaps/${pname}.png
+ substituteInPlace $out/share/applications/${pname}.desktop \
+ --replace 'Exec=net.davidotek.pupgui2' 'Exec=${pname}' \
+ --replace 'Icon=net.davidotek.pupgui2' 'Icon=${pname}'
+ '';
+
+ meta = with lib; {
+ homepage = "https://davidotek.github.io/protonup-qt/";
+ description = "Install and manage Proton-GE and Luxtorpeda for Steam and Wine-GE for Lutris with this graphical user interface.";
+ license = licenses.gpl3;
+ sourceProvenance = with sourceTypes; [ binaryNativeCode ];
+ mainProgram = "protonup-qt";
+ platforms = [ "x86_64-linux" ];
+ maintainers = with maintainers; [ ];
+ };
+}
diff --git a/pkgs/applications/networking/cluster/helm/plugins/helm-diff.nix b/pkgs/applications/networking/cluster/helm/plugins/helm-diff.nix
index 64fa0f35e543..c08e12a4de8e 100644
--- a/pkgs/applications/networking/cluster/helm/plugins/helm-diff.nix
+++ b/pkgs/applications/networking/cluster/helm/plugins/helm-diff.nix
@@ -2,16 +2,18 @@
buildGoModule rec {
pname = "helm-diff";
- version = "3.5.0";
+ version = "3.6.0";
src = fetchFromGitHub {
owner = "databus23";
repo = pname;
rev = "v${version}";
- sha256 = "sha256-evFdMM2AilKQPdSCUzKo6RuC4OC4zfjj+JzFvtkSrdk=";
+ sha256 = "sha256-JeQP2KXoLxkyRZVFcd6Rrz5xyJd+F3plzznAVP3Um8g=";
};
- vendorSha256 = "sha256-9i4ryBpaK7mMbsOpIaaZWBRjewD1MtTpf4zJ0yU0KMg=";
+ vendorSha256 = "sha256-d5NSqCJrk9QhV5gVOKUG/uJxuvt8X8hiQd8yJEoXPL0=";
+
+ ldflags = [ "-s" "-w" "-X github.com/databus23/helm-diff/v3/cmd.Version=${version}" ];
# NOTE: Remove the install and upgrade hooks.
postPatch = ''
diff --git a/pkgs/applications/networking/cluster/helm/plugins/helm-secrets.nix b/pkgs/applications/networking/cluster/helm/plugins/helm-secrets.nix
index 7d9135045f17..39a03eceacaa 100644
--- a/pkgs/applications/networking/cluster/helm/plugins/helm-secrets.nix
+++ b/pkgs/applications/networking/cluster/helm/plugins/helm-secrets.nix
@@ -2,13 +2,13 @@
stdenv.mkDerivation rec {
pname = "helm-secrets";
- version = "3.8.3";
+ version = "4.2.2";
src = fetchFromGitHub {
owner = "jkroepke";
repo = pname;
rev = "v${version}";
- hash = "sha256-FpF/d+e5T6nb0OENaYLY+3ATZ+qcAeih5/yKI+AtfKA=";
+ hash = "sha256-aqRgny1vU+dxpZpzwL4aSbYfTGrZbRffQy81mMBvnJk=";
};
nativeBuildInputs = [ makeWrapper ];
@@ -17,9 +17,9 @@ stdenv.mkDerivation rec {
# NOTE: helm-secrets is comprised of shell scripts.
dontBuild = true;
- # NOTE: Remove the install and upgrade hooks.
+ # NOTE: Fix version string
postPatch = ''
- sed -i '/^hooks:/,+2 d' plugin.yaml
+ sed -i 's/^version:.*/version: "${version}"/' plugin.yaml
'';
installPhase = ''
diff --git a/pkgs/applications/networking/feedreaders/rsstail/default.nix b/pkgs/applications/networking/feedreaders/rsstail/default.nix
index 1cd83cda77a9..af2dbd1a9a4f 100644
--- a/pkgs/applications/networking/feedreaders/rsstail/default.nix
+++ b/pkgs/applications/networking/feedreaders/rsstail/default.nix
@@ -1,18 +1,17 @@
-{ lib, stdenv, fetchFromGitHub, cppcheck, libmrss, libiconv }:
+{ lib, stdenv, fetchFromGitHub, libmrss, libiconv }:
stdenv.mkDerivation {
pname = "rsstail";
version = "2.1";
src = fetchFromGitHub {
- sha256 = "12p69i3g1fwlw0bds9jqsdmzkid3k5a41w31d227i7vm12wcvjf6";
- rev = "6f2436185372b3f945a4989406c4b6a934fe8a95";
- repo = "rsstail";
owner = "folkertvanheusden";
+ repo = "rsstail";
+ rev = "6f2436185372b3f945a4989406c4b6a934fe8a95";
+ sha256 = "12p69i3g1fwlw0bds9jqsdmzkid3k5a41w31d227i7vm12wcvjf6";
};
buildInputs = [ libmrss ] ++ lib.optionals stdenv.isDarwin [ libiconv ];
- nativeCheckInputs = [ cppcheck ];
postPatch = ''
substituteInPlace Makefile --replace -liconv_hook ""
@@ -21,7 +20,8 @@ stdenv.mkDerivation {
makeFlags = [ "prefix=$(out)" ];
enableParallelBuilding = true;
- doCheck = true;
+ # just runs cppcheck linter
+ doCheck = false;
meta = with lib; {
description = "Monitor RSS feeds for new entries";
@@ -29,7 +29,7 @@ stdenv.mkDerivation {
RSSTail is more or less an RSS reader: it monitors an RSS feed and if it
detects a new entry it'll emit only that new entry.
'';
- homepage = "http://www.vanheusden.com/rsstail/";
+ homepage = "https://www.vanheusden.com/rsstail/";
license = licenses.gpl2Plus;
maintainers = [ maintainers.Necior ];
platforms = platforms.unix;
diff --git a/pkgs/applications/networking/flexget/default.nix b/pkgs/applications/networking/flexget/default.nix
index dca8f277867a..818ceb74ea0c 100644
--- a/pkgs/applications/networking/flexget/default.nix
+++ b/pkgs/applications/networking/flexget/default.nix
@@ -5,7 +5,7 @@
python3Packages.buildPythonApplication rec {
pname = "flexget";
- version = "3.5.23";
+ version = "3.5.24";
format = "pyproject";
# Fetch from GitHub in order to use `requirements.in`
@@ -13,7 +13,7 @@ python3Packages.buildPythonApplication rec {
owner = "flexget";
repo = "flexget";
rev = "refs/tags/v${version}";
- hash = "sha256-VWpcXwiQHpQ3X/rmm6fWfPfuUoUmWQMfOq5A87nED3A=";
+ hash = "sha256-4RQBaqC3nmyEq9Kqg0n9KIN9Gw4Z+uCl6hQeqo/NTls=";
};
postPatch = ''
diff --git a/pkgs/applications/networking/instant-messengers/webex/default.nix b/pkgs/applications/networking/instant-messengers/webex/default.nix
index f28cc3c25f6e..1c2c3eb9fec7 100644
--- a/pkgs/applications/networking/instant-messengers/webex/default.nix
+++ b/pkgs/applications/networking/instant-messengers/webex/default.nix
@@ -55,11 +55,11 @@
stdenv.mkDerivation rec {
pname = "webex";
- version = "42.10.0.24000";
+ version = "42.12.0.24485";
src = fetchurl {
- url = "https://binaries.webex.com/WebexDesktop-Ubuntu-Gold/20221019145240/Webex_ubuntu.7z";
- sha256 = "03b77a3fcce76f04cf684bcdecb3bcce97c5a8b6cc36b40967cc14fa9a46c102";
+ url = "https://binaries.webex.com/WebexDesktop-Ubuntu-Gold/20221206141837/Webex_ubuntu.7z";
+ sha256 = "4c09c13b760abbdcc8bc1a74d137f8bc23386da4425cbefd8ea75bd0a877fdbf";
};
buildInputs = [
diff --git a/pkgs/applications/science/biology/nest/default.nix b/pkgs/applications/science/biology/nest/default.nix
new file mode 100644
index 000000000000..01874763901b
--- /dev/null
+++ b/pkgs/applications/science/biology/nest/default.nix
@@ -0,0 +1,70 @@
+{ lib
+, stdenv
+, fetchFromGitHub
+, testers
+, cmake
+, gsl
+, libtool
+, mpi
+, nest
+, pkg-config
+, python3
+, readline
+, autoPatchelfHook
+, withPython ? false
+, withMpi ? false
+}:
+
+stdenv.mkDerivation rec {
+ pname = "nest";
+ version = "3.3";
+
+ src = fetchFromGitHub {
+ owner = "nest";
+ repo = "nest-simulator";
+ rev = "v${version}";
+ sha256 = "sha256-wmn5LOOHlSuyPdV6O6v7j10dxdcvqpym6MfveZdL+dU=";
+ };
+
+ postPatch = ''
+ patchShebangs cmake/CheckFiles/check_return_val.sh
+ # fix PyNEST installation path
+ # it expects CMAKE_INSTALL_LIBDIR to be relative
+ substituteInPlace cmake/ProcessOptions.cmake \
+ --replace "\''${CMAKE_INSTALL_LIBDIR}/python" "lib/python"
+ '';
+
+ nativeBuildInputs = [
+ cmake
+ pkg-config
+ autoPatchelfHook
+ ];
+
+ buildInputs = [
+ gsl
+ readline
+ libtool # libltdl
+ ] ++ lib.optionals withPython [
+ python3
+ python3.pkgs.cython
+ ] ++ lib.optional withMpi mpi;
+
+ cmakeFlags = [
+ "-Dwith-python=${if withPython then "ON" else "OFF"}"
+ "-Dwith-mpi=${if withMpi then "ON" else "OFF"}"
+ "-Dwith-openmp=${if stdenv.isDarwin then "OFF" else "ON"}"
+ ];
+
+ passthru.tests.version = testers.testVersion {
+ package = nest;
+ command = "nest --version";
+ };
+
+ meta = with lib; {
+ description = "NEST is a command line tool for simulating neural networks";
+ homepage = "https://www.nest-simulator.org/";
+ license = licenses.gpl2;
+ maintainers = with maintainers; [ jiegec ];
+ platforms = platforms.unix;
+ };
+}
diff --git a/pkgs/applications/version-management/fnc/default.nix b/pkgs/applications/version-management/fnc/default.nix
index 7fd1b34d4560..b74200a6919c 100644
--- a/pkgs/applications/version-management/fnc/default.nix
+++ b/pkgs/applications/version-management/fnc/default.nix
@@ -13,7 +13,7 @@ stdenv.mkDerivation rec {
makeFlags = [ "PREFIX=$(out)" ];
- NIX_CFLAGS_COMPILE = [
+ NIX_CFLAGS_COMPILE = lib.optionals stdenv.cc.isGNU [
# Needed with GCC 12
"-Wno-error=maybe-uninitialized"
];
diff --git a/pkgs/applications/video/obs-studio/plugins/obs-vkcapture.nix b/pkgs/applications/video/obs-studio/plugins/obs-vkcapture.nix
index ba0e8a818263..c156ac288b66 100644
--- a/pkgs/applications/video/obs-studio/plugins/obs-vkcapture.nix
+++ b/pkgs/applications/video/obs-studio/plugins/obs-vkcapture.nix
@@ -8,6 +8,7 @@
, wayland-scanner
, obs-studio
, libX11
+, libxcb
, vulkan-headers
, vulkan-loader
, libGL
@@ -35,6 +36,7 @@ stdenv.mkDerivation rec {
buildInputs = [
libGL
libX11
+ libxcb
vulkan-headers
vulkan-loader
wayland
diff --git a/pkgs/development/libraries/hunspell/dictionaries.nix b/pkgs/development/libraries/hunspell/dictionaries.nix
index 3eee425d4be8..09d68fa0199d 100644
--- a/pkgs/development/libraries/hunspell/dictionaries.nix
+++ b/pkgs/development/libraries/hunspell/dictionaries.nix
@@ -1,6 +1,6 @@
/* hunspell dictionaries */
-{ lib, stdenv, fetchurl, fetchFromGitHub, unzip, coreutils, bash, which, zip, ispell, perl, hunspell }:
+{ lib, stdenv, fetchurl, fetchzip, fetchFromGitHub, unzip, coreutils, bash, which, zip, ispell, perl, hunspell }:
let
@@ -878,4 +878,28 @@ rec {
shortDescription = "Norwegian Nynorsk (Norway)";
license = with lib.licenses; [ gpl2Only ];
};
+
+ /* TOKI PONA */
+
+ tok = mkDict rec {
+ pname = "hunspell-dict-tok";
+ version = "20220829";
+ dictFileName = "tok";
+ readmeFile = "README.en.adoc";
+
+ src = fetchzip {
+ url = "https://github.com/somasis/hunspell-tok/releases/download/${version}/hunspell-tok-${version}.tar.gz";
+ sha256 = "sha256-RiAODKXPUeIcf8IFcU6Tacehq5S8GYuPTuxEiN2CXD0=";
+ };
+
+ dontBuild = true;
+
+ meta = with lib; {
+ description = "Hunspell dictionary for Toki Pona";
+ homepage = "https://github.com/somasis/hunspell-tok";
+ license = with lib.licenses; [ cc0 publicDomain cc-by-sa-30 cc-by-sa-40 ];
+ maintainers = with maintainers; [ somasis ];
+ platforms = platforms.all;
+ };
+ };
}
diff --git a/pkgs/development/libraries/migraphx/default.nix b/pkgs/development/libraries/migraphx/default.nix
index 27caa1f94137..15581e00e528 100644
--- a/pkgs/development/libraries/migraphx/default.nix
+++ b/pkgs/development/libraries/migraphx/default.nix
@@ -7,7 +7,6 @@
, rocm-cmake
, hip
, clang-tools-extra
-, cppcheck
, openmp
, rocblas
, rocmlir
@@ -70,7 +69,6 @@ in stdenv.mkDerivation (finalAttrs: {
rocm-cmake
hip
clang-tools-extra
- cppcheck
python3Packages.python
] ++ lib.optionals buildDocs [
latex
diff --git a/pkgs/development/libraries/sqlitecpp/default.nix b/pkgs/development/libraries/sqlitecpp/default.nix
index f4b2ee9e9a95..aad1ee34e5c4 100644
--- a/pkgs/development/libraries/sqlitecpp/default.nix
+++ b/pkgs/development/libraries/sqlitecpp/default.nix
@@ -1,4 +1,4 @@
-{ lib, stdenv, fetchFromGitHub, cmake, sqlite, cppcheck, gtest }:
+{ lib, stdenv, fetchFromGitHub, cmake, sqlite, gtest }:
stdenv.mkDerivation rec {
pname = "sqlitecpp";
@@ -12,7 +12,6 @@ stdenv.mkDerivation rec {
};
nativeBuildInputs = [ cmake ];
- nativeCheckInputs = [ cppcheck ];
buildInputs = [ sqlite gtest ];
doCheck = true;
diff --git a/pkgs/development/libraries/tbb/default.nix b/pkgs/development/libraries/tbb/default.nix
index e0c48bc6dcef..ec22952cc42b 100644
--- a/pkgs/development/libraries/tbb/default.nix
+++ b/pkgs/development/libraries/tbb/default.nix
@@ -101,6 +101,6 @@ stdenv.mkDerivation rec {
details and threading mechanisms for scalability and performance.
'';
platforms = platforms.unix;
- maintainers = with maintainers; [ thoughtpolice dizfer ];
+ maintainers = with maintainers; [ thoughtpolice ];
};
}
diff --git a/pkgs/development/libraries/webkitgtk/default.nix b/pkgs/development/libraries/webkitgtk/default.nix
index fdefeb86a046..73073a6b7117 100644
--- a/pkgs/development/libraries/webkitgtk/default.nix
+++ b/pkgs/development/libraries/webkitgtk/default.nix
@@ -69,7 +69,7 @@
stdenv.mkDerivation (finalAttrs: {
pname = "webkitgtk";
- version = "2.38.4";
+ version = "2.38.5";
name = "${finalAttrs.pname}-${finalAttrs.version}+abi=${if lib.versionAtLeast gtk3.version "4.0" then "5.0" else "4.${if lib.versions.major libsoup.version == "2" then "0" else "1"}"}";
outputs = [ "out" "dev" "devdoc" ];
@@ -80,7 +80,7 @@ stdenv.mkDerivation (finalAttrs: {
src = fetchurl {
url = "https://webkitgtk.org/releases/webkitgtk-${finalAttrs.version}.tar.xz";
- hash = "sha256-T0fqKaLU1fFe7z3J4tbG8Gfo3oY6P2RFXhzPlpPMHTY=";
+ hash = "sha256-QMIMQwIidN9Yk/IrEFT6iUw+6gVzibsIruCMWwuwwac=";
};
patches = lib.optionals stdenv.isLinux [
diff --git a/pkgs/development/python-modules/ansible-doctor/default.nix b/pkgs/development/python-modules/ansible-doctor/default.nix
index 0ddd26b7ffb4..96f381f56d03 100644
--- a/pkgs/development/python-modules/ansible-doctor/default.nix
+++ b/pkgs/development/python-modules/ansible-doctor/default.nix
@@ -18,7 +18,7 @@
buildPythonPackage rec {
pname = "ansible-doctor";
- version = "2.0.0";
+ version = "2.0.1";
format = "pyproject";
disabled = pythonOlder "3.7";
@@ -27,7 +27,7 @@ buildPythonPackage rec {
owner = "thegeeklab";
repo = "ansible-doctor";
rev = "refs/tags/v${version}";
- hash = "sha256-P2PC90coR+FpQkO+SUon72bDLTYJhZ5qbcOdCKuFFwE=";
+ hash = "sha256-xUg7+7oWxIVdKLOGIE1uxh7SSjkz/w0//OyMF1HhEJk=";
};
pythonRelaxDeps = true;
diff --git a/pkgs/development/python-modules/arcam-fmj/default.nix b/pkgs/development/python-modules/arcam-fmj/default.nix
index 1169e1ca341f..7cba156bd684 100644
--- a/pkgs/development/python-modules/arcam-fmj/default.nix
+++ b/pkgs/development/python-modules/arcam-fmj/default.nix
@@ -12,7 +12,7 @@
buildPythonPackage rec {
pname = "arcam-fmj";
- version = "1.2.0";
+ version = "1.2.1";
format = "setuptools";
disabled = pythonOlder "3.8";
@@ -21,7 +21,7 @@ buildPythonPackage rec {
owner = "elupus";
repo = "arcam_fmj";
rev = "refs/tags/${version}";
- hash = "sha256-stoxDb25K/h55rwR0faWO0AOjSJmjZNbMbOAuUE2iSM=";
+ hash = "sha256-nRInKju3Q4En+SiSl6DOeeTRK56TzKPweoVXsvzs45I=";
};
propagatedBuildInputs = [
diff --git a/pkgs/development/python-modules/brian2/default.nix b/pkgs/development/python-modules/brian2/default.nix
new file mode 100644
index 000000000000..52149b883060
--- /dev/null
+++ b/pkgs/development/python-modules/brian2/default.nix
@@ -0,0 +1,53 @@
+{ lib
+, buildPythonPackage
+, fetchPypi
+, cython
+, jinja2
+, numpy
+, pyparsing
+, setuptools
+, sympy
+, pytest
+, pytest-xdist
+, python
+}:
+
+buildPythonPackage rec {
+ pname = "brian2";
+ version = "2.5.1";
+
+ src = fetchPypi {
+ pname = "Brian2";
+ inherit version;
+ sha256 = "sha256-x1EcS7PFCsjPYsq3Lt87SJRW4J5DE/OfdFs3NuyHiLw=";
+ };
+
+ propagatedBuildInputs = [
+ cython
+ jinja2
+ numpy
+ pyparsing
+ setuptools
+ sympy
+ ];
+
+ checkInputs = [
+ pytest
+ pytest-xdist
+ ];
+
+ checkPhase = ''
+ runHook preCheck
+ # Cython cache lies in home directory
+ export HOME=$(mktemp -d)
+ cd $HOME && ${python.interpreter} -c "import brian2;assert brian2.test()"
+ runHook postCheck
+ '';
+
+ meta = with lib; {
+ description = "A clock-driven simulator for spiking neural networks";
+ homepage = "https://briansimulator.org/";
+ license = licenses.cecill21;
+ maintainers = with maintainers; [ jiegec ];
+ };
+}
diff --git a/pkgs/development/python-modules/elastic-apm/default.nix b/pkgs/development/python-modules/elastic-apm/default.nix
index 0f44f7b8fb02..b7286ad39c26 100644
--- a/pkgs/development/python-modules/elastic-apm/default.nix
+++ b/pkgs/development/python-modules/elastic-apm/default.nix
@@ -1,5 +1,4 @@
{ lib
-, asynctest
, aiohttp
, blinker
, buildPythonPackage
@@ -30,7 +29,7 @@
buildPythonPackage rec {
pname = "elastic-apm";
- version = "6.14.0";
+ version = "6.15.0";
format = "setuptools";
disabled = pythonOlder "3.8";
@@ -39,7 +38,7 @@ buildPythonPackage rec {
owner = "elastic";
repo = "apm-agent-python";
rev = "refs/tags/v${version}";
- hash = "sha256-T1TWILlJZffTISVt8YSi8ZYSXOHieh6SV55j8W333LQ=";
+ hash = "sha256-Uoybe6Mx7ZLs2GaOnl278Xj6KlTEgrOuNxMRmPpSq8k=";
};
propagatedBuildInputs = [
@@ -54,22 +53,18 @@ buildPythonPackage rec {
];
nativeCheckInputs = [
- pytestCheckHook
- ];
-
- checkInputs = [
- asynctest
ecs-logging
+ httpx
jinja2
jsonschema
Logbook
mock
- httpx
pytest-asyncio
pytest-bdd
- pytest-mock
pytest-localserver
+ pytest-mock
pytest-random-order
+ pytestCheckHook
sanic-testing
structlog
webob
diff --git a/pkgs/development/python-modules/oslo-serialization/default.nix b/pkgs/development/python-modules/oslo-serialization/default.nix
index a94c79e9baf6..bb2cfbea90ad 100644
--- a/pkgs/development/python-modules/oslo-serialization/default.nix
+++ b/pkgs/development/python-modules/oslo-serialization/default.nix
@@ -11,12 +11,12 @@
buildPythonPackage rec {
pname = "oslo-serialization";
- version = "5.0.0";
+ version = "5.1.0";
src = fetchPypi {
pname = "oslo.serialization";
inherit version;
- sha256 = "sha256-KEUyjQ9H3Ioj/tKoIlPpCs/wqnMdvSTzec+OUObMZro=";
+ sha256 = "sha256-pIR98yaBwahL0TotunpuydW0SITeYyUhGS9tx1DOCYQ=";
};
postPatch = ''
diff --git a/pkgs/development/python-modules/pynvml/default.nix b/pkgs/development/python-modules/pynvml/default.nix
index 8f02bcdbe816..bad74b2aed9c 100644
--- a/pkgs/development/python-modules/pynvml/default.nix
+++ b/pkgs/development/python-modules/pynvml/default.nix
@@ -9,12 +9,12 @@
buildPythonPackage rec {
pname = "pynvml";
- version = "11.4.1";
+ version = "11.5.0";
disabled = pythonOlder "3.6";
src = fetchPypi {
inherit pname version;
- sha256 = "b2e4a33b80569d093b513f5804db0c7f40cfc86f15a013ae7a8e99c5e175d5dd";
+ sha256 = "sha256-0CeyG5WxCIufwngRf59ht8Z/jjOnh+n4P3NfD3GsMtA=";
};
patches = [
diff --git a/pkgs/development/python-modules/selenium/default.nix b/pkgs/development/python-modules/selenium/default.nix
index 76c3956ec86b..598bbc41deee 100644
--- a/pkgs/development/python-modules/selenium/default.nix
+++ b/pkgs/development/python-modules/selenium/default.nix
@@ -13,7 +13,7 @@
buildPythonPackage rec {
pname = "selenium";
- version = "4.7.0";
+ version = "4.8.0";
format = "setuptools";
disabled = pythonOlder "3.7";
@@ -23,7 +23,7 @@ buildPythonPackage rec {
repo = "selenium";
# check if there is a newer tag with or without -python suffix
rev = "refs/tags/selenium-${version}";
- hash = "sha256-7inmi8dHi6So+8AbLq85Go/GEaiV1XK/7+wt9UkTdo8=";
+ hash = "sha256-YTi6SNtTWuEPlQ3PTeis9osvtnWmZ7SRQbne9fefdco=";
};
postPatch = ''
diff --git a/pkgs/development/python-modules/simpleeval/default.nix b/pkgs/development/python-modules/simpleeval/default.nix
index 28e5c2578602..57693fb3791c 100644
--- a/pkgs/development/python-modules/simpleeval/default.nix
+++ b/pkgs/development/python-modules/simpleeval/default.nix
@@ -7,14 +7,14 @@
buildPythonPackage rec {
pname = "simpleeval";
- version = "0.9.12";
+ version = "0.9.13";
format = "pyproject";
src = fetchFromGitHub {
owner = "danthedeckie";
repo = pname;
- rev = version;
- sha256 = "0khgl729q5133fgc00d550f4r77707rkkn7r56az4v8bvx0q8xp4";
+ rev = "refs/tags/${version}";
+ hash = "sha256-I1GILYPE6OyotgRe0Ek/iHHv6q9/b/MlcTxMAtfZD80=";
};
nativeBuildInputs = [
@@ -36,6 +36,7 @@ buildPythonPackage rec {
meta = with lib; {
description = "Simple, safe single expression evaluator library";
homepage = "https://github.com/danthedeckie/simpleeval";
+ changelog = "https://github.com/danthedeckie/simpleeval/releases/tag/${version}";
license = licenses.mit;
maintainers = with maintainers; [ johbo ];
};
diff --git a/pkgs/development/tools/rust/cargo-valgrind/default.nix b/pkgs/development/tools/rust/cargo-valgrind/default.nix
index af7abb9a1abf..7b0647c14c45 100644
--- a/pkgs/development/tools/rust/cargo-valgrind/default.nix
+++ b/pkgs/development/tools/rust/cargo-valgrind/default.nix
@@ -8,16 +8,16 @@
rustPlatform.buildRustPackage rec {
pname = "cargo-valgrind";
- version = "2.1.0";
+ version = "2.1.1";
src = fetchFromGitHub {
owner = "jfrimmel";
repo = "cargo-valgrind";
rev = "v${version}";
- sha256 = "sha256-FCz15kMSKckifYWSTMGqJbRpZ8X/AM5dSw46dg8ERcY=";
+ sha256 = "sha256-l/1paghG/ARD0JfzNh0xj2UD5kW6FddM8Xrd/FCygYc=";
};
- cargoSha256 = "sha256-csSUe2qUIN2xKOMHWyM56FZyCwKPdfAI0NrFiDOtRiE=";
+ cargoSha256 = "sha256-9/kIIZDIsOhUvRT3TyXN5PGFUB+a8m2yXmzBbsPUK28=";
passthru = {
updateScript = nix-update-script { };
diff --git a/pkgs/development/web/nodejs/v14.nix b/pkgs/development/web/nodejs/v14.nix
index 4563dd7a045a..e7dec1c12f66 100644
--- a/pkgs/development/web/nodejs/v14.nix
+++ b/pkgs/development/web/nodejs/v14.nix
@@ -8,7 +8,7 @@ let
in
buildNodejs {
inherit enableNpm;
- version = "14.21.2";
- sha256 = "00zzl43iis8mr8x48hww5ncj8mj5dmpn05rq7ihpffkp2q7rmw6q";
+ version = "14.21.3";
+ sha256 = "sha256-RY7AkuYK1wDdzwectj1DXBXaTHuz0/mbmo5YqZ5UB14=";
patches = lib.optional stdenv.isDarwin ./bypass-xcodebuild.diff;
}
diff --git a/pkgs/development/web/nodejs/v16.nix b/pkgs/development/web/nodejs/v16.nix
index c8241ababc0d..725bbc690df1 100644
--- a/pkgs/development/web/nodejs/v16.nix
+++ b/pkgs/development/web/nodejs/v16.nix
@@ -10,8 +10,8 @@ let
in
buildNodejs {
inherit enableNpm;
- version = "16.19.0";
- sha256 = "01k72p0hp4lhlpz1syd9cbkm2gpfww0hn10xdpmzd4i3x8dfq7sg";
+ version = "16.19.1";
+ sha256 = "sha256-F/txZAYZgSWzDJTdPRdWIHspdwViav4W2NxHmmWh2LU=";
patches = [
./disable-darwin-v8-system-instrumentation.patch
./bypass-darwin-xcrun-node16.patch
diff --git a/pkgs/development/web/nodejs/v18.nix b/pkgs/development/web/nodejs/v18.nix
index 86accf5977b3..2a5a5ae3f677 100644
--- a/pkgs/development/web/nodejs/v18.nix
+++ b/pkgs/development/web/nodejs/v18.nix
@@ -9,8 +9,8 @@ let
in
buildNodejs {
inherit enableNpm;
- version = "18.14.0";
- sha256 = "sha256-Qu+d0xmT1cjoKwqwlpE1CT5qKW76J7G+mvwErADwJno=";
+ version = "18.14.1";
+ sha256 = "sha256-7sNTQ4Jm/QrvU6lEa+ELMu5udNCOMt1UVLOC/2eT2gQ=";
patches = [
./disable-darwin-v8-system-instrumentation.patch
./bypass-darwin-xcrun-node16.patch
diff --git a/pkgs/development/web/nodejs/v19.nix b/pkgs/development/web/nodejs/v19.nix
index 85739c36c132..f344324291c3 100644
--- a/pkgs/development/web/nodejs/v19.nix
+++ b/pkgs/development/web/nodejs/v19.nix
@@ -9,8 +9,8 @@ let
in
buildNodejs {
inherit enableNpm;
- version = "19.6.0";
- sha256 = "sha256-UZxtVCqfmW8AwaPTsuXPUrfbmY2V9s7VqJPRagPeM+o=";
+ version = "19.6.1";
+ sha256 = "sha256-dxDmwoUclWvkkm/CVAZ48/3fjm04Juo6qbjCjW6omps=";
patches = [
./revert-arm64-pointer-auth.patch
./disable-darwin-v8-system-instrumentation-node19.patch
diff --git a/pkgs/games/freeorion/default.nix b/pkgs/games/freeorion/default.nix
index 5b4407038015..9f9075d75a4d 100644
--- a/pkgs/games/freeorion/default.nix
+++ b/pkgs/games/freeorion/default.nix
@@ -5,8 +5,7 @@
, doxygen
, graphviz
, makeWrapper
-, cppcheck
-, boost16x
+, boost17x
, SDL2
, python3
, freetype
@@ -24,8 +23,8 @@
}:
stdenv.mkDerivation rec {
- version = "0.4.10.2";
pname = "freeorion";
+ version = "0.4.10.2";
src = fetchFromGitHub {
owner = "freeorion";
@@ -35,7 +34,7 @@ stdenv.mkDerivation rec {
};
buildInputs = [
- (boost16x.override { enablePython = true; python = python3; })
+ (boost17x.override { enablePython = true; python = python3; })
(python3.withPackages (p: with p; [ pycodestyle ]))
SDL2
freetype
@@ -53,7 +52,6 @@ stdenv.mkDerivation rec {
nativeBuildInputs = [
cmake
- cppcheck
doxygen
graphviz
makeWrapper
@@ -81,7 +79,7 @@ stdenv.mkDerivation rec {
meta = with lib; {
description = "A free, open source, turn-based space empire and galactic conquest (4X) computer game";
- homepage = "http://www.freeorion.org";
+ homepage = "https://www.freeorion.org/";
license = with licenses; [ gpl2 cc-by-sa-30 ];
platforms = platforms.linux;
maintainers = with maintainers; [ tex ];
diff --git a/pkgs/misc/wiki-tui/default.nix b/pkgs/misc/wiki-tui/default.nix
index 9131f66491d5..332577489faf 100644
--- a/pkgs/misc/wiki-tui/default.nix
+++ b/pkgs/misc/wiki-tui/default.nix
@@ -10,13 +10,13 @@
rustPlatform.buildRustPackage rec {
pname = "wiki-tui";
- version = "0.6.1";
+ version = "0.6.3";
src = fetchFromGitHub {
owner = "Builditluc";
repo = pname;
rev = "v${version}";
- hash = "sha256-WiyRBF3rWLpOZ8mxT89ImRL++Oq9+b88oSKjr4tzCGs=";
+ hash = "sha256-vBfD5SQnVx/UqRoyGJc4PINW/wKuHjpiUEz3WiRCR9A=";
};
nativeBuildInputs = [
@@ -30,7 +30,7 @@ rustPlatform.buildRustPackage rec {
Security
];
- cargoHash = "sha256-R9xxIDqkU7FeulpD7PUM6aHgA67PVgqxHKYtdrjdaUo=";
+ cargoHash = "sha256-xbjUdQs2t+cjplAlNVRN1Zw5CeAYv4+ir4Pvrt+/n9k=";
meta = with lib; {
description = "A simple and easy to use Wikipedia Text User Interface";
diff --git a/pkgs/servers/sql/rqlite/default.nix b/pkgs/servers/sql/rqlite/default.nix
new file mode 100644
index 000000000000..713072953be2
--- /dev/null
+++ b/pkgs/servers/sql/rqlite/default.nix
@@ -0,0 +1,37 @@
+{ lib
+, buildGoModule
+, fetchFromGitHub
+}:
+
+buildGoModule rec {
+ pname = "rqlite";
+ version = "7.6.1";
+
+ src = fetchFromGitHub {
+ owner = "rqlite";
+ repo = pname;
+ rev = "v${version}";
+ sha256 = "sha256-WvEnMAz3dKG8xMlQzm7E0TmAgvsrRED50bb4Ved1+4U=";
+ };
+
+ vendorSha256 = "sha256-qirt5g7dcjAnceejrBnfhDpA4LSEj7eOuznSlfUBUgo=";
+
+ subPackages = [ "cmd/rqlite" "cmd/rqlited" "cmd/rqbench" ];
+
+ # Leaving other flags from https://github.com/rqlite/rqlite/blob/master/package.sh
+ # since automatically retriving those is nontrivial and inessential
+ ldflags = [
+ "-s" "-w"
+ "-X github.com/rqlite/rqlite/cmd.Version=${src.rev}"
+ ];
+
+ # Tests are in a different subPackage which fails trying to access the network
+ doCheck = false;
+
+ meta = with lib; {
+ description = "The lightweight, distributed relational database built on SQLite";
+ homepage = "https://github.com/rqlite/rqlite";
+ license = licenses.mit;
+ maintainers = with maintainers; [ dit7ya ];
+ };
+}
diff --git a/pkgs/servers/traefik/default.nix b/pkgs/servers/traefik/default.nix
index 60eb9a22a829..4bc0a230d3cc 100644
--- a/pkgs/servers/traefik/default.nix
+++ b/pkgs/servers/traefik/default.nix
@@ -2,16 +2,16 @@
buildGoModule rec {
pname = "traefik";
- version = "2.9.6";
+ version = "2.9.8";
# Archive with static assets for webui
src = fetchzip {
url = "https://github.com/traefik/traefik/releases/download/v${version}/traefik-v${version}.src.tar.gz";
- sha256 = "sha256-T1yJT45bCjGizS6bqkzc6EF9uhJ3dhXsSc5X3di6SJ4=";
+ sha256 = "sha256-3vrMh0zrJQhIG9VAlG/iHlOVlUFlE4qd0EkOB0ckAtY=";
stripRoot = false;
};
- vendorSha256 = "sha256-g/UL+cUenWW94afWIGFU2fBSpo48YcUIUaX/1M5vhNk=";
+ vendorSha256 = "sha256-NyI+3wYRZ3L98qwrkDfrbJK4S+Wdx/UJ8FlLAMhaL7A=";
subPackages = [ "cmd/traefik" ];
diff --git a/pkgs/tools/misc/yt-dlp/default.nix b/pkgs/tools/misc/yt-dlp/default.nix
index f99632fac2de..09771083f1c4 100644
--- a/pkgs/tools/misc/yt-dlp/default.nix
+++ b/pkgs/tools/misc/yt-dlp/default.nix
@@ -20,11 +20,11 @@ buildPythonPackage rec {
# The websites yt-dlp deals with are a very moving target. That means that
# downloads break constantly. Because of that, updates should always be backported
# to the latest stable release.
- version = "2023.1.6";
+ version = "2023.2.17";
src = fetchPypi {
inherit pname version;
- sha256 = "sha256-Ong6NnUc7RY2j0CzuoZas5swaJ7YBW8e4jRqo4OaCw8=";
+ sha256 = "sha256-mvkt5e/8GTvbUSFtnr8oh02WGA0gL651Kw2fKmM4Dzo=";
};
propagatedBuildInputs = [ brotli certifi mutagen pycryptodomex websockets ];
diff --git a/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/__init__.py b/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/__init__.py
index 67d7bce0047d..56b68ba27a53 100644
--- a/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/__init__.py
+++ b/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/__init__.py
@@ -29,9 +29,9 @@ def pretty_print_exc(e: BaseException, *, _desc_text: str = "error") -> None:
print(textwrap.indent(extra_info, "\t"), file=sys.stderr, end="")
else:
print(e)
- if e.__context__ is not None:
+ if e.__cause__ is not None:
print("", file=sys.stderr)
- pretty_print_exc(e.__context__, _desc_text="caused by")
+ pretty_print_exc(e.__cause__, _desc_text="caused by")
def main() -> None:
parser = argparse.ArgumentParser(description='render nixos manual bits')
diff --git a/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/docbook.py b/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/docbook.py
index b3728645f75f..28ab53720936 100644
--- a/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/docbook.py
+++ b/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/docbook.py
@@ -28,6 +28,9 @@ class Deflist:
class Heading(NamedTuple):
container_tag: str
level: int
+ # special handling for titles: whether partinfo was already closed from elsewhere
+ # or still needs closing.
+ partintro_closed: bool = False
class DocBookRenderer(Renderer):
__output__ = "docbook"
@@ -251,7 +254,17 @@ class DocBookRenderer(Renderer):
return result + f'<{tag}{attrs_str}>\n'
def heading_close(self, token: Token, tokens: Sequence[Token], i: int, options: OptionsDict,
env: MutableMapping[str, Any]) -> str:
- return ''
+ heading = self._headings[-1]
+ result = ''
+ if heading.container_tag == 'part':
+ # generate the same ids as were previously assigned manually. if this collides we
+ # rely on outside schema validation to catch it!
+ maybe_id = ""
+ assert tokens[i - 2].type == 'heading_open'
+ if id := cast(str, tokens[i - 2].attrs.get('id', "")):
+ maybe_id = " xml:id=" + quoteattr(id + "-intro")
+ result += f""
+ return result
def example_open(self, token: Token, tokens: Sequence[Token], i: int, options: OptionsDict,
env: MutableMapping[str, Any]) -> str:
if id := token.attrs.get('id'):
@@ -266,8 +279,10 @@ class DocBookRenderer(Renderer):
result = []
while len(self._headings):
if level is None or self._headings[-1].level >= level:
- result.append(f"{self._headings[-1].container_tag}>")
- self._headings.pop()
+ heading = self._headings.pop()
+ if heading.container_tag == 'part' and not heading.partintro_closed:
+ result.append("")
+ result.append(f"{heading.container_tag}>")
else:
break
return "\n".join(result)
diff --git a/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/manual.py b/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/manual.py
index ab61d699d7f5..efc8b02e8d6b 100644
--- a/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/manual.py
+++ b/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/manual.py
@@ -2,68 +2,107 @@ import argparse
import json
from abc import abstractmethod
-from collections.abc import MutableMapping, Sequence
+from collections.abc import Mapping, MutableMapping, Sequence
from pathlib import Path
from typing import Any, cast, NamedTuple, Optional, Union
from xml.sax.saxutils import escape, quoteattr
+
+import markdown_it
from markdown_it.token import Token
from markdown_it.utils import OptionsDict
-from .docbook import DocBookRenderer
+from . import options
+from .docbook import DocBookRenderer, Heading
from .md import Converter
-class RenderedSection:
- id: Optional[str]
- chapters: list[str]
-
- def __init__(self, id: Optional[str]) -> None:
- self.id = id
- self.chapters = []
-
-class BaseConverter(Converter):
- _sections: list[RenderedSection]
-
- def __init__(self, manpage_urls: dict[str, str]):
- super().__init__(manpage_urls)
- self._sections = []
-
- def add_section(self, id: Optional[str], chapters: list[Path]) -> None:
- self._sections.append(RenderedSection(id))
- for chpath in chapters:
- try:
- with open(chpath, 'r') as f:
- self._md.renderer._title_seen = False # type: ignore[attr-defined]
- self._sections[-1].chapters.append(self._render(f.read()))
- except Exception as e:
- raise RuntimeError(f"failed to render manual chapter {chpath}") from e
-
- @abstractmethod
- def finalize(self) -> str: raise NotImplementedError()
-
class ManualDocBookRenderer(DocBookRenderer):
- # needed to check correctness of chapters.
- # we may want to use front matter instead of this kind of heuristic.
- _title_seen = False
+ _toplevel_tag: str
+
+ def __init__(self, toplevel_tag: str, manpage_urls: Mapping[str, str],
+ parser: Optional[markdown_it.MarkdownIt] = None):
+ super().__init__(manpage_urls, parser)
+ self._toplevel_tag = toplevel_tag
+ self.rules |= {
+ 'included_sections': lambda *args: self._included_thing("section", *args),
+ 'included_chapters': lambda *args: self._included_thing("chapter", *args),
+ 'included_preface': lambda *args: self._included_thing("preface", *args),
+ 'included_parts': lambda *args: self._included_thing("part", *args),
+ 'included_appendix': lambda *args: self._included_thing("appendix", *args),
+ 'included_options': self.included_options,
+ }
+
+ def render(self, tokens: Sequence[Token], options: OptionsDict,
+ env: MutableMapping[str, Any]) -> str:
+ wanted = { 'h1': 'title' }
+ wanted |= { 'h2': 'subtitle' } if self._toplevel_tag == 'book' else {}
+ for (i, (tag, kind)) in enumerate(wanted.items()):
+ if len(tokens) < 3 * (i + 1):
+ raise RuntimeError(f"missing {kind} ({tag}) heading")
+ token = tokens[3 * i]
+ if token.type != 'heading_open' or token.tag != tag:
+ assert token.map
+ raise RuntimeError(f"expected {kind} ({tag}) heading in line {token.map[0] + 1}", token)
+ for t in tokens[3 * len(wanted):]:
+ if t.type != 'heading_open' or (info := wanted.get(t.tag)) is None:
+ continue
+ assert t.map
+ raise RuntimeError(
+ f"only one {info[0]} heading ({t.markup} [text...]) allowed per "
+ f"{self._toplevel_tag}, but found a second in lines [{t.map[0] + 1}..{t.map[1]}]. "
+ "please remove all such headings except the first or demote the subsequent headings.",
+ t)
+
+ # books get special handling because they have *two* title tags. doing this with
+ # generic code is more complicated than it's worth. the checks above have verified
+ # that both titles actually exist.
+ if self._toplevel_tag == 'book':
+ assert tokens[1].children
+ assert tokens[4].children
+ if (maybe_id := cast(str, tokens[0].attrs.get('id', ""))):
+ maybe_id = "xml:id=" + quoteattr(maybe_id)
+ return (f''
+ f' {self.renderInline(tokens[1].children, options, env)}'
+ f' {self.renderInline(tokens[4].children, options, env)}'
+ f' {super().render(tokens[6:], options, env)}'
+ f'')
+
+ return super().render(tokens, options, env)
def _heading_tag(self, token: Token, tokens: Sequence[Token], i: int, options: OptionsDict,
env: MutableMapping[str, Any]) -> tuple[str, dict[str, str]]:
(tag, attrs) = super()._heading_tag(token, tokens, i, options, env)
- if self._title_seen:
- if token.tag == 'h1':
- assert token.map is not None
- raise RuntimeError(
- "only one title heading (# [text...]) allowed per manual chapter "
- f"but found a second in lines [{token.map[0]}..{token.map[1]}]. "
- "please remove all such headings except the first, split your "
- "chapters, or demote the subsequent headings to (##) or lower.",
- token)
+ # render() has already verified that we don't have supernumerary headings and since the
+ # book tag is handled specially we can leave the check this simple
+ if token.tag != 'h1':
return (tag, attrs)
- self._title_seen = True
- return ("chapter", attrs | {
+ return (self._toplevel_tag, attrs | {
'xmlns': "http://docbook.org/ns/docbook",
'xmlns:xlink': "http://www.w3.org/1999/xlink",
})
+ def _included_thing(self, tag: str, token: Token, tokens: Sequence[Token], i: int,
+ options: OptionsDict, env: MutableMapping[str, Any]) -> str:
+ result = []
+ # close existing partintro. the generic render doesn't really need this because
+ # it doesn't have a concept of structure in the way the manual does.
+ if self._headings and self._headings[-1] == Heading('part', 1):
+ result.append("")
+ self._headings[-1] = self._headings[-1]._replace(partintro_closed=True)
+ # must nest properly for structural includes. this requires saving at least
+ # the headings stack, but creating new renderers is cheap and much easier.
+ r = ManualDocBookRenderer(tag, self._manpage_urls, None)
+ for (included, path) in token.meta['included']:
+ try:
+ result.append(r.render(included, options, env))
+ except Exception as e:
+ raise RuntimeError(f"rendering {path}") from e
+ return "".join(result)
+ def included_options(self, token: Token, tokens: Sequence[Token], i: int, options: OptionsDict,
+ env: MutableMapping[str, Any]) -> str:
+ return cast(str, token.meta['rendered-options'])
+
# TODO minimize docbook diffs with existing conversions. remove soon.
def paragraph_open(self, token: Token, tokens: Sequence[Token], i: int, options: OptionsDict,
env: MutableMapping[str, Any]) -> str:
@@ -76,127 +115,113 @@ class ManualDocBookRenderer(DocBookRenderer):
return f"\n{escape(token.content)}"
def fence(self, token: Token, tokens: Sequence[Token], i: int, options: OptionsDict,
env: MutableMapping[str, Any]) -> str:
- # HACK for temporarily being able to replace md-to-db.sh. pandoc used this syntax to
- # allow md files to inject arbitrary docbook, and manual chapters use it.
- if token.info == '{=docbook}':
- return token.content
info = f" language={quoteattr(token.info)}" if token.info != "" else ""
return f"\n{escape(token.content)}"
-class DocBookSectionConverter(BaseConverter):
- __renderer__ = ManualDocBookRenderer
+class DocBookConverter(Converter):
+ def __renderer__(self, manpage_urls: Mapping[str, str],
+ parser: Optional[markdown_it.MarkdownIt]) -> ManualDocBookRenderer:
+ return ManualDocBookRenderer('book', manpage_urls, parser)
- def finalize(self) -> str:
- result = []
+ _base_paths: list[Path]
+ _revision: str
- for section in self._sections:
- id = "id=" + quoteattr(section.id) if section.id is not None else ""
- result.append(f'')
- result += section.chapters
- result.append(f'')
+ def __init__(self, manpage_urls: Mapping[str, str], revision: str):
+ super().__init__(manpage_urls)
+ self._revision = revision
- return "\n".join(result)
-
-class ManualFragmentDocBookRenderer(ManualDocBookRenderer):
- _tag: str = "chapter"
-
- def _heading_tag(self, token: Token, tokens: Sequence[Token], i: int, options: OptionsDict,
- env: MutableMapping[str, Any]) -> tuple[str, dict[str, str]]:
- (tag, attrs) = super()._heading_tag(token, tokens, i, options, env)
- if token.tag == 'h1':
- return (self._tag, attrs | { 'xmlns:xi': "http://www.w3.org/2001/XInclude" })
- return (tag, attrs)
-
-class DocBookFragmentConverter(Converter):
- __renderer__ = ManualFragmentDocBookRenderer
-
- def convert(self, file: Path, tag: str) -> str:
- assert isinstance(self._md.renderer, ManualFragmentDocBookRenderer)
+ def convert(self, file: Path) -> str:
+ self._base_paths = [ file ]
try:
with open(file, 'r') as f:
- self._md.renderer._title_seen = False
- self._md.renderer._tag = tag
return self._render(f.read())
except Exception as e:
- raise RuntimeError(f"failed to render manual {tag} {file}") from e
+ raise RuntimeError(f"failed to render manual {file}") from e
+
+ def _parse(self, src: str, env: Optional[MutableMapping[str, Any]] = None) -> list[Token]:
+ tokens = super()._parse(src, env)
+ for token in tokens:
+ if token.type != "fence" or not token.info.startswith("{=include=} "):
+ continue
+ typ = token.info[12:].strip()
+ if typ == 'options':
+ token.type = 'included_options'
+ self._parse_options(token)
+ elif typ in [ 'sections', 'chapters', 'preface', 'parts', 'appendix' ]:
+ token.type = 'included_' + typ
+ self._parse_included_blocks(token, env)
+ else:
+ raise RuntimeError(f"unsupported structural include type '{typ}'")
+ return tokens
+
+ def _parse_included_blocks(self, token: Token, env: Optional[MutableMapping[str, Any]]) -> None:
+ assert token.map
+ included = token.meta['included'] = []
+ for (lnum, line) in enumerate(token.content.splitlines(), token.map[0] + 2):
+ line = line.strip()
+ path = self._base_paths[-1].parent / line
+ if path in self._base_paths:
+ raise RuntimeError(f"circular include found in line {lnum}")
+ try:
+ self._base_paths.append(path)
+ with open(path, 'r') as f:
+ tokens = self._parse(f.read(), env)
+ included.append((tokens, path))
+ self._base_paths.pop()
+ except Exception as e:
+ raise RuntimeError(f"processing included file {path} from line {lnum}") from e
+
+ def _parse_options(self, token: Token) -> None:
+ assert token.map
+
+ items = {}
+ for (lnum, line) in enumerate(token.content.splitlines(), token.map[0] + 2):
+ if len(args := line.split(":", 1)) != 2:
+ raise RuntimeError(f"options directive with no argument in line {lnum}")
+ (k, v) = (args[0].strip(), args[1].strip())
+ if k in items:
+ raise RuntimeError(f"duplicate options directive {k} in line {lnum}")
+ items[k] = v
+ try:
+ id_prefix = items.pop('id-prefix')
+ varlist_id = items.pop('list-id')
+ source = items.pop('source')
+ except KeyError as e:
+ raise RuntimeError(f"options directive {e} missing in block at line {token.map[0] + 1}")
+ if items.keys():
+ raise RuntimeError(
+ f"unsupported options directives in block at line {token.map[0] + 1}",
+ " ".join(items.keys()))
+
+ try:
+ conv = options.DocBookConverter(
+ self._manpage_urls, self._revision, False, 'fragment', varlist_id, id_prefix)
+ with open(self._base_paths[-1].parent / source, 'r') as f:
+ conv.add_options(json.load(f))
+ token.meta['rendered-options'] = conv.finalize(fragment=True)
+ except Exception as e:
+ raise RuntimeError(f"processing options block in line {token.map[0] + 1}") from e
-class Section:
- id: Optional[str] = None
- chapters: list[str]
-
- def __init__(self) -> None:
- self.chapters = []
-
-class SectionAction(argparse.Action):
- def __call__(self, parser: argparse.ArgumentParser, ns: argparse.Namespace,
- values: Union[str, Sequence[Any], None], opt_str: Optional[str] = None) -> None:
- sections = getattr(ns, self.dest)
- if sections is None: sections = []
- sections.append(Section())
- setattr(ns, self.dest, sections)
-
-class SectionIDAction(argparse.Action):
- def __call__(self, parser: argparse.ArgumentParser, ns: argparse.Namespace,
- values: Union[str, Sequence[Any], None], opt_str: Optional[str] = None) -> None:
- sections = getattr(ns, self.dest)
- if sections is None: raise argparse.ArgumentError(self, "no active section")
- sections[-1].id = cast(str, values)
-
-class ChaptersAction(argparse.Action):
- def __call__(self, parser: argparse.ArgumentParser, ns: argparse.Namespace,
- values: Union[str, Sequence[Any], None], opt_str: Optional[str] = None) -> None:
- sections = getattr(ns, self.dest)
- if sections is None: raise argparse.ArgumentError(self, "no active section")
- sections[-1].chapters.extend(map(Path, cast(Sequence[str], values)))
-
-class SingleFileAction(argparse.Action):
- def __call__(self, parser: argparse.ArgumentParser, ns: argparse.Namespace,
- values: Union[str, Sequence[Any], None], opt_str: Optional[str] = None) -> None:
- assert isinstance(values, Sequence)
- chapters = getattr(ns, self.dest) or []
- chapters.append((Path(values[0]), Path(values[1])))
- setattr(ns, self.dest, chapters)
-
-def _build_cli_db_section(p: argparse.ArgumentParser) -> None:
+def _build_cli_db(p: argparse.ArgumentParser) -> None:
p.add_argument('--manpage-urls', required=True)
- p.add_argument("outfile")
- p.add_argument("--section", dest="contents", action=SectionAction, nargs=0)
- p.add_argument("--section-id", dest="contents", action=SectionIDAction)
- p.add_argument("--chapters", dest="contents", action=ChaptersAction, nargs='+')
+ p.add_argument('--revision', required=True)
+ p.add_argument('infile', type=Path)
+ p.add_argument('outfile', type=Path)
-def _build_cli_db_fragment(p: argparse.ArgumentParser) -> None:
- p.add_argument('--manpage-urls', required=True)
- p.add_argument("--chapter", action=SingleFileAction, required=True, nargs=2)
- p.add_argument("--section", action=SingleFileAction, required=True, nargs=2)
-
-def _run_cli_db_section(args: argparse.Namespace) -> None:
+def _run_cli_db(args: argparse.Namespace) -> None:
with open(args.manpage_urls, 'r') as manpage_urls:
- md = DocBookSectionConverter(json.load(manpage_urls))
- for section in args.contents:
- md.add_section(section.id, section.chapters)
- with open(args.outfile, 'w') as f:
- f.write(md.finalize())
-
-def _run_cli_db_fragment(args: argparse.Namespace) -> None:
- with open(args.manpage_urls, 'r') as manpage_urls:
- md = DocBookFragmentConverter(json.load(manpage_urls))
- for kind in [ 'chapter', 'section' ]:
- for (target, file) in getattr(args, kind):
- converted = md.convert(file, kind)
- target.parent.mkdir(parents=True, exist_ok=True)
- target.write_text(converted)
+ md = DocBookConverter(json.load(manpage_urls), args.revision)
+ converted = md.convert(args.infile)
+ args.outfile.write_text(converted)
def build_cli(p: argparse.ArgumentParser) -> None:
formats = p.add_subparsers(dest='format', required=True)
- _build_cli_db_section(formats.add_parser('docbook-section'))
- _build_cli_db_fragment(formats.add_parser('docbook-fragment'))
+ _build_cli_db(formats.add_parser('docbook'))
def run_cli(args: argparse.Namespace) -> None:
- if args.format == 'docbook-section':
- _run_cli_db_section(args)
- elif args.format == 'docbook-fragment':
- _run_cli_db_fragment(args)
+ if args.format == 'docbook':
+ _run_cli_db(args)
else:
raise RuntimeError('format not hooked up', args)
diff --git a/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/options.py b/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/options.py
index 95091d3cdd28..3cba36140bb4 100644
--- a/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/options.py
+++ b/pkgs/tools/nix/nixos-render-docs/src/nixos_render_docs/options.py
@@ -29,7 +29,7 @@ class BaseConverter(Converter):
_options: dict[str, RenderedOption]
- def __init__(self, manpage_urls: dict[str, str],
+ def __init__(self, manpage_urls: Mapping[str, str],
revision: str,
markdown_by_default: bool):
super().__init__(manpage_urls)
@@ -231,10 +231,11 @@ class DocBookConverter(BaseConverter):
def _decl_def_footer(self) -> list[str]:
return [ "" ]
- def finalize(self) -> str:
+ def finalize(self, *, fragment: bool = False) -> str:
result = []
- result.append('')
+ if not fragment:
+ result.append('')
if self._document_type == 'appendix':
result += [
'