-
-
Notifications
You must be signed in to change notification settings - Fork 38
Overview of Scan Logic
Here is a quick overview of how TV Rename checks your media library, identifies missing episodes, and then locates the files to copy/move/rename across. (Original version of this text from Google Code issue #20)
-
TV Rename has a list of shows (each is a "ShowItem"). Each show has a number of seasons, and each season has a number of episodes (episodes are downloaded from TheTVDB, as "Episode" items. Once the merge/rename/etc. rules are applied, they are turned into "ProcessedEpisode" classes).
-
When you do a "Scan", for each of your shows, for each of the seasons, it determines the name of the folder(s) in your media library for that season (function RenameAndMissingCheck). Automatic and manual folders feature here. (ShowItem.AllFolderLocations)
-
For each file in that folder, it determines the season and episode number of the file.
- If the filename doesn't match the official filename template, create a new "action" to rename it.
-
For each episode that has aired so far in the season, mark each one off as "found" as they are found in (3). (variable "localEps").
-
After processing all files in the folder, anything not marked off in "localEps" is added as a "missing" action.
The checking of .NFO, .TBN, and folder.jpg files is mixed into the above, too, since its most convenient/efficient to do it at the same time.
At this point we have a list of episodes missing from the media library. Next step is to figure out where they are:
-
For each missing episode (function LookForMissingEps)
-
For each file in the folder in the user's "Search Folders", see if it's name contains the show's name. If so, determine the season and episode number. (functions FindMissingEp and FindSeasEp).
- If the show has "use sequential number matching" turned on, then also look for the overall number of the episode (function MatchesSequentialNumber).
-
If found, set up an "action" (i.e. thing to do pending the user's approval in the Scan tab) to rename/move/copy the file as appropriate, with the name as per the global "Filename template".