2019-10-04 17:49:09 +00:00
# Supported Command Line Switches
2014-08-15 05:06:52 +00:00
2016-04-21 22:39:12 +00:00
> Command line switches supported by Electron.
2016-04-21 22:35:29 +00:00
You can use [app.commandLine.appendSwitch][append-switch] to append them in
2016-04-22 18:42:54 +00:00
your app's main script before the [ready][ready] event of the [app][app] module
is emitted:
2014-08-15 05:06:52 +00:00
```javascript
2018-09-13 16:10:51 +00:00
const { app } = require('electron')
2016-07-26 01:39:25 +00:00
app.commandLine.appendSwitch('remote-debugging-port', '8315')
app.commandLine.appendSwitch('host-rules', 'MAP * 127.0.0.1')
2014-08-15 05:06:52 +00:00
2020-02-03 22:43:22 +00:00
app.whenReady().then(() => {
2015-06-09 14:59:14 +00:00
// Your code here
2016-07-26 01:39:25 +00:00
})
2014-08-15 05:06:52 +00:00
```
2020-02-07 02:59:38 +00:00
## Electron CLI Flags
2015-06-16 08:13:46 +00:00
2020-02-07 02:59:38 +00:00
### --auth-server-whitelist=`url`
2018-02-08 16:49:28 +00:00
2020-02-07 02:59:38 +00:00
A comma-separated list of servers for which integrated authentication is enabled.
2016-10-13 09:53:33 +00:00
2020-02-07 02:59:38 +00:00
For example:
2014-08-15 05:06:52 +00:00
2020-02-07 02:59:38 +00:00
```sh
--auth-server-whitelist='*example.com, *foobar.com, *baz'
```
2014-08-15 05:06:52 +00:00
2020-02-07 02:59:38 +00:00
then any `url` ending with `example.com` , `foobar.com` , `baz` will be considered
for integrated authentication. Without `*` prefix the URL has to match exactly.
2017-05-15 17:38:20 +00:00
2020-02-07 02:59:38 +00:00
### --auth-negotiate-delegate-whitelist=`url`
2017-05-15 17:38:20 +00:00
2020-02-07 02:59:38 +00:00
A comma-separated list of servers for which delegation of user credentials is required.
Without `*` prefix the URL has to match exactly.
2015-11-13 04:22:08 +00:00
2020-06-02 19:58:00 +00:00
### --disable-ntlm-v2
Disables NTLM v2 for posix platforms, no effect elsewhere.
2020-02-07 02:59:38 +00:00
### --disable-http-cache
2015-11-13 04:22:08 +00:00
2020-02-07 02:59:38 +00:00
Disables the disk cache for HTTP requests.
2015-11-13 04:22:08 +00:00
2020-02-07 02:59:38 +00:00
### --disable-http2
2016-10-13 09:53:33 +00:00
2020-02-07 02:59:38 +00:00
Disable HTTP/2 and SPDY/3.1 protocols.
2014-08-20 03:57:15 +00:00
2020-02-07 02:59:38 +00:00
### --disable-renderer-backgrounding
2014-08-20 03:57:15 +00:00
2020-02-07 02:59:38 +00:00
Prevents Chromium from lowering the priority of invisible pages' renderer
processes.
2015-11-22 21:44:20 +00:00
2020-02-07 02:59:38 +00:00
This flag is global to all renderer processes, if you only want to disable
throttling in one window, you can take the hack of
[playing silent audio][play-silent-audio].
2015-11-22 21:44:20 +00:00
2020-02-07 02:59:38 +00:00
### --disk-cache-size=`size`
2015-11-22 21:44:20 +00:00
2020-02-07 02:59:38 +00:00
Forces the maximum disk space to be used by the disk cache, in bytes.
2015-11-22 21:44:20 +00:00
2023-01-16 09:22:49 +00:00
### --enable-logging\[=file]
2015-07-10 08:26:21 +00:00
2021-06-17 21:17:25 +00:00
Prints Chromium's logging to stderr (or a log file).
2014-08-20 03:57:15 +00:00
2021-06-17 21:17:25 +00:00
The `ELECTRON_ENABLE_LOGGING` environment variable has the same effect as
passing `--enable-logging` .
Passing `--enable-logging` will result in logs being printed on stderr.
Passing `--enable-logging=file` will result in logs being saved to the file
specified by `--log-file=...` , or to `electron_debug.log` in the user-data
directory if `--log-file` is not specified.
> **Note:** On Windows, logs from child processes cannot be sent to stderr.
> Logging to a file is the most reliable way to collect logs on Windows.
See also `--log-file` , `--log-level` , `--v` , and `--vmodule` .
2014-08-20 03:57:15 +00:00
2021-05-15 01:32:21 +00:00
### --force-fieldtrials=`trials`
2021-03-26 00:49:00 +00:00
Field trials to be forcefully enabled or disabled.
For example: `WebRTC-Audio-Red-For-Opus/Enabled/`
2020-02-07 02:59:38 +00:00
### --host-rules=`rules`
2014-08-15 05:06:52 +00:00
2015-07-23 16:59:51 +00:00
A comma-separated list of `rules` that control how hostnames are mapped.
2014-08-15 05:06:52 +00:00
For example:
* `MAP * 127.0.0.1` Forces all hostnames to be mapped to 127.0.0.1
* `MAP *.google.com proxy` Forces all google.com subdomains to be resolved to
"proxy".
* `MAP test.com [::1]:77` Forces "test.com" to resolve to IPv6 loopback. Will
also force the port of the resulting socket address to be 77.
* `MAP * baz, EXCLUDE www.google.com` Remaps everything to "baz", except for
"www.google.com".
These mappings apply to the endpoint host in a net request (the TCP connect
2015-07-23 16:59:51 +00:00
and host resolver in a direct connection, and the `CONNECT` in an HTTP proxy
2014-08-15 05:06:52 +00:00
connection, and the endpoint host in a `SOCKS` proxy connection).
2020-02-07 02:59:38 +00:00
### --host-resolver-rules=`rules`
2014-08-15 05:06:52 +00:00
Like `--host-rules` but these `rules` only apply to the host resolver.
2020-02-07 02:59:38 +00:00
### --ignore-certificate-errors
2016-05-21 18:08:50 +00:00
2020-02-07 02:59:38 +00:00
Ignores certificate related errors.
2016-05-21 18:08:50 +00:00
2020-02-07 02:59:38 +00:00
### --ignore-connections-limit=`domains`
Ignore the connections limit for `domains` list separated by `,` .
### --js-flags=`flags`
Specifies the flags passed to the Node.js engine. It has to be passed when starting
Electron if you want to enable the `flags` in the main process.
2016-05-21 18:08:50 +00:00
2017-11-24 10:13:57 +00:00
```sh
2020-02-07 02:59:38 +00:00
$ electron --js-flags="--harmony_proxies --harmony_collections" your-app
2016-05-21 18:08:50 +00:00
```
2020-02-07 02:59:38 +00:00
See the [Node.js documentation][node-cli] or run `node --help` in your terminal for a list of available flags. Additionally, run `node --v8-options` to see a list of flags that specifically refer to Node.js's V8 JavaScript engine.
2016-05-21 18:08:50 +00:00
2020-02-07 02:59:38 +00:00
### --lang
2016-05-21 18:08:50 +00:00
2020-02-07 02:59:38 +00:00
Set a custom locale.
2016-05-21 18:08:50 +00:00
2021-06-17 21:17:25 +00:00
### --log-file=`path`
If `--enable-logging` is specified, logs will be written to the given path. The
parent directory must exist.
Setting the `ELECTRON_LOG_FILE` environment variable is equivalent to passing
this flag. If both are present, the command-line switch takes precedence.
2020-02-07 02:59:38 +00:00
### --log-net-log=`path`
2015-01-07 04:52:28 +00:00
2020-02-07 02:59:38 +00:00
Enables net log events to be saved and writes them to `path` .
2015-03-25 12:21:56 +00:00
2021-06-17 21:17:25 +00:00
### --log-level=`N`
Sets the verbosity of logging when used together with `--enable-logging` .
`N` should be one of [Chrome's LogSeverities][severities].
Note that two complimentary logging mechanisms in Chromium -- `LOG()`
and `VLOG()` -- are controlled by different switches. `--log-level`
controls `LOG()` messages, while `--v` and `--vmodule` control `VLOG()`
messages. So you may want to use a combination of these three switches
depending on the granularity you want and what logging calls are made
by the code you're trying to watch.
See [Chromium Logging source][logging] for more information on how
`LOG()` and `VLOG()` interact. Loosely speaking, `VLOG()` can be thought
of as sub-levels / per-module levels inside `LOG(INFO)` to control the
firehose of `LOG(INFO)` data.
See also `--enable-logging` , `--log-level` , `--v` , and `--vmodule` .
2020-02-07 02:59:38 +00:00
### --no-proxy-server
2015-05-10 04:55:19 +00:00
2020-02-07 02:59:38 +00:00
Don't use a proxy server and always make direct connections. Overrides any other
proxy server flags that are passed.
2015-05-10 04:55:19 +00:00
2020-02-07 02:59:38 +00:00
### --no-sandbox
2015-05-10 04:55:19 +00:00
2021-05-06 11:53:55 +00:00
Disables the Chromium [sandbox ](https://www.chromium.org/developers/design-documents/sandbox ).
Forces renderer process and Chromium helper processes to run un-sandboxed.
2020-02-07 02:59:38 +00:00
Should only be used for testing.
2015-05-10 04:55:19 +00:00
2020-02-07 02:59:38 +00:00
### --proxy-bypass-list=`hosts`
2015-06-05 19:29:28 +00:00
2020-02-07 02:59:38 +00:00
Instructs Electron to bypass the proxy server for the given semi-colon-separated
list of hosts. This flag has an effect only if used in tandem with
`--proxy-server` .
2015-06-05 19:29:28 +00:00
2020-02-07 02:59:38 +00:00
For example:
2016-01-07 04:28:20 +00:00
2020-02-07 02:59:38 +00:00
```javascript
const { app } = require('electron')
app.commandLine.appendSwitch('proxy-bypass-list', '< local > ;*.google.com;*foo.com;1.2.3.4:5678')
```
2016-01-07 04:28:20 +00:00
2020-02-07 02:59:38 +00:00
Will use the proxy server for all hosts except for local addresses (`localhost`,
`127.0.0.1` etc.), `google.com` subdomains, hosts that contain the suffix
`foo.com` and anything at `1.2.3.4:5678` .
2015-10-19 20:56:01 +00:00
2020-02-07 02:59:38 +00:00
### --proxy-pac-url=`url`
2015-10-03 07:43:26 +00:00
2020-02-07 02:59:38 +00:00
Uses the PAC script at the specified `url` .
2015-10-03 07:43:26 +00:00
2020-02-07 02:59:38 +00:00
### --proxy-server=`address:port`
Use a specified proxy server, which overrides the system setting. This switch
only affects requests with HTTP protocol, including HTTPS and WebSocket
requests. It is also noteworthy that not all proxy servers support HTTPS and
WebSocket requests. The proxy URL does not support username and password
authentication [per Chromium issue ](https://bugs.chromium.org/p/chromium/issues/detail?id=615947 ).
### --remote-debugging-port=`port`
Enables remote debugging over HTTP on the specified `port` .
2015-10-03 07:43:26 +00:00
2020-02-07 02:59:38 +00:00
### --v=`log_level`
2015-03-25 12:21:56 +00:00
2015-03-26 03:27:06 +00:00
Gives the default maximal active V-logging level; 0 is the default. Normally
positive values are used for V-logging levels.
2015-03-25 12:21:56 +00:00
2015-10-03 07:43:26 +00:00
This switch only works when `--enable-logging` is also passed.
2015-03-25 12:21:56 +00:00
2021-06-17 21:17:25 +00:00
See also `--enable-logging` , `--log-level` , and `--vmodule` .
2020-02-07 02:59:38 +00:00
### --vmodule=`pattern`
2015-03-25 12:21:56 +00:00
2015-03-26 03:27:06 +00:00
Gives the per-module maximal V-logging levels to override the value given by
`--v` . E.g. `my_module=2,foo*=3` would change the logging level for all code in
source files `my_module.*` and `foo*.*` .
2015-03-25 12:21:56 +00:00
2015-03-26 03:27:06 +00:00
Any pattern containing a forward or backward slash will be tested against the
2018-05-08 05:16:09 +00:00
whole pathname and not only the module. E.g. `*/foo/bar/*=2` would change the
2015-07-23 16:59:51 +00:00
logging level for all code in the source files under a `foo/bar` directory.
2015-03-25 12:21:56 +00:00
2015-10-03 07:43:26 +00:00
This switch only works when `--enable-logging` is also passed.
2016-01-07 04:28:20 +00:00
2021-06-17 21:17:25 +00:00
See also `--enable-logging` , `--log-level` , and `--v` .
2020-09-29 15:49:09 +00:00
### --force_high_performance_gpu
Force using discrete GPU when there are multiple GPUs available.
### --force_low_power_gpu
Force using integrated GPU when there are multiple GPUs available.
2020-02-07 02:59:38 +00:00
## Node.js Flags
2019-10-04 17:49:09 +00:00
2020-02-07 02:59:38 +00:00
Electron supports some of the [CLI flags][node-cli] supported by Node.js.
2019-10-04 17:49:09 +00:00
2020-02-07 02:59:38 +00:00
**Note:** Passing unsupported command line switches to Electron when it is not running in `ELECTRON_RUN_AS_NODE` will have no effect.
2019-04-24 04:07:40 +00:00
2023-08-04 10:59:40 +00:00
### `--inspect-brk\[=\[host:]port]`
2020-02-07 02:59:38 +00:00
Activate inspector on host:port and break at start of user script. Default host:port is 127.0.0.1:9229.
Aliased to `--debug-brk=[host:]port` .
2023-08-04 10:59:40 +00:00
#### `--inspect-brk-node[=[host:]port]`
Activate inspector on `host:port` and break at start of the first internal
JavaScript script executed when the inspector is available.
Default `host:port` is `127.0.0.1:9229` .
### `--inspect-port=\[host:]port`
2020-02-07 02:59:38 +00:00
Set the `host:port` to be used when the inspector is activated. Useful when activating the inspector by sending the SIGUSR1 signal. Default host is `127.0.0.1` .
Aliased to `--debug-port=[host:]port` .
2023-08-04 10:59:40 +00:00
### `--inspect\[=\[host:]port]`
2020-02-07 02:59:38 +00:00
Activate inspector on `host:port` . Default is `127.0.0.1:9229` .
2020-03-31 04:06:25 +00:00
V8 inspector integration allows tools such as Chrome DevTools and IDEs to debug and profile Electron instances. The tools attach to Electron instances via a TCP port and communicate using the [Chrome DevTools Protocol ](https://chromedevtools.github.io/devtools-protocol/ ).
2020-02-07 02:59:38 +00:00
See the [Debugging the Main Process][debugging-main-process] guide for more details.
Aliased to `--debug[=[host:]port` .
2023-08-04 10:59:40 +00:00
### `--inspect-publish-uid=stderr,http`
2020-11-05 22:12:43 +00:00
2020-02-07 02:59:38 +00:00
Specify ways of the inspector web socket url exposure.
By default inspector websocket url is available in stderr and under /json/list endpoint on http://host:port/json/list.
2019-04-24 04:07:40 +00:00
2023-08-04 10:59:40 +00:00
### `--no-deprecation`
Silence deprecation warnings.
### `--throw-deprecation`
Throw errors for deprecations.
### `--trace-deprecation`
Print stack traces for deprecations.
### `--trace-warnings`
Print stack traces for process warnings (including deprecations).
2023-08-15 10:19:45 +00:00
### `--dns-result-order=order`
Set the default value of the `verbatim` parameter in the Node.js [`dns.lookup()` ](https://nodejs.org/api/dns.html#dnslookuphostname-options-callback ) and [`dnsPromises.lookup()` ](https://nodejs.org/api/dns.html#dnspromiseslookuphostname-options ) functions. The value could be:
* `ipv4first` : sets default `verbatim` `false` .
* `verbatim` : sets default `verbatim` `true` .
The default is `verbatim` and `dns.setDefaultResultOrder()` have higher priority than `--dns-result-order` .
2016-01-07 04:28:20 +00:00
[app]: app.md
2020-10-20 01:46:27 +00:00
[append-switch]: command-line.md#commandlineappendswitchswitch-value
2016-10-13 09:53:33 +00:00
[debugging-main-process]: ../tutorial/debugging-main-process.md
2022-03-17 12:45:55 +00:00
[logging]: https://source.chromium.org/chromium/chromium/src/+/main:base/logging.h
2016-10-13 10:03:29 +00:00
[node-cli]: https://nodejs.org/api/cli.html
2021-06-17 21:17:25 +00:00
[play-silent-audio]: https://github.com/atom/atom/pull/9485/files
[ready]: app.md#event-ready
2022-03-17 12:45:55 +00:00
[severities]: https://source.chromium.org/chromium/chromium/src/+/main:base/logging.h?q=logging::LogSeverity& ss=chromium