Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dictu-lang/Dictu
Dictu is a high-level dynamically typed, multi-paradigm, interpreted programming language.
https://github.com/dictu-lang/Dictu
bytecode bytecode-interpreter c dictu hacktoberfest interpreter language programming-language scripting-language
Last synced: 3 months ago
JSON representation
Dictu is a high-level dynamically typed, multi-paradigm, interpreted programming language.
- Host: GitHub
- URL: https://github.com/dictu-lang/Dictu
- Owner: dictu-lang
- License: mit
- Created: 2018-12-24T02:27:16.000Z (about 6 years ago)
- Default Branch: develop
- Last Pushed: 2024-02-25T16:24:48.000Z (11 months ago)
- Last Synced: 2024-05-18T21:40:27.944Z (8 months ago)
- Topics: bytecode, bytecode-interpreter, c, dictu, hacktoberfest, interpreter, language, programming-language, scripting-language
- Language: C
- Homepage: https://dictu-lang.com
- Size: 8.54 MB
- Stars: 271
- Watchers: 14
- Forks: 53
- Open Issues: 51
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-programming-languages - Dictu - Dictu is a high-level dynamically typed, multi-paradigm, interpreted programming language. (Uncategorized / Uncategorized)
README
# Dictu
*What is Dictu?*
Dictu is a high-level dynamically typed, multi-paradigm, interpreted programming language. Dictu has a very familiar
C-style syntax along with taking inspiration from the family of languages surrounding it, such as Python and JavaScript.### Dictu documentation
Documentation for Dictu can be found [here](https://dictu-lang.com/)[![Codacy Badge](https://api.codacy.com/project/badge/Grade/ab84059049bd4ba7b7b8c1fcfaac4ea5)](https://app.codacy.com/manual/jasonhall96686/Dictu?utm_source=github.com&utm_medium=referral&utm_content=Jason2605/Dictu&utm_campaign=Badge_Grade_Dashboard)
[![CI](https://github.com/Jason2605/Dictu/workflows/CI/badge.svg)](https://github.com/Jason2605/Dictu/actions)## Example programs
```cs
import System;const guess = 10;
while {
const userInput = input("Input your guess: ").toNumber().unwrap();
if (userInput == guess) {
print("Well done!");
break;
} else if (userInput < guess) {
print("Too low!");
} else {
print("Too high!");
}System.sleep(1);
}
``````cs
def fibonacci(num) {
if (num < 2) {
return num;
}return fibonacci(num - 2) + fibonacci(num - 1);
}print(fibonacci(10));
```More [here.](https://github.com/Jason2605/Dictu/tree/develop/examples)
## Running Dictu
Dictu requires that you have CMake installed and it is at least version 3.16.3.
### Using CMake (at least version 3.16.3 or greater)
```bash
$ git clone -b master https://github.com/dictu-lang/Dictu.git
$ cd Dictu
$ cmake -DCMAKE_BUILD_TYPE=Release -B ./build
$ cmake --build ./build # on Windows add "--config Release" here to get a Release build
$ ./dictu # on Windows the executable is ".\Release\dictu.exe"
```### Using CMake presets (version 3.21.0 or greater)
```bash
$ git clone -b master https://github.com/dictu-lang/Dictu.git
$ cd Dictu
$ cmake --preset release
$ cmake --build --preset release
$ ./dictu # on Windows the executable is ".\Release\dictu.exe"
```#### Compiling without HTTP
The HTTP class within Dictu requires [cURL](https://curl.haxx.se/) to be installed when building the interpreter. If you wish to
build Dictu without cURL, and in turn the HTTP class, build with the `DISABLE_HTTP` flag.##### Without CMake presets (at least version 3.16.3 or greater)
```bash
$ git clone -b master https://github.com/dictu-lang/Dictu.git
$ cd Dictu
$ cmake -DCMAKE_BUILD_TYPE=Release -DDISABLE_HTTP=1 -B ./build
$ cmake --build ./build # on Windows add "--config Release" here to get a Release build
$ ./dictu # on Windows the executable is ".\Release\dictu.exe"
```##### CMake presets (version 3.21.0 or greater)
```bash
$ git clone -b master https://github.com/dictu-lang/Dictu.git
$ cd Dictu
$ cmake --preset release-nohttp
$ cmake --build --preset release
$ ./dictu # on Windows add "--config Release" here to get a Release build
```#### Compiling with VCPKG
This project includes support for the VCPKG C/C++ package manager in [manifest mode](https://learn.microsoft.com/en-us/vcpkg/users/manifests).
To enable VCPKG support, the `VCPKG_ROOT` environmental variable must be set to the path of a check-out and bootstrapped
[vcpkg repository](https://github.com/microsoft/vcpkg) on the compiling machine, and the `ENABLE_VCPKG` cmake flag must be set.Compiling with VCPKG will enable certain features of Dictu that requires external library features to be automatically pulled and compiled.
##### Without CMake presets (at least version 3.16.3 or greater)
```bash
$ git clone -b master https://github.com/dictu-lang/Dictu.git
$ cd Dictu
$ cmake -DCMAKE_BUILD_TYPE=Release -DENABLE_VCPKG=1 -DCMAKE_TOOLCHAIN_FILE=${VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake -B ./build
$ cmake --build ./build # on Windows add "--config Release" here to get a Release build
$ ./dictu # on Windows the executable is ".\Release\dictu.exe"
```##### CMake presets (version 3.21.0 or greater)
```bash
$ git clone -b master https://github.com/dictu-lang/Dictu.git
$ cd Dictu
$ cmake --preset release-vcpkg
$ cmake --build --preset release-vcpkg
$ ./dictu # on Windows add "--config Release" here to get a Release build
```### Docker Installation
Refer to [Dictu Docker](https://github.com/dictu-lang/Dictu/blob/develop/Docker/README.md)
### FreeBSD Installation
For a full installation, make sure `curl` is installed. It can be installed from the commands below:
```bash
$ pkg install -y curl linenoise-ng
```The following variables need to be set/available to run `cmake` successfully.
For Bourne compatible shells...
```bash
export CPATH=/usr/local/include
export LIBRARY_PATH=/usr/local/lib
export LD_LIBRARY_PATH=/usr/local/lib
``````bash
$ git clone -b master https://github.com/dictu-lang/Dictu.git
$ cd Dictu
$ cmake -DCMAKE_BUILD_TYPE=Release -B ./build
$ cmake --build ./build
$ ./dictu
```## Extensions
Dictu has a Visual Studio Code extension [here](https://marketplace.visualstudio.com/items?itemName=Dictu.dictuvsc) with the implementation located
in the [DictuVSC repo](https://github.com/dictu-lang/DictuVSC).## Credits
This language was initially based on the very good [craftinginterpreters book](http://www.craftinginterpreters.com/contents.html), along with inspiration from [Wren](https://github.com/wren-lang/wren).
This project is supported by: