
# libWiiPy
libWiiPy is a modern Python 3 library for handling the various files and formats found on the Wii. It aims to be simple to use, well maintained, and offer as many features as reasonably possible in one library, so that a newly-written Python program could do 100% of its Wii-related work with just one library. It also aims to be fully cross-platform, so that any tools written with it can also be cross-platform.
libWiiPy is inspired by [libWiiSharp](https://github.com/TheShadowEevee/libWiiSharp), which was originally created by `Leathl` and is now maintained by [@TheShadowEevee](https://github.com/TheShadowEevee).
# Features
This list will expand as libWiiPy is developed, but these features are currently available:
- TMD and Ticket parsing/editing (`.tmd`, `.tik`)
- Title parsing/editing, including content encryption/decryption (both retail and development)
- WAD file parsing/editing (`.wad`)
- Downloading titles and their components from the NUS
- Certificate, TMD, and Ticket signature verification
- Packing and unpacking U8 archives (`.app`, `.arc`)
- Decompressing ASH files (`.ash`, both the standard variants and the variants found in My Pokémon Ranch)
- Compressing/Decompressing LZ77-compressed files
- IOS patching
- NAND-related functionality:
  - EmuNAND title management (currently requires an existing EmuNAND)
  - `content.map` parsing/editing
  - `setting.txt` parsing/editing
  - `uid.sys` parsing/editing
- Limited channel banner parsing/editing
- Assorted miscellaneous features used to make the other core features possible
For a more detailed look at what's available in libWiiPy, check out our [API docs](https://ninjacheetah.github.io/libWiiPy).
# Usage
The easiest way to get libWiiPy for your project is to install the latest version of the library from PyPI, as shown below. 
```sh
pip install -U libWiiPy
```
Our PyPI project page can be found [here](https://pypi.org/project/libWiiPy/).
Because libWiiPy is very early in development, you may want to use the latest version of the package via git instead, so that you have the latest features available. You can do that like this:
```sh
pip install -U git+https://github.com/NinjaCheetah/libWiiPy
```
Please be aware that because libWiiPy is in a very early state right now, many features may be subject to change, and methods and properties available now have the potential to disappear in the future.
                               
For more tips on getting started, see our guide [here](https://ninjacheetah.github.io/libWiiPy/usage/installation.html).
# Building
To build this package locally, the steps are quite simple, and should apply to all platforms. Make sure you've set up your `venv` first!
First, install the dependencies from `requirements.txt`:
```sh
pip install -r requirements.txt
```
Then, build the package using the Python `build` module:
```sh
python -m build
```
And that's all! You'll find your compiled pip package in `dist/`.
# Special Thanks
This project wouldn't be possible without the amazing people behind its predecessors and all of the people who have contributed to the documentation of the Wii's inner workings over at [WiiBrew](https://wiibrew.org).
## Special Thanks to People Behind Related Projects
- Xuzz, SquidMan, megazig, Matt_P, Omega and The Lemon Man for creating Wii.py
- Leathl for creating libWiiSharp
- TheShadowEevee for maintaining libWiiSharp
## Special Thanks to WiiBrew Contributors
Thank you to all of the contributors to the documentation on the WiiBrew pages that make this all understandable! Some of the key articles referenced are as follows:
- [Title metadata](https://wiibrew.org/wiki/Title_metadata), for the documentation on how a TMD is structured
- [WAD files](https://wiibrew.org/wiki/WAD_files), for the documentation on how a WAD is structured
- [IOS history](https://wiibrew.org/wiki/IOS_history), for the documentation on IOS TIDs and how IOS is versioned
### One additional special thanks to [@DamiDoop](https://github.com/DamiDoop)!
She made the very cool banner you can see at the top of this README, and has also helped greatly with my sanity throughout debugging this library.
            
         
        Raw data
        
            {
    "_id": null,
    "home_page": null,
    "name": "libWiiPy",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.10",
    "maintainer_email": null,
    "keywords": "Wii, wii",
    "author": null,
    "author_email": "NinjaCheetah <ninjacheetah@ncxprogramming.com>, Lillian Skinner <lillian@randommeaninglesscharacters.com>",
    "download_url": "https://files.pythonhosted.org/packages/a7/ee/dcf113e485e4102c6beeb9c511a1740de8f50f1152045b89003fd5dc64df/libwiipy-0.6.0.tar.gz",
    "platform": null,
    "description": "\n# libWiiPy\nlibWiiPy is a modern Python 3 library for handling the various files and formats found on the Wii. It aims to be simple to use, well maintained, and offer as many features as reasonably possible in one library, so that a newly-written Python program could do 100% of its Wii-related work with just one library. It also aims to be fully cross-platform, so that any tools written with it can also be cross-platform.\n\nlibWiiPy is inspired by [libWiiSharp](https://github.com/TheShadowEevee/libWiiSharp), which was originally created by `Leathl` and is now maintained by [@TheShadowEevee](https://github.com/TheShadowEevee).\n\n\n# Features\nThis list will expand as libWiiPy is developed, but these features are currently available:\n- TMD and Ticket parsing/editing (`.tmd`, `.tik`)\n- Title parsing/editing, including content encryption/decryption (both retail and development)\n- WAD file parsing/editing (`.wad`)\n- Downloading titles and their components from the NUS\n- Certificate, TMD, and Ticket signature verification\n- Packing and unpacking U8 archives (`.app`, `.arc`)\n- Decompressing ASH files (`.ash`, both the standard variants and the variants found in My Pok\u00e9mon Ranch)\n- Compressing/Decompressing LZ77-compressed files\n- IOS patching\n- NAND-related functionality:\n  - EmuNAND title management (currently requires an existing EmuNAND)\n  - `content.map` parsing/editing\n  - `setting.txt` parsing/editing\n  - `uid.sys` parsing/editing\n- Limited channel banner parsing/editing\n- Assorted miscellaneous features used to make the other core features possible\n\nFor a more detailed look at what's available in libWiiPy, check out our [API docs](https://ninjacheetah.github.io/libWiiPy).\n\n# Usage\nThe easiest way to get libWiiPy for your project is to install the latest version of the library from PyPI, as shown below. \n```sh\npip install -U libWiiPy\n```\nOur PyPI project page can be found [here](https://pypi.org/project/libWiiPy/).\n\nBecause libWiiPy is very early in development, you may want to use the latest version of the package via git instead, so that you have the latest features available. You can do that like this:\n```sh\npip install -U git+https://github.com/NinjaCheetah/libWiiPy\n```\nPlease be aware that because libWiiPy is in a very early state right now, many features may be subject to change, and methods and properties available now have the potential to disappear in the future.\n                               \nFor more tips on getting started, see our guide [here](https://ninjacheetah.github.io/libWiiPy/usage/installation.html).\n\n# Building\nTo build this package locally, the steps are quite simple, and should apply to all platforms. Make sure you've set up your `venv` first!\n\nFirst, install the dependencies from `requirements.txt`:\n```sh\npip install -r requirements.txt\n```\n\nThen, build the package using the Python `build` module:\n```sh\npython -m build\n```\n\nAnd that's all! You'll find your compiled pip package in `dist/`.\n\n# Special Thanks\nThis project wouldn't be possible without the amazing people behind its predecessors and all of the people who have contributed to the documentation of the Wii's inner workings over at [WiiBrew](https://wiibrew.org).\n\n## Special Thanks to People Behind Related Projects\n- Xuzz, SquidMan, megazig, Matt_P, Omega and The Lemon Man for creating Wii.py\n- Leathl for creating libWiiSharp\n- TheShadowEevee for maintaining libWiiSharp\n\n## Special Thanks to WiiBrew Contributors\nThank you to all of the contributors to the documentation on the WiiBrew pages that make this all understandable! Some of the key articles referenced are as follows:\n- [Title metadata](https://wiibrew.org/wiki/Title_metadata), for the documentation on how a TMD is structured\n- [WAD files](https://wiibrew.org/wiki/WAD_files), for the documentation on how a WAD is structured\n- [IOS history](https://wiibrew.org/wiki/IOS_history), for the documentation on IOS TIDs and how IOS is versioned\n\n### One additional special thanks to [@DamiDoop](https://github.com/DamiDoop)!\nShe made the very cool banner you can see at the top of this README, and has also helped greatly with my sanity throughout debugging this library.\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "A modern Python library for handling files used by the Wii",
    "version": "0.6.0",
    "project_urls": {
        "Documentation": "https://ninjacheetah.github.io/libWiiPy/",
        "Homepage": "https://github.com/NinjaCheetah/libWiiPy",
        "Issues": "https://github.com/NinjaCheetah/libWiiPy/issues",
        "Repository": "https://github.com/NinjaCheetah/libWiiPy.git"
    },
    "split_keywords": [
        "wii",
        " wii"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "71297953b0cc843bdb3a810703b9cd0131318e9b0d928862d8cc669e1faffd95",
                "md5": "c63dfab42e86165fc360d5cf61916afb",
                "sha256": "d35dee2c1f096916ec2d67fcb98690f791e5324673361682e7afd6129ebf74bc"
            },
            "downloads": -1,
            "filename": "libWiiPy-0.6.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "c63dfab42e86165fc360d5cf61916afb",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.10",
            "size": 64819,
            "upload_time": "2025-02-10T22:01:24",
            "upload_time_iso_8601": "2025-02-10T22:01:24.611212Z",
            "url": "https://files.pythonhosted.org/packages/71/29/7953b0cc843bdb3a810703b9cd0131318e9b0d928862d8cc669e1faffd95/libWiiPy-0.6.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "a7eedcf113e485e4102c6beeb9c511a1740de8f50f1152045b89003fd5dc64df",
                "md5": "e55354d003b544ff31c33c0ab69ed57a",
                "sha256": "63f8f5144f8fcbb7ebd4b811a72fd4099ebec21f0fa8f6ddbdfd395297b2d937"
            },
            "downloads": -1,
            "filename": "libwiipy-0.6.0.tar.gz",
            "has_sig": false,
            "md5_digest": "e55354d003b544ff31c33c0ab69ed57a",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.10",
            "size": 55137,
            "upload_time": "2025-02-10T22:01:27",
            "upload_time_iso_8601": "2025-02-10T22:01:27.586741Z",
            "url": "https://files.pythonhosted.org/packages/a7/ee/dcf113e485e4102c6beeb9c511a1740de8f50f1152045b89003fd5dc64df/libwiipy-0.6.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-02-10 22:01:27",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "NinjaCheetah",
    "github_project": "libWiiPy",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [
        {
            "name": "build",
            "specs": []
        },
        {
            "name": "pycryptodome",
            "specs": []
        },
        {
            "name": "requests",
            "specs": []
        },
        {
            "name": "sphinx",
            "specs": []
        },
        {
            "name": "sphinx-book-theme",
            "specs": []
        },
        {
            "name": "myst-parser",
            "specs": []
        },
        {
            "name": "sphinx-copybutton",
            "specs": []
        },
        {
            "name": "sphinx-tippy",
            "specs": []
        },
        {
            "name": "sphinx-design",
            "specs": []
        }
    ],
    "lcname": "libwiipy"
}