From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from lists.gentoo.org (pigeon.gentoo.org [208.92.234.80]) by finch.gentoo.org (Postfix) with ESMTP id F37F5138BF3 for ; Sat, 15 Feb 2014 16:06:55 +0000 (UTC) Received: from pigeon.gentoo.org (localhost [127.0.0.1]) by pigeon.gentoo.org (Postfix) with SMTP id A40B8E0B2C; Sat, 15 Feb 2014 16:06:50 +0000 (UTC) Received: from smtp101-3.vfemail.net (three.vfemail.net [108.76.175.3]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by pigeon.gentoo.org (Postfix) with ESMTPS id 9748BE0B07 for ; Sat, 15 Feb 2014 16:06:49 +0000 (UTC) Received: (qmail 7423 invoked by uid 89); 15 Feb 2014 16:06:48 -0000 Received: by simscan 1.4.0 ppid: 7416, pid: 7420, t: 0.2951s scanners:none Received: from unknown (HELO ciguri) (ZW1lcnlAdmZlbWFpbC5uZXQ=@MTYyLjE5Ny43MC4xNzE=) by mail.vfemail.net with ESMTPA; 15 Feb 2014 16:06:48 -0000 Date: Sat, 15 Feb 2014 11:06:45 -0500 From: Emery Hemingway To: gentoo-dev@lists.gentoo.org Subject: Re: [gentoo-dev] dev-lang/go Message-ID: <20140215110645.69141131@ciguri> In-Reply-To: <20140214231327.GA1994@laptop.home> References: <20131230154817.34a69433@ciguri> <20140211013844.4057ddb2@gentoo.org> <20140213175916.GA1919@laptop.home> <20140214133010.153a46b8@deathstar> <20140214110249.27842f70@ciguri> <20140214231327.GA1994@laptop.home> X-Mailer: Claws Mail 3.9.3 (GTK+ 2.24.22; x86_64-pc-linux-gnu) Precedence: bulk List-Post: List-Help: List-Unsubscribe: List-Subscribe: List-Id: Gentoo Linux mail X-BeenThere: gentoo-dev@lists.gentoo.org Reply-to: gentoo-dev@lists.gentoo.org MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Archives-Salt: f0fcbe50-0e16-47a2-9674-9d320402d372 X-Archives-Hash: 42fbb07fb320bb51ab8bc195482ea999 On Fri, 14 Feb 2014 17:13:27 -0600 William Hubbs wrote: > On Fri, Feb 14, 2014 at 11:02:49AM -0500, Emery Hemingway wrote: > > On Fri, 14 Feb 2014 13:30:10 +0100 > > Jan Matejka wrote: > > > > > On Thu, 13 Feb 2014 11:59:16 -0600 > > > William Hubbs wrote: > > > > > > > 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 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. > > > > > > Please see what python does for different python versions (which > > > you omitted from my previous email). > > I omitted it, because thinking about it, we don't need to worry about > this. There isn't a reason you would want go 1.1 and go 1.2 on your > system. Source level compatibility is guaranteed for all go1 programs > [1]. > > > I've modified the go-1.2 ebuild to install to usr/lib/go1.2 and I'm > > working on an eselect module to manage the symlink to > > usr/bin/[go,gofmt] > > I would just install to /usr/lib/go1 and not worry about the eselect > module; there should not be a need to keep several versions of go1 > around, again, because go1.x releases will be source compatible. > > We could even just leave this as /usr/lib/go, because upstream doesn't > even know if a go-2 specification will happen. > > > The default GOROOT that go looks at for base libraries seems to be > > compiled in so this should be pretty easy, like python but simplier. > > It looks for standard libraries in GOROOT_FINAL which is set in the > ebuild and compiled into the binaries. > > Third party libraries are interesting in this case, because, all of > the third party libraries we install will not be usable once the user > upgrades from say go-1.2 to go-1.3. However, rebuilding those > libraries from source will work. > > William > > [1] http://golang.org/doc/go1compat The reason I thought go should be slotting was that all compliled libraries would break when go was replaced. Mabye the only the library source could be installed, and a cache of compiled libraries could be overlayed over that...