mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-25 07:16:49 +00:00
Merge pull request #833 from lsylvester/cache-serializers-for-class
Cache serializers for class
This commit is contained in:
commit
0446a9714d
@ -1,3 +1,5 @@
|
|||||||
|
require 'thread_safe'
|
||||||
|
|
||||||
module ActiveModel
|
module ActiveModel
|
||||||
class Serializer
|
class Serializer
|
||||||
extend ActiveSupport::Autoload
|
extend ActiveSupport::Autoload
|
||||||
@ -201,11 +203,16 @@ module ActiveModel
|
|||||||
opts
|
opts
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def self.serializers_cache
|
||||||
|
@serializers_cache ||= ThreadSafe::Cache.new
|
||||||
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
attr_reader :options
|
attr_reader :options
|
||||||
|
|
||||||
def self.get_serializer_for(klass)
|
def self.get_serializer_for(klass)
|
||||||
|
serializers_cache.fetch_or_store(klass) do
|
||||||
serializer_class_name = "#{klass.name}Serializer"
|
serializer_class_name = "#{klass.name}Serializer"
|
||||||
serializer_class = serializer_class_name.safe_constantize
|
serializer_class = serializer_class_name.safe_constantize
|
||||||
|
|
||||||
@ -215,6 +222,7 @@ module ActiveModel
|
|||||||
get_serializer_for(klass.superclass)
|
get_serializer_for(klass.superclass)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@ -9,6 +9,9 @@ begin
|
|||||||
|
|
||||||
ActiveSupport.on_load(:action_controller) do
|
ActiveSupport.on_load(:action_controller) do
|
||||||
include ::ActionController::Serialization
|
include ::ActionController::Serialization
|
||||||
|
ActionDispatch::Reloader.to_prepare do
|
||||||
|
ActiveModel::Serializer.serializers_cache.clear
|
||||||
|
end
|
||||||
end
|
end
|
||||||
rescue LoadError
|
rescue LoadError
|
||||||
# rails not installed, continuing
|
# rails not installed, continuing
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user