LanguageSourceData_Import_CSV.cs 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253
  1. using System;
  2. using System.Collections.Generic;
  3. using UnityEngine;
  4. namespace I2.Loc
  5. {
  6. public partial class LanguageSourceData
  7. {
  8. public string Import_CSV( string Category, string CSVstring, eSpreadsheetUpdateMode UpdateMode = eSpreadsheetUpdateMode.Replace, char Separator = ',' )
  9. {
  10. List<string[]> CSV = LocalizationReader.ReadCSV (CSVstring, Separator);
  11. return Import_CSV( Category, CSV, UpdateMode );
  12. }
  13. public string Import_I2CSV( string Category, string I2CSVstring, eSpreadsheetUpdateMode UpdateMode = eSpreadsheetUpdateMode.Replace )
  14. {
  15. List<string[]> CSV = LocalizationReader.ReadI2CSV (I2CSVstring);
  16. return Import_CSV( Category, CSV, UpdateMode );
  17. }
  18. public string Import_CSV( string Category, List<string[]> CSV, eSpreadsheetUpdateMode UpdateMode = eSpreadsheetUpdateMode.Replace )
  19. {
  20. string[] Tokens = CSV[0];
  21. int LanguagesStartIdx = 1;
  22. int TypeColumnIdx = -1;
  23. int DescColumnIdx = -1;
  24. var ValidColumnName_Key = new[]{ "Key" };
  25. var ValidColumnName_Type = new[]{ "Type" };
  26. var ValidColumnName_Desc = new[]{ "Desc", "Description" };
  27. if (Tokens.Length>1 && ArrayContains(Tokens[0], ValidColumnName_Key))
  28. {
  29. if (UpdateMode == eSpreadsheetUpdateMode.Replace)
  30. ClearAllData();
  31. if (Tokens.Length>2)
  32. {
  33. if (ArrayContains(Tokens[1], ValidColumnName_Type))
  34. {
  35. TypeColumnIdx = 1;
  36. LanguagesStartIdx = 2;
  37. }
  38. if (ArrayContains(Tokens[1], ValidColumnName_Desc))
  39. {
  40. DescColumnIdx = 1;
  41. LanguagesStartIdx = 2;
  42. }
  43. }
  44. if (Tokens.Length>3)
  45. {
  46. if (ArrayContains(Tokens[2], ValidColumnName_Type))
  47. {
  48. TypeColumnIdx = 2;
  49. LanguagesStartIdx = 3;
  50. }
  51. if (ArrayContains(Tokens[2], ValidColumnName_Desc))
  52. {
  53. DescColumnIdx = 2;
  54. LanguagesStartIdx = 3;
  55. }
  56. }
  57. }
  58. else
  59. return "Bad Spreadsheet Format.\nFirst columns should be 'Key', 'Type' and 'Desc'";
  60. int nLanguages = Mathf.Max (Tokens.Length-LanguagesStartIdx, 0);
  61. int[] LanIndices = new int[nLanguages];
  62. for (int i=0; i<nLanguages; ++i)
  63. {
  64. if (string.IsNullOrEmpty(Tokens[i+LanguagesStartIdx]))
  65. {
  66. LanIndices [i] = -1;
  67. continue;
  68. }
  69. string langToken = Tokens[i + LanguagesStartIdx];
  70. string LanName, LanCode;
  71. bool isLangEnabled = true;
  72. if (langToken.StartsWith("$", StringComparison.Ordinal))
  73. {
  74. isLangEnabled = false;
  75. langToken = langToken.Substring(1);
  76. }
  77. GoogleLanguages.UnPackCodeFromLanguageName(langToken, out LanName, out LanCode);
  78. int LanIdx = -1;
  79. if (!string.IsNullOrEmpty(LanCode))
  80. LanIdx = GetLanguageIndexFromCode(LanCode);
  81. else
  82. LanIdx = GetLanguageIndex(LanName, SkipDisabled:false);
  83. if (LanIdx < 0)
  84. {
  85. LanguageData lanData = new LanguageData();
  86. lanData.Name = LanName;
  87. lanData.Code = LanCode;
  88. lanData.Flags = (byte)(0 | (isLangEnabled?0:(int)eLanguageDataFlags.DISABLED));
  89. mLanguages.Add (lanData);
  90. LanIdx = mLanguages.Count-1;
  91. }
  92. LanIndices[i] = LanIdx;
  93. }
  94. //--[ Update the Languages array in the existing terms]-----
  95. nLanguages = mLanguages.Count;
  96. for (int i=0, imax=mTerms.Count; i<imax; ++i)
  97. {
  98. TermData termData = mTerms[i];
  99. if (termData.Languages.Length < nLanguages)
  100. {
  101. Array.Resize( ref termData.Languages, nLanguages );
  102. Array.Resize( ref termData.Flags, nLanguages );
  103. }
  104. }
  105. //--[ Keys ]--------------
  106. for (int i = 1, imax = CSV.Count; i < imax; ++i)
  107. {
  108. Tokens = CSV[i];
  109. string sKey = string.IsNullOrEmpty(Category) ? Tokens[0] : string.Concat(Category, "/", Tokens[0]);
  110. string specialization = null;
  111. if (sKey.EndsWith("]", StringComparison.Ordinal))
  112. {
  113. int idx = sKey.LastIndexOf('[');
  114. if (idx>0)
  115. {
  116. specialization = sKey.Substring(idx + 1, sKey.Length - idx - 2);
  117. if (specialization == "touch") specialization = "Touch";
  118. sKey = sKey.Remove(idx);
  119. }
  120. }
  121. ValidateFullTerm(ref sKey);
  122. if (string.IsNullOrEmpty(sKey))
  123. continue;
  124. TermData termData = GetTermData(sKey);
  125. // Check to see if its a new term
  126. if (termData==null)
  127. {
  128. termData = new TermData();
  129. termData.Term = sKey;
  130. termData.Languages = new string[ mLanguages.Count ];
  131. termData.Flags = new byte[ mLanguages.Count ];
  132. for (int j=0; j<mLanguages.Count; ++j)
  133. termData.Languages[j] = string.Empty;
  134. mTerms.Add (termData);
  135. mDictionary.Add (sKey, termData);
  136. }
  137. else
  138. // This term already exist
  139. if (UpdateMode==eSpreadsheetUpdateMode.AddNewTerms)
  140. continue;
  141. if (TypeColumnIdx>0)
  142. termData.TermType = GetTermType(Tokens[TypeColumnIdx]);
  143. if (DescColumnIdx>0)
  144. termData.Description = Tokens[DescColumnIdx];
  145. for (int j = 0; j < LanIndices.Length && j < Tokens.Length - LanguagesStartIdx; ++j)
  146. if (!string.IsNullOrEmpty(Tokens[j + LanguagesStartIdx])) // Only change the translation if there is a new value
  147. {
  148. var lanIdx = LanIndices[j];
  149. if (lanIdx < 0)
  150. continue;
  151. var value = Tokens[j + LanguagesStartIdx];
  152. if (value == "-")
  153. value = string.Empty;
  154. else
  155. if (value == "")
  156. value = null;
  157. termData.SetTranslation(lanIdx, value, specialization);
  158. }
  159. }
  160. if (Application.isPlaying)
  161. {
  162. SaveLanguages(HasUnloadedLanguages());
  163. }
  164. return string.Empty;
  165. }
  166. bool ArrayContains( string MainText, params string[] texts )
  167. {
  168. for (int i=0, imax=texts.Length; i<imax; ++i)
  169. if (MainText.IndexOf(texts[i], StringComparison.OrdinalIgnoreCase)>=0)
  170. return true;
  171. return false;
  172. }
  173. public static eTermType GetTermType( string type )
  174. {
  175. for (int i=0, imax=(int)eTermType.Object; i<=imax; ++i)
  176. if (string.Equals( ((eTermType)i).ToString(), type, StringComparison.OrdinalIgnoreCase))
  177. return (eTermType)i;
  178. return eTermType.Text;
  179. }
  180. #region Language Cache format
  181. void Import_Language_from_Cache(int langIndex, string langData, bool useFallback, bool onlyCurrentSpecialization)
  182. {
  183. int index = 0;
  184. while (index < langData.Length)
  185. {
  186. int nextIndex = langData.IndexOf("[i2t]", index, StringComparison.Ordinal);
  187. if (nextIndex < 0) nextIndex = langData.Length;
  188. // check for errors
  189. int termNameEnd = langData.IndexOf("=", index, StringComparison.Ordinal);
  190. if (termNameEnd >= nextIndex)
  191. return;
  192. string termName = langData.Substring(index, termNameEnd - index);
  193. index = termNameEnd+1;
  194. var termData = GetTermData(termName);
  195. if (termData != null)
  196. {
  197. string translation = null;
  198. if (index != nextIndex)
  199. {
  200. translation = langData.Substring(index, nextIndex - index);
  201. if (translation.StartsWith("[i2fb]", StringComparison.Ordinal))
  202. {
  203. translation = useFallback ? translation.Substring(6) : null;
  204. }
  205. if (onlyCurrentSpecialization && translation != null)
  206. {
  207. translation = SpecializationManager.GetSpecializedText(translation);
  208. }
  209. }
  210. termData.Languages[langIndex] = translation;
  211. }
  212. index = nextIndex + 5;
  213. }
  214. }
  215. #endregion
  216. }
  217. }