Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/pine-vm/pine

Cross-platform runtime environment for the Elm programming language.
https://github.com/pine-vm/pine

backend database dbms declarative-programming elm event-sourcing full-stack functional-programming runtime virtual-machine

Last synced: 4 days ago
JSON representation

Cross-platform runtime environment for the Elm programming language.

Awesome Lists containing this project

README

        

# Pine

Pine is a free, open-source, cross-platform Elm runtime environment that lets developers create servers, web apps, and command line tools.

+ Pine supports building and running Elm programs natively on .NET without JavaScript.
+ The Elm compilation interfaces support the customization of code generation at build time.
+ Pine comes bundled with an integrated web server and database management system, simplifying the development and operation of web services.

## Web Services

+ Pine integrates web server and database management system, automating the persistence and maintenance of application state and database migrations.
+ Run reports or custom updates as Elm functions on your database via the admin interface.

## Getting Started

Download the pre-built Pine binary for your platform at , or on the [releases page](https://github.com/pine-vm/pine/releases) on GitHub.

The `pine` executable file integrates all functionality to build apps and operate web services.

The command below runs a server and deploys a full-stack web app:

```txt
pine run-server --public-urls="http://*:5000" --deploy=https://github.com/pine-vm/pine/tree/8dbd5c91853fbcef3b645d95bccc01a886ccd7e2/implement/example-apps/docker-image-default-app
```

## Docker Image

To deploy in a docker container, use the `pine-vm/pine` image from the [GitHub Container registry](https://github.com/pine-vm/pine/pkgs/container/pine) (`ghcr.io/pine-vm/pine`). The tags are aligned with the version IDs in the CLI executable file.

```txt
docker run -p 5000:80 -p 4000:4000 --env "APPSETTING_adminPassword=test" ghcr.io/pine-vm/pine
```

## 📚 Guides

A selection of guides on popular topics:

+ Building full-stack web apps: [./guide/how-to-build-a-full-stack-web-app-in-elm.md](./guide/how-to-build-a-full-stack-web-app-in-elm.md)

+ Building a backend or web service: [./guide/how-to-build-a-backend-app-in-elm.md](./guide/how-to-build-a-backend-app-in-elm.md)

+ Using Elm compilation interfaces: [./guide/how-to-use-elm-compilation-interfaces.md](./guide/how-to-use-elm-compilation-interfaces.md)

For an overview of all guides and documentation, see the [`guide` directory](./guide/).

## 🎥 Videos

+ Manually Applying Elm Functions On An Online Database Using Pine:

## Example Apps

### Rich Chat Room

The [rich chat room example app](https://github.com/pine-vm/pine/tree/main/implement/example-apps/rich-chat-room) demonstrates features typically found in a chat app, such as user names, message rate-limiting, sound effects, etc.
For a detailed description of this app, see the readme file at

### Elm Editor

[Elm Editor](https://github.com/pine-vm/pine/tree/main/implement/example-apps/elm-editor) is a web app for developing Elm programs.

As an integrated development environment, it assists us in reading, writing, and testing Elm programs and in collaborating with other developers.



To see Elm Editor in action, check out the public instance at https://elm-editor.com

To learn more about Elm Editor, see

### More Examples

For more example apps, see the [`example-apps` directory](./implement/example-apps/)