imported>SpaceManiac (we can now detect python more reliably than before) |
imported>SpaceManiac Нет описания правки |
||
Строка 1: | Строка 1: | ||
/tg/station uses a tool called the '''Map Merger''' to | : [[Guide to contributing to the game]] > [[Guide to mapping]] | ||
/tg/station uses a tool called the '''Map Merger''' to make map changes easier for maintainers to review and less likely to conflict with map changes made by others. | |||
There are two ways of running the tool, each requiring some amount of setup. If you have trouble or need help, ask in [[Community|#coderbus]]. | There are two ways of running the tool, each requiring some amount of setup. If you have trouble or need help, ask in [[Community|#coderbus]]. | ||
== Basic | == Basic setup == | ||
# '''Install Python''': If you don't already have Python installed, [https://www.python.org/downloads/ download and install] the latest version. | # '''Install Python''': If you don't already have Python installed, [https://www.python.org/downloads/ download and install] the latest version. | ||
Строка 29: | Строка 31: | ||
With this method, leaving the map open in DreamMaker or reviewing it after running the map merger makes it possible to accidentally save and overwrite the merged map with an unmerged map. Close DreamMaker entirely before manually running the map merger or be extra-careful not to overwrite the changes the map merger made. | With this method, leaving the map open in DreamMaker or reviewing it after running the map merger makes it possible to accidentally save and overwrite the merged map with an unmerged map. Close DreamMaker entirely before manually running the map merger or be extra-careful not to overwrite the changes the map merger made. | ||
== What is map merging, actually? == | |||
The "map merge" operation describes the process of converting a map file written by the DreamMaker map editor to: | |||
# Use a format more amenable to Git's conflict resolution, called "TGM" and originally developed by Remie. The TGM map format is like the standard Dream Maker map format, but arranged differently, meaning Dream Maker is able to open TGM maps. | |||
# Keep the size of the difference between the old version and the new version of the map as small as possible. | |||
It requires an old version of the map to use as a reference and a new version of the map which contains the desired changes. | |||
Information on the tool's implementation is stored with [https://github.com/tgstation/tgstation/blob/master/tools/mapmerge2/ the code]. |
Версия от 03:39, 30 ноября 2020
/tg/station uses a tool called the Map Merger to make map changes easier for maintainers to review and less likely to conflict with map changes made by others.
There are two ways of running the tool, each requiring some amount of setup. If you have trouble or need help, ask in #coderbus.
Basic setup
- Install Python: If you don't already have Python installed, download and install the latest version.
Use as a Git hook (recommended)
- Install the hook: Windows users open the
tools/hooks
folder and double-clickinstall.bat
. Other platforms runtools/hooks/install.sh
.
Once the Git hook is installed, no further manual intervention is needed and the map merger will run automatically any time you commit in Git.
The dialog box or console output of the commit will show the map merger's log. You can check the git commit log to review changes, or run tools/mapmerge2/precommit.py
manually to review changes before committing.
Run manually (not recommended)
This is the older method, and is simpler but requires careful manual use each time you want to make changes to the map. First:
- Install dependencies: For Windows users, run
tools/mapmerge2/requirements-install.bat
. Non-Windows or advanced users can manually runpython -m pip install tools/mapmerge2/requirements.txt
.
Each time you want to edit a map, follow these steps:
- Prepare maps: Run
tools/mapmerge2/Prepare Maps.bat
to save a backup of all maps in their current state. - Make your changes: Don't forget to save.
- Exit DreamMaker: Optional, but ensures that you don't accidentally undo the map merger's work.
- Run the map merger: Run
tools/mapmerge2/mapmerge.bat
and select the map you edited to merge.
With this method, leaving the map open in DreamMaker or reviewing it after running the map merger makes it possible to accidentally save and overwrite the merged map with an unmerged map. Close DreamMaker entirely before manually running the map merger or be extra-careful not to overwrite the changes the map merger made.
What is map merging, actually?
The "map merge" operation describes the process of converting a map file written by the DreamMaker map editor to:
- Use a format more amenable to Git's conflict resolution, called "TGM" and originally developed by Remie. The TGM map format is like the standard Dream Maker map format, but arranged differently, meaning Dream Maker is able to open TGM maps.
- Keep the size of the difference between the old version and the new version of the map as small as possible.
It requires an old version of the map to use as a reference and a new version of the map which contains the desired changes.
Information on the tool's implementation is stored with the code.