Gentoo Websites Logo
Go to: Gentoo Home Documentation Forums Lists Bugs Planet Store Wiki Get Gentoo!

Bug 475916

Summary: sys-apps/portage - Error output for USE_EXPAND flags is unclear towards the user; doesn't suggest whether to do PHP_TARGETS="php_targets_php5-3" or PHP_TARGETS="php5-3", leaves user confused.
Product: Portage Development Reporter: Juergen Rose <rose>
Component: Core - Interface (emerge)Assignee: Portage team <dev-portage>
Status: CONFIRMED ---    
Severity: normal CC: tomwij
Priority: Normal    
Version: unspecified   
Hardware: All   
OS: Linux   
Whiteboard:
Package list:
Runtime testing required: ---

Description Juergen Rose 2013-07-06 08:03:31 UTC
'emerge -uvDN world' fails with:

root@impala:/root(17)# emerge -uvDN world
...
!!! The ebuild selected to satisfy "dev-php/pecl-ps" has unmet requirements.
- dev-php/pecl-ps-1.3.6-r1::gentoo USE="examples" PHP_TARGETS="-php5-3"

  The following REQUIRED_USE flag constraints are unsatisfied:
    php_targets_php5-3

  The above constraints are a subset of the following complete expression:
    any-of ( php_targets_php5-3 )

(dependency required by "app-benchmarks/phoronix-test-suite-4.6.1" [installed])
(dependency required by "@selected" [set])
(dependency required by "@world" [argument])

Setting PHP_TARGETS="php_targets_php5-3" in /etc/make.conf does not help:

root@impala:/root(21)# grep php_targets_php5-3 /etc/make.conf
PHP_TARGETS="php_targets_php5-3"

root@impala:/root(23)# emerge -uvDN world
...
!!! The ebuild selected to satisfy "dev-php/pecl-ps" has unmet requirements.
- dev-php/pecl-ps-1.3.6-r1::gentoo USE="examples" PHP_TARGETS="-php5-3"



root@impala:/root(27)# emerge --info pecl-ps
Portage 2.1.12.11 (default/linux/amd64/13.0, gcc-4.7.3, glibc-2.17, 3.10.0-gentoo x86_64)
=================================================================
                        System Settings
