-
Notifications
You must be signed in to change notification settings - Fork 17.8k
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
x/tools/go/gcexportdata: improved API to replace gcimporter15 #15651
Comments
I think we should not add yet another package. We should integrate the needed functionality into go/importer, even if that means deprecating some of it's API. It's less confusing. Also, I suggest that we take this slow - experience has shown that we've been very bad at nailing down the exact API; and once we had something, we had to change it soon for a new use case. Marking as 1.8Early. |
The idea behind a subpackage is to suggest that this is a more advanced, complete API, but adding the same API to the existing go/importer package sounds good to me. I don't think we need to deprecate the old API. It's restricted but works well enough for the simplest use-cases. |
What is the status here? Is this important for Go 1.8? |
See comment on #14738. |
Recently the issue of version skew has made me question whether importers belong in the standard library at all. Consider the moment at which a large Go customer switches from, say, Go 1.7 to Go 1.8. The compiler starts producing object files and export data in the latest format, but any other tools used by that customer will still be using the Go 1.7 importer and will instantly break. It is impossible to upgrade the whole ecosystem atomically; Google's tooling ecosystem involves many teams and complex release processes. The solution to the version skew problem is to put the importer in a separate repo and to release it each time the file format evolves. That way, the tip version of the importer in the weeks before the Go 1.8 release is capable of reading Go 1.7 and Go 1.8 files. So long as the ecosystem is using this version of the library by the time of the release, everything just works. This is what we are already doing by developing the importer in x/tools. The API improvements are still a good idea, though. |
We do need an importer in the std library otherwise go/types cannot function (unless we make it just an internal part of go/types, which is a possibility). The tip importer is backward-compatible and can read older formats. But @alandonovan is also correct that an older importer won't be able to read a newer format. This is an issue for infrastructure that cannot move to the latest release yet must process (for some reason or another) object files and export data built with the latest compiler (as is the case for source code analysis tools). |
@alandonovan Based on our conversations, can we close this now? We are still planning to fix the go/importer implementation and API (issues #16088, #13847, and #11415). |
I no longer think we should change the standard library, but we should provide in |
CL https://golang.org/cl/30612 mentions this issue. |
Currently (tip prior to go 1.7) the go/importer package provides an implementation of the go/types.Importer interface that loads types.Packages and types.Objects from gc exportdata. However, the standard library provides only very restricted access to this functionality (
importer.For
). For example, there is no way to control how the importer finds .a files nor any way to access to the position information recorded in the export data, and the API provides no access to the functions that convert a types.Package to a []byte and back again. So, many clients need to use the golang.org/x/tools/go/gcimporter15 package, whose implementation is essentially identical, but whose API is not artificially restricted by theimporter.For
bottleneck. Maintaining the two packages is a nuisance and there is a risk of version skew.I propose that the Go 1.8 standard library include a new package that is essentially equivalent to gcimporter15, and that the latter package be deprecated.
The API of the new standard package would look like this:
It might be better for
Import
andExport
to take a single config struct as a parameter so that options can be added later without breaking compatibility, since the export data format will surely change as the compiler evolves.The text was updated successfully, but these errors were encountered: