mirror of
https://github.com/NinjaCheetah/WiiPy.git
synced 2025-04-26 13:21:01 -04:00
Added lz77 command to allow for decompressing LZ77-compressed files
This commit is contained in:
parent
a6388834e0
commit
9a89f80247
28
commands/archive/lz77.py
Normal file
28
commands/archive/lz77.py
Normal file
@ -0,0 +1,28 @@
|
||||
# "commands/archive/lz77.py" from WiiPy by NinjaCheetah
|
||||
# https://github.com/NinjaCheetah/WiiPy
|
||||
|
||||
import pathlib
|
||||
import libWiiPy
|
||||
from modules.core import fatal_error
|
||||
|
||||
|
||||
def handle_lz77_compress(args):
|
||||
print("Compression is not implemented yet.")
|
||||
|
||||
|
||||
def handle_lz77_decompress(args):
|
||||
input_path = pathlib.Path(args.input)
|
||||
if args.output is not None:
|
||||
output_path = pathlib.Path(args.output)
|
||||
else:
|
||||
output_path = pathlib.Path(input_path.name + ".out")
|
||||
|
||||
if not input_path.exists():
|
||||
fatal_error(f"The specified file \"{input_path}\" does not exist!")
|
||||
|
||||
lz77_data = input_path.read_bytes()
|
||||
data = libWiiPy.archive.decompress_lz77(lz77_data)
|
||||
output_path.write_bytes(data)
|
||||
|
||||
print("LZ77 file decompressed!")
|
||||
|
@ -26,8 +26,15 @@ def handle_u8_unpack(args):
|
||||
|
||||
if not input_path.exists():
|
||||
fatal_error(f"The specified input file \"{input_path}\" does not exist!")
|
||||
|
||||
u8_data = input_path.read_bytes()
|
||||
# U8 archives are sometimes compressed. In the event that the provided data is LZ77 data, assume it's a compressed
|
||||
# U8 archive and decompress it before continuing. Standard checks will then catch it if it was something else.
|
||||
if u8_data[0:4] == b'LZ77':
|
||||
u8_data = libWiiPy.archive.decompress_lz77(u8_data)
|
||||
|
||||
# Output path is deliberately not checked in any way because libWiiPy already has those checks, and it's easier
|
||||
# and cleaner to only have one component doing all the checks.
|
||||
libWiiPy.archive.extract_u8(input_path.read_bytes(), str(output_path))
|
||||
libWiiPy.archive.extract_u8(u8_data, str(output_path))
|
||||
|
||||
print("U8 archive unpacked!")
|
||||
|
25
wiipy.py
25
wiipy.py
@ -5,6 +5,7 @@ import argparse
|
||||
from importlib.metadata import version
|
||||
|
||||
from commands.archive.ash import *
|
||||
from commands.archive.lz77 import *
|
||||
from commands.archive.theme import *
|
||||
from commands.archive.u8 import *
|
||||
from commands.nand.emunand import *
|
||||
@ -30,7 +31,7 @@ if __name__ == "__main__":
|
||||
# Argument parser for the ASH subcommand.
|
||||
ash_parser = subparsers.add_parser("ash", help="compress/decompress an ASH file",
|
||||
description="compress/decompress an ASH file")
|
||||
ash_subparsers = ash_parser.add_subparsers(title="emunand", dest="emunand", required=True)
|
||||
ash_subparsers = ash_parser.add_subparsers(title="ash", dest="ash", required=True)
|
||||
# ASH compress parser.
|
||||
ash_compress_parser = ash_subparsers.add_parser("compress", help="compress a file into an ASH file",
|
||||
description="compress a file into an ASH file; by default, this "
|
||||
@ -146,6 +147,28 @@ if __name__ == "__main__":
|
||||
iospatch_parser.add_argument("-ns", "--no-shared", action="store_true",
|
||||
help="set all patched content to be non-shared")
|
||||
|
||||
# Argument parser for the LZ77 subcommand.
|
||||
lz77_parser = subparsers.add_parser("lz77", help="compress/decompress data using LZ77 compression",
|
||||
description="compress/decompress data using LZ77 compression")
|
||||
lz77_subparsers = lz77_parser.add_subparsers(title="lz77", dest="lz77", required=True)
|
||||
# LZ77 compress parser.
|
||||
lz77_compress_parser = lz77_subparsers.add_parser("compress", help="compress a file with LZ77 compression",
|
||||
description="compress a file with LZ77 compression; by default, "
|
||||
"this will output to <input file>.lz77")
|
||||
lz77_compress_parser.set_defaults(func=handle_lz77_compress)
|
||||
lz77_compress_parser.add_argument("input", metavar="IN", type=str, help="file to compress")
|
||||
lz77_compress_parser.add_argument("-o", "--output", metavar="OUT", type=str,
|
||||
help="file to output the compressed data to (optional)")
|
||||
# LZ77 decompress parser.
|
||||
lz77_decompress_parser = lz77_subparsers.add_parser("decompress", help="decompress an LZ77-compressed file",
|
||||
description="decompress an LZ77-compressed file; by default, "
|
||||
"this will output to <input file>.out")
|
||||
lz77_decompress_parser.set_defaults(func=handle_lz77_decompress)
|
||||
lz77_decompress_parser.add_argument("input", metavar="IN", type=str,
|
||||
help="LZ77-compressed file to decompress")
|
||||
lz77_decompress_parser.add_argument("-o", "--output", metavar="OUT", type=str,
|
||||
help="file to output the decompressed data to (optional)")
|
||||
|
||||
# Argument parser for the NUS subcommand.
|
||||
nus_parser = subparsers.add_parser("nus", help="download data from the NUS",
|
||||
description="download from the NUS")
|
||||
|
Loading…
x
Reference in New Issue
Block a user