tts_save v1.2.0
TTS Save File Tools
tts_save is a command-line tool for extracting
components from a Tabletop Simulator save file.
Installation
npm install -g tts_savenpm is provided by Node.js.
Synopsis
To extract all components of TS_Save_000.json into the
out subdirectory, use the following command:
tts_save extract -a -o out TS_Save_000.jsonThis works whether TS_Save_000.json is found in the current
directory or in TTS's Saves directory.
Once the above command has been executed, you can use the following command to download the resources referenced by the save file:
tts_save download -o outUsage
Command: help
tts_save (help|-h|--help) [command]Command: version
tts_save (version|-v|--version)Command: extract
Extract components from a Tabletop Simulator save file.
tts_save extract (-h|--help)
tts_save extract [options] [--] [TS_Save_000.json]From the specified file, this tool will extract the components indicated by the provided options. By default, nothing is extracted.
If no file is specified, the tool will read from stdin.
If a file name or relative path is provided, the tool will first look in the current work directory. If it fails to find the named file there, it will then look in Tabletop Simulator's "Saves" folder.
Options:
--output=DIR,-o DIRDefault:
.The directory into which the extracted components should be placed. This directory need not exist. If it does, existing files within the directory won't be deleted. They may, however, be overwritten.
--all,-aA shortcut for
--scripts --xml --linked --notes --unbundle. This is subject to being extended if/when new features are added.--scripts,-sSave the Lua script of every object into the
objssubdirectory of the output directory.See
--unbundle.--xml,-xSave the UI XML of every object into the
objssubdirectory of the output directory.See
--unbundle.--linked,-lCreate a list of all the linked resources (e.g. images and object models). This list is saved in
linked_resources.json, which has the following format:{ "resources": [ { "url": "http://...", "type": "image" }, ... ] }The following are the possible values for
type:asset_bundleaudioimagemodelpdfThe format may be extended in future versions of this tool.
--notes,-nSave the notebook entries into the
notessubdirectory of the output directory.--unbundle,-uWhen used in conjunction with
--scripts, included scripts (#include pathand#include <path>) and required modules (require("path")) will be extracted into thelibsubdirectory of the output directory.When used in conjunction with
--xml, included XML files (<Include src="path"/>) will be extracted into the same directory.
Accuracy, Conflicts and Safety
The extracted scripts and modules and XML should be byte-for-byte equivalent with the original files, with the following exceptions:
- Line endings will be normalized for the current platform (CRLF on Windows, LF elsewhere).
- Non-empty files that do not end with a line ending will be given one.
It is possible for multiple objects to have the same GUID. The tool handles this situation gracefully. Similarly, the tool handles notebook entries with the same title gracefully.
The tool avoids using a few particularly dangerous characters in the names of files it creates. While this could result in a file that's named differently than the directive used to include it, you should never encounter this in practice.
On the flip side, you could end up with very oddly-named files in the event of
a maliciously-created save file. The name of files could even contain shell
metacharacters. However, the tool constrains its output to the specified
directory, even when provided a maliciously-crafted save file (e.g. one that
includes a file named ../../etc/passwd).
Command: download
Download the resources referenced by a Tabletop Simulator save file.
tts_save download (-h|--help)
tts_save download [options] [--]This command expects tts_save extract to have previously been run.
It uses the produced linked_resources.json file to determine
which files to download and what names to give those files.
The name of a downloaded file is based on how it's used in TTS
(image, audio, etc). An attempt is made to provide the file
with the correct extension based on its file type (e.g. .png
for PNG images, .jpg for JPEG images, etc).
As files are downloaded, linked_resources.json is updated to
include the file name associated with the downloaded resources.
Options:
--output=DIR,-o DIRDefault:
.The directory into which
tts_save extractplacedlinked_resources.json. The downloaded resources will be placed in theresourcessubdirectory of this directory.--force,-fBy default, this tool will check if a required file is in TTS's cache. If found, the cached file will copied rather than downloaded. This options forces the download of files, even if they are found in TTS's cache.
--quiet,-qSuppress informational messages.
Support
You may contact the author directly.
Bugs and improvements can be reported using GitHub's issue tracker at https://github.com/ikegami/tts_save/issues.
Repository
Author
Eric Brine <ikegami@adaelis.com>.
Copyright and License
No rights reserved.
The author has dedicated the work to the Commons by waiving all of his or her rights to the work worldwide under copyright law and all related or neighboring legal rights he or she had in the work, to the extent allowable by law.
Works under CC0 do not require attribution. When citing the work, you should not imply endorsement by the author.