Gentoo Websites Logo
Go to: Gentoo Home Documentation Forums Lists Bugs Planet Store Wiki Get Gentoo!
Bug 497220 - app-portage/ufed-0.90_rc2-r1 - ufed: WARNING: 'portageq envvar PORTDIR' is deprecated. Use 'portageq repositories_configuration' instead.
Summary: app-portage/ufed-0.90_rc2-r1 - ufed: WARNING: 'portageq envvar PORTDIR' is de...
Status: RESOLVED FIXED
Alias: None
Product: Portage Development
Classification: Unclassified
Component: Third-Party Tools (show other bugs)
Hardware: All Linux
: Normal normal (vote)
Assignee: Sven Eden
URL:
Whiteboard:
Keywords:
Depends on:
Blocks:
 
Reported: 2014-01-06 09:26 UTC by Juergen Rose
Modified: 2014-03-21 15:29 UTC (History)
6 users (show)

See Also:
Package list:
Runtime testing required: ---


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description Juergen Rose 2014-01-06 09:26:29 UTC
ufed complains:

root@caiman:/root(2)# ufed
WARNING: 'portageq envvar PORTDIR' is deprecated. Use 'portageq repositories_configuration' instead.
WARNING: 'portageq envvar PORTDIR_OVERLAY' is deprecated. Use 'portageq repositories_configuration' instead.
Cancelled, not saving changes.

I have set PORTDIR_OVERLAY in /etc/make.conf:

root@caiman:/root(7)# grep PORTDIR /etc/make.conf
PORTDIR_OVERLAY="/usr/local/portage ${GCPAN_OVERLAY} ${GOCTAVE_OVERLAY}"

root@caiman:/root(8)# qlist -Iv ufed
app-portage/ufed-0.90_rc2-r1




root@caiman:/root(9)# emerge --info =ufed-0.90_rc2-r1
Portage 2.2.8 (default/linux/amd64/13.0, gcc-4.8.2, glibc-2.17, 3.12.6-gentoo x86_64)
=================================================================
                        System Settings
=================================================================
System uname: Linux-3.12.6-gentoo-x86_64-AMD_Phenom-tm-_II_X6_1090T_Processor-with-gentoo-2.2
KiB Mem:    16178132 total,   1518016 free
KiB Swap:  100663280 total, 100616408 free
Timestamp of tree: Mon, 06 Jan 2014 03:00:01 +0000
ld GNU ld (GNU Binutils) 2.24
app-shells/bash:          4.2_p45
dev-java/java-config:     2.2.0
dev-lang/python:          2.7.6, 3.3.3
dev-util/cmake:           2.8.12.1-r2
dev-util/pkgconfig:       0.28
sys-apps/baselayout:      2.2
sys-apps/openrc:          0.12.4
sys-apps/sandbox:         2.6-r1
sys-devel/autoconf:       2.13, 2.69
sys-devel/automake:       1.10.3, 1.11.6, 1.12.6, 1.14.1
sys-devel/binutils:       2.24
sys-devel/gcc:            4.8.2
sys-devel/gcc-config:     1.8
sys-devel/libtool:        2.4.2
sys-devel/make:           4.0-r1
sys-kernel/linux-headers: 3.12 (virtual/os-headers)
sys-libs/glibc:           2.17
Repositories: gentoo x11 science sunrise x-portage g-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 NVIDIA-CUDA Nero-AAC-EULA GIMPS"
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.5/ext-active/ /etc/php/cgi-php5.5/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 parallel-fetch preserve-libs protect-owned sandbox sfperms strict unknown-features-warn unmerge-logs unmerge-orphans userfetch userpriv usersandbox usersync xattr"
FFLAGS="-O2 -pipe"
GENTOO_MIRRORS="http://distfiles.gentoo.org"
LANG="en_US.UTF-8"
LDFLAGS="-Wl,-O1 -Wl,--as-needed"
MAKEOPTS="-j7"
PKGDIR="/usr/portage/packages"
PORTAGE_CONFIGROOT="/"
PORTAGE_RSYNC_OPTS="--recursive --links --safe-links --perms --times --omit-dir-times --compress --force --whole-file --delete --stats --human-readable --timeout=180 --exclude=/distfiles --exclude=/local --exclude=/packages"
PORTAGE_TMPDIR="/var/tmp"
PORTDIR="/usr/portage_caiman"
PORTDIR_OVERLAY="/var/lib/layman/x11 /var/lib/layman/science /var/lib/layman/sunrise /usr/local/portage /var/lib/cpan /var/lib/g-octave"
USE="3dnow 3dnowext 64bit R X Xaw3d a52 aac 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 cgi chm cli cmake consolekit cracklib crypt css 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 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 irda ithreads jabber jadetex java java6 jbig john jpeg jpeg2k kate kdepim kdrive kerberos keymap kpathsea kvm ladspa lame lapack latex lcms ldap lensfun libffi libkms libnotify libsamplerate live lm_sensors lua lzma 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 obex objc ocaml ocr octave odbc ofa ogdi ogg openexr opengl openmp openvg pam pango 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 systemd szip t1lib tcl tcpd tex tex4ht texmacs tgif theora thesaurus threads thunderbird tidy tiff tk toolbar 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 ublox 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="php5-3" PYTHON_SINGLE_TARGET="python2_7" PYTHON_TARGETS="python2_7 python3_3" QEMU_SOFTMMU_TARGETS="arm i386 x86_64" QEMU_USER_TARGETS="arm i386 x86_64" RUBY_TARGETS="ruby19 ruby18" USERLAND="GNU" VIDEO_CARDS="radeon 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, SYNC, USE_PYTHON

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

