make the fallback make.conf more generic by removing x86 specific stuff and removing...
[portage.git] / cnf / make.conf
1 # Copyright 1999-2006 Gentoo Foundation
2 # Distributed under the terms of the GNU General Public License v2
3 # $Id: /var/cvsroot/gentoo-src/portage/cnf/make.conf,v 1.84.2.5 2005/04/13 15:28:38 jstubbs Exp $
4 # Contains local system settings for Portage system
5
6 # Please review 'man make.conf' for more information.
7
8 # Build-time functionality
9 # ========================
10 #
11 # The USE variable is used to enable optional build-time functionality. For
12 # example, quite a few packages have optional X, gtk or GNOME functionality
13 # that can only be enabled or disabled at compile-time. Gentoo Linux has a
14 # very extensive set of USE variables described in our USE variable HOWTO at
15 # http://www.gentoo.org/doc/en/handbook/handbook-x86.xml?part=2&chap=1
16 #
17 # The available list of use flags with descriptions is in your portage tree.
18 # Use 'less' to view them:  --> less /usr/portage/profiles/use.desc <--
19 #
20 # 'ufed' is an ncurses/dialog interface available in portage to make handling
21 # useflags for you. 'emerge app-portage/ufed'
22 #
23 # Example:
24 #USE="X gtk gnome -alsa"
25
26 # Host and optimization settings 
27 # ==============================
28 #
29 # For optimal performance, enable a CFLAGS setting appropriate for your CPU.
30 #
31 # Please note that if you experience strange issues with a package, it may be
32 # due to gcc's optimizations interacting in a strange way. Please test the
33 # package (and in some cases the libraries it uses) at default optimizations
34 # before reporting errors to developers.
35 #
36 # Please refer to the GCC manual for a list of possible values.
37 #
38 #CFLAGS="-O2 -pipe"
39 #
40 # If you set a CFLAGS above, then this line will set your default C++ flags to
41 # the same settings.
42 #CXXFLAGS="${CFLAGS}"
43
44 # Advanced Masking
45 # ================
46 #
47 # Gentoo is using a new masking system to allow for easier stability testing
48 # on packages. KEYWORDS are used in ebuilds to mask and unmask packages based
49 # on the platform they are set for. A special form has been added that
50 # indicates packages and revisions that are expected to work, but have not yet
51 # been approved for the stable set. '~arch' is a superset of 'arch' which
52 # includes the unstable, in testing, packages. Users of the 'x86' architecture
53 # would add '~x86' to ACCEPT_KEYWORDS to enable unstable/testing packages.
54 # '~ppc', '~sparc' are the unstable KEYWORDS for their respective platforms.
55 #
56 # Please note that this is not for development, alpha, beta, nor cvs release
57 # packages. "Broken" packages will not be added to testing and should not be
58 # requested to be added. Alternative routes are available to developers
59 # for experimental packages, and it is at their discretion to use them.
60 #
61 # DO NOT PUT ANYTHING BUT YOUR SPECIFIC ~ARCHITECTURE IN THE LIST.
62 # IF YOU ARE UNSURE OF YOUR ARCH, OR THE IMPLICATIONS, DO NOT MODIFY THIS.
63 #
64 #ACCEPT_KEYWORDS="~arch"
65
66 # Portage Directories
67 # ===================
68 #
69 # Each of these settings controls an aspect of portage's storage and file
70 # system usage. If you change any of these, be sure it is available when
71 # you try to use portage. *** DO NOT INCLUDE A TRAILING "/" ***
72 #
73 # PORTAGE_TMPDIR is the location portage will use for compilations and
74 #     temporary storage of data. This can get VERY large depending upon
75 #     the application being installed.
76 #PORTAGE_TMPDIR=/var/tmp
77 #
78 # PORTDIR is the location of the portage tree. This is the repository
79 #     for all profile information as well as all ebuilds. If you change
80 #     this, you must update your /etc/make.profile symlink accordingly.
81 #PORTDIR=/usr/portage
82 #
83 # DISTDIR is where all of the source code tarballs will be placed for
84 #     emerges. The source code is maintained here unless you delete
85 #     it. The entire repository of tarballs for gentoo is 9G. This is
86 #     considerably more than any user will ever download. 2-3G is
87 #     a large DISTDIR.
88 #DISTDIR=${PORTDIR}/distfiles
89 #
90 # PKGDIR is the location of binary packages that you can have created
91 #     with '--buildpkg' or '-b' while emerging a package. This can get
92 #     upto several hundred megs, or even a few gigs.
93 #PKGDIR=${PORTDIR}/packages
94 #
95 # PORT_LOGDIR is the location where portage will store all the logs it
96 #     creates from each individual merge. They are stored as NNNN-$PF.log
97 #     in the directory specified. This is disabled until you enable it by
98 #     providing a directory. Permissions will be modified as needed IF the
99 #     directory exists, otherwise logging will be disabled. NNNN is the
100 #     increment at the time the log is created. Logs are thus sequential.
101 #PORT_LOGDIR=/var/log/portage
102 #
103 # PORTDIR_OVERLAY is a directory where local ebuilds may be stored without
104 #     concern that they will be deleted by rsync updates. Default is not
105 #     defined.
106 #PORTDIR_OVERLAY=/usr/local/portage
107
108 # Fetching files 
109 # ==============
110 #
111 # If you need to set a proxy for wget or lukemftp, add the appropriate "export
112 # ftp_proxy=<proxy>" and "export http_proxy=<proxy>" lines to /etc/profile if
113 # all users on your system should use them.
114 #
115 # Portage uses wget by default. Here are some settings for some alternate
116 # downloaders -- note that you need to merge these programs first before they
117 # will be available.
118 #
119 # Default fetch command (5 tries, passive ftp for firewall compatibility)
120 #FETCHCOMMAND="/usr/bin/wget -t 5 --passive-ftp \${URI} -P \${DISTDIR}"
121 #RESUMECOMMAND="/usr/bin/wget -c -t 5 --passive-ftp \${URI} -P \${DISTDIR}"
122 #
123 # Using wget, ratelimiting downloads
124 #FETCHCOMMAND="/usr/bin/wget -t 5 --passive-ftp --limit-rate=200k \${URI} -P \${DISTDIR}"
125 #RESUMECOMMAND="/usr/bin/wget -c -t 5 --passive-ftp --limit-rate=200k \${URI} -P \${DISTDIR}"
126 #
127 # Lukemftp (BSD ftp):
128 #FETCHCOMMAND="/usr/bin/lukemftp -s -a -o \${DISTDIR}/\${FILE} \${URI}"
129 #RESUMECOMMAND="/usr/bin/lukemftp -s -a -R -o \${DISTDIR}/\${FILE} \${URI}"
130 #
131 # Portage uses GENTOO_MIRRORS to specify mirrors to use for source retrieval.
132 # The list is a space separated list which is read left to right. If you use
133 # another mirror we highly recommend leaving the default mirror at the end of
134 # the list so that portage will fall back to it if the files cannot be found
135 # on your specified mirror. We _HIGHLY_ recommend that you change this setting
136 # to a nearby mirror by merging and using the 'mirrorselect' tool.
137 #GENTOO_MIRRORS="<your_mirror_here> http://distfiles.gentoo.org http://www.ibiblio.org/pub/Linux/distributions/gentoo"
138 #
139 # Portage uses PORTAGE_BINHOST to specify mirrors for prebuilt-binary packages.
140 # The list is a single entry specifying the full address of the directory
141 # serving the tbz2's for your system. Running emerge with either '--getbinpkg'
142 # or '--getbinpkgonly' will cause portage to retrieve the metadata from all
143 # packages in the directory specified, and use that data to determine what will
144 # be downloaded and merged. '-g' or '-gK' are the recommend parameters. Please
145 # consult the man pages and 'emerge --help' for more information. For FTP, the
146 # default connection is passive -- If you require an active connection, affix
147 # an asterisk (*) to the end of the host:port string before the path.
148 #PORTAGE_BINHOST="http://grp.mirror.site/gentoo/grp/1.4/i686/athlon-xp/"
149 # This ftp connection is passive ftp.
150 #PORTAGE_BINHOST="ftp://login:pass@grp.mirror.site/pub/grp/i686/athlon-xp/"
151 # This ftp connection is active ftp.
152 #PORTAGE_BINHOST="ftp://login:pass@grp.mirror.site:21*/pub/grp/i686/athlon-xp/"
153
154 # Synchronizing Portage
155 # =====================
156 #
157 # Each of these settings affects how Gentoo synchronizes your Portage tree.
158 # Synchronization is handled by rsync and these settings allow some control
159 # over how it is done.
160 #
161 #
162 # SYNC is the server used by rsync to retrieve a localized rsync mirror
163 #     rotation. This allows you to select servers that are geographically
164 #     close to you, yet still distribute the load over a number of servers.
165 #     Please do not single out specific rsync mirrors. Doing so places undue
166 #     stress on particular mirrors.  Instead you may use one of the following
167 #     continent specific rotations:
168 #
169 #   Default:       "rsync://rsync.gentoo.org/gentoo-portage"
170 #   North America: "rsync://rsync.namerica.gentoo.org/gentoo-portage"
171 #   South America: "rsync://rsync.samerica.gentoo.org/gentoo-portage"
172 #   Europe:        "rsync://rsync.europe.gentoo.org/gentoo-portage"
173 #   Asia:          "rsync://rsync.asia.gentoo.org/gentoo-portage"
174 #   Australia:     "rsync://rsync.au.gentoo.org/gentoo-portage"
175 #SYNC="rsync://rsync.gentoo.org/gentoo-portage"
176 #
177 # PORTAGE_RSYNC_RETRIES sets the number of times portage will attempt to retrieve
178 #     a current portage tree before it exits with an error. This allows
179 #     for a more successful retrieval without user intervention most times.
180 #PORTAGE_RSYNC_RETRIES="3"
181 #
182 # PORTAGE_RSYNC_EXTRA_OPTS can be used to feed additional options to the rsync
183 #     command used by `emerge --sync`. This will not change the default options
184 #     which are set by PORTAGE_RSYNC_OPTS (don't change those unless you know 
185 #     exactly what you're doing).
186 #PORTAGE_RSYNC_EXTRA_OPTS=""
187 #
188 # Advanced Features
189 # =================
190 #
191 # EMERGE_DEFAULT_OPTS allows emerge to act as if certain options are
192 #     specified on every run. Useful options include --ask, --verbose,
193 #     --usepkg and many others. Options that are not useful, such as --help,
194 #     are not filtered.
195 #EMERGE_DEFAULT_OPTS=""
196 #
197 # MAKEOPTS provides extra options that may be passed to 'make' when a
198 #     program is compiled. Presently the only use is for specifying
199 #     the number of parallel makes (-j) to perform. The suggested number
200 #     for parallel makes is CPUs+1.
201 #MAKEOPTS="-j2"
202 #
203 # PORTAGE_NICENESS provides a default increment to emerge's niceness level.
204 #     Note: This is an increment. Running emerge in a niced environment will
205 #     reduce it further. Default is unset.
206 #PORTAGE_NICENESS=3
207 #
208 # AUTOCLEAN enables portage to automatically clean out older or overlapping
209 #     packages from the system after every successful merge. This is the
210 #     same as running 'emerge -c' after every merge. Set with: "yes" or "no".
211 #     This does not affect the unpacked source. See 'noclean' below.
212 #AUTOCLEAN="yes"
213 #
214 # PORTAGE_TMPFS is a location where portage may create temporary files.
215 #     If specified, portage will use this directory whenever possible
216 #     for all rapid operations such as lockfiles and transient data.
217 #     It is _highly_ recommended that this be a tmpfs or ramdisk. Do not
218 #     set this to anything that does not give a significant performance
219 #     enhancement and proper FS compliance for locks and read/write.
220 #     /dev/shm is a glibc mandated tmpfs, and should be a reasonable
221 #     setting for all linux kernel+glibc based systems.
222 #PORTAGE_TMPFS="/dev/shm"
223 #
224 # FEATURES are settings that affect the functionality of portage. Most of
225 #     these settings are for developer use, but some are available to non-
226 #     developers as well. 
227 #
228 #  'autoaddcvs'  causes portage to automatically try to add files to cvs
229 #                that will have to be added later. Done at generation times
230 #                and only has an effect when 'cvs' is also set.
231 #  'buildpkg'    causes binary packages to be created of all packages that 
232 #                are being merged.
233 #  'ccache'      enables ccache support via CC.
234 #  'confcache'   enable confcache support; speeds up autotool based configure
235 #                calls
236 #  'collision-protect'
237 #                prevents packages from overwriting files that are owned by
238 #                another package or by no package at all.
239 #  'cvs'         causes portage to enable all cvs features (commits, adds),
240 #                and to apply all USE flags in SRC_URI for digests -- for
241 #                developers only.
242 #  'digest'      causes digests to be generated for all packages being merged.
243 #  'distcc'      enables distcc support via CC.
244 #  'distlocks'   enables distfiles locking using fcntl or hardlinks. This
245 #                is enabled by default. Tools exist to help clean the locks
246 #                after crashes: /usr/lib/portage/bin/clean_locks.
247 #  'fixpackages' allows portage to fix binary packages that are stored in
248 #                PKGDIR. This can consume a lot of time. 'fixpackages' is
249 #                also a script that can be run at any given time to force
250 #                the same actions.
251 #  'gpg'         enables basic verification of Manifest files using gpg.
252 #                This features is UNDER DEVELOPMENT and reacts to features
253 #                of strict and severe. Heavy use of gpg sigs is coming.
254 #  'keeptemp'    prevents the clean phase from deleting the temp files ($T) 
255 #                from a merge.
256 #  'keepwork'    prevents the clean phase from deleting the WORKDIR.
257 #  'test'    causes ebuilds to perform testing phases if they are capable
258 #                of it. Some packages support this automaticaly via makefiles.
259 #  'metadata-transfer'
260 #                automatically perform a metadata transfer when `emerge --sync`
261 #                is run.
262 #  'noauto'      causes ebuild to perform only the action requested and 
263 #                not any other required actions like clean or unpack -- for
264 #                debugging purposes only.
265 #  'noclean'     prevents portage from removing the source and temporary files 
266 #                after a merge -- for debugging purposes only. 
267 #  'nostrip'     prevents the stripping of binaries.
268 #  'notitles'    disables xterm titlebar updates (which contain status info). 
269 #  'parallel-fetch'
270 #                do fetching in parallel to compilation
271 #  'sandbox'     enables sandboxing when running emerge and ebuild.
272 #  'strict'      causes portage to react strongly to conditions that are
273 #                potentially dangerous, like missing/incorrect Manifest files.
274 #  'userpriv'    allows portage to drop root privileges while it is compiling,
275 #                as a security measure.  As a side effect this can remove 
276 #                sandbox access violations for users. 
277 #  'usersandbox' enables sandboxing while portage is running under userpriv.
278 #FEATURES="sandbox buildpkg ccache distcc userpriv usersandbox notitles noclean noauto cvs keeptemp keepwork autoaddcvs"
279 #FEATURES="sandbox ccache distcc distlocks autoaddcvs"
280 #
281 # CCACHE_SIZE sets the space use limitations for ccache. The default size is
282 #     2G, and will be set if not defined otherwise and ccache is in features. 
283 #     Portage will set the default ccache dir if it is not present in the
284 #     user's environment, for userpriv it sets: ${PORTAGE_TMPDIR}/ccache
285 #     (/var/tmp/ccache), and for regular use the default is /root/.ccache.
286 #     Sizes are specified with 'G' 'M' or 'K'.
287 #     '2G' for 2 gigabytes, '2048M' for 2048 megabytes (same as 2G).
288 #CCACHE_SIZE="512M"
289 #
290 # DISTCC_DIR sets the temporary space used by distcc.
291 #DISTCC_DIR="${PORTAGE_TMPDIR}/.distcc"
292 #
293 # RSYNC_EXCLUDEFROM is a file that portage will pass to rsync when it updates
294 #     the portage tree. Specific chunks of the tree may be excluded from
295 #     consideration. This may cause dependency failures if you are not careful.
296 #     The file format is one pattern per line, blanks and ';' or '#' lines are
297 #     comments. See 'man rsync' for more details on the exclude-from format.
298 #RSYNC_EXCLUDEFROM=/etc/portage/rsync_excludes
299
300 # logging related variables:
301 # PORTAGE_ELOG_CLASSES: selects messages to be logged, possible values are:
302 #                          info, warn, error, log
303 #                       Warning: commenting this will disable elog
304 PORTAGE_ELOG_CLASSES="warn error log"
305
306 # PORTAGE_ELOG_SYSTEM: selects the module(s) to process the log messages. Modules
307 #                      included in portage are (empty means logging is disabled):
308 #                          save (saves one log per package in $PORTAGE_TMPDIR/elogs)
309 #                          custom (passes all messages to $PORTAGE_LOG_COMMAND)
310 #                          syslog (sends all messages to syslog)
311 #                          mail (send all messages to the mailserver defined 
312 #                                in $PORTAGE_LOG_MAILURI)
313 #                      To use elog you should enable at least one module
314 #PORTAGE_ELOG_SYSTEM="save mail"
315
316 # PORTAGE_ELOG_COMMAND: only used with the "custom" logging module. Specifies a command
317 #                      to process log messages. Two variables are expanded:
318 #                          ${PACKAGE} - expands to the cpv entry of the processed 
319 #                                       package (see $PVR in ebuild(5))
320 #                          ${LOGFILE} - absolute path to the logfile
321 #                                               Both variables have to be quoted with single quotes
322 #PORTAGE_ELOG_COMMAND="/path/to/logprocessor -p '${PACKAGE}' -f '${LOGFILE}'"
323
324 # PORTAGE_ELOG_MAILURI: this variable holds all important settings for the mail
325 #                       module. In most cases listing the recipient address and
326 #                       the receiving mailserver should be sufficient, but you can
327 #                       also use advanced settings like authentication or TLS. The
328 #                       full syntax is:
329 #                           address [[user:passwd@]mailserver[:port]]
330 #                       where
331 #                           address:     recipient address
332 #                           user:       username for smtp auth (defaults to none)
333 #                           passwd:     password for smtp auth (defaults to none)
334 #                           mailserver: smtp server that should be used to deliver the mail (defaults to localhost)
335 #                           port:       port to use on the given smtp server (defaults to 25, values > 100000 indicate that starttls should be used on (port-100000))
336 #                       Examples:
337 #PORTAGE_ELOG_MAILURI="root@localhost localhost" (this is also the default setting)
338 #PORTAGE_ELOG_MAILURI="user@some.domain mail.some.domain" (sends mails to user@some.domain using the mailserver mail.some.domain)
339 #PORTAGE_ELOG_MAILURI="user@some.domain user:secret@mail.some.domain:100465" (this is left uncommented as a reader excercise ;)