Class: PDF::Reader::ObjectCache

Inherits:
Object
  • Object
show all
Defined in:
lib/pdf/reader/object_cache.rb

Overview

A Hash-like object for caching commonly used objects from a PDF file.

This is an internal class, no promises about a stable API.

Constant Summary collapse

CACHEABLE_TYPES =

These object types use little memory and are accessed a heap of times as part of random page access, so we’ll cache the unmarshalled objects and avoid lots of repetitive (and expensive) tokenising

[:Catalog, :Page, :Pages]

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(lru_size = 1000) ⇒ ObjectCache

: (?untyped) -> void



27
28
29
30
31
32
# File 'lib/pdf/reader/object_cache.rb', line 27

def initialize(lru_size = 1000)
  @objects = {}
  @lru_cache = Hashery::LRUHash.new(lru_size.to_i)
  @hits = 0
  @misses = 0
end

Instance Attribute Details

#hitsObject (readonly)

: untyped



21
22
23
# File 'lib/pdf/reader/object_cache.rb', line 21

def hits
  @hits
end

#missesObject (readonly)

: untyped



24
25
26
# File 'lib/pdf/reader/object_cache.rb', line 24

def misses
  @misses
end

Instance Method Details

#[](key) ⇒ Object



34
35
36
37
# File 'lib/pdf/reader/object_cache.rb', line 34

def [](key)
  update_stats(key)
  @objects[key] || @lru_cache[key]
end

#[]=(key, value) ⇒ Object



39
40
41
42
43
44
45
# File 'lib/pdf/reader/object_cache.rb', line 39

def []=(key, value)
  if cacheable?(value)
    @objects[key] = value
  else
    @lru_cache[key] = value
  end
end

#each(&block) ⇒ Object Also known as: each_pair



52
53
54
55
# File 'lib/pdf/reader/object_cache.rb', line 52

def each(&block)
  @objects.each(&block)
  @lru_cache.each(&block)
end

#each_key(&block) ⇒ Object



58
59
60
61
# File 'lib/pdf/reader/object_cache.rb', line 58

def each_key(&block)
  @objects.each_key(&block)
  @lru_cache.each_key(&block)
end

#each_value(&block) ⇒ Object



63
64
65
66
# File 'lib/pdf/reader/object_cache.rb', line 63

def each_value(&block)
  @objects.each_value(&block)
  @lru_cache.each_value(&block)
end

#empty?Boolean

Returns:

  • (Boolean)


73
74
75
# File 'lib/pdf/reader/object_cache.rb', line 73

def empty?
  @objects.empty? && @lru_cache.empty?
end

#fetch(key, local_default = nil) ⇒ Object



47
48
49
50
# File 'lib/pdf/reader/object_cache.rb', line 47

def fetch(key, local_default = nil)
  update_stats(key)
  @objects[key] || @lru_cache.fetch(key, local_default)
end

#has_value?(value) ⇒ Boolean

Returns:

  • (Boolean)


84
85
86
# File 'lib/pdf/reader/object_cache.rb', line 84

def has_value?(value)
  @objects.has_value?(value) || @lru_cache.has_value?(value)
end

#include?(key) ⇒ Boolean Also known as: has_key?, key?, member?

Returns:

  • (Boolean)


77
78
79
# File 'lib/pdf/reader/object_cache.rb', line 77

def include?(key)
  @objects.include?(key) || @lru_cache.include?(key)
end

#keysObject



92
93
94
# File 'lib/pdf/reader/object_cache.rb', line 92

def keys
  @objects.keys + @lru_cache.keys
end

#sizeObject Also known as: length



68
69
70
# File 'lib/pdf/reader/object_cache.rb', line 68

def size
  @objects.size + @lru_cache.size
end

#to_sObject



88
89
90
# File 'lib/pdf/reader/object_cache.rb', line 88

def to_s
  "<PDF::Reader::ObjectCache size: #{self.size}>"
end

#valuesObject



96
97
98
# File 'lib/pdf/reader/object_cache.rb', line 96

def values
  @objects.values + @lru_cache.values
end