app-portage/ufed-0.90_rc2-r1 was built with the following:
USE=""


Reproducible: Always
Comment 1 Paul Varner (RETIRED) gentoo-dev 2014-01-07 21:25:37 UTC
I'll work on this when I get a chance.

However, the command portageq repositories_configuration is not a suitable replacement for portageq envvar PORTDIR.

The tools are looking for the directory of the main repository.

Here is the difference in outputs:

# portageq envvar PORTDIR
WARNING: 'portageq envvar PORTDIR' is deprecated. Use 'portageq repositories_configuration' instead.
/usr/portage

# portageq repositories_configuration /            
[DEFAULT]
main-repo = gentoo

[gentoo]
location = /usr/portage
masters = 
priority = -1000
sync-type = rsync
sync-uri = rsync://rsync.namerica.gentoo.org/gentoo-portage

[local]
location = /usr/local/portage/local
masters = gentoo
priority = 0

Honestly, given that I might as well have the tools parse repos.conf directly since it becomes the same level of complexity.
Comment 2 Sven Eden 2014-01-08 09:58:37 UTC
This could be easily changed by using dev-perl/Config-IniFiles, but that would add another dependency, which I'd like to avoid.

However, parsing INI-Files isn't that hard.

I guess I'll fix this for the 0.91 release.

Paul, did you get my E-Mails regarding the 0.90 final release?

