And adjust users.
Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
        select BR2_PACKAGE_BUSYBOX_SHOW_OTHERS # util-linux
        select BR2_PACKAGE_UTIL_LINUX
        select BR2_PACKAGE_UTIL_LINUX_LIBBLKID
+       select BR2_PACKAGE_UTIL_LINUX_LIBUUID
        help
-         The EXT2 file system utilities and libraries
+         The EXT2 file system utilities.
 
-menuconfig BR2_PACKAGE_E2FSPROGS_UTILS
-       bool "e2fsprogs utilities"
-       depends on BR2_PACKAGE_E2FSPROGS
-       help
-         e2fsprogs utilities selection
+         http://e2fsprogs.sf.net
 
-if BR2_PACKAGE_E2FSPROGS_UTILS
+if BR2_PACKAGE_E2FSPROGS
 
 config BR2_PACKAGE_E2FSPROGS_BADBLOCKS
        bool "badblocks"
 config BR2_PACKAGE_E2FSPROGS_DUMPE2FS
        bool "dumpe2fs"
        default y
-       select BR2_PACKAGE_E2FSPROGS_LIBUUID
 
 config BR2_PACKAGE_E2FSPROGS_E2FREEFRAG
        bool "e2freefrag"
 config BR2_PACKAGE_E2FSPROGS_UUIDGEN
        bool "uuidgen"
        default y
-       select BR2_PACKAGE_E2FSPROGS_LIBUUID
 
 config BR2_PACKAGE_E2FSPROGS_UUIDD
        bool "uuidd"
        default y
-       select BR2_PACKAGE_E2FSPROGS_LIBUUID
        help
          The uuidd daemon from the e2fsprogs suite
 
 endif
 
-menu "e2fsprogs libraries"
-       depends on BR2_PACKAGE_E2FSPROGS
-
-config BR2_PACKAGE_E2FSPROGS_LIBUUID
-       bool "libuuid"
-       help
-         The uuid library from the e2fsprogs suite
-
-endmenu
-
 comment "e2fsprogs requires a toolchain with LARGEFILE + WCHAR support"
        depends on !(BR2_LARGEFILE && BR2_USE_WCHAR)
-
 
 
 E2FSPROGS_VERSION = 1.41.14
 E2FSPROGS_SITE = http://$(BR2_SOURCEFORGE_MIRROR).dl.sourceforge.net/sourceforge/e2fsprogs
-E2FSPROGS_INSTALL_STAGING = YES
 
 E2FSPROGS_CONF_OPT = \
        --disable-tls \
        $(if $(BR2_PACKAGE_E2FSPROGS_RESIZE2FS),,--disable-resizer) \
        $(if $(BR2_PACKAGE_E2FSPROGS_UUIDD),,--disable-uuidd) \
        --disable-blkid \
+       --disable-libuuid \
        --enable-fsck \
        --disable-e2initrd-helper \
        --disable-testio-debug
 E2FSPROGS_BINTARGETS_$(BR2_PACKAGE_E2FSPROGS_MKLOSTFOUND) += usr/sbin/mklost+found
 E2FSPROGS_BINTARGETS_$(BR2_PACKAGE_E2FSPROGS_UUIDGEN) += usr/bin/uuidgen
 
-# libraries to keep or remove
-E2FSPROGS_BINTARGETS_$(BR2_PACKAGE_E2FSPROGS_LIBUUID) += usr/lib/libuuid.so*
-E2FSPROGS_BINTARGETS_$(BR2_PACKAGE_E2FSPROGS_UTILS) += usr/lib/libcom_err.so*
-E2FSPROGS_BINTARGETS_$(BR2_PACKAGE_E2FSPROGS_UTILS) += usr/lib/libe2p.so*
-E2FSPROGS_BINTARGETS_$(BR2_PACKAGE_E2FSPROGS_UTILS) += usr/lib/libext2fs.so*
-E2FSPROGS_BINTARGETS_$(BR2_PACKAGE_E2FSPROGS_UTILS) += usr/lib/libss.so*
-
 # files to remove
 E2FSPROGS_TXTTARGETS_ = \
        usr/sbin/mkfs.ext[234] \
 E2FSPROGS_POST_INSTALL_TARGET_HOOKS += E2FSPROGS_TARGET_FINDFS_SYMLINK
 endif
 
-define E2FSPROGS_STAGING_LIBUUID_INSTALL
-       install -D $(@D)/lib/uuid/uuid.h $(STAGING_DIR)/usr/include/uuid/uuid.h
-       install -D $(@D)/lib/uuid/uuid.pc \
-               $(STAGING_DIR)/usr/lib/pkgconfig/uuid.pc
-endef
-
-ifeq ($(BR2_PACKAGE_E2FSPROGS_LIBUUID),y)
-E2FSPROGS_POST_INSTALL_STAGING_HOOKS += E2FSPROGS_STAGING_LIBUUID_INSTALL
-endif
-
 $(eval $(call AUTOTARGETS,package,e2fsprogs))
 $(eval $(call AUTOTARGETS,package,e2fsprogs,host))
 
 config BR2_PACKAGE_GDISK
        bool "gdisk"
-       depends on BR2_LARGEFILE && BR2_INSTALL_LIBSTDCPP
+       depends on BR2_LARGEFILE
+       depends on BR2_INSTALL_LIBSTDCPP
+       depends on BR2_USE_WCHAR # util-linux
        help
          GPT fdisk (consisting of the gdisk and sgdisk programs) is a
          text-mode partitioning tool that works on Globally Unique Identifier
 config BR2_PACKAGE_GDISK_GDISK
        bool "interactive gdisk"
        depends on BR2_PACKAGE_GDISK
-       select BR2_PACKAGE_E2FSPROGS
-       select BR2_PACKAGE_E2FSPROGS_LIBUUID
+       select BR2_PACKAGE_BUSYBOX_SHOW_OTHERS # util-linux
+       select BR2_PACKAGE_UTIL_LINUX
+       select BR2_PACKAGE_UTIL_LINUX_LIBUUID
        help
          Install the interactive GUID partition table (GPT) manipulator
          /usr/sbin/gdisk which is modelled after and quite similar in use
 config BR2_PACKAGE_GDISK_SGDISK
        bool "command line sgdisk"
        depends on BR2_PACKAGE_GDISK
-       select BR2_PACKAGE_E2FSPROGS
-       select BR2_PACKAGE_E2FSPROGS_LIBUUID
+       select BR2_PACKAGE_BUSYBOX_SHOW_OTHERS # util-linux
+       select BR2_PACKAGE_UTIL_LINUX
+       select BR2_PACKAGE_UTIL_LINUX_LIBUUID
        select BR2_PACKAGE_POPT
        help
          Install the command-line GUID partition table (GPT) manipulator
          /usr/sbin/sgdisk which is named after the traditional MBR based
          sfdisk tool albeit with an entirely different option syntax.
 
-comment "gdisk requires a toolchain with LARGEFILE and C++ support enabled"
-       depends on !BR2_LARGEFILE || !BR2_INSTALL_LIBSTDCPP
+comment "gdisk requires a toolchain with LARGEFILE/WCHAR/C++ support enabled"
+       depends on !(BR2_LARGEFILE && BR2_INSTALL_LIBSTDCPP && BR2_USE_WCHAR)
 
 
 ifneq ($(GDISK_TARGETS_y),)
 
-GDISK_DEPENDENCIES += e2fsprogs
+GDISK_DEPENDENCIES += util-linux
 ifeq ($(BR2_PACKAGE_GDISK_SGDISK),y)
     GDISK_DEPENDENCIES += popt
 endif
 
 comment "Note that xfsprogs needs a toolchain with UCLIBC_SV4_DEPRECATED and UCLIBC_HAS_OBSOLETE_BSD_SIGNAL enabled"
        depends on BR2_PACKAGE_XFSPROGS
 
-comment "xfsprogs requires a toolchain with LARGEFILE support"
-        depends on !BR2_LARGEFILE
+comment "xfsprogs requires a toolchain with LARGEFILE + WCHAR support"
+        depends on !(BR2_LARGEFILE && BR2_USE_WCHAR)
 
 config BR2_PACKAGE_XFSPROGS
        bool "xfsprogs"
        depends on BR2_LARGEFILE
-       select BR2_PACKAGE_E2FSPROGS
-       select BR2_PACKAGE_E2FSPROGS_LIBUUID
+       depends on BR2_USE_WCHAR # util-linux
+       select BR2_PACKAGE_BUSYBOX_SHOW_OTHERS # util-linux
+       select BR2_PACKAGE_UTIL_LINUX
+       select BR2_PACKAGE_UTIL_LINUX_LIBUUID
        help
          The XFS file system utilities and libraries
 
 
        rm -rf $(TARGET_DIR)/usr/man $(TARGET_DIR)/usr/share/doc
        touch -c $(TARGET_DIR)/$(XFSPROGS_TARGET_BINARY)
 
-xfsprogs: e2fsprogs $(TARGET_DIR)/$(XFSPROGS_TARGET_BINARY)
+xfsprogs: util-linux $(TARGET_DIR)/$(XFSPROGS_TARGET_BINARY)
 
 xfsprogs-clean:
        rm -f $(TARGET_DIR)/bin/xfs_* $(TARGET_DIR)/sbin/xfs_* $(TARGET_DIR)/sbin/*.xfs