Repository: haxpor/aseprite-macos-buildsh
Branch: master
Commit: 6e3672eab1e8
Files: 12
Total size: 12.3 KB
Directory structure:
gitextract_qd71miwl/
├── .gitignore
├── Aseprite.app/
│ ├── Contents/
│ │ ├── Info.plist
│ │ ├── MacOS/
│ │ │ └── applet
│ │ ├── PkgInfo
│ │ └── Resources/
│ │ ├── Scripts/
│ │ │ └── main.scpt
│ │ ├── applet.icns
│ │ ├── applet.rsrc
│ │ └── description.rtfd/
│ │ └── TXT.rtf
│ └── Icon
├── LICENSE
├── README.md
└── aseprite.sh
================================================
FILE CONTENTS
================================================
================================================
FILE: .gitignore
================================================
aseprite/
deps/
================================================
FILE: Aseprite.app/Contents/Info.plist
================================================
CFBundleAllowMixedLocalizations
CFBundleDevelopmentRegion
English
CFBundleExecutable
applet
CFBundleIconFile
applet
CFBundleIdentifier
com.apple.ScriptEditor.id.Aseprite
CFBundleInfoDictionaryVersion
6.0
CFBundleName
Aseprite
CFBundlePackageType
APPL
CFBundleShortVersionString
1.0
CFBundleSignature
aplt
LSMinimumSystemVersionByArchitecture
x86_64
10.6
LSRequiresCarbon
WindowState
bundleDividerCollapsed
bundlePositionOfDivider
0.0
dividerCollapsed
eventLogLevel
2
name
ScriptWindowState
positionOfDivider
157
savedFrame
214 69 700 672 0 0 1280 777
selectedTab
result
================================================
FILE: Aseprite.app/Contents/PkgInfo
================================================
APPLaplt
================================================
FILE: Aseprite.app/Contents/Resources/description.rtfd/TXT.rtf
================================================
{\rtf1\ansi\ansicpg1252\cocoartf1539\cocoasubrtf120
{\fonttbl}
{\colortbl;\red255\green255\blue255;}
{\*\expandedcolortbl;;}
}
================================================
FILE: Aseprite.app/Icon
================================================
================================================
FILE: LICENSE
================================================
MIT License
Copyright (c) 2017 Wasin Thonkaew
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
================================================
FILE: README.md
================================================
# aseprite-macos-buildsh
Automated script to create latest release (whatever it will be either development snapshot commit, beta, or release) of Aseprite for macOS
Update : Added support x64 Architecture build for SKIA on MacOS
Project is updated against aseprite v.1.2.10 build workflow.
# Pre-Requisite
You need
* Xcode
* [CMake](http://www.cmake.org/) (3.4 or greater)
* [Ninja](https://ninja-build.org/) build system
* Python 2.x ([version 3](https://github.com/haxpor/aseprite-macos-buildsh/issues/2) didn't work)
For Xcode, you need to install it by downloading [here](https://developer.apple.com/download/). After successfully installed, execute `xcode-select --install` to install its toolchain, then finally follow along as dialog popup shows up.
Now you're ready to use this script.
# How to Build
Just execute `bash aseprite.sh`. Then open `Aseprite` application.
If the script asks for root password, enter it. This is to be able to execute command to properly set environment path variable. It's safe, the script never try to do anything beside trying to build the app successfully.
## Command line Configuration
In case you want to install aseprite to different path, or your `xcode-select` is not set properly, you can use either `--sdk-root` and `--target` to properly set things up before building.
* `--sdk-root`
To set your latest macOS SDK root as part of Xcode toolchain. By default it will query current prefix-value from `xcode-select` and append it with `/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.14.sdk`. But in case, it doesn't work or `xcode-select` didn't do the work, you can use this option to manually specify it.
* `--target`
To set you target path to install aseprite. By default it will be at `/Applications` but some users might want it differently. In case you use this parameter, please see [#3](https://github.com/haxpor/aseprite-macos-buildsh/issues/3).
So for example, you will execute
```
bash aseprite.sh --sdk-root /Volumes/Slave/Applications/Xcode8.3/Xcode.app/Contents/Developer --target ~/slave/Applications
```
**note** if you use `--target`, please see [#3](https://github.com/haxpor/aseprite-macos-buildsh/issues/3).
Normal, barebone version with no parameters.
```shell
bash aseprite.sh
```
With custom parameters to specify SDK_ROOT and TARGET
```shell
bash aseprite.sh --sdk-root /Volumes/Slave/Applications/YourCustomDir/Xcode.app/Contents/Developer --target ~/YourCustomDir/Appliations
```
# Behind the Scene
The script will proceed with following
* Clone down Aseprite and Skia repository, and its dependencies required to bulid Aseprite.
* Compile and build dependencies
* Clone down Aseprite repository, then compile and build for latest release as tagged on Github (can be either beta or release version)
* Created `.app` bundle at `~/Applications`
> `Aseprite.app` is pre-created bundle file to wrap soon-to-be-built Aseprite. It contains script to execute an aseprite binary file with default executable path at `~/Applications/Aseprite/aseprite`. Such bundle file is created with macOS's Script Editor application.
# Notes
## for building v1.2.9
* If you previously clone any dependencies, the script will know and will instead try to update it from upstream for you. So you're ensured that it will operate on the most latest __release state__ version of Aseprite.
* Updated version of Aseprite might break cloned dependencies's build workflow especially error about `CC` or `CXX` environment variables are not set to correct path. If this is a case, it's likely that you re-build on previously compiled source code of dependencies in which `cmake` still keeps the old configurations used in successful compile. To resolve the problem, remove the whole build folder namedly `aseprite` then start it all over again.
* ~~In case you want to build older version of Aseprite, take a look at [Releases](https://github.com/haxpor/aseprite-macos-buildsh/releases) section then find a corresponding target version of Aseprite you look for.~~ - won't work, will stick to latest version only
# Support Aseprite
Aseprite is cool. It is free if you build it by yourself like you did above, or you can purchase it at [official website](https://www.aseprite.org/) to avoid spending effort in manual build process.
# Credits
This automated build script gathers information from Aseprite's [INSTALL.md](https://github.com/aseprite/aseprite/blob/master/INSTALL.md) on how to build, and sum it up together as automated script you're using here.
# License
[MIT](https://github.com/haxpor/aseprite-macos-buildsh/blob/master/LICENSE), Wasin Thonkaew
================================================
FILE: aseprite.sh
================================================
#!/bin/bash
#
# Script to automate building latest release of Aseprite (it can be release or beta build)
# This is for macOS build version.
POSTFIXPATH_SDKROOT=Platforms/MacOSX.platform/Developer/SDKs/MacOSX11.3.sdk
CCPATH_TOOLCHAIN=Toolchains/XcodeDefault.xctoolchain/usr/bin/cc
CXXPATH_TOOLCHAIN=Toolchains/XcodeDefault.xctoolchain/usr/bin/c++
SDK_ROOT=`xcode-select -p`
TARGET="/Applications"
# temporary value for returned value from function
TEMP_RET=""
# find value of target param --xxx if there's any, if not then TEMP_RET will still be empty "", else it will contain value from finding
# param 1 - parameter key name
# param 2 - program list of param, usually is $@
# return 1 if it found, and TEMP_RET is set, otherwise return 0. TEMP_RET will be always set to "" (empty) at the beginning of this function.
function findValueOfParam() {
# set empty to temporary return variable first
TEMP_RET=""
count=$#
argv=($@)
for (( i=1; i