( *sigh* I am assigned but (again) can't change the status to "IN_PROGRESS", could somebody change it then, please? )
Comment 3 Sebastian Luther (few) 2014-01-08 10:15:13 UTC
(In reply to Sven Eden from comment #2)
> This could be easily changed by using dev-perl/Config-IniFiles, but that
> would add another dependency, which I'd like to avoid.

Don't do that. If what portageq provides is insufficient we'll add more commands.

I think that the deprecation warning suggest "portageq repositories_configuration" is very unfortunate. It should point users to 'get_repos and get_repo_path'. These two may or may not be good enough for you. For example there's no command to get the 'main-repo', but portage is moving in a direction where this concept doesn't make sense any more. So hardcoding the repository name 'gentoo' may be good enough for you.

> 
> However, parsing INI-Files isn't that hard.
> 
> I guess I'll fix this for the 0.91 release.
> 
> Paul, did you get my E-Mails regarding the 0.90 final release?
> 
> ( *sigh* I am assigned but (again) can't change the status to "IN_PROGRESS",
> could somebody change it then, please? )
Done.
Comment 4 Sergey Popov gentoo-dev 2014-01-16 09:10:24 UTC
Little addition to previous comment - result string will look like

portageq get_repo_path $(portageq envvar EROOT) gentoo
Comment 5 Sven Eden 2014-01-16 11:38:46 UTC
(In reply to Sergey Popov from comment #4)
> Little addition to previous comment - result string will look like
> 
> portageq get_repo_path $(portageq envvar EROOT) gentoo

This works, although it needs several seconds to complete on my machine, which is a nightmare with ufed parsing so much stuff!

========
 ~ $ xEROOT="$(portageq envvar EROOT)" ; time for repo in $(portageq get_repos $xEROOT) ; do echo "$repo;$(portageq get_repo_path $xEROOT $repo)" ; done
SED-Local;/usr/local/portage
stuff;/var/lib/layman/stuff
mv;/var/lib/layman/mv
vmware;/var/lib/layman/vmware
java;/var/lib/layman/java
init6;/var/lib/layman/init6
sunrise;/var/lib/layman/sunrise
proaudio;/var/lib/layman/pro-audio
qt;/var/lib/layman/qt
seden;/var/lib/layman/seden
gentoo;/usr/portage

real    0m3.731s
user    0m3.355s
sys     0m0.358s
========

Why is portageq this slow? Might there be a faster way?

... some minutes later ... Good I didn't submit, yet:

Found a faster way, as I only need the paths anyway:

========

 ~ $ time ( xEROOT="$(portageq envvar EROOT)" ; portageq get_repo_path $xEROOT $(portageq get_repos $xEROOT) )
/usr/local/portage
/var/lib/layman/stuff
/var/lib/layman/mv
/var/lib/layman/vmware
/var/lib/layman/java
/var/lib/layman/init6
/var/lib/layman/sunrise
/var/lib/layman/pro-audio
/var/lib/layman/qt
/var/lib/layman/seden
/usr/portage

real    0m0.929s
user    0m0.859s
sys     0m0.066s
========

I think I can live with that.
Comment 6 Martin Väth 2014-02-01 15:17:39 UTC
You can also check whether eix is available and in this case use
eix --print PORTDIR
eix --print PORTDIR_OVERLAY
(with a fallback to the slower portageq if eix is not available).
Comment 7 Martin Väth 2014-02-01 16:30:19 UTC
Just to avoid a misunderstanding:

These two "environment variables" are *calculated* by eix (using repos.conf).

Note that for perl you should set $ENV{PRINT_APPEND}=''; then you do not need to "chomp" the output. However, you should "chop" the output of --print PORTDIR since (in contrast to PORTDIR_OVERLAY) this is normalized to contain a trailing slash.
Comment 8 Sven Eden 2014-02-05 13:26:52 UTC
 ~ $ time PRINT_APPEND='' eix --print PORTDIR
/usr/portage/
real    0m0.043s
user    0m0.035s
sys     0m0.008s

 ~ $ time PRINT_APPEND='' eix --print PORTDIR_OVERLAY
/var/lib/layman/seden /var/lib/layman/qt /var/lib/layman/pro-audio /var/lib/layman/sunrise /var/lib/layman/init6 /var/lib/layman/java /var/lib/layman/vmware /var/lib/layman/mv /var/lib/layman/stuff /usr/local/portage
real    0m0.045s
user    0m0.037s
sys     0m0.008s

Wow! Much faster. Thank you very much for the suggestion!

Hopefully I'll have some time the next few days to add this, with the portageq varaiant as a fallback.
Comment 9 Sven Eden 2014-02-25 11:28:15 UTC
I have added a determination of PORTDIR and PORTDIR_OVERLAY using eix if available with portageq as fallback.

Please test using the live ebuild.
Comment 10 Francesco Turco 2014-03-18 19:28:36 UTC
I get the following error when using euse from gentoolkit-0.3.0.9:

> WARNING: 'portageq envvar PORTDIR' is deprecated. Use 'portageq repositories_configuration' instead.

Should I file a separate bug?
Comment 11 Francesco Turco 2014-03-20 12:24:21 UTC
I decided to file bug 505160 specifically for euse.
Comment 12 Sven Eden 2014-03-21 15:29:14 UTC
This bug is fixed with the new version 0.91 in the tree.