Skip to content
This repository has been archived by the owner on Dec 21, 2023. It is now read-only.

Commit

Permalink
Use Rails' index_by where it makes sense (mastodon#15542)
Browse files Browse the repository at this point in the history
* Use Rails' index_by where it makes sense

* Fix tests

Co-authored-by: Claire <[email protected]>
  • Loading branch information
ClearlyClaire and ClearlyClaire authored Jan 12, 2021
1 parent 7bed25f commit 54d4e52
Show file tree
Hide file tree
Showing 12 changed files with 12 additions and 12 deletions.
2 changes: 1 addition & 1 deletion app/controllers/api/v1/markers_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ class Api::V1::MarkersController < Api::BaseController
before_action :require_user!

def index
@markers = current_user.markers.where(timeline: Array(params[:timeline])).each_with_object({}) { |marker, h| h[marker.timeline] = marker }
@markers = current_user.markers.where(timeline: Array(params[:timeline])).index_by(&:timeline)
render json: serialize_map(@markers)
end

Expand Down
2 changes: 1 addition & 1 deletion app/controllers/concerns/cache_concern.rb
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ def cache_collection(raw, klass)
klass.reload_stale_associations!(cached_keys_with_value.values) if klass.respond_to?(:reload_stale_associations!)

unless uncached_ids.empty?
uncached = klass.where(id: uncached_ids).with_includes.each_with_object({}) { |item, h| h[item.id] = item }
uncached = klass.where(id: uncached_ids).with_includes.index_by(&:id)

uncached.each_value do |item|
Rails.cache.write(item, item)
Expand Down
2 changes: 1 addition & 1 deletion app/lib/entity_cache.rb
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ def emoji(shortcodes, domain)
end

unless uncached_ids.empty?
uncached = CustomEmoji.where(shortcode: shortcodes, domain: domain, disabled: false).each_with_object({}) { |item, h| h[item.shortcode] = item }
uncached = CustomEmoji.where(shortcode: shortcodes, domain: domain, disabled: false).index_by(&:shortcode)
uncached.each_value { |item| Rails.cache.write(to_key(:emoji, item.shortcode, domain), item, expires_in: MAX_EXPIRATION) }
end

Expand Down
2 changes: 1 addition & 1 deletion app/lib/settings/scoped_settings.rb
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ def respond_to_missing?(*)

def all_as_records
vars = thing_scoped
records = vars.each_with_object({}) { |r, h| h[r.var] = r }
records = vars.index_by(&:var)

Setting.default_settings.each do |key, default_value|
next if records.key?(key) || default_value.is_a?(Hash)
Expand Down
2 changes: 1 addition & 1 deletion app/lib/webfinger.rb
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ def link(rel, attribute)
private

def links
@links ||= @json['links'].map { |link| [link['rel'], link] }.to_h
@links ||= @json['links'].index_by { |link| link['rel'] }
end
end

Expand Down
2 changes: 1 addition & 1 deletion app/models/account.rb
Original file line number Diff line number Diff line change
Expand Up @@ -273,7 +273,7 @@ def keypair
end

def tags_as_strings=(tag_names)
hashtags_map = Tag.find_or_create_by_names(tag_names).each_with_object({}) { |tag, h| h[tag.name] = tag }
hashtags_map = Tag.find_or_create_by_names(tag_names).index_by(&:name)

# Remove hashtags that are to be deleted
tags.each do |tag|
Expand Down
2 changes: 1 addition & 1 deletion app/models/notification.rb
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,7 @@ def reload_stale_associations!(cached_items)

return if account_ids.empty?

accounts = Account.where(id: account_ids).includes(:account_stat).each_with_object({}) { |a, h| h[a.id] = a }
accounts = Account.where(id: account_ids).includes(:account_stat).index_by(&:id)

cached_items.each do |item|
item.from_account = accounts[item.from_account_id]
Expand Down
2 changes: 1 addition & 1 deletion app/models/setting.rb
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ def [](key)

def all_as_records
vars = thing_scoped
records = vars.each_with_object({}) { |r, h| h[r.var] = r }
records = vars.index_by(&:var)

default_settings.each do |key, default_value|
next if records.key?(key) || default_value.is_a?(Hash)
Expand Down
2 changes: 1 addition & 1 deletion app/models/status.rb
Original file line number Diff line number Diff line change
Expand Up @@ -301,7 +301,7 @@ def reload_stale_associations!(cached_items)

return if account_ids.empty?

accounts = Account.where(id: account_ids).includes(:account_stat).each_with_object({}) { |a, h| h[a.id] = a }
accounts = Account.where(id: account_ids).includes(:account_stat).index_by(&:id)

cached_items.each do |item|
item.account = accounts[item.account_id]
Expand Down
2 changes: 1 addition & 1 deletion app/models/trending_tags.rb
Original file line number Diff line number Diff line change
Expand Up @@ -91,7 +91,7 @@ def get(limit, filtered: true)

tags = Tag.where(id: tag_ids)
tags = tags.trendable if filtered
tags = tags.each_with_object({}) { |tag, h| h[tag.id] = tag }
tags = tags.index_by(&:id)

tag_ids.map { |tag_id| tags[tag_id] }.compact.take(limit)
end
Expand Down
2 changes: 1 addition & 1 deletion lib/mastodon/media_cli.rb
Original file line number Diff line number Diff line change
Expand Up @@ -326,7 +326,7 @@ def preload_records_from_mixed_objects(objects)
end

preload_map.each_with_object({}) do |(model_name, record_ids), model_map|
model_map[model_name] = model_name.constantize.where(id: record_ids).each_with_object({}) { |record, record_map| record_map[record.id] = record }
model_map[model_name] = model_name.constantize.where(id: record_ids).index_by(&:id)
end
end
end
Expand Down
2 changes: 1 addition & 1 deletion spec/models/notification_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@
before do
allow(accounts_with_ids).to receive(:[]).with(stale_account1.id).and_return(account1)
allow(accounts_with_ids).to receive(:[]).with(stale_account2.id).and_return(account2)
allow(Account).to receive_message_chain(:where, :includes, :each_with_object).and_return(accounts_with_ids)
allow(Account).to receive_message_chain(:where, :includes, :index_by).and_return(accounts_with_ids)
end

let(:cached_items) do
Expand Down

0 comments on commit 54d4e52

Please sign in to comment.