Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/krzyzanowskim/onlineswiftplayground
Online Swift Playground
https://github.com/krzyzanowskim/onlineswiftplayground
kitura server-side-swift swift swift-on-server web
Last synced: 17 days ago
JSON representation
Online Swift Playground
- Host: GitHub
- URL: https://github.com/krzyzanowskim/onlineswiftplayground
- Owner: krzyzanowskim
- License: other
- Created: 2018-01-08T00:12:47.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2024-03-10T16:54:00.000Z (8 months ago)
- Last Synced: 2024-04-14T05:36:45.761Z (7 months ago)
- Topics: kitura, server-side-swift, swift, swift-on-server, web
- Language: Swift
- Homepage: http://online.SwiftPlayground.run
- Size: 9.91 MB
- Stars: 238
- Watchers: 12
- Forks: 32
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE.txt
- Code of conduct: CODE_OF_CONDUCT.md
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 8080Now 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.