multimedia_paradise 1.1.344 → 1.2.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +99 -77
- data/bin/audio_player +1 -1
- data/bin/extract_images_from_this_video_file +1 -1
- data/bin/loop_this_video +1 -1
- data/bin/merge_avi_files +1 -1
- data/bin/merge_mp3 +1 -1
- data/bin/mp3_to_opus +1 -1
- data/bin/mpg_to_mp4 +1 -1
- data/bin/multimedia_paradise +1 -1
- data/bin/to_aiff +2 -5
- data/bin/to_flac +7 -0
- data/bin/to_mp3 +8 -0
- data/bin/to_mp4 +1 -1
- data/bin/to_ogg +7 -0
- data/bin/verbose_analyse_this_mp3_file_for_id3_tags +1 -1
- data/bin/video_codec +1 -1
- data/bin/video_thumbnail +1 -1
- data/bin/video_to_images +1 -1
- data/doc/README.gen +88 -51
- data/doc/{CHANGELOG.md → changelog/changelog.md} +8 -6
- data/doc/{LINKS.md → links/links.md} +2 -2
- data/doc/{MOTIVATION_FOR_THIS_PROJECT.md → motivation_for_the_multimedia_paradise_project/motivation_for_the_multimedia_paradise_project.md} +5 -5
- data/doc/todo/todo_for_the_multimedia_paradise_project.md +79 -93
- data/lib/multimedia_paradise/actions/actions.rb +224 -0
- data/lib/multimedia_paradise/audio/audio_player/audio_player.rb +61 -64
- data/lib/multimedia_paradise/audio/audio_tag_reader/audio_tag_reader.rb +17 -8
- data/lib/multimedia_paradise/audio/base.rb +0 -5
- data/lib/multimedia_paradise/audio/compress.rb +8 -5
- data/lib/multimedia_paradise/audio/create_m3u_playlist.rb +7 -11
- data/lib/multimedia_paradise/audio/extract_audio/constants.rb +0 -37
- data/lib/multimedia_paradise/audio/extract_audio/extract_audio.rb +90 -68
- data/lib/multimedia_paradise/audio/file_duration/file_duration.rb +134 -80
- data/lib/multimedia_paradise/audio/genres/boogie.rb +1 -6
- data/lib/multimedia_paradise/audio/genres/concerts.rb +1 -6
- data/lib/multimedia_paradise/audio/genres/constants.rb +1 -1
- data/lib/multimedia_paradise/audio/genres/eurodance.rb +1 -6
- data/lib/multimedia_paradise/audio/genres/genre.rb +36 -33
- data/lib/multimedia_paradise/audio/genres/hip_hop.rb +1 -6
- data/lib/multimedia_paradise/audio/genres/italian_songs.rb +1 -6
- data/lib/multimedia_paradise/audio/genres/the_1980s.rb +1 -6
- data/lib/multimedia_paradise/audio/genres/trance.rb +4 -7
- data/lib/multimedia_paradise/audio/lyrics_fetcher.rb +27 -22
- data/lib/multimedia_paradise/audio/merge_audio_files.rb +18 -11
- data/lib/multimedia_paradise/audio/modify_year_of_audio_file.rb +23 -11
- data/lib/multimedia_paradise/audio/n_audio_songs.rb +3 -2
- data/lib/multimedia_paradise/audio/play_all_audio_files.rb +41 -16
- data/lib/multimedia_paradise/audio/playlist/playlist.rb +163 -123
- data/lib/multimedia_paradise/audio/remove_audio.rb +11 -6
- data/lib/multimedia_paradise/audio/remove_last_second.rb +2 -3
- data/lib/multimedia_paradise/audio/report_missing_id.rb +22 -12
- data/lib/multimedia_paradise/audio/streamripper/streamripper_wrapper.rb +7 -5
- data/lib/multimedia_paradise/audio/to_mp3.rb +7 -5
- data/lib/multimedia_paradise/audio/to_ogg.rb +3 -1
- data/lib/multimedia_paradise/audio/wav_to_mp3.rb +5 -5
- data/lib/multimedia_paradise/base/base.rb +854 -15
- data/lib/multimedia_paradise/base/colours.rb +28 -31
- data/lib/multimedia_paradise/base/{commandline_arguments.rb → commandline_arguments_module/commandline_arguments_module.rb} +12 -9
- data/lib/multimedia_paradise/colours/colours.rb +4 -1
- data/lib/multimedia_paradise/commandline/{menu.rb → commandline.rb} +19 -16
- data/lib/multimedia_paradise/constants/constants.rb +504 -14
- data/lib/multimedia_paradise/constants/web_constants.rb +2 -4
- data/lib/multimedia_paradise/gui/gui_base.rb +2 -2
- data/lib/multimedia_paradise/gui/libui/lyrics/lyrics.rb +1 -1
- data/lib/multimedia_paradise/gui/libui/simple_play_widget/simple_play_widget.rb +1 -1
- data/lib/multimedia_paradise/gui/libui/video_player/video_player.rb +1 -1
- data/lib/multimedia_paradise/gui/libui/youtube_channels/youtube_channels.rb +1 -1
- data/lib/multimedia_paradise/gui/shared_code/multimedia_converter/multimedia_converter_module.rb +0 -478
- data/lib/multimedia_paradise/gui/shared_code/playlist/playlist_module.rb +94 -41
- data/lib/multimedia_paradise/gui/shared_code/simple_play_widget/simple_play_widget_module.rb +0 -257
- data/lib/multimedia_paradise/gui/universal_widgets/change_metadata_widget/change_metadata_widget.rb +2 -2
- data/lib/multimedia_paradise/gui/universal_widgets/information_about_a_mp3_file/information_about_a_mp3_file.rb +1 -1
- data/lib/multimedia_paradise/gui/universal_widgets/lyrics/lyrics.rb +1 -1
- data/lib/multimedia_paradise/gui/universal_widgets/multimedia_converter/multimedia_converter.rb +589 -0
- data/lib/multimedia_paradise/gui/universal_widgets/playlist/playlist.rb +197 -0
- data/lib/multimedia_paradise/gui/universal_widgets/radio/radio.rb +1 -1
- data/lib/multimedia_paradise/gui/{gtk2 → universal_widgets}/simple_play_widget/README.md +1 -1
- data/lib/multimedia_paradise/gui/universal_widgets/simple_play_widget/simple_play_widget.rb +404 -0
- data/lib/multimedia_paradise/gui/universal_widgets/tag_mp3_files/tag_mp3_files.rb +3 -6
- data/lib/multimedia_paradise/java/Playlist.class +0 -0
- data/lib/multimedia_paradise/java/Playlist.java +198 -0
- data/lib/multimedia_paradise/multimedia/analyse_multimedia_file.rb +21 -19
- data/lib/multimedia_paradise/multimedia/avisynth/avisynth_code.avs +441 -442
- data/lib/multimedia_paradise/multimedia/base.rb +0 -18
- data/lib/multimedia_paradise/multimedia/chord.rb +1 -1
- data/lib/multimedia_paradise/multimedia/cut_multimedia/cut_multimedia.rb +7 -5
- data/lib/multimedia_paradise/multimedia/cut_multimedia/evaluate_from_this_file.rb +2 -2
- data/lib/multimedia_paradise/multimedia/interactive_shell.rb +22 -3
- data/lib/multimedia_paradise/multimedia/merge_multimedia.rb +4 -3
- data/lib/multimedia_paradise/multimedia/play_from_this_list.rb +4 -27
- data/lib/multimedia_paradise/multimedia/{read_meta_tags.rb → read_meta_tags/read_meta_tags.rb} +14 -19
- data/lib/multimedia_paradise/multimedia/start_length_duration.rb +3 -3
- data/lib/multimedia_paradise/project/project.rb +8 -4
- data/lib/multimedia_paradise/requires/require_the_multimedia_paradise_project.rb +5 -5
- data/lib/multimedia_paradise/requires/require_toplevel_methods_files.rb +1 -1
- data/lib/multimedia_paradise/sinatra/app.rb +3 -3
- data/lib/multimedia_paradise/statistics/README.md +6 -5
- data/lib/multimedia_paradise/statistics/video.rb +34 -14
- data/lib/multimedia_paradise/{misc → time}/long_format_to_milliseconds_converter.rb +4 -2
- data/lib/multimedia_paradise/{misc → time}/milliseconds_to_long_format_converter.rb +2 -2
- data/lib/multimedia_paradise/toplevel_methods/audio_related_code.rb +138 -0
- data/lib/multimedia_paradise/toplevel_methods/chop_into_segments_of_n_seconds_size.rb +2 -2
- data/lib/multimedia_paradise/{conversions → toplevel_methods}/conversions.rb +140 -48
- data/lib/multimedia_paradise/toplevel_methods/copy_and_merge_this_video_n_times.rb +5 -5
- data/lib/multimedia_paradise/toplevel_methods/create_video_from_this_audio.rb +7 -6
- data/lib/multimedia_paradise/toplevel_methods/cut_from_to.rb +2 -2
- data/lib/multimedia_paradise/toplevel_methods/denoise.rb +2 -2
- data/lib/multimedia_paradise/toplevel_methods/deshake.rb +3 -6
- data/lib/multimedia_paradise/toplevel_methods/{output_directory.rb → directory_related_code.rb} +38 -1
- data/lib/multimedia_paradise/toplevel_methods/encode_this_video.rb +8 -4
- data/lib/multimedia_paradise/toplevel_methods/esystem.rb +43 -4
- data/lib/multimedia_paradise/{ffmpeg → toplevel_methods}/ffmpeg.rb +200 -193
- data/lib/multimedia_paradise/toplevel_methods/{files_and_directories.rb → files_related_code.rb} +19 -56
- data/lib/multimedia_paradise/toplevel_methods/flip_and_rotate.rb +3 -3
- data/lib/multimedia_paradise/toplevel_methods/is_audio_file_is_video_file_is_image_file_is_multimedia_file.rb +115 -0
- data/lib/multimedia_paradise/toplevel_methods/is_on_roebe.rb +1 -1
- data/lib/multimedia_paradise/toplevel_methods/{merge_multimedia_file.rb → merge.rb} +98 -4
- data/lib/multimedia_paradise/toplevel_methods/opn.rb +5 -4
- data/lib/multimedia_paradise/toplevel_methods/player_in_use.rb +14 -7
- data/lib/multimedia_paradise/toplevel_methods/query_the_audio_codec_of_this_file.rb +4 -3
- data/lib/multimedia_paradise/toplevel_methods/radio.rb +1 -3
- data/lib/multimedia_paradise/toplevel_methods/return_all_video_files.rb +4 -4
- data/lib/multimedia_paradise/toplevel_methods/return_path_to_random_simpsons_video_file.rb +1 -1
- data/lib/multimedia_paradise/toplevel_methods/return_random_video_file_from_the_video_collection.rb +9 -7
- data/lib/multimedia_paradise/toplevel_methods/scale_video.rb +3 -4
- data/lib/multimedia_paradise/toplevel_methods/set_title_of.rb +6 -6
- data/lib/multimedia_paradise/{help/help.rb → toplevel_methods/show_help.rb} +14 -8
- data/lib/multimedia_paradise/toplevel_methods/slow_down_this_video_file.rb +2 -3
- data/lib/multimedia_paradise/toplevel_methods/start_screencast.rb +3 -2
- data/lib/multimedia_paradise/toplevel_methods/{misc.rb → toplevel_methods.rb} +485 -527
- data/lib/multimedia_paradise/toplevel_methods/total_duration.rb +4 -3
- data/lib/multimedia_paradise/toplevel_methods/use_lame_codec.rb +1 -2
- data/lib/multimedia_paradise/toplevel_methods/video_dataset.rb +1 -1
- data/lib/multimedia_paradise/version/version.rb +2 -2
- data/lib/multimedia_paradise/video/all_videos.rb +12 -19
- data/lib/multimedia_paradise/video/check_numbers.rb +76 -32
- data/lib/multimedia_paradise/video/columbo/columbo.rb +36 -14
- data/lib/multimedia_paradise/video/guess_video_name.rb +2 -10
- data/lib/multimedia_paradise/video/mike_hammer/mike_hammer.rb +2 -2
- data/lib/multimedia_paradise/video/missing_video_files/missing_video_files.rb +1 -9
- data/lib/multimedia_paradise/video/movie_searcher.rb +2 -10
- data/lib/multimedia_paradise/video/mplayer_wrapper.rb +1 -9
- data/lib/multimedia_paradise/video/random_video.rb +1 -2
- data/lib/multimedia_paradise/video/registered_video_file.rb +2 -10
- data/lib/multimedia_paradise/video/report_local_videos.rb +1 -9
- data/lib/multimedia_paradise/video/simpsons.rb +2 -10
- data/lib/multimedia_paradise/video/smart_animals/smart_animals.rb +10 -8
- data/lib/multimedia_paradise/video/speed_up_video.rb +28 -10
- data/lib/multimedia_paradise/video/store_available_video_files.rb +49 -33
- data/lib/multimedia_paradise/video/the_simpsons/README.md +0 -0
- data/lib/multimedia_paradise/video/the_simpsons/good_the_simpsons_episodes.rb +8 -8
- data/lib/multimedia_paradise/video/the_simpsons/the_simpsons.rb +14 -10
- data/lib/multimedia_paradise/video/video_information.rb +55 -49
- data/lib/multimedia_paradise/{configuration → yaml/configuration}/play_zoomed.yml +0 -0
- data/lib/multimedia_paradise/yaml/{playlist.yml → playlist/playlist.yml} +14 -15
- data/lib/multimedia_paradise/yaml/video/video.yml +1 -1
- data/lib/multimedia_paradise/yaml/video_collection/video_collection.yml +34 -32
- data/lib/multimedia_paradise/yaml/youtube/alltagsgeschichte/alltagsgeschichte.yml +61 -11
- data/lib/multimedia_paradise/yaml/youtube/songs/songs.yml +5 -3
- data/multimedia_paradise.gemspec +1 -1
- data/test/testing_audio_player.rb +3 -3
- data/test/testing_file_duration.rb +5 -5
- metadata +45 -76
- data/lib/multimedia_paradise/audio/file_duration/constants.rb +0 -53
- data/lib/multimedia_paradise/audio/waveform/class.rb +0 -341
- data/lib/multimedia_paradise/audio/waveform/constants.rb +0 -38
- data/lib/multimedia_paradise/audio/waveform/log.rb +0 -101
- data/lib/multimedia_paradise/base/constants.rb +0 -19
- data/lib/multimedia_paradise/base/encoding.rb +0 -31
- data/lib/multimedia_paradise/base/misc.rb +0 -665
- data/lib/multimedia_paradise/base/namespace.rb +0 -36
- data/lib/multimedia_paradise/base/time.rb +0 -25
- data/lib/multimedia_paradise/constants/conversions.rb +0 -62
- data/lib/multimedia_paradise/constants/directory_constants.rb +0 -139
- data/lib/multimedia_paradise/constants/encodings.rb +0 -26
- data/lib/multimedia_paradise/constants/file_constants.rb +0 -176
- data/lib/multimedia_paradise/constants/misc.rb +0 -80
- data/lib/multimedia_paradise/constants/my_video_directory.rb +0 -30
- data/lib/multimedia_paradise/constants/namespace.rb +0 -14
- data/lib/multimedia_paradise/constants/newline.rb +0 -14
- data/lib/multimedia_paradise/constants/video_filetypes.rb +0 -27
- data/lib/multimedia_paradise/conversions/README.md +0 -2
- data/lib/multimedia_paradise/ffmpeg/README.md +0 -2
- data/lib/multimedia_paradise/gui/gtk2/multimedia_converter/multimedia_converter.rb +0 -33
- data/lib/multimedia_paradise/gui/gtk2/notebook.rb +0 -144
- data/lib/multimedia_paradise/gui/gtk2/play_video_from_my_collection/play_video_from_my_collection.rb +0 -43
- data/lib/multimedia_paradise/gui/gtk2/simple_play_widget/simple_play_widget.rb +0 -40
- data/lib/multimedia_paradise/gui/gtk2/widget_increase_or_decrease_audio/widget_increase_or_decrease_audio.rb +0 -42
- data/lib/multimedia_paradise/gui/gtk2/youtube_downloader/youtube_downloader.rb +0 -32
- data/lib/multimedia_paradise/gui/gtk3/lyrics/lyrics.rb +0 -0
- data/lib/multimedia_paradise/gui/gtk3/multimedia_converter/multimedia_converter.rb +0 -34
- data/lib/multimedia_paradise/gui/gtk3/playlist/playlist.rb +0 -34
- data/lib/multimedia_paradise/gui/gtk3/simple_play_widget/simple_play_widget.rb +0 -38
- data/lib/multimedia_paradise/toplevel_methods/analyze_audio_stream.rb +0 -31
- data/lib/multimedia_paradise/toplevel_methods/codecs.rb +0 -50
- data/lib/multimedia_paradise/toplevel_methods/copy_file.rb +0 -18
- data/lib/multimedia_paradise/toplevel_methods/delay_audio.rb +0 -31
- data/lib/multimedia_paradise/toplevel_methods/ensure_that_the_output_directory_exists.rb +0 -27
- data/lib/multimedia_paradise/toplevel_methods/has_audio.rb +0 -48
- data/lib/multimedia_paradise/toplevel_methods/increase_volume_of_this_audio_file.rb +0 -61
- data/lib/multimedia_paradise/toplevel_methods/is_a_multimedia_file.rb +0 -27
- data/lib/multimedia_paradise/toplevel_methods/is_audio_file.rb +0 -27
- data/lib/multimedia_paradise/toplevel_methods/is_image_file.rb +0 -31
- data/lib/multimedia_paradise/toplevel_methods/is_video_file.rb +0 -62
- data/lib/multimedia_paradise/toplevel_methods/merge_these_videos.rb +0 -106
- data/lib/multimedia_paradise/toplevel_methods/run_sys_command.rb +0 -30
- data/lib/multimedia_paradise/toplevel_methods/to_flac.rb +0 -30
- data/lib/multimedia_paradise/toplevel_methods/to_mp4.rb +0 -24
- /data/doc/{MergingVideoLectures.md → merging_video_lectures/merging_video_lectures.md} +0 -0
- /data/doc/{Readme_for_the_cut_audio_component.md → readme_for_the_cut_audio_component/Readme_for_the_cut_audio_component.md} +0 -0
- /data/lib/multimedia_paradise/yaml/{audio_formats.yml → audio_formats/audio_formats.yml} +0 -0
- /data/lib/multimedia_paradise/yaml/{image_formats.yml → image_formats/image_formats.yml} +0 -0
- /data/lib/multimedia_paradise/yaml/{lyrics.yml → lyrics/lyrics.yml} +0 -0
- /data/lib/multimedia_paradise/yaml/{music_genres.yml → music_genres/music_genres.yml} +0 -0
- /data/lib/multimedia_paradise/yaml/{song_tags.yml → song_tags/song_tags.yml} +0 -0
- /data/lib/multimedia_paradise/yaml/{use_this_video_player.yml → use_this_video_player/use_this_video_player.yml} +0 -0
- /data/lib/multimedia_paradise/yaml/{video_encoding_settings.yml → video_encoding_settings/video_encoding_settings.yml} +0 -0
- /data/lib/multimedia_paradise/yaml/{video_filter_aliases.yml → video_filter_aliases/video_filter_aliases.yml} +0 -0
@@ -25,11 +25,6 @@ module Video
|
|
25
25
|
|
26
26
|
class ReportLocalVideos < ::MultimediaParadise::Base # === MultimediaParadise::Video::ReportLocalVideos
|
27
27
|
|
28
|
-
# ========================================================================= #
|
29
|
-
# === NAMESPACE
|
30
|
-
# ========================================================================= #
|
31
|
-
NAMESPACE = inspect
|
32
|
-
|
33
28
|
# ========================================================================= #
|
34
29
|
# === initialize
|
35
30
|
# ========================================================================= #
|
@@ -49,10 +44,7 @@ class ReportLocalVideos < ::MultimediaParadise::Base # === MultimediaParadise::V
|
|
49
44
|
# ========================================================================= #
|
50
45
|
def reset
|
51
46
|
super()
|
52
|
-
|
53
|
-
# === @namespace
|
54
|
-
# ======================================================================= #
|
55
|
-
@namespace = NAMESPACE
|
47
|
+
infer_the_namespace
|
56
48
|
end
|
57
49
|
|
58
50
|
# ========================================================================= #
|
@@ -19,11 +19,6 @@ module MultimediaParadise
|
|
19
19
|
|
20
20
|
class Simpsons < MultimediaParadise::Base # === MultimediaParadise::Simpsons.new
|
21
21
|
|
22
|
-
# ========================================================================= #
|
23
|
-
# === NAMESPACE
|
24
|
-
# ========================================================================= #
|
25
|
-
NAMESPACE = inspect
|
26
|
-
|
27
22
|
# ========================================================================= #
|
28
23
|
# === DEFAULT_PLAY_N_TIMES
|
29
24
|
# ========================================================================= #
|
@@ -72,10 +67,7 @@ class Simpsons < MultimediaParadise::Base # === MultimediaParadise::Simpsons.new
|
|
72
67
|
# ========================================================================= #
|
73
68
|
def reset
|
74
69
|
super()
|
75
|
-
|
76
|
-
# === @namespace
|
77
|
-
# ======================================================================= #
|
78
|
-
@namespace = NAMESPACE
|
70
|
+
infer_the_namespace
|
79
71
|
end
|
80
72
|
|
81
73
|
# ========================================================================= #
|
@@ -108,7 +100,7 @@ class Simpsons < MultimediaParadise::Base # === MultimediaParadise::Simpsons.new
|
|
108
100
|
e 'No simpsons-video could be found.'
|
109
101
|
else
|
110
102
|
_ = '"'+use_this_video+'"'.dup
|
111
|
-
_.prepend(MPLAYER_COMMAND_TO_USE)
|
103
|
+
_.prepend("#{use_which_player?} ") # MPLAYER_COMMAND_TO_USE)
|
112
104
|
e _
|
113
105
|
esystem(_)
|
114
106
|
end
|
@@ -4,10 +4,10 @@
|
|
4
4
|
# =========================================================================== #
|
5
5
|
# === MultimediaParadise::Video::SmartAnimals
|
6
6
|
#
|
7
|
-
# This class gathers different videos
|
8
|
-
# hosted on youtube. The idea is that we will download
|
9
|
-
# and then create one new, merged video file that contains
|
10
|
-
# "smart animals" in a single video.
|
7
|
+
# This class gathers different videos of intelligent animals - primarily
|
8
|
+
# videos that are hosted on youtube. The idea is that we will download
|
9
|
+
# these videos and then create one new, merged video file that contains
|
10
|
+
# all these "smart animals" in a single video.
|
11
11
|
#
|
12
12
|
# Usage example:
|
13
13
|
#
|
@@ -15,6 +15,7 @@
|
|
15
15
|
#
|
16
16
|
# =========================================================================== #
|
17
17
|
# require 'multimedia_paradise/video/smart_animals/smart_animals.rb'
|
18
|
+
# MultimediaParadise::Video::SmartAnimals.new(ARGV)
|
18
19
|
# =========================================================================== #
|
19
20
|
require 'multimedia_paradise/base/base.rb'
|
20
21
|
|
@@ -38,7 +39,7 @@ class SmartAnimals < ::MultimediaParadise::Base # === MultimediaParadise::Video:
|
|
38
39
|
# === ARRAY_URL_OF_VIDEOS_THAT_HAVE_TO_BE_DOWNLOADED
|
39
40
|
#
|
40
41
|
# This Array will contain all the relevant remote URLs to videos
|
41
|
-
# showing clever animals.
|
42
|
+
# showing clever animals. It has to be updated manually.
|
42
43
|
# ========================================================================= #
|
43
44
|
_ = <<-EOF
|
44
45
|
|
@@ -51,7 +52,7 @@ class SmartAnimals < ::MultimediaParadise::Base # === MultimediaParadise::Video:
|
|
51
52
|
|
52
53
|
EOF
|
53
54
|
ARRAY_URL_OF_VIDEOS_THAT_HAVE_TO_BE_DOWNLOADED = _.split("\n").map {|entry|
|
54
|
-
if entry.include? '#'
|
55
|
+
if entry.include? '#' # Eliminate comments here.
|
55
56
|
entry = entry.split('#').first.rstrip
|
56
57
|
end
|
57
58
|
entry.strip
|
@@ -90,7 +91,7 @@ EOF
|
|
90
91
|
e
|
91
92
|
e '(1) Creating a directory for hosting the videos '\
|
92
93
|
'showcasing smart animals next:'
|
93
|
-
_ = log_dir
|
94
|
+
_ = "#{log_dir?}smart_animals/"
|
94
95
|
mkdir(_) { :be_verbose }
|
95
96
|
e '(2) Navigating to the directory `'+sdir(_)+'`.'
|
96
97
|
cd(_)
|
@@ -170,7 +171,8 @@ EOF
|
|
170
171
|
# === verbose_add_this_file_to_the_main_array
|
171
172
|
# ========================================================================= #
|
172
173
|
def verbose_add_this_file_to_the_main_array(i)
|
173
|
-
e 'Adding the file '+sfile(i)+
|
174
|
+
e rev+'Adding the file '+sfile(i)+rev+
|
175
|
+
' to the local array of downloaded video files.'
|
174
176
|
@array_all_local_files << i
|
175
177
|
end
|
176
178
|
|
@@ -2,12 +2,17 @@
|
|
2
2
|
# Encoding: UTF-8
|
3
3
|
# frozen_string_literal: true
|
4
4
|
# =========================================================================== #
|
5
|
-
# === MultimediaParadise::SpeedUpVideo
|
5
|
+
# === MultimediaParadise::Video::SpeedUpVideo
|
6
6
|
#
|
7
7
|
# This class can be used to speed up a video, using ffmpeg.
|
8
8
|
#
|
9
9
|
# Usage example:
|
10
|
-
#
|
10
|
+
#
|
11
|
+
# MultimediaParadise::Video::SpeedUpVideo.new
|
12
|
+
#
|
13
|
+
# =========================================================================== #
|
14
|
+
# require 'multimedia_paradise/video/speed_up_video.rb'
|
15
|
+
# MultimediaParadise.speed_up_video(ARGV)
|
11
16
|
# =========================================================================== #
|
12
17
|
require 'multimedia_paradise/base/base.rb'
|
13
18
|
|
@@ -15,7 +20,7 @@ module MultimediaParadise
|
|
15
20
|
|
16
21
|
module Video
|
17
22
|
|
18
|
-
class SpeedUpVideo < MultimediaParadise::Base #
|
23
|
+
class SpeedUpVideo < MultimediaParadise::Base # === MultimediaParadise::Video::SpeedUpVideo
|
19
24
|
|
20
25
|
# ========================================================================= #
|
21
26
|
# === initialize
|
@@ -35,6 +40,8 @@ class SpeedUpVideo < MultimediaParadise::Base # require 'speed_up_video'; SpeedU
|
|
35
40
|
def reset
|
36
41
|
super()
|
37
42
|
# ======================================================================= #
|
43
|
+
# === @speed_up_by_n_percent
|
44
|
+
#
|
38
45
|
# Define the speed-up as percentage-number for the instance
|
39
46
|
# variable @speed_up_by_n_percent. 200 effectively means
|
40
47
|
# "double speed".
|
@@ -108,7 +115,8 @@ class SpeedUpVideo < MultimediaParadise::Base # require 'speed_up_video'; SpeedU
|
|
108
115
|
# ========================================================================= #
|
109
116
|
def run
|
110
117
|
# ======================================================================= #
|
111
|
-
# We will speed up video and audio at the same time
|
118
|
+
# We will speed up video and audio at the same time, for the given
|
119
|
+
# video at hand.
|
112
120
|
# ======================================================================= #
|
113
121
|
_ = 'ffmpeg'.dup
|
114
122
|
_ << ' -i '+input_file?
|
@@ -118,18 +126,28 @@ class SpeedUpVideo < MultimediaParadise::Base # require 'speed_up_video'; SpeedU
|
|
118
126
|
_ << ' -map "[v]" -map "[a]"'
|
119
127
|
_ << ' -y' # Overwrite it: yes.
|
120
128
|
_ << ' output.mkv'
|
121
|
-
|
129
|
+
e
|
130
|
+
esystem _, :steelblue, :use_a_newline
|
122
131
|
end
|
123
132
|
|
124
133
|
# ========================================================================= #
|
125
134
|
# === MultimediaParadise::Video::SpeedUpVideo[]
|
126
135
|
# ========================================================================= #
|
127
|
-
def self.[](i =
|
128
|
-
|
136
|
+
def self.[](i = ARGV)
|
137
|
+
new(i)
|
129
138
|
end
|
130
139
|
|
131
|
-
end; end
|
140
|
+
end; end
|
141
|
+
|
142
|
+
# =========================================================================== #
|
143
|
+
# === MultimediaParadise.speed_up_video
|
144
|
+
# =========================================================================== #
|
145
|
+
def self.speed_up_video(i = ARGV, &block)
|
146
|
+
MultimediaParadise::Video::SpeedUpVideo.new(ARGV, &block)
|
147
|
+
end
|
148
|
+
|
149
|
+
end
|
132
150
|
|
133
151
|
if __FILE__ == $PROGRAM_NAME
|
134
|
-
MultimediaParadise
|
135
|
-
end #
|
152
|
+
MultimediaParadise.speed_up_video(ARGV)
|
153
|
+
end # speedupvideo
|
@@ -9,8 +9,8 @@
|
|
9
9
|
#
|
10
10
|
# It will store this information into a .md file.
|
11
11
|
#
|
12
|
-
# This then allows us to do restorations or at the least notify if
|
13
|
-
#
|
12
|
+
# This then allows us to do restorations or at the least notify if we are
|
13
|
+
# missing something.
|
14
14
|
#
|
15
15
|
# Usage example:
|
16
16
|
#
|
@@ -35,11 +35,25 @@ class StoreAvailableVideoFiles < Base # === MultimediaParadise::StoreAvailableVi
|
|
35
35
|
# === initialize
|
36
36
|
# ========================================================================= #
|
37
37
|
def initialize(
|
38
|
-
i =
|
39
|
-
run_already = true
|
38
|
+
i = ARGV,
|
39
|
+
run_already = true,
|
40
|
+
&block
|
40
41
|
)
|
41
42
|
reset
|
42
|
-
|
43
|
+
set_commandline_arguments(i)
|
44
|
+
# ======================================================================= #
|
45
|
+
# === Handle blocks given to this method next
|
46
|
+
# ======================================================================= #
|
47
|
+
if block_given?
|
48
|
+
yielded = yield
|
49
|
+
case yielded
|
50
|
+
# ===================================================================== #
|
51
|
+
# === :no_opn
|
52
|
+
# ===================================================================== #
|
53
|
+
when :no_opn
|
54
|
+
do_not_use_opn
|
55
|
+
end
|
56
|
+
end
|
43
57
|
run if run_already
|
44
58
|
end
|
45
59
|
|
@@ -52,26 +66,19 @@ class StoreAvailableVideoFiles < Base # === MultimediaParadise::StoreAvailableVi
|
|
52
66
|
end
|
53
67
|
|
54
68
|
# ========================================================================= #
|
55
|
-
# ===
|
56
|
-
#
|
57
|
-
|
58
|
-
i = i.first if i.is_a? Array
|
59
|
-
i = i.to_s.dup
|
60
|
-
@input = i
|
61
|
-
end
|
62
|
-
|
63
|
-
# ========================================================================= #
|
64
|
-
# === input?
|
69
|
+
# === filter_for_video_entries
|
70
|
+
#
|
71
|
+
# This method must filter for entries that are video files.
|
65
72
|
# ========================================================================= #
|
66
|
-
def
|
67
|
-
|
73
|
+
def filter_for_video_entries
|
74
|
+
all_available_videos?.select! {|entry| is_video_file?(entry)}
|
68
75
|
end
|
69
76
|
|
70
77
|
# ========================================================================= #
|
71
|
-
# ===
|
78
|
+
# === all_available_videos?
|
72
79
|
# ========================================================================= #
|
73
|
-
def
|
74
|
-
@all_available_videos
|
80
|
+
def all_available_videos?
|
81
|
+
@all_available_videos
|
75
82
|
end
|
76
83
|
|
77
84
|
# ========================================================================= #
|
@@ -80,37 +87,37 @@ class StoreAvailableVideoFiles < Base # === MultimediaParadise::StoreAvailableVi
|
|
80
87
|
# This method will collect all available video-files.
|
81
88
|
# ========================================================================= #
|
82
89
|
def gather_all_available_videos(
|
83
|
-
from_this_directory =
|
90
|
+
from_this_directory = MultimediaParadise.home_x_video?
|
84
91
|
)
|
85
|
-
@all_available_videos = Dir[from_this_directory
|
92
|
+
@all_available_videos = Dir["#{from_this_directory}**/**"]
|
86
93
|
end
|
87
94
|
|
88
95
|
# ========================================================================= #
|
89
|
-
# ===
|
96
|
+
# === store_the_results
|
90
97
|
#
|
91
98
|
# This method will store the results into a .md file.
|
92
99
|
# ========================================================================= #
|
93
|
-
def
|
100
|
+
def store_the_results
|
94
101
|
ensure_that_the_output_directory_exists
|
95
102
|
# ======================================================================= #
|
96
103
|
# We aggregate the String that has to be saved into the variable
|
97
104
|
# what. This will also include the file-size of the video file
|
98
105
|
# at hand.
|
99
106
|
# ======================================================================= #
|
100
|
-
what =
|
107
|
+
what = all_available_videos?.map {|entry|
|
101
108
|
"#{entry} # file size: #{File.size(entry)}"
|
102
109
|
}
|
103
110
|
what = what.join(N)
|
104
111
|
into = STORE_INTO_THIS_FILE
|
105
|
-
|
112
|
+
opne "#{rev}Now storing into the file at `#{sfile(into)}#{rev}`."
|
106
113
|
write_what_into(what, into)
|
107
114
|
# ======================================================================= #
|
108
115
|
# Also store silently for my home system:
|
109
116
|
# ======================================================================= #
|
110
|
-
_ = '
|
117
|
+
_ = MultimediaParadise.home_x?+'data/personal/video/'
|
111
118
|
if File.directory? _
|
112
|
-
into = _
|
113
|
-
|
119
|
+
into = "#{_}#{File.basename(into)}"
|
120
|
+
opne "#{rev}Storing into the file at `#{sfile(into)}#{rev}` as well."
|
114
121
|
write_what_into(what, into)
|
115
122
|
end
|
116
123
|
end
|
@@ -120,18 +127,27 @@ class StoreAvailableVideoFiles < Base # === MultimediaParadise::StoreAvailableVi
|
|
120
127
|
# ========================================================================= #
|
121
128
|
def run
|
122
129
|
gather_all_available_videos
|
123
|
-
|
124
|
-
|
130
|
+
filter_for_video_entries
|
131
|
+
store_the_results
|
125
132
|
end
|
126
133
|
|
127
134
|
# ========================================================================= #
|
128
135
|
# === MultimediaParadise::StoreAvailableVideoFiles[]
|
129
136
|
# ========================================================================= #
|
130
|
-
def self.[](i =
|
137
|
+
def self.[](i = ARGV)
|
131
138
|
new(i)
|
132
139
|
end
|
133
140
|
|
134
|
-
end
|
141
|
+
end
|
142
|
+
|
143
|
+
# =========================================================================== #
|
144
|
+
# === MultimediaParadise.store_available_video_files
|
145
|
+
# =========================================================================== #
|
146
|
+
def self.store_available_video_files(i = ARGV, &block)
|
147
|
+
MultimediaParadise::StoreAvailableVideoFiles.new(i, &block)
|
148
|
+
end
|
149
|
+
|
150
|
+
end
|
135
151
|
|
136
152
|
if __FILE__ == $PROGRAM_NAME
|
137
153
|
MultimediaParadise::StoreAvailableVideoFiles.new(ARGV)
|
File without changes
|
@@ -9,7 +9,7 @@ module MultimediaParadise
|
|
9
9
|
|
10
10
|
module Video
|
11
11
|
|
12
|
-
require 'multimedia_paradise/constants/
|
12
|
+
require 'multimedia_paradise/constants/constants.rb'
|
13
13
|
|
14
14
|
# ========================================================================= #
|
15
15
|
# === MultimediaParadise::Video.return_good_the_simpsons_episodes
|
@@ -22,7 +22,7 @@ module Video
|
|
22
22
|
# ======================================================================= #
|
23
23
|
# === Season 09
|
24
24
|
# ======================================================================= #
|
25
|
-
base_09 = "#{use_this_as_the_base_directory}
|
25
|
+
base_09 = "#{use_this_as_the_base_directory}cartoons/Simpsons-09/"
|
26
26
|
_ = [
|
27
27
|
'Treehouse_Of_Horror_VIII.m4v',
|
28
28
|
'The_Joy_Of_Sect.m4v'
|
@@ -31,7 +31,7 @@ module Video
|
|
31
31
|
# ======================================================================= #
|
32
32
|
# === Season 08
|
33
33
|
# ======================================================================= #
|
34
|
-
base_08 = "#{use_this_as_the_base_directory}
|
34
|
+
base_08 = "#{use_this_as_the_base_directory}cartoons/Simpsons-08/"
|
35
35
|
_ = [
|
36
36
|
"Homer's_Enemy.m4v",
|
37
37
|
'The_Springfield_Files.m4v',
|
@@ -43,7 +43,7 @@ module Video
|
|
43
43
|
# ======================================================================= #
|
44
44
|
# === Season 07
|
45
45
|
# ======================================================================= #
|
46
|
-
base_07 = "#{use_this_as_the_base_directory}
|
46
|
+
base_07 = "#{use_this_as_the_base_directory}cartoons/Simpsons-07/"
|
47
47
|
_ = [
|
48
48
|
'The_Simpsons_7x21_22_Short_Films_About_Springfield.mp4'
|
49
49
|
# 'The_Simpsons_7x23_Much_Apu_About_Nothing.avi'
|
@@ -52,7 +52,7 @@ module Video
|
|
52
52
|
# ======================================================================= #
|
53
53
|
# === Season 06
|
54
54
|
# ======================================================================= #
|
55
|
-
base_06 = "#{use_this_as_the_base_directory}
|
55
|
+
base_06 = "#{use_this_as_the_base_directory}cartoons/Simpsons-06/"
|
56
56
|
_ = [
|
57
57
|
'Sideshow_Bob_Roberts.m4v',
|
58
58
|
'Homer_the_Great.m4v',
|
@@ -65,7 +65,7 @@ module Video
|
|
65
65
|
# ======================================================================= #
|
66
66
|
# === Season 05
|
67
67
|
# ======================================================================= #
|
68
|
-
base_05 = "#{use_this_as_the_base_directory}
|
68
|
+
base_05 = "#{use_this_as_the_base_directory}cartoons/Simpsons-05/"
|
69
69
|
_ = [
|
70
70
|
'Treehouse_of_Horror_IV.mp4',
|
71
71
|
#'Cape_Feare.mp4',
|
@@ -75,7 +75,7 @@ module Video
|
|
75
75
|
# ======================================================================= #
|
76
76
|
# === Season 04
|
77
77
|
# ======================================================================= #
|
78
|
-
base_04 = "#{use_this_as_the_base_directory}
|
78
|
+
base_04 = "#{use_this_as_the_base_directory}cartoons/Simpsons-04/"
|
79
79
|
_ = [
|
80
80
|
'Treehouse_of_Horror_III.mp4'
|
81
81
|
# 'Marge_Gets_A_Job.mp4',
|
@@ -85,7 +85,7 @@ module Video
|
|
85
85
|
# ======================================================================= #
|
86
86
|
# === Season 03
|
87
87
|
# ======================================================================= #
|
88
|
-
base_03 = "#{use_this_as_the_base_directory}
|
88
|
+
base_03 = "#{use_this_as_the_base_directory}cartoons/Simpsons-03/"
|
89
89
|
_ = [
|
90
90
|
'The_Simpsons_3x03_When_Flanders_Failed.mp4',
|
91
91
|
# 'The_Simpsons_3x01_Stark_Raving_Dad.mp4',
|
@@ -2,23 +2,26 @@
|
|
2
2
|
# Encoding: UTF-8
|
3
3
|
# frozen_string_literal: true
|
4
4
|
# =========================================================================== #
|
5
|
-
# === MultimediaParadise::TheSimpsons
|
5
|
+
# === MultimediaParadise::Video::TheSimpsons
|
6
6
|
#
|
7
|
-
# Currently this class will only store which simpsons episodes I
|
8
|
-
#
|
7
|
+
# Currently this class will only store which simpsons episodes I will
|
8
|
+
# keep about on my local computer system.
|
9
9
|
#
|
10
10
|
# Usage example:
|
11
11
|
#
|
12
|
-
# MultimediaParadise::TheSimpsons.new(ARGV)
|
12
|
+
# MultimediaParadise::Video::TheSimpsons.new(ARGV)
|
13
13
|
#
|
14
14
|
# =========================================================================== #
|
15
|
-
# require 'multimedia_paradise/the_simpsons.rb'
|
15
|
+
# require 'multimedia_paradise/video/the_simpsons/the_simpsons.rb'
|
16
|
+
# MultimediaParadise::Video::TheSimpsons.new(ARGV)
|
16
17
|
# =========================================================================== #
|
17
18
|
require 'multimedia_paradise/base/base.rb'
|
18
19
|
|
19
20
|
module MultimediaParadise
|
20
21
|
|
21
|
-
|
22
|
+
module Video
|
23
|
+
|
24
|
+
class TheSimpsons < Base # === MultimediaParadise::Video::TheSimpsons
|
22
25
|
|
23
26
|
# ========================================================================= #
|
24
27
|
# === DIRECTORY_TO_THE_CARTOONS
|
@@ -44,6 +47,7 @@ class TheSimpsons < Base
|
|
44
47
|
# ========================================================================= #
|
45
48
|
def reset
|
46
49
|
super()
|
50
|
+
infer_the_namespace
|
47
51
|
end
|
48
52
|
|
49
53
|
# ========================================================================= #
|
@@ -74,14 +78,14 @@ class TheSimpsons < Base
|
|
74
78
|
end
|
75
79
|
|
76
80
|
# ========================================================================= #
|
77
|
-
# === MultimediaParadise::TheSimpsons[]
|
81
|
+
# === MultimediaParadise::Video::TheSimpsons[]
|
78
82
|
# ========================================================================= #
|
79
|
-
def self.[](i =
|
83
|
+
def self.[](i = ARGV)
|
80
84
|
new(i)
|
81
85
|
end
|
82
86
|
|
83
|
-
end; end
|
87
|
+
end; end; end
|
84
88
|
|
85
89
|
if __FILE__ == $PROGRAM_NAME
|
86
|
-
MultimediaParadise::TheSimpsons.new(ARGV)
|
90
|
+
MultimediaParadise::Video::TheSimpsons.new(ARGV)
|
87
91
|
end # thesimpsons
|