A project to extend Skyrim's Papyrus scripting with JSON formatted serializable data structures.
Important
This project is fork of the original JContainers. It strives to convert and mash it up to the new Skyrim Special 64-bit edition. Cudos to the original author and all of his supporters!
If you are programmer, sooner or later you'll notice the lack of many useful features in Papyrus. There is no way to:
- Append or erase values from arrays
- Put an array into an array (i.e. no nested arrays)
- Put multiple value types into a single array
- Have associative containers
- Be able to load or save a data into a file
Since there is no source code of the Papyrus virtual machine, it is tricky and no easy to extend the existing Papyrus Array type or add new data structure types. JContainers implements from scratch its own data structures, garbage collector and other infernals. Features offered:
- Data structures: arrays and associative containers (a.k.a. maps or dictionaries)
- Import and export data to and from JSON files
- Embedded, lightweight scripting with Lua
- Interaction with JContainers via C++ interface.
Sure! Feel free to do whatever you think is good - post feature requests, report bugs, improve Wiki or source code.
- Microsoft Visual Studio 2017 Community Edition with Visual C++ support would suffice. All project files are of that version, but with a bit of manual work they may be converted to older versions too (e.g. 2013, though issues most certainly will arrise).
- A Python environment for Windows, version 3.4 or later.
This is needed to run some helper scripts for testing, building distributions and any other small
helpful tasks. Its
python.exe
should be available on the PATH variable. - The GIT revisioning system and/or GitHub account may help if you want to contribute or work more easily with the public repository of this project.
- Run
git submodule update --init --recursive
so that all dependencies like Jannson, Google Test and etc. get downloaded and linked to the correct revisions. - Run the JContainer's
tools\build_boost.bat
file. It should manage to download, unpack, bootstrap and build the neccessary libraries from Boost (version 1.66 currently). - Run also the
tools\merge_skse.bat
file. It should extract the stripped down and bundled SKSE64 distribution into the local source tree. - Open the
JContainers.sln
file with Visual Studio and Rebuild the whole solution. It will take some time. - After successfull build, run from the command line
python tools\install.py x64\Release
. Eventually swapRelease
forDebug
- depending on what kind of distribution was build and actually is wanted in thedist\
folder. - Optionaly, run
python tools\test.py x64\Release\Data\SKSE\Plugins\JContainers64.dll
. Again it depends whetherRelease
orDebug
builds should be tested. Note however that step 4, must be ran first!
That's it!