electron/docs/tutorial/application-distribution.md

125 lines
4.1 KiB
Markdown
Raw Permalink Normal View History

---
title: 'Application Packaging'
description: 'To distribute your app with Electron, you need to package and rebrand it. To do this, you can either use specialized tooling or manual approaches.'
slug: application-distribution
hide_title: false
---
To distribute your app with Electron, you need to package and rebrand it. To do this, you
can either use specialized tooling or manual approaches.
## With tooling
There are a couple tools out there that exist to package and distribute your Electron app.
We recommend using [Electron Forge](./forge-overview.md). You can check out
its [documentation](https://www.electronforge.io) directly, or refer to the [Packaging and Distribution](./tutorial-5-packaging.md)
part of the Electron tutorial.
## Manual packaging
If you prefer the manual approach, there are 2 ways to distribute your application:
- With prebuilt binaries
- With an app source code archive
### With prebuilt binaries
To distribute your app manually, you need to download Electron's
[prebuilt binaries](https://github.com/electron/electron/releases). Next, the folder
containing your app should be named `app` and placed in Electron's resources
directory as shown in the following examples.
:::note
The location of Electron's prebuilt binaries is indicated
with `electron/` in the examples below.
:::
```plain title='macOS'
2015-04-15 21:31:12 -06:00
electron/Electron.app/Contents/Resources/app/
├── package.json
├── main.js
└── index.html
```
```plain title='Windows and Linux'
2015-04-15 21:31:12 -06:00
electron/resources/app
├── package.json
├── main.js
└── index.html
```
Then execute `Electron.app` on macOS, `electron` on Linux, or `electron.exe`
on Windows, and Electron will start as your app. The `electron` directory
will then be your distribution to deliver to users.
### With an app source code archive (asar)
2014-12-29 11:46:15 -07:00
2021-11-17 11:20:24 -07:00
Instead of shipping your app by copying all of its source files, you can
package your app into an [asar][] archive to improve the performance of reading
files on platforms like Windows, if you are not already using a bundler such
as Parcel or Webpack.
2014-12-29 11:46:15 -07:00
To use an `asar` archive to replace the `app` folder, you need to rename the
2015-04-15 21:31:12 -06:00
archive to `app.asar`, and put it under Electron's resources directory like
below, and Electron will then try to read the archive and start from it.
2014-12-29 11:46:15 -07:00
```plain title='macOS'
2015-04-15 21:31:12 -06:00
electron/Electron.app/Contents/Resources/
2014-12-29 11:46:15 -07:00
└── app.asar
```
```plain title='Windows'
2015-04-15 21:31:12 -06:00
electron/resources/
2014-12-29 11:46:15 -07:00
└── app.asar
```
You can find more details on how to use `asar` in the
[`electron/asar` repository][asar].
2014-12-29 11:46:15 -07:00
### Rebranding with downloaded binaries
2014-12-29 11:46:15 -07:00
2015-04-15 21:31:12 -06:00
After bundling your app into Electron, you will want to rebrand Electron
before distributing it to users.
2014-09-29 07:34:54 -06:00
- **Windows:** You can rename `electron.exe` to any name you like, and edit
its icon and other information with tools like [rcedit](https://github.com/electron/rcedit).
- **Linux:** You can rename the `electron` executable to any name you like.
- **macOS:** You can rename `Electron.app` to any name you want, and you also have to rename
the `CFBundleDisplayName`, `CFBundleIdentifier` and `CFBundleName` fields in the
following files:
2014-12-29 11:46:15 -07:00
- `Electron.app/Contents/Info.plist`
- `Electron.app/Contents/Frameworks/Electron Helper.app/Contents/Info.plist`
2015-04-16 21:59:40 -06:00
You can also rename the helper app to avoid showing `Electron Helper` in the
Activity Monitor, but make sure you have renamed the helper app's executable
file's name.
2015-04-16 21:59:40 -06:00
The structure of a renamed app would be like:
2015-04-16 21:59:40 -06:00
```plain
2015-04-16 21:59:40 -06:00
MyApp.app/Contents
├── Info.plist
├── MacOS/
│ └── MyApp
2015-04-16 21:59:40 -06:00
└── Frameworks/
└── MyApp Helper.app
├── Info.plist
└── MacOS/
└── MyApp Helper
2015-04-16 21:59:40 -06:00
```
2014-12-29 11:46:15 -07:00
:::note
it is also possible to rebrand Electron by changing the product name and
building it from source. To do this you need to set the build argument
corresponding to the product name (`electron_product_name = "YourProductName"`)
in the `args.gn` file and rebuild.
Keep in mind this is not recommended as setting up the environment to compile
from source is not trivial and takes significant time.
:::
[asar]: https://github.com/electron/asar