From bfcd1b520fd79b893e721ba916ae5e1656407d2f Mon Sep 17 00:00:00 2001 From: Luke Pulverenti Date: Wed, 16 Aug 2017 02:43:41 -0400 Subject: merge common implementations and server implementations --- .../TextEncoding/NLangDetect/LanguageDetector.cs | 37 ++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 Emby.Server.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs (limited to 'Emby.Server.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs') diff --git a/Emby.Server.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs b/Emby.Server.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs new file mode 100644 index 000000000..fc7d420a9 --- /dev/null +++ b/Emby.Server.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 + } +} -- cgit v1.2.3