OXIESEC PANEL
- Current Dir:
/
/
lib
/
python3.9
/
site-packages
/
rhn
Server IP: 2a02:4780:11:1594:0:ef5:22d7:a
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
10/22/2025 07:58:12 AM
rwxr-xr-x
📄
SSL.py
10.79 KB
12/07/2022 01:15:22 PM
rw-r--r--
📄
SmartIO.py
2.11 KB
02/19/2018 08:18:29 AM
rw-r--r--
📄
UserDictCase.py
2.96 KB
02/19/2018 08:18:29 AM
rw-r--r--
📄
__init__.py
132 bytes
02/19/2018 08:18:29 AM
rw-r--r--
📁
__pycache__
-
05/14/2024 12:06:29 PM
rwxr-xr-x
📁
actions
-
04/05/2025 03:57:15 AM
rwxr-xr-x
📄
connections.py
9.48 KB
12/07/2022 01:15:22 PM
rw-r--r--
📄
i18n.py
1.73 KB
02/19/2018 08:18:29 AM
rw-r--r--
📄
nonblocking.py
2.37 KB
02/19/2018 08:18:29 AM
rw-r--r--
📄
rhnLockfile.py
3.35 KB
02/19/2018 08:18:29 AM
rw-r--r--
📄
rpclib.py
23.68 KB
12/07/2022 01:15:24 PM
rw-r--r--
📄
tb.py
836 bytes
02/19/2018 08:18:29 AM
rw-r--r--
📄
transports.py
31.18 KB
12/07/2022 01:15:24 PM
rw-r--r--
Editing: SmartIO.py
Close
# # Smart IO class # # Copyright (c) 2002--2016 Red Hat, Inc. # # Author: Mihai Ibanescu <misa@redhat.com> """ This module implements the SmartIO class """ import os try: # python2 from cStringIO import StringIO except ImportError: # python3 from io import BytesIO as StringIO class SmartIO: """ The SmartIO class allows one to put a cap on the memory consumption. StringIO objects are very fast, because they are stored in memory, but if they are too big the memory footprint becomes noticeable. The write method of a SmartIO determines if the data that is to be added to the (initially) StrintIO object does not exceed a certain threshold; if it does, it switches the storage to a temporary disk file """ def __init__(self, max_mem_size=16384, force_mem=0): self._max_mem_size = max_mem_size self._io = StringIO() # self._fixed is a flag to show if we're supposed to consider moving # the StringIO object into a tempfile # Invariant: if self._fixed == 0, we have a StringIO (if self._fixed # is 1 and force_mem was 0, then we have a file) if force_mem: self._fixed = 1 else: self._fixed = 0 def set_max_mem_size(self, max_mem_size): self._max_mem_size = max_mem_size def get_max_mem_size(self): return self._max_mem_size def write(self, data): if not self._fixed: # let's consider moving it to a file if len(data) + self._io.tell() > self._max_mem_size: # We'll overflow, change to a tempfile tmpfile = _tempfile() tmpfile.write(self._io.getvalue()) self._fixed = 1 self._io = tmpfile self._io.write(data) def __getattr__(self, name): return getattr(self._io, name) # Creates a temporary file and passes back its file descriptor def _tempfile(): import tempfile (fd, fname) = tempfile.mkstemp(prefix="_rhn_transports-%d-" \ % os.getpid()) # tempfile, unlink it os.unlink(fname) return os.fdopen(fd, "wb+")