Add support for embedded resources and add strings

This commit is contained in:
Norbi Peti 2020-11-19 00:24:52 +01:00
parent 53fc61da14
commit ae8fd9f7d5
4 changed files with 1215 additions and 22 deletions

2
.gitignore vendored
View file

@ -3,3 +3,5 @@ obj/
/packages/
riderModule.iml
/_ReSharper.Caches/
.idea/
/Localization.sln.DotSettings.user

View file

@ -2,6 +2,7 @@
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Reflection;
using GamecraftModdingAPI;
using GamecraftModdingAPI.App;
using GamecraftModdingAPI.Commands;
@ -18,6 +19,7 @@ namespace Localization
{
private readonly DirectoryInfo _pluginFolder = new DirectoryInfo(Path.Combine("Plugins", "Localization"));
private Dictionary<string, string> _origStrings;
private readonly string[] _embeddedLanguages = Assembly.GetExecutingAssembly().GetManifestResourceNames();
public override void OnApplicationStart()
{
@ -60,31 +62,30 @@ namespace Localization
.Action(() =>
{
Logging.CommandLog(new[] {"en"}.Concat(_pluginFolder.EnumerateFiles()
.Where(file => file.Extension == ".json" && file.Name.Length < 8)
.Select(file => file.Name.Replace(file.Extension, ""))).Distinct()
.Aggregate((a, b) => a + ", " + b));
.Where(file => file.Extension == ".json"
&& (file.Name.Length < 8 || file.Name.Contains("-")))
.Select(file => file.Name.Replace(file.Extension, "")))
.Concat(_embeddedLanguages)
.Select(lang => lang.Replace("Localization.", "").Replace(".json", ""))
.Distinct().Aggregate((a, b) => a + ", " + b));
}).Build();
CommandBuilder.Builder("DumpLangStrings", "Dumps the current strings. Set language to en-us first.")
CommandBuilder.Builder("DumpLangStrings", "Dumps the current strings. Set language to en first.")
.Action(() =>
{
File.WriteAllText(Path.Combine(_pluginFolder.FullName, "dumped.json"),
JsonConvert.SerializeObject(_origStrings, Formatting.Indented));
}).Build();
if (!settings.ContainsKey("autoload") || (bool) settings["autoload"])
if (!settings.ContainsKey("autoload"))
{
settings["autoload"] = true;
using (var stream = new JsonTextWriter(new StreamWriter(File.OpenWrite(settingsPath))))
settings.WriteTo(stream);
}
if ((bool) settings["autoload"])
Client.EnterMenu += TryLoadSteamLanguageMenuEnterEvent;
}
else
{
settings["autoload"] = false;
using (var stream = new JsonTextWriter(new StreamWriter(File.OpenWrite(settingsPath))))
settings.WriteTo(stream);
}
}
public override void OnApplicationQuit()
{
@ -97,6 +98,10 @@ namespace Localization
LoadOriginalStrings();
string langPath = Path.Combine(_pluginFolder.FullName, lang + ".json");
if (!File.Exists(langPath))
{
if (_embeddedLanguages.Contains("Localization." + lang + ".json"))
langPath = null;
else
{
if (lang == "en")
{
@ -106,11 +111,28 @@ namespace Localization
Logging.CommandLog("Strings reset to default. (" + _origStrings.Count + " strings in total)");
return;
}
Logging.CommandLogError("Could not find json file!");
return;
}
}
var strings = JsonConvert.DeserializeObject<Dictionary<string, string>>(File.ReadAllText(langPath));
string jsonText = langPath != null ? File.ReadAllText(langPath) : null;
if (jsonText == null)
{
var stream = Assembly.GetExecutingAssembly()
.GetManifestResourceStream("Localization." + lang + ".json");
if (stream != null)
using (var st = new StreamReader(stream))
jsonText = st.ReadToEnd();
else
{
Logging.CommandLogError("Failed to load embedded translation for " + lang);
return;
}
}
var strings = JsonConvert.DeserializeObject<Dictionary<string, string>>(jsonText);
foreach (var kv in strings)
{
if (!_origStrings.Remove(kv.Key))

View file

@ -0,0 +1,4 @@
<?xml version="1.0" encoding="utf-8"?>
<packages>
<package id="Lib.Harmony" version="2.0.2" targetFramework="net48" />
</packages>

1165
dumped.json Normal file

File diff suppressed because it is too large Load diff