libWiiPy.archive.u8 Module#

The libWiiPy.archive.u8 module provides support for handling U8 archives, which are a non-compressed archive format used extensively on the Wii to join multiple files into one.

This module exposes functions for both packing and unpacking U8 archives, as well as code to parse IMET headers. IMET headers are a header format used specifically for U8 archives containing the banner of a channel, as they store the localized name of the channel along with other banner metadata.

Module Contents#

class libWiiPy.archive.u8.IMETHeader#

Bases: object

An IMETHeader object that allows for parsing, editing, and generating an IMET header. These headers precede the data of a channel banner (00000000.app), and are used to store metadata about the banner and verify its data.

An IMET header is always 1,536 (0x600) bytes long.

magic#

Magic number for the header, should be “IMD5”.

Type:

str

header_size#

Length of the M

Type:

int

imet_version#

Version of the IMET header. Normally always 3.

Type:

int

sizes#

The file sizes of icon.bin, banner.bin, and sound.bin.

Type:

List[int]

flag1#

Unknown.

Type:

int

channel_names#

The name of the channel this header is for in Japanese, English, German, French, Spanish, Italian, Dutch, Simplified Chinese, Traditional Chinese, and Korean, in that order.

Type:

List[str]

md5_hash#

MD5 sum of the entire header, with this field being all zeros during the hashing.

Type:

bytes

class LocalizedTitles(value, names=None, *, module=None, qualname=None, type=None, start=1, boundary=None)#

Bases: IntEnum

TITLE_CHINESE_SIMPLIFIED = 7#
TITLE_CHINESE_TRADITIONAL = 8#
TITLE_DUTCH = 6#
TITLE_ENGLISH = 1#
TITLE_FRENCH = 3#
TITLE_GERMAN = 2#
TITLE_ITALIAN = 5#
TITLE_JAPANESE = 0#
TITLE_KOREAN = 9#
TITLE_SPANISH = 4#
create(sizes: List[int], channel_names: Tuple[int, str] | List[Tuple[int, str]]) None#

Create a new IMET header, specifying the sizes of the banner components and one or more localized channel names.

Parameters:
  • sizes (List[int]) – The size in bytes of icon.bin, banner.bin, and sound.bin, in that order.

  • channel_names (Tuple(int, str), List[Tuple[int, str]]) – A pair or list of pairs of the target language and channel name for that language. Target languages are defined in LocalizedTitles.

dump() bytes#

Dump the IMETHeader back into raw bytes.

Returns:

The IMET header as bytes.

Return type:

bytes

get_channel_names(target_languages: int | List[int]) str | List[str]#

Get one or more channel names from the IMET header based on the specified languages.

Parameters:

target_languages (int, List[int, str]) – One or more target languages. Target languages are defined in LocalizedTitles.

Returns:

The channel name for the specified language, or a list of channel names in the same order as the specified languages.

Return type:

str, List[str]

load(imet_data: bytes) None#

Loads the raw data of an IMET header.

Parameters:

imet_data (bytes) – The data for the IMET header to load.

set_channel_names(channel_names: Tuple[int, str] | List[Tuple[int, str]]) None#

Specify one or more new channel names to set in the IMET header.

Parameters:

channel_names (Tuple(int, str), List[Tuple[int, str]]) – A pair or list of pairs of the target language and channel name for that language. Target languages are defined in LocalizedTitles.

class libWiiPy.archive.u8.U8Archive#

Bases: object

A U8 object that allows for parsing and editing the contents of a U8 archive.

u8_node_list#

A list of U8Node objects representing the nodes of the U8 archive.

Type:

List[_U8Node]

file_name_list#

A list of the names of the files in the U8 archive.

Type:

List[str]

file_data_list#

A list of file data for the files in the U8 archive; corresponds with file_name_list.

Type:

List[bytes]

header_size#

The size of the U8 archive header.

Type:

int

data_offset#

The offset of the data region of the U8 archive.

Type:

int

imet_header#

The IMET header of the U8 archive, if one exists. Otherwise, an empty IMETHeader object.

Type:

IMETHeader

dump() bytes#

Dumps the U8Archive object into the raw data of a U8 archive.

Returns:

The full U8 archive as bytes.

Return type:

bytes

load(u8_data: bytes) None#

Loads raw U8 data into a new U8 object. This allows for extracting the file and updating its contents.

Parameters:

u8_data (bytes) – The data for the U8 file to load.

libWiiPy.archive.u8.extract_u8(u8_data, output_folder) None#

Extracts the provided U8 archive file data into the provided output folder path. Note that the folder must not already exist to ensure that the output can correctly represent the file structure of the original U8 archive.

Parameters:
  • u8_data (bytes) – The data for the U8 file to extract.

  • output_folder (str) – The path to a new folder to extract the archive to.

libWiiPy.archive.u8.pack_u8(input_path, generate_imet=False, imet_titles: List[str] = None) bytes#

Packs the provided file or folder into a new U8 archive, and returns the raw file data for it.

To generate an IMET header for this U8 archive, the archive must contain the required banner files “icon.bin”, “banner.bin”, and “sound.bin”, because the sizes of these files are stored in the header.

Parameters:
  • input_path – The path to the input file or folder.

  • generate_imet (bool, optional) – Whether an IMET header should be generated for this U8 archive or not. IMET headers are only used for channel banners (00000000.app), and required banner files must exist to generate this header. Defaults to False.

  • imet_titles (List[str], optional) – A list of the channel title in different languages for the IMET header. If only one item is provided, that item will be used for all entries in the header. Defaults to None, and is only used when generate_imet is True.

Returns:

u8_archive – The data for the packed U8 archive.

Return type:

bytes