aboutsummaryrefslogtreecommitdiff
path: root/Emby.Common.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs
diff options
context:
space:
mode:
authorLuke <luke.pulverenti@gmail.com>2017-07-01 12:24:26 -0400
committerGitHub <noreply@github.com>2017-07-01 12:24:26 -0400
commitff3713153ad2317e1c196f33ac2cba61b449a00e (patch)
tree84d2e6ed5bcb556a2395603b6403c8e992535e6b /Emby.Common.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs
parentfad71a6c7d12c8b207cdf473c7dd7daafa53c174 (diff)
parent2dcad6b5977f5c5be81b18c42506ed8ad3fb73b6 (diff)
Merge pull request #2739 from MediaBrowser/beta
Beta
Diffstat (limited to 'Emby.Common.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs')
-rw-r--r--Emby.Common.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs37
1 files changed, 37 insertions, 0 deletions
diff --git a/Emby.Common.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs b/Emby.Common.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs
new file mode 100644
index 000000000..fc7d420a9
--- /dev/null
+++ b/Emby.Common.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs
@@ -0,0 +1,37 @@
+using System;
+using MediaBrowser.Model.Serialization;
+
+namespace NLangDetect.Core
+{
+ // TODO IMM HI: change to non-static class
+ // TODO IMM HI: hide other, unnecassary classes via internal?
+ public static class LanguageDetector
+ {
+ private const double _DefaultAlpha = 0.5;
+
+ #region Public methods
+
+ public static void Initialize(IJsonSerializer json)
+ {
+ DetectorFactory.LoadProfiles(json);
+ }
+
+ public static void Release()
+ {
+ DetectorFactory.Clear();
+ }
+
+ public static string DetectLanguage(string plainText)
+ {
+ if (string.IsNullOrEmpty(plainText)) { throw new ArgumentException("Argument can't be null nor empty.", "plainText"); }
+
+ Detector detector = DetectorFactory.Create(_DefaultAlpha);
+
+ detector.Append(plainText);
+
+ return detector.Detect();
+ }
+
+ #endregion
+ }
+}