xt-build
xt-build
command builds an extension project.
Build command can be used to create a debuggable version, or a production-ready .zip file that can be uploaded to an extension/add-on marketplace for distribution.
Successful build command always generates an extension in build output directory that can be debugged in the browser. The underlying build system uses gulp, babel and webpack (among other plugins) to compile the extension project.
Dev Build Artifacts
When specifyingdev
build flag, the build will complete using development settings. Successful dev build generates extension source code in the specified build output directory, which can be debugged in a browser.
Prod Build Artifacts
When specifying prod
build flag, the build will run a production build. Successful production build generates extension source code in build output directory, which can be debugged in a browser. It also generates a .zip file in the project root. This zip file can be uploaded to extension/add-on marketplace such as Chrome Web Store or Firefox add-ons. When running a production build, all code files (js, css, HTML, json) will be optimized.
Commands
Braces { }
indicate that the user must choose one (and only one) of the items inside the braces.
Run build with default options
Default option runs production build targeting Chrome browser.
1 |
|
Run build with explicit environment flag -e
or --env
1 |
|
1 |
|
Run build for specific target browser
1 |
|
1 |
|
Run build using custom configuration file path
1 |
|
Run development build and keep watching changes
1 |
|
Get help using this command
1 |
|
Package.json scripts
After adding Extension CLI to your project, you can run these commands from a
terminal using syntax npx xt-build
, or add the following to packages.json
scripts section,
then execute the commands as npm run start
or npm run build
:
1 2 3 4 |
|
Default Configuration
By default the CLI will look for build configuration in two different places:
-
in
package.json
using keyxtbuild
-
in a file named
.xtbuild.json
in project root
Alternatively you can provide a path to configuration file with -c
or
--config
flag, followed by a path to configuration file.
The CLI uses a default build configuration shown below. This tells extension CLI where to look for input files, how to process them, and where to output files. You can override any of these key-value pairs at project level.
Explanations for each of these keys is given below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
|
Configuration Keys
Key | Description | Guide |
---|---|---|
"dist" |
Build output directory | |
"source" |
Source code directory | |
"releases" |
Directory for outputting release zip file | |
"release_name" |
name of release zip file | |
"manifest" |
extension manifest file path | Guide |
"js" |
Watch pattern for script changes during dev builds | |
"js_bundles" |
Javascript bundles configuration | Guide |
"html" |
location and watch pattern of HTML files | |
"scss" |
Watch pattern for style changes during dev builds | |
"scss_bundles" |
Stylesheets bundles configuration | Guide |
"assets" |
Static assets configuration match pattern | Guide |
"copyAsIs" |
Files and directories to copy to output directory without modification | Guide |
"locales_dir" |
Localizations directory | Guide |
"locales_list" |
List of locales | Guide |
"commands" |
Custom commands | Guide |