Commit cbb54ad
committed
fix(live-debugger): emit correct sourcemaps for instrumented functions
Live Debugger probes capture stack traces from instrumented functions.
For those traces to point at the right place in the user's source, the
source map for each transformed file must (a) carry segments for the
purely-injected probe code and (b) report positions in the original
source rather than in whatever intermediate buffer the transform was
handed.
For (a), wrap each function body's boundary characters (the opening
`{`, the closing `}`, and the trailing terminator of any leading
directive) via `MagicString#update` rather than `appendLeft`. `update`
routes content through `Mappings.addEdit`, which emits one source-map
segment per line of the new content anchored at the boundary
character's original location; `appendLeft` content goes through
`Mappings.advance` and produces no segments at all. Combined with
`hires: true`, every injected line resolves back to the function it
wraps, and the preamble and postamble can stay multi-line and readable
in the bundled output.
For (b), compose the magic-string delta map with the input source map
produced by the previous loader (e.g. `builtin:swc-loader` stripping
TypeScript types). With `enforce: 'post'` the transform sees the
post-loader buffer, so magic-string anchors to positions in *that*
buffer and labels them with the original file path. Without
composition the bundler reports those post-loader positions as if they
were original-source positions — captured probe stack frames in
production resolved to import statements near the top of the file
rather than the function body. Compose via `@jridgewell/remapping`
(already in the lockfile via `unplugin`) using the `inputSourceMap`
exposed by unplugin's native build context on webpack/rspack;
rollup/vite/esbuild compose maps through their own pipelines and don't
need this. Fall back to the un-composed map and log at error level —
matching the `Instrumentation Error` precedent in the same handler —
when composition throws, so a single malformed input map doesn't kill
instrumentation for every other file.
The integration test that exercises the full rspack pipeline uses a
non-identity input map (a banner-shift loader that shifts source line
numbers) so composition is validated end-to-end; an identity shim is
indistinguishable from no composition.1 parent 7dd0c81 commit cbb54ad
14 files changed
Lines changed: 481 additions & 30 deletions
File tree
- .yarn/cache
- packages
- plugins/live-debugger
- src
- transform
- published
- esbuild-plugin
- rollup-plugin
- rspack-plugin
- vite-plugin
- webpack-plugin
Binary file not shown.
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
165 | 165 | | |
166 | 166 | | |
167 | 167 | | |
168 | | - | |
| 168 | + | |
169 | 169 | | |
170 | 170 | | |
171 | 171 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
24 | 24 | | |
25 | 25 | | |
26 | 26 | | |
| 27 | + | |
27 | 28 | | |
28 | 29 | | |
29 | 30 | | |
30 | 31 | | |
31 | 32 | | |
32 | 33 | | |
| 34 | + | |
33 | 35 | | |
34 | 36 | | |
35 | 37 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
212 | 212 | | |
213 | 213 | | |
214 | 214 | | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
| 270 | + | |
| 271 | + | |
| 272 | + | |
| 273 | + | |
| 274 | + | |
| 275 | + | |
| 276 | + | |
| 277 | + | |
| 278 | + | |
| 279 | + | |
| 280 | + | |
| 281 | + | |
| 282 | + | |
| 283 | + | |
| 284 | + | |
| 285 | + | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
215 | 328 | | |
216 | 329 | | |
217 | 330 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
7 | 11 | | |
8 | 12 | | |
9 | 13 | | |
| |||
103 | 107 | | |
104 | 108 | | |
105 | 109 | | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
106 | 116 | | |
107 | 117 | | |
108 | | - | |
| 118 | + | |
109 | 119 | | |
110 | 120 | | |
111 | 121 | | |
| |||
158 | 168 | | |
159 | 169 | | |
160 | 170 | | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
0 commit comments