A module for compiling RistLang
Project description
RistPy
Just a programming language made to shorten the Python code
R - Rist
I - Is
S - Short
T - Text
Py - Python
Usage
First of all, it should be installed by
python3 -m pip install -U RistLang
Create a file named main.rist
A sample code is given here
@+ os, pprint
+@ typing @+ Union
cls${}: os.system{"cls" if os.name == "nt" $e "clear"}
cls{}
something${arg: Union[str, int]}:
p$p.p$p{["myText", [arg]]};
something{"text2"};
Then in your shell
rist run main.rist
Or if you want to compile into python file then run in your shell
rist run main.rist --compile-to rist_compiled_main.py
Or in your python file
from ristpy import rist, E, W
print(rist("main.rist"))
# if you want some text to compile then
code = """
$p{"hello"} # Print
"""
print(rist(code, fp=False))
# if you wanna execute then
rist(code, fp=False, flags=E) # E flag means execute
rist('main.rist', flags=E)
# compile code somewhere
rist("main.rist", flags=W, compile_to="main.py") # W flag means write
# if execute too then
rist("main.rist", flags=W|E, compile_to="main.py")
Syntax
Importing
What can it Import?
It can Import all python modules
How to Import?
In python you do import asyncio
In rist you have to do @+ asyncio
In python you do from aiohttp import web
In rist you have to do +@ aiohttp @+ web
Functions
How do i make a function?
Making a function
# synchronous func;
foo${}: # <name_of_func> + $
pass
# asynchronous func
$bar${}: # $ + <name_of_func> + $
pass
How do i call it?
Calling a function
# synchronous function
foo{}
# asynchronous func
?bar{} # ? + <name_of_func>
Dict
How can I make dict as {}
is used as ()
Working With Dictionaries and sets
Dictionaries and Sets, in this language are enclosed within parentheses
()
For example
("hi": "hello")
("hello": ("wor": "ld"))
Tuples and lists
Making a List
[1,2]
[
1,
2
]
Making a Tuple
{1,2}
{
1,
2
}
Comments
To use comments in this language, use #
, Just like Python
For example:-
# Some comment
Built-ins
Like every language, this language also have some built-in functions, but with other syntax
The syntax made for them is $ + <function name>
$f # for
$i # int
$s # str
$y # try
$x # xor
$d # dict
$ei # elif
$e # else
$l # list
$pa # pass
$t # type
$b # break
$n # input
$p # print
$u # tuple
$wh # while
$yi # yield
$ex # except
$la # lambda
$o # locals
$ret # return
$fi # finally
$g # globals
$co # continue
$m # __import__
$r # ristpy.rist
$eval # run rist code
$re # regex library (re)
The xor
given here is a function provided by rist
which takes two inputs/parameters and returns boolean value as follows:
Input1 | Input2 | Output |
---|---|---|
False | False | False |
False | True | True |
True | False | True |
True | True | False |
Which can be written as
t = True
f = False
$p{$x{f,f}}
$p{$x{f,t}}
$p{$x{t,f}}
$p{$x{t,t}}
And its output will be
False
True
True
False
MultiFile Project
For Multiple File projects, make a file named ristconf.json
Format of the file is
{
"main": "<main file>",
"dirs": [
"<directories to use>"
],
"ignore": [
"<files to ignore>"
],
"snippets": {
"<macro name>": [
"line1",
"line2"
]
},
"snippets_py": {
"<macro name>": [
"line1",
"line2"
]
}
}
Here main
key is required while others are optional
A sample file is given here
{
"main": "main.rist",
"dirs": ["dir_example"],
"ignore": ["not_to_compile.rist"],
"snippets": {
"a": [
"$p{0}",
"$p{1}",
"$p{2}"
]
},
"snippets_py": {
"b": [
"print(3)",
"print(4)",
"print(5)"
]
}
}
Now the question arises, what is the snippets
key given here.
Here you can create macros which you can directly import in rist files
Working with macros
Syntax
{
"snippets": {
"<name of macro>": [
"Line 1, (in rist)",
"Line 2, (in rist)",
"and so on...(in rist)"
]
},
"snippets_py": {
"<name of macro>": [
"Line 1, (in Python)",
"Line 2, (in Python)",
"and so on...(in Python)"
]
}
}
For example
{
"main": "main.rist",
"snippets": {
"a": [
"$p{0}",
"$p{1}",
"$p{2}"
]
},
"snippets_py": {
"b": [
"print(3)",
"print(4)"
]
}
}
You can use it by %- <name of macro> -%
%- a -%
# inside function
func${}:
%- b -%
Note: Nothing other should be there in the lines containing
%-
syntax
Encryptions/Decryptions
Encryptions and Decryptions too comes with rist. You can encrypt anything with rist!
Encrypting from shell
If you want to encrypt something, then just run this in your shell
rist encrypt --filepath <file_to_encrypt> --output <encrypted_output_file> --key <any_integer> --depth 2
Here, key is any number of your choice which will be the passcode and it is optional. Generates automatically if not given Depth is also a number, between 1 to 8 which specifies the layers/times it will be encrypted. It is 1 by default
For example:
rist encrypt --filepath myfile.rist --output myfile.rist.enc --key 22 --depth 2
Encrypting from rist
If you want to encrypt something from rist, then
+@ ristpy @+ encrypt
text="Some_Text"
encrypted=encrypt{text,22,depth=2}
$p{encrypted}
Decrypting from shell
If you want to Decrypt something, then just run this in your shell
rist decrypt --filepath <file_to_decrypt> --output <decrypted_output_file> --key <your_key> --depth <the_depth_you_used>
For example:
rist decrypt --filepath myfile.rist.enc --output myfile.rist --key 22 --depth 2
Decrypting from rist
If you want to decrypt something from rist, then
+@ ristpy @+ decrypt
text="1100 1254 1166 1254 726 1122 1166 1210 1166 726 1122 1166 1122 1078 726 1122 1122 1166 1166 726 1122 1100 1100 1122 726 1100 1254 1232 1078 726 1122 1122 1166 1166 726 1122 1210 1210 1122 726 1122 1188 1232 1166"
decrypted=decrypt{text,22,depth=2}
$p{decrypted}
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file RistLang-1.2.1.tar.gz
.
File metadata
- Download URL: RistLang-1.2.1.tar.gz
- Upload date:
- Size: 12.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b9b626473c13d747f9951faddc759f78cb641f160f487b839949b4b9caa11b79 |
|
MD5 | caaf270c1dc6523cdc3eec6d8a3b6c72 |
|
BLAKE2b-256 | d9b5ab303ca37d6a90b9101edc74eaded59313ccfc717960ce22259fbffaa46c |
File details
Details for the file RistLang-1.2.1-py3-none-any.whl
.
File metadata
- Download URL: RistLang-1.2.1-py3-none-any.whl
- Upload date:
- Size: 13.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 02b12112b60aa00d0d969d4e9c8800b00787f511ffc0c015f5f972eb49b8728d |
|
MD5 | 5e69171925c359e412588ce56c91b6e1 |
|
BLAKE2b-256 | c589ced2465a82cfad924e075aa8815c028afadd6dfd7529587a68bf2b6cf206 |