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
@@ -5,10 +5,10 @@
|
|
5
5
|
# require 'multimedia_paradise/toplevel_methods/encode_this_video.rb'
|
6
6
|
# MultimediaParadise.encode_this_video('foobar.avi')
|
7
7
|
# =========================================================================== #
|
8
|
-
require 'multimedia_paradise/toplevel_methods/esystem.rb'
|
9
|
-
|
10
8
|
module MultimediaParadise
|
11
9
|
|
10
|
+
require 'multimedia_paradise/toplevel_methods/esystem.rb'
|
11
|
+
|
12
12
|
# ========================================================================= #
|
13
13
|
# === MultimediaParadise.encode_this_video
|
14
14
|
#
|
@@ -22,7 +22,8 @@ module MultimediaParadise
|
|
22
22
|
#
|
23
23
|
# ========================================================================= #
|
24
24
|
def self.encode_this_video(
|
25
|
-
i
|
25
|
+
i = ARGV,
|
26
|
+
use_this_mode = :CRF
|
26
27
|
)
|
27
28
|
[i].flatten.compact.each {|this_video|
|
28
29
|
if File.exist? this_video
|
@@ -31,13 +32,16 @@ module MultimediaParadise
|
|
31
32
|
sub(/#{File.extname(this_video)}$/,'')+
|
32
33
|
'.mkv'
|
33
34
|
case use_this_mode
|
35
|
+
# =================================================================== #
|
36
|
+
# === :CRF
|
37
|
+
# =================================================================== #
|
34
38
|
when :CRF, :default
|
35
39
|
_ = 'ffmpeg -i '+this_video+' -c:v libx264 '\
|
36
40
|
'-preset slow -crf 22 -c:a copy '+output_filename
|
37
41
|
esystem _
|
38
42
|
end
|
39
43
|
else
|
40
|
-
|
44
|
+
no_file_exists_at(this_video)
|
41
45
|
end
|
42
46
|
}
|
43
47
|
end
|
@@ -19,23 +19,62 @@ module MultimediaParadise
|
|
19
19
|
# Currently only Hashes are supported like that.
|
20
20
|
# ========================================================================= #
|
21
21
|
def self.esystem(
|
22
|
-
i,
|
22
|
+
i,
|
23
|
+
optional_colour_to_use = nil,
|
24
|
+
use_a_newline_before_the_system_command = false
|
23
25
|
)
|
26
|
+
case use_a_newline_before_the_system_command
|
27
|
+
# ======================================================================= #
|
28
|
+
# === :use_a_newline
|
29
|
+
# ======================================================================= #
|
30
|
+
when :use_a_newline,
|
31
|
+
:use_newline
|
32
|
+
use_a_newline_before_the_system_command = true
|
33
|
+
end
|
24
34
|
Signal.trap('SIGINT') { exit }
|
25
35
|
i = i.dup if i.frozen?
|
26
36
|
i.strip!
|
27
37
|
display_this_string = i.dup
|
28
38
|
if optional_colour_to_use
|
29
|
-
if optional_colour_to_use.is_a?(Hash) and
|
30
|
-
|
31
|
-
|
39
|
+
if (optional_colour_to_use.is_a?(Hash) and
|
40
|
+
optional_colour_to_use.has_key?(:colour)) or
|
41
|
+
optional_colour_to_use.is_a?(Symbol)
|
42
|
+
if optional_colour_to_use.is_a? Hash
|
43
|
+
use_this_colour = optional_colour_to_use[:colour]
|
44
|
+
else
|
45
|
+
use_this_colour = optional_colour_to_use
|
46
|
+
end
|
32
47
|
display_this_string = COLOURS.send(use_this_colour, display_this_string)
|
33
48
|
end
|
34
49
|
end
|
35
50
|
e display_this_string
|
51
|
+
e if use_a_newline_before_the_system_command
|
36
52
|
system i
|
37
53
|
end
|
38
54
|
|
55
|
+
# ========================================================================= #
|
56
|
+
# === MultimediaParadise.run_sys_command (sys tag, sys cmd)
|
57
|
+
#
|
58
|
+
# Echo the command before running it via ``. This is the main difference
|
59
|
+
# towards the other method called MultimediaParadise.esystem().
|
60
|
+
# ========================================================================= #
|
61
|
+
def self.run_sys_command(
|
62
|
+
cmd,
|
63
|
+
pad_the_output = true
|
64
|
+
)
|
65
|
+
cmd = cmd.strip
|
66
|
+
e if pad_the_output
|
67
|
+
e cmd
|
68
|
+
e if pad_the_output
|
69
|
+
begin
|
70
|
+
result = `#{cmd}` # Sigint event can happen here.
|
71
|
+
return result
|
72
|
+
rescue Errno::ENOENT => error
|
73
|
+
e "No such file exists. (#{error})"
|
74
|
+
return nil
|
75
|
+
end
|
76
|
+
end
|
77
|
+
|
39
78
|
end
|
40
79
|
|
41
80
|
if __FILE__ == $PROGRAM_NAME
|
@@ -2,7 +2,11 @@
|
|
2
2
|
# Encoding: UTF-8
|
3
3
|
# frozen_string_literal: true
|
4
4
|
# =========================================================================== #
|
5
|
-
#
|
5
|
+
# This file will specifically include code that relates to ffmpeg. On top
|
6
|
+
# of that, most methods (or even all methods) that are listed here will
|
7
|
+
# start with the substring "ffmpeg_".
|
8
|
+
# =========================================================================== #
|
9
|
+
# require 'multimedia_paradise/toplevel_methods/ffmpeg.rb'
|
6
10
|
# =========================================================================== #
|
7
11
|
module MultimediaParadise
|
8
12
|
|
@@ -49,6 +53,145 @@ module MultimediaParadise
|
|
49
53
|
alias return_image_from_this_video_file ffmpeg_return_image_from_this_video_file # === MultimediaParadise.return_image_from_this_video_file
|
50
54
|
}
|
51
55
|
|
56
|
+
# ========================================================================= #
|
57
|
+
# === MultimediaParadise.ffmpeg_slow_down_this_video_file
|
58
|
+
#
|
59
|
+
# This method can be used to slow down a video file.
|
60
|
+
#
|
61
|
+
# FFmpeg will be doing this slow down action.
|
62
|
+
#
|
63
|
+
# This uses the "setpts" video filter of ffmpeg, for the video stream
|
64
|
+
# at hand. The video stream can be changed without tampering with
|
65
|
+
# the audio stream. This is also the default modus operandi for this
|
66
|
+
# method here.
|
67
|
+
# ========================================================================= #
|
68
|
+
def self.ffmpeg_slow_down_this_video_file(
|
69
|
+
this_video_file = ARGV,
|
70
|
+
pts_value_to_use = 2.0
|
71
|
+
)
|
72
|
+
if this_video_file.is_a? Array
|
73
|
+
this_video_file.each {|entry|
|
74
|
+
ffmpeg_slow_down_this_video_file(entry, pts_value_to_use)
|
75
|
+
}
|
76
|
+
else
|
77
|
+
# ===================================================================== #
|
78
|
+
# To slow down a video, a multiplier greater than 1 has to be used:
|
79
|
+
# ===================================================================== #
|
80
|
+
_ = "ffmpeg -i #{this_video_file} -filter:v \"setpts=#{pts_value_to_use}*PTS\" "\
|
81
|
+
"OUTPUT_SLOWED_DOWN_VIDEO_#{this_video_file}"
|
82
|
+
esystem _
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
# ========================================================================= #
|
87
|
+
# === MultimediaParadise.ffmpeg_flip_video_to_the_right
|
88
|
+
#
|
89
|
+
# This toplevel-method can be used to flip a video to the right,
|
90
|
+
# that is, to rotate it by +90 degrees.
|
91
|
+
# ========================================================================= #
|
92
|
+
def self.ffmpeg_flip_video_to_the_right(i)
|
93
|
+
_ = "ffmpeg -i #{i} -vf transpose=1 flipped_to_the_right_#{i}"
|
94
|
+
esystem _
|
95
|
+
end
|
96
|
+
|
97
|
+
# ========================================================================= #
|
98
|
+
# === MultimediaParadise.ffmpeg_flip_video_to_the_left
|
99
|
+
#
|
100
|
+
# This toplevel-method can be used to flip a video to the left,
|
101
|
+
# that is, to rotate it by -90 degrees.
|
102
|
+
#
|
103
|
+
# Strangely enough the number 2 denotes left-hand flipping (or,
|
104
|
+
# to remain in ffmpeg-parlance, this means "90°CounterClockwise"
|
105
|
+
# rotation).
|
106
|
+
# ========================================================================= #
|
107
|
+
def self.ffmpeg_flip_video_to_the_left(i)
|
108
|
+
_ = "ffmpeg -i #{i} -vf transpose=2 flipped_to_the_left_#{i}"
|
109
|
+
esystem _
|
110
|
+
end
|
111
|
+
|
112
|
+
# ========================================================================= #
|
113
|
+
# === MultimediaParadise.ffmpeg_extract_audio
|
114
|
+
#
|
115
|
+
# This method will specifically use ffmpeg in order to extract the
|
116
|
+
# audio from a video or audio file.
|
117
|
+
# ========================================================================= #
|
118
|
+
def self.ffmpeg_extract_audio(
|
119
|
+
i = input.mkv, # The input filename.
|
120
|
+
o = :ogg # The output filename.
|
121
|
+
)
|
122
|
+
extname = File.extname(i)
|
123
|
+
case o
|
124
|
+
# ======================================================================= #
|
125
|
+
# === :ogg
|
126
|
+
# ======================================================================= #
|
127
|
+
when :ogg
|
128
|
+
use_this_name = i.
|
129
|
+
sub(/#{extname}$/,'')
|
130
|
+
o = use_this_name+'.ogg'
|
131
|
+
end
|
132
|
+
esystem 'ffmpeg -i '+i+' -vn '+o
|
133
|
+
end
|
134
|
+
|
135
|
+
# ========================================================================= #
|
136
|
+
# === MultimediaParadise.ffmpeg_convert_this_multimedia_file
|
137
|
+
#
|
138
|
+
# This method can be used to convert a file from A to B, through
|
139
|
+
# ffmpeg.
|
140
|
+
#
|
141
|
+
# Remember that the command ffmpeg -codecs will print every codec
|
142
|
+
# FFmpeg knows about.
|
143
|
+
# ========================================================================= #
|
144
|
+
def self.ffmpeg_convert_this_multimedia_file(
|
145
|
+
input_file = 'input.mp3',
|
146
|
+
output_file = :mkv #'output.ogg'
|
147
|
+
)
|
148
|
+
yielded = nil
|
149
|
+
if block_given?
|
150
|
+
yielded = yield
|
151
|
+
end
|
152
|
+
if File.exist? input_file
|
153
|
+
case output_file
|
154
|
+
when :mkv
|
155
|
+
extname = File.extname(input_file)
|
156
|
+
use_this_name = input_file.
|
157
|
+
sub(/#{extname}$/,'')
|
158
|
+
output_file = use_this_name+'.mkv'
|
159
|
+
end
|
160
|
+
_ = "ffmpeg -i #{input_file}"
|
161
|
+
case yielded
|
162
|
+
# ===================================================================== #
|
163
|
+
# === :copy_audio
|
164
|
+
# ===================================================================== #
|
165
|
+
when :copy_audio
|
166
|
+
_ << ' -c:a copy'
|
167
|
+
# ===================================================================== #
|
168
|
+
# === :libvorbis_audiostream
|
169
|
+
# ===================================================================== #
|
170
|
+
when :libvorbis_audiostream
|
171
|
+
_ << ' -c:a libvorbis'
|
172
|
+
# ===================================================================== #
|
173
|
+
# === :vp9_codec
|
174
|
+
# ===================================================================== #
|
175
|
+
when :vp9_codec
|
176
|
+
_ << ' -c:v vp9'
|
177
|
+
else
|
178
|
+
if yielded.is_a? Hash
|
179
|
+
# ================================================================= #
|
180
|
+
# === :framerate
|
181
|
+
# ================================================================= #
|
182
|
+
if yielded.has_key? :framerate
|
183
|
+
_ << " -r #{yielded.delete(:framerate)}"
|
184
|
+
end
|
185
|
+
end
|
186
|
+
end
|
187
|
+
_ << " #{output_file}"
|
188
|
+
e _
|
189
|
+
system _
|
190
|
+
else
|
191
|
+
e 'No file exists at '+input_file+'.'
|
192
|
+
end
|
193
|
+
end
|
194
|
+
|
52
195
|
# ========================================================================= #
|
53
196
|
# === MultimediaParadise.ffmpeg_chroma_subsampling
|
54
197
|
#
|
@@ -72,7 +215,7 @@ module MultimediaParadise
|
|
72
215
|
# effect.
|
73
216
|
#
|
74
217
|
# Yadif ("yet another deinterlacing filter") is the name of the
|
75
|
-
# filter used by ffmpeg.
|
218
|
+
# filter used by ffmpeg.
|
76
219
|
# ========================================================================= #
|
77
220
|
def self.ffmpeg_deinterlace_this_video(this_video)
|
78
221
|
esystem 'ffmpeg -i '+this_video+' -vf yadif output.mp4'
|
@@ -181,88 +324,6 @@ module MultimediaParadise
|
|
181
324
|
end; self.instance_eval { alias ffmpeg_audio_codec? ffmpeg_query_the_audio_codec_of_this_file } # === MultimediaParadise.ffmpeg_audio_codec?
|
182
325
|
self.instance_eval { alias ffmpeg_query_the_audio_codec ffmpeg_query_the_audio_codec_of_this_file } # === MultimediaParadise.ffmpeg_query_the_audio_codec
|
183
326
|
|
184
|
-
# ========================================================================= #
|
185
|
-
# === MultimediaParadise.ffmpeg_vertical_flip
|
186
|
-
#
|
187
|
-
# This method will make use of the video-filter called "vflip". A
|
188
|
-
# vertical flip will flip the video from head-to-bottom, so people
|
189
|
-
# will suddenly appear as if they are hanging from the ceiling. :)
|
190
|
-
#
|
191
|
-
# Invocation example:
|
192
|
-
#
|
193
|
-
# MultimediaParadise.ffmpeg_vertical_flip '/Depot/Video/Reallife/O.J.Simpson_TV_News_etwa_1995.avi'
|
194
|
-
#
|
195
|
-
# ========================================================================= #
|
196
|
-
def self.ffmpeg_vertical_flip(this_video_file)
|
197
|
-
if this_video_file.is_a? Array
|
198
|
-
this_video_file.each {|entry| ffmpeg_vertical_flip(entry) }
|
199
|
-
else
|
200
|
-
extname = File.extname(this_video_file)
|
201
|
-
base_dir = File.dirname(this_video_file)
|
202
|
-
filename = File.basename(this_video_file)
|
203
|
-
output_name = base_dir+'/vertical_flip_'+filename.sub(/#{extname}/,'')+extname
|
204
|
-
_ = 'ffmpeg -i '+this_video_file+' -vf "vflip" '+output_name
|
205
|
-
esystem _
|
206
|
-
output_name # <- Also return the output name here.
|
207
|
-
end
|
208
|
-
end; self.instance_eval { alias ffmpeg_flip_upside_down ffmpeg_vertical_flip } # === MultimediaParadise.flip_upside_down
|
209
|
-
|
210
|
-
# ========================================================================= #
|
211
|
-
# === MultimediaParadise.ffmpeg_horizontal_flip
|
212
|
-
#
|
213
|
-
# This method will make use of the video-filter called "hflip".
|
214
|
-
# ========================================================================= #
|
215
|
-
def self.ffmpeg_horizontal_flip(this_video_file)
|
216
|
-
if this_video_file.is_a? Array
|
217
|
-
this_video_file.each {|entry| horizontal_flip(entry) }
|
218
|
-
else
|
219
|
-
extname = File.extname(this_video_file)
|
220
|
-
output_name = 'horizontal_flip_'+this_video_file.sub(/#{extname}/,'')+extname
|
221
|
-
_ = 'ffmpeg -i '+this_video_file+' -vf "hflip" '+output_name
|
222
|
-
esystem _
|
223
|
-
output_name # <- Also return the output filename here.
|
224
|
-
end
|
225
|
-
end
|
226
|
-
|
227
|
-
# ========================================================================= #
|
228
|
-
# === MultimediaParadise.ffmpeg_rotate_this_video_file_by_90_degrees
|
229
|
-
#
|
230
|
-
# This method can be used to rotate a video file by 90°. Sometimes
|
231
|
-
# smartphones create tilted videos, so this method can correct
|
232
|
-
# this distortion.
|
233
|
-
#
|
234
|
-
# This can be fixed by using FFMPEG's transpose filter. The
|
235
|
-
# transpose value will work in multiples of 90, so "1"
|
236
|
-
# means 90°.
|
237
|
-
#
|
238
|
-
# Invocation example:
|
239
|
-
#
|
240
|
-
# MultimediaParadise.ffmpeg_rotate_this_video_file_by_90_degrees('foo.mpg')
|
241
|
-
#
|
242
|
-
# ========================================================================= #
|
243
|
-
def self.ffmpeg_rotate_this_video_file_by_90_degrees(
|
244
|
-
this_video_file
|
245
|
-
)
|
246
|
-
output_file = 'output_'+this_video_file+'.mp4'
|
247
|
-
_ = 'ffmpeg -i '+this_video_file+' -vf transpose=1 '+output_file
|
248
|
-
esystem _
|
249
|
-
output_file # <- And return the output file too.
|
250
|
-
end
|
251
|
-
|
252
|
-
# ========================================================================= #
|
253
|
-
# === MultimediaParadise.ffmpeg_increase_volume_of_this_audio_file
|
254
|
-
# ========================================================================= #
|
255
|
-
def self.ffmpeg_increase_volume_of_this_audio_file(
|
256
|
-
input_file,
|
257
|
-
modify_volume_by_this_value = '5.0' # or 3.0 or 4.0 and so forth.
|
258
|
-
)
|
259
|
-
[input_file].flatten.compact.each {|this_file|
|
260
|
-
_ = 'ffmpeg -i '+this_file+' -vcodec copy -af "volume='+modify_volume_by_this_value.to_s+
|
261
|
-
'" output_'+this_file
|
262
|
-
esystem _
|
263
|
-
}
|
264
|
-
end
|
265
|
-
|
266
327
|
# ========================================================================= #
|
267
328
|
# === MultimediaParadise.ffmpeg_start_screencast
|
268
329
|
#
|
@@ -478,139 +539,85 @@ module MultimediaParadise
|
|
478
539
|
end
|
479
540
|
|
480
541
|
# ========================================================================= #
|
481
|
-
# === MultimediaParadise.
|
542
|
+
# === MultimediaParadise.ffmpeg_vertical_flip
|
482
543
|
#
|
483
|
-
# This method
|
544
|
+
# This method will make use of the video-filter called "vflip". A
|
545
|
+
# vertical flip will flip the video from head-to-bottom, so people
|
546
|
+
# will suddenly appear as if they are hanging from the ceiling. :)
|
484
547
|
#
|
485
|
-
#
|
548
|
+
# Invocation example:
|
549
|
+
#
|
550
|
+
# MultimediaParadise.ffmpeg_vertical_flip '/Depot/Video/Reallife/O.J.Simpson_TV_News_etwa_1995.avi'
|
486
551
|
#
|
487
|
-
# This uses the "setpts" video filter of ffmpeg, for the video stream
|
488
|
-
# at hand. The video stream can be changed without tampering with
|
489
|
-
# the audio stream. This is also the default modus operandi for this
|
490
|
-
# method here.
|
491
552
|
# ========================================================================= #
|
492
|
-
def self.
|
493
|
-
this_video_file = ARGV,
|
494
|
-
pts_value_to_use = 2.0
|
495
|
-
)
|
553
|
+
def self.ffmpeg_vertical_flip(this_video_file)
|
496
554
|
if this_video_file.is_a? Array
|
497
|
-
this_video_file.each {|entry|
|
498
|
-
ffmpeg_slow_down_this_video_file(entry, pts_value_to_use)
|
499
|
-
}
|
555
|
+
this_video_file.each {|entry| ffmpeg_vertical_flip(entry) }
|
500
556
|
else
|
501
|
-
|
502
|
-
|
503
|
-
|
504
|
-
|
505
|
-
|
557
|
+
extname = File.extname(this_video_file)
|
558
|
+
base_dir = File.dirname(this_video_file)
|
559
|
+
filename = File.basename(this_video_file)
|
560
|
+
output_name = base_dir+'/vertical_flip_'+filename.sub(/#{extname}/,'')+extname
|
561
|
+
_ = 'ffmpeg -i '+this_video_file+' -vf "vflip" '+output_name
|
506
562
|
esystem _
|
563
|
+
output_name # <- Also return the output name here.
|
507
564
|
end
|
508
|
-
end
|
565
|
+
end; self.instance_eval { alias ffmpeg_flip_upside_down ffmpeg_vertical_flip } # === MultimediaParadise.flip_upside_down
|
509
566
|
|
510
567
|
# ========================================================================= #
|
511
|
-
# === MultimediaParadise.
|
568
|
+
# === MultimediaParadise.ffmpeg_horizontal_flip
|
512
569
|
#
|
513
|
-
# This
|
514
|
-
# that is, to rotate it by +90 degrees.
|
570
|
+
# This method will make use of the video-filter called "hflip".
|
515
571
|
# ========================================================================= #
|
516
|
-
def self.
|
517
|
-
|
518
|
-
|
572
|
+
def self.ffmpeg_horizontal_flip(this_video_file)
|
573
|
+
if this_video_file.is_a? Array
|
574
|
+
this_video_file.each {|entry| horizontal_flip(entry) }
|
575
|
+
else
|
576
|
+
extname = File.extname(this_video_file)
|
577
|
+
output_name = 'horizontal_flip_'+this_video_file.sub(/#{extname}/,'')+extname
|
578
|
+
_ = 'ffmpeg -i '+this_video_file+' -vf "hflip" '+output_name
|
579
|
+
esystem _
|
580
|
+
output_name # <- Also return the output filename here.
|
581
|
+
end
|
519
582
|
end
|
520
583
|
|
521
584
|
# ========================================================================= #
|
522
|
-
# === MultimediaParadise.
|
585
|
+
# === MultimediaParadise.ffmpeg_rotate_this_video_file_by_90_degrees
|
523
586
|
#
|
524
|
-
# This
|
525
|
-
#
|
587
|
+
# This method can be used to rotate a video file by 90°. Sometimes
|
588
|
+
# smartphones create tilted videos, so this method can correct
|
589
|
+
# this distortion.
|
526
590
|
#
|
527
|
-
#
|
528
|
-
#
|
529
|
-
#
|
530
|
-
# ========================================================================= #
|
531
|
-
def self.ffmpeg_flip_video_to_the_left(i)
|
532
|
-
_ = "ffmpeg -i #{i} -vf transpose=2 flipped_to_the_left_#{i}"
|
533
|
-
esystem _
|
534
|
-
end
|
535
|
-
|
536
|
-
# ========================================================================= #
|
537
|
-
# === MultimediaParadise.ffmpeg_extract_audio
|
591
|
+
# This can be fixed by using FFMPEG's transpose filter. The
|
592
|
+
# transpose value will work in multiples of 90, so "1"
|
593
|
+
# means 90°.
|
538
594
|
#
|
539
|
-
#
|
540
|
-
#
|
541
|
-
#
|
542
|
-
|
543
|
-
|
544
|
-
|
595
|
+
# Invocation example:
|
596
|
+
#
|
597
|
+
# MultimediaParadise.ffmpeg_rotate_this_video_file_by_90_degrees('foo.mpg')
|
598
|
+
#
|
599
|
+
# ========================================================================= #
|
600
|
+
def self.ffmpeg_rotate_this_video_file_by_90_degrees(
|
601
|
+
this_video_file
|
545
602
|
)
|
546
|
-
|
547
|
-
|
548
|
-
|
549
|
-
|
550
|
-
sub(/#{extname}$/,'')
|
551
|
-
o = use_this_name+'.ogg'
|
552
|
-
end
|
553
|
-
esystem 'ffmpeg -i '+i+' -vn '+o
|
603
|
+
output_file = 'output_'+this_video_file+'.mp4'
|
604
|
+
_ = 'ffmpeg -i '+this_video_file+' -vf transpose=1 '+output_file
|
605
|
+
esystem _
|
606
|
+
output_file # <- And return the output file too.
|
554
607
|
end
|
555
608
|
|
556
609
|
# ========================================================================= #
|
557
|
-
# === MultimediaParadise.
|
558
|
-
#
|
559
|
-
# This method can be used to convert a file from A to B, through
|
560
|
-
# ffmpeg.
|
561
|
-
#
|
562
|
-
# Remember that the command ffmpeg -codecs will print every codec
|
563
|
-
# FFmpeg knows about.
|
610
|
+
# === MultimediaParadise.ffmpeg_increase_volume_of_this_audio_file
|
564
611
|
# ========================================================================= #
|
565
|
-
def self.
|
566
|
-
input_file
|
567
|
-
|
612
|
+
def self.ffmpeg_increase_volume_of_this_audio_file(
|
613
|
+
input_file,
|
614
|
+
modify_volume_by_this_value = '5.0' # or 3.0 or 4.0 and so forth.
|
568
615
|
)
|
569
|
-
|
570
|
-
|
571
|
-
|
572
|
-
|
573
|
-
|
574
|
-
case output_file
|
575
|
-
when :mkv
|
576
|
-
extname = File.extname(input_file)
|
577
|
-
use_this_name = input_file.
|
578
|
-
sub(/#{extname}$/,'')
|
579
|
-
output_file = use_this_name+'.mkv'
|
580
|
-
end
|
581
|
-
_ = "ffmpeg -i #{input_file}"
|
582
|
-
case yielded
|
583
|
-
# ===================================================================== #
|
584
|
-
# === :copy_audio
|
585
|
-
# ===================================================================== #
|
586
|
-
when :copy_audio
|
587
|
-
_ << ' -c:a copy'
|
588
|
-
# ===================================================================== #
|
589
|
-
# === :libvorbis_audiostream
|
590
|
-
# ===================================================================== #
|
591
|
-
when :libvorbis_audiostream
|
592
|
-
_ << ' -c:a libvorbis'
|
593
|
-
# ===================================================================== #
|
594
|
-
# === :vp9_codec
|
595
|
-
# ===================================================================== #
|
596
|
-
when :vp9_codec
|
597
|
-
_ << ' -c:v vp9'
|
598
|
-
else
|
599
|
-
if yielded.is_a? Hash
|
600
|
-
# ================================================================= #
|
601
|
-
# === :framerate
|
602
|
-
# ================================================================= #
|
603
|
-
if yielded.has_key? :framerate
|
604
|
-
_ << " -r #{yielded.delete(:framerate)}"
|
605
|
-
end
|
606
|
-
end
|
607
|
-
end
|
608
|
-
_ << " #{output_file}"
|
609
|
-
e _
|
610
|
-
system _
|
611
|
-
else
|
612
|
-
e 'No file exists at '+input_file+'.'
|
613
|
-
end
|
616
|
+
[input_file].flatten.compact.each {|this_file|
|
617
|
+
_ = 'ffmpeg -i '+this_file+' -vcodec copy -af "volume='+modify_volume_by_this_value.to_s+
|
618
|
+
'" output_'+this_file
|
619
|
+
esystem _
|
620
|
+
}
|
614
621
|
end
|
615
622
|
|
616
623
|
end
|
data/lib/multimedia_paradise/toplevel_methods/{files_and_directories.rb → files_related_code.rb}
RENAMED
@@ -2,69 +2,30 @@
|
|
2
2
|
# Encoding: UTF-8
|
3
3
|
# frozen_string_literal: true
|
4
4
|
# =========================================================================== #
|
5
|
-
#
|
6
|
-
# cd-related actions, removal of files, creation of files and so forth.
|
7
|
-
# =========================================================================== #
|
8
|
-
# require 'multimedia_paradise/toplevel_methods/files_and_directories.rb'
|
9
|
-
# MultimediaParadise.chdir
|
5
|
+
# require 'multimedia_paradise/toplevel_methods/files_related_code.rb'
|
10
6
|
# =========================================================================== #
|
11
7
|
module MultimediaParadise
|
12
8
|
|
13
9
|
require 'fileutils'
|
14
10
|
require 'multimedia_paradise/toplevel_methods/e.rb'
|
11
|
+
require 'multimedia_paradise/toplevel_methods/is_on_roebe.rb'
|
15
12
|
require 'multimedia_paradise/colours/colours.rb'
|
16
13
|
|
17
14
|
# ========================================================================= #
|
18
|
-
# === MultimediaParadise.
|
19
|
-
#
|
20
|
-
# This method can be used to move a file - in other words, to rename it.
|
15
|
+
# === MultimediaParadise.copy_file
|
21
16
|
# ========================================================================= #
|
22
|
-
def self.
|
23
|
-
FileUtils.
|
24
|
-
end; self.instance_eval { alias mv move_file } # === MultimediaParadise.mv
|
25
|
-
self.instance_eval { alias rename_file move_file } # === MultimediaParadise.rename_file
|
26
|
-
|
27
|
-
# ========================================================================= #
|
28
|
-
# === MultimediaParadise.remove_file
|
29
|
-
#
|
30
|
-
# Remove a given file, without any further checks.
|
31
|
-
# ========================================================================= #
|
32
|
-
def self.remove_file(i)
|
33
|
-
File.delete(i) if File.exist?(i)
|
34
|
-
end; self.instance_eval { alias delete_file remove_file } # === MultimediaParadise.delete_file
|
35
|
-
|
36
|
-
# ========================================================================= #
|
37
|
-
# === remove_file
|
38
|
-
# ========================================================================= #
|
39
|
-
def remove_file(i)
|
40
|
-
MultimediaParadise.remove_file(i)
|
41
|
-
end
|
42
|
-
|
43
|
-
# ========================================================================= #
|
44
|
-
# === MultimediaParadise.mkdir
|
45
|
-
#
|
46
|
-
# This method can be used to create a directory on the local computer
|
47
|
-
# system.
|
48
|
-
# ========================================================================= #
|
49
|
-
def self.mkdir(i)
|
50
|
-
FileUtils.mkdir_p(i)
|
51
|
-
end
|
52
|
-
|
53
|
-
# ========================================================================= #
|
54
|
-
# === mkdir
|
55
|
-
# ========================================================================= #
|
56
|
-
def mkdir(i)
|
57
|
-
MultimediaParadise.mkdir(i)
|
17
|
+
def self.copy_file(from, to)
|
18
|
+
FileUtils.cp(from, to)
|
58
19
|
end
|
59
20
|
|
60
21
|
# ========================================================================= #
|
61
22
|
# === MultimediaParadise.rename
|
62
23
|
#
|
63
|
-
# This perform a rename-action, using mv.
|
24
|
+
# This method will perform a rename-action, using mv.
|
64
25
|
# ========================================================================= #
|
65
26
|
def self.rename(from, to)
|
66
27
|
if File.exist? from
|
67
|
-
e rev
|
28
|
+
e "#{rev}Now renaming `"+sfile(from.to_s)+rev+'` to `'+sfile(to.to_s)+rev+'`.'
|
68
29
|
FileUtils.mv(from, to)
|
69
30
|
else
|
70
31
|
e "#{rev}Can not rename `#{sfancy(from)}` as it does not exist."
|
@@ -73,20 +34,22 @@ module MultimediaParadise
|
|
73
34
|
self.instance_eval { alias rename_file rename } # === MultimediaParadise.rename_file
|
74
35
|
|
75
36
|
# ========================================================================= #
|
76
|
-
# ===
|
37
|
+
# === MultimediaParadise.move_file
|
38
|
+
#
|
39
|
+
# This method can be used to move a file - in other words, to rename it.
|
77
40
|
# ========================================================================= #
|
78
|
-
def
|
79
|
-
|
80
|
-
end; alias
|
41
|
+
def self.move_file(old, new)
|
42
|
+
FileUtils.mv(old, new)
|
43
|
+
end; self.instance_eval { alias mv move_file } # === MultimediaParadise.mv
|
44
|
+
self.instance_eval { alias rename_file move_file } # === MultimediaParadise.rename_file
|
81
45
|
|
82
46
|
# ========================================================================= #
|
83
|
-
# === MultimediaParadise.
|
47
|
+
# === MultimediaParadise.remove_file
|
84
48
|
#
|
85
|
-
#
|
86
|
-
# directory.
|
49
|
+
# Remove a given file, without any further checks.
|
87
50
|
# ========================================================================= #
|
88
|
-
def self.
|
89
|
-
|
90
|
-
end; self.instance_eval { alias
|
51
|
+
def self.remove_file(i)
|
52
|
+
File.delete(i) if File.exist?(i)
|
53
|
+
end; self.instance_eval { alias delete_file remove_file } # === MultimediaParadise.delete_file
|
91
54
|
|
92
55
|
end
|