forked from mirrors/gecko-dev
		
	Bug 1810885 - Use ChromeMap for rewriting chrome:// URIs in Storybook r=hjones
Differential Revision: https://phabricator.services.mozilla.com/D170936
This commit is contained in:
		
							parent
							
								
									53f11d24f2
								
							
						
					
					
						commit
						a40c763925
					
				
					 4 changed files with 43 additions and 90 deletions
				
			
		
							
								
								
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							|  | @ -200,7 +200,7 @@ config/external/icu4x | ||||||
| # Ignore Storybook generated files | # Ignore Storybook generated files | ||||||
| browser/components/storybook/node_modules/ | browser/components/storybook/node_modules/ | ||||||
| browser/components/storybook/storybook-static/ | browser/components/storybook/storybook-static/ | ||||||
| browser/components/storybook/.storybook/rewrites.js | browser/components/storybook/.storybook/chrome-map.js | ||||||
| browser/components/storybook/custom-elements.json | browser/components/storybook/custom-elements.json | ||||||
| 
 | 
 | ||||||
| # Ignore jscodeshift installed by mach esmify on windows | # Ignore jscodeshift installed by mach esmify on windows | ||||||
|  |  | ||||||
|  | @ -273,7 +273,7 @@ gfx/wr/target/ | ||||||
| # Ignore Storybook generated files | # Ignore Storybook generated files | ||||||
| ^browser/components/storybook/node_modules/ | ^browser/components/storybook/node_modules/ | ||||||
| ^browser/components/storybook/storybook-static/ | ^browser/components/storybook/storybook-static/ | ||||||
| ^browser/components/storybook/.storybook/rewrites.js | ^browser/components/storybook/.storybook/chrome-map.js | ||||||
| ^browser/components/storybook/custom-elements.json | ^browser/components/storybook/custom-elements.json | ||||||
| 
 | 
 | ||||||
| # Ignore jscodeshift installed by mach esmify on windows | # Ignore jscodeshift installed by mach esmify on windows | ||||||
|  |  | ||||||
|  | @ -4,10 +4,33 @@ | ||||||
| /* eslint-env node */ | /* eslint-env node */ | ||||||
| 
 | 
 | ||||||
| const path = require("path"); | const path = require("path"); | ||||||
|  | const webpack = require("webpack"); | ||||||
|  | 
 | ||||||
|  | const [prefixMap, aliasMap, sourceMap] = require("./chrome-map.js"); | ||||||
|  | 
 | ||||||
| const projectRoot = path.resolve(__dirname, "../../../../"); | const projectRoot = path.resolve(__dirname, "../../../../"); | ||||||
| 
 | 
 | ||||||
