This file is indexed.

/usr/lib/python3/dist-packages/UM/LockFile.py is in python3-uranium 3.1.0-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
77
78
79
80
81
82
83
84
85
# Copyright (c) 2016 Ultimaker B.V.
# Uranium is released under the terms of the LGPLv3 or higher.

import os
import time  # For timing lock file

from UM.Logger import Logger


##  Manage a lock file for reading / writing in a directory.
#   \param filename the filename to use as lock file
#   \param timeout in seconds; if the file is too old by this amount, then it gets ignored
#   \param wait_msg the message to log when waiting for the lock file to disappear
#
#   example usage:
#   $ with LockFile("my_lock_file.lock"):
#   $   <do something in a directory>
class LockFile:
    ##  Creates the locker instance that will hold the lock file.
    #
    #   \param filename The name and path of the lockfile to create.
    #   \param timeout After this amount of seconds, the lock will break
    #   regardless of the state of the file system.
    #   \param wait_msg A message to log when the thread is blocked by the lock.
    #   It is intended that you modify this to better indicate what lock file is
    #   blocking the thread.
    def __init__(self, filename: str, timeout: int = 10, wait_msg: str = "Waiting for lock file to disappear..."):
        self._filename = filename
        self._wait_msg = wait_msg
        self._timeout = timeout

    ##  Block the thread until the lock file no longer exists.
    #
    #   This is implemented using a spin loop.
    def _waitLockFileDisappear(self):
        now = time.time()
        while os.path.exists(self._filename) and now < os.path.getmtime(self._filename) + self._timeout and now > os.path.getmtime(self._filename):
            Logger.log("d", self._wait_msg)
            time.sleep(0.1)
            now = time.time()

    ##  Creates the lock file on the file system.
    #
    #   The lock file is filled with the current process ID. Python's own GIL
    #   will ensure that this is thread-safe then.
    def _createLockFile(self):
        try:
            with open(self._filename, "w") as lock_file:
                lock_file.write("%s" % os.getpid())
        except:
            Logger.log("e", "Could not create lock file [%s]" % self._filename)

    ##  Deletes the lock file from the file system.
    def _deleteLockFile(self):
        try:
            os.remove(self._filename)
        except FileNotFoundError:
            #This can happen due to a leak in the thread-safety of this system.
            #We ignore this leak for now, but this is how it can happen:
            #   This thread              Other thread
            # 1 Check if lock exists     Check if lock exists
            # 2                          Create lock file
            # 3 Create lock file (fails)
            # 4 Do work                  Do work
            # 5                          Delete lock file
            # 6 Delete lock file (here)
            pass
        except:
            Logger.log("e", "Could not delete lock file [%s]" % self._filename)

    ##  Attempt to grab the lock file for personal use.
    def __enter__(self):
        self._waitLockFileDisappear()
        self._createLockFile()

    ##  Release the lock file so that other processes may use it.
    #
    #   \param exc_type The type of exception that was raised during the
    #   ``with`` block, if any. Use ``None`` if no exception was raised.
    #   \param exc_val The exception instance that was raised during the
    #   ``with`` block, if any. Use ``None`` if no exception was raised.
    #   \param exc_tb The traceback frames at the time the exception occurred,
    #   if any. Use ``None`` if no exception was raised.
    def __exit__(self, exc_type, exc_val, exc_tb):
        self._deleteLockFile()