-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
Allow pymhf to attach to running process and config improvements
- Loading branch information
Showing
13 changed files
with
345 additions
and
96 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,34 +1,79 @@ | ||
# pyMHF settings file [OBSOLETE] | ||
# Configuring `pymhf` | ||
|
||
**TODO: Update these settings** | ||
The way that `pymhf` is configured is by way of settings in [toml](https://toml.io/en/) format. | ||
These can be provided in one of two ways, depending on whether you are providing them as part of a library, or as part of a single-file mod. | ||
|
||
*pyMHF* contains a file called `pymhf.cfg` which (currently) must be situated within the root directory of the modding library (cf. [here](../writing_libraries.md)) | ||
This file has a number of properties in different sections. Some are required and others are not: | ||
For a library, the settings MUST be provided in a `pymhf.toml` file within the root directory of the library (ie. not the top level, but the named directory which contains all the files relevant to the library, cf. [here](../writing_libraries.md)) | ||
For a single-file mod, the settings are provided in the inline metadata (see [here](../single_file_mods.md)) | ||
|
||
## `binary` section: | ||
## Configuration sections and values | ||
|
||
In the following we shall name the sections as how they must be typed in the `pymhf.toml` file. To use these in the inline metadata for a single-file mod, simply prepend `tool.` to the section name. | ||
|
||
### `pymhf` section: | ||
|
||
This section handles properties which relate to the game or program that the library will be for. | ||
|
||
- **path**: The full path of the binary to be run. | ||
- **exe**: Either the absolute path to the binary being run, or the name of the exe which is being run by steam. | ||
|
||
- **steam_guid** [Optional]: If the game is run through steam, this should set to the Steam App ID. This can be found by right clicking on the game in your library and selecting "Properties...". The value can be found under the "Updates" option on the left. | ||
|
||
- **mod_dir**: The full path to the directory containing the mods to be run. | ||
- **required_assemblies**: [Optional]: A list of assemblies that are required to be loaded by the binary at `path` for the game to be considered "loaded". For now, if this is provided, it will also be the binary within which offsets are found relative to, however this will be relaxed in the future as better functionality regarding this is developed. | ||
|
||
- **hash**: The `SHA1` hash of the exe. This is used to ensure that the binary matches what is expected by the library exactly. | ||
- **start_paused**: [Optional] - default `True`: Whether or not to start the binary paused. Some programs do no like being started paused, however, if you can start paused it is preferred so that all hooks are created before any code is executed, ensuring no potential detours to be run are missed. | ||
|
||
- **steam_guid** [optional]: If the game is run through steam, this should set to the Steam App ID. This can be found by right clicking on the game in your library and selecting "Properties...". The value can be found under the "Updates" option on the left. | ||
- **default_mod_save_dir**: [Can use magic path] The path to the directory within which mod saves are to be placed. If this is not an absolute path and instead a "magic" path, `MOD_SAVES` will be appended to the magic path for the final path. | ||
|
||
- **required_assemblies**: [optional]: A list of assemblies that are required to be loaded by the binary at `path` for the game to be considered "loaded". For now, if this is provided, it will also be the binary within which offsets are found relative to, however this will be relaxed in the future as better functionality regarding this is developed. | ||
- **internal_mod_dir**: [Optional] [Can use magic path] [Library only] The path to the directory which contains the mods to be run by the library. | ||
|
||
## `pymhf` section: | ||
### `pymhf.logging` section: | ||
|
||
- **default_log_dir** [Can use magic path] The path to save the logs under. If not an absolute path, a subdirectory called `LOGS` will be created under this directory. | ||
|
||
- **log_level**: Whether to log at the standard level (`INFO`), or more in-depth (`DEBUG`). | ||
|
||
## `gui` section: | ||
- **window_name_override**: A string to override the default log window name. Note: This has some limitation currently such as only ascii characters being supported. This will be fixed some time in the future. | ||
|
||
### `pymhf.gui` section: | ||
|
||
This section related to properties specifically for the GUI which is auto-generated. | ||
|
||
- **shown**: Whether or not to show the GUI (`True` or `False`). | ||
|
||
- **scale**: The scale of the GUI. For some high-resolution monitors the GUI may end up scaled down when running from within a process, so sometimes this may need to be set to 1.5 for the GUI to look correct. | ||
|
||
- **log_window_name_override** The text to display at the top of the log window. | ||
|
||
## Magic path variables | ||
|
||
`pymhf` has a few "magic" path variables which can be used to make setting up configs more generic and flexible. | ||
|
||
To use the "name" versions of the magic strings, they must be surrounded by braces (ie. `{EXE_DIR}`) as part of the path. | ||
|
||
These path variables get resolved as part of a path, so we can provide a path like so `{EXE_PATH}/../MyMods` to place things in a folder called `MyMods` in the parent directory of the location of the main binary. | ||
|
||
### `EXE_DIR` | ||
|
||
This is the absolute path to directory which contains the main binary being run. | ||
|
||
### `USER_DIR` / `~` | ||
|
||
This is a directory within your user folder. This will often look something like `C:/Users/<username>/pymhf/<plugin name>`. For a single-file mod there is no `plugin name` so the folder will just be the `pymhf` folder. | ||
|
||
### `CURR_DIR` / `.` | ||
|
||
The current working directory, ie. the directory the single-file mod or modding library is located in. For the modding library it will be the main directory of the project which contains the `pymhf.toml` file. | ||
|
||
|
||
## Local-only variables and sections | ||
|
||
The above configuration settings are the defaults as set by the library or single-file mod. However, there are some settings which will need to be configured before running any libraries since the location of mod folders will very for each user. | ||
|
||
## `pymhf.local_config` section: | ||
|
||
These settings are set by calling `pymhf --config <libraryname>` or on first run of `pymhf <libraryname>`. | ||
|
||
- **mod_dir**: [Can use magic path] [Library only] The path to the directory which contains the mods to be run by the library. | ||
|
||
- **mod_save_dir**: [Can use magic path] [Overrides `default_mod_save_dir`] The path to the directory within which mod saves are to be placed. If this is not an absolute path and instead a "magic" path, `MOD_SAVES` will be appended to the magic path for the final path. | ||
|
||
- **log_dir** [Can use magic path] [Overrides `default_log_dir`] The path to save the logs under. If not an absolute path, a subdirectory called `LOGS` will be created under this directory. |
Oops, something went wrong.