What we do is add all dependencies as git submodules. There is no tool to automate this (as far as I know) so each time you add new dependencies you have to manually 'git submodule add' it and it's dependencies. But after that updating them is as easy as doing a git pull in their directory.
On Sunday, November 13, 2016 at 1:00:08 AM UTC+8, Nick Stogner wrote: > > I would like to version control my entire GOPATH to store all of my go > code in a monolithic repository. (see http://danluu.com/monorepo/ or > https://blog.gopheracademy.com/advent-2015/go-in-a-monorepo/) > > The problem that I run into: how to manage dependencies with "go get" ?.. > I would like to vendor these dependencies but git wants to treat them as > nested repos and doesn't end up vendoring them on commit to the parent repo. > > I have tried: moving nested ".git" directories to ".git-moved", etc. This > works for vendoring go-gotten repos but is a hassle and also messes up > future calls to go get: > > $ mv src/github.com/Sirupsen/logrus/.git src/github.com/Sirupsen/ > logrus/.git-moved > $ git add --all; git commit -m 'this commit vendors the logrus package' > $ go get -u github.com/Sirupsen/logrus > package github.com/Sirupsen/logrus: directory "/tmp/monorepo/src/ > github.com/Sirupsen/logrus" is not using a known version control system > > I would have to mv those .git-moved directories back to .git before using > go-get again and this would be a pain and not scalable to a team. > > Has anyone come up with a solution for this? > -- You received this message because you are subscribed to the Google Groups "golang-nuts" group. To unsubscribe from this group and stop receiving emails from it, send an email to golang-nuts+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.