Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nwutils/nwjs-shell-builder
NW.js (node-webkit) shell script builder and packager scripts
https://github.com/nwutils/nwjs-shell-builder
builder-script nwjs shell
Last synced: 2 months ago
JSON representation
NW.js (node-webkit) shell script builder and packager scripts
- Host: GitHub
- URL: https://github.com/nwutils/nwjs-shell-builder
- Owner: nwutils
- License: mit
- Created: 2014-12-07T21:29:47.000Z (about 10 years ago)
- Default Branch: main
- Last Pushed: 2023-08-13T12:12:48.000Z (over 1 year ago)
- Last Synced: 2024-10-28T21:04:55.432Z (3 months ago)
- Topics: builder-script, nwjs, shell
- Language: Shell
- Homepage:
- Size: 86.9 KB
- Stars: 82
- Watchers: 9
- Forks: 22
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: CODEOWNERS
Awesome Lists containing this project
README
> This repository is in maintainance mode. Bug fixes will be provided on a best effort basis. If you use this project, please consider contributing back.
# nwjs application shell builder and packager
What's in here:
- [Builder script](#nwjs-shell-builder-script)
- [How it works](#how-it-works)
- [How we use it](#how-we-use-it)
- [Usage](#usage)
- [Options](#options)
- [Examples](#examples)
- [The bare minimum to build](#the-bare-minimum-to-build)
- [Clean working dir](#clean-working-dir)
- [Build for all targets](#build-for-all-targets)
- [Build only for windows 64 and 32 bit targets](#build-only-for-windows-64-and-32-bit-targets)
- [build only for OSX 32 bit target](#build-only-for-osx-32-bit-target)
- [Build for all 64 bit](#build-only-for-all-64-bit)
- [Packaging script](#nwjs-packaging-script-currently-in-beta) _(currently in **BETA**)_
- [Hooks](#hooks)
- [Usage](#usage-1)
- [License](#license)
- [Thanks](#thanks)## nwjs shell builder script
nwjs shell script builder for nwjs (node-webkit) applications.This script can be easily integrated into your build process.
### How it works
It will download nwjs 32/64bit for Linux, Windows and OSX and build for all 3 platforms from given source directory### How we use it
This script was made to help us automate nightly builds of [Gisto](http://www.gistoapp.com)You can see example usage in the CI script in Gisto repository: [drone.io script](https://github.com/Gisto/Gisto/blob/master/droneIO.sh)
### Usage:
> If you want/have to build on Windows machine, use: [Babun](http://babun.github.io/) as your shell. Tested on Windows 8 but should work on Windows 7 too. If you're missing an package (like ZIP), just install it via Babun with `pact` - a Babun provided package manager.`$ /path/to/nwjs-build.sh --help`
#### Options:
Option | Description
:------------------------------------- | :--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
`-h, --help` | Show help and usage
`--version=PACKAGE_VERSION` | Set package version (defaults to 1.0.0)
`--name=NAME` | Set package name (if not set - default will be used)
`--src=/PATH/TO/DIR` | Set path to source dir
`--target="2 3"` | Build for particular OS or all (default is to build for all targets)
Available targets:
- 0 - linux-ia32
- 1 - linux-x64
- 2 - win-ia32
- 3 - win-x64
- 4 - osx-ia32
- 5 - osx-x64
`--nw=VERSION` | Set nwjs version to use (if not set - default will be used)
`--output-dir=/PATH/TO/DIR` | Change output directory (if not set - default will be used)
`--win-icon=/PATH/TO/FILE` | (For Windows target only) Path to .ico file (if not set - default will be used)
`--osx-icon=/PATH/TO/FILE` | (For OSX target only) Path to .icns file (if not set - default will be used)
`--CFBundleIdentifier=com.bundle.name` | (For OSX target only) Name of the [bundle’s Identifier](https://developer.apple.com/library/ios/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html#//apple_ref/doc/uid/20001431-102070) (if not set - default will be used)
`--libudev` | (For Linux target only) Use if you want the script to handle the lack of _libudev.so.0_ (linux targets) as mentioned [here](https://github.com/nwjs/nw.js/wiki/The-solution-of-lacking-libudev.so.0)
`--build` | Start the build process (**IMPORTANT!** Must be the last parameter of the command)
`--clean` | Clean and remove TMP directory#### Examples
========================##### The bare minimum to build:
```
$ ./path/to/nwjs-build.sh \
--src=/home/projects/PACKAGE_NAME/src \
--build
```##### Clean working dir:
```
$ ./path/to/nwjs-build.sh \
--clean
```##### Build for all targets:
```
$ ./path/to/nwjs-build.sh \
--src=/home/projects/PACKAGE_NAME/src \
--output-dir=/path/to/output/the/builds \
--name=PACKAGE_NAME \
--win-icon=/home/projects/resorses/icon.ico \
--osx-icon=/home/projects/resorses/icon.icns \
--CFBundleIdentifier=com.bundle.name \
--target="0 1 2 3 4 5" \
--version="1.0.0" \
--libudev \
--nw=0.11.6 \
--build
```##### Build only for windows 64 and 32 bit targets:
```
$ ./path/to/nwjs-build.sh \
--src=/home/projects/PACKAGE_NAME/src \
--output-dir=/path/to/output/the/builds \
--name=PACKAGE_NAME \
--win-icon=/home/projects/resorses/icon.ico \
--target="2 3" \
--version="1.0.0" \
--build
```##### Build only for osx 32 bit target:
```
$ ./path/to/nwjs-build.sh \
--src=/home/projects/PACKAGE_NAME/src \
--output-dir=/path/to/output/the/builds \
--name=PACKAGE_NAME \
--osx-icon=/home/projects/resorses/icon.icns \
--CFBundleIdentifier=com.bundle.name \
--target="4" \
--version="1.0.0" \
--build
```##### Build for all 64 bit:
```
$ ./path/to/nwjs-build.sh \
--src=/home/projects/PACKAGE_NAME/src \
--output-dir=/path/to/output/the/builds \
--name=PACKAGE_NAME \
--osx-icon=/home/projects/resorses/icon.icns \
--win-icon=/home/projects/resorses/icon.ico \
--CFBundleIdentifier=com.bundle.name \
--target="1 3 5 " \
--version="1.0.0" \
--libudev \
--build
```## NWJS packaging script _(currently in **BETA**)_
> :exclamation: Please note that this is currently in BETA and it is not affecting the `build` script. You may off course use it but beta warning applies with all consequenses, so don't expect it to work out-of-the-box.
- install if not present zip, unzip, tar, git, NSIS, libxml2
- rename `config.json.sample` to `config.json` and adjust correct paths or generate with `./pack.sh init` or specify location of the `config.json` by adding `--config=/path/to/config.json`### Usage:
`./pack.sh init` - generate `config.json` with interactive CMD
`./pack.sh --windows` - to build Windows installers
`./pack.sh --linux` - to build Linux installers
`./pack.sh --osx` - to build OSX installers
`./pack.sh --all` - to build installers for all systems
`./pack.sh --all --config=/path/to/config.json` - to build installers for all systems but using `config.json` located in any other path than in root directory
`./pack.sh --clean` - removes the `./TMP` working directory`./pack.sh --clean all` - removes the `./TMP` working directory and `releases` directory (with all the content)
### Hooks:
Place hooks in `./hooks/` directory
- file name `before.sh` will be executed before each build start
- file name `after.sh` will be executed after packaging script is finished
- file name `after_build.sh` will be executed after each platform build is finished#### License
[MIT](https://github.com/Gisto/nwjs-shell-builder/blob/master/LICENSE)# Thanks
Huge thanks to @SchizoDuckie for assisting with OSX build