Skip to main content

Tool to enable a more concise and thematically structured creation of mods for Crusader Kings 2

Project description

Suvorov: Expanded scripting language for CK2

Suvorov allows you to write CK2 modifications in a more concise and organized fashion, grouping features together according to your own file structure instead of splitting each individual feature up over a multitude of folders. For example, if you have an event that fires on a specific action and adds a character modifier, you can group the on_action, the event and the modifier together in the same file. If you add a new province, you can define its history, titles, holder character etc in the same file. If you create a trait that unlocks an associated targetted decision as well as a maintenance event to fire for all trait holders, there is no need to pollute three different subfolders. This way, mods are more maintainable and adding or removing features doesn't mean you have to go through several different files.

Install and use

Install with pip install suvorov. Make sure to use pip3 if Python 3 isn't your default version.

You can now create new mods in the folder suvorovmods in your CK2 user directory.

Call the command suvorov build (modfoldername) to prepare the mod so that CK2 can read it. Call suvorov build without any arguments to build all your mods.

Mod structure

In a suvorov mod, you can add any files according to the vanilla structure (e.g. gfx, interface, common) in the pdx subfolder. For new, suvorov-style files, you can follow any folder structure you like (except the pdx folder of course). So your mod could look like this:

mymod
├ pdx
| ├ gfx
| | └ trait.png
| └ localisation
|   └ texts.csv
├ crusade_changes
|  ├ crusade_start.txt
|  └ crusade_end.txt
├ various.txt
└ modinfo.yml

Specify your mod metadata (name, picture, esc.) in modinfo.yml in the root of your folder directory.

New Syntax

Path-independent definitions

These new files with the ending .txt or .suv accept a syntax like vanilla files, only with an enclosing scope defining their type, e.g.:

events = {
	namespace = mymod

	character_event = {
		id = mymod.1
		is_triggered_only = yes

		option = {
			name = mymod.eventoption.1
			add_trait = patient
			remove_trait = cynical
			remove_trait = arbitrary
		}
	}
}

on_actions = {
	on_crusade_preparation_starts = {
		events = {
			mymod.1
		}
	}
}

Templating

In case of .suv files, you can also use some basic templating:

events = {
	namespace = mymod

	character_event = {
		id = mymod.2
		is_triggered_only = yes

		@forin = {
			@for = choice
			@in = choices
			option = {
				name = $$choice.name
				change_$$choice.attribute = 2
			}
		}
	}
}

The data source for these can be defined over any number of .yaml files in your mod under the top key data, like this:

data:
   choices:
   - name: "Use the dagger"
     attribute: "intrigue"
   - name: "Use the quill"
     attribute: "diplomacy"

Inline localisation

.suv files allow you to localize things directly in their definition file - if you don't care about multilingual support, this is a nice way to further lower the amount of files and to keep things together:

traits = {
	idol = {
		@loc = "Idol"
		@loc_desc = "This character is a K-Pop Idol."
		sex_appeal_opinion = 70
		intrigue = 1
	}
}

events = {
	character_event = {
		id = 31
		desc = @loc:"Your sister wants to become a K-Pop idol."

		option = {
			name = @loc:"Nice"
			FROM = { add_trait = idol }
		}
	}

}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

suvorov-1.0.2.tar.gz (12.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

suvorov-1.0.2-py3-none-any.whl (27.5 kB view details)

Uploaded Python 3

File details

Details for the file suvorov-1.0.2.tar.gz.

File metadata

  • Download URL: suvorov-1.0.2.tar.gz
  • Upload date:
  • Size: 12.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.9

File hashes

Hashes for suvorov-1.0.2.tar.gz
Algorithm Hash digest
SHA256 f07cdf850d37c1b9bd3f427db0b2502f21fc0f67dc5c4931235c920c5cd9b91c
MD5 58d68edf1663f2b6d20437fcde7eeb9e
BLAKE2b-256 d3edf08ad79ce2c21e68ba75675664761e3e14c3da9979f7691ea6a4e155ca05

See more details on using hashes here.

File details

Details for the file suvorov-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: suvorov-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 27.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.9

File hashes

Hashes for suvorov-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 fc20f8b0e3ddd61a6af315dc9bbd8d5a674d373ed47c359b41925adfa33a2ce0
MD5 25c7961162d9d51d244410595e8a3922
BLAKE2b-256 e21051d673a1a1a2eae13704aa132e79a5786223a4845e0a98b61a0448adfc57

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page