yukatool
yukatool copied to clipboard
A collection of tools for the "Yuka System" visual novel engine
What is this?
"Yuka System" is a visual novel engine used by a few companies such as HookSoft, Smee, PeasSoft and feng.
Unfortunately little to no information about the engine (and therefore no documentation) is publicly available, so I took a few weeks to carefully analyze the game archives.
Why? Because we (Rabu Rabu Translations) are currently working on a fan-tl of the game "Lover Able" by Smee: http://raburabu.net/projects/lover-able/progress/
I've attached my notes on the file formats and some general information I've gathered in the doc/ folder.
What does it do?
Yukatool aims to be the all in one solution for everything neccessary to properly work with the engine.
This includes features to deal with the three main components: archives, graphics and scripts.
At this point, the following operations (tasks) are supported:
helpDisplays a list of available commandsunpackUnpacks a yuka archive (.ykc) to a directory treepackPacks a directory tree into a yuka archive (.ykc)patchCopies all files from one archive to anothersplitSplits a binary yuka script (.yks) into it's main sectors (code, index, data) and generates a comprehensible breakdown of the former two.decompileDecompiles a binary yuka script into a yuka source file (.ykd) and an optional string table (.csv). Works on entire directory treescompileCompiles a yuka source file (.ykd) and an optional string table (.csv) into a binary yuka script (.yks). Works on entire directory treesunwrapConverts a yuka graphics file (.ykg) to png and optional meta information (.meta)wrapConverts a png file and optional meta information (.meta) to a yuka graphics file (.ykg)
The following tasks are planned for future versions:
disassembleUnpacks a yuka archive and automatically decompiles all scripts / unwraps all graphicsassemblePacks a directory tree into a yuka archive and automatically compiles all scripts / wraps all graphics
How do I use it?
Yukatool is completely command-line operated. The basic syntax is as follows:
yuka.exe [flags] <task> <arguments...>
Flags do not have to be at the beginning and can be specified in a long or short form:
-rvw adds the flags --raw, --verbose and --wait
Which flags are available depends on the task you want to execute.
If you need technical support, want to contribute or have any other questions regarding the project, feel free to contact me at [email protected] :)