Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

https://github.com/sveinbjornt/Platypus

Create native Mac applications from command line scripts.
https://github.com/sveinbjornt/Platypus

application application-bundle cocoa command-line-app gui-application macos objective-c osx platypus scripting scripts

Last synced: 28 days ago
JSON representation

Create native Mac applications from command line scripts.

Lists

README

        

[![License](https://img.shields.io/badge/License-BSD%203--Clause-blue.svg)](https://opensource.org/licenses/BSD-3-Clause)
[![Language](https://img.shields.io/badge/language-objective--c-lightgrey)]()
[![Release](https://shields.io/github/v/release/sveinbjornt/Platypus?display_name=tag)]()
[![Build](https://github.com/sveinbjornt/platypus/actions/workflows/macos.yml/badge.svg)]()

# Platypus

**Platypus** is a developer tool that creates native Mac applications
from command line scripts such as shell scripts or Python, Perl, Ruby,
Tcl, JavaScript and PHP programs. This is done by wrapping the script in an
[application bundle](https://en.wikipedia.org/wiki/Bundle_(OS_X)) along
with a slim app binary that runs the script.

Platypus makes it easy to share scripts and programs with people who are
unfamiliar with the command line interface. Native, user-friendly
applications can be created with a few clicks. It is very easy to
create installers, droplets, administrative applications, login items,
status menu items, launchers and automations using Platypus.

## Features

* Supports shell scripts, Python, Perl, Ruby, PHP, Swift, Expect, Tcl, AWK, JavaScript, Dart, AppleScript or any other user-specified interpreter
* Apps can display graphical feedback of script execution as a progress bar, text window with script output, droplet, WebKit HTML rendering or status item menu
* Apps support receiving dragged and dropped files or text snippets, which are then passed to the script as arguments
* Apps can execute scripts with root privileges via the macOS Security Framework
* Apps can register as handlers for URI schemes and send user notifications
* Apps can be configured to run in the background (LSUIElement)
* Set own application icon or select from presets
* Set app's associated file types, identifier, version, author, etc.
* Graphical interface for bundling support files with the script
* Command line tool for automation and build process integration
* "Profiles" can be used to save app configurations
* Built-in script editor, or linking with external editor of choice
* Extensive [documentation](Documentation/Documentation.md) and many built-in examples to help you get started
* Generates slim and speedy native applications that launch and run quickly
* Fast, responsive native app written in Objective-C/Cocoa

## Install

Platypus is free, open source software and has been continuously developed and maintained for over 20 years. **If you find this program useful, please [make a donation](https://sveinbjorn.org/donations).**

* **[⇩ Download Platypus 5.4.1](https://sveinbjorn.org/files/software/platypus.zip)** (Intel/ARM 64-bit, 10.11 or later, ~4.5 MB)

Platypus can also be installed via [Homebrew](https://brew.sh) (may not be latest version):

```shell
$ brew install --cask platypus
```

## Links

* [Platypus Documentation](Documentation/Documentation.md)
* [Platypus Website](https://sveinbjorn.org/platypus)
* [man `platypus`](https://sveinbjorn.org/files/manpages/platypus.man.html)
* [Platypus Appcast XML feed](https://sveinbjorn.org/files/appcasts/PlatypusAppcast.xml)
* [Old Versions](https://sveinbjorn.org/files/software/platypus)

## Screenshots

### Platypus main window

### Interfaces

Platypus lets you select one of several different user interfaces for your script.

#### Progress Bar Interface

#### Text Window Interface

#### Web View Interface

#### Status Menu Interface

#### Droplet Interface

## Building Platypus

To build Platypus, run the following command from the repository root (requires Xcode build tools):

```shell
$ make build_unsigned
```

The resulting application bundle is created in the `products` directory.

## Some notes on the code

Platypus is very old software, dating back to the early days of
Mac OS X, around 2003, when I was first learning to use Objective-C
and the Cocoa APIs. I made many beginner mistakes, some of which remain
in the structure of the code. This software has since gone through
about three dozen significant versions. It has been patched, bugfixed,
streamlined to include new features and was transitioned over to
modern Objective-C some years ago. It's not how I would write it today.

With these caveats in mind, here is the BSD-licensed source code to Platypus.

## BSD License

Copyright (c) 2003-2023 Sveinbjorn Thordarson <[email protected]>
All rights reserved.

Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:

1. Redistributions of source code must retain the above copyright notice, this
list of conditions and the following disclaimer.

2. Redistributions in binary form must reproduce the above copyright notice, this
list of conditions and the following disclaimer in the documentation and/or other
materials provided with the distribution.

3. Neither the name of the copyright holder nor the names of its contributors may
be used to endorse or promote products derived from this software without specific
prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.