Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/samuelmtimbo/unit
Next Generation Visual Programming System
https://github.com/samuelmtimbo/unit
dataflow-programming functional-programming live-programming programming programming-language reactive-programming unit visual-programming
Last synced: about 12 hours ago
JSON representation
Next Generation Visual Programming System
- Host: GitHub
- URL: https://github.com/samuelmtimbo/unit
- Owner: samuelmtimbo
- License: mit
- Created: 2021-06-09T14:49:54.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2025-01-09T07:41:11.000Z (13 days ago)
- Last Synced: 2025-01-11T01:05:22.072Z (11 days ago)
- Topics: dataflow-programming, functional-programming, live-programming, programming, programming-language, reactive-programming, unit, visual-programming
- Language: TypeScript
- Homepage: https://unit.land
- Size: 45.4 MB
- Stars: 3,681
- Watchers: 45
- Forks: 84
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Unit
Next Generation Visual Programming System
![Unit merge sort example](/public/gif/0.gif)
## Unit
Unit is a General Purpose Visual Programming Language and Environment built with a primary focus on Developer Experience.
It is heavily inspired by Live, Data Flow, Reactive, Functional and Object Oriented Programming paradigms. Formally, units are Multi Input Multi Output (MIMO) Finite State Machines (FSM). A program in Unit is represented as a Graph.
The Unit Programming Language was developed in close junction to the Unit Programming Environment, which is a Web application built for easy composition of new units. The environment is designed to feel visual and kinesthetic, giving the perception of Direct Manipulation of Live Virtual Objects. The Unit Programming experience is minimalistic, ergonomic, mobile, and can be performed through a variety of input devices, and editing can be partially expressed through Drawing, Gesture and Voice.
Unit is similar in concept to the Unix shell. For a seasoned programmer, Unit should feel like the 2D evolution of the Command Line Interface (CLI) where units' (commands) inputs and outputs (stdin/stdout/stderr) can be piped together into a graph (script). Unit can be thought of as a re-exploration of the [Unix Philosophy](https://en.wikipedia.org/wiki/Unix_philosophy) in the context of modern Software Engineering and Web Development.
The Unit system is set to grow into a simple and approachable Web Operating System, which is sandboxed by default, enabling a new era of Software Sharing and Collaboration, unifying the currently fragmented Computer Experience.
For an introduction to Unit Programming, visit [Getting Started](src/docs/start/README.md).
The broader design philosophy behind Unit is discussed in [Concept](src/docs/concept/README.md).
To jump right into the official Unit Programming Environment, visit [unit.land](https://unit.land) (beta).
Check out a collection of public open source units at [unit.tools](https://unit.tools) (beta).
## Development
Install [npm](https://nodejs.org/en/download/) and [git](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git) if you haven't already.
Clone this repository:
```
git clone [email protected]:samuelmtimbo/unit.git
```Get into the unit folder:
```
cd unit
```Install:
```
npm install
```Setup:
```
npm run setup
```Start a local unit server:
```
npm start
```For development mode:
```
npm run watch
```## Library
Unit source code can be used as a general purpose library in any JavaScript project, both on Web and Node.js.
```sh
npm install --save @_unit/unit
```To install unit globally:
```sh
npm install --global @_unit/unit
```Then to start a local server:
```sh
unit
```To render a unit JSON bundle:
```js
import { renderBundle } from '@_unit/unit/lib/client/platform/web/render'const root = document.getElementById('root')
const bundle = {
spec: {
units: {
helloworld: {
id: 'a9cbed12-9a53-11eb-8c2e-f3146b36128d',
},
},
render: true,
component: {
subComponents: {
helloworld: {},
},
children: ['helloworld'],
},
},
}const [system, graph] = renderBundle(root, bundle)
const helloworld = graph.getUnit('helloworld')
helloworld.push('style', {
color: '#ffdd00',
})
```To boot a system and instantiate a new unit on it:
```js
import { boot } from '@_unit/unit/lib/client/platform/node/boot'
import { fromBundle } from '@_unit/unit/lib/spec/fromBundle'
import _specs from '@_unit/unit/lib/system/_specs'export const [system] = boot()
const bundle = require('./MergeSort.json')
const MergeSort = fromBundle(bundle, _specs, {})
const mergeSort = new MergeSort(system)
mergeSort.play()
mergeSort.push('a', [2, 1])
console.log(mergeSort.take('a')) // [1, 2]
```## Test
```sh
npm test
```## Links
List of related web applications:
### [unit.software](https://unit.software)
Landing page featuring the Unit language and system's vision.
### [unit.md](https://unit.md)
Redirect to the official unit source code.
### [unit.land](https://unit.land)
Fully local version of the Unit Environment.
Any \*.unit.land subdomain represents a completely isolated instance of the Unit system.
### [unit.tools](https://unit.tools)
Marketplace to explore, collect and play with open live visual programs built in Unit.
### [unit.moe](https://unit.moe)
Appending #url to https://unit.moe will attempt to encapsulate the unit served at that URL in a graph editor. This is helpful for debugging an open unit website, for instance:
https://unit.moe#https://unit.software will show the code for https://unit.software.
https://unit.moe#https://unit.land will show the code for https://unit.land.
https://unit.moe#https://unit.tools will show the code for https://unit.tools.## Documentation
The unit Programming Environment was designed to be learnable by Experimentation and Exploration. Visual and written documentation about each unit can be accessed using [Info Mode](https://github.com/samuelmtimbo/unit/tree/main/src/docs/start#info-mode).
This codebase is a TypeScript implementation of the unit Programming Language Spec with an accompanying Web based Programming Environment.
## Contributing
Please feel free to clone or fork Unit's source code.
This is the best place to learn about Unit's design and implementation, and the official channel for Open Source collaboration.
The project is open for pull requests.
If you have a feature idea or hit a malfunction, this is a basic workflow to follow:
1. Iterate over a solution on top the latest main, testing it locally until it works and the code is clean;
2. Open a pull request explaining the problem and solution;
3. Iterate over it to make sure the change is positive and aligned with Unit's design and vision.The Unit project has nearly infinite space for creative freedom, invention, and intimacy, which is what motivated it.
## Backlog
Unit system API is composed of logical, platform (frontend and backend) and "operating system" units.
The direction of growth right now is ensuring a robust basic UI/UX and feature parity with Web and a subset of NodeJS (not native to the Web), like TCP and HTTP.
Visit [Evolution](/src/docs/evolution/README.md) to learn more about where Unit development is headed.
## Community
If you have a question or a suggestion related to Unit, or if you just want to talk about the future of Programming, or if you wish to join Unit team, feel free to message me at [@io_sammt](https://x.com/io_sammt) or email me at [email protected].
For updates about Unit's development, including thoughts about vision and roadmap, follow us on X [@io_unit](https://x.com/io_unit).
We hope you enjoy Unit and invite you to be part of our community!
## License
MIT License
Copyright 2021 UNIT IO, Inc