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
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
|
.TH "UFED" "8" "09 Apr 2013" "UFED 0.90" "UFED"
.SH "NAME"
ufed \- Gentoo Linux USE flags editor
.SH "SYNOPSIS"
.B ufed
.SH "INTRODUCTION"
UFED is a simple program designed to help you configure the
systems USE flags (see below) to your liking. To enable or
disable a flag highlight it and hit space.
ufed edits the USE flag settings in your make.conf file only. It can not be
used to edit your package.use file.
If you have two make.conf files, @GENTOO_PORTAGE_EPREFIX@/etc/make.conf and
@GENTOO_PORTAGE_EPREFIX@/etc/portage/make.conf, ufed reads the first, overrides
its settings with the second, and writes changes to the second.
If @GENTOO_PORTAGE_EPREFIX@/etc/portage/make.conf is a directory, ufed will
parse all files in this directory recursively, omitting files that begin with a
'.' or end with a '~', and will read all USE flag settings that can be found.
Changes are written to the last file found, overriding all others.
.B What are USE flags?
The USE settings system is a flexible way to enable or disable various features
at package build-time on a global level and for individual packages. This
allows an administrator to control how packages are built in regards to the
optional features which can be compiled into those packages.
For instance, packages with optional GNOME support can have this support
disabled at compile time by disabling the "gnome" USE flag. Enabling the
"gnome" USE flag would enable GNOME support in these packages.
The effect of USE flags on packages is dependent on whether both the
software itself and the package ebuild supports the USE flag as an optional
feature. If the software does not have support for an optional feature then the
corresponding USE flag will obviously have no effect.
Also many package dependencies are not considered optional by the software and
thus USE flags will have no effect on those mandatory dependencies.
A list of USE keywords used by a particular package can be found by checking
the IUSE line in any ebuild file or by using "equery" from gentoolkit.
See http://www.gentoo.org/doc/en/handbook/handbook-x86.xml?part=2&chap=2
for more information on USE flags.
Please also note that if UFED describes a flag (Unknown) it generally means
that it is either a spelling error in one of the three configuration files or
it is not an officially sanctioned USE flag. Sanctioned USE flags can be found
in @GENTOO_PORTAGE_EPREFIX@/usr/portage/profiles/use.desc and
in @GENTOO_PORTAGE_EPREFIX@/usr/portage/profiles/use.local.desc.
.B What are "global" and "local" USE flags?
Global USE flags are called such because they represent functionality that is
found in a wider variety of packages. For example, the global flag "cjk" is
about adding / not adding support for Eastern-Asian languages, which affects
a multitude of various packages. Global flags are described in
@GENTOO_PORTAGE_EPREFIX@/usr/portage/profiles/use.desc.
Local USE flags are unique package-wise, because the functionality they stand
for is only found in that particular package and no other. See
@GENTOO_PORTAGE_EPREFIX@/usr/portage/profiles/use.local.desc for a full,
per-package listing of all local USE flags.
It still happens that a flag which is defined as global is also defined as
local for one or more packages. That is because the general definition of the
global flag takes on specialized semantics in some particular package. It also
occurs that multiple packages define a local flag of the same name - the
meaning of the flag differs, however, for each package.
.B What are "Masked" and "Forced" flags?
ufed allows to view the descriptions of flags that are either masked or forced.
If a USE flag does not apply to your system, or is highly experimental, it is
"masked" and can not be enabled.
.br
If a USE flag is mandatory for your system or for a specific package, it is
"forced" and can not be disabled.
Flags that are masked or forced globally have their names displayed in
parentheses, and are prefixed with a '-' if they are masked. If one of these
flags is set in your make.conf, you can remove it with ufed.
.br
If a flag is only masked or forced for specific packages, a lower case 'm'
or 'f' in the defaults column (see "Display layout" below) indicates this.
.SH "Navigation and control"
ufed will present you with a list of descriptions for each USE flag. If a
description is too long to fit on your screen, you can use the Left and Right
arrow keys to scroll the descriptions.
Use the Up and Down arrow keys, the Page Up and Page Down keys, the Home and
End keys, or start typing the name of a flag to select it.
Use the space bar to toggle the setting.
You can apply various filters on the flags to display. The text of the bottom
line buttons show, which filter the button (or key press) will switch to.
F5: Toggle display of local / global / all flag descriptions.
.br
F6: Toggle display of flags supported by at least one installed
package / supported by no installed package / all flags.
.br
F7: Toggle display of masked and forced flags / flags that are
neither masked nor forced / all flags.
The default is to display all flags that are neither masked nor forced.
You can change the way the descriptions are displayed. The text of the
bottom line buttons show, which way the button (or key press) the display
will change to.
F9: Toggle the order of the affected package list and the description.
.br
F10: Toggle whether to display the full description or a stripped version.
The stripped version has various wordings like "Enables support for" or
"Build and install the" at the beginning of the description removed.
Although somewhat crippled, the descriptions key information then needs
less space and allows, with switched order of the package list and the
description, to determine a flags meaning without scrolling the text in most
cases; even on low resolution displays.
The default is to display the full description preceeded by the list of
affected packages.
Below the list of descriptions an indicator line is displayed that shows the
current setting of all filters and settings.
.br
The order and layout is:
.br
[Scope|State|Mask|Order|Description] with
.br
Scope:
glob : Global USE flags are shown.
loca : Local USE flags are shown.
all : All USE flags are shown.
.br
State:
inst : USE flags affecting installed packages are shown.
noti : USE flags affecting not installed packages are shown.
all : All USE flags are shown
.br
Mask:
mask : Masked and forced USE flags are shown
norm : USE flags that are neither masked nor forced are shown.
all : All USE flags are shown.
.br
Order:
left : The list of affected packages is shown left of the description.
righ : The list of affected packages is shown right of the description.
.br
Description:
orig : The original full description is shown.
stri : The stripped version of the description is shown.
If ncurses is installed with the "gpm" use flag enabled, you can use your
mouse to navigate and to toggle the settings, too.
After changing flags, press the Return or Enter key to save your USE flag setup
to make.conf, or press Escape to revert your changes.
Note: Depending on your system, you may need to wait a second before ufed
detects the Escape key or mouse clicks; in some cases, you can use the
ncurses environment variable ESCDELAY to change this. See \fBncurses\fR(3X)
for more info.
.SH "Display layout"
ufed attempts to show you where a particular use setting came from, and what
its scope and state is.
Each line consists of the following elements:
(s) flag |DPC|Si| (packages) description
.TP
\fB(s) : Your selection.\fR
.br
Either [+] to enable, [-] to disable, or empty to keep the default value. If a
flag is enabled or disabled by default, it will be shown as either (+) or (-).
.TP
\fBflag : The name of the flag.\fR
.br
If the flag is globally masked, it will be shown as (-flag). If the flag is
globally forced, it will be shown as (flag).
.TP
\fBD : System [D]efault settings.\fR
.br
These are read from
@GENTOO_PORTAGE_EPREFIX@/usr/portage/profiles/.../make.defaults and the
\fBebuild\fR(5) IUSE defaults of installed packages. The settings in make.defaults,
however, take precedence over the ebuild IUSE settings.
.br
Masked flags are shown here as 'm', forced flags as 'f'.
.TP
\fBP : [P]rofile package settings.\fR
.br
These are read from
@GENTOO_PORTAGE_EPREFIX@/usr/portage/profiles/.../package.use. These package
specific settings take precedence over the [D]efault settings.
.TP
\fBC : [C]onfiguration settings.\fR
.br
These are read from @GENTOO_PORTAGE_EPREFIX@/etc/make.conf,
@GENTOO_PORTAGE_EPREFIX@/etc/portage/make.conf and
@GENTOO_PORTAGE_EPREFIX@/etc/portage/package.use. These take precedence over
the [D]efault and [P]rofile settings, with package.use overriding settings
from make.conf.
.TP
\fBS : [S]cope of the description.\fR
.br
Local flag descriptions have an 'L' for "local" here.
.TP
\fBi : [i]nstalled.\fR
.br
Indicates with an 'i' if either the listed packages are installed on your
system, or if at least one package that supports this flag is installed.
The latter applies to the global description of the flag.
.TP
\fB(packages): List of packages that support this flag.\fR
.TP
\fBdescription : The description of the flag from use.desc or use.local.desc.\fR
.PP
If the character in any of the D, P or C column is a + then that USE flag was
set in that file(s), if it is a space then the flag was not mentioned in that
file(s) and if it is a - then that flag was unset in that file(s).
Flags marked as [+] or [-] will be saved in your make.conf when you leave the
program with an Enter.
You can change the order of the (packages) and the description with the F9 key.
.SH "REPORTING BUGS"
Please report bugs via http://bugs.gentoo.org/
.SH "SEE ALSO"
.BR emerge (1),
.BR ebuild (5),
.BR make.conf (5)
.SH "FILES"
.TP
\fB@GENTOO_PORTAGE_EPREFIX@/etc/make.conf, @GENTOO_PORTAGE_EPREFIX@/etc/portage/make.conf\fR
.br
Contains user specified USE flags
.TP
\fB@GENTOO_PORTAGE_EPREFIX@/etc/make.conf.old, @GENTOO_PORTAGE_EPREFIX@/etc/portage/make.conf.old\fR
.br
This is where ufed places a backup of your make.conf file.
.TP
\fB@GENTOO_PORTAGE_EPREFIX@/usr/portage/profiles/.../make.defaults\fR
Contains system default USE flags. These are the default settings and take
precedence over \fBebuild\fR(5) IUSE defaults.
.TP
\fB@GENTOO_PORTAGE_EPREFIX@/usr/portage/profiles/.../package.use\fR
Contains per package default USE flags. These are per package default settings
and take precedence over system default USE flags.
.TP
\fB@GENTOO_PORTAGE_EPREFIX@/etc/portage/package.use\fR
Contains user specified USE flags per package. These take precedence over all
system defaults and the settings in your make.conf file.
.TP
\fB@GENTOO_PORTAGE_EPREFIX@/usr/portage/profiles/.../use.mask\fR
Restricted USE flags
.TP
\fB@GENTOO_PORTAGE_EPREFIX@/usr/portage/profiles/.../use.force\fR
Enforced USE flags
.TP
\fB@GENTOO_PORTAGE_EPREFIX@/usr/portage/profiles/use.desc\fR
Description strings for global USE flags
.TP
\fB@GENTOO_PORTAGE_EPREFIX@/usr/portage/profiles/use.local.desc\fR
Description strings for local USE flags
.SH "AUTHORS"
ufed was originally written by Maik Schreiber <blizzy@blizzy.de>.
.br
ufed was previously maintained by
.br
Robin Johnson <robbat2@gentoo.org>,
.br
Fred Van Andel <fava@gentoo.org>,
.br
Arun Bhanu <codebear@gentoo.org> and
.br
Harald van Dijk <truedfx@gentoo.org>.
.br
ufed is currently maintained by
.br
Sven Eden <yamakuzure@gmx.net>.
.SH Thanks
Paul Varner - for proxy maintaining and support.
.br
Roman Zilka - for ideas, testing and a lot of patience.
|