summaryrefslogtreecommitdiff
path: root/src/SMAPI/Framework
diff options
context:
space:
mode:
authorJesse Plamondon-Willard <github@jplamondonw.com>2018-08-18 23:00:01 -0400
committerJesse Plamondon-Willard <github@jplamondonw.com>2018-08-18 23:00:01 -0400
commitd918ceb224bd6ed8b428219ab28a436896a30b45 (patch)
treeb1856080c290be01e9eaa809f8f4b39fca69757b /src/SMAPI/Framework
parentf9eb16489fcf3f4c486df5f96a94edf16cf19a09 (diff)
downloadSMAPI-d918ceb224bd6ed8b428219ab28a436896a30b45.tar.gz
SMAPI-d918ceb224bd6ed8b428219ab28a436896a30b45.tar.bz2
SMAPI-d918ceb224bd6ed8b428219ab28a436896a30b45.zip
add IContentPack.WriteJsonFile method (#468)
Diffstat (limited to 'src/SMAPI/Framework')
-rw-r--r--src/SMAPI/Framework/ContentPack.cs10
1 files changed, 10 insertions, 0 deletions
diff --git a/src/SMAPI/Framework/ContentPack.cs b/src/SMAPI/Framework/ContentPack.cs
index 62d8b80d..ccb2b9a0 100644
--- a/src/SMAPI/Framework/ContentPack.cs
+++ b/src/SMAPI/Framework/ContentPack.cs
@@ -59,6 +59,16 @@ namespace StardewModdingAPI.Framework
: null;
}
+ /// <summary>Save data to a JSON file in the content pack's folder.</summary>
+ /// <typeparam name="TModel">The model type. This should be a plain class that has public properties for the data you want. The properties can be complex types.</typeparam>
+ /// <param name="path">The file path relative to the mod folder.</param>
+ /// <param name="data">The arbitrary data to save.</param>
+ public void WriteJsonFile<TModel>(string path, TModel data) where TModel : class
+ {
+ path = Path.Combine(this.DirectoryPath, PathUtilities.NormalisePathSeparators(path));
+ this.JsonHelper.WriteJsonFile(path, data);
+ }
+
/// <summary>Load content from the content pack folder (if not already cached), and return it. When loading a <c>.png</c> file, this must be called outside the game's draw loop.</summary>
/// <typeparam name="T">The expected data type. The main supported types are <see cref="Map"/>, <see cref="Texture2D"/>, and dictionaries; other types may be supported by the game's content pipeline.</typeparam>
/// <param name="key">The local path to a content file relative to the content pack folder.</param>