Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jddev0/lang
This project provides a CLI and GUI interface to the Standard Lang implementation of the Lang Programming Language
https://github.com/jddev0/lang
interpreter lang-language programming-language translation-files
Last synced: about 2 months ago
JSON representation
This project provides a CLI and GUI interface to the Standard Lang implementation of the Lang Programming Language
- Host: GitHub
- URL: https://github.com/jddev0/lang
- Owner: JDDev0
- License: mit
- Created: 2020-05-26T18:32:39.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-04-17T18:47:06.000Z (9 months ago)
- Last Synced: 2024-04-17T22:56:19.723Z (9 months ago)
- Topics: interpreter, lang-language, programming-language, translation-files
- Language: Java
- Homepage:
- Size: 2.21 MB
- Stars: 4
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# The Lang Programming Language
This project provides a CLI and GUI interface to the Standard Lang implementation of the Lang Programming Language
## Features
Uses the [Lang interpreter](https://github.com/lang-programming/lang-interpreter) reference implementation with support for Native Modules and Native Functions
### Lang CLI
You can execute lang files with the Lang CLI.
### Lang Shell (REPL)
The Lang Shell is a REPL shell with many features to aid you during development.
Features:
- Syntax highlighting
- Code autocompletion
- Function help popup
- Command history
- Loading and saving of lang files
- Additional debug functions (like `func.printDebug()`)
- 4k font size support### Combinator functions
One of the main feature of this programming language is the combinator function system. You can use more than 100 predefined combinator functions. Combinator functions can be created by partially calling and combining combinator functions
## Lang Modules
Lang Modules can be used to put common code into one library which can be re-used easily.
Here is a list of all existing modules for lang:
- The [Lang Example Native Module](https://github.com/JDDev0/LangExampleNativeModule) is a reference implementation of a Lang native module. It can be used as a base for creating new modules.
- The [Lang IO Module](https://github.com/JDDev0/LangIOModule) is a Lang native module providing basic IO operations for files.### Native Lang Modules
Lang modules can contain native code (In the standard Lang implementation native code is Java code). In the [Lang Example Native Module](https://github.com/JDDev0/LangExampleNativeModule) repository a build script can be found in order to create modules containing native code easily.
## Docs and examples
**Language definitions**: See the Lang docs repository for details: [Lang Docs](https://github.com/lang-programming/docs) and checkout the .lang files located in /assets/
**Language Tutorial**: You can find many tutorial Lang files in /assets/tuts/.
**Language code examples**: Some examples are in /assets/examples/, many more are on [Rosetta Code](https://rosettacode.org/wiki/lang).## "TermIO-Control" window commands
**Execution of Lang file**: Type "executeLang -*Path to .lang file*" in the white text input in the "TermIO-Control" window
**LangShell** (REPL): Type "startShell" in the white text input in the "TermIO-Control" window
**Print AST tree**: Type "printAST -*Path to .lang file*" for parsing a Lang file and printing the parsed AST tree
**4K-Support**: Type "toggle4k" for a larger font in the "TermIO-Control" window and the "LangShell" window### "TermIO-Control" window commands from terminal/console
You can also run "java -jar Lang.jar -**command** **args**" in a terminal or console.
If "-e CODE" is used in Linux single quotes should be used for the CODE argument to prevent the shell from parsing $-shell variables and to enable multiline code execution (e.g. "java -jar Lang.jar -e '$a = test
func.println($a)')
You can use the "-log" argument to enable log file logging## Building from source
- This project uses the latest version (= latest commit) of the [Lang Interpreter Project](https://github.com/lang-programming/lang-interpreter) and of the [Lang Platform API Swing Project](https://github.com/lang-programming/lang-platform-api-swing)
- If a breaking change is introduced in the lang-interpreter this project will most likely not compile with the latest released lang-interpreter version
- In that case you should check out the [Building from source](https://github.com/lang-programming/lang-interpreter#build-from-source) section of the lang-interpreter project
- This project is already setup to use a locally built version of the lang-interpreter if it is newer than the latest release of the lang-interpreter
- If a breaking change is introduced in the lang-platform-api-swing you should publish the lang platform API to maven locally (See the [Building from source](https://github.com/lang-programming/lang-platform-api-swing#build-from-source) section)