svn commit: r54612 - in head/en_US.ISO8859-1/books/porters-handbook: flavors special uses
Sergio Carlavilla Delgado
carlavilla at FreeBSD.org
Mon Oct 19 17:41:55 UTC 2020
Author: carlavilla
Date: Mon Oct 19 17:41:54 2020
New Revision: 54612
URL: https://svnweb.freebsd.org/changeset/doc/54612
Log:
Update porters handbook for Lua changes
Submitted by: andrew_tao173.riddles.org.uk
Approved by: mat@
Differential Revision: https://reviews.freebsd.org/D24430
Modified:
head/en_US.ISO8859-1/books/porters-handbook/flavors/chapter.xml
head/en_US.ISO8859-1/books/porters-handbook/special/chapter.xml
head/en_US.ISO8859-1/books/porters-handbook/uses/chapter.xml
Modified: head/en_US.ISO8859-1/books/porters-handbook/flavors/chapter.xml
==============================================================================
--- head/en_US.ISO8859-1/books/porters-handbook/flavors/chapter.xml Mon Oct 19 15:25:04 2020 (r54611)
+++ head/en_US.ISO8859-1/books/porters-handbook/flavors/chapter.xml Mon Oct 19 17:41:54 2020 (r54612)
@@ -424,4 +424,28 @@ USE_PYTHON= distutils allflavors</programlisting>
USES= python:3.5+</programlisting>
</example>
</sect1>
+
+ <sect1 xml:id="flavors-auto-lua">
+ <title><literal>USES=lua</literal> and Flavors</title>
+ <para>When using <link
+ linkend="uses-lua"><literal>USES=lua:module</literal></link>
+ or <link
+ linkend="uses-lua"><literal>USES=lua:flavors</literal></link>,
+ the port will automatically have <varname>FLAVORS</varname>
+ filled in with the <application>Lua</application> versions it
+ supports. However, it is not expected that ordinary
+ applications (rather than <application>Lua</application>
+ modules) should use this feature; most applications that embed
+ or otherwise use <application>Lua</application> should simply
+ use <literal>USES=lua</literal>.</para>
+
+ <para><varname>LUA_FLAVOR</varname> is available (and must be
+ used) to depend on the correct version of dependencies
+ regardless of whether the port used the
+ <literal>flavors</literal> or <literal>module</literal>
+ parameters.</para>
+
+ <para>See <xref linkend="using-lua" /> for further
+ information.</para>
+ </sect1>
</chapter>
Modified: head/en_US.ISO8859-1/books/porters-handbook/special/chapter.xml
==============================================================================
--- head/en_US.ISO8859-1/books/porters-handbook/special/chapter.xml Mon Oct 19 15:25:04 2020 (r54611)
+++ head/en_US.ISO8859-1/books/porters-handbook/special/chapter.xml Mon Oct 19 17:41:54 2020 (r54612)
@@ -6390,22 +6390,157 @@ PLIST_SUB+= VERSION="${VER_STR}"
application has to be modified to find the expected version.
But it can be solved by adding some additional flags to the
compiler and linker.</para>
+
+ <para>Applications that use <application>Lua</application>
+ should normally build for just one version. However, loadable
+ modules for Lua are built in a separate flavor for each Lua
+ version that they support, and dependencies on such modules
+ should specify the flavor using the
+ <literal>@${LUA_FLAVOR}</literal> suffix on the port
+ origin.</para>
+
</sect2>
<sect2 xml:id="lua-version">
<title>Version Selection</title>
- <para>A port using <application>Lua</application> only needs to
- have this line:</para>
+ <para>A port using <application>Lua</application> should
+ have a line of this form:</para>
<programlisting>USES= lua</programlisting>
- <para>If a specific version of Lua is needed, instructions on
- how to select it are given in the <link
- linkend="uses-lua"><literal>USES=lua</literal></link> part
- of <xref linkend="uses"/>.</para>
+ <para>If a specific version of Lua, or range of versions, is
+ needed, it can be specified as a parameter in the form
+ <literal>XY</literal> (which may be used multiple times),
+ <literal>XY+</literal>, <literal>-XY</literal>, or
+ <literal>XY-ZA</literal>. The default version of
+ <application>Lua</application> as set via
+ <varname>DEFAULT_VERSIONS</varname> will be used if it falls
+ in the requested range, otherwise the closest requested
+ version to the default will be used. For example:</para>
+
+ <programlisting>USES= lua:52-53</programlisting>
+
+ <para>Note that no attempt is made to adjust the version
+ selection based on the presence of any already-installed
+ <application>Lua</application> version.</para>
+
+ <note>
+ <para>The <literal>XY+</literal> form of version specification
+ should not be used without careful consideration; the
+ <application>Lua</application> API changes to some extent in
+ every version, and configuration tools like
+ <application>CMake</application> or
+ <application>Autoconf</application> will often fail to work
+ on future versions of <application>Lua</application> until
+ updated to do so.</para>
+ </note>
</sect2>
+ <sect2 xml:id="lua-version-config">
+ <title>Configuration and Compiler flags</title>
+
+ <para>Software that uses <application>Lua</application> may have
+ been written to auto-detect the <application>Lua</application>
+ version in use. In general ports should override this
+ assumption, and force the use of the specific
+ <application>Lua</application> version selected as described
+ above. Depending on the sortware being ported, this might
+ require any or all of:
+ </para>
+
+ <itemizedlist>
+ <listitem>
+ <para>Using <varname>LUA_VER</varname> as part of a parameter
+ to the software's configuration script via
+ <varname>CONFIGURE_ARGS</varname> or
+ <varname>CONFIGURE_ENV</varname> (or equivalent for other
+ build systems);
+ </para>
+ </listitem>
+
+ <listitem>
+ <para>Adding <literal>-I${LUA_INCDIR}</literal>,
+ <literal>-L${LUA_LIBDIR}</literal>, and
+ <literal>-llua-${LUA_VER}</literal> to <varname>CFLAGS</varname>,
+ <varname>LDFLAGS</varname>, <varname>LIBS</varname> respectively
+ as appropriate;
+ </para>
+ </listitem>
+
+ <listitem>
+ <para>Patch the software's configuration or build files to select
+ the correct version.
+ </para>
+ </listitem>
+ </itemizedlist>
+
+ </sect2>
+
+ <sect2 xml:id="lua-version-flavors">
+ <title>Version Flavors</title>
+
+ <para>A port which installs a <application>Lua</application>
+ module (rather than an application that simply makes use of
+ <application>Lua</application>) should build a separate
+ flavor for each supported <application>Lua</application>
+ version. This is done by adding the <literal>module</literal>
+ parameter:</para>
+
+ <programlisting>USES= lua:module</programlisting>
+
+ <para>A version number or range of versions can be specified as
+ well; use a comma to separate parameters.</para>
+
+ <para>Since each flavor must have a different package name, the
+ variable <varname>LUA_PKGNAMEPREFIX</varname> is provided which
+ will be set to an appropriate value; the intended usage
+ is:</para>
+
+ <programlisting>PKGNAMEPREFIX= ${LUA_PKGNAMEPREFIX}</programlisting>
+
+ <para>Module ports should normally install files only to
+ <varname>LUA_MODLIBDIR</varname>,
+ <varname>LUA_MODSHAREDIR</varname>,
+ <varname>LUA_DOCSDIR</varname>, and
+ <varname>LUA_EXAMPLESDIR</varname>, all of which are set up
+ to refer to version-specific subdirectories. Installing any
+ other files must be done with care to avoid conflicts between
+ versions.</para>
+
+ <para>A port (other than a <application>Lua</application> module)
+ which wishes to build a separate package for each
+ <application>Lua</application> version should use the
+ <literal>flavors</literal> parameter:</para>
+
+ <programlisting>USES= lua:flavors</programlisting>
+
+ <para>This operates the same way as the <literal>module</literal>
+ parameter described above, but without the assumption that the
+ package should be documented as a <application>Lua</application>
+ module (so <varname>LUA_DOCSDIR</varname> and
+ <varname>LUA_EXAMPLESDIR</varname> are not defined by
+ default). However, the port may choose to define
+ <varname>LUA_DOCSUBDIR</varname> as a suitable subdirectory name
+ (usually the port's <varname>PORTNAME</varname> as long as this
+ does not conflict with the <varname>PORTNAME</varname> of any
+ module), in which case the framework will define both
+ <varname>LUA_DOCSDIR</varname> and
+ <varname>LUA_EXAMPLESDIR</varname>.
+ </para>
+
+ <para>As with module ports, a flavored port should avoid installing
+ files that would conflict between versions. Typically this is done
+ by adding <varname>LUA_VER_STR</varname> as a suffix to program
+ names (e.g. using
+ <link linkend="uses-uniquefiles">USES=uniquefiles</link>), and
+ otherwise using either <varname>LUA_VER</varname> or
+ <varname>LUA_VER_STR</varname> as part of any other files or
+ subdirectories used outside of <varname>LUA_MODLIBDIR</varname>
+ and <varname>LUA_MODSHAREDIR</varname>.
+ </para>
+ </sect2>
+
<sect2 xml:id="lua-defined-variables">
<title>Defined Variables</title>
@@ -6439,48 +6574,69 @@ PLIST_SUB+= VERSION="${VER_STR}"
</row>
<row>
- <entry><varname>LUA_PREFIX</varname></entry>
- <entry>The prefix where <application>Lua</application>
- (and components) is installed</entry>
+ <entry><varname>LUA_FLAVOR</varname></entry>
+ <entry>The flavor name corresponding to the selected
+ <application>Lua</application> version, to be used
+ for specifying dependencies</entry>
</row>
<row>
- <entry><varname>LUA_SUBDIR</varname></entry>
- <entry>The directory under
- <filename>${PREFIX}/bin</filename>,
- <filename>${PREFIX}/share</filename> and
- <filename>${PREFIX}/lib</filename> where
- <application>Lua</application> is installed</entry>
+ <entry><varname>LUA_BASE</varname></entry>
+ <entry>The prefix that should be used to locate
+ <application>Lua</application> (and components) that
+ are already installed</entry>
</row>
<row>
+ <entry><varname>LUA_PREFIX</varname></entry>
+ <entry>The prefix where <application>Lua</application>
+ (and components) are to be installed by this port</entry>
+ </row>
+
+ <row>
<entry><varname>LUA_INCDIR</varname></entry>
<entry>The directory where
- <application>Lua</application> and
- <application>tolua</application> header files are
+ <application>Lua</application> header files are
installed</entry>
</row>
<row>
<entry><varname>LUA_LIBDIR</varname></entry>
<entry>The directory where
- <application>Lua</application> and
- <application>tolua</application> libraries are
+ <application>Lua</application> libraries are
installed</entry>
</row>
<row>
+ <entry><varname>LUA_REFMODLIBDIR</varname></entry>
+ <entry>The directory where
+ <application>Lua</application> module libraries
+ (<filename>.so</filename>) that are already
+ installed are to be found</entry>
+ </row>
+
+ <row>
+ <entry><varname>LUA_REFMODSHAREDIR</varname></entry>
+ <entry>The directory where
+ <application>Lua</application> modules
+ (<filename>.lua</filename>) that are already
+ installed are to be found</entry>
+ </row>
+
+ <row>
<entry><varname>LUA_MODLIBDIR</varname></entry>
<entry>The directory where
<application>Lua</application> module libraries
- (<filename>.so</filename>) are installed</entry>
+ (<filename>.so</filename>) are to be installed
+ by this port</entry>
</row>
<row>
<entry><varname>LUA_MODSHAREDIR</varname></entry>
<entry>The directory where
<application>Lua</application> modules
- (<filename>.lua</filename>) are installed</entry>
+ (<filename>.lua</filename>) are to be installed
+ by this port</entry>
</row>
<row>
@@ -6491,18 +6647,96 @@ PLIST_SUB+= VERSION="${VER_STR}"
<row>
<entry><varname>LUA_CMD</varname></entry>
- <entry>The path to the <application>Lua</application>
- interpreter</entry>
+ <entry>The name of the <application>Lua</application>
+ interpreter (e.g. <literal>lua53</literal>)</entry>
</row>
<row>
<entry><varname>LUAC_CMD</varname></entry>
- <entry>The path to the <application>Lua</application>
- compiler</entry>
+ <entry>The name of the <application>Lua</application>
+ compiler (e.g. <literal>luac53</literal>)</entry>
</row>
</tbody>
</tgroup>
</table>
+
+ <para>These additional variables are available for ports that
+ specified the <literal>module</literal> parameter:</para>
+
+ <table frame="none" xml:id="using-lua-variables-modules">
+ <title>Variables Defined for <application>Lua</application>
+ Module Ports</title>
+
+ <tgroup cols="2">
+ <thead>
+ <row>
+ <entry>Name</entry>
+ <entry>Description</entry>
+ </row>
+ </thead>
+ <tbody>
+ <row>
+ <entry><varname>LUA_DOCSDIR</varname></entry>
+ <entry>the directory to which the module's
+ documentation should be installed.</entry>
+ </row>
+
+ <row>
+ <entry><varname>LUA_EXAMPLESDIR</varname></entry>
+ <entry>the directory to which the module's
+ example files should be installed.</entry>
+ </row>
+ </tbody>
+ </tgroup>
+ </table>
+
+ </sect2>
+
+ <sect2 xml:id="lua-examples">
+ <title>Examples</title>
+
+ <example xml:id="lua-app-Makefile">
+ <title>Makefile for an application using
+ <application>Lua</application></title>
+
+ <para>This example shows how to reference a
+ <application>Lua</application> module required at run
+ time. Notice that the reference must specify a
+ flavor.</para>
+
+ <programlisting>PORTNAME= sample
+DISTVERSION= 1.2.3
+CATEGORIES= whatever
+
+MAINTAINER= john at doe.tld
+COMMENT= Sample
+
+RUN_DEPENDS= ${LUA_REFMODLIBDIR}/lpeg.so:devel/lua-lpeg@${LUA_FLAVOR}
+
+USES= lua
+
+.include <bsd.port.mk></programlisting>
+ </example>
+
+ <example xml:id="lua-mod-Makefile">
+ <title>Makefile for a simple <application>Lua</application>
+ module</title>
+
+ <programlisting>PORTNAME= sample
+DISTVERSION= 1.2.3
+CATEGORIES= whatever
+PKGNAMEPREFIX= ${LUA_PKGNAMEPREFIX}
+
+MAINTAINER= john at doe.tld
+COMMENT= Sample
+
+USES= lua:module
+
+DOCSDIR= ${LUA_DOCSDIR}
+
+.include <bsd.port.mk></programlisting>
+ </example>
+
</sect2>
</sect1>
Modified: head/en_US.ISO8859-1/books/porters-handbook/uses/chapter.xml
==============================================================================
--- head/en_US.ISO8859-1/books/porters-handbook/uses/chapter.xml Mon Oct 19 15:25:04 2020 (r54611)
+++ head/en_US.ISO8859-1/books/porters-handbook/uses/chapter.xml Mon Oct 19 17:41:54 2020 (r54612)
@@ -1969,17 +1969,33 @@ GSSAPI_NONE_CONFIGURE_ON= --without-gssapi</programlis
<title><literal>lua</literal></title>
<para>Possible arguments: (none),
- <literal><replaceable>XY</replaceable>+</literal>,
<literal><replaceable>XY</replaceable></literal>,
- <literal>build</literal>, <literal>run</literal></para>
+ <literal><replaceable>XY</replaceable>+</literal>,
+ <literal>-<replaceable>XY</replaceable></literal>,
+ <literal><replaceable>XY</replaceable>-<replaceable>ZA</replaceable></literal>,
+ <literal>module</literal>, <literal>flavors</literal>,
+ <literal>build</literal>, <literal>run</literal>,
+ <literal>env</literal></para>
<para>Adds a dependency on <application>Lua</application>. By
default this is a library dependency, unless overridden by the
- <literal>build</literal> or <literal>run</literal> option. The
- default version is 5.2, unless set by the
- <literal><replaceable>XY</replaceable></literal> parameter (for
- example, <literal>51</literal> or
- <literal>52+</literal>).</para>
+ <literal>build</literal> and/or <literal>run</literal> option.
+ The <literal>env</literal> option prevents the addition of any
+ dependency, while still defining all the usual variables.</para>
+
+ <para>The default version is set by the usual
+ <literal>DEFAULT_VERSIONS</literal> mechanism, unless a version or
+ range of versions is specified as an argument, for
+ example, <literal>51</literal> or <literal>51-53</literal>.</para>
+
+ <para>Applications using <application>Lua</application> are
+ normally built for only a single <application>Lua</application>
+ version. However, library modules intended to be loaded by
+ <application>Lua</application> code should use the
+ <literal>module</literal> option to build with multiple
+ flavors.</para>
+
+ <para>For more information see <xref linkend="using-lua" />.</para>
</sect1>
<sect1 xml:id="uses-lxqt">
More information about the svn-doc-head
mailing list