| // ./mach environment --format json
 | function rewriteChromeUri(uri) { | ||||||
| // topobjdir should be the build location
 |   if (uri in aliasMap) { | ||||||
|  |     return rewriteChromeUri(aliasMap[uri]); | ||||||
|  |   } | ||||||
|  |   for (let [prefix, [bundlePath]] of Object.entries(prefixMap)) { | ||||||
|  |     if (uri.startsWith(prefix)) { | ||||||
|  |       if (!bundlePath.endsWith("/")) { | ||||||
|  |         bundlePath += "/"; | ||||||
|  |       } | ||||||
|  |       let relativePath = uri.slice(prefix.length); | ||||||
|  |       let objdirPath = bundlePath + relativePath; | ||||||
|  |       for (let [_objdirPath, [filePath]] of Object.entries(sourceMap)) { | ||||||
|  |         if (_objdirPath == objdirPath) { | ||||||
|  |           // We're just hoping this is the actual path =\
 | ||||||
|  |           return filePath; | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   return ""; | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| module.exports = { | module.exports = { | ||||||
|   stories: [ |   stories: [ | ||||||
|  | @ -62,16 +85,18 @@ module.exports = { | ||||||
|     config.resolve.alias["lit-html/directive-helpers.js"] = "lit.all.mjs"; |     config.resolve.alias["lit-html/directive-helpers.js"] = "lit.all.mjs"; | ||||||
|     config.resolve.alias["lit-html"] = "lit.all.mjs"; |     config.resolve.alias["lit-html"] = "lit.all.mjs"; | ||||||
| 
 | 
 | ||||||
|  |     config.plugins.push( | ||||||
|  |       // Rewrite chrome:// URI imports to file system paths.
 | ||||||
|  |       new webpack.NormalModuleReplacementPlugin(/^chrome:\/\//, resource => { | ||||||
|  |         resource.request = rewriteChromeUri(resource.request); | ||||||
|  |       }) | ||||||
|  |     ); | ||||||
|  | 
 | ||||||
|     config.module.rules.push({ |     config.module.rules.push({ | ||||||
|       test: /\.ftl$/, |       test: /\.ftl$/, | ||||||
|       type: "asset/source", |       type: "asset/source", | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     config.module.rules.push({ |  | ||||||
|       test: /\.mjs/, |  | ||||||
|       loader: path.resolve(__dirname, "./chrome-uri-loader.js"), |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|     // We're adding a rule for files matching this pattern in order to support
 |     // We're adding a rule for files matching this pattern in order to support
 | ||||||
|     // writing docs only stories in plain markdown.
 |     // writing docs only stories in plain markdown.
 | ||||||
|     const MD_STORY_REGEX = /(stories|story)\.md$/; |     const MD_STORY_REGEX = /(stories|story)\.md$/; | ||||||
|  |  | ||||||
|  | @ -2,12 +2,8 @@ | ||||||
| # License, v. 2.0. If a copy of the MPL was not distributed with this | # License, v. 2.0. If a copy of the MPL was not distributed with this | ||||||
| # file, You can obtain one at http://mozilla.org/MPL/2.0/. | # file, You can obtain one at http://mozilla.org/MPL/2.0/. | ||||||
| 
 | 
 | ||||||
| import json |  | ||||||
| import os |  | ||||||
| 
 |  | ||||||
| import mozpack.path as mozpath | import mozpack.path as mozpath | ||||||
| from mach.decorators import Command, SubCommand | from mach.decorators import Command, SubCommand | ||||||
| from mozpack.manifests import InstallManifest |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @Command( | @Command( | ||||||
|  | @ -43,84 +39,16 @@ def storybook_launch(command_context): | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def build_storybook_manifest(command_context): | def build_storybook_manifest(command_context): | ||||||
|  |     print("Build ChromeMap backend") | ||||||
|  |     run_mach(command_context, "build-backend", backend=["ChromeMap"]) | ||||||
|     config_environment = command_context.config_environment |     config_environment = command_context.config_environment | ||||||
|     # The InstallManifest object will have mappings of JAR entries to paths on disk. |     storybook_chrome_map_path = "browser/components/storybook/.storybook/chrome-map.js" | ||||||
|     unified_manifest = InstallManifest( |     chrome_map_path = mozpath.join(config_environment.topobjdir, "chrome-map.json") | ||||||
|         mozpath.join(config_environment.topobjdir, "faster", "unified_install_dist_bin") |     with open(chrome_map_path, "r") as chrome_map_f: | ||||||
|     ) |         with open(storybook_chrome_map_path, "w") as storybook_chrome_map_f: | ||||||
|     paths = {} |             storybook_chrome_map_f.write("module.exports = ") | ||||||
| 
 |             storybook_chrome_map_f.write(chrome_map_f.read()) | ||||||
|     for dest, entry in unified_manifest._dests.items(): |             storybook_chrome_map_f.write(";") | ||||||
|         # dest in the JAR path |  | ||||||
|         # entry can be many things, but we care about the [1, file_path] form |  | ||||||
|         #   1 essentially means this is a file |  | ||||||
|         if ( |  | ||||||
|             entry[0] == 1 |  | ||||||
|             and (dest.endswith(".js") or dest.endswith(".mjs")) |  | ||||||
|             and ( |  | ||||||
|                 dest.startswith("chrome/toolkit/") or dest.startswith("browser/chrome/") |  | ||||||
|             ) |  | ||||||
|         ): |  | ||||||
|             try: |  | ||||||
|                 # Try to map the dest to a chrome URI. This could fail for some weird cases that |  | ||||||
|                 # don't seem like they're worth handling. |  | ||||||
|                 chrome_uri = _parse_dest_to_chrome_uri(dest) |  | ||||||
|                 # Since we run through mach we're relative to the project root here. |  | ||||||
|                 paths[chrome_uri] = os.path.relpath(entry[1]) |  | ||||||
|             except Exception as e: |  | ||||||
|                 # Log the files that failed, this could get noisy but the list is short for now. |  | ||||||
|                 print('Error rewriting to chrome:// URI "{}" [{}]'.format(dest, e)) |  | ||||||
|                 pass |  | ||||||
| 
 |  | ||||||
|     with open("browser/components/storybook/.storybook/rewrites.js", "w") as f: |  | ||||||
|         f.write("module.exports = ") |  | ||||||
|         json.dump(paths, f, indent=2) |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| def _parse_dest_to_chrome_uri(dest): |  | ||||||
|     """Turn a jar destination into a chrome:// URI. Will raise an error on unknown input.""" |  | ||||||
| 
 |  | ||||||
|     global_start = dest.find("global/") |  | ||||||
|     content_start = dest.find("content/") |  | ||||||
|     skin_classic_browser = "skin/classic/browser/" |  | ||||||
|     browser_skin_start = dest.find(skin_classic_browser) |  | ||||||
|     package, provider, path = "", "", "" |  | ||||||
| 
 |  | ||||||
|     if global_start != -1: |  | ||||||
|         # e.g. chrome/toolkit/content/global/vendor/lit.all.mjs |  | ||||||
|         #      chrome://global/content/vendor/lit.all.mjs |  | ||||||
|         # If the jar location has global in it, then: |  | ||||||
|         #   * the package is global, |  | ||||||
|         #   * the portion after global should be the path, |  | ||||||
|         #   * the provider is in the path somewhere (we want skin or content). |  | ||||||
|         package = "global" |  | ||||||
|         provider = "skin" if "/skin/" in dest else "content" |  | ||||||
|         path = dest[global_start + len("global/") :] |  | ||||||
|     elif content_start != -1: |  | ||||||
|         # e.g. browser/chrome/browser/content/browser/aboutDialog.js |  | ||||||
|         #      chrome://browser/content/aboutDialog.js |  | ||||||
|         # e.g. chrome/toolkit/content/mozapps/extensions/shortcuts.js |  | ||||||
|         #      chrome://mozapps/content/extensions/shortcuts.js |  | ||||||
|         # If the jar location has content/ in it, then: |  | ||||||
|         #   * starting from "content/" split on slashes and, |  | ||||||
|         #   * the provider is "content", |  | ||||||
|         #   * the package is the next part, |  | ||||||
|         #   * the path is the remainder. |  | ||||||
|         provider, package, path = dest[content_start:].split("/", 2) |  | ||||||
|     elif browser_skin_start != -1: |  | ||||||
|         # e.g. browser/chrome/browser/skin/classic/browser/browser.css |  | ||||||
|         #      chrome://browser/skin/browser.css |  | ||||||
|         # If the jar location has skin/classic/browser/ in it, then: |  | ||||||
|         #   * the package is browser, |  | ||||||
|         #   * the provider is skin, |  | ||||||
|         #   * the path is what remains after sking/classic/browser. |  | ||||||
|         package = "browser" |  | ||||||
|         provider = "skin" |  | ||||||
|         path = dest[browser_skin_start + len(skin_classic_browser) :] |  | ||||||
| 
 |  | ||||||
|     return "chrome://{package}/{provider}/{path}".format( |  | ||||||
|         package=package, provider=provider, path=path |  | ||||||
|     ) |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def run_mach(command_context, cmd, **kwargs): | def run_mach(command_context, cmd, **kwargs): | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Mark Striemer
						Mark Striemer