mirror of
https://gitlab.com/mbunkus/mkvtoolnix.git
synced 2025-01-08 11:11:51 +00:00
260 lines
6.7 KiB
Ruby
260 lines
6.7 KiB
Ruby
$use_tempfile_for_run = defined?(RUBY_PLATFORM) && /mingw/i.match(RUBY_PLATFORM)
|
|
require "tempfile"
|
|
require "fileutils"
|
|
|
|
if defined? Mutex
|
|
$message_mutex = Mutex.new
|
|
def puts(message)
|
|
$message_mutex.lock
|
|
$stdout.puts message
|
|
$stdout.flush
|
|
$message_mutex.unlock
|
|
end
|
|
end
|
|
|
|
def error(message)
|
|
puts message
|
|
exit 1
|
|
end
|
|
|
|
def last_exit_code
|
|
$?.respond_to?(:exitstatus) ? $?.exitstatus : $?.to_i
|
|
end
|
|
|
|
def run cmdline, opts = {}
|
|
code = run_wrapper cmdline, opts
|
|
exit code if (code != 0) && !opts[:allow_failure].to_bool
|
|
end
|
|
|
|
def run_wrapper cmdline, opts = {}
|
|
cmdline = cmdline.gsub(/\n/, ' ').gsub(/^\s+/, '').gsub(/\s+$/, '').gsub(/\s+/, ' ')
|
|
code = nil
|
|
shell = ENV["RUBYSHELL"].blank? ? "c:/msys/bin/sh" : ENV["RUBYSHELL"]
|
|
|
|
puts cmdline unless opts[:dont_echo].to_bool
|
|
|
|
output = nil
|
|
|
|
if opts[:filter_output]
|
|
output = Tempfile.new("mkvtoolnix-rake-output")
|
|
cmdline += " > #{output.path} 2>&1"
|
|
end
|
|
|
|
if $use_tempfile_for_run
|
|
Tempfile.open("mkvtoolnix-rake-run") do |t|
|
|
t.puts cmdline
|
|
t.flush
|
|
system shell, t.path
|
|
code = last_exit_code
|
|
t.unlink
|
|
end
|
|
else
|
|
system cmdline
|
|
code = last_exit_code
|
|
end
|
|
|
|
code = opts[:filter_output].call code, output.readlines if opts[:filter_output]
|
|
|
|
return code
|
|
|
|
ensure
|
|
if output
|
|
output.close
|
|
output.unlink
|
|
end
|
|
end
|
|
|
|
def runq(msg, cmdline, options = {})
|
|
verbose = ENV['V'].to_bool
|
|
puts msg if !verbose
|
|
run cmdline, options.clone.merge(:dont_echo => !verbose)
|
|
end
|
|
|
|
def bin2h bin_file_name, h_file_name
|
|
bin_name = File.basename(bin_file_name).gsub(/[^a-z\d]/i, '_').gsub(/_+/, '_') + '_bin'
|
|
|
|
File.open(h_file_name, "w") do |file|
|
|
file.puts <<EOT
|
|
// Automatically generated. Do not modify.
|
|
#ifndef BIN2H__#{bin_name.upcase}_INCLUDED
|
|
#define BIN2H__#{bin_name.upcase}_INCLUDED
|
|
|
|
static unsigned char #{bin_name}[] = {
|
|
EOT
|
|
|
|
data = IO.binread(bin_file_name).unpack("C*")
|
|
data.each_with_index do |byte, idx|
|
|
file.write sprintf("0x%02x", byte)
|
|
file.write(((idx + 1) % 13) != 0 ? ", " : ",\n") unless (idx == data.size - 1)
|
|
end
|
|
|
|
file.puts <<EOT
|
|
|
|
};
|
|
|
|
#endif // BIN2H__#{bin_name.upcase}_INCLUDED
|
|
EOT
|
|
end
|
|
end
|
|
|
|
def create_dependency_dirs
|
|
[ $dependency_dir, $dependency_tmp_dir ].each do |dir|
|
|
File.unlink(dir) if FileTest.exist?(dir) && !FileTest.directory?(dir)
|
|
Dir.mkdir(dir) if !FileTest.exist?(dir)
|
|
end
|
|
end
|
|
|
|
def dependency_output_name_for file_name
|
|
$dependency_tmp_dir + "/" + file_name.gsub(/[\/\.]/, '_') + '.d'
|
|
end
|
|
|
|
def handle_deps(target, exit_code, skip_abspath=false)
|
|
dep_file = dependency_output_name_for target
|
|
get_out = lambda do
|
|
File.unlink(dep_file) if FileTest.exist?(dep_file)
|
|
exit exit_code if 0 != exit_code
|
|
return
|
|
end
|
|
|
|
FileTest.exist?(dep_file) || get_out.call
|
|
|
|
create_dependency_dirs
|
|
|
|
File.open("#{$dependency_dir}/" + target.gsub(/[\/\.]/, '_') + '.dep', "w") do |out|
|
|
line = IO.readlines(dep_file).collect { |line| line.chomp }.join(" ").gsub(/\\/, ' ').gsub(/\s+/, ' ')
|
|
if /(.+?):\s*([^\s].*)/.match(line)
|
|
target = $1
|
|
sources = $2.gsub(/^\s+/, '').gsub(/\s+$/, '').split(/\s+/)
|
|
|
|
if skip_abspath
|
|
sources.delete_if { |entry| entry.start_with? '/' }
|
|
end
|
|
|
|
out.puts(([ target ] + sources).join("\n"))
|
|
end
|
|
end
|
|
|
|
get_out.call
|
|
rescue Exception => e
|
|
get_out.call
|
|
end
|
|
|
|
def import_dependencies
|
|
return unless FileTest.directory? $dependency_dir
|
|
Dir.glob("#{$dependency_dir}/*.dep").each do |file_name|
|
|
lines = IO.readlines(file_name).collect &:chomp
|
|
target = lines.shift
|
|
file target => lines.select { |dep_name| File.exists? dep_name }
|
|
end
|
|
end
|
|
|
|
def arrayify(*args)
|
|
args.collect { |arg| arg.is_a?(Array) ? arg.to_a : arg }.flatten
|
|
end
|
|
|
|
def install_dir(*dirs)
|
|
arrayify(*dirs).each do |dir|
|
|
dir = c(dir) if dir.is_a? Symbol
|
|
run "#{c(:mkinstalldirs)} #{c(:DESTDIR)}#{dir}"
|
|
end
|
|
end
|
|
|
|
def install_program(destination, *files)
|
|
destination = c(destination) + '/' if destination.is_a? Symbol
|
|
arrayify(*files).each do |file|
|
|
run "#{c(:INSTALL_PROGRAM)} #{file} #{c(:DESTDIR)}#{destination}"
|
|
end
|
|
end
|
|
|
|
def install_data(destination, *files)
|
|
destination = c(destination) + '/' if destination.is_a? Symbol
|
|
arrayify(*files).each do |file|
|
|
run "#{c(:INSTALL_DATA)} #{file} #{c(:DESTDIR)}#{destination}"
|
|
end
|
|
end
|
|
|
|
def adjust_to_poedit_style(in_name, out_name, language)
|
|
File.open(out_name, "w") do |out|
|
|
lines = IO.readlines(in_name).collect { |line| line.chomp.gsub(/\r/, '') }.reject { |line| /^\s*$/.match(line) }
|
|
state = :initial
|
|
previous_state = :initial
|
|
sources = []
|
|
one_source = !$unwrapped_po.include?(language)
|
|
|
|
lines.each do |line|
|
|
previous_state = state
|
|
|
|
if /^#~/.match(line)
|
|
state = :removed
|
|
elsif /^\"/.match(line)
|
|
state = :string
|
|
elsif /^msgstr/.match(line)
|
|
state = :msgstr
|
|
elsif /^#[^:]/.match(line)
|
|
state = :comment
|
|
else
|
|
state = :other
|
|
end
|
|
|
|
if /^(?:#,|msgid)/.match(line)
|
|
if one_source
|
|
sources.each { |source| out.puts "#: #{source}" }
|
|
else
|
|
while !sources.empty?
|
|
new_line = "#:"
|
|
while !sources.empty? && ((new_line.length + sources[0].length + 1) < 80)
|
|
new_line += " " + sources.shift
|
|
end
|
|
out.puts new_line
|
|
end
|
|
end
|
|
|
|
sources = []
|
|
end
|
|
|
|
out.puts if /^#(?:,|:|\s|~\s+msgid)/.match(line) && [:removed, :string, :msgstr].include?(previous_state)
|
|
|
|
if /^#:/.match(line)
|
|
sources += line.gsub(/^#:\s*/, '').split(/\s+/)
|
|
else
|
|
out.puts line
|
|
end
|
|
end
|
|
|
|
out.puts unless %w{es it}.include?(language)
|
|
end
|
|
|
|
File.unlink in_name
|
|
end
|
|
|
|
def remove_files_by_patters patterns
|
|
verbose = ENV['V'].to_bool
|
|
|
|
patterns.collect { |pattern| FileList[pattern].to_a }.flatten.uniq.select { |file_name| File.exists? file_name }.each do |file_name|
|
|
puts " rm #{file_name}" if verbose
|
|
File.unlink file_name
|
|
end
|
|
end
|
|
|
|
def read_files *file_names
|
|
Hash[ *file_names.flatten.collect { |file_name| [ file_name, IO.readlines(file_name) ] }.flatten(1) ]
|
|
end
|
|
|
|
class Rake::Task
|
|
def investigate
|
|
result = "------------------------------\n"
|
|
result << "Investigating #{name}\n"
|
|
result << "class: #{self.class}\n"
|
|
result << "task needed: #{needed?}\n"
|
|
result << "timestamp: #{timestamp}\n"
|
|
result << "pre-requisites:\n"
|
|
prereqs = @prerequisites.collect { |name| Rake::Task[name] }
|
|
prereqs.sort! { |a,b| a.timestamp <=> b.timestamp }
|
|
result += prereqs.collect { |p| "--#{p.name} (#{p.timestamp})\n" }.join("")
|
|
latest_prereq = @prerequisites.collect{|n| Rake::Task[n].timestamp}.max
|
|
result << "latest-prerequisite time: #{latest_prereq}\n"
|
|
result << "................................\n\n"
|
|
return result
|
|
end
|
|
end
|