diff --git a/docs/html/config_dvr.html b/docs/html/config_dvr.html
index 2b72e8a0..354b3297 100644
--- a/docs/html/config_dvr.html
+++ b/docs/html/config_dvr.html
@@ -78,6 +78,10 @@
If checked, commercials will be dropped from the recordings. At the
moment, commercial detection only works for the swedish channel TV4.
+ Episode duplicate detection
+ If checked, broadcasts with matching title and matching non-zero episode number
+ are considered duplicates.
+
Post-processor command
Command to run after finishing a recording. The command will be
run in background and is executed even if a recording is aborted
diff --git a/src/dvr/dvr.h b/src/dvr/dvr.h
index 59d285cc..a945e8f4 100644
--- a/src/dvr/dvr.h
+++ b/src/dvr/dvr.h
@@ -66,6 +66,7 @@ extern struct dvr_entry_list dvrentries;
#define DVR_CLEAN_TITLE 0x100
#define DVR_TAG_FILES 0x200
#define DVR_SKIP_COMMERCIALS 0x400
+#define DVR_EPISODE_DUPLICATE_DETECTION 0x800
typedef enum {
DVR_PRIO_IMPORTANT,
diff --git a/src/dvr/dvr_db.c b/src/dvr/dvr_db.c
index 17949a73..c6168d87 100644
--- a/src/dvr/dvr_db.c
+++ b/src/dvr/dvr_db.c
@@ -436,7 +436,7 @@ static int _dvr_duplicate_event ( epg_broadcast_t *e )
epg_episode_num_t empty_epnum;
int has_epnum = 1;
- /* do not do episode duplicate check below if no episode number */
+ /* skip episode duplicate check below if no episode number */
memset(&empty_epnum, 0, sizeof(empty_epnum));
if (epg_episode_number_cmp(&empty_epnum, &e->episode->epnum) == 0)
has_epnum = 0;
@@ -446,13 +446,18 @@ static int _dvr_duplicate_event ( epg_broadcast_t *e )
if (de->de_bcast->episode == e->episode) return 1;
if (has_epnum) {
- const char* de_title = lang_str_get(de->de_bcast->episode->title, NULL);
- const char* e_title = lang_str_get(e->episode->title, NULL);
+ dvr_config_t *cfg = dvr_config_find_by_name_default(de->de_config_name);
+ int ep_dup_det = (cfg->dvr_flags & DVR_EPISODE_DUPLICATE_DETECTION);
- /* duplicate if title and episode match */
- if (de_title && e_title && strcmp(de_title, e_title) == 0
- && epg_episode_number_cmp(&de->de_bcast->episode->epnum, &e->episode->epnum) == 0) {
- return 1;
+ if (ep_dup_det) {
+ const char* de_title = lang_str_get(de->de_bcast->episode->title, NULL);
+ const char* e_title = lang_str_get(e->episode->title, NULL);
+
+ /* duplicate if title and episode match */
+ if (de_title && e_title && strcmp(de_title, e_title) == 0
+ && epg_episode_number_cmp(&de->de_bcast->episode->epnum, &e->episode->epnum) == 0) {
+ return 1;
+ }
}
}
}
@@ -1145,6 +1150,9 @@ dvr_init(void)
if(!htsmsg_get_u32(m, "skip-commercials", &u32) && !u32)
cfg->dvr_flags &= ~DVR_SKIP_COMMERCIALS;
+ if(!htsmsg_get_u32(m, "episode-duplicate-detection", &u32) && u32)
+ cfg->dvr_flags |= DVR_EPISODE_DUPLICATE_DETECTION;
+
tvh_str_set(&cfg->dvr_postproc, htsmsg_get_str(m, "postproc"));
}
@@ -1311,6 +1319,7 @@ dvr_save(dvr_config_t *cfg)
htsmsg_add_u32(m, "clean-title", !!(cfg->dvr_flags & DVR_CLEAN_TITLE));
htsmsg_add_u32(m, "tag-files", !!(cfg->dvr_flags & DVR_TAG_FILES));
htsmsg_add_u32(m, "skip-commercials", !!(cfg->dvr_flags & DVR_SKIP_COMMERCIALS));
+ htsmsg_add_u32(m, "episode-duplicate-detection", !!(cfg->dvr_flags & DVR_EPISODE_DUPLICATE_DETECTION));
if(cfg->dvr_postproc != NULL)
htsmsg_add_str(m, "postproc", cfg->dvr_postproc);
diff --git a/src/webui/extjs.c b/src/webui/extjs.c
index 6ff9fbb8..86ffd2af 100644
--- a/src/webui/extjs.c
+++ b/src/webui/extjs.c
@@ -1306,6 +1306,7 @@ extjs_dvr(http_connection_t *hc, const char *remain, void *opaque)
htsmsg_add_u32(r, "cleanTitle", !!(cfg->dvr_flags & DVR_CLEAN_TITLE));
htsmsg_add_u32(r, "tagFiles", !!(cfg->dvr_flags & DVR_TAG_FILES));
htsmsg_add_u32(r, "commSkip", !!(cfg->dvr_flags & DVR_SKIP_COMMERCIALS));
+ htsmsg_add_u32(r, "episodeDuplicateDetection", !!(cfg->dvr_flags & DVR_EPISODE_DUPLICATE_DETECTION));
out = json_single_record(r, "dvrSettings");
@@ -1358,6 +1359,8 @@ extjs_dvr(http_connection_t *hc, const char *remain, void *opaque)
flags |= DVR_TAG_FILES;
if(http_arg_get(&hc->hc_req_args, "commSkip") != NULL)
flags |= DVR_SKIP_COMMERCIALS;
+ if(http_arg_get(&hc->hc_req_args, "episodeDuplicateDetection") != NULL)
+ flags |= DVR_EPISODE_DUPLICATE_DETECTION;
dvr_flags_set(cfg,flags);
diff --git a/src/webui/static/app/dvr.js b/src/webui/static/app/dvr.js
index 02021eb3..a4bb8e46 100644
--- a/src/webui/static/app/dvr.js
+++ b/src/webui/static/app/dvr.js
@@ -729,7 +729,7 @@ tvheadend.dvrsettings = function() {
}, [ 'storage', 'postproc', 'retention', 'dayDirs', 'channelDirs',
'channelInTitle', 'container', 'dateInTitle', 'timeInTitle',
'preExtraTime', 'postExtraTime', 'whitespaceInTitle', 'titleDirs',
- 'episodeInTitle', 'cleanTitle', 'tagFiles', 'commSkip' ]);
+ 'episodeInTitle', 'cleanTitle', 'tagFiles', 'commSkip', 'episodeDuplicateDetection' ]);
var confcombo = new Ext.form.ComboBox({
store : tvheadend.configNames,
@@ -822,6 +822,9 @@ tvheadend.dvrsettings = function() {
}), new Ext.form.Checkbox({
fieldLabel : 'Skip commercials',
name : 'commSkip'
+ }), new Ext.form.Checkbox({
+ fieldLabel : 'Episode duplicate detection',
+ name : 'episodeDuplicateDetection'
}), {
width : 300,
fieldLabel : 'Post-processor command',