晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
Server : Apache System : Linux srv.rainic.com 4.18.0-553.47.1.el8_10.x86_64 #1 SMP Wed Apr 2 05:45:37 EDT 2025 x86_64 User : rainic ( 1014) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /proc/thread-self/root/lib/python3.6/site-packages/dnf-plugins/ |
Upload File : |
# coding=utf-8
# generate_completion_cache.py - generate cache for dnf bash completion
# Copyright © 2013 Elad Alfassa <elad@fedoraproject.org>
# Copyright (C) 2014-2015 Igor Gnatenko <i.gnatenko.brain@gmail.com>
# Copyright (C) 2015 Red Hat, Inc.
# This copyrighted material is made available to anyone wishing to use,
# modify, copy, or redistribute it subject to the terms and conditions of
# the GNU General Public License v.2, or (at your option) any later version.
# This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY expressed or implied, including the implied warranties of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
# Public License for more details. You should have received a copy of the
# GNU General Public License along with this program; if not, write to the
# Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
# 02110-1301, USA.
from __future__ import absolute_import
from __future__ import unicode_literals
from dnf.i18n import ucd
from dnfpluginscore import logger
import dnf
import os.path
import sqlite3
class BashCompletionCache(dnf.Plugin):
name = 'generate_completion_cache'
def __init__(self, base, cli):
super(BashCompletionCache, self).__init__(base, cli)
self.base = base
self.cache_file = "/var/cache/dnf/packages.db"
@staticmethod
def _out(msg):
logger.debug('Completion plugin: %s', msg)
def sack(self):
''' Generate cache of available packages '''
# We generate this cache only if the repos were just freshed or if the
# cache file doesn't exist
fresh = False
for repo in self.base.repos.iter_enabled():
if repo.metadata is not None and repo.metadata.fresh:
# One fresh repo is enough to cause a regen of the cache
fresh = True
break
if not os.path.exists(self.cache_file) or fresh:
try:
with sqlite3.connect(self.cache_file) as conn:
self._out('Generating completion cache...')
cur = conn.cursor()
cur.execute(
"create table if not exists available (pkg TEXT)")
cur.execute(
"create unique index if not exists "
"pkg_available ON available(pkg)")
cur.execute("delete from available")
avail_pkgs = self.base.sack.query().available()
avail_pkgs_insert = [[str(x)] for x in avail_pkgs if x.arch != "src"]
cur.executemany("insert or ignore into available values (?)",
avail_pkgs_insert)
conn.commit()
except sqlite3.OperationalError as e:
self._out("Can't write completion cache: %s" % ucd(e))
def transaction(self):
''' Generate cache of installed packages '''
if not self.transaction:
return
try:
with sqlite3.connect(self.cache_file) as conn:
self._out('Generating completion cache...')
cur = conn.cursor()
cur.execute("create table if not exists installed (pkg TEXT)")
cur.execute(
"create unique index if not exists "
"pkg_installed ON installed(pkg)")
cur.execute("delete from installed")
inst_pkgs = dnf.sack._rpmdb_sack(self.base).query().installed()
inst_pkgs_insert = [[str(x)] for x in inst_pkgs if x.arch != "src"]
cur.executemany("insert or ignore into installed values (?)",
inst_pkgs_insert)
conn.commit()
except sqlite3.OperationalError as e:
self._out("Can't write completion cache: %s" % ucd(e))