Porter's Handbook: Add an example on how to create a USES=go port

Submitted by:	tobik
Reviewed by:	Dmitri Goutnik <dg@syrec.org>, mat
Approved by:	mat
Differential Revision:	https://reviews.freebsd.org/D21243
This commit is contained in:
Tobias Kortkamp 2019-08-13 17:49:49 +00:00
parent e79c1938bb
commit 4e5f3ff43e
Notes: svn2git 2020-12-08 03:00:23 +00:00
svn path=/head/; revision=53306
2 changed files with 110 additions and 0 deletions

View file

@ -1211,6 +1211,114 @@ byteorder-1.2.2 Unlicense/MIT
MESON_ARGS= -Dfoo=enabled</programlisting>
</example>
</sect2>
<sect2 xml:id="using-go">
<title>Building <application>Go</application> applications</title>
<para>For ports that use <application>Go</application>,
define <literal>USES=go</literal>. Refer to <xref
linkend="uses-go" /> for a list of variables that can be
set to control the build process.</para>
<example xml:id="go-ex1">
<title>Creating a Port for a Go Modules Based
Application</title>
<para>Creating a Go based port is a five stage process.
First we need to provide a ports template that fetches the
application distribution file:</para>
<programlisting>PORTNAME= ghq
DISTVERSIONPREFIX= v
DISTVERSION= 0.12.5
CATEGORIES= devel
MAINTAINER= tobik@FreeBSD.org
COMMENT= Remote repository management made easy
USES= go:modules
USE_GITHUB= yes
GH_ACCOUNT= motemen
.include &lt;bsd.port.mk&gt;</programlisting>
<para>Generate an initial
<filename>distinfo</filename>:</para>
<screen>&prompt.user; <userinput>make makesum</userinput>
===> License MIT accepted by the user
=> motemen-ghq-v0.12.5_GH0.tar.gz doesn't seem to exist in /usr/ports/distfiles/.
=> Attempting to fetch https://codeload.github.com/motemen/ghq/tar.gz/v0.12.5?dummy=/motemen-ghq-v0.12.5_GH0.tar.gz
fetch: https://codeload.github.com/motemen/ghq/tar.gz/v0.12.5?dummy=/motemen-ghq-v0.12.5_GH0.tar.gz: size of remote file is not known
motemen-ghq-v0.12.5_GH0.tar.gz 32 kB 177 kBps 00s</screen>
<para>Now the distribution file is ready to use and we can
extract the required Go module dependencies. This step
requires having
<package role="port">ports-mgmt/modules2tuple</package>
installed:</para>
<screen>&prompt.user; <userinput>make gomod-vendor</userinput>
[...]
GH_TUPLE= \
Songmu:gitconfig:v0.0.2:songmu_gitconfig/vendor/github.com/Songmu/gitconfig \
daviddengcn:go-colortext:186a3d44e920:daviddengcn_go_colortext/vendor/github.com/daviddengcn/go-colortext \
go-yaml:yaml:v2.2.2:go_yaml_yaml/vendor/gopkg.in/yaml.v2 \
golang:net:3ec191127204:golang_net/vendor/golang.org/x/net \
golang:sync:112230192c58:golang_sync/vendor/golang.org/x/sync \
golang:xerrors:3ee3066db522:golang_xerrors/vendor/golang.org/x/xerrors \
motemen:go-colorine:45d19169413a:motemen_go_colorine/vendor/github.com/motemen/go-colorine \
urfave:cli:v1.20.0:urfave_cli/vendor/github.com/urfave/cli</screen>
<para>The output of this command needs to be pasted directly
into the Makefile:</para>
<programlisting>PORTNAME= ghq
DISTVERSIONPREFIX= v
DISTVERSION= 0.12.5
CATEGORIES= devel
MAINTAINER= tobik@FreeBSD.org
COMMENT= Remote repository management made easy
USES= go:modules
USE_GITHUB= yes
GH_ACCOUNT= motemen
GH_TUPLE= Songmu:gitconfig:v0.0.2:songmu_gitconfig/vendor/github.com/Songmu/gitconfig \
daviddengcn:go-colortext:186a3d44e920:daviddengcn_go_colortext/vendor/github.com/daviddengcn/go-colortext \
go-yaml:yaml:v2.2.2:go_yaml_yaml/vendor/gopkg.in/yaml.v2 \
golang:net:3ec191127204:golang_net/vendor/golang.org/x/net \
golang:sync:112230192c58:golang_sync/vendor/golang.org/x/sync \
golang:xerrors:3ee3066db522:golang_xerrors/vendor/golang.org/x/xerrors \
motemen:go-colorine:45d19169413a:motemen_go_colorine/vendor/github.com/motemen/go-colorine \
urfave:cli:v1.20.0:urfave_cli/vendor/github.com/urfave/cli
.include &lt;bsd.port.mk&gt;</programlisting>
<para><filename>distinfo</filename> needs to be regenerated to
contain all the distribution files:</para>
<screen>&prompt.user; <userinput>make makesum</userinput>
=> Songmu-gitconfig-v0.0.2_GH0.tar.gz doesn't seem to exist in /usr/ports/distfiles/.
=> Attempting to fetch https://codeload.github.com/Songmu/gitconfig/tar.gz/v0.0.2?dummy=/Songmu-gitconfig-v0.0.2_GH0.tar.gz
fetch: https://codeload.github.com/Songmu/gitconfig/tar.gz/v0.0.2?dummy=/Songmu-gitconfig-v0.0.2_GH0.tar.gz: size of remote file is not known
Songmu-gitconfig-v0.0.2_GH0.tar.gz 5662 B 936 kBps 00s
=> daviddengcn-go-colortext-186a3d44e920_GH0.tar.gz doesn't seem to exist in /usr/ports/distfiles/.
=> Attempting to fetch https://codeload.github.com/daviddengcn/go-colortext/tar.gz/186a3d44e920?dummy=/daviddengcn-go-colortext-186a3d44e920_GH0.tar.gz
fetch: https://codeload.github.com/daviddengcn/go-colortext/tar.gz/186a3d44e920?dummy=/daviddengcn-go-colortext-186a3d44e920_GH0.tar.gz: size of remote file is not known
daviddengcn-go-colortext-186a3d44e920_GH0.tar. 4534 B 1098 kBps 00s
[...]</screen>
<para>The port is now ready for a test build and further
adjustments like creating a plist, writing a description,
adding license information, options, etc. as normal.</para>
<para>If you are not testing your port in a clean environment
like with <application>Poudriere</application>, remember to
run <command>make clean</command> before any testing.
</para>
</example>
</sect2>
</sect1>
<sect1 xml:id="using-autotools">

View file

@ -1237,6 +1237,8 @@ USE_GNOME= gnomemenus3:build intlhack</programlisting>
</listitem>
</varlistentry>
</variablelist>
<para>See <xref linkend="using-go" /> for usage examples.</para>
</sect1>
<sect1 xml:id="uses-gperf">