diff options
| author | Louise Crow <louise.crow@gmail.com> | 2013-05-16 10:19:48 +0100 | 
|---|---|---|
| committer | Louise Crow <louise.crow@gmail.com> | 2013-05-16 10:19:48 +0100 | 
| commit | ea6fb578bfcdf9b6733f00df4b0ebca3963f7117 (patch) | |
| tree | 2d905ff5709ebe9b3b8c96699b0bd9ba8289f629 | |
| parent | f7e42400df70a16e4b6a22029055e944013ba64c (diff) | |
| parent | 27b3baf837ef3b3998a1a0ab7db053f92615dee5 (diff) | |
Merge branch 'external-command-memory-limit' into hotfix/0.9.0.3
| -rw-r--r-- | Rakefile | 3 | ||||
| -rw-r--r-- | lib/alaveteli_external_command.rb | 4 | ||||
| -rw-r--r-- | lib/mail_handler/mail_handler.rb | 3 | 
3 files changed, 9 insertions, 1 deletions
| @@ -3,9 +3,12 @@  require(File.join(File.dirname(__FILE__), 'config', 'boot')) +  require 'rake'  require 'rake/testtask'  require 'rdoc/task'  require 'tasks/rails' + +Dir[File.join(File.dirname(__FILE__),'commonlib','rblib','tests','*.rake')].each { |file| load(file) } diff --git a/lib/alaveteli_external_command.rb b/lib/alaveteli_external_command.rb index 24b4b1aa8..5e9a7ee83 100644 --- a/lib/alaveteli_external_command.rb +++ b/lib/alaveteli_external_command.rb @@ -8,6 +8,7 @@ module AlaveteliExternalCommand          # :stdin_string - stdin string to pass to the process          # :binary_output - boolean flag for treating the output as binary or text (only significant          #                  ruby 1.9 and above) +        # :memory_limit - maximum amount of memory (in bytes) available to the process          def run(program_name, *args)              # Run an external program, and return its output.              # Standard error is suppressed unless the program @@ -38,6 +39,9 @@ module AlaveteliExternalCommand              if opts.has_key? :binary_output                  xc.binary_mode = opts[:binary_output]              end +            if opts.has_key? :memory_limit +                xc.memory_limit = opts[:memory_limit] +            end              xc.run(opts[:stdin_string] || "", opts[:env] || {})              if xc.status != 0 diff --git a/lib/mail_handler/mail_handler.rb b/lib/mail_handler/mail_handler.rb index 8b227b9ca..cd5abfab7 100644 --- a/lib/mail_handler/mail_handler.rb +++ b/lib/mail_handler/mail_handler.rb @@ -84,7 +84,8 @@ module MailHandler              tempfile.flush              default_params = { :append_to => text, :binary_output => false }              if content_type == 'application/vnd.ms-word' -                AlaveteliExternalCommand.run("wvText", tempfile.path, tempfile.path + ".txt") +                AlaveteliExternalCommand.run("wvText", tempfile.path, tempfile.path + ".txt", +                                             { :memory_limit => 536870912 } )                  # Try catdoc if we get into trouble (e.g. for InfoRequestEvent 2701)                  if not File.exists?(tempfile.path + ".txt")                      AlaveteliExternalCommand.run("catdoc", tempfile.path, default_params) | 
