From: William Hubbs <williamh@gentoo.org>
To: gentoo-dev@lists.gentoo.org
Subject: Re: [gentoo-dev] dev-lang/go
Date: Thu, 13 Feb 2014 11:59:16 -0600 [thread overview]
Message-ID: <20140213175916.GA1919@laptop.home> (raw)
In-Reply-To: <20140211013844.4057ddb2@gentoo.org>
[-- Attachment #1: Type: text/plain, Size: 3137 bytes --]
Hi all,
I responded to this a while back, but I guess my email didn't go out for
some reason.
As the primary go maintainer, I do want to be involved in this. :-)
On Tue, Feb 11, 2014 at 01:38:44AM +0100, yac wrote:
> On Mon, 30 Dec 2013 15:48:17 -0500
> Emery Hemingway <emery@vfemail.net> wrote:
>
> > I really like working with Go, and would like to see a means of
> > merging Go packages with Portage. In short I am asking if anyone else
> > is interested in a Go project.
>
> I might be. I have packaged something for private use but it just a
> bunch of hacks. Anyway, I have some production go code.
>
> >
> > For those who aren't familiar with Go, I will sumarise why Portage and
> > Go do not play well together.
> >
> > Go is static linked by default.
> > The Go compiler creates static libraries and binaries. Libraries
> > compilied with different versions of Go (1.1/1.2) may not be linked
> > into the same binary.
>
> Haskell is staticaly linked as well (by default) and you can see the
> gentoo haskell project. I don't see this as a problem, we just will have
> all dependencies in DEPEND and will have to scope on the go compiler
> version under something like /usr/lib/go-1.{1,2}/...
That could be done easily enough, but what about the tools in /usr/bin
(there aren't many, but there are a couple), and these do not change
name with each version of go.
> > Go libraries are usually unversioned.
> > Libraries outside the system library are resolved with an import
> > statement that specifies a source code repository, such as a git or
> > mecurial repository. Most often Go libraries are installed using the
> > 'go get' tool that clones a repository, and simply assumes HEAD/tip is
> > the best revision to build against. There is some support for using
> > git tags but it is not well documented. Often these libraries are very
> > small for the sake of reuse and to keep APIs simple.
My understanding is that a library repo will have branches based on the
version of go, so for example, it might have a branch called go-1 which
will be where go get will look to find the latest version of the code
that works with go-1.x.
> In this case we just have to require upstream to make releases or
> publish either live ebuilds, or ebuilds versioned something like
> 0_preYYYY-MM-DD.ebuild [1]
I don't think we are going to be able to require upstream to make
releases, so that leaves us with:
1) using live ebuilds, which will never be allowed to have keywords by
gentoo policy, or
2) publishing snapshots, which also means we have to create tarballs to
match them. This will be a lot of work for us as maintainers. Also, the
only way we will know when a new "version" of the library is released is
to closely monitor the upstream git repository.
The other concern, which I believe zero was talking about is, once a
library is installed in GOPATH, I don't think the go build system
rebuilds it. In other words, "go get" will see that it is already there
and I don't think it goes back out to the net to check for any changes.
William
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 198 bytes --]
next prev parent reply other threads:[~2014-02-13 17:59 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-12-30 20:48 [gentoo-dev] dev-lang/go Emery Hemingway
2013-12-30 21:20 ` Rick "Zero_Chaos" Farina
2013-12-31 2:16 ` [gentoo-dev] dev-lang/go Ryan Hill
2014-01-01 6:51 ` [gentoo-dev] dev-lang/go Alec Warner
2014-02-11 0:38 ` yac
2014-02-13 14:20 ` Emery Hemingway
2014-02-13 17:59 ` William Hubbs [this message]
2014-02-13 22:36 ` Emery Hemingway
2014-02-14 12:30 ` Jan Matejka
2014-02-14 16:02 ` Emery Hemingway
2014-02-14 23:13 ` William Hubbs
2014-02-15 16:06 ` Emery Hemingway
2014-02-14 23:48 ` yac
2014-02-15 22:44 ` William Hubbs
2014-02-19 11:34 ` yac
2014-02-20 0:52 ` William Hubbs
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20140213175916.GA1919@laptop.home \
--to=williamh@gentoo.org \
--cc=gentoo-dev@lists.gentoo.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox