Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/report finish time #24

Open
wants to merge 32 commits into
base: develop
Choose a base branch
from

Conversation

carlasplund
Copy link
Contributor

estimate time remaining (step 5/5)

Present timing of each transcode to 0.1 s resolution and also,
after 20 s of transcoding, display the estimated time remaining
for the whole job. The latter time is extapolated from the
total file size converted so far and from the time elapsed since
transcoding begun.

The estimed time remaining is updated each time a file is
transcoded. The accuracy of the estimation will successively
improve during the job as more and more files are transcoded.

This is the fifth and final changeset for the step-by-step
implementation of progress reporting.

carlasplund and others added 30 commits February 27, 2013 23:38
Added option "--copyfiles" (Copy non-flac files to dest
directories)

When this option is selected, non-flac files present in the source
directories are copied to the target directories (which, for some, is
another way of handling album
art). Copying only takes place when the source and target md5
hashes don't match.
Non-flac files ar no longer copied by default.
Preparing for a a new fresh start with git flow, therefore resetting
'master' to match Robins 'develop' branch as of 2013-03-09
testing to pull request from Robin to match his 'develop' branch
Define a new subroutine msg_info which prints messages to screen only if option{info} is true. No need to use the check to info flag ( $Options{info} && msg(...) ) every time something is to be displayed.

Also fix a few bugs, where message output was not properly suppressed with the --quiet option set.
With both --copy and --pretend options selected a directory could sometimes be created in destination (it shouldn't be possible).
As a service to windows users, the paths to typical locations of lame and flac are provided. These will work for most (intended for people who haven't included these paths into the envionment variables).
Functionality is unchanged, but the way source and target file paths are retrieved is more generalized. This is an intermediary step towards the implementation of the "--delete" option.
This option works as the --delete option in "rsync": it deletes surplus files and directories in the destination, keeping in perfect sync with the source dir.
Improve readabiliy of the main program by moving the code for (non-flac) file
copying to a subroutine.
In a first step towards progress reporting during transcoding,
refactor code for the 'path_and_conversion' sub. The checking of
flags that determine whether a file should be transcoded is
lifted into this sub from 'transcode_file'. The latter sub
therefore loses a wrapping if-statement and consequently also
loses an indentation step, which makes the changeset look
much messier than it actually is.

The sub 'convert_file' is no longer used.
In this second step towards progress reporting the messages from
transcoding and tagging are not display immediately on screen, but
saved to an array variable and displayed once the respective forked
child exits. Without this step, there is no real control over the
order by with the messages appear when using several parallel
processes, and progress reporting would look a complete mess.

A callback subroutine is used to output the messages. It is
called via the method 'run_on_finish' from the module
Parallel::Forkmanager.
In the third step towards progress reporting, two separate loops
are used instead of one. The first loop is non-parallelized, where
we check each file for need of transcoding. If it doesn't need to be
transcoded it is tagged, if necessary. If it does need to be
transcoded its name and filesize is saved in a datastructure, but no
more processing on the file takes place until the second loop. The
progress of this loop is displayed and updated in 1 s intervals.

In the second loop, parallel processing is used to transcode the
files found in the first loop. Here, in the coming steps 4 and 5,
we will extend the 'run_on_finish' callback sub to also include
progress reporting and estimated time to finish, based on timing
and file size data.

Nothing would be gained by having the first loop similarily
parallelized - the computational overhead is far too big in
comparison to the relatively light cpu load.
Display total flac file size to convert before transcoding
begins (in units of MB), as well as a progress report after
each transcoded file (as in "Processed 3/1267 files."). This
is accomplished by extending the callback code that runs
every time a child exits.

The timing and estimated finish time of the transcoding job is
implemented by extending this callback code further in the
next commit, step 5/5.
Present timing of each transcode to 0.1 s resolution and also,
after 20 s of transcoding, display the estimated time remaining
for the whole job. The latter time is extapolated from the
total file size converted so far and from the time elapsed since
transcoding begun.

The estimed time remaining is updated each time a file is
transcoded. The accuracy of the estimation will successively
improve during the job as more and more files are transcoded.

This is the fifth and final changeset for the step-by-step
implementation of progress reporting.
@robinbowes robinbowes force-pushed the develop branch 2 times, most recently from fdbfca0 to ae49d07 Compare December 23, 2014 00:18
@fatso83
Copy link

fatso83 commented Feb 23, 2015

For a small time I was thinking that this project was abondoned by looking at the date of this PR (2013) and the fact that there was no discussion around it. But then I saw the closed PRs, the latest as of last month!

What's preventing this (and the other PRs from Carl) from being merged? Other than the obvious merge conflict, of course, which I assume has arisen due to time gone by...

@robinbowes
Copy link
Owner

It's essentially down to lack of time on my part to take a look at this (and other PRs).

This one is particularly huge and I am unlikely to be inclined to work my way through it in its current form.

It certainly needs rebasing, and I'd prefer a series of much smaller commits.

R.

@fatso83
Copy link

fatso83 commented Feb 24, 2015

Thanks - totally OK with that.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants