Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nthnn/yttria-lang
Yttria programming language using LLVM bindings in pure TypeScript.
https://github.com/nthnn/yttria-lang
compiler compiler-construction compiler-design compiler-infrastructure compiler-principles language llvm llvm-bindings nodejs-application programming-language typescript-app typescript-application typescript-compiler
Last synced: about 2 months ago
JSON representation
Yttria programming language using LLVM bindings in pure TypeScript.
- Host: GitHub
- URL: https://github.com/nthnn/yttria-lang
- Owner: nthnn
- Created: 2023-08-13T03:52:30.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-04-27T11:55:37.000Z (9 months ago)
- Last Synced: 2024-04-28T09:34:18.854Z (9 months ago)
- Topics: compiler, compiler-construction, compiler-design, compiler-infrastructure, compiler-principles, language, llvm, llvm-bindings, nodejs-application, programming-language, typescript-app, typescript-application, typescript-compiler
- Language: TypeScript
- Homepage:
- Size: 142 KB
- Stars: 3
- Watchers: 1
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
README
# Yttria Programming Language
![NodeJS/CI](https://github.com/nthnn/yttria-lang/actions/workflows/node_ci.yml/badge.svg)
Yttria is a versatile and powerful general-purpose programming language designed to provide a coherent blend of performance, expressiveness, and ease of use. Developed using TypeScript, Yttria leverages LLVM bindings to generate an Intermediate Representation (IR), which can be further compiled using GCC for optimal performance and for target architectures.
> **Note:** Yttria is still in its development stage.
## Getting Started
To contribute to the development of Yttria, you can follow the steps below by cloning the repository first:
```git
git clone https://github.com/nthnn/yttria-lang.git
```**Required Softwares**
1. [NodeJS](https://nodejs.org/en) - The development uses version 20.4.0.
2. [VS Code](https://code.visualstudio.com/) - Optional. Used for editing codes and more.**Development Commands**
- `npm run install-modules` - Used for installing required node modules. Should be executed after downloading or cloning the whole repository.
- `npm run daemon-core` - Command for starting a listening nodemon every code changes on the Yttria's compiler core.
- `npm run build-core` - For cleaning up existing multiple source file builds, and then re-building again the compiler core of Yttria.
- `npm run clean-core` - Cleaning up all the compiler core build files.
- `npm run pack-core` - Package up the latest code base of the compiler core to generate executables for Linux, macOS, Windows, and Alpine.
- `npm run core` - Run the latest built Yttria compiler on console.
- `npm run daemon-cli-tool` - Command for starting a listening nodemon every code changes on the CLI tool.
- `npm run build-cli-tool` - For cleaning up existing multiple source file builds, and then re-building again the CLI tool.
- `npm run clean-cli-tool` - Cleaning up all the CLI tool build files.
- `npm run pack-cli-tool` - Package up the latest code base of the CLI tool to generate executables for Linux, macOS, Windows, and Alpine.
- `npm run cli-tool` - Run the latest built CLI tool on console.
- `npm run pack` - Can be used for packaging up both compiler core of Yttria and the CLI tool.
- `npm run clean-packages` - Cleans up the build files and the distributable files.
## Contributing
Contributions to the Yttria programming language are welcome and encouraged! To contribute, follow these steps:
1. Fork the Yttria repository on GitHub.
2. Clone your forked repository to your local machine.
3. Create a new branch for your feature or bug fix.
4. Make your changes and commit them with descriptive commit messages.
5. Push your changes to your GitHub repository.
6. Submit a pull request to the main Yttria repository.## License
Copyright 2023 Nathanne Isip
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at[http://www.apache.org/licenses/LICENSE-2.0](http://www.apache.org/licenses/LICENSE-2.0)
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.