diff options
author | Jesse Plamondon-Willard <github@jplamondonw.com> | 2017-10-07 20:16:04 -0400 |
---|---|---|
committer | Jesse Plamondon-Willard <github@jplamondonw.com> | 2017-10-07 20:16:04 -0400 |
commit | 4d32b37790442b8f19379ac89e72f0ecb161b549 (patch) | |
tree | 1c6c234ab0e247b1c975a8b375eb388793a53d67 /build/smapi.targets | |
parent | 78e59e1a48e6d9d2583c9adf54422d15e6e7074e (diff) | |
download | SMAPI-4d32b37790442b8f19379ac89e72f0ecb161b549.tar.gz SMAPI-4d32b37790442b8f19379ac89e72f0ecb161b549.tar.bz2 SMAPI-4d32b37790442b8f19379ac89e72f0ecb161b549.zip |
switch create-zip task to class type to simplify encapsulation
Diffstat (limited to 'build/smapi.targets')
-rw-r--r-- | build/smapi.targets | 138 |
1 files changed, 83 insertions, 55 deletions
diff --git a/build/smapi.targets b/build/smapi.targets index 88408994..3512d042 100644 --- a/build/smapi.targets +++ b/build/smapi.targets @@ -1,6 +1,6 @@ <Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> <!--********************************************* - ** Define build tasks used below + ** Define build tasks **********************************************--> <!--###### ## create a release zip file for a mod (CodeTaskFactory only available on Windows?) @@ -15,69 +15,97 @@ <Reference Include="System.IO" /> <Reference Include="System.IO.Compression" /> <Reference Include="System.Web.Extensions"/> - <Using Namespace="System.IO" /> - <Using Namespace="System.IO.Compression" /> - <Using Namespace="System.Web.Script.Serialization"/> - <Code Type="Fragment" Language="cs"> + <Code Type="Class" Language="cs"> <![CDATA[ - try + using System; + using System.Collections.Generic; + using System.IO; + using System.IO.Compression; + using System.Web.Script.Serialization; + using Microsoft.Build.Framework; + using Microsoft.Build.Utilities; + + /// <summary>A build task which packs mod files into a conventional release zip.</summary> + public class CreateModReleaseZip : Task, ITask { - // create output path if needed - Directory.CreateDirectory(OutputFolderPath); + /********* + ** Accessors + *********/ + /// <summary>The mod files to pack.</summary> + public ITaskItem[] Files { get; set; } - // Get the file JSON string - string json = ""; - foreach(ITaskItem file in Files) - { - if(Path.GetFileName(file.ItemSpec).ToLower() != "manifest.json") - continue; - json = File.ReadAllText(file.ItemSpec); - break; - } - - // Serialize the manifest json into a data object, then get a version object from that. - IDictionary<string, object> data = (IDictionary<string, object>)new JavaScriptSerializer().DeserializeObject(json); - IDictionary<string, object> version = (IDictionary<string, object>)data["Version"]; - - // Store our version numbers for ease of use - int major = (int)version["MajorVersion"]; - int minor = (int)version["MinorVersion"]; - int patch = (int)version["PatchVersion"]; - - string fileName = String.Format("{0}-{1}.{2}.{3}.zip", ModName, major, minor, patch); - - // clear old zip file if present - string zipPath = Path.Combine(OutputFolderPath, fileName); - if (File.Exists(zipPath)) - File.Delete(zipPath); - - // create zip file - using (Stream zipStream = new FileStream(zipPath, FileMode.Create, FileAccess.Write)) - using (ZipArchive archive = new ZipArchive(zipStream, ZipArchiveMode.Create)) + /// <summary>The name of the mod.</param> + public string ModName { get; set; } + + /// <summary>The absolute or relative path to the folder which should contain the generated zip file.</summary> + public string OutputFolderPath { get; set; } + + + /********* + ** Public methods + *********/ + public override bool Execute() { - foreach (ITaskItem file in Files) + try { - // get file info - string filePath = file.ItemSpec; - string entryName = ModName + '/' + file.GetMetadata("RecursiveDir") + file.GetMetadata("Filename") + file.GetMetadata("Extension"); - if (new FileInfo(filePath).Directory.Name.Equals("i18n", StringComparison.InvariantCultureIgnoreCase)) - entryName = Path.Combine("i18n", entryName); - - // add to zip - using (Stream fileStream = new FileStream(filePath, FileMode.Open, FileAccess.Read)) - using (Stream fileStreamInZip = archive.CreateEntry(entryName).Open()) + // create output path if needed + Directory.CreateDirectory(OutputFolderPath); + + // Get the file JSON string + string json = ""; + foreach(ITaskItem file in Files) + { + if(Path.GetFileName(file.ItemSpec).ToLower() != "manifest.json") + continue; + json = File.ReadAllText(file.ItemSpec); + break; + } + + // Serialize the manifest json into a data object, then get a version object from that. + IDictionary<string, object> data = (IDictionary<string, object>)new JavaScriptSerializer().DeserializeObject(json); + IDictionary<string, object> version = (IDictionary<string, object>)data["Version"]; + + // Store our version numbers for ease of use + int major = (int)version["MajorVersion"]; + int minor = (int)version["MinorVersion"]; + int patch = (int)version["PatchVersion"]; + + string fileName = String.Format("{0}-{1}.{2}.{3}.zip", ModName, major, minor, patch); + + // clear old zip file if present + string zipPath = Path.Combine(OutputFolderPath, fileName); + if (File.Exists(zipPath)) + File.Delete(zipPath); + + // create zip file + using (Stream zipStream = new FileStream(zipPath, FileMode.Create, FileAccess.Write)) + using (ZipArchive archive = new ZipArchive(zipStream, ZipArchiveMode.Create)) { - fileStream.CopyTo(fileStreamInZip); + foreach (ITaskItem file in Files) + { + // get file info + string filePath = file.ItemSpec; + string entryName = ModName + '/' + file.GetMetadata("RecursiveDir") + file.GetMetadata("Filename") + file.GetMetadata("Extension"); + if (new FileInfo(filePath).Directory.Name.Equals("i18n", StringComparison.InvariantCultureIgnoreCase)) + entryName = Path.Combine("i18n", entryName); + + // add to zip + using (Stream fileStream = new FileStream(filePath, FileMode.Open, FileAccess.Read)) + using (Stream fileStreamInZip = archive.CreateEntry(entryName).Open()) + { + fileStream.CopyTo(fileStreamInZip); + } + } } + + return true; + } + catch (Exception ex) + { + Log.LogErrorFromException(ex); + return false; } } - - return true; - } - catch (Exception ex) - { - Log.LogErrorFromException(ex); - return false; } ]]> </Code> |