2023-12-04 15:22:44 +00:00
|
|
|
410430342 2152 proto/build-container/Dockerfile
|
2022-07-12 13:45:03 +00:00
|
|
|
3003861496 625 proto/build-container/scripts/install-go.sh
|
|
|
|
853251015 873 proto/build-container/scripts/install-node.sh
|
|
|
|
2003827277 549 proto/build-container/scripts/install-packages.sh
|
2023-12-04 15:22:44 +00:00
|
|
|
1782845978 1900 proto/build-container/scripts/install-protobuf-tools.sh
|
2023-03-04 22:11:52 +00:00
|
|
|
745180271 1066 proto/build-container/scripts/install-python.sh
|
2022-07-12 13:45:03 +00:00
|
|
|
2099022623 1282 proto/build-container/scripts/utils.sh
|
2023-12-04 15:22:44 +00:00
|
|
|
1171868040 6961 proto/generate.sh
|
2022-11-03 16:49:38 +00:00
|
|
|
1574098198 4061 proto/google/protobuf/status.proto
|
2022-09-22 17:13:55 +00:00
|
|
|
1405145341 1741 proto/pulumi/alias.proto
|
2023-10-09 18:31:17 +00:00
|
|
|
4283367129 10425 proto/pulumi/analyzer.proto
|
2024-03-04 13:01:25 +00:00
|
|
|
2045336065 1464 proto/pulumi/callback.proto
|
2022-10-17 14:21:11 +00:00
|
|
|
2452746699 3822 proto/pulumi/codegen/hcl.proto
|
2024-03-04 13:01:25 +00:00
|
|
|
520813116 1497 proto/pulumi/codegen/loader.proto
|
|
|
|
2331804404 1707 proto/pulumi/codegen/mapper.proto
|
|
|
|
1027667133 3164 proto/pulumi/converter.proto
|
2022-09-20 08:31:01 +00:00
|
|
|
2889436496 3240 proto/pulumi/engine.proto
|
|
|
|
3421371250 793 proto/pulumi/errors.proto
|
2024-03-26 13:10:34 +00:00
|
|
|
4059302536 10403 proto/pulumi/language.proto
|
2023-08-25 15:26:25 +00:00
|
|
|
2893249402 1992 proto/pulumi/plugin.proto
|
2024-05-15 16:22:39 +00:00
|
|
|
3028749592 26559 proto/pulumi/provider.proto
|
2024-05-15 10:30:51 +00:00
|
|
|
1907809579 16205 proto/pulumi/resource.proto
|
[engine] Add support for source positions
These changes add support for passing source position information in
gRPC metadata and recording the source position that corresponds to a
resource registration in the statefile.
Enabling source position information in the resource model can provide
substantial benefits, including but not limited to:
- Better errors from the Pulumi CLI
- Go-to-defintion for resources in state
- Editor integration for errors, etc. from `pulumi preview`
Source positions are (file, line) or (file, line, column) tuples
represented as URIs. The line and column are stored in the fragment
portion of the URI as "line(,column)?". The scheme of the URI and the
form of its path component depends on the context in which it is
generated or used:
- During an active update, the URI's scheme is `file` and paths are
absolute filesystem paths. This allows consumers to easily access
arbitrary files that are available on the host.
- In a statefile, the URI's scheme is `project` and paths are relative
to the project root. This allows consumers to resolve source positions
relative to the project file in different contexts irrespective of the
location of the project itself (e.g. given a project-relative path and
the URL of the project's root on GitHub, one can build a GitHub URL for
the source position).
During an update, source position information may be attached to gRPC
calls as "source-position" metadata. This allows arbitrary calls to be
associated with source positions without changes to their protobuf
payloads. Modifying the protobuf payloads is also a viable approach, but
is somewhat more invasive than attaching metadata, and requires changes
to every call signature.
Source positions should reflect the position in user code that initiated
a resource model operation (e.g. the source position passed with
`RegisterResource` for `pet` in the example above should be the source
position in `index.ts`, _not_ the source position in the Pulumi SDK). In
general, the Pulumi SDK should be able to infer the source position of
the resource registration, as the relationship between a resource
registration and its corresponding user code should be static per SDK.
Source positions in state files will be stored as a new `registeredAt`
property on each resource. This property is optional.
2023-06-29 18:41:19 +00:00
|
|
|
607478140 1008 proto/pulumi/source.proto
|
Add SupportPack to schemas to write out in the new style (#15713)
<!---
Thanks so much for your contribution! If this is your first time
contributing, please ensure that you have read the
[CONTRIBUTING](https://github.com/pulumi/pulumi/blob/master/CONTRIBUTING.md)
documentation.
-->
# Description
<!--- Please include a summary of the change and which issue is fixed.
Please also include relevant motivation and context. -->
This adds a new flag to the schema metadata to tell codegen to use the
new proposed style of SDKs where we fill in versions and write go.mods
etc.
I've reworked pack to operate on packages assuming they're in this new
style. That is pack no longer has the responsibility to fill in any
version information.
This updates python and node codegen to write out SDKs in this new
style, and fixes their core libraries to still be buildable via pack.
There are two approaches to fixing those, I've chosen option 1 below but
could pretty easily rework for option 2.
1) Write the version information directly to the SDKs at the same time
as we edit the .version file. To simplify this I've added a new
'set-version.py' script that takes a version string an writes it to all
the relevant places (.version, package.json, etc).
2) Write "pack" in the language host to search up the directory tree for
the ".version" file and then fill in the version information as we we're
doing before with envvar tricks and copying and editing package.json.
I think 1 is simpler long term, but does force some amount of cleanup in
unrelated bits of the system right now (release makefiles need a small
edit). 2 is much more localised but keeps this complexity that
sdk/nodejs sdk/python aren't actually valid source modules.
## Checklist
- [x] I have run `make tidy` to update any new dependencies
- [x] I have run `make lint` to verify my code passes the lint check
- [x] I have formatted my code using `gofumpt`
<!--- Please provide details if the checkbox below is to be left
unchecked. -->
- [x] I have added tests that prove my fix is effective or that my
feature works
<!---
User-facing changes require a CHANGELOG entry.
-->
- [ ] I have run `make changelog` and committed the
`changelog/pending/<file>` documenting my change
<!--
If the change(s) in this PR is a modification of an existing call to the
Pulumi Cloud,
then the service should honor older versions of the CLI where this
change would not exist.
You must then bump the API version in
/pkg/backend/httpstate/client/api.go, as well as add
it to the service.
-->
- [ ] Yes, there are changes in this PR that warrants bumping the Pulumi
Cloud API version
<!-- @Pulumi employees: If yes, you must submit corresponding changes in
the service repo. -->
2024-03-22 09:25:46 +00:00
|
|
|
1507248916 2314 proto/pulumi/testing/language.proto
|