File: dalli.rb

package info (click to toggle)
ruby-dalli 5.0.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 992 kB
  • sloc: ruby: 9,447; sh: 19; makefile: 4
file content (84 lines) | stat: -rw-r--r-- 2,626 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
# frozen_string_literal: true

##
# Namespace for all Dalli code.
##
module Dalli
  # generic error
  class DalliError < RuntimeError; end

  # socket/server communication error
  class NetworkError < DalliError; end

  # no server available/alive error
  class RingError < DalliError; end

  # application error in marshalling serialization
  class MarshalError < DalliError; end

  # application error in marshalling deserialization or decompression
  class UnmarshalError < DalliError; end

  # payload too big for memcached
  class ValueOverMaxSize < DalliError; end

  # operation is not permitted in a multi block
  class NotPermittedMultiOpError < DalliError; end

  # raised when Memcached response with a SERVER_ERROR
  class ServerError < DalliError; end

  # socket/server communication error that can be retried
  class RetryableNetworkError < NetworkError; end

  # Implements the NullObject pattern to store an application-defined value for 'Key not found' responses.
  class NilObject; end # rubocop:disable Lint/EmptyClass
  NOT_FOUND = NilObject.new

  QUIET = :dalli_multi

  def self.logger
    @logger ||= rails_logger || default_logger # rubocop:disable ThreadSafety/ClassInstanceVariable
  end

  def self.rails_logger
    (defined?(Rails) && Rails.respond_to?(:logger) && Rails.logger) ||
      (defined?(RAILS_DEFAULT_LOGGER) && RAILS_DEFAULT_LOGGER.respond_to?(:debug) && RAILS_DEFAULT_LOGGER)
  end

  def self.default_logger
    require 'logger'
    l = Logger.new($stdout)
    l.level = Logger::INFO
    l
  end

  def self.logger=(logger)
    @logger = logger # rubocop:disable ThreadSafety/ClassInstanceVariable
  end
end

require_relative 'dalli/version'
require_relative 'dalli/instrumentation'

require_relative 'dalli/compressor'
require_relative 'dalli/client'
require_relative 'dalli/key_manager'
require_relative 'dalli/pipelined_getter'
require_relative 'dalli/pipelined_setter'
require_relative 'dalli/pipelined_deleter'
require_relative 'dalli/ring'
require_relative 'dalli/protocol'
require_relative 'dalli/protocol/base'
require_relative 'dalli/protocol/connection_manager'
require_relative 'dalli/protocol/meta'
require_relative 'dalli/protocol/response_buffer'
require_relative 'dalli/protocol/server_config_parser'
require_relative 'dalli/protocol/ttl_sanitizer'
require_relative 'dalli/protocol/value_compressor'
require_relative 'dalli/protocol/value_marshaller'
require_relative 'dalli/protocol/string_marshaller'
require_relative 'dalli/protocol/value_serializer'
require_relative 'dalli/servers_arg_normalizer'
require_relative 'dalli/socket'
require_relative 'dalli/options'