晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
| DIR:/opt/hc_python/lib64/python3.12/site-packages/virtualenv/run/ |
| Current File : //opt/hc_python/lib64/python3.12/site-packages/virtualenv/run/session.py |
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",
]
|