Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/wsdt/almostbinary
Compiler & Runtime for 'Almost Binary'. Code in platform-independent binary and utilize high-level data structures and state-of-the-art libraries (e.g. quantum computing, blockchain, ..)
https://github.com/wsdt/almostbinary
binary blockchain compiler csharp esolang esoteric-programming-language platform-independent programming-language qsharp quantum-computing runtime
Last synced: 3 months ago
JSON representation
Compiler & Runtime for 'Almost Binary'. Code in platform-independent binary and utilize high-level data structures and state-of-the-art libraries (e.g. quantum computing, blockchain, ..)
- Host: GitHub
- URL: https://github.com/wsdt/almostbinary
- Owner: wsdt
- License: gpl-3.0
- Created: 2020-05-10T19:34:18.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-03-31T09:40:33.000Z (almost 2 years ago)
- Last Synced: 2024-08-05T01:10:38.441Z (6 months ago)
- Topics: binary, blockchain, compiler, csharp, esolang, esoteric-programming-language, platform-independent, programming-language, qsharp, quantum-computing, runtime
- Language: C#
- Homepage:
- Size: 29.1 MB
- Stars: 8
- Watchers: 4
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.MD
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Almost Binary [![HitCount](http://hits.dwyl.com/wsdt/AlmostBinary.svg)](http://hits.dwyl.com/wsdt/AlmostBinary) [![Maintenance](https://img.shields.io/badge/Maintained%3F-no-red.svg)](https://bitbucket.org/lbesson/ansi-colors) [![GitHub license](https://img.shields.io/github/license/wsdt/AlmostBinary.svg)](https://github.com/wsdt/AlmostBinary/blob/master/LICENSE) [![Generic badge](https://img.shields.io/badge/Made%20with-CSharp-37f)](https://docs.microsoft.com/en-us/dotnet/csharp/tour-of-csharp/) [![Donate](https://img.shields.io/badge/Donate-Pay%20me%20a%20coffee-3cf)](https://github.com/wsdt/Global/wiki/Donation) [![Codacy Badge](https://api.codacy.com/project/badge/Grade/7512be0122164bbbb19c5123914fe2a5)](https://app.codacy.com/manual/wsdt/AlmostBinary?utm_source=github.com&utm_medium=referral&utm_content=wsdt/AlmostBinary&utm_campaign=Badge_Grade_Dashboard)
This compiler & runtime will be improved continuously. Please be clement, as this is my first time implementing a compiler and runtime.**Take a look at the documentation: [Almost Binary - Wiki](https://github.com/wsdt/AlmostBinary/wiki)**
## Code Once, Run Everywhere. [![Tests within Docker](https://img.shields.io/badge/Tests%20within%20Docker-passing-success)](https://github.com/wsdt/Global/wiki/Donation)
Code in platform-independent Binary. It was never so easy to proof that you are a real geek.This programming language is made for people, who..
- ..always wanted to code in Binary.
- ..love real challenges.
- ..want to bring their programming skills to the next level.
- ..want to run binary-programs on any machine.## Example
You will find some [example files here](https://github.com/wsdt/AlmostBinary/tree/master/examples).
Simple hello-world program:```
0000000000000000011010010110110101110000011011110111001001110100
000000000000000001110011011110010111001101110100011001010110110100000000000000000000000000000000000000000000000000000000000000000110011001110101011011100110001101110100011010010110111101101110
0000000000000000000000000000000001001101011000010110100101101110
0000000000000000000000000000000000000000000000000000000000101000
0000000000000000000000000000000000000000000000000000000000101001
000000000000000000000000000000000000000000000000000000000111101100000000000000000000000000000000000000000000000000000000010100000111001001101001011011100111010001001100011010010110111001100101
0000000000000000000000000000000000000000000000000000000000101000
0000000000000000000000000000000000000000000000000000000000100010000000000000000000000000000000000000000001001000011001010110110001101100011011110010000001010111011011110111001001101100011001000000000000000000000000000000000000000000000000000000000000100010
0000000000000000000000000000000000000000000000000000000000101001
00000000000000000000000000000000000000000000000000000000000000000101001001100101011000010110010001001100011010010110111001100101
0000000000000000000000000000000000000000000000000000000000101000
0000000000000000000000000000000000000000000000000000000000101001
0000000000000000000000000000000000000000000000000000000001111101
```
Of course you can remove all tabs and newlines. Removing spaces is only supported in some cases as I didn't want to introduce too much delimiters (e.g. 8 zeros).
***## Libraries
This is an exhaustive list of all implemented AlmostBinary libraries:### system
**Identifier/Name (x64):**
`0000000000000000011100110111100101110011011101000110010101101101`**Description:**
_Default functions, e.g. PrintLine, InputString, ..._### blockchain
**Identifier/Name (x64):**
`00000000000000000000000000000000000000000000000001100010011011000110111101100011011010110110001101101000011000010110100101101110`**Description:**
_Create simple proof-of-work blockchains, create transactions, validate the blockchain and mine abin-Coins._### quantum
**Identifier/Name (x64):**
`0000000001110001011101010110000101101110011101000111010101101101`**Description:**
_Utilize a small part of the Q# simulator api. E.g. create true random number._
***## Why I made this
Esoteric languages like [WhiteSpace](https://esolangs.org/wiki/Whitespace), [Brainfuck](https://esolangs.org/wiki/Brainfuck) or [Arnold-C](https://esolangs.org/wiki/ArnoldC) have inspired me to write my own compiler & runtime.
In the very beginnings of my programming-journey, I thought that programmers and hackers code today's applications in Binary. As most, even non-tech people, know today, this is not the case.
The closest you can get is actually coding [Assembly](https://en.wikipedia.org/wiki/Assembly_language) or if you know Assembly really well, even real machine code. Nevertheless, coding in real binary is incredible difficult
and runs only on a set of processors. Thus, you will have to adapt your binary code to the target machine.This project should make it possible to write **platform-independent binary**. Of course, you are not coding in real binary, like you would if you go the assembly way.
Thus, some "binary" code written will be compiled to normal strings and other binary-strings will be interpreted at runtime.## TO-DOs
- Add node support for [blockchain library](https://www.c-sharpcorner.com/article/blockchain-basics-building-a-blockchain-in-net-core/), maybe even [smart-contracts](https://docs.microsoft.com/en-us/archive/msdn-magazine/2019/november/blockchain-programming-smart-contracts-in-csharp)
- Improve performance of compiler & runtime## Contribution [![Open Source Love svg2](https://badges.frapsoft.com/os/v2/open-source.svg?v=103)](https://github.com/ellerbrock/open-source-badges/) [![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square)](http://makeapullrequest.com)
This project is licensed under GNU V3, so contributions/pull-requests are welcome. All contributors get listed here.
**Contributors** [![saythanks](https://img.shields.io/badge/say-thanks-ff69b4.svg)](https://saythanks.io/to/kevin.riedl.privat%40gmail.com)
- Kevin Riedl ([WSDT](https://github.com/wsdt))### Additional notes
Almost Binary is supposed to be an esoteric programming language and is surely not suitable for real-world programs.#### More resources
- [Esolang-Wiki](https://esolangs.org/wiki/Almost_Binary)#### Template
This project was inspried by **[Klip](https://github.com/TimeLoad00/Klip)**.