Sanskritayam is a fun and experimental programming language inspired by Sanskrit, the ancient language of India. This project was created based on a viral meme from last year, where a group of aunties were discussing the idea of making Sanskrit a coding language. As a joke, my friend Pinakkk and I thought of turning this idea into reality, and thus, Sanskritayam was born!
Please note that Sanskritayam is not intended for serious production use and comes with no warranty. It's a purely recreational project meant for learning and entertainment purposes.
- Sanskrit-inspired syntax and keywords
- Basic programming constructs like variables, conditionals, loops, and functions
- Support for common data types such as integers, floats, strings, lists, and dictionaries
- File I/O operations
- Exception handling
- Object-oriented programming concepts
- Write "Swaha" to have some extra fun!
To get started with Sanskritayam, follow these steps:
-
Clone the repository:
git clone https://github.com/thtskaran/sanskritayam.git
-
Install Python 3.x if you haven't already.
-
Navigate to the directory containing the setup.py file:
cd sanskritayam
-
Install the Sanskritayam interpreter:
pip install -e .
Alternatively you can install the latest release from PyPi using pip install sanskritayam
command .
Whatever way you opted to install Sanskritayam now you should be able to execute .skt codes right away , choose the way most suited :
- Non-Sudo Installation
If you didnt use
sudo
privelleges while installation , sanskritayam wont be in your$PATH
, and you must use it in this way :python -m sanskritayam <filename.skt>
- Sudo Installation
If you used
sudo
while installation of sanskritayam you should be able to use it right away without explicitly usingpython -m
sanskrityam <filename.skt>
If Sanskritayam interpreter is updated on GitHub and want to update your local installation, follow either ways:
- Pull the latest changes from GitHub:
git pull origin main
Replace main
with the name of the branch that contains the updated Sanskritayam interpreter, if it's not the main branch.
Reinstall the Sanskritayam interpreter:
```
pip install --upgrade --force-reinstall -e .
Now, your local installation of the Sanskritayam interpreter should be updated with the latest changes from GitHub.
- Pull the latest release from PyPi:
pip install --upgrade sanskritayam
Now, you should have the latest release of sanskritayam which was published on PyPi (could be a downstream version , but the most stable one.)
Sanskritayam has a simple and intuitive syntax inspired by Sanskrit words and concepts. Here's an overview of the language's syntax and usage:
To give your code more extraordinary looks! you can try writing "swaha" after each line of code! Note :
- You should not use "swaha" inside any functions nor with when writing functions.
- You can use the "swaha" at the end of the line when calling a function. (Use cases are mentioned below in the docucmentation)
- You cannot use swaha with if(yadi) and else(anyatha).
- The "swaha" is not mandatory for the user to write but you can write it to make your coding more fun!
To declare a variable in Sanskritayam, you can use the following syntax:
<variable_name> = <value> swaha
The "swaha" is not mandatory for the user to write but you can write it to make your coding more fun!
For example:
ganakah = 42
Sanskritayam supports various data types, including:
- Integers (
ganakah
) - Floats (
chhedakah
) - Strings (
aksharankhyata
) - Lists (
samhata
) - Dictionaries (
nirukti
)
Sanskritayam includes control flow statements like conditional statements and loops:
yadi <condition>:
# code block
anyatha:
# code block
You can also use the athavayadi
statement for else-if conditions.
For loops:
krte <variable> antargatam <iterable>:
# code block
While loops:
jabtak <condition>:
# code block
To define a function in Sanskritayam, use the paribhasha
keyword:
paribhasha <function_name>(<arguments>):
# function body
pratyahar <return_value>
To call a function, simply use its name followed by parentheses with the arguments:
You can also use the "swaha" ability here -->
<function_name>(<arguments>) swaha
Sanskritayam allows you to read from and write to files using the following functions:
ayatah "<file_path>", "r" yatha patham:
# read from the file
ayatah "<file_path>", "w" yatha lekhyam:
# write to the file
Sanskritayam provides exception handling capabilities using the prayatnah
, apavadah
, and antatah
keywords:
prayatnah:
# code that might raise an exception
apavadah <exception_type>:
# exception handling code
antatah:
# code that will always execute
Sanskritayam supports object-oriented programming concepts like classes and objects:
vargah <class_name>:
# class body
# Creating an instance of the class
samskritayam = <class_name>()
To learn how to write code in Sanskritayam, check out the usage guide.
You can find various example programs written in Sanskritayam in the examples directory. These examples demonstrate different aspects of the language and serve as a starting point for learning Sanskritayam.
To ensure the correctness and reliability of the Sanskritayam language, a comprehensive test suite is available in the tests directory. The test suite covers various language features and helps maintain the integrity of the language implementation.
To run the tests, execute the following command:
python -m skm tests/sanskritayam_comprehensive_test.skt
The Sanskritayam programming language is released under the Apache License 2.0. Feel free to use, modify, and distribute the language according to the terms of the license.
Sanskritayam is a joke programming language created for fun and learning purposes. It is not recommended for use in production environments, and no warranty or support is provided. Use it at your own risk!
If anyone feels offended or uncomfortable with the concept or any aspect of this project, we sincerely apologize. Our intention is not to mock or disrespect any language, culture, political party, or religion. It's purely a lighthearted attempt to explore the idea of creating a programming language based on Sanskrit.
We would like to acknowledge the creators of the viral meme that inspired this project. Their humorous discussion sparked the idea of creating Sanskritayam, and we are grateful for the laughter and inspiration they provided.
Special thanks to Pinakkk for his invaluable contributions and collaboration in bringing Sanskritayam to life. His creativity, technical expertise, and sense of humor have been instrumental in shaping this project.
We also want to acknowledge that we may have unintentionally caused offense or hurt sentiments with this project. We deeply apologize if this is the case. Please read our full apology and explanation in the documentation.
As Sanskritayam is a fun and experimental project, we welcome contributions from the community. If you have any ideas, suggestions, or improvements, feel free to open an issue or submit a pull request on the GitHub repository.
Let's have fun coding in Sanskritayam and embrace the quirks and joys of this unique language!