=================================================================
System uname: Linux-3.10.0-gentoo-x86_64-AMD_Phenom-tm-_II_X4_965_Processor-with-gentoo-2.2
KiB Mem:     8165416 total,    623048 free
KiB Swap:   50347696 total,  49983520 free
Timestamp of tree: Sat, 06 Jul 2013 07:00:02 +0000
ld GNU ld (GNU Binutils) 2.23.1
app-shells/bash:          4.2_p45
dev-java/java-config:     2.2.0
dev-lang/python:          2.7.5, 3.2.5-r1, 3.3.2-r1
dev-util/cmake:           2.8.11.1
dev-util/pkgconfig:       0.28
sys-apps/baselayout:      2.2
sys-apps/openrc:          0.11.8
sys-apps/sandbox:         2.6-r1
sys-devel/autoconf:       2.13, 2.69
sys-devel/automake:       1.9.6-r3, 1.10.3, 1.11.6, 1.12.6, 1.14
sys-devel/binutils:       2.23.1
sys-devel/gcc:            4.6.4, 4.7.3
sys-devel/gcc-config:     1.8
sys-devel/libtool:        2.4.2
sys-devel/make:           3.82-r4
sys-kernel/linux-headers: 3.9 (virtual/os-headers)
sys-libs/glibc:           2.17
Repositories: gentoo x11 science sage-on-gentoo sunrise x-portage x-cpan g-octave
ACCEPT_KEYWORDS="amd64 ~amd64"
ACCEPT_LICENSE="* -@EULA PUEL Intel-SDP dlj-1.1 skype-eula skype-4.0.0.7-copyright googleearth AdobeFlash-11.x cadsoft Oracle-BCLA-JavaSE MakeMKV-EULA"
CBUILD="x86_64-pc-linux-gnu"
CFLAGS="-march=amdfam10 -O2 -pipe"
CHOST="x86_64-pc-linux-gnu"
CONFIG_PROTECT="/etc /usr/share/config /usr/share/gnupg/qualified.txt /var/lib/hsqldb"
CONFIG_PROTECT_MASK="/etc/ca-certificates.conf /etc/dconf /etc/env.d /etc/fonts/fonts.conf /etc/gconf /etc/gentoo-release /etc/php/apache2-php5.3/ext-active/ /etc/php/apache2-php5.5/ext-active/ /etc/php/cgi-php5.3/ext-active/ /etc/php/cgi-php5.5/ext-active/ /etc/php/cli-php5.3/ext-active/ /etc/php/cli-php5.5/ext-active/ /etc/revdep-rebuild /etc/sandbox.d /etc/terminfo /etc/texmf/language.dat.d /etc/texmf/language.def.d /etc/texmf/updmap.d /etc/texmf/web2c"
CXXFLAGS="-march=amdfam10 -O2 -pipe"
DISTDIR="/usr/portage/distfiles"
FCFLAGS="-O2 -pipe"
FEATURES="assume-digests binpkg-logs config-protect-if-modified distlocks ebuild-locks fixlafiles merge-sync news noclean nostrip parallel-fetch preserve-libs protect-owned sandbox sfperms splitdebug strict unknown-features-warn unmerge-logs unmerge-orphans userfetch xattr"
FFLAGS="-O2 -pipe"
GENTOO_MIRRORS="http://distfiles.gentoo.org"
LANG="en_US.UTF-8"
LDFLAGS="-Wl,-O1 -Wl,--as-needed"
MAKEOPTS="-j5"
PKGDIR="/usr/portage/packages"
PORTAGE_CONFIGROOT="/"
PORTAGE_RSYNC_OPTS="--recursive --links --safe-links --perms --times --compress --force --whole-file --delete --stats --human-readable --timeout=180 --exclude=/distfiles --exclude=/local --exclude=/packages"
PORTAGE_TMPDIR="/var/tmp"
PORTDIR="/usr/portage"
PORTDIR_OVERLAY="/var/lib/layman/x11 /var/lib/layman/science /var/lib/layman/sage-on-gentoo /var/lib/layman/sunrise /usr/local/portage /var/lib/cpan /var/lib/g-octave"
SYNC="rsync://rsync.gentoo.org/gentoo-portage"
USE="3dnow 3dnowext 64bit R X Xaw3d a52 aac accessibility acl acpi admin afs alsa amd64 ao apache2 apng applet archive armadillo arpack asf aspell atlas audacious audiofile automap automount bash-completion berkdb blas blast bluetooth bluray boost bzip2 cairo cdda cddb cdf cdio cdparanoia cdr cg cgi chm cli cmake consolekit cracklib crypt css cuda cups curl cxx daap db dbi dbm dbus declarative designer devhelp device-mapper dga dia dirac djvu doc dot dri ds2490 ds9097 ds9097u dts dv dvb dvd dvdr dvi dynamicplugin eds egl elf emacs emboss emf encode epiphany evo examples exif expat extensions extra extras faac faad fam ffmpeg fftw firefox fits flac fltk fontconfig foomaticdb fortran fortran95 fpm fpx fuse g3dvl gcj gd gdal gdbm gdu gedit geoip geolocation geos gfortran gif gimp git glade glib glpk gml gmp gnome gnome-keyring gnome-print gnuplot gnutls gold gphoto2 gpm grammar graphics graphtft graphviz grass gsl gsm gstreamer gtk gtk3 gudev guile hddtemp hdf hdf5 hdri html http httpd hvm hwdb iconv icq icu id3 id3tag ide imagemagick imap inotify introspection ipod ipv6 ithreads jabber jadetex java java6 jbig john jpeg jpeg2k kate kde kdepim kdrive kerberos keymap kpathsea kvm ladspa lame lapack latex lcms ldap lensfun libffi libkms libnotify libsamplerate live lm_sensors lua lzo mad mail maildir mapnik math matroska media-library mercurial mikmod mkl mmx mmxext mng mod modules mono motif mozilla mp3 mp4 mpeg mpi mplayer mtp mudflap multilib multimedia musepack musicbrainz mysql mysqli nautilus ncurses netcdf netpbm network networking networkmanager nfs nls nntp nptl nsplugin ntfs ntp numpy nvidia obex objc ocaml ocr octave odbc ofa ogdi ogg openexr opengl openmp pam pcre pda pdf perl plasma plotutils plugins png podcast policykit portaudio posix postgres postscript ppds preview-latex proj projectm projectx pstricks pulseaudio python python-bindings q16 q32 qemu qhull qt3support qt4 quicktime raw readline real reiserfs reports rhythmbox rle romio rpc rrdcgi rrdtool sage samba sasl schroedinger science sdk sdl secure-delete semantic-desktop server session shout sip slang slp smart smbclient smp sms sndfile snmp soap sockets sound soup sox speex spell sql sqlite sse sse2 ssl stlport subtitles subversion sudo suexec svg svm swig szip t1lib tcl tcpd tex tex4ht texmacs tgif theora thesaurus threads thunderbird tidy tiff tk tools truetype udev udisks unicode usb userlocales utempter v4l vaapi vala valgrind vdpau video virt-network virtualbox visio vorbis vpx wav webdav webdav-serf webkit wmf wxwidgets x264 xa xattr xcb xemacs xetex xext xft xine xml xmlreader xmlrpc xpm xv xvid xvmc yaml youtube zlib zvbi" ABI_X86="64" ALSA_CARDS="ali5451 als4000 atiixp atiixp-modem bt87x ca0106 cmipci emu10k1x ens1370 ens1371 es1938 es1968 fm801 hda-intel intel8x0 intel8x0m maestro3 trident usb-audio via82xx via82xx-modem ymfpci" APACHE2_MODULES="actions alias auth_basic auth_digest authn_anon authn_dbd authn_core authn_dbm authn_default authn_file authz_core authz_dbm authz_default authz_groupfile authz_host authz_owner authz_user autoindex cache cgid dav dav_fs dav_lock dbd deflate dir disk_cache env expires ext_filter file_cache filter headers ident imagemap include info lbmethod_byrequests log_config logio mem_cache mime mime_magic negotiation proxy proxy_ajp proxy_balancer proxy_connect proxy_http rewrite setenvif slotmem_shm so socache_shmcb speling status unique_id unixd userdir usertrack vhost_alias" CALLIGRA_FEATURES="kexi words flow plan sheets stage tables krita karbon braindump author" CAMERAS="canon fuji ptp2" COLLECTD_PLUGINS="df interface irq load memory rrdtool swap syslog" CURL_SSL="nss" DRACUT_MODULES="caps lvm mdraid syslog" ELIBC="glibc" GPSD_PROTOCOLS="ashtech aivdm earthmate evermore fv18 garmin garmintxt gpsclock itrax mtk3301 nmea ntrip navcom oceanserver oldstyle oncore rtcm104v2 rtcm104v3 sirf superstar2 timing tsip tripmate tnt ubx" INPUT_DEVICES="keyboard mouse evdev void" KERNEL="linux" LCD_DEVICES="cfontz hd44780 mtxorb ncurses X lcd2usb lcdlinux png usblcd" LIBREOFFICE_EXTENSIONS="presenter-console presenter-minimizer" LINGUAS="de fr ru" NETBEANS_MODULES="apisupport cnd dlight enterprise ergonomics groovy gsf harness ide identity j2ee java mobility nb php profiler ruby websvccommon xml" OFFICE_IMPLEMENTATION="libreoffice" PHP_TARGETS="php_targets_php5-3" PYTHON_SINGLE_TARGET="python2_7" PYTHON_TARGETS="python2_7 python3_2" QEMU_SOFTMMU_TARGETS="arm i386 x86_64" QEMU_USER_TARGETS="arm i386 x86_64" RUBY_TARGETS="ruby19 ruby18" USERLAND="GNU" VIDEO_CARDS="nouveau displaylink" XTABLES_ADDONS="quota2 psd pknock lscan length2 ipv4options ipset ipp2p iface geoip fuzzy condition tee tarpit sysrq steal rawnat logmark ipmark dhcpmac delude chaos account"
Unset:  CPPFLAGS, CTARGET, EMERGE_DEFAULT_OPTS, INSTALL_MASK, LC_ALL, PORTAGE_BUNZIP2_COMMAND, PORTAGE_COMPRESS, PORTAGE_COMPRESS_FLAGS, PORTAGE_RSYNC_EXTRA_OPTS, USE_PYTHON

