aboutsummaryrefslogtreecommitdiff
path: root/codegen/lib/download.py
diff options
context:
space:
mode:
authormat <github@matdoes.dev>2022-05-27 01:11:42 -0500
committermat <github@matdoes.dev>2022-05-27 01:11:42 -0500
commit68ab3d65247c02d469d77e5702f57e46f690965b (patch)
tree0bf5e7e4950fd82c0e1848b95c0ab0a3bcbdf2d2 /codegen/lib/download.py
parent7743bb1a84020752d49d1b308da6cc93f7254e80 (diff)
downloadazalea-drasl-68ab3d65247c02d469d77e5702f57e46f690965b.tar.xz
Fix codegen more
Diffstat (limited to 'codegen/lib/download.py')
-rw-r--r--codegen/lib/download.py40
1 files changed, 19 insertions, 21 deletions
diff --git a/codegen/lib/download.py b/codegen/lib/download.py
index 5030f8f3..0d6668bd 100644
--- a/codegen/lib/download.py
+++ b/codegen/lib/download.py
@@ -1,42 +1,40 @@
+from lib.utils import get_dir_location
from .mappings import Mappings
import requests
import json
import os
# make sure the downloads directory exists
-if not os.path.exists('downloads'):
- os.mkdir('downloads')
+if not os.path.exists(get_dir_location('downloads')):
+ os.mkdir(get_dir_location('downloads'))
def get_burger():
- if not os.path.exists('downloads/Burger'):
- with open('burger.json', 'w') as f:
- json.dump(requests.get(
- 'https://api.github.com/repos/Burger/Burger/releases/latest').json(), f)
+ if not os.path.exists(get_dir_location('downloads/Burger')):
print('\033[92mDownloading Burger...\033[m')
os.system(
- 'cd downloads && git clone https://github.com/pokechu22/Burger && cd Burger && git pull')
+ f'cd {get_dir_location("downloads")} && git clone https://github.com/pokechu22/Burger && cd Burger && git pull')
print('\033[92mInstalling dependencies...\033[m')
os.system('cd downloads/Burger && pip install six jawa')
def get_version_manifest():
- if not os.path.exists(f'downloads/version_manifest.json'):
+ if not os.path.exists(get_dir_location(f'downloads/version_manifest.json')):
print(
f'\033[92mDownloading version manifest...\033[m')
version_manifest_data = requests.get(
'https://launchermeta.mojang.com/mc/game/version_manifest.json').json()
- with open(f'downloads/version_manifest.json', 'w') as f:
+ with open(get_dir_location(f'downloads/version_manifest.json'), 'w') as f:
json.dump(version_manifest_data, f)
else:
- with open(f'downloads/version_manifest.json', 'r') as f:
+ with open(get_dir_location(f'downloads/version_manifest.json'), 'r') as f:
version_manifest_data = json.load(f)
return version_manifest_data
def get_version_data(version_id: str):
- if not os.path.exists(f'downloads/{version_id}.json'):
+ if not os.path.exists(get_dir_location(f'downloads/{version_id}.json')):
version_manifest_data = get_version_manifest()
print(
@@ -48,46 +46,46 @@ def get_version_data(version_id: str):
raise ValueError(
f'No version with id {version_id} found. Maybe delete downloads/version_manifest.json and try again?')
package_data = requests.get(package_url).json()
- with open(f'downloads/{version_id}.json', 'w') as f:
+ with open(get_dir_location(f'downloads/{version_id}.json'), 'w') as f:
json.dump(package_data, f)
else:
- with open(f'downloads/{version_id}.json', 'r') as f:
+ with open(get_dir_location(f'downloads/{version_id}.json'), 'r') as f:
package_data = json.load(f)
return package_data
def get_client_jar(version_id: str):
- if not os.path.exists(f'downloads/client-{version_id}.jar'):
+ if not os.path.exists(get_dir_location(f'downloads/client-{version_id}.jar')):
package_data = get_version_data(version_id)
print('\033[92mDownloading client jar...\033[m')
client_jar_url = package_data['downloads']['client']['url']
- with open(f'downloads/client-{version_id}.jar', 'wb') as f:
+ with open(get_dir_location(f'downloads/client-{version_id}.jar'), 'wb') as f:
f.write(requests.get(client_jar_url).content)
def get_burger_data_for_version(version_id: str):
- if not os.path.exists(f'downloads/burger-{version_id}.json'):
+ if not os.path.exists(get_dir_location(f'downloads/burger-{version_id}.json')):
get_burger()
get_client_jar(version_id)
os.system(
- f'cd downloads/Burger && python munch.py ../client-{version_id}.jar --output ../burger-{version_id}.json'
+ f'cd {get_dir_location("downloads/Burger")} && python munch.py ../client-{version_id}.jar --output ../burger-{version_id}.json'
)
- with open(f'downloads/burger-{version_id}.json', 'r') as f:
+ with open(get_dir_location(f'downloads/burger-{version_id}.json'), 'r') as f:
return json.load(f)
def get_mappings_for_version(version_id: str):
- if not os.path.exists(f'downloads/mappings-{version_id}.txt'):
+ if not os.path.exists(get_dir_location(f'downloads/mappings-{version_id}.txt')):
package_data = get_version_data(version_id)
client_mappings_url = package_data['downloads']['client_mappings']['url']
mappings_text = requests.get(client_mappings_url).text
- with open(f'downloads/mappings-{version_id}.txt', 'w') as f:
+ with open(get_dir_location(f'downloads/mappings-{version_id}.txt'), 'w') as f:
f.write(mappings_text)
else:
- with open(f'downloads/mappings-{version_id}.txt', 'r') as f:
+ with open(get_dir_location(f'downloads/mappings-{version_id}.txt'), 'r') as f:
mappings_text = f.read()
return Mappings.parse(mappings_text)