tts_save
is a command-line tool for extracting
components from a Tabletop Simulator save file.
npm install -g tts_save
npm
is provided by Node.js.
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.json
This 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 out
tts_save (help|-h|--help) [command]
tts_save (version|-v|--version)
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.
-
--output=DIR
,-o DIR
Default:
.
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
,-a
A shortcut for
--scripts --xml --linked --notes --unbundle
. This is subject to being extended if/when new features are added. -
--scripts
,-s
Save the Lua script of every object into the
objs
subdirectory of the output directory.See
--unbundle
. -
--xml
,-x
Save the UI XML of every object into the
objs
subdirectory of the output directory.See
--unbundle
. -
--linked
,-l
Create 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_bundle
audio
image
model
pdf
The format may be extended in future versions of this tool.
-
--notes
,-n
Save the notebook entries into the
notes
subdirectory of the output directory. -
--unbundle
,-u
When used in conjunction with
--scripts
, included scripts (#include path
and#include <path>
) and required modules (require("path")
) will be extracted into thelib
subdirectory of the output directory.When used in conjunction with
--xml
, included XML files (<Include src="path"/>
) will be extracted into the same directory.
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
).
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 with the --linked
/-l
(or --all
/-a
) option.
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
(as an image, as an audio file, 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.
-
--output=DIR
,-o DIR
Default:
.
The directory into which
tts_save extract
placedlinked_resources.json
. The downloaded resources will be placed in theresources
subdirectory of this directory. -
--force
,-f
By default, this tool will check if a required file is in TTS's cache. If found, the file will be copied from the cache rather than downloaded. This options forces the download of files, even if they are found in TTS's cache.
-
--quiet
,-q
Suppress informational messages.
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.
Eric Brine <[email protected]>
.
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.