diff options
-rw-r--r-- | doc/default.nix | 2 | ||||
-rw-r--r-- | doc/languages-frameworks/beam.xml | 344 |
2 files changed, 182 insertions, 164 deletions
diff --git a/doc/default.nix b/doc/default.nix index 540a209c2ac9..cfd51fba257e 100644 --- a/doc/default.nix +++ b/doc/default.nix @@ -26,7 +26,7 @@ pkgs.stdenv.mkDerivation { extraHeader = ''xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink" ''; in '' { - pandoc '${inputFile}' -w docbook ${lib.optionalString useChapters "--chapters"} \ + pandoc '${inputFile}' -w docbook ${lib.optionalString useChapters "--top-level-division=chapter"} \ --smart \ | sed -e 's|<ulink url=|<link xlink:href=|' \ -e 's|</ulink>|</link>|' \ diff --git a/doc/languages-frameworks/beam.xml b/doc/languages-frameworks/beam.xml index 28dec9f77dea..1a18ed27237c 100644 --- a/doc/languages-frameworks/beam.xml +++ b/doc/languages-frameworks/beam.xml @@ -2,30 +2,29 @@ xmlns:xlink="http://www.w3.org/1999/xlink" xml:id="sec-beam"> - <title>Beam Languages (Erlang, Elixir & LFE)</title> + <title>BEAM Languages (Erlang, Elixir & LFE)</title> <section xml:id="beam-introduction"> <title>Introduction</title> <para> - In this document and related Nix expressions we use the term - <emphasis>Beam</emphasis> to describe the environment. BEAM is - the name of the Erlang Virtial Machine and, as far as we know, - from a packaging perspective all languages that run on BEAM are - interchangable. The things that do change, like the build - system, are transperant to the users of the package. So we make - no distinction. + In this document and related Nix expressions, we use the term, + <emphasis>BEAM</emphasis>, to describe the environment. BEAM is the name + of the Erlang Virtual Machine and, as far as we're concerned, from a + packaging perspective, all languages that run on the BEAM are + interchangeable. That which varies, like the build system, is transparent + to users of any given BEAM package, so we make no distinction. </para> </section> <section xml:id="beam-structure"> <title>Structure</title> <para> - All Beam-related things are available via top-level + All BEAM-related expressions are available via the top-level <literal>beam</literal> attribute, which includes: </para> <itemizedlist> <listitem> <para> - <literal>interpreters</literal>: contains a set of compilers running - on Beam, including multiple Erlang/OTP versions + <literal>interpreters</literal>: a set of compilers running on the + BEAM, including multiple Erlang/OTP versions (<literal>beam.interpreters.erlangR19</literal>, etc), Elixir (<literal>beam.interpreters.elixir</literal>) and LFE (<literal>beam.interpreters.lfe</literal>). @@ -33,36 +32,37 @@ </listitem> <listitem> <para> - <literal>packages</literal>: contains a set of package sets, each - compiled with a specific Erlang/OTP version, e.g. + <literal>packages</literal>: a set of package sets, each compiled with + a specific Erlang/OTP version, e.g. <literal>beam.packages.erlangR19</literal>. </para> </listitem> </itemizedlist> <para> - Default Erlang compiler is defined by - <literal>beam.interpreters.erlang</literal> and aliased as - <literal>erlang</literal>. Default package set with Beam packages is - defined by <literal>beam.packages.erlang</literal> and aliased at - top-level as <literal>beamPackages</literal>. + The default Erlang compiler, defined by + <literal>beam.interpreters.erlang</literal>, is aliased as + <literal>erlang</literal>. The default BEAM package set is defined by + <literal>beam.packages.erlang</literal> and aliased at the top level as + <literal>beamPackages</literal>. </para> <para> - If you want to create a package set built with a custom Erlang version, - use lambda <literal>beam.packagesWith</literal>, which accepts an - Erlang/OTP derivative and produces a package set similar to + To create a package set built with a custom Erlang version, use the + lambda, <literal>beam.packagesWith</literal>, which accepts an Erlang/OTP + derivation and produces a package set similar to <literal>beam.packages.erlang</literal>. </para> <para> Many Erlang/OTP distributions available in - <literal>beam.interpreters</literal> have their versions with ODBC and/or - Java enabled. For example there's - <literal>beam.interpreters.erlangR19_odbc_javac</literal> which + <literal>beam.interpreters</literal> have versions with ODBC and/or Java + enabled. For example, there's + <literal>beam.interpreters.erlangR19_odbc_javac</literal>, which corresponds to <literal>beam.interpreters.erlangR19</literal>. </para> - <para> - We also provide <literal>beam.packages.erlang.callPackage</literal>, which - simplifies writing Beam package definitions, by injecting all packages from - <literal>beam.packages.erlang</literal> into top-level context. + <para xml:id="erlang-call-package"> + We also provide the lambda, + <literal>beam.packages.erlang.callPackage</literal>, which simplifies + writing BEAM package definitions by injecting all packages from + <literal>beam.packages.erlang</literal> into the top-level context. </para> </section> <section xml:id="build-tools"> @@ -70,42 +70,52 @@ <section xml:id="build-tools-rebar3"> <title>Rebar3</title> <para> - By default Rebar3 wants to manage it's own dependencies. This is perfectly - acceptable in the normal non-Nix setup. In the Nix world it is not. To - support this we have created two versions of rebar3, - <literal>rebar3</literal> and <literal>rebar3-open</literal>. The - <literal>rebar3</literal> version has been patched to remove the ability - to download anything from it. If you are not running it a nix-shell or a - nix-build then its probably not going to work for you. - <literal>rebar3-open</literal> is the normal, un-modified rebar3. It - should work exactly as would any other version of rebar3. Any Erlang - package should rely on <literal>rebar3</literal> and thats really what you - should be using too. See <literal>buildRebar3</literal> below. + By default, Rebar3 wants to manage its own dependencies. This is perfectly + acceptable in the normal, non-Nix setup, but in the Nix world, it is not. + To rectify this, we provide two versions of Rebar3: + <itemizedlist> + <listitem> + <para> + <literal>rebar3</literal>: patched to remove the ability to download + anything. When not running it via <literal>nix-shell</literal> or + <literal>nix-build</literal>, it's probably not going to work as + desired. + </para> + </listitem> + <listitem> + <para> + <literal>rebar3-open</literal>: the normal, unmodified Rebar3. It + should work exactly as would any other version of Rebar3. Any Erlang + package should rely on <literal>rebar3</literal> instead. See <xref + linkend="rebar3-packages"/>. + </para> + </listitem> + </itemizedlist> </para> </section> <section xml:id="build-tools-other"> <title>Mix & Erlang.mk</title> <para> - Both Mix and Erlang.mk work exactly as you would expect. There - is a bootstrap process that needs to be run for both of - them. However, that is supported by the - <literal>buildMix</literal> and <literal>buildErlangMk</literal> derivations. + Both Mix and Erlang.mk work exactly as expected. There is a bootstrap + process that needs to be run for both, however, which is supported by the + <literal>buildMix</literal> and <literal>buildErlangMk</literal> + derivations, respectively. </para> </section> </section> <section xml:id="how-to-install-beam-packages"> - <title>How to install Beam packages</title> + <title>How to Install BEAM Packages</title> <para> - Beam packages are not registered in the top level simply because they are + BEAM packages are not registered at the top level, simply because they are not relevant to the vast majority of Nix users. They are installable using - the <literal>beam.packages.erlang</literal> attribute set and aliased as - <literal>beamPackages</literal>. This attribute points at packages built by - the default Erlang/OTP version in Nixpkgs as defined by + the <literal>beam.packages.erlang</literal> attribute set (aliased as + <literal>beamPackages</literal>), which points to packages built by the + default Erlang/OTP version in Nixpkgs, as defined by <literal>beam.interpreters.erlang</literal>. - You can list the avialable packages in the - <literal>beamPackages</literal> with the following command: + To list the available packages in + <literal>beamPackages</literal>, use the following command: </para> <programlisting> @@ -119,145 +129,152 @@ beamPackages.meck meck-0.8.3 beamPackages.rebar3-pc pc-1.1.0 </programlisting> <para> - To install any of those packages into your profile, refer to them by - their attribute path (first column): + To install any of those packages into your profile, refer to them by their + attribute path (first column): </para> <programlisting> $ nix-env -f "<nixpkgs>" -iA beamPackages.ibrowse </programlisting> <para> - The attribute path of any Beam packages corresponds to the name - of that particular package in Hex or its OTP Application/Release name. + The attribute path of any BEAM package corresponds to the name of that + particular package in <link xlink:href="https://hex.pm">Hex</link> or its + OTP Application/Release name. </para> </section> <section xml:id="packaging-beam-applications"> - <title>Packaging Beam Applications</title> + <title>Packaging BEAM Applications</title> <section xml:id="packaging-erlang-applications"> <title>Erlang Applications</title> <section xml:id="rebar3-packages"> <title>Rebar3 Packages</title> <para> - There is a Nix function called <literal>buildRebar3</literal> (defined - in <literal>beam.packages.erlang.buildRebar3</literal> and aliased at - top-level). We use this function to make a derivation that understands - how to build the rebar3 project. For example, the expression we use to - build the <link - xlink:href="https://github.com/erlang-nix/hex2nix">hex2nix</link> - project follows. + The Nix function, <literal>buildRebar3</literal>, defined in + <literal>beam.packages.erlang.buildRebar3</literal> and aliased at the + top level, can be used to build a derivation that understands how to + build a Rebar3 project. For example, we can build <link + xlink:href="https://github.com/erlang-nix/hex2nix">hex2nix</link> as + follows: </para> <programlisting> - {stdenv, fetchFromGitHub, buildRebar3, ibrowse, jsx, erlware_commons }: + { stdenv, fetchFromGitHub, buildRebar3, ibrowse, jsx, erlware_commons }: - buildRebar3 rec { - name = "hex2nix"; - version = "0.0.1"; + buildRebar3 rec { + name = "hex2nix"; + version = "0.0.1"; - src = fetchFromGitHub { - owner = "ericbmerritt"; - repo = "hex2nix"; - rev = "${version}"; - sha256 = "1w7xjidz1l5yjmhlplfx7kphmnpvqm67w99hd2m7kdixwdxq0zqg"; - }; + src = fetchFromGitHub { + owner = "ericbmerritt"; + repo = "hex2nix"; + rev = "${version}"; + sha256 = "1w7xjidz1l5yjmhlplfx7kphmnpvqm67w99hd2m7kdixwdxq0zqg"; + }; beamDeps = [ ibrowse jsx erlware_commons ]; } </programlisting> <para> - This derivation is callable with - <literal>beam.packages.erlang.callPackage</literal> (see above). If you - want to call this package using normal <literal>callPackage</literal>, - you should refer to dependency packages via + Such derivations are callable with + <literal>beam.packages.erlang.callPackage</literal> (see <xref + linkend="erlang-call-package"/>). To call this package using the normal + <literal>callPackage</literal>, refer to dependency packages via <literal>beamPackages</literal>, e.g. <literal>beamPackages.ibrowse</literal>. </para> <para> - The only visible difference between this derivation and - something like <literal>stdenv.mkDerivation</literal> is that we - have added <literal>beamDeps</literal> to the derivation. If - you add your Beam dependencies here they will be correctly - handled by the system. + Notably, <literal>buildRebar3</literal> includes + <literal>beamDeps</literal>, while + <literal>stdenv.mkDerivation</literal> does not. BEAM dependencies added + there will be correctly handled by the system. </para> <para> - If your package needs to compile native code via Rebar's port - compilation mechenism. You should add <literal>compilePort = - true;</literal> to the derivation. + If a package needs to compile native code via Rebar3's port compilation + mechanism, add <literal>compilePort = true;</literal> to the derivation. </para> </section> <section xml:id="erlang-mk-packages"> <title>Erlang.mk Packages</title> <para> - Erlang.mk functions almost identically to Rebar. The only real - difference is that <literal>buildErlangMk</literal> is called - instead of <literal>buildRebar3</literal> + Erlang.mk functions similarly to Rebar3, except we use + <literal>buildErlangMk</literal> instead of + <literal>buildRebar3</literal>. </para> <programlisting> - { buildErlangMk, fetchHex, cowlib, ranch }: - buildErlangMk { - name = "cowboy"; + { buildErlangMk, fetchHex, cowlib, ranch }: + + buildErlangMk { + name = "cowboy"; + version = "1.0.4"; + + src = fetchHex { + pkg = "cowboy"; version = "1.0.4"; - src = fetchHex { - pkg = "cowboy"; - version = "1.0.4"; - sha256 = - "6a0edee96885fae3a8dd0ac1f333538a42e807db638a9453064ccfdaa6b9fdac"; - }; - beamDeps = [ cowlib ranch ]; - - meta = { - description = ''Small, fast, modular HTTP server written in - Erlang.''; - license = stdenv.lib.licenses.isc; - homepage = "https://github.com/ninenines/cowboy"; - }; + sha256 = "6a0edee96885fae3a8dd0ac1f333538a42e807db638a9453064ccfdaa6b9fdac"; + }; + + beamDeps = [ cowlib ranch ]; + + meta = { + description = '' + Small, fast, modular HTTP server written in Erlang + ''; + license = stdenv.lib.licenses.isc; + homepage = https://github.com/ninenines/cowboy; + }; } </programlisting> </section> <section xml:id="mix-packages"> <title>Mix Packages</title> <para> - Mix functions almost identically to Rebar. The only real - difference is that <literal>buildMix</literal> is called - instead of <literal>buildRebar3</literal> + Mix functions similarly to Rebar3, except we use + <literal>buildMix</literal> instead of <literal>buildRebar3</literal>. </para> <programlisting> { buildMix, fetchHex, plug, absinthe }: + buildMix { name = "absinthe_plug"; version = "1.0.0"; + src = fetchHex { pkg = "absinthe_plug"; version = "1.0.0"; - sha256 = - "08459823fe1fd4f0325a8bf0c937a4520583a5a26d73b193040ab30a1dfc0b33"; + sha256 = "08459823fe1fd4f0325a8bf0c937a4520583a5a26d73b193040ab30a1dfc0b33"; }; - beamDeps = [ plug absinthe ]; + + beamDeps = [ plug absinthe ]; meta = { - description = ''A plug for Absinthe, an experimental GraphQL - toolkit''; + description = '' + A plug for Absinthe, an experimental GraphQL toolkit + ''; license = stdenv.lib.licenses.bsd3; - homepage = "https://github.com/CargoSense/absinthe_plug"; - }; - } + homepage = https://github.com/CargoSense/absinthe_plug; + }; + } </programlisting> <para> - Alternatively one can use <literal>buildHex</literal> as a shortcut for the above: + Alternatively, we can use <literal>buildHex</literal> as a shortcut: </para> <programlisting> { buildHex, buildMix, plug, absinthe }: + buildHex { name = "absinthe_plug"; version = "1.0.0"; - sha256 = - "08459823fe1fd4f0325a8bf0c937a4520583a5a26d73b193040ab30a1dfc0b33"; + + sha256 = "08459823fe1fd4f0325a8bf0c937a4520583a5a26d73b193040ab30a1dfc0b33"; + builder = buildMix; - beamDeps = [ plug absinthe]; + + beamDeps = [ plug absinthe ]; meta = { - description = ''A plug for Absinthe, an experimental GraphQL - toolkit''; + description = '' + A plug for Absinthe, an experimental GraphQL toolkit + ''; license = stdenv.lib.licenses.bsd3; - homepage = "https://github.com/CargoSense/absinthe_plug"; + homepage = https://github.com/CargoSense/absinthe_plug; }; } </programlisting> @@ -265,18 +282,18 @@ $ nix-env -f "<nixpkgs>" -iA beamPackages.ibrowse </section> </section> <section xml:id="how-to-develop"> - <title>How to develop</title> + <title>How to Develop</title> <section xml:id="accessing-an-environment"> <title>Accessing an Environment</title> <para> - Often, all you want to do is be able to access a valid - environment that contains a specific package and its - dependencies. we can do that with the <literal>env</literal> - part of a derivation. For example, lets say we want to access an - erlang repl with ibrowse loaded up. We could do the following. + Often, we simply want to access a valid environment that contains a + specific package and its dependencies. We can accomplish that with the + <literal>env</literal> attribute of a derivation. For example, let's say + we want to access an Erlang REPL with <literal>ibrowse</literal> loaded + up. We could do the following: </para> <programlisting> - ~/w/nixpkgs ❯❯❯ nix-shell -A beamPackages.ibrowse.env --run "erl" + $ nix-shell -A beamPackages.ibrowse.env --run "erl" Erlang/OTP 18 [erts-7.0] [source] [64-bit] [smp:4:4] [async-threads:10] [hipe] [kernel-poll:false] Eshell V7.0 (abort with ^G) @@ -317,20 +334,19 @@ $ nix-env -f "<nixpkgs>" -iA beamPackages.ibrowse 2> </programlisting> <para> - Notice the <literal>-A beamPackages.ibrowse.env</literal>.That - is the key to this functionality. + Notice the <literal>-A beamPackages.ibrowse.env</literal>. That is the key + to this functionality. </para> </section> <section xml:id="creating-a-shell"> <title>Creating a Shell</title> <para> Getting access to an environment often isn't enough to do real - development. Many times we need to create a - <literal>shell.nix</literal> file and do our development inside - of the environment specified by that file. This file looks a lot - like the packaging described above. The main difference is that - <literal>src</literal> points to project root and we call the - package directly. + development. Usually, we need to create a <literal>shell.nix</literal> + file and do our development inside of the environment specified therein. + This file looks a lot like the packaging described above, except that + <literal>src</literal> points to the project root and we call the package + directly. </para> <programlisting> { pkgs ? import "<nixpkgs"> {} }: @@ -349,13 +365,14 @@ let drv = beamPackages.callPackage f {}; in - drv + + drv </programlisting> <section xml:id="building-in-a-shell"> - <title>Building in a shell (for mix projects)</title> + <title>Building in a Shell (for Mix Projects)</title> <para> - We can leverage the support of the Derivation, regardless of - which build Derivation is called by calling the commands themselves. + We can leverage the support of the derivation, irrespective of the build + derivation, by calling the commands themselves. </para> <programlisting> # ============================================================================= @@ -415,42 +432,43 @@ analyze: build plt </programlisting> <para> - If you add the <literal>shell.nix</literal> as described and - user rebar as follows things should simply work. Aside from the + Using a <literal>shell.nix</literal> as described (see <xref + linkend="creating-a-shell"/>) should just work. Aside from <literal>test</literal>, <literal>plt</literal>, and - <literal>analyze</literal> the talks work just fine for all of - the build Derivations. + <literal>analyze</literal>, the Make targets work just fine for all of the + build derivations. </para> </section> </section> </section> <section xml:id="generating-packages-from-hex-with-hex2nix"> - <title>Generating Packages from Hex with Hex2Nix</title> + <title>Generating Packages from Hex with <literal>hex2nix</literal></title> <para> - Updating the Hex packages requires the use of the - <literal>hex2nix</literal> tool. Given the path to the Erlang - modules (usually - <literal>pkgs/development/erlang-modules</literal>). It will - dump a file called - <literal>hex-packages.nix</literal>. That file will contain all - the packages that use a recognized build system in Hex. However, - it can't know whether or not all those packages are buildable. + Updating the <link xlink:href="https://hex.pm">Hex</link> package set + requires <link + xlink:href="https://github.com/erlang-nix/hex2nix">hex2nix</link>. Given the + path to the Erlang modules (usually + <literal>pkgs/development/erlang-modules</literal>), it will dump a file + called <literal>hex-packages.nix</literal>, containing all the packages that + use a recognized build system in <link + xlink:href="https://hex.pm">Hex</link>. It can't be determined, however, + whether every package is buildable. </para> <para> - To make life easier for our users, it makes good sense to go - ahead and attempt to build all those packages and remove the - ones that don't build. To do that, simply run the command (in - the root of your <literal>nixpkgs</literal> repository). that follows. + To make life easier for our users, try to build every <link + xlink:href="https://hex.pm">Hex</link> package and remove those that fail. + To do that, simply run the following command in the root of your + <literal>nixpkgs</literal> repository: </para> <programlisting> $ nix-build -A beamPackages </programlisting> <para> - That will build every package in - <literal>beamPackages</literal>. Then you can go through and - manually remove the ones that fail. Hopefully, someone will - improve <literal>hex2nix</literal> in the future to automate - that. + That will attempt to build every package in + <literal>beamPackages</literal>. Then manually remove those that fail. + Hopefully, someone will improve <link + xlink:href="https://github.com/erlang-nix/hex2nix">hex2nix</link> in the + future to automate the process. </para> </section> </section> |