pulumi/pkg/backend/display
Pat Gavlin 948bb36e7e [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-07-10 14:35:40 -07:00
..
internal/terminal [cli] Add an "open in browser" keybinding 2023-03-09 15:52:13 -08:00
testdata Fix diff display partially parsing JSON/YAML 2023-06-22 09:31:10 +01:00
diff.go Use slice.Prealloc instead of make([]T, 0, ...) 2023-06-29 11:27:50 +01:00
diff_test.go CLI update summary now shows after non-mandatory policy events seen. 2023-06-20 13:28:01 -07:00
display.go display: Switch "Open in Browser" to "View in Browser" 2023-03-10 10:52:43 -07:00
doc.go Document Go packages (#6009) 2021-01-11 11:07:59 -07:00
events.go Use slice.Prealloc instead of make([]T, 0, ...) 2023-06-29 11:27:50 +01:00
events_test.go This commit colorizes nodejs stack traces to respect the default 2023-02-16 14:20:42 -08:00
json.go [engine] Add support for source positions 2023-07-10 14:35:40 -07:00
jsonmessage.go all: Reformat with gofumpt 2023-03-03 09:00:24 -08:00
object_diff.go Use slice.Prealloc instead of make([]T, 0, ...) 2023-06-29 11:27:50 +01:00
object_diff_test.go Fix diff display partially parsing JSON/YAML 2023-06-22 09:31:10 +01:00
options.go [cli] Abstract out terminal interactions 2022-11-08 17:13:56 -08:00
progress.go Print update summary in preview even if there are diagnostics. 2023-06-23 15:14:30 -07:00
progress_test.go Print update summary in preview even if there are diagnostics. 2023-06-23 15:14:30 -07:00
query.go all: Reformat with gofumpt 2023-03-03 09:00:24 -08:00
rows.go Use slice.Prealloc instead of make([]T, 0, ...) 2023-06-29 11:27:50 +01:00
sigint_unix.go [cli] Reimplement the interactive renderer 2022-11-07 22:02:44 -08:00
sigint_windows.go [cli] Reimplement the interactive renderer 2022-11-07 22:02:44 -08:00
tableutil.go [color] Use graphemes to measure strings. 2022-11-09 08:23:00 -08:00
tree.go Fixed panic in display on terminals with few rows and columns. 2023-03-30 16:16:48 -07:00
tree_test.go Fixed panic in display on terminals with few rows and columns. 2023-03-30 16:16:48 -07:00
watch.go [cli] Add a replay-events debug command. (#9271) 2022-04-07 09:03:19 -07:00