Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/krzyzanowskim/onlineswiftplayground

Online Swift Playground
https://github.com/krzyzanowskim/onlineswiftplayground

kitura server-side-swift swift swift-on-server web

Last synced: 4 days ago
JSON representation

Online Swift Playground

Awesome Lists containing this project

README

        

# SwiftPlayground.run

[![Platform](https://img.shields.io/badge/Platforms-macOS%20%7C%20Linux-4E4E4E.svg?colorA=28a745)](#installation)
[![Twitter](https://img.shields.io/badge/[email protected]?style=flat&colorB=64A5DE&label=Twitter)](https://twitter.com/krzyzanowskim)

Online Swift Playground. Implemented in Swift.

TBA. Checkout http://SwiftPlayground.run

![SwiftPlayground.run](https://user-images.githubusercontent.com/758033/35674872-55a53386-0746-11e8-8bc1-ae5aee13fcfd.gif)

## Installation & Run

```shell
$ git clone https://github.com/krzyzanowskim/OnlineSwiftPlayground.git
$ cd OnlineSwiftPlayground
$ ./run.sh
```

The `run.sh` script will generate Xcode project (on macOS) and bootstrap the environment. `run.sh` needs `npm` to be installed to work properly.
Bootstraping involves
1. Download Swift Toochains supported by the playground
2. Pre-build support module using the toolchains
3. Install dependencies
4. Launches web server on localhost on port 8080

Now you could access playground pointing web browser to 127.0.0.1:8080.

## Development

### Xcode

Generate Xcode project

```
$ swift package generate-xcodeproj
```

### React

Web user interface is build with [React](https://reactjs.org/) and [webpack](https://webpack.js.org/).

```
$ npm run build
```

## Docker

[krzyzanowskim/onlineswiftplayground](https://store.docker.com/community/images/krzyzanowskim/onlineswiftplayground)

Download the latest image:

```
$ docker pull krzyzanowskim/onlineswiftplayground
```

or build docker image by yourself:

```
$ git clone https://github.com/krzyzanowskim/OnlineSwiftPlayground.git
$ cd OnlineSwiftPlayground
$ docker buildx create --use
$ docker buildx build --platform=linux/amd64,linux/arm64 . -t krzyzanowskim/onlineswiftplayground
```

then run container:

```
$ docker run -d -p 8080:8080 --name onlineswiftplayground -t krzyzanowskim/onlineswiftplayground
```

and wait until docker container is up (usually several seconds).

Playground is available at [http://localhost:8080](http://localhost:8080).
If the docker setup uses VirtualBox, the you can get the IP address from `docker-machine ip` command.

```
$ open http://$(docker-machine ip):8080
```

## Config

Third party frameworks should be copied to `Frameworks` directory (Frameworks are for **macOS** host only)

See `config/` for GitHub auth. sample config.

## Author

SwiftPlayground.run is owned and maintained by [Marcin Krzyzanowski](https://www.krzyzanowskim.com)

You can follow me on Twitter at [@krzyzanowskim](https://twitter.com/krzyzanowskim) for project updates and releases.

## License

Creative Commons Attribution Non Commercial 4.0. See [LICENSE](LICENSE.txt) file.