This file is indexed.

/usr/lib/python2.7/dist-packages/smmap/test/test_tutorial.py is in python-smmap 0.9.0-2.

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
77
78
79
80
81
82
83
84
from .lib import TestBase


class TestTutorial(TestBase):

    def test_example(self):
        # Memory Managers
        ##################
        import smmap
        # This instance should be globally available in your application
        # It is configured to be well suitable for 32-bit or 64 bit applications.
        mman = smmap.SlidingWindowMapManager()

        # the manager provides much useful information about its current state
        # like the amount of open file handles or the amount of mapped memory
        assert mman.num_file_handles() == 0
        assert mman.mapped_memory_size() == 0
        # and many more ...

        # Cursors
        ##########
        import smmap.test.lib
        fc = smmap.test.lib.FileCreator(1024 * 1024 * 8, "test_file")

        # obtain a cursor to access some file.
        c = mman.make_cursor(fc.path)

        # the cursor is now associated with the file, but not yet usable
        assert c.is_associated()
        assert not c.is_valid()

        # before you can use the cursor, you have to specify a window you want to
        # access. The following just says you want as much data as possible starting
        # from offset 0.
        # To be sure your region could be mapped, query for validity
        assert c.use_region().is_valid()        # use_region returns self

        # once a region was mapped, you must query its dimension regularly
        # to assure you don't try to access its buffer out of its bounds
        assert c.size()
        c.buffer()[0]           # first byte
        c.buffer()[1:10]            # first 9 bytes
        c.buffer()[c.size() - 1]  # last byte

        # its recommended not to create big slices when feeding the buffer
        # into consumers (e.g. struct or zlib).
        # Instead, either give the buffer directly, or use pythons buffer command.
        from smmap.util import buffer
        buffer(c.buffer(), 1, 9)    # first 9 bytes without copying them

        # you can query absolute offsets, and check whether an offset is included
        # in the cursor's data.
        assert c.ofs_begin() < c.ofs_end()
        assert c.includes_ofs(100)

        # If you are over out of bounds with one of your region requests, the
        # cursor will be come invalid. It cannot be used in that state
        assert not c.use_region(fc.size, 100).is_valid()
        # map as much as possible after skipping the first 100 bytes
        assert c.use_region(100).is_valid()

        # You can explicitly free cursor resources by unusing the cursor's region
        c.unuse_region()
        assert not c.is_valid()

        # Buffers
        #########
        # Create a default buffer which can operate on the whole file
        buf = smmap.SlidingWindowMapBuffer(mman.make_cursor(fc.path))

        # you can use it right away
        assert buf.cursor().is_valid()

        buf[0]  # access the first byte
        buf[-1]  # access the last ten bytes on the file
        buf[-10:]  # access the last ten bytes

        # If you want to keep the instance between different accesses, use the
        # dedicated methods
        buf.end_access()
        assert not buf.cursor().is_valid()  # you cannot use the buffer anymore
        assert buf.begin_access(offset=10)  # start using the buffer at an offset

        # it will stop using resources automatically once it goes out of scope