=================================================================
                        Package Settings
=================================================================

dev-php/pecl-ps-1.3.6-r1 was built with the following:
USE="examples" PHP_TARGETS="php5-3"




Setting PHP_TARGETS="php5-3" in /etc/make.conf seems to help. The first error message was a little bit misleading.
Comment 1 Tom Wijsman (TomWij) (RETIRED) gentoo-dev 2013-07-06 18:04:00 UTC
At the least, it would be nice if Portage also suggests to change the variable.

For example:

    The minimal make.conf change needed to satisfy the requirements is:

        PHP_TARGETS="php5-3"

And optionally we could add:

    Possible other combinations are:

        ... enumerate all possible satisfied combinations for PHP_TARGETS ...

Expanded dependency output is nice for devs, but is confusing towards users.
Comment 2 Tony Butler 2014-11-05 17:50:34 UTC
This message seems to be repaired, currently gives:

 * Make sure that PHP_TARGETS in /etc/make.conf includes php5-5 in order 
 * to compile extensions for the 5.5 ABI

However if the is no PHP_TARGETS defined at all, and you're only installing php freshly, this should be assumed.  Took me a while to figure out I was missing a definition that should be the default.
Comment 3 Tony Butler 2014-11-05 18:03:52 UTC
[ebuild   R    ] dev-lang/php-5.5.18:5.5  USE="berkdb bzip2 cli crypt ctype curl fileinfo filter fpm gd gdbm gmp hash iconv ipv6 json ldap ldap-sasl mhash nls opcache phar posix readline session simplexml snmp sqlite ssl threads* tokenizer truetype unicode vpx xml zip zlib -apache2 -bcmath -calendar -cdb -cgi -cjk -debug -embed -enchant -exif (-firebird) -flatfile (-frontbase) -ftp -imap -inifile -intl -iodbc -kerberos -libedit -libmysqlclient -mssql -mysql -mysqli -oci8-instant-client -odbc -pcntl -pdo -postgres -qdbm -recode (-selinux) -sharedmem* -soap -sockets -spell (-sybase-ct) -systemd -sysvipc -tidy -wddx -xmlreader -xmlrpc -xmlwriter -xpm -xslt" 0 kB


