1
0
mirror of https://github.com/VDR4Arch/vdr.git synced 2023-10-10 13:36:52 +02:00

Fixed sorting recordings by time in the Recordings menu if "Setup/OSD/Recording directories" is set to "no"

This commit is contained in:
Klaus Schmidinger 2014-01-29 10:51:18 +01:00
parent 9e9219d8fb
commit c1ddb52405
3 changed files with 22 additions and 12 deletions

View File

@ -7870,7 +7870,7 @@ Video Disk Recorder Revision History
and also to use the correct directory with --edit (the latter reported by Marko and also to use the correct directory with --edit (the latter reported by Marko
Mäkelä). Mäkelä).
2014-01-28: Version 2.0.6 2014-01-29: Version 2.0.6
- Updated 'sources.conf' (thanks to Antti Hartikainen). - Updated 'sources.conf' (thanks to Antti Hartikainen).
- cFont::CreateFont() now returns a dummy font in case there are no fonts installed. - cFont::CreateFont() now returns a dummy font in case there are no fonts installed.
@ -7885,3 +7885,5 @@ Video Disk Recorder Revision History
of actual video TS packets in cTsPayload in order to be able to record channels that of actual video TS packets in cTsPayload in order to be able to record channels that
sometimes need even more than 10 TS packets for detecting frame borders (reported by sometimes need even more than 10 TS packets for detecting frame borders (reported by
Eike Sauer and Oliver Endriss). Eike Sauer and Oliver Endriss).
- Fixed sorting recordings by time in the Recordings menu if "Setup/OSD/Recording
directories" is set to "no".

4
menu.c
View File

@ -4,7 +4,7 @@
* See the main source file 'vdr.c' for copyright information and * See the main source file 'vdr.c' for copyright information and
* how to reach the author. * how to reach the author.
* *
* $Id: menu.c 2.82.1.5 2013/10/16 09:46:24 kls Exp $ * $Id: menu.c 2.82.1.6 2014/01/29 10:48:02 kls Exp $
*/ */
#include "menu.h" #include "menu.h"
@ -2648,7 +2648,7 @@ eOSState cMenuSetupOSD::ProcessKey(eKeys Key)
ModifiedAppearance = true; ModifiedAppearance = true;
if (strcmp(data.FontFix, Setup.FontFix) || !DoubleEqual(data.FontFixSizeP, Setup.FontFixSizeP)) if (strcmp(data.FontFix, Setup.FontFix) || !DoubleEqual(data.FontFixSizeP, Setup.FontFixSizeP))
ModifiedAppearance = true; ModifiedAppearance = true;
if (data.AlwaysSortFoldersFirst != Setup.AlwaysSortFoldersFirst) if (data.AlwaysSortFoldersFirst != Setup.AlwaysSortFoldersFirst || data.RecordingDirs != Setup.RecordingDirs)
Recordings.ClearSortNames(); Recordings.ClearSortNames();
} }

View File

@ -4,7 +4,7 @@
* See the main source file 'vdr.c' for copyright information and * See the main source file 'vdr.c' for copyright information and
* how to reach the author. * how to reach the author.
* *
* $Id: recording.c 2.91.1.3 2013/12/25 10:55:32 kls Exp $ * $Id: recording.c 2.91.1.4 2014/01/29 10:50:28 kls Exp $
*/ */
#include "recording.h" #include "recording.h"
@ -958,14 +958,22 @@ char *cRecording::SortName(void) const
{ {
char **sb = (RecordingsSortMode == rsmName) ? &sortBufferName : &sortBufferTime; char **sb = (RecordingsSortMode == rsmName) ? &sortBufferName : &sortBufferTime;
if (!*sb) { if (!*sb) {
char *s = strdup(FileName() + strlen(VideoDirectory)); if (RecordingsSortMode == rsmTime && !Setup.RecordingDirs) {
if (RecordingsSortMode != rsmName || Setup.AlwaysSortFoldersFirst) char buf[32];
s = StripEpisodeName(s, RecordingsSortMode != rsmName); struct tm tm_r;
strreplace(s, '/', '0'); // some locales ignore '/' when sorting strftime(buf, sizeof(buf), "%Y%m%d%H%I", localtime_r(&start, &tm_r));
int l = strxfrm(NULL, s, 0) + 1; *sb = strdup(buf);
*sb = MALLOC(char, l); }
strxfrm(*sb, s, l); else {
free(s); char *s = strdup(FileName() + strlen(VideoDirectory));
if (RecordingsSortMode != rsmName || Setup.AlwaysSortFoldersFirst)
s = StripEpisodeName(s, RecordingsSortMode != rsmName);
strreplace(s, '/', '0'); // some locales ignore '/' when sorting
int l = strxfrm(NULL, s, 0) + 1;
*sb = MALLOC(char, l);
strxfrm(*sb, s, l);
free(s);
}
} }
return *sb; return *sb;
} }