Skip to content

Commit

Permalink
Merge branch 'PortsMaster:main' into Bananaguy-2
Browse files Browse the repository at this point in the history
  • Loading branch information
JanTrueno authored Mar 22, 2024
2 parents a9f26fd + 001bf50 commit b8b3340
Show file tree
Hide file tree
Showing 2 changed files with 122 additions and 4 deletions.
2 changes: 2 additions & 0 deletions ports/angband/Angband.sh
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,8 @@ if [ $? -ne 0 ]; then
sed -i "s/CONF_FONT_SIZE/5x8x/" $GAMEDIR/conf/.angband/Angband/sdl2init.txt
elif [ "$DISPLAY_WIDTH" -lt "641" ] && [ "$DISPLAY_HEIGHT" -lt "481" ]; then
sed -i "s/CONF_FONT_SIZE/7x13x/" $GAMEDIR/conf/.angband/Angband/sdl2init.txt
elif [ "$DISPLAY_WIDTH" -lt "900" ] && [ "$DISPLAY_HEIGHT" -lt "481" ]; then
sed -i "s/CONF_FONT_SIZE/8x12x/" $GAMEDIR/conf/.angband/Angband/sdl2init.txt
elif [ "$DISPLAY_HEIGHT" -lt "721" ] && [ "$DISPLAY_WIDTH" -lt "721" ]; then
sed -i "s/CONF_FONT_SIZE/8x16x/" $GAMEDIR/conf/.angband/Angband/sdl2init.txt
else
Expand Down
124 changes: 120 additions & 4 deletions tools/build_release.py
Original file line number Diff line number Diff line change
Expand Up @@ -535,6 +535,118 @@ def build_gameinfo_zip(old_manifest, new_manifest):
zf.write(file_pair[0], file_pair[1])


def port_info_id(port_status, max_info_count=100):
"""
This sorts the ports by their date_added & name lower case.
We iterate through the ports keeping track of the total ports under an `info_id`.
Once we reach `max_info_count` ports in a single info_id, we increment the number.
To make it predictable we make sure that all ports with the same 'date_added'
stay in the same `info_id`, so we keep track of the last_date.
"""
info_id = 0
port_info_ids = {
info_id: 0,
}

port_info_id_map = {}
last_date = ''

for port_zip in sorted(port_status.keys(), key=lambda port_zip: (port_status[port_zip]['date_added'], port_zip.casefold())):
if not port_zip.lower().endswith('.zip'):
continue

if port_zip.lower().startswith('images.'):
continue

if port_zip.lower() in ('images.zip', 'gameinfo.zip'):
continue

current_date = port_status[port_zip]['date_added']

if (port_info_ids[info_id] >= max_info_count) and (last_date != current_date):
info_id += 1
port_info_ids[info_id] = 0

port_info_ids[info_id] += 1

port_zip = port_zip.rsplit('.', 1)[0]

port_info_id_map[port_zip] = info_id

last_date = current_date

# print(json.dumps(port_info_id_map, indent=2, sort_keys=True))

return port_info_id_map


def build_new_images_zip(old_manifest, new_manifest, port_status):
port_info_id_map = port_info_id(port_status)

max_info_id = max(port_info_id_map.values()) + 1

for info_id in range(max_info_id):
new_files = [
f"{file.replace('/', '.')}:{digest}"
for file, digest in new_manifest.items()
if file.count('/') == 1 and port_info_id_map[file.split('/', 1)[0]] == info_id and file_type(Path(file)) == SCREENSHOT_FILE]

old_files = [
f"{file.replace('/', '.')}:{digest}"
for file, digest in old_manifest.items()
if file.count('/') == 1 and port_info_id_map[file.split('/', 1)[0]] == info_id and file_type(Path(file)) == SCREENSHOT_FILE]

new_files.sort()
old_files.sort()

zip_name = f'images.{info_id:03d}.zip'

new_manifest[zip_name] = hash_items(new_files)
if old_manifest.get(zip_name) == new_manifest[zip_name]:
return

changes = {}
differ = Differ()

for line in differ.compare(old_files, new_files):
# line = " <FILENAME>:<md5SUM>"
mode = line[:2]
name = line[2:].split(":", 1)[0]
if mode == '- ':
# File is removed.
changes[name] = 'Removed'

elif mode == '+ ':
if name in changes:
# If the file was already seen, its been removed, and readded, which means modified.
changes[name] = 'Modified'

else:
# File is just added.
changes[name] = 'Added'

if zip_name in old_manifest:
print(f"Adding {zip_name}")

else:
print(f"Updating {zip_name}")

for name, mode in changes.items():
print(f" - {mode} {name}")

zip_files = [
((PORTS_DIR / file), f"{file.replace('/', '.')}")
for file, digest in new_manifest.items()
if file.count('/') == 1 and port_info_id_map[file.split('/', 1)[0]] == info_id and file_type(PORTS_DIR / file) == SCREENSHOT_FILE]

with zipfile.ZipFile(RELEASE_DIR / zip_name, 'w', compression=zipfile.ZIP_DEFLATED, compresslevel=9) as zf:
for file_pair in zip_files:
zf.write(file_pair[0], file_pair[1])


def build_images_zip(old_manifest, new_manifest):
new_files = [
f"{file.replace('/', '.')}:{digest}"
Expand Down Expand Up @@ -814,7 +926,7 @@ def port_diff(port_name, old_manifest, new_manifest):
print(f" - Added {file_name}")


def generate_ports_json(all_ports, port_status):
def generate_ports_json(all_ports, port_status, old_manifest, new_manifest):
ports_json_output = {
"ports": {},
"utils": {},
Expand All @@ -831,13 +943,17 @@ def generate_ports_json(all_ports, port_status):
port_status
)

## Jank :|
build_new_images_zip(old_manifest, new_manifest, port_status)

utils = []

if (RELEASE_DIR / 'PortMaster.zip').is_file():
utils.append(RELEASE_DIR / 'PortMaster.zip')

utils.append(RELEASE_DIR / 'gameinfo.zip')
utils.append(RELEASE_DIR / 'images.zip')
utils.extend(RELEASE_DIR.glob('images.*.zip'))

runtimes_map = {}

Expand Down Expand Up @@ -1047,7 +1163,7 @@ def main(argv):

build_gameinfo_zip(old_manifest, new_manifest)

generate_ports_json(all_ports, port_status)
generate_ports_json(all_ports, port_status, old_manifest, new_manifest)

errors = 0
warnings = 0
Expand Down Expand Up @@ -1105,10 +1221,10 @@ def main(argv):
del port_status[check_for]

with open(STATUS_FILE, 'w') as fh:
json.dump(port_status, fh, indent=2)
json.dump(port_status, fh, sort_keys=True, indent=2)

with open(MANIFEST_FILE, 'w') as fh:
json.dump(new_manifest, fh, indent=2)
json.dump(new_manifest, fh, sort_keys=True, indent=2)

if '--do-check' not in argv and len(argv) > 0:
if status['unchanged'] == status['total']:
Expand Down

0 comments on commit b8b3340

Please sign in to comment.