module Bootsnap::CompileCache::JSON

def cache_dir=(cache_dir)

def cache_dir=(cache_dir)
  @cache_dir = cache_dir.end_with?("/") ? "#{cache_dir}json" : "#{cache_dir}-json"
end

def init!

def init!
  require("json")
  require("msgpack")
  self.msgpack_factory = MessagePack::Factory.new
  self.supported_options = [:symbolize_names]
  if supports_freeze?
    self.supported_options = [:freeze]
  end
  supported_options.freeze
end

def input_to_output(data, kwargs)

def input_to_output(data, kwargs)
  ::JSON.parse(data, **(kwargs || {}))
end

def input_to_storage(payload, _)

def input_to_storage(payload, _)
  obj = ::JSON.parse(payload)
  msgpack_factory.dump(obj)
end

def install!(cache_dir)

def install!(cache_dir)
  self.cache_dir = cache_dir
  init!
  if ::JSON.respond_to?(:load_file)
    ::JSON.singleton_class.prepend(Patch)
  end
end

def precompile(path)

def precompile(path)
  Bootsnap::CompileCache::Native.precompile(
    cache_dir,
    path.to_s,
    self,
  )
end

def storage_to_output(data, kwargs)

def storage_to_output(data, kwargs)
  if kwargs&.key?(:symbolize_names)
    kwargs[:symbolize_keys] = kwargs.delete(:symbolize_names)
  end
  msgpack_factory.load(data, kwargs)
end

def supports_freeze?

def supports_freeze?
  ::JSON.parse('["foo"]', freeze: true).first.frozen? &&
    MessagePack.load(MessagePack.dump("foo"), freeze: true).frozen?
end