TermPY/main.py

280 lines
7.7 KiB
Python
Raw Normal View History

import json
import os
import sys
import importlib
from inspect import isfunction
import random
import time
import ast
2023-08-27 02:28:03 +00:00
if os.name != "nt":
import readline
import threading
2023-08-27 03:34:08 +00:00
import signal
2023-08-27 04:24:51 +00:00
import requests
import subprocess
class color:
green = "\033[1;32m"
blue = "\033[1;34m"
white = "\033[0m"
red = "\033[1;31m"
orange = "\033[1;33m"
def restart_program():
python = sys.executable
subprocess.call([python, __file__])
sys.exit()
def clear():
os.system('cls' if os.name == 'nt' else 'clear')
def call(full_module_name, func_name, *args, **kwargs):
module = importlib.import_module(full_module_name)
if func_name in dir(module):
for attribute_name in dir(module):
attribute = getattr(module, attribute_name)
if isfunction(attribute) and attribute_name == func_name:
attribute(*args, **kwargs)
else:
raise Exception("Command Not Found")
def getPrompt():
path = "USERNAME" if os.name == "nt" else "USER"
username = os.environ.get(path)
if username is None:
username = ""
path = os.getcwd()
# Set up tab completion for file and directory names
2023-08-27 01:57:23 +00:00
if os.name != "nt":
completer = readline.get_completer()
readline.set_completer_delims(' \t\n')
readline.parse_and_bind("tab: complete")
prompt = color.white + "" + color.green + username + color.white + ":" + color.blue + path + color.white + "\n└ $ "
return prompt
def getInput():
print(getPrompt(), end="")
return input()
def getIndex( packages:list, package: str) -> str:
for key in packages:
if packages[key] == package:
return key
def toList(List: str) -> list:
newList = ast.literal_eval(List)
if isinstance(newList, list):
return newList
class packages:
def __init__(self):
try:
with open(("./packages/pakk.conf"), "r") as f:
self.packages = toList(f.readline())
except Exception as e:
print(e)
self.packages = [["builtin", "packages.builtin", ["echo", "ls", "rm", "clear", "cd", "ll"]]]
self.update(self.packages)
def update(self, packages):
with open(("./packages/pakk.conf"), "w") as f:
f.write(str(packages))
Packages = packages()
class packagemanager:
def __init__(self, args):
if len(args) <= 1:
print("Options:\ninstall <package name> | installs package \nlist | lists installed packages\nremove <package name> | uninstall packages\navailable | lists available commands")
elif args[1] == "install":
self.install(args[2])
elif args[1] == "list":
self.List()
elif args[1] == "remove":
self.uninstall(args[2:])
elif args[1] == "available":
self.commands("./packages")
else:
print("Options:\ninstall <package name> | installs package \nlist | lists installed packages\nremove <package name> | uninstall packages\navailable | lists available commands")
return
def commands(self, directory):
with os.scandir(directory) as entries:
for entry in entries:
if entry.name.endswith(".py"):
package_name = entry.name[:-3] # Remove the ".py" extension
if package_name not in [row[0] for row in Packages.packages]:
print(f"Package '{package_name}' is not installed.")
def install(self, name: str) -> int:
2023-08-27 05:02:37 +00:00
if name in [row[0] for row in Packages.packages]:
raise Exception("Package already installed")
try:
if not os.path.exists(f"./packages/{name}.py"):
raise FileNotFoundError(name)
except FileNotFoundError:
print("Downloading File from Source")
2023-08-27 04:24:51 +00:00
url = f"https://raw.githubusercontent.com/OusmBlueNinja/TermPY/main/packages/{name}.py"
r = requests.get(url)
#print(r.text)
fileInstallingCreator = os.path.join(os.path.dirname(os.path.realpath(__file__)), "packages", name+".py")
print("Saving file to disk")
2023-08-27 04:24:51 +00:00
with open(fileInstallingCreator, "w") as newFile:
newFile.write(r.text)
time.sleep(1)
call("helper.helper", "install", name, Packages)
print(f"{color.orange}WARNING: {color.white}Restarting Program")
restart_program()
except Exception as e:
raise Exception(f"Package could not be found, make sure package source is in [ packages ] folder. {e}")
try:
if name in [row[0] for row in Packages.packages]:
raise Exception("Package already installed")
with open(("./packages/"+name+".py"), "r") as f:
line = f.readline()
line = line.strip("#")
# ... (existing code)
print("Installing Package")
Packages.packages.append(toList(line))
Packages.update(Packages.packages)
print(f"\n{color.green}Success:{color.white} Successfully installed {name}.")
except Exception as e:
2023-08-27 02:36:57 +00:00
raise Exception(f"{color.red}{e}")
def List(self):
print("Installed Packages: \n"+ "\n".join([row[0] for row in Packages.packages]))
def uninstall(self, package: list):
for name in package:
#print(Packages.packages)
print(f"Uninstalling {name}")
for package in Packages.packages:
if name in package[0]:
Packages.packages.remove(package)
Packages.update(Packages.packages)
print(f"{color.green}Sucess:{color.white} Uninstalled {name}.")
#print(Packages.packages)
def handleCommands(command: list) -> list:
try:
2023-08-27 03:34:52 +00:00
if command[0] == "exit":
quit()
if command[0] == "help":
print("Type pakk for more help installing packages" )
return [0,None]
if command[0] == "pakk":
try:
PackageManager = packagemanager(command)
except Exception as e:
print(e)
return [0,None]
except Exception as e:
raise Exception(e)
try:
ran = False
for package in Packages.packages:
if command[0] in package[2]:
call(package[1], command[0], command[1:])
ran = True
return [0,None]
return [1, 'Command not Found']
except Exception as e:
print(e)
return [1, "A Faital error has acured while running commmand"]
def main():
while True:
command = getInput()
if command == "":
pass
else:
command = command.split(" ")
error = handleCommands(command)
if error[0]==1:
print(f"{color.red}ERROR{color.white}:{color.red} {error[1]}{color.white}")
2023-08-27 04:24:51 +00:00
def start():
2023-08-27 05:20:47 +00:00
if not os.path.exists(f"./packages"):
with open(f"/packages", "w") as f:
f.close()
2023-08-27 04:24:51 +00:00
try:
print("")
2023-08-27 04:24:51 +00:00
main()
except (KeyboardInterrupt, EOFError):
restart_program()
if __name__ == '__main__':
2023-08-27 04:24:51 +00:00
start()