Released 15 October 2020.
- Added support for setting the default value for an
i18ntoken. - Fixed
i18ntoken not accepting named arguments. - Fixed error-handling for invalid
Includepatches. - Fixed errors using a dynamic token in some cases when it's set to the value of an immutable token like
{{HasMod |contains=X}}.
Released 13 September 2020.
ConfigSchemaoptions can now have an optionalDescriptionfield, which is shown in UIs like Generic Mod Config Menu.- Fixed
TextOperationsincorrectly adding delimiters when there's no previous value. - Fixed errors sometimes showing "ContentPatcher.Framework.Conditions.TokenString" instead of the intended value.
- Fixed error when using a field reference token as the only input to a token which requires input.
Released 13 September 2020.
- Fixed format issue when applying field edits to
Data\Achievements.
Released 12 September 2020. See the release highlights.
- Added content pack translation support using
i18nfiles. - Added text operations, which let you change a value instead of replacing it (e.g. append to a map's
Warpproperty). - You can now configure content packs in-game if you have Generic Mod Config Menu installed (thanks to a collaboration with spacechase0!). This works automatically for any content pack that has configuration options, no changes needed by mod authors.
- You can now edit fields via
EditDataforData\Achievementstoo. - Patches now update immediately when you change language.
- Fixed
EditDatapatches not always updated if they useFromFileto load a file containing tokens. - Fixed patches not always updated for a
Randomtoken reroll. - Fixed error text when an
EditDatapatch uses an invalid field index. - Removed support for
FromFileinEditDatapatches in newer format versions.
Update note for mod authors:
If you use the FromFile field with EditData patches, updating the Format field to 1.18.0 or
later requires changes to your content.json. See the
migration guide for more info.
Released 28 August 2020.
- Fixed patches not always updated if they depend on mod-provided tokens that incorrectly change outside a context update.
Released 19 August 2020.
- Made 'multiple patches want to load asset' errors more user-friendly.
- Fixed error in some cases when warping to a new location as a farmhand in multiplayer.
- Fixed error editing an image previously loaded through the Scale Up mod.
Released 16 August 2020. See the release highlights for mod authors.
- Patches can now optionally update on location change, including all tokens (not only location-specific tokens).
- Patches can now resize maps automatically using
Action: EditMap(just patch past the bottom or right edges). - Added
TargetPathOnlytoken (the target field value for the current patch, without the filename). - Added
patch reloadconsole command (thanks to spacechase0!). - Added troubleshooting hints related to update rate in
patch summaryconsole command. - Removed legacy token API obsolete since Content Patcher 1.12.
- Fixed ambiguous-method detection in advanced API.
- Internal changes to prepare for realtime content updates.
Update note for mod authors:
If you use the LocationName or IsOutdoors token/condition, updating the Format field to
1.17.0 or later requires changes to your content.json. See the
migration guide for more info.
Released 12 August 2020.
- Fixed 'collection was modified' error when unloading
Action: Includepatches.
Released 08 August 2020.
- Fixed incorrect token input validation in some cases with 1.16.2.
Released 08 August 2020.
- Fixed patches not always unapplied when an
Includepatch changes. - Fixed error using some tokens within the
containsinput argument. - Fixed broken error message when multiple load patches apply in 1.16.
Released 03 August 2020.
- Fixed some patches not applied correctly in 1.16.
Released 02 August 2020. See the release highlights for mod authors.
- Added an
Includeaction to load patches from another JSON file. That includes full token support, so you can load files dynamically or conditionally. - Randomization is now consistent between players, regardless of installed content packs.
- Content packs containing
nullpatches are no longer disabled; instead those patches are now skipped with a warning. - Improved performance when updating very large content packs.
- Fixed boolean/numeric fields rejecting tokens with surrounding whitespace like
" {{SomeToken}} ". - Fixed auto-generated patch names not normalising path separators.
- Fixed
patch summaryshowing duplicate target paths in some cases. - Fixed string sorting/comparison for some special characters.
- Internal changes to prepare for realtime content updates.
Update note for mod authors:
Using "Action": "EditData" with a FromFile field is now deprecated, though it still works.
Migrating to an "Action": "Include" patch is recommended; it's more flexible and works more
intuitively. (That doesn't apply to "Action": "EditData" patches without a FromFile field.)
Released 21 July 2020.
- Fixed error using
HasFilewith filenames containing commas. - Fixed broken patches preventing other patches from being applied/updated in rare cases.
- Internal changes to prepare for 1.16.
Released 06 July 2020.
- Fixed error loading pre-1.15 content packs that use a token with empty input arguments like
{{token:}}.
Released 04 July 2020. See the release highlights for mod authors.
- Added named token arguments.
- Added a universal
|contains=argument to search token values. - Added a universal
|inputSeparator=argument to allow commas in input values using a custom separator. - Added a
keyargument to{{Random}}. - Several player tokens now let you choose whether to check the host player, current player, or both.
- Added
HasConversationTopictoken. - Reduced trace logs when a mod adds many custom tokens.
- Fixed custom tokens added by other mods able to break Content Patcher in some cases.
- Fixed support for tokens in a
From/ToArea'sWidthandHeightfields. - Fixed support for tokens in a
.jsonfile loaded throughAction: EditDatawith aFromFilepath containing tokens. - Fixed format migrations not applied to tokens within JSON objects.
- Fixed multiple input arguments allowed for tokens that only recognize one (like
{{HasFile: fileA.png, fileB.png}}). Doing so now shows an error.
Update note for mod authors:
Updating the Format field to 1.15.0 or later requires changes to your content.json. See the migration guide for more info.
Released 14 May 2020.
- Fixed patches not updating correctly in 1.14 when a changed token is only in their
FromFilefield.
Released 02 May 2020. See the release highlights for mod authors.
- Added
Roundtoken. - Added
FromFilepatch token (e.g. so you can do"HasFile:{{FromFile}}": true). - The
patch exportcommand can now export assets that haven't been loaded yet. - Fixed
Rangetoken excluding its upper bound. - Fixed validation for
Targetfields containing{{Target}}and{{TargetWithoutPath}}tokens. - Fixed validation for
Targetfields not shown inpatch summaryin some cases. - Fixed 'file does not exist' error when the
FromFilepath is ready and doesn't exist, but the patch is disabled by a patch-specific condition. - Fixed error when removing a map tile without edits.
- Fixed token handling in map tile/property fields.
- Fixed format validation for 1.13 features not applied.
Released 09 March 2020. See the release highlights for mod authors.
- Added support for arithmetic expressions.
- Added support for editing map tiles.
- Added support for editing map tile properties.
- Added support for multi-key bindings (like
LeftShift + F3). EditMappatches now also copy layers and layer properties from the source map (thanks to mouse!).- Patches are now applied in the order listed more consistently.
- Improved logic for matching tilesheets when applying a map patch.
- Fixed incorrect warning when using
HasWalletItemtoken in 1.12.
Released 01 February 2020. See the release highlights for mod authors.
- Added advanced API to let other mods add more flexible tokens.
- Added support for mod-provided tokens in
EditDatafields. - Reduced trace logs when another mod adds a custom token.
- The
patch exportcommand now exports the asset cached by the game, instead of trying to load it. - Fixed dialogue and marriage dialogue changes not applied until the next day (via SMAPI 3.2).
- Fixed error when a data model patch uses an invalid token in its fields.
- Fixed whitespace between tokens being ignored (e.g.
{{season}} {{day}}now outputsSummer 14instead ofSummer14).
Released 27 December 2019.
- Mitigated
OutOfMemoryExceptionissue for some players. (The underlying issue in SMAPI is still being investigated.) - Reduced performance impact in some cases when warping with content packs which have a large number of seasonal changes.
- Fixed patches being reapplied unnecessarily in some cases.
- Fixed token validation not applied to the entire token string in some cases.
- Fixed
Randomtokens being rerolled when warping if the patch is location-dependent. - Fixed error when married to an NPC that's not loaded.
Released 15 December 2019. See the release highlights for mod authors.
- Added
LowercaseandUppercasetokens. Randomtokens can have 'pinned keys' to support many new scenarios (see readme).Randomtokens are now bounded for immutable choices (e.g. you can use them in numeric fields if all their choices are numeric).FromAreaandToAreafields can now use tokens (thanks to spacechase0!).- Optimized asset loading/editing a bit.
- Fixed warning when an
EditDatapatch references a file that doesn't exist when that's checked with aHasFilecondition. - Fixed
HasFiletoken being case-sensitive on Linux/Mac. - Fixed error if a content pack has a null patch.
Released 02 December 2019.
- Updated for Stardew Valley 1.4.0.1.
- Fixed error when an
EditDatapatch uses tokens inFromFilethat aren't available.
Released 26 November 2019. See the release highlights for mod authors.
- Updated for Stardew Valley 1.4, including new farm type.
- Added new tokens:
HavingChildandPregnant: check if an NPC/player is having a child.HasDialogueAnswer: the player's selected response IDs for question dialogues (thanks to mus-candidus!).IsJojaMartComplete: whether the player bought a Joja membership and completed all Joja bundles.Random: a random value from the given list.Range: a list of integers between the specified min/max values.
- Added support for editing map properties with
EditMappatches. - Added support for using
FromFilewithEditDatapatches. - Added
patch exportconsole command, which lets you see what an asset looks like with all changes applied. - Added
patch parseconsole command, which parses an arbitrary tokenizable string and shows the result. - Added new 'current changes' list for each content pack to
patch summaryoutput. - Added world state IDs to the
HasFlagtoken. - Added
manifest.jsonandcontent.jsonvalidator for content pack authors. - Content packs can now use mod-provided tokens without a dependency if the patch has an appropriate
HasModcondition. - Improved error if a content pack sets a
FromFilepath with invalid characters. - Fixed
HeartsandRelationshiptokens not working for unmet NPCs. They now return0andUnmetrespectively. - Fixed issue where dynamic tokens weren't correctly updated in some cases if they depend on another dynamic token whose conditions changed. (Thanks to kfahy!)
- Fixed
patch summarydisplay for mod-provided tokens which require an unbounded input. - Fixed
patch summarynot showing token input validation errors in some cases. - Fixed
NullReferenceExceptionin some cases with invalidEntrieskeys.
Released 25 July 2019.
- Fixed
Daytoken not allowing zero values. - Fixed dynamic tokens validated before they're ready.
- Fixed mod-provided tokens called with non-ready inputs in some cases.
- Fixed Linux/Mac players getting
HasFile-related errors in some cases.
Released 12 June 2019.
- Fixed error loading local XNB files in some cases with Content Patcher 1.9.
- Fixed mod-provided tokens being asked for values when they're marked non-ready.
Released 09 June 2019.
- Added API to let other mods create custom tokens and conditions.
- Fixed config parsing errors for some players.
- Fixed tokens not being validated consistently in some cases.
- Fixed a broken warning message.
Released 27 May 2019.
- Fixed some patches broken in Content Patcher 1.8.1.
- Fixed
EditMapworking with older format versions.
Released 26 May 2019.
- Improved
patch summary:- now tracks the reason a patch wasn't loaded (instead of showing a heuristic guess);
- added more info for local tokens;
- simplified some output.
- Improved errors when a local file doesn't exist.
- Fixed patch update bugs in Content Patcher 1.8.
Released 16 May 2019.
- Added new tokens:
IsOutdoors: whether the player is outdoors.LocationName: the name of the player's current location.Target: the target field value for the current patch.TargetWithoutPath: the target field value for the current patch (only the part after the last path separator).
- Added map patching.
- Added support for list assets in the upcoming Stardew Valley 1.4.
- Improved errors when token parsing fails.
- Fixed patches not applied in some cases.
- Fixed incorrect error message when
DefaultandAllowValuesconflict. - Fixed confusing errors when a content pack is broken and using an old format version.
Thanks to spacechase0 for contributions to support the new tokens!
Released 08 May 2019.
- Added new tokens:
HasReadLetter: whether the player has opened a given mail letter.HasValue: whether the input argument is non-blank, likeHasValue:{{spouse}}.IsCommunityCenterComplete: whether all bundles in the community center are completed.IsMainPlayer: whether the player is the main player.
- Tokens can now be nested (like
Hearts:{{spouse}}). - Tokens can now be used almost everywhere (including dynamic token values, condition values, and
Fieldskeys). - Tokens with multiple values can now be used as placeholders.
- Tokens from
config.jsoncan now be unrestricted (AllowValuesis now optional). - Improved input argument validation.
- Added support for new asset structures in the upcoming Stardew Valley 1.4.
- Fixed incorrect error text when dynamic/config tokens conflict.
- Fixed config schema issues logged as
Debuginstead ofWarning. - Removed support for the condition value subkey syntax (like
"Relationship": "Abigail:Married"instead of"Relationship:Abigail": "Married"). This only affects one content pack on Nexus.
Update note for mod authors:
Updating the Format field to 1.7.0 or later requires changes to your content.json. See the migration guide for more info.
Released 06 April 2019.
- Fixed
EditDataallowing field values containing/(which is the field delimiter). - Fixed error with upcoming SMAPI 3.0 changes.
- Fixed some broken maps in Stardew Valley 1.3.36 not detected.
- Fixed typo in some errors.
- Internal rewriting to support upcoming features.
Released 05 March 2019.
- Added detection for most custom maps broken by Stardew Valley 1.3.36 (they'll now be rejected instead of crashing the game).
Released 15 January 2019.
- Fixed some conditions not available for multiplayer farmhands after 1.6.2.
Released 04 January 2019.
- Conditions are now checked much sooner when loading a save, so early setup like map debris spawning can be affected conditionally.
- Fixed token subkey form not allowed in boolean fields.
- Updated for changes in the upcoming SMAPI 3.0.
Released 08 December 2018.
- Fixed error when a content pack has a patch with no
Targetfield. - Fixed some conditions using subkeys marked invalid incorrectly.
Released 08 December 2018.
- Added new tokens:
DaysPlayed: the number of in-game days played for the current save.HasWalletItem: the special items in the player wallet.SkillLevel: the player's level for a given skill.
- Added
Windvalue forWeathertoken. - Added support for matching subkey/value pairs like
"Relationship": "Abigail:Married, Marnie:Friend". - Added support for conditional map edits (via SMAPI 2.9).
- Added support for editing
Data\NPCDispositionsafter the NPC is already created (via SMAPI 2.9). - Improved performance for most content packs.
- Improved
patch summaryformat. - Updated for the upcoming SMAPI 3.0.
- Fixed language token always marked 'not valid in this context'.
- Fixed token strings not validated for format version compatibility.
- Fixed some 1.5 tokens not validated for format version compatibility.
Update note for mod authors:
Updating the Format field to 1.6.0 or later requires changes to your content.json. See the migration guide for more info.
Released 08 November 2018.
- Added
patch summaryhint ifTargetvalue incorrectly includes a file extension. - Migrated verbose logs to SMAPI's verbose logging feature.
- Fixed yet another error setting
EditDataentries tonullsince 1.5.
Released 29 September 2018.
- Improved
patch summaryoutput a bit. - Fixed another error setting
EditDataentries tonullsince 1.5.
Released 23 September 2018.
- Added token support in
EditDatakeys. - Fixed error setting
EditDataentries tonullsince 1.5. - Fixed error using tokens in
Enabledfield since 1.5.
Released 17 September 2018.
- Added support for dynamic tokens defined by the modder.
- Added new tokens:
FarmCave(the current farm cave type);FarmhouseUpgrade(the upgrade level for the main farmhouse);FarmName(the farm name);FarmType(the farm type likeStandardorWilderness);HasFile(whether a given file path exists in the content pack);HasProfession(whether the player has a given profession);PlayerGender(the player's gender);PlayerName(the player's name);PreferredPet(whether the player is a cat or dog person);Year(the year number).
- Added subkey form for all tokens, which can be used to enable AND logic and condition negation (see readme).
- Added: you can now use any condition with
Action: Loadpatches. - Added: you can now use tokens in
EditDataentries and fields. - Added: you can now list multiple values in the
Targetfield. - Added config tokens to
patch summary. - Added warning when a config field has
AllowValuesbut a patch checks for an unlisted value. - Removed some early warnings for issues like patch conflicts. That validation required a number of restrictions on how conditions and tokens could be used. Based on discussion with content pack modders, lifting those restrictions was more valuable than the early validation.
- Removed image preloading, which is no longer needed with SMAPI 2.8+.
- Fixed
patch summaryshowing tokens that aren't valid in the current context.
Released 26 August 2018.
- Updated for Stardew Valley 1.3.29.
- Fixed broken error message.
Released 01 August 2018.
- Updated for Stardew Valley 1.3 (including multiplayer support).
- Added new tokens:
DayEvent(the festival name or wedding today);HasFlag(the letters or flags set for the current player);HasMod(the installed mods and content packs);HasSeenEvent(the events seen by the current player);Hearts:<NPC>(the relationship type for a given NPC);Relationship:<NPC>(the relationship type for a given NPC);Spouse(the player's spouse name);
- Added support for deleting entries via
EditData. - Added warnings for common mistakes in
patch summaryresult. - Fixed case sensitivity issues in some cases.
Released 08 April 2018.
- Added more detailed info to
patch summarycommand. - Improved error handling for image edits.
- Fixed unnecessary warnings when a patch is disabled.
- Fixed error when a content pack's
config.jsonhas invalid keys.
Released 26 March 2018.
- Added support for patch conditions (with initial support for season, day of month, day of week, and language).
- Added support for content packs having
config.json. - Added support for condition/config tokens in
content.json. - Added
patch summaryandpatch updatecommands to simplify troubleshooting. - Added trace logs when a content pack loads/edits an asset.
- Added optional verbose logs.
- Added unique patch names (editable via
LogNamefield) to simplify troubleshooting. - Improved error when a patch specifies an invalid source/target area.
- Fixed issue where an exception in one patch prevented other patches from being applied.
- Fixed
Targetnot being normalized. - Fixed errors using debug overlay on Linux/Mac.
Released 09 March 2018.
- Added support for overlaying images.
- Added optional debug mode for modders.
FromFile,Target, and map tilesheets are now case-insensitive.- Fixed null fields not being ignored after warning.
Released 02 March 2018.
- Added
Enabledfield to disable individual patches (thanks to f4iTh!). - Added support for XNB files in
FromFile. - Added support for maps in
FromFilewhich reference unpacked PNG tilesheets.
Released 25 February 2018.
- Initial release.
- Added support for replacing assets, editing images, and editing data files.
- Added support for extending spritesheets.
- Added support for locale-specific changes.