DialectMorph is a powerful code transpilation tool designed to convert source code from one programming language to another. It leverages the Groq API to perform intelligent code translations while maintaining the original functionality and logic.
- Supports transpilation between Python, JavaScript, Java, and C++
- Command-line interface for easy usage
- Automatically creates a
transpiledFiles
directory for output - By default, Utilizes Groq's language model for accurate code conversion, option to use Gemini can be specified
- User can also provide their own API-Key to be used in this CLI Tool
- User can also request the the list of models available in the Groq-API
- User can also specify the model that they want to use for their use-case
-
Clone the repository:
git clone https://github.com/Kannav02/DialectMorph.git cd DialectMorph
-
Install dependencies:
To install
bun
, please follow this installation guide.bun install
To skip steps 3 and 4 , you can run the following script, which will run all of these commands in a single-go
bun run linkage:build
-
Run the following commands to have bun build/transpile typescript files to javascript so as to run the binary
bun run build
-
Link and Install Bun Binaries in the Global Scope
we would have to register the CLI tool globally and then also install the binaries in the global scope to make it useful in the terminal
to register the CLI tool globally ,run the following command
bun link
after this, to install the bun binaries globally, run the following commmand
bun link dialect-morph
-
Run the following commands in the terminal to make sure that .bun/bin exists in the path variable
export PATH="/Users/username/.bun/bin:$PATH"
reload the shell config file
source ~/.zshrc
-
Set up your Groq API key:
-
Create a
.env
file in the root directory or run the following command in the shellcp .env.example .env
-
Add your Groq API key:
GROQ_API_KEY=your_api_key_here
-
Add your Gemini API key:
GEMINI_API_KEY=api_key_goes_here
-
You can specify your preferred settings for the CLI tool by creating and editing a TOML configuration file. It will allow you to customize the default options to tailor the tool's behaviour to your needs. Learn more about TOML on the official website.
The arguments that can be specified in the dialectMorph.config.toml
:
api_key
- provide the API key to be usedmodel
- set the Large Language Model of choicelanguage
- specify the output programming language
- A sample configuration file
sample.dialectMorph.config.toml
is provided in the repository. - To create your own configuration file, run the following command:
To create your own configuration file in your home directory, run the following command:
cp sample.dialectMorph.config.toml ~/dialectMorph.config.toml
Important! - Make sure that the config file you create is named dialectMorph.config.toml
, as the tool will be looking for this specific file in your home directory.
Run DialectMorph using the following command:
dialectMorph <input_files...> -l <output_language>
The input_files
argument can take multiple files at once and is a required argument
the output_language
argument is also a required argument
Examples:
Take one of the files from the examples folder and run the following command
dialectMorph ./examples/example.py -l java
dialectMorph ./examples/example.cpp -l python
-
a (--api_key) This command is one of the optional arguments and can be used with the main command or the lm command (see below)
Command
dialectMorph ./examples/examples.py -l C++ -a YOUR_API_KEY
-
m (--model) This command is one of the optional arguments and can be used with the main command to specify the model that you want to be used to fetch the request , by default the model is
llama3-8b-8192
for Groq andgemini-1.5-flash
for GeminiBE CAREFUL TO ONLY USE A MODEL NAME THAT EXISTS AFTER YOU USE THE LM OPTION OTHERWISE THE PROGRAM WILL THROW AN ERROR
Command
dialectMorph ./example/example.py -l java -a YOUR_API_KEY -m MODEL_NAME
-
lm (--list_models) This command can be used on its own without the need to provide any files and is used to fetch the list of models that are available on Groq, it can also take an API-Key as one of the optional arguments
Command
dialectMorph -lm -a YOUR_API_KEY
-
t (--token) This command is one of the optional arguments and can be used with the main command to specify the desire to see how many tokens are consumed (i.e., prompt tokens, completion tokens, and total tokens) from making a request to the Groq API.
dialectMorph ./examples/example.py -l java -t
-
gem (--gemini) This command is used to indicate to the CLI tool that Gemini LLM would be used to generate the code that would be used in the transpiled files, if this option isn't provided, groq is used by default
dialectMorph ./examples/example.py -l java -gem
- Python (.py)
- JavaScript (.js)
- Java (.java)
- C++ (.cpp)
index.ts
: Main entry point and CLI logicLLMHandler.ts
: Handles interactions with Groq API and Gemini APIfileHelper.ts
: Utility functions for file and directory operations
Before making any Pull Requests or Pushes to the main branch, make sure to run the following linting scripts to pass the tests set by the CI pipeline
bun run format
bun run format:check
format
script here is used to format all of the files to the standards specified by prettier
format:check
script here is used to check if all of the files have been formatted by prettier
Contributions are welcome! Please feel free to submit a Pull Request.
This project is licensed under the MIT License.
- Groq SDK for providing the language model API
- Gemini SDK for providing the a secondary language model API
- Commander.js for CLI argument parsing
- Figlet for ASCII art text generation
- Chalk for terminal styling
- Ora for terminal spinner
- VHS for making the demo video for the CLI tool
- Prettier for maintaining consistent formatting throughout the code
- TOML for parsing the contents of the config file