docs: specify various types in the readme

This commit is contained in:
zaaarf 2024-12-14 23:24:20 +01:00 committed by GitHub
parent f712320610
commit 7bcb3448ed
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -2,9 +2,31 @@
A tiny library to process mappings in various formats. A tiny library to process mappings in various formats.
## Why? ## Why?
I initially [meant to fork Enigma](https://github.com/zaaarf/enigma), but honestly it was far more than I needed, even when stripped down to its core library. I initially [meant to fork Enigma](https://github.com/FabricMC/Enigma), but honestly it was far more than I needed, even when stripped down to its core library.
The purpose of this library is to act as base for the [Lillero processor](https://github.com/zaaarf/lillero-processor/), to work with various mapping formats. The purpose of this library is to act as base for [Lillero-processor](https://github.com/zaaarf/lillero-processor/), to work with various mapping formats.
## Usage ## Usage
Simply call `MapperProvider.getMapper()` and pass it a `List` of `String`s representing the mapping file's contents, line by line. Call then `populate()` on the resulting `IMapper`, passing the same `List` once again, and you'll have an object that can process stuff back and forth - granted that a mapper capable of parsing the input was found. Simply call `MapperProvider.getMapper()` and pass it a `List` of `String`s representing the mapping file's contents, line by line. Call then `populate()` on the resulting `IMapper`, passing the same `List` once again, and you'll have an object that can process stuff back and forth - granted that a mapper capable of parsing the input was found.
## Supported formats
These are the formats currently supported by this library:
- `srg`
- `tsrg`
- `tinyv2`
- `multi` (see below)
### Multimapper
A case where multiple passes of deobfuscation may be needed is also supported, although unrecommended; I would also very much advise against referencing an untrusted multimapper in a remote location, for reasons that will be obvious to you in a second. A multimapper looks like this:
```
lll multimapper
<url-or-path-for-first-mapping>
<url-or-path-for-second-mapping>
...
<url-or-path-for-last-mapping>
```
You obviously don't want a remote location you don't control telling you what to download on your computer.
The passes are applied in the provided order, from the first to the last.