Also of note, it doesn't show PHP_TARGETS on that line like every other USE_EXPAND using package does.
Comment 4 Zac Medico gentoo-dev 2014-11-05 22:33:10 UTC
(In reply to Tony Butler from comment #3)
> [ebuild   R    ] dev-lang/php-5.5.18:5.5  USE="berkdb bzip2 cli crypt ctype
> curl fileinfo filter fpm gd gdbm gmp hash iconv ipv6 json ldap ldap-sasl
> mhash nls opcache phar posix readline session simplexml snmp sqlite ssl
> threads* tokenizer truetype unicode vpx xml zip zlib -apache2 -bcmath
> -calendar -cdb -cgi -cjk -debug -embed -enchant -exif (-firebird) -flatfile
> (-frontbase) -ftp -imap -inifile -intl -iodbc -kerberos -libedit
> -libmysqlclient -mssql -mysql -mysqli -oci8-instant-client -odbc -pcntl -pdo
> -postgres -qdbm -recode (-selinux) -sharedmem* -soap -sockets -spell
> (-sybase-ct) -systemd -sysvipc -tidy -wddx -xmlreader -xmlrpc -xmlwriter
> -xpm -xslt" 0 kB
> 
> 
> Also of note, it doesn't show PHP_TARGETS on that line like every other
> USE_EXPAND using package does.

That's because dev-lang/php doesn't use PHP_TARGETS. PHP_TARGETS is for packages like dev-php/pecl-ps that require one or more php implementations.