diff options
| author | Luke Pulverenti <luke.pulverenti@gmail.com> | 2017-06-17 18:59:17 -0400 |
|---|---|---|
| committer | Luke Pulverenti <luke.pulverenti@gmail.com> | 2017-06-17 18:59:17 -0400 |
| commit | 0e7cbb04651bd9b65668ca1635a4625640639560 (patch) | |
| tree | 664fa5a66abb0d492479353da08a95ce6553125f /Emby.Common.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs | |
| parent | c9d7eb9b0482ab26c2d288c460cd5fba3c993e7a (diff) | |
add subtitle language detection
Diffstat (limited to 'Emby.Common.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs')
| -rw-r--r-- | Emby.Common.Implementations/TextEncoding/NLangDetect/LanguageDetector.cs | 37 |
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 + } +} |
