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.
To contribute to the development of Yttria, you can follow the steps below by cloning the repository first:
git clone https://github.com/nthnn/yttria-lang.git
Required Softwares
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.
Contributions to the Yttria programming language are welcome and encouraged! To contribute, follow these steps:
- Fork the Yttria repository on GitHub.
- Clone your forked repository to your local machine.
- Create a new branch for your feature or bug fix.
- Make your changes and commit them with descriptive commit messages.
- Push your changes to your GitHub repository.
- Submit a pull request to the main Yttria repository.
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
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.