Skip to content
New issue

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

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

Already on GitHub? Sign in to your account

Some (very) minor utils additions #1

Open
wants to merge 7 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Jump to
Jump to file
Failed to load files.
Diff view
Diff view
2 changes: 1 addition & 1 deletion Rakefile
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
require 'rubygems'
require 'rake/gempackagetask'
require 'rubygems/package_task'
require 'rake/testtask'
require 'lib/image_squeeze'

Expand Down
25 changes: 24 additions & 1 deletion lib/image_squeeze.rb
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
require 'image_squeeze/processors/png_crush_processor'
require 'image_squeeze/processors/jpeg_tran_progressive_processor'
require 'image_squeeze/processors/jpeg_tran_non_progressive_processor'
require 'image_squeeze/processors/jpeg_optim_processor'
require 'image_squeeze/processors/gifsicle_processor'
require 'image_squeeze/processors/gif_to_png_processor'
require 'image_squeeze/processors/optipng_processor'
Expand Down Expand Up @@ -53,6 +54,27 @@ def initialize(options = {})
def self.default
@processors = self.class.default_processors
end

def squeeze_dir(path, substantial = 0.03)
puts "filename,output_filename,bytes_saved,original_size,percent_savings,processor"
squeeze_dir_recursive(path,substantial)
end

def squeeze_dir_recursive(path, substantial = 0.03)
if path.directory?
path.each_child {|p| squeeze_dir_recursive(p)}
else
r = squeeze(path)
if r
if r.percent_savings > substantial
finalize_result(r)
puts "#{r.filename},#{r.output_filename},#{r.bytes_saved},#{r.original_size},#{r.percent_savings * 100}%,#{r.processor}"
else
puts "-No substantial savings (#{r.percent_savings * 100}%) on #{r.filename}"
end
end
end
end

def squeeze(filename)
image_type = self.class.image_type(filename)
Expand All @@ -66,7 +88,7 @@ def squeeze(filename)
output_filename = tmp_filename(filename)
processor_class.squeeze(filename, output_filename)
output_file_size = File.size(output_filename)
result_options = { :filename => filename, :output_filename => output_filename, :bytes_saved => original_file_size - output_file_size, :output_extension => processor_class.output_extension }
result_options = { :processor => processor_class.to_s, :filename => filename, :output_filename => output_filename, :original_size => original_file_size, :bytes_saved => original_file_size - output_file_size, :output_extension => processor_class.output_extension }
Result.new(result_options)
end.sort

Expand Down Expand Up @@ -113,6 +135,7 @@ def self.default_processors
end
processors << OptiPNGProcessor if ImageSqueeze::Utils.image_utility_available?('optipng', 'png')
processors << GifsicleProcessor if ImageSqueeze::Utils.image_utility_available?('gifsicle', 'animated gif')
processors << JpegOptimProcessor if ImageSqueeze::Utils.image_utility_available?('jpegoptim', 'jpg')
if ImageSqueeze::Utils.image_utility_available?('jpegtran', 'jpeg')
processors << JPEGTranProgressiveProcessor
processors << JPEGTranNonProgressiveProcessor
Expand Down
11 changes: 11 additions & 0 deletions lib/image_squeeze/processors/jpeg_optim_processor.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
class ImageSqueeze
class JpegOptimProcessor < Processor
def self.input_type
JPEG
end

def self.squeeze(filename, output_filename)
system("jpegoptim --strip-all --dest=#{output_filename} #{filename} > /dev/null")
end
end
end
3 changes: 2 additions & 1 deletion lib/image_squeeze/processors/optipng_processor.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,8 @@ class OptiPNGProcessor < Processor
def self.input_type
PNG
end


#i1 is interlaced, i0 is noninterlaced
def self.squeeze(filename, output_filename)
system("optipng -i1 -o7 #{filename} -out=#{output_filename} > /dev/null")
end
Expand Down
3 changes: 2 additions & 1 deletion lib/image_squeeze/processors/png_crush_processor.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,8 @@ class PNGCrushProcessor < Processor
def self.input_type
PNG
end


#-rem alla will remove all known ancillary chunks
def self.squeeze(filename, output_filename)
system("pngcrush -rem alla -brute -reduce #{filename} #{output_filename} > /dev/null")
end
Expand Down
9 changes: 8 additions & 1 deletion lib/image_squeeze/result.rb
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
class ImageSqueeze
class Result
attr_reader :filename, :output_filename, :bytes_saved, :output_extension
attr_reader :processor, :filename, :output_filename, :bytes_saved, :output_extension, :original_size

def initialize(options = {})
@filename = options[:filename]
@output_filename = options[:output_filename]
@bytes_saved = options[:bytes_saved]
@output_extension = options[:output_extension]
@original_size = options[:original_size]
@processor = options[:processor]
end

def optimized?
Expand All @@ -16,5 +18,10 @@ def optimized?
def <=>(other)
self.bytes_saved <=> other.bytes_saved
end

def percent_savings
@bytes_saved.to_f/@original_size
end

end
end