You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

227 lines
7.3 KiB

3 months ago
  1. # @jridgewell/gen-mapping
  2. > Generate source maps
  3. `gen-mapping` allows you to generate a source map during transpilation or minification.
  4. With a source map, you're able to trace the original location in the source file, either in Chrome's
  5. DevTools or using a library like [`@jridgewell/trace-mapping`][trace-mapping].
  6. You may already be familiar with the [`source-map`][source-map] package's `SourceMapGenerator`. This
  7. provides the same `addMapping` and `setSourceContent` API.
  8. ## Installation
  9. ```sh
  10. npm install @jridgewell/gen-mapping
  11. ```
  12. ## Usage
  13. ```typescript
  14. import { GenMapping, addMapping, setSourceContent, toEncodedMap, toDecodedMap } from '@jridgewell/gen-mapping';
  15. const map = new GenMapping({
  16. file: 'output.js',
  17. sourceRoot: 'https://example.com/',
  18. });
  19. setSourceContent(map, 'input.js', `function foo() {}`);
  20. addMapping(map, {
  21. // Lines start at line 1, columns at column 0.
  22. generated: { line: 1, column: 0 },
  23. source: 'input.js',
  24. original: { line: 1, column: 0 },
  25. });
  26. addMapping(map, {
  27. generated: { line: 1, column: 9 },
  28. source: 'input.js',
  29. original: { line: 1, column: 9 },
  30. name: 'foo',
  31. });
  32. assert.deepEqual(toDecodedMap(map), {
  33. version: 3,
  34. file: 'output.js',
  35. names: ['foo'],
  36. sourceRoot: 'https://example.com/',
  37. sources: ['input.js'],
  38. sourcesContent: ['function foo() {}'],
  39. mappings: [
  40. [ [0, 0, 0, 0], [9, 0, 0, 9, 0] ]
  41. ],
  42. });
  43. assert.deepEqual(toEncodedMap(map), {
  44. version: 3,
  45. file: 'output.js',
  46. names: ['foo'],
  47. sourceRoot: 'https://example.com/',
  48. sources: ['input.js'],
  49. sourcesContent: ['function foo() {}'],
  50. mappings: 'AAAA,SAASA',
  51. });
  52. ```
  53. ### Smaller Sourcemaps
  54. Not everything needs to be added to a sourcemap, and needless markings can cause signficantly
  55. larger file sizes. `gen-mapping` exposes `maybeAddSegment`/`maybeAddMapping` APIs that will
  56. intelligently determine if this marking adds useful information. If not, the marking will be
  57. skipped.
  58. ```typescript
  59. import { maybeAddMapping } from '@jridgewell/gen-mapping';
  60. const map = new GenMapping();
  61. // Adding a sourceless marking at the beginning of a line isn't useful.
  62. maybeAddMapping(map, {
  63. generated: { line: 1, column: 0 },
  64. });
  65. // Adding a new source marking is useful.
  66. maybeAddMapping(map, {
  67. generated: { line: 1, column: 0 },
  68. source: 'input.js',
  69. original: { line: 1, column: 0 },
  70. });
  71. // But adding another marking pointing to the exact same original location isn't, even if the
  72. // generated column changed.
  73. maybeAddMapping(map, {
  74. generated: { line: 1, column: 9 },
  75. source: 'input.js',
  76. original: { line: 1, column: 0 },
  77. });
  78. assert.deepEqual(toEncodedMap(map), {
  79. version: 3,
  80. names: [],
  81. sources: ['input.js'],
  82. sourcesContent: [null],
  83. mappings: 'AAAA',
  84. });
  85. ```
  86. ## Benchmarks
  87. ```
  88. node v18.0.0
  89. amp.js.map
  90. Memory Usage:
  91. gen-mapping: addSegment 5852872 bytes
  92. gen-mapping: addMapping 7716042 bytes
  93. source-map-js 6143250 bytes
  94. source-map-0.6.1 6124102 bytes
  95. source-map-0.8.0 6121173 bytes
  96. Smallest memory usage is gen-mapping: addSegment
  97. Adding speed:
  98. gen-mapping: addSegment x 441 ops/sec ±2.07% (90 runs sampled)
  99. gen-mapping: addMapping x 350 ops/sec ±2.40% (86 runs sampled)
  100. source-map-js: addMapping x 169 ops/sec ±2.42% (80 runs sampled)
  101. source-map-0.6.1: addMapping x 167 ops/sec ±2.56% (80 runs sampled)
  102. source-map-0.8.0: addMapping x 168 ops/sec ±2.52% (80 runs sampled)
  103. Fastest is gen-mapping: addSegment
  104. Generate speed:
  105. gen-mapping: decoded output x 150,824,370 ops/sec ±0.07% (102 runs sampled)
  106. gen-mapping: encoded output x 663 ops/sec ±0.22% (98 runs sampled)
  107. source-map-js: encoded output x 197 ops/sec ±0.45% (84 runs sampled)
  108. source-map-0.6.1: encoded output x 198 ops/sec ±0.33% (85 runs sampled)
  109. source-map-0.8.0: encoded output x 197 ops/sec ±0.06% (93 runs sampled)
  110. Fastest is gen-mapping: decoded output
  111. ***
  112. babel.min.js.map
  113. Memory Usage:
  114. gen-mapping: addSegment 37578063 bytes
  115. gen-mapping: addMapping 37212897 bytes
  116. source-map-js 47638527 bytes
  117. source-map-0.6.1 47690503 bytes
  118. source-map-0.8.0 47470188 bytes
  119. Smallest memory usage is gen-mapping: addMapping
  120. Adding speed:
  121. gen-mapping: addSegment x 31.05 ops/sec ±8.31% (43 runs sampled)
  122. gen-mapping: addMapping x 29.83 ops/sec ±7.36% (51 runs sampled)
  123. source-map-js: addMapping x 20.73 ops/sec ±6.22% (38 runs sampled)
  124. source-map-0.6.1: addMapping x 20.03 ops/sec ±10.51% (38 runs sampled)
  125. source-map-0.8.0: addMapping x 19.30 ops/sec ±8.27% (37 runs sampled)
  126. Fastest is gen-mapping: addSegment
  127. Generate speed:
  128. gen-mapping: decoded output x 381,379,234 ops/sec ±0.29% (96 runs sampled)
  129. gen-mapping: encoded output x 95.15 ops/sec ±2.98% (72 runs sampled)
  130. source-map-js: encoded output x 15.20 ops/sec ±7.41% (33 runs sampled)
  131. source-map-0.6.1: encoded output x 16.36 ops/sec ±10.46% (31 runs sampled)
  132. source-map-0.8.0: encoded output x 16.06 ops/sec ±6.45% (31 runs sampled)
  133. Fastest is gen-mapping: decoded output
  134. ***
  135. preact.js.map
  136. Memory Usage:
  137. gen-mapping: addSegment 416247 bytes
  138. gen-mapping: addMapping 419824 bytes
  139. source-map-js 1024619 bytes
  140. source-map-0.6.1 1146004 bytes
  141. source-map-0.8.0 1113250 bytes
  142. Smallest memory usage is gen-mapping: addSegment
  143. Adding speed:
  144. gen-mapping: addSegment x 13,755 ops/sec ±0.15% (98 runs sampled)
  145. gen-mapping: addMapping x 13,013 ops/sec ±0.11% (101 runs sampled)
  146. source-map-js: addMapping x 4,564 ops/sec ±0.21% (98 runs sampled)
  147. source-map-0.6.1: addMapping x 4,562 ops/sec ±0.11% (99 runs sampled)
  148. source-map-0.8.0: addMapping x 4,593 ops/sec ±0.11% (100 runs sampled)
  149. Fastest is gen-mapping: addSegment
  150. Generate speed:
  151. gen-mapping: decoded output x 379,864,020 ops/sec ±0.23% (93 runs sampled)
  152. gen-mapping: encoded output x 14,368 ops/sec ±4.07% (82 runs sampled)
  153. source-map-js: encoded output x 5,261 ops/sec ±0.21% (99 runs sampled)
  154. source-map-0.6.1: encoded output x 5,124 ops/sec ±0.58% (99 runs sampled)
  155. source-map-0.8.0: encoded output x 5,434 ops/sec ±0.33% (96 runs sampled)
  156. Fastest is gen-mapping: decoded output
  157. ***
  158. react.js.map
  159. Memory Usage:
  160. gen-mapping: addSegment 975096 bytes
  161. gen-mapping: addMapping 1102981 bytes
  162. source-map-js 2918836 bytes
  163. source-map-0.6.1 2885435 bytes
  164. source-map-0.8.0 2874336 bytes
  165. Smallest memory usage is gen-mapping: addSegment
  166. Adding speed:
  167. gen-mapping: addSegment x 4,772 ops/sec ±0.15% (100 runs sampled)
  168. gen-mapping: addMapping x 4,456 ops/sec ±0.13% (97 runs sampled)
  169. source-map-js: addMapping x 1,618 ops/sec ±0.24% (97 runs sampled)
  170. source-map-0.6.1: addMapping x 1,622 ops/sec ±0.12% (99 runs sampled)
  171. source-map-0.8.0: addMapping x 1,631 ops/sec ±0.12% (100 runs sampled)
  172. Fastest is gen-mapping: addSegment
  173. Generate speed:
  174. gen-mapping: decoded output x 379,107,695 ops/sec ±0.07% (99 runs sampled)
  175. gen-mapping: encoded output x 5,421 ops/sec ±1.60% (89 runs sampled)
  176. source-map-js: encoded output x 2,113 ops/sec ±1.81% (98 runs sampled)
  177. source-map-0.6.1: encoded output x 2,126 ops/sec ±0.10% (100 runs sampled)
  178. source-map-0.8.0: encoded output x 2,176 ops/sec ±0.39% (98 runs sampled)
  179. Fastest is gen-mapping: decoded output
  180. ```
  181. [source-map]: https://www.npmjs.com/package/source-map
  182. [trace-mapping]: https://github.com/jridgewell/trace-mapping