This file is indexed.

/usr/lib/ruby/vendor_ruby/sequel/extensions/schema_caching.rb is in ruby-sequel 3.36.1-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 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
# The schema_caching extension adds a few methods to Sequel::Database
# that make it easy to dump the parsed schema information to a file,
# and load it from that file.  Loading the schema information from a
# dumped file is faster than parsing it from the database, so this
# can save bootup time for applications with large numbers of models.
#
# Basic usage in application code:
#
#   Sequel.extension :schema_caching
#
#   DB = Sequel.connect('...')
#
#   DB.load_schema_cache('/path/to/schema.dump')
#
#   # load model files
#
# Then, whenever the database schema is modified, write a new cached
# file.  You can do that with <tt>bin/sequel</tt>'s -S option:
#
#   bin/sequel -S /path/to/schema.dump postgres://...
#
# Alternatively, if you don't want to dump the schema information for
# all tables, and you don't worry about race conditions, you can
# choose to use the following in your application code:
#
#   Sequel.extension :schema_caching
#
#   DB = Sequel.connect('...')
#
#   DB.load_schema_cache?('/path/to/schema.dump')
#
#   # load model files
#
#   DB.dump_schema_cache?('/path/to/schema.dump')
#
# With this method, you just have to delete the schema dump file if
# the schema is modified, and the application will recreate it for you
# using just the tables that your models use.
#
# Note that it is up to the application to ensure that the dumped
# cached schema reflects the current state of the database.  Sequel
# does no checking to ensure this, as checking would take time and the
# purpose of this code is to take a shortcut.
#
# The cached schema is dumped in Marshal format, since it is the fastest
# and it handles all ruby objects used in the schema hash.  Because of this,
# you should not attempt to load the schema from a untrusted file.

module Sequel
  class Database
    # Dump the cached schema to the filename given in Marshal format.
    def dump_schema_cache(file)
      File.open(file, 'wb'){|f| f.write(Marshal.dump(@schemas))}
      nil
    end

    # Dump the cached schema to the filename given unless the file
    # already exists.
    def dump_schema_cache?(file)
      dump_schema_cache(file) unless File.exist?(file)
    end

    # Replace the schema cache with the data from the given file, which
    # should be in Marshal format.
    def load_schema_cache(file)
      @schemas = Marshal.load(File.read(file))
      nil
    end

    # Replace the schema cache with the data from the given file if the
    # file exists.
    def load_schema_cache?(file)
      load_schema_cache(file) if File.exist?(file)
    end
  end
end