diff options
author | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2012-02-09 20:06:36 +0000 |
---|---|---|
committer | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2012-02-09 20:06:36 +0000 |
commit | 8c38510ee5045447a0be063596c888a678521b7b (patch) | |
tree | d2114936eee4bba4cb5ed9163a26bb36c9bd700e /app/controllers | |
parent | 8b3ed4175d6e9d09175c1bea6f01b03079918f80 (diff) | |
download | redmine-8c38510ee5045447a0be063596c888a678521b7b.tar.gz redmine-8c38510ee5045447a0be063596c888a678521b7b.zip |
Use #reduce instead of #inject for getting the intersection of arrays.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@8827 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/controllers')
-rw-r--r-- | app/controllers/context_menus_controller.rb | 8 | ||||
-rw-r--r-- | app/controllers/issues_controller.rb | 10 |
2 files changed, 9 insertions, 9 deletions
diff --git a/app/controllers/context_menus_controller.rb b/app/controllers/context_menus_controller.rb index fa7caf4e0..dbfa4057e 100644 --- a/app/controllers/context_menus_controller.rb +++ b/app/controllers/context_menus_controller.rb @@ -8,7 +8,7 @@ class ContextMenusController < ApplicationController @issue = @issues.first end - @allowed_statuses = @issues.map(&:new_statuses_allowed_to).inject{|memo,a| memo & a} + @allowed_statuses = @issues.map(&:new_statuses_allowed_to).reduce(:&) @projects = @issues.collect(&:project).compact.uniq @project = @projects.first if @projects.size == 1 @@ -28,8 +28,8 @@ class ContextMenusController < ApplicationController @trackers = @project.trackers else #when multiple projects, we only keep the intersection of each set - @assignables = @projects.map(&:assignable_users).inject{|memo,a| memo & a} - @trackers = @projects.map(&:trackers).inject{|memo,t| memo & t} + @assignables = @projects.map(&:assignable_users).reduce(:&) + @trackers = @projects.map(&:trackers).reduce(:&) end @priorities = IssuePriority.active.reverse @@ -37,7 +37,7 @@ class ContextMenusController < ApplicationController @options_by_custom_field = {} if @can[:edit] - custom_fields = @issues.map(&:available_custom_fields).inject {|memo, f| memo & f}.select do |f| + custom_fields = @issues.map(&:available_custom_fields).reduce(:&).select do |f| %w(bool list user version).include?(f.field_format) && !f.multiple? end custom_fields.each do |field| diff --git a/app/controllers/issues_controller.rb b/app/controllers/issues_controller.rb index df130f9d5..4e3fe8aef 100644 --- a/app/controllers/issues_controller.rb +++ b/app/controllers/issues_controller.rb @@ -229,12 +229,12 @@ class IssuesController < ApplicationController end target_projects ||= @projects - @available_statuses = target_projects.map{|p|Workflow.available_statuses(p)}.inject{|memo,w|memo & w} - @custom_fields = target_projects.map{|p|p.all_issue_custom_fields}.inject{|memo,c|memo & c} - @assignables = target_projects.map(&:assignable_users).inject{|memo,a| memo & a} - @trackers = target_projects.map(&:trackers).inject{|memo,t| memo & t} + @available_statuses = target_projects.map{|p|Workflow.available_statuses(p)}.reduce(:&) + @custom_fields = target_projects.map{|p|p.all_issue_custom_fields}.reduce(:&) + @assignables = target_projects.map(&:assignable_users).reduce(:&) + @trackers = target_projects.map(&:trackers).reduce(:&) - @safe_attributes = @issues.map(&:safe_attribute_names).inject {|memo,attrs| memo & attrs} + @safe_attributes = @issues.map(&:safe_attribute_names).reduce(:&) render :layout => false if request.xhr? end |