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.9.tar.gz (16.4 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.9-py3-none-any.whl (18.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pyelf2rel-1.0.9.tar.gz
  • Upload date:
  • Size: 16.4 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.9.tar.gz
Algorithm Hash digest
SHA256 fdd42f1a53ba2daa5b01281b64fc6055f0b7c559f6ec9aff12b846ac29b6411e
MD5 80cdfabfadb155f399bb1aca11795ef6
BLAKE2b-256 d85cfa2187ccfe76df3edaa03c33e87f3b33b0d98530a8d6fb2328d4a3c13f36

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pyelf2rel-1.0.9-py3-none-any.whl
  • Upload date:
  • Size: 18.3 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.9-py3-none-any.whl
Algorithm Hash digest
SHA256 54993d0dae7853818c62b16e66e30cb1ad1bb36e1674ad50098d6ac2f5bfa4ce
MD5 575f514527b29062451eb0e9aaddbdf1
BLAKE2b-256 7c6bda16d185affa06546d0049d20380b68de587fe2d534747b883f107bca2b5

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