Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added README.md with documentation #124

Open
wants to merge 9 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
# Builing umu-protonfixes binaries
builddir/
dist/
subprojects/

# Byte-compiled / optimized / DLL files
__pycache__/
*.py[cod]
Expand Down
185 changes: 185 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,185 @@
# UMU-Protonfixes

This project acts as a stopgap for fixing games that don't work out of the box on Proton. It implements game-specific patches, such as installing Winetricks verbs.

It is the heart of `UMU-Proton` and `GE-Proton`.

## Start parameter fixes

The [default fix file for Steam](gamefixes-steam/default.py) implements a feature to install Winetricks / Protontricks verbs via startup parameters. Just add `-pf_tricks=<verb>` to it. You can install multiple verbs by adding the parameter more than once.

```bash
-pf_tricks=xliveless -pf_tricks=d3dcompiler_47
```
Additionally, you have the option to replace parts of the executable's path, such as the name of the .exe file.
Please note that all occurrences of the first part (before the '=') will be replaced. Be careful.

```bash
-pf_replace_cmd=/launcher.exe=/game.exe -pf_replace_cmd=/demo/=/full_version/
```

You can also set [dxvk options](https://github.com/doitsujin/dxvk/wiki/Configuration).

```bash
-pf_dxvk_set=dxgi.maxFrameRate=40 -pf_dxvk_set=d3d9.maxFrameRate=40
```

The order is not important and the arguments are not passed on to the game.

If you don't use `%command%` in your launch options, you can just add the parameters.

If you do, please add it after the `%command%` part, as in this example:

```bash
mangohud %command% -window -pf_replace_cmd=/launcher.exe=/game.exe -pf_tricks=xliveless
```

## Local fixes

The easiest way to implement a new fix or modify an existing one, is to use local fixes.

### Game fixes

First of all, you should find the Steam-ID of the game (right click the game in your Steam library -> 'Properties...' -> 'Updates' -> 'App ID:') and use it as the filename, with a `.py` extension.

Example `Day of Defeat: Source` (AppID 300):

> ~/.config/protonfixes/localfixes/300.py

Another type of fix is one that runs before each game. This allows you to set defaults for all games.

> ~/.config/protonfixes/localfixes/default.py

Note that local fixes override the included "global" fixes. So using an existing fix might be a good starting point for modifications, as they will not be executed.

For example, overriding the default fix will disable [the parameter parsing for Steam games](#start-parameter-fixes). This can be restored by copying [the global default file](gamefixes-steam/default.py) and applying your changes accordingly.

### Verbs

You can also add local Winetricks verbs, just like the ones implemented [here](verbs).

This also allows you to override existing Protontricks and Winetricks verbs, for example if a URL or file hash has changed.

> ~/.config/protonfixes/localfixes/<verb_name>.verb

To call them, just use the default function:

```python
util.protontricks('<verb_name>')
```

## Non-Steam games

As we support platforms other than Steam, these fixes can also be used by other launchers, such as Lutris, Heroic, Legendary or Bottles.

The current implementation requires entries in a special database that looks up the `UMU-ID`, which consists of the prefix `umu-` and in most cases the SteamID (if the game exists on that platform).

https://github.com/Open-Wine-Components/umu-database

## Config file

There is a config file located at:

> ~/.config/protonfixes/config.ini

It's not widely used at the moment, but you can configure some aspects.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Agreed. I doubt this feature is widely used too, so we should definitely consider deprecating this feature along with the GDrive functionality.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Or we can add more config parameters and actually use that feature. Not sure yet.


### Defaults

```toml
[main]
enable_checks = true
enable_global_fixes = true

[path]
cache_dir = ~/.cache/protonfixes
```

### Variables

`enable_checks`: De-/activate checks that are run on every startup. Currently only a check if esync might cause problems.

`enable_global_fixes`: De-/activate global fixes, which are the built-in files in the `gamefix-*` folders. Only [local fixes](#local-fixes) will be executed.

`cache_dir`: Used when something needs to be unpacked or similar.

### Values

Valid "enable" values are: `yes`, `y`, `true`, `1`

Any other value is interpreted as disabled.

## Building binaries

UMU-Protonfixes ships some binaries - used by some fixes - that need to be built.

**You probably do not need to build them to contribute.**

These binaries are not included in this repository, but are built from git-submodules in the [subprojects folder](subprojects/). To get the submodules, run the following command:

```bash
git submodule update --init --recursive
```

To actually build the binaries, simply run:

```bash
make
```

## Contributing

We do enforce some linting and testing that can and should be done locally - before you open a pull request.

### Linting

To install the necessary tools, just run:

```bash
python -m pip install --upgrade pip
pip install ruff
```

On Arch / Manjaro, you should run this instead:

```bash
sudo pacman -Sy ruff
```

To run a check, just execute:

```bash
ruff check .
Root-Core marked this conversation as resolved.
Show resolved Hide resolved
```

You are good to go when you see the message `All checks passed!`.

If not, try letting `ruff` (the linter we use) fix it automatically:

```bash
ruff format .
```

### Testing

The filenames of the fixes are checked against the Steam and GOG APIs. All symbolic links are also checked. This is not mandatory to run locally, as you should have a working game fix to begin with, and it will be done automatically by Github's CI.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Once we get more fixes related to other stores, it'd be nice to validate their store IDs against an API too. Or if there isn't an API, maybe query the game's store page if it includes the game's identifier in the URL like Steam's.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sure, I was just documenting the current state.

Loosely related, but I had some discussion about the other stores here: Open-Wine-Components/umu-database#39


You can still run it though:

```bash
cd .github/scripts
python check_gamefixes.py
```

You need the following prerequisites:

```bash
python -m pip install --upgrade pip
pip install ijson
```

On Arch / Manjaro:

```bash
sudo pacman -Sy python-ijson
```
1 change: 0 additions & 1 deletion config.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@
DEFAULT_CONF = """
[main]
enable_checks = true
enable_splash = false
enable_global_fixes = true


Expand Down