[grilo-plugins/0.2.x] lua-factory: improve title parsing for movies



commit 6b2349b05484de98ded5479f554c67248edaf952
Author: Victor Toso <me victortoso com>
Date:   Thu Sep 24 14:56:32 2015 +0200

    lua-factory: improve title parsing for movies
    
    When our parser does not work for tv shows nor movies, the default is to
    remove the suffix if it is possible.
    
    https://bugzilla.gnome.org/show_bug.cgi?id=755464

 .../sources/grl-video-title-parsing.lua            |   37 ++++++++++++++++++-
 1 files changed, 35 insertions(+), 2 deletions(-)
---
diff --git a/src/lua-factory/sources/grl-video-title-parsing.lua 
b/src/lua-factory/sources/grl-video-title-parsing.lua
index 3bf51cf..9c790d4 100644
--- a/src/lua-factory/sources/grl-video-title-parsing.lua
+++ b/src/lua-factory/sources/grl-video-title-parsing.lua
@@ -42,6 +42,12 @@ blacklisted_words = {
   "dsr", "DVDRip", "divx", "xvid",
 }
 
+-- https://en.wikipedia.org/wiki/Video_file_format
+video_suffixes = {
+  "webm", "mkv", "flv", "ogv", "ogg", "avi", "mov",
+  "wmv", "mp4", "m4v", "mpeg", "mpg"
+}
+
 parsers = {
   tvshow = {
     "(.-)[sS](%d+)[%s.]*[eE][pP]?(%d+)(.+)",
@@ -53,6 +59,21 @@ parsers = {
   }
 }
 
+-- in case suffix is recognized, remove it and return true
+-- or return the title and false if it fails
+function remove_suffix(title)
+  local s = title:gsub(".*%.(.-)$", "%1")
+  if s then
+    for _, suffix in ipairs(video_suffixes) do
+      if s:find(suffix) then
+        local t = title:gsub("(.*)%..-$", "%1")
+        return t, true
+      end
+    end
+  end
+  return title, false
+end
+
 function clean_title(title)
   return title:gsub("^[%s%W]*(.-)[%s%W]*$", "%1"):gsub("%.", " ")
 end
@@ -60,9 +81,13 @@ end
 function clean_title_from_blacklist(title)
   local s = title:lower()
   local last_index
+  local suffix_removed
 
-  -- remove movie sufix
-  s = s:gsub("(.+)%..-$", "%1")
+  -- remove movie suffix
+  s, suffix_removed = remove_suffix(s)
+  if suffix_removed == false then
+    grl.debug ("Suffix not find in " .. title)
+  end
 
   -- ignore everything after the first blacklisted word
   last_index = #s
@@ -130,6 +155,14 @@ function grl_source_resolve()
     return
   end
 
+  local suffix_removed
+  media.title, suffix_removed = remove_suffix(media.title)
+  if media.title and suffix_removed then
+    grl.debug(req.title .. " is a MOVIE (without suffix)")
+    grl.callback(media, 0)
+    return
+  end
+
   grl.debug("Fail to identify video: " .. req.title)
   grl.callback()
 end


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]