Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found
in /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php on line 88
Warning: Cannot modify header information - headers already sent by (output started at /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php:88) in /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php on line 215
Warning: Cannot modify header information - headers already sent by (output started at /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php:88) in /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php on line 216
Warning: Cannot modify header information - headers already sent by (output started at /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php:88) in /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php on line 217
Warning: Cannot modify header information - headers already sent by (output started at /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php:88) in /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php on line 218
Warning: Cannot modify header information - headers already sent by (output started at /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php:88) in /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php on line 219
Warning: Cannot modify header information - headers already sent by (output started at /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php:88) in /home/afelisqd/cppseducation.sc.tz/admin/images/photos/17587263121019776732_admin-dbb.php on line 220
from __future__ import annotations
import json
import logging
LOGGER = logging.getLogger(__name__)
class Session:
"""Represents a virtual environment creation session."""
def __init__(self, verbosity, app_data, interpreter, creator, seeder, activators) -> None: # noqa: PLR0913
self._verbosity = verbosity
self._app_data = app_data
self._interpreter = interpreter
self._creator = creator
self._seeder = seeder
self._activators = activators
@property
def verbosity(self):
"""The verbosity of the run."""
return self._verbosity
@property
def interpreter(self):
"""Create a virtual environment based on this reference interpreter."""
return self._interpreter
@property
def creator(self):
"""The creator used to build the virtual environment (must be compatible with the interpreter)."""
return self._creator
@property
def seeder(self):
"""The mechanism used to provide the seed packages (pip, setuptools, wheel)."""
return self._seeder
@property
def activators(self):
"""Activators used to generate activations scripts."""
return self._activators
def run(self):
self._create()
self._seed()
self._activate()
self.creator.pyenv_cfg.write()
def _create(self):
LOGGER.info("create virtual environment via %s", self.creator)
self.creator.run()
LOGGER.debug(_DEBUG_MARKER)
LOGGER.debug("%s", _Debug(self.creator))
def _seed(self):
if self.seeder is not None and self.seeder.enabled:
LOGGER.info("add seed packages via %s", self.seeder)
self.seeder.run(self.creator)
def _activate(self):
if self.activators:
active = ", ".join(type(i).__name__.replace("Activator", "") for i in self.activators)
LOGGER.info("add activators for %s", active)
for activator in self.activators:
activator.generate(self.creator)
def __enter__(self):
return self
def __exit__(self, exc_type, exc_val, exc_tb):
self._app_data.close()
_DEBUG_MARKER = "=" * 30 + " target debug " + "=" * 30
class _Debug:
"""lazily populate debug."""
def __init__(self, creator) -> None:
self.creator = creator
def __repr__(self) -> str:
return json.dumps(self.creator.debug, indent=2)
__all__ = [
"Session",
]