Pushed And Thanks....!!!
04-IPTV-recording-in-E2.patch 27.24KB 11 downloads
Posted 12 July 2015 - 11:36
WaveFrontier 28.2E | 23.5E | 19.2E | 16E | 13E | 10/9E | 7E | 5E | 1W | 4/5W | 15W
Posted 12 July 2015 - 18:42
@littlesat ,
I just noticed a small enoying bug in cuesheet support.
If a media did not had a cuts file and the user did not ad a cut. There was always a cuts file saved but an empty then.
Also If A user made a cuts file and did removed all the cuts he made. The cuts file remained empty then.
Now If there was no cuts file loaded or user did not add cuts or just removed previousely made cuts
There will be no empty cuts file made or left.
Sorry had forgotten on that.
Included the small patch for current e2.
Posted 12 July 2015 - 21:33
WaveFrontier 28.2E | 23.5E | 19.2E | 16E | 13E | 10/9E | 7E | 5E | 1W | 4/5W | 15W
Posted 13 July 2015 - 08:05
Posted 13 July 2015 - 11:02
I am not following the discussion and here is my question. Are crazy spinners on vu+ solved with 1.0 gstreamer when you load .srt subtitles?
I'm currently bussy with the subtitles on gst-1.0.
For internal srt (embedded in media m4v or mkv) all 100 % no spinner. Start , Stop and resume.
For external srt at media start I never have a spinner anymore. Working 100 % and synchronized.
- At media resume (a stopt movie restarted which goes to the last play position does bug cause buffers are pushed whitout segment )
I'm still just trying to find out the real cause since this problem does not happen always .
Posted 17 July 2015 - 09:27
@Christophecvr.
Combining your cuesheet patch and fix on top of it results in this code in servicemp3.cpp:
FILE *f = fopen(filename.c_str(), "wb"); if (f) { /* remove the cuts file if cue is empty */ if(empty_cue) { fclose(f); remove(filename.c_str()); return; } unsigned long long where; int what; .... }
I'm sure you can see the unlogical sequence of events here and know how to refactor this in a more optimized way.
Please think and review your code before submitting.
Also when implementing an unimplemented function (cuesheet()), do not leave the 'unimplemented' version in the .h file in a commented version. You implemented the function so just remove the 'unimplemented version in the servicemp3.h file.
Posted 17 July 2015 - 09:53
@mirakels
Also when implementing an unimplemented function (cuesheet()), do not leave the 'unimplemented' version in the .h file in a commented version. You implemented the function so just remove the 'unimplemented version in the servicemp3.h file.
Yes I left it commented , but indeed it should be removed now. Sorry forgot that.
FILE *f = fopen(filename.c_str(), "wb"); if (f) { /* remove the cuts file if cue is empty */ if(empty_cue) { fclose(f); remove(filename.c_str()); return; } unsigned long long where; int what; .... }
Actually it's not that unlogic.
First You must think about the fact that A user maight have set some cuts into one off his movies he wathed before.
Later on he is wathcing the movie again. The cuts file is loaded. Cuts are there.
On this occasion he decided to remove all cuts previousely made.
The cuesheet will be empty , but the file will still be there,
With that code it will remove the file.
p.s. I used the FILE *f = fopen(filename.c_str(), "wb") also as check if file exist.
Posted 17 July 2015 - 10:32
@mirakels gues You prefere it like this then
void eServiceMP3::saveCuesheet() { std::string filename = m_ref.path; /* save cuesheet only when main file is accessible. */ #if GST_VERSION_MAJOR < 1 if (::access(filename.c_str(), R_OK) < 0) return; #else /* save cuesheet only when main file is accessible. and no TOC chapters avbl*/ if ((::access(filename.c_str(), R_OK) < 0) || m_use_chapter_entries) return; #endif filename.append(".cuts"); /* do not save to file if there are no cuts */ /* remove the cuts file if cue is empty */ if(m_cue_entries.begin() == m_cue_entries.end()) { if (::access(filename.c_str(), R_OK) == 0) remove(filename.c_str()); return; } FILE *f = fopen(filename.c_str(), "wb"); if (f) { unsigned long long where; int what; for (std::multiset<cueEntry>::iterator i(m_cue_entries.begin()); i != m_cue_entries.end(); ++i) { where = htobe64(i->where); what = htonl(i->what); fwrite(&where, sizeof(where), 1, f); fwrite(&what, sizeof(what), 1, f); } fclose(f); } m_cuesheet_changed = 0; }
I well can't test now since I cant build e2 with sourcefourge down.
Posted 17 July 2015 - 13:36
@mirakels
Actually it's not that unlogic.
First You must think about the fact that A user maight have set some cuts into one off his movies he wathed before.
Later on he is wathcing the movie again. The cuts file is loaded. Cuts are there.
On this occasion he decided to remove all cuts previousely made.
The cuesheet will be empty , but the file will still be there,
With that code it will remove the file.
p.s. I used the FILE *f = fopen(filename.c_str(), "wb") also as check if file exist.
Yes I understand your reasoning and saw that, but in this implementation you use more or less uses 'hidden' or side effect functionality that may not be obvious to people trying to understand the code. Using fopen() to verify a file exist is odd. Why not use access() for that too just like you do to check the main file?
Something like:
filename.append(".cuts"); if(empty_cue) { if (!access(filename.c_str(), 0) remove(filename.c_str()); /* remove now unneeded cue file */ return; } /* save new cues */ FILE *f = fopen(filename.c_str(), "wb"); if (f) { unsigned long long where; int what; ... } m_cuesheet_changed = 0;
And I think this 'm_cuesheet_changed = 0' should be at the start of the saveCuesheet() function cause when the main file is not accessible or the cue_sheet is empty, the function is exited leaving this variable untouched.
Posted 17 July 2015 - 13:40
oops sorry, just saw your new code to late
Note my use of acces (file, 0). instead of R_OK. You do not want to verify any mode bits for checking if the file exists.
factoring out the empty_que variable is also fine in this case.
Also please think about my m_cuesheet_changed remark..
Posted 17 July 2015 - 14:43
@mirakels
I did understand you're remarks.
As the mather off fact it was an issue for witch I use a darts board when a wrote the initial code . Using fopen() to verify a file exist is odd , but still a quit accepted way off work in c,c++ or using an extra rule before.
You're remark made me understand that my bet was wrong you're really right, cause :
- first the code is much more readable
- But on top off it much more performant(and i'm a performance freak)
Then the remark that I just commented the code which was there in the servicemp3.h instead off removing it was meant as info to the pli4 dev team. This I will remove in one off next patches.
A last this is more a question. Instead off using 0 is it not better to use F_OK as fare I understand R_OK will be there if file is only readable but F_OK will check read/write acces.
I still need to check this at base , but I prefer to use the R_OK , F_OK or ... instead off the nummerical value, this makes code more readable.
Posted 17 July 2015 - 22:39
Hihi if you are a perforamce freak you should certainly object to using fopen() to check if a file exists. fopen() has much more overhead than access().
(I'm also keen on performance but also on not using unnecessary resources)
About the F_OK/R_OK or 0. Using R_OK is not what you want. As most of the code runs as root it does not care much if a file is really readable or not, root can probably read it anyway. You really want to test for file existence. So yes, F_OK is fine too. F_OK is actually defined as 0, so it indeed is better to use F_OK
Posted 22 July 2015 - 12:34
Some updates for gst-1 branch. Subtitles.
I did found a solution to the last error with external srt.
on vuduo2 it works perfect.
Since still no gstreamer I can't make a clean patch. (For that I first need to have the real last commit off enigma2 pure pli4 git version)
Also I noticed that the vob subtittle support was already tried out. Did worked quit ok, but caused other bugs.
The other bugs where well more cause gst-0.10 is so buggy further the sequencing is very wrong in gst-0.10 enigma2. (could be required due to buggy gst-0.10)
gst-1 is pretty stable (1.5.1 actually 1.4.5 was already)
bugs ? off course there still some, comparing to 0.10 it's almost none.
Can gst-1 give more problems then gst-0.10 ?
There may be more problems, they are not due to gstreamer-1.0 but due to bad implementation off gstreamer into the plugins.
A lot off hack's,work-arounds and not updated code to the new standards off linux kernels,libc,c++,c and gstreamer self (which by gst-1.5.1 is well updated to this standards).
Some schedule when to expect a beta gst-1 pli4 image ?
Well I can't tell, that's up to the pli4 dev team and it's not so an easy task (a lot off work).
Concerning having the perfect mediaplayer for gst-1,
There I'm working on I expect .... hope around september.
Posted 22 July 2015 - 13:34
For Enigma2 it is c6061e6215b69376a7eb91a2fb2f19ddb7ac7ee4. For the rest (dvbmediasink..pliplugins) sorry.
Since still no gstreamer I can't make a clean patch. (For that I first need to have the real last commit off enigma2 pure pli4 git version)
Dreambox dm920, Uclan Ustym4Kpro, Gigablue UHD TRIO 4K and Dreambox dm8000. Wavefrontier T55 13.0|19.2|23.5|28.2 + Ziggo.
Posted 22 July 2015 - 20:24
Ok. Sourceforge is coming back to life. Only tuxbox-common is a problem at the moment. FIx rev at svn373 and build ok
Edited by Beeker, 22 July 2015 - 20:24.
Dreambox dm920, Uclan Ustym4Kpro, Gigablue UHD TRIO 4K and Dreambox dm8000. Wavefrontier T55 13.0|19.2|23.5|28.2 + Ziggo.
DVB subtitles support in eServiceMP3/GStreamerStarted by DimitarCC, 17 Oct 2024 DVB, Subtitles, GStreamer |
|
|||
Change from openvix to openpli - lose existing hdd recordings?Started by xdoktor, 30 Dec 2023 openpli, openvix, hdd, recordings |
|
|||
Having Trouble While Installing This SoftwareStarted by CharleyDavis, 27 Jun 2023 OpenPLi |
|
|||
Faild to flash or update OPENPLIStarted by dede_one, 8 Oct 2022 openpli |
|
|||
hd+ funktioneret nichtStarted by JeppeG, 29 Sep 2022 Vu+, hd+, oscam, openpli |
|
0 members, 14 guests, 0 anonymous users