Hey! Several months ago I opened the proposal for extending the systax of go.mod in order to allow to specify/overwrite the source URL for a dependency (https://github.com/golang/go/issues/39536). It feels it could also solve what you described in "Problem 1", although the motivation behind the proposal is a bit different.
Let me know what you think. On Tuesday, September 22, 2020 at 12:02:01 AM UTC+2 shirshendu...@gmail.com wrote: > Hi All, > > I create a github issue to suggest a proposal for making go dependency > managment better. > > As people there suggested that this group is probably the best place to > discuss this, I am posting the exact same post here: > > Even after the introduction of Go modules, the dependency management is > complex and not so developer friendly. For beginners it takes a good amount > of time to understand what's going on behind the scene. > > Some of this may be because of lack of well written documentation about > dependency management. > > - > > There are some confusing syntax, for example > github.com/myorganzation/mypackage/pkg > > This url results in 404 in browsers but somehow go resolves it, so it > seems like depending on hosting providers such as GitHub, BitBucket etc go > have different mechanisms of resolving the URL. > > Which is somewhat described in here > <https://golang.org/cmd/go/#hdr-Remote_import_paths> > - > > Upgrading to major version with a suffix like vX > - > > Though i am not sure about this but i didn't find any way by which i > can tell that this indirect dependency x is from the dependency y, just by > looking into go.sum or go.mod files. > - > > Error messages not being so helpful > If i try to go get a package in a directory which is not a module i > get an error message which is not so helpful for beginners > > go get github.com/gofiber/fiber/v2 cannot find package " > github.com/gofiber/fiber/v2" in any of: /usr/local/go/src/ > github.com/gofiber/fiber/v2 (from $GOROOT) > /Users/shirshendubhowmick/go/src/github.com/gofiber/fiber/v2 (from > $GOPATH) > > - There is no easy way of adding dev only dependencies. > > Gophers please do let me know your thoughts about this, also request you > to think about these issues from a beginners perspective especially if > someone is coming from JavaScript or Python background. > > I feel like there is a steep learning curve for go dependency management, > which can be made easy with little changes in go and it's documentation. > > *Edit: Adding some suggestion to deal with the problems I mentioned above* > Some high level suggestion to deal with the current problems > > - > > *Problem 1:* The current way of downloading, using & maintaining a > package > > I like the idea of not having a central registry like npm or pip. > However using repo URLs (that is also some modified URL) everywhere in the > codebase to import the package doesn't seem to be the best way. > > Instead what we can do is use git URLs git+ssh:// > g...@github.com/myorganization/mypackage > <http://g...@github.com/myorganization/mypackage> (HTTPS url works > too), only at one place, i.e. our dependency file (currently go.mod) > With this, we can also refer to a particular branch, tag or commit. > > Now our dependency file (currently go.mod) will have a mapping of > module name and its URL to create an alias for the module, for example > mypackage git+ssh://g...@github.com/myorganization/mypackage > <http://g...@github.com/myorganization/mypackage> > > Everywhere in the code base a consumer will use the alias name instead > of a URL to import the package, for example > > import "mypackage" > > Now how do we know where the module is located inside the repo ? Right > now we add a go.mod file in every module root directory. With this change > maybe we can add a single file in the repo root which will tell where the > modules are located relative to the repo root. I guess this will give more > flexibility to both the module developer and consumer. > > For updating version, we can either do it manually by changing the URL > or maybe via some tool like go update mypackage > - > > *Problem 2:* Improving the error messages > This might be a simpler problem to solve compared to the above one. > There is no specific solution to this. I think the best way is to run an > audit to figure out point of failures while working with modules in go. > And > try to have as much meaningful error message as possible with some > detailed > log. > > This is very high level solution proposal, happy to discuss more on it and > also pros & cons, gotchas, bottlenecks etc. > > Original github issue link: > https://github.com/golang/go/issues/41510 > -- 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. To view this discussion on the web visit https://groups.google.com/d/msgid/golang-nuts/5c725fa0-e704-4c9e-a151-bfde8f9ae6e5n%40googlegroups.com.