No project description provided
Project description
[!CAUTION] This is a heavily WIP project
RimWorld XML library
This library is designed to assist with writing mods and mod patches for RimWorld. It provides functionality to load game data into an xml file and apply patches to it.
Basic usage
The package provides a convenience function load_world
for when you just need to
load the rimworld's xml data, apply patches, and then explore the resulting xml as you
like.
from pathlib import Path
from rimworld import load_world
# First let's prepare some paths (i'm using wsl2):
RIMWORLD_CORE_PACKAGES = Path("/mnt/e/steam/steamapps/common/RimWorld/Data")
RIMWORLD_LOCAL_MODS = Path("/mnt/e/steam/steamapps/common/Rimworld/Mods")
RIMWORLD_STEAM_MODS = Path("/mnt/e/steam/steamapps/workshop/content/294100")
RIMWORLD_MODSCONFIG_FOLDER = Path(
"/mnt/c/Users/lai/AppData/LocalLow/Ludeon Studios/"
"RimWorld by Ludeon Studios/Config/ModsConfig.xml"
)
world = load_world(
mod_folders=[RIMWORLD_CORE_PACKAGES, RIMWORLD_LOCAL_MODS, RIMWORLD_STEAM_MODS],
modsconfig_folder=RIMWORLD_MODSCONFIG_FOLDER,
)
print(world.xpath("/Defs/ThingDef/label/text()"))
Slightly more advanced usage
If you need something more advanced, you can go lower level.
Here is basically what load_world
from the above example does:
from pathlib import Path
from lxml import etree
from rimworld.mod import ModsConfig, load_mods, select_mods
from rimworld.patch import PatchContext, get_operation
from rimworld.xml import load_xml, merge
# First let's prepare some paths (i'm using wsl2):
RIMWORLD_CORE_PACKAGES = Path("/mnt/e/steam/steamapps/common/RimWorld/Data")
RIMWORLD_LOCAL_MODS = Path("/mnt/e/steam/steamapps/common/Rimworld/Mods")
RIMWORLD_STEAM_MODS = Path("/mnt/e/steam/steamapps/workshop/content/294100")
RIMWORLD_MODSCONFIG_FOLDER = Path(
"/mnt/c/Users/lai/AppData/LocalLow/Ludeon Studios/"
"RimWorld by Ludeon Studios/Config/ModsConfig.xml"
)
# We know where our mods are, but we need to load information about them
# This will take a few seconds as the script loads About.xml files
mods_collection = list(
load_mods(RIMWORLD_CORE_PACKAGES, RIMWORLD_LOCAL_MODS, RIMWORLD_STEAM_MODS)
)
# Now let's load game version, known expansions, and a list of active mods
mods_config = ModsConfig.load(RIMWORLD_MODSCONFIG_FOLDER)
# Select mods from our mods collection which are active
active_mods = list(select_mods(mods_collection, package_id_in=mods_config.active_mods))
# Prepare patching context - this is needed for proper patching
patch_context = PatchContext(
active_package_ids={m.package_id for m in active_mods},
active_package_names={m.about.name for m in active_mods if m.about.name},
)
# Create an empty xml tree
tree = etree.ElementTree(etree.Element("Defs"))
# And the final step
for mod in active_mods:
for def_file in mod.def_files(mods_config):
merge(tree, load_xml(def_file))
for patch_file in mod.patch_files(mods_config):
patch_operation_nodes = load_xml(patch_file).getroot().findall("Operation")
for patch_operation_node in patch_operation_nodes:
patch_operation = get_operation(patch_operation_node)
patch_operation(tree, patch_context)
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
Built Distribution
File details
Details for the file rimworld-0.3.2.tar.gz
.
File metadata
- Download URL: rimworld-0.3.2.tar.gz
- Upload date:
- Size: 21.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.4 Linux/5.15.153.1-microsoft-standard-WSL2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0b5c1db876aa39a14b439db70478e88a333efd63ec45a7bad679ef0c9556ee99 |
|
MD5 | f133ff779a19480142fc1edea131235a |
|
BLAKE2b-256 | a4c15a7011a736ae1d12d018ce6848f9a924dc055f73749d1553226daa397d06 |
File details
Details for the file rimworld-0.3.2-py3-none-any.whl
.
File metadata
- Download URL: rimworld-0.3.2-py3-none-any.whl
- Upload date:
- Size: 33.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.12.4 Linux/5.15.153.1-microsoft-standard-WSL2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9595774cfc76e2e58b88a5c495261f8d4b795a1d75ab760b196ffb4369ad2bb6 |
|
MD5 | 2ddbebd222bbfea8104ac34331a9753e |
|
BLAKE2b-256 | df3123dcc3d87ce82ccf4da6a9b99ab961cfe087c158429d396e9ff83cfbc567 |