lib/usps_flags/generate.rb in usps_flags-0.3.5 vs lib/usps_flags/generate.rb in usps_flags-0.3.6
- old
+ new
@@ -52,18 +52,15 @@
# @param [Boolean] svg Whether to generate SVG images.
# @param [Boolean] png Whether to generate PNG images.
# @param [Boolean] zips Whether to create zip archives for all images created. Does not create a zip for skipped formats.
# @param [Boolean] reset Whether to delete all previous files before generating new files.
def all(svg: true, png: true, zips: true, reset: true)
- raise USPSFlags::Errors::StaticFilesGenerationError, "At least one argument switch must be true out of [svg, png, zips]." unless svg || png || zips
+ raise USPSFlags::Errors::StaticFilesGenerationError, "At least one argument switch must be true out of [svg, png, zips, reset]." unless svg || png || zips || reset
- remove_static_files if reset
- static_generation_header
overall_start_time = Time.now
- USPSFlags::Helpers.valid_flags(:all).each do |flag|
- generate_static_images_for(flag, svg: svg, png: png)
- end
+ remove_static_files if reset
+ images(svg: svg, png: png) if svg || png
zips(svg: svg, png: png) if zips
USPSFlags::Helpers.log "\nTotal run time: #{Time.now - overall_start_time} s\n\n"
end
# Generate zip archives of current static image files.
@@ -74,19 +71,29 @@
raise USPSFlags::Errors::ZipGenerationError, "At least one argument switch must be true out of [svg, png]." unless svg || png
generate_zip("svg") if svg
generate_zip("png") if png
end
+ # Generate static image files.
+ #
+ # @param [Boolean] svg Generate static SVG images.
+ # @param [Boolean] png Generate static PNG images.
+ def images(svg: true, png: true)
+ static_generation_header
+ USPSFlags::Helpers.valid_flags(:all).each do |flag|
+ generate_static_images_for(flag, svg: svg, png: png)
+ end
+ end
+
# Generate trident spec sheet as an SVG image.
#
# @param [String] outfile The path to save the SVG file to. If not set, prints to console.
# @param [Integer] fly The nominal fly length of an appropriate flag field for the generated tridents. Size labels scale to this size.
# @param [String] outfile The unit to append to all trident measurements.
# @param [String] scale The image scale divisor factor.
# @return [String] Returns the SVG data.
- def spec(outfile: nil, fly: nil, unit: nil, scale: nil)
- fly = fly.nil? ? USPSFlags::Config::BASE_FLY : fly
+ def spec(outfile: nil, fly: USPSFlags::Config::BASE_FLY, unit: nil, scale: nil)
svg = ""
svg << USPSFlags::Core.headers(scale: scale, title: "USPS Trident Specifications")
svg << USPSFlags::Core.trident_spec(fly: fly, unit: unit)
svg << USPSFlags::Core.footer
@@ -101,12 +108,12 @@
end
["SVG/insignia", "PNG/insignia"].each { |dir| ::FileUtils.mkdir_p("#{USPSFlags::Config.flags_dir}/#{dir}") }
USPSFlags::Helpers.log "\n - Cleared previous files.\n"
end
- def set_file_paths(flag)
- @svg_file = "#{USPSFlags::Config.flags_dir}/SVG/#{flag}.svg"
+ def set_file_paths
+ @svg_file = "#{USPSFlags::Config.flags_dir}/SVG/#{@flag}.svg"
@png_file = @svg_file.gsub("/SVG/", "/PNG/").gsub(".svg", ".png")
@svg_ins_file = @svg_file.gsub("/SVG/", "/SVG/insignia/")
@png_ins_file = @svg_file.gsub("/SVG/", "/PNG/insignia/").gsub(".svg", ".png")
[@svg_file, @png_file, @svg_ins_file, @png_ins_file]
end
@@ -142,82 +149,98 @@
end
def generate_static_images_for(flag, svg: true, png: true)
start_time = Time.now
# USPSFlags::Helpers.log " | | _ _ _ _ _ | \r".rjust(USPSFlags::Helpers.max_flag_name_length+31, " ")
- flag = flag.upcase
- USPSFlags::Helpers.log "#{flag.rjust(USPSFlags::Helpers.max_flag_name_length)} |"
+ @flag = flag.upcase
+ USPSFlags::Helpers.log "#{@flag.rjust(USPSFlags::Helpers.max_flag_name_length)} |"
- set_file_paths(flag)
+ set_file_paths
- svg ? generate_static_svg(flag) : USPSFlags::Helpers.log("-")
- png ? generate_static_png(flag) : USPSFlags::Helpers.log("- ")
+ svg ? generate_static_svg : USPSFlags::Helpers.log("-")
+ png ? generate_static_png : USPSFlags::Helpers.log("- ")
run_time = (Time.now - start_time).round(4).to_s[(0..5)].ljust(6, "0")
USPSFlags::Helpers.log " | #{run_time} s\n"
end
- def generate_static_svg(flag)
+ def generate_static_svg
USPSFlags::Helpers.log " "
- svg flag, outfile: @svg_file, scale: 1
+ svg @flag, outfile: @svg_file, scale: 1
USPSFlags::Helpers.log "S"
- if USPSFlags::Helpers.valid_flags(:past).include?(flag) || !USPSFlags::Helpers.valid_flags(:insignia).include?(flag)
+ if USPSFlags::Helpers.valid_flags(:past).include?(@flag) || !USPSFlags::Helpers.valid_flags(:insignia).include?(@flag)
USPSFlags::Helpers.log "-"
else
- svg flag, field: false, outfile: @svg_ins_file, scale: 1
+ svg @flag, field: false, outfile: @svg_ins_file, scale: 1
USPSFlags::Helpers.log "I"
end
end
- def generate_static_png(flag)
+ def generate_static_png
USPSFlags::Helpers.log " | "
generate_fullsize_png
- generate_fullsize_png_insignia(flag)
- generate_reduced_size_pngs(flag)
+ generate_fullsize_png_insignia
+ generate_reduced_size_pngs
end
def generate_fullsize_png
- png(File.read(@svg_file), outfile: @png_file) unless ::File.exist?(@png_file)
+ return if file_found?(@png_file)
+
+ png(File.read(@svg_file), outfile: @png_file)
USPSFlags::Helpers.log "F"
end
- def generate_fullsize_png_insignia(flag)
- if can_have_insignia?(flag)
- USPSFlags::Helpers.log "-"
- else
- png(File.read(@svg_ins_file), outfile: @png_ins_file, trim: true) unless ::File.exist?(@png_ins_file)
- USPSFlags::Helpers.log "I"
- end
- end
+ def generate_fullsize_png_insignia
+ return if no_insignia?
+ return if file_found?(@png_ins_file)
- def can_have_insignia?(flag)
- USPSFlags::Helpers.valid_flags(:past).include?(flag) || !USPSFlags::Helpers.valid_flags(:insignia).include?(flag)
+ png(File.read(@svg_ins_file), outfile: @png_ins_file, trim: true)
+ USPSFlags::Helpers.log "I"
end
- def generate_reduced_size_pngs(flag)
+ def generate_reduced_size_pngs
USPSFlags::Helpers.png_sizes.keys.each do |size|
- USPSFlags::Helpers.log(".") and next if ::File.exist?("#{USPSFlags::Config.flags_dir}/PNG/#{flag}.#{size}.png")
- size, size_key = USPSFlags::Helpers.size_and_key(size: size, flag: flag)
- generate_smaller_png(flag, size, size_key)
- generate_smaller_png_insignia(flag, size, size_key)
+ size, size_key = USPSFlags::Helpers.size_and_key(size: size, flag: @flag)
+ @sized_png_file = "#{USPSFlags::Config.flags_dir}/PNG/#{@flag}.#{@size_key}.png"
+ @sized_png_ins_file = @sized_png_file.gsub("/PNG/", "/PNG/insignia/")
+
+ generate_smaller_png(size, size_key)
+ generate_smaller_png_insignia(size, size_key)
end
end
- def generate_smaller_png(flag, size, size_key)
- USPSFlags::Helpers.resize_png(@png_ins_file, flag: flag, size: size, size_key: size_key) if USPSFlags::Helpers.valid_flags(:insignia).include?(flag)
+ def generate_smaller_png(size, size_key)
+ return if file_found?(@sized_png_file)
+ return if too_big?(@png_file, size)
+
+ USPSFlags::Helpers.resize_png(@png_file, file: @flag, size: size, size_key: size_key)
USPSFlags::Helpers.log USPSFlags::Helpers.png_sizes[size_key]
end
- def generate_smaller_png_insignia(flag, size, size_key)
- if ::File.exist?(@png_ins_file) && ::File.exist?("#{USPSFlags::Config.flags_dir}/PNG/insignia/#{flag}.#{size}.png")
- USPSFlags::Helpers.log "."
- elsif ::File.exist?(@png_ins_file) && MiniMagick::Image.open(@png_ins_file)[:width] > size && USPSFlags::Helpers.valid_flags(:insignia).include?(flag)
- USPSFlags::Helpers.resize_png(@png_ins_file, flag: flag, size: size, size_key: size_key)
- USPSFlags::Helpers.log "i"
- elsif ::File.exist?(@png_ins_file)
- USPSFlags::Helpers.log "+"
- else
- USPSFlags::Helpers.log "-"
- end
+ def generate_smaller_png_insignia(size, size_key)
+ return if no_insignia?
+ return if file_found?(@sized_png_ins_file)
+ return if too_big?(@png_ins_file, size)
+
+ USPSFlags::Helpers.resize_png(@png_ins_file, file: "insignia/#{@flag}", size: size, size_key: size_key)
+ USPSFlags::Helpers.log "i"
+ end
+
+ def no_insignia?
+ return false if USPSFlags::Helpers.valid_flags(:insignia).include?(@flag)
+ USPSFlags::Helpers.log "-"
+ true
+ end
+
+ def file_found?(file)
+ return false unless ::File.exist?(file)
+ USPSFlags::Helpers.log "."
+ true
+ end
+
+ def too_big?(file, size)
+ return false unless size > MiniMagick::Image.open(file)[:width]
+ USPSFlags::Helpers.log "+"
+ true
end
end
end