-
Notifications
You must be signed in to change notification settings - Fork 709
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Further compile failures due repository rename #483
Comments
I agree. Old repos should have been left alone and even archived with new ones made on new names. This is the only way to keep things working with how go is. |
Will look into it this today. Apologies for the inconveniences. |
Thanks @maxb for sharing this idea and again sorry for the inconvenience. I did send an update for |
@derekcollison following what @maxb suggests repo would look as follows: https://github.com/wallyqs/go-nats-follow This is what I did: # Create new repository and fetch tags from nats-io/nats.go
mkdir -p src/github.com/nats-io/go-nats
git init
git remote add nats-io https://github.com/nats-io/nats.go
git fetch nats-io
git remote rm nats-io
# Remove tags that use Go modules and nats-io/nats.go import path
git tag -d v1.8.0
git tag -d v1.8.1
# Set master to the last commit that does not use go modules
git remote add wallyqs https://github.com/wallyqs/go-nats-follow
git push --follow-tags https://github.com/wallyqs/go-nats-follow d15e1944e18167d8e4266e8fe5371171af758c68:refs/heads/master tag v1.2.2 tag v1.3.0 tag v1.4.0 As a next step, we would create a repository at |
I think it will work just as he described. I will give it a shot now. |
ok this is in place and I verified it worked with the sandbox example above. Will update README. |
@maxb Thank you very much for the suggestion. Much appreciated. |
Thank you very much for this speedy fix! Looks good to me. |
We also did this for the |
I really appreciate you all taking the time to do this on the weekend! I'll be checking bazel compatibility later today, but in theory this will fix the issue. |
Thank you for the patience. |
Hello,
Sorry to be the bearer of bad news - there are still unsolved problems with the repository rename.
Specifically the issue is that currently, GitHub's automatic HTTP redirection from nats-io/go-nats to nats-io/nats.go is being relied upon to make old code - including old tagged versions of code which cannot be realistically updated - continue to compile.
This worked before Go modules came along, but now that there is a go.mod in the repository, module-aware Go will follow the redirect, but then realise that what it has downloaded declares itself (in go.mod) as being a different import path to what it was trying to fetch.
To reproduce this failure, the conditions are:
Here is a simple example where the intermediate library is github.com/go-kit/kit, which seems to show up a fair bit in various dependency trees:
You might suggest updating the code of go-kit, or using go.mod replace statements ... and whilst these are viable workarounds for fresh development, they don't address repairing the build of old tagged releases which would have previously built, so I propose a more thorough fix would be desirable - my suggestion is:
(Git's --follow-tags only follows annotated tags, so since three versions were tagged with lightweight tags they had to be mentioned explicitly.)
This should repair the existing builds, and the extra Git repository can then be archived and configured with a description explaining that it is just for compatibility and pointing users to the current repository.
Does this sound like a good approach?
The text was updated successfully, but these errors were encountered: