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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
|
# Copyright 2007 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Id$
from portage.versions import catsplit, catpkgsplit
from portage.sets import PackageSet, SetConfigError
from portage.dbapi.vartree import dblink
from portage.util import grabfile
import os
__all__ = ["CategorySet", "EverythingSet"]
class EverythingSet(PackageSet):
_operations = ["merge", "unmerge"]
description = "Package set containing all installed packages"
def __init__(self, vdbapi):
super(EverythingSet, self).__init__()
self._db = vdbapi
def load(self):
myatoms = []
for cp in self._db.cp_all():
if len(self._db.cp_list(cp)) > 1:
for cpv in self._db.cp_list(cp):
myslot = self._db.aux_get(cpv, ["SLOT"])[0]
myatoms.append(cp+":"+myslot)
else:
myatoms.append(cp)
self._setAtoms(myatoms)
def singleBuilder(self, options, settings, trees):
return EverythingSet(trees["vartree"].dbapi)
singleBuilder = classmethod(singleBuilder)
class CategorySet(PackageSet):
_operations = ["merge", "unmerge"]
def __init__(self, category, dbapi, only_visible=True):
super(CategorySet, self).__init__()
self._db = dbapi
self._category = category
self._check = only_visible
if only_visible:
s="visible"
else:
s="all"
self.description = "Package set containing %s packages of category %s" % (s, self._category)
def load(self):
myatoms = []
for cp in self._db.cp_all():
if catsplit(cp)[0] == self._category:
if (not self._check) or len(self._db.match(cp)) > 0:
myatoms.append(cp)
self._setAtoms(myatoms)
def _builderGetRepository(cls, options, repositories):
repository = options.get("repository", "porttree")
if not repository in repositories:
raise SetConfigError("invalid repository class '%s'" % repository)
return repository
_builderGetRepository = classmethod(_builderGetRepository)
def _builderGetVisible(cls, options):
visible = options.get("only_visible", "true").lower()
if visible not in ["1", "0", "yes", "no", "true", "false", "on", "off"]:
raise SetConfigError("invalid value for only_visible: %s" % visible)
return bool(visible in ["1", "yes", "true", "on"])
_builderGetVisible = classmethod(_builderGetVisible)
def singleBuilder(cls, options, settings, trees):
if not "category" in options:
raise SetConfigError("no category given")
category = options["category"]
if not category in categories:
raise SetConfigError("invalid category name '%s'" % category)
repository = cls._builderGetRepository(options, trees.keys())
visible = cls._builderGetVisible(options)
return CategorySet(category, dbapi=trees[repository].dbapi, only_visible=visible)
singleBuilder = classmethod(singleBuilder)
def multiBuilder(cls, options, settings, trees):
rValue = {}
if "categories" in options:
categories = options["categories"].split()
invalid = set(categories).difference(settings.categories)
if invalid:
raise SetConfigError("invalid categories: %s" % ", ".join(list(invalid)))
else:
categories = settings.categories
repository = cls._builderGetRepository(options, trees.keys())
visible = cls._builderGetVisible(options)
name_pattern = options.get("name_pattern", "$category/*")
if not "$category" in name_pattern and not "${category}" in name_pattern:
raise SetConfigError("name_pattern doesn't include $category placeholder")
for cat in categories:
myset = CategorySet(cat, trees[repository].dbapi, only_visible=visible)
myname = name_pattern.replace("$category", cat)
myname = myname.replace("${category}", cat)
rValue[myname] = myset
return rValue
multiBuilder = classmethod(multiBuilder)
class LibraryConsumerSet(PackageSet):
_operations = ["merge", "unmerge"]
def __init__(self, vardbapi, debug=False):
super(LibraryConsumerSet, self).__init__()
self.dbapi = vardbapi
self.debug = debug
def mapPathsToAtoms(self, paths):
rValue = set()
for cpv in self.dbapi.cpv_all():
mysplit = catsplit(cpv)
link = dblink(mysplit[0], mysplit[1], myroot=self.dbapi.root, \
mysettings=self.dbapi.settings, treetype='vartree', \
vartree=self.dbapi.vartree)
if paths.intersection(link.getcontents().keys()):
rValue.add("/".join(catpkgsplit(cpv)[:2]))
return rValue
class PreservedLibraryConsumerSet(LibraryConsumerSet):
def load(self):
reg = self.dbapi.plib_registry
libmap = self.dbapi.libmap.get()
consumers = set()
if reg:
for libs in reg.getPreservedLibs().values():
for lib in libs:
paths = libmap.get(os.path.basename(lib), [])
consumers.update(paths)
else:
return
if not consumers:
return
self._setAtoms(self.mapPathsToAtoms(consumers))
def singleBuilder(cls, options, settings, trees):
return PreservedLibraryConsumerSet(trees["vartree"].dbapi)
singleBuilder = classmethod(singleBuilder)
class MissingLibraryConsumerSet(LibraryConsumerSet):
_operations = ["merge", "unmerge"]
def load(self):
atoms = set()
consumers = set()
for lib in self.dbapi.libmap.get():
found=False
for searchdir in grabfile(os.path.join(os.sep, self.dbapi.root, "etc/ld.so.conf")):
if os.path.exists(os.path.join(searchdir, lib)):
found=True
break
if not found:
print "missing library: %s" % lib
print "consumers:"
for x in self.dbapi.libmap.get()[lib]:
print " ", x
consumers.update(self.dbapi.libmap.get()[lib])
if not consumers:
return
self._setAtoms(self.mapPathsToAtoms(consumers))
def singleBuilder(cls, options, settings, trees):
if options.get("debug", "true").lower() in ["true", "on", "1", "yes"]:
debug = True
else:
debug = False
return MissingLibraryConsumerSet(trees["vartree"].dbapi, debug=debug)
singleBuilder = classmethod(singleBuilder)
|