lib/princely.rb in princely-1.3.0 vs lib/princely.rb in princely-1.4.0

- old
+ new

@@ -1,6 +1,6 @@ -# PrinceXML Ruby interface. +# PrinceXML Ruby interface. # http://www.princexml.com # # Library by Subimage Interactive - http://www.subimage.com # # @@ -12,11 +12,10 @@ # princely.pdf_from_string(html_string), # :filename => 'some_document.pdf' # :type => 'application/pdf' # ) # -$:.unshift(File.dirname(__FILE__)) require 'logger' require 'princely/rails' if defined?(Rails) class Princely attr_accessor :exe_path, :style_sheets, :log_file, :logger @@ -27,20 +26,21 @@ # Finds where the application lives, so we can call it. @exe_path = options[:path] || find_prince_executable raise "Cannot find prince command-line app in $PATH" if @exe_path.length == 0 raise "Cannot find prince command-line app at #{@exe_path}" if @exe_path && !File.executable?(@exe_path) @style_sheets = '' + @cmd_args = '' @log_file = options[:log_file] @logger = options[:logger] end def logger @logger ||= defined?(Rails) ? Rails.logger : StdoutLogger end def log_file - @log_file ||= defined?(Rails) ? + @log_file ||= defined?(Rails) ? Rails.root.join("log/prince.log") : File.expand_path(File.dirname(__FILE__) + "/log/prince.log") end def ruby_platform @@ -52,46 +52,52 @@ "C:/Program Files/Prince/Engine/bin/prince" else `which prince`.chomp end end - + # Sets stylesheets... # Can pass in multiple paths for css files. # def add_style_sheets(*sheets) for sheet in sheets do @style_sheets << " -s #{sheet} " end end - + + # Sets arbitrary command line arguments + def add_cmd_args(str) + @cmd_args << " #{str} " + end + # Returns fully formed executable path with any command line switches # we've set based on our variables. # def exe_path # Add any standard cmd line arguments we need to pass @exe_path << " --input=html --server --log=#{log_file} " + @exe_path << @cmd_args @exe_path << @style_sheets return @exe_path end - + # Makes a pdf from a passed in string. # # Returns PDF as a stream, so we can use send_data to shoot # it down the pipe using Rails. # def pdf_from_string(string, output_file = '-') path = self.exe_path() - # Don't spew errors to the standard out...and set up to take IO + # Don't spew errors to the standard out...and set up to take IO # as input and output path << ' --silent - -o -' - + # Show the command used... logger.info "\n\nPRINCE XML PDF COMMAND" logger.info path logger.info '' - + # Actually call the prince command, and pass the entire data stream back. pdf = IO.popen(path, "w+") pdf.puts(string) pdf.close_write result = pdf.gets(nil) @@ -100,18 +106,18 @@ return result end def pdf_from_string_to_file(string, output_file) path = self.exe_path() - # Don't spew errors to the standard out...and set up to take IO + # Don't spew errors to the standard out...and set up to take IO # as input and output path << " --silent - -o '#{output_file}' >> '#{log_file}' 2>> '#{log_file}'" - + # Show the command used... logger.info "\n\nPRINCE XML PDF COMMAND" logger.info path logger.info '' - + # Actually call the prince command, and pass the entire data stream back. pdf = IO.popen(path, "w+") pdf.puts(string) pdf.close end