summary refs log tree commit diff
path: root/nixos/doc/manual/development/meta-attributes.xml
diff options
context:
space:
mode:
authorEric Sagnes <eric.sagnes@gmail.com>2016-08-29 16:54:25 +0900
committerRobin Gloster <mail@glob.in>2016-08-29 07:54:25 +0000
commitaa8e663b6e6f6e0c47000ab509cbe7e0f35a8aad (patch)
tree31f8f4a314fe2da96d9bc678195a5ab3de973ddb /nixos/doc/manual/development/meta-attributes.xml
parentda6e81ff6bf1e1f008f4c1ee0a0c67a722ca6b18 (diff)
downloadnixpkgs-aa8e663b6e6f6e0c47000ab509cbe7e0f35a8aad.tar
nixpkgs-aa8e663b6e6f6e0c47000ab509cbe7e0f35a8aad.tar.gz
nixpkgs-aa8e663b6e6f6e0c47000ab509cbe7e0f35a8aad.tar.bz2
nixpkgs-aa8e663b6e6f6e0c47000ab509cbe7e0f35a8aad.tar.lz
nixpkgs-aa8e663b6e6f6e0c47000ab509cbe7e0f35a8aad.tar.xz
nixpkgs-aa8e663b6e6f6e0c47000ab509cbe7e0f35a8aad.tar.zst
nixpkgs-aa8e663b6e6f6e0c47000ab509cbe7e0f35a8aad.zip
nixos doc: add modules meta-attributes (#18078)
Diffstat (limited to 'nixos/doc/manual/development/meta-attributes.xml')
-rw-r--r--nixos/doc/manual/development/meta-attributes.xml62
1 files changed, 62 insertions, 0 deletions
diff --git a/nixos/doc/manual/development/meta-attributes.xml b/nixos/doc/manual/development/meta-attributes.xml
new file mode 100644
index 00000000000..cebd16c2a9d
--- /dev/null
+++ b/nixos/doc/manual/development/meta-attributes.xml
@@ -0,0 +1,62 @@
+<section xmlns="http://docbook.org/ns/docbook"
+        xmlns:xlink="http://www.w3.org/1999/xlink"
+        xmlns:xi="http://www.w3.org/2001/XInclude"
+        version="5.0"
+        xml:id="sec-meta-attributes">
+
+<title>Meta-attributes</title>
+
+<para>Like Nix packages, NixOS modules can declare meta-attributes to provide 
+  extra information.  Module meta-attributes are defined in the 
+  <filename 
+    xlink:href="https://github.com/NixOS/nixpkgs/blob/master/nixos/modules/misc/meta.nix">meta.nix</filename> 
+  special module.</para>
+
+<para><literal>meta</literal> is a top level attribute like 
+  <literal>options</literal> and <literal>config</literal>. Available 
+  meta-attributes are <literal>maintainers</literal> and 
+  <literal>doc</literal>.</para>
+
+<para>Each of the meta-attributes must be defined at most once per module 
+  file.</para>
+
+<programlisting>
+{ config, lib, pkgs, ... }:
+{
+  options = {
+    ...
+  };
+  
+  config = {
+    ...
+  };
+  
+  meta = {
+    maintainers = with lib.maintainers; [ ericsagnes ]; <co 
+      xml:id='modules-meta-1' />
+    doc = ./default.xml; <co xml:id='modules-meta-2' />
+  };
+}
+</programlisting>
+
+<calloutlist>
+ <callout arearefs='modules-meta-1'>
+  <para>
+    <varname>maintainers</varname> contains a list of the module maintainers.
+  </para>
+ </callout>
+
+ <callout arearefs='modules-meta-2'>
+  <para>
+    <varname>doc</varname> point to a valid docbook file containing the module 
+    documentation, its contents are automatically added to the <xref 
+      linkend="ch-configuration"/>.
+    Changes to a module documentation must be checked to be non-breaking by 
+    building the NixOS manual.
+  </para>
+  <programlisting>$ nix-build nixos/release.nix -A manual</programlisting>
+ </callout>
+
+</calloutlist>
+
+</section>