Skip to main content

Python tools for creating Nintendo REL files

Project description

pyelf2rel

PyPI - Version PyPI - Python Version


Table of Contents

About

pyelf2rel is a tool / library for creation of files in Nintendo's GameCube/Wii REL format.

Alternatives

  • ttyd-tools has a C++ implementation of ELF to REL conversion.
    • This doesn't support linking against other REL files, though there is a fork that does.
    • This tool tends to have better performance than pyelf2rel, though in practice the difference seems to be negligible
    • pyelf2rel can be configured to behave the same way as this tool (see below)
  • ppcdis has a more specialised python implementation of the conversion designed for matching decompilation.
    • pyelf2rel is based off of this implementation and is more friendly for general use

Why make another elf2rel implementation?

  • ttyd-tools is a bit awkward to build, requiring Visual Studio (or manual setup on Linux) and Boost
  • Some legacy code requires specific fork builds of ttyd-tools elf2rel to work, all of those are supported by pyelf2rel
  • Upstream support for linking against other rels
  • Redirection of unlinked branches to _unresolved
  • Control over which sections to include and strip
  • This is easier to customise for projects to extend the format
    • Some kind of built-in metadata extension may be coming at some point

makelst

Also included is the makelst tool, which can generate LST symbol maps based on global symbols in ELFs and existing LSTs, for use with this or ttyd-tools elf2rel.

Installation

Run the following command to install the package.

pip install pyelf2rel

You will now have access to the pyelf2rel and makelst commands (also the extra elf2rel command, see below for information). Use each with -h for more information.

Using in place of ttyd-tools elf2rel

The tool provides an option for matching the API and behaviour (byte-matching output) of the ttyd-tools elf2rel tool through the elf2rel command.

  • For building projects requiring the ELF2REL environment variable, set it equal to elf2rel
  • For building projects requiring the TTYDTOOLS environment variable, set it equal to elf2rel -x

Multiple versions of the API and behaviour can be matched:

  • Use elf2rel [-x] to match the modern spm-rel-loader fork (elf2rel-21-12-2021)
    • elf2rel-13-6-2022 should function the same as this version other than the fact it supported using leading zeroes on the module id and section id without changing to octal - support for this quirk is not planned
  • Use elf2rel --old-fork [-x] to match the old spm-rel-loader fork (elf2rel-24-6-2021)
    • Notably, this includes support for the offset:symbol?moduleId,sectionId syntax
    • Like in the old fork, fixed linking is unsafe for rels produced by this
    • Support for the modern LST syntax isn't disabled while using this
  • Both modes are supersets of the original ttyd-tools elf2rel, and should match the behaviour of it on projects which used it.

License

pyelf2rel is distributed under the terms of the MIT license.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyelf2rel-1.0.6.tar.gz (16.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyelf2rel-1.0.6-py3-none-any.whl (18.2 kB view details)

Uploaded Python 3

File details

Details for the file pyelf2rel-1.0.6.tar.gz.

File metadata

  • Download URL: pyelf2rel-1.0.6.tar.gz
  • Upload date:
  • Size: 16.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.11.1

File hashes

Hashes for pyelf2rel-1.0.6.tar.gz
Algorithm Hash digest
SHA256 6a26d4a803e56d209da9121d3e7161de5a8ccd6c5bebb9dd3075bf7532d9799f
MD5 f0616ebbb413217a913c40392e43f615
BLAKE2b-256 cb35ebc8689a00723ffe369b7edeea75fb3a09709ecd1397e861728162b0a7a3

See more details on using hashes here.

File details

Details for the file pyelf2rel-1.0.6-py3-none-any.whl.

File metadata

  • Download URL: pyelf2rel-1.0.6-py3-none-any.whl
  • Upload date:
  • Size: 18.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.11.1

File hashes

Hashes for pyelf2rel-1.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 18d7ccac1d86029947bdbdd49161b24df43e93a58ced2b35c33bcaadf74f3aee
MD5 bec641da1cb8159158c8fb8aec68ed3d
BLAKE2b-256 d7be74ae1f5dc43ca3ef985cc9ceb41c4a245ea30b07c43f3d4209bce40373d8

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page