From 767cdc1f6f6a63ce997fc9476911e2c361f9d402 Mon Sep 17 00:00:00 2001 From: LukePulverenti Date: Wed, 20 Feb 2013 20:33:05 -0500 Subject: Pushing missing changes --- .../Localization/LocalizedStrings.cs | 155 +++++++++++++++++++++ 1 file changed, 155 insertions(+) create mode 100644 MediaBrowser.Controller/Localization/LocalizedStrings.cs (limited to 'MediaBrowser.Controller/Localization/LocalizedStrings.cs') diff --git a/MediaBrowser.Controller/Localization/LocalizedStrings.cs b/MediaBrowser.Controller/Localization/LocalizedStrings.cs new file mode 100644 index 000000000..b7e66f095 --- /dev/null +++ b/MediaBrowser.Controller/Localization/LocalizedStrings.cs @@ -0,0 +1,155 @@ +using MediaBrowser.Common.Localization; +using MediaBrowser.Common.Logging; +using System; +using System.Collections.Concurrent; +using System.Globalization; +using System.IO; +using System.Linq; +using System.Reflection; +using System.Xml.Serialization; + +namespace MediaBrowser.Controller.Localization +{ + /// + /// Class LocalizedStrings + /// + public class LocalizedStrings + { + /// + /// The base prefix + /// + public const string BasePrefix = "base-"; + /// + /// The local strings + /// + protected ConcurrentDictionary LocalStrings = new ConcurrentDictionary(); + /// + /// The _instance + /// + private static LocalizedStrings _instance; + + /// + /// Gets the instance. + /// + /// The instance. + public static LocalizedStrings Instance { get { return _instance ?? (_instance = new LocalizedStrings()); } } + + /// + /// Initializes a new instance of the class. + /// + public LocalizedStrings() + { + foreach (var stringObject in Kernel.Instance.StringFiles) + { + AddStringData(LoadFromFile(GetFileName(stringObject),stringObject.GetType())); + } + } + + /// + /// Gets the name of the file. + /// + /// The string object. + /// System.String. + protected string GetFileName(LocalizedStringData stringObject) + { + var path = Kernel.Instance.ApplicationPaths.LocalizationPath; + var name = Path.Combine(path, stringObject.Prefix + "strings-" + CultureInfo.CurrentCulture + ".xml"); + if (File.Exists(name)) + { + return name; + } + + name = Path.Combine(path, stringObject.Prefix + "strings-" + CultureInfo.CurrentCulture.Parent + ".xml"); + if (File.Exists(name)) + { + return name; + } + + //just return default + return Path.Combine(path, stringObject.Prefix + "strings-en.xml"); + } + + /// + /// Loads from file. + /// + /// The file. + /// The t. + /// LocalizedStringData. + protected LocalizedStringData LoadFromFile(string file, Type t) + { + var xs = new XmlSerializer(t); + var strings = (LocalizedStringData)Activator.CreateInstance(t); + strings.FileName = file; + Logger.LogInfo("Using String Data from {0}", file); + if (File.Exists(file)) + { + using (var fs = new FileStream(file, FileMode.Open, FileAccess.Read)) + { + strings = (LocalizedStringData)xs.Deserialize(fs); + } + } + else + { + strings.Save(); //brand new - save it + } + + if (strings.ThisVersion != strings.Version && file.ToLower().Contains("-en.xml")) + { + //only re-save the english version as that is the one defined internally + strings = new BaseStrings {FileName = file}; + strings.Save(); + } + return strings; + + } + + /// + /// Adds the string data. + /// + /// The string data. + public void AddStringData(object stringData ) + { + //translate our object definition into a dictionary for lookups + // and a reverse dictionary so we can lookup keys by value + foreach (var field in stringData.GetType().GetFields().Where(f => f != null && f.FieldType == typeof(string))) + { + string value; + + try + { + value = field.GetValue(stringData) as string; + } + catch (TargetException ex) + { + Logger.LogException("Error getting value for field: {0}", ex, field.Name); + continue; + } + catch (FieldAccessException ex) + { + Logger.LogException("Error getting value for field: {0}", ex, field.Name); + continue; + } + catch (NotSupportedException ex) + { + Logger.LogException("Error getting value for field: {0}", ex, field.Name); + continue; + } + + LocalStrings.TryAdd(field.Name, value); + } + } + + /// + /// Gets the string. + /// + /// The key. + /// System.String. + public string GetString(string key) + { + string value; + + LocalStrings.TryGetValue(key, out value); + return value; + } + } +} -- cgit v1.2.3