summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--media-gfx/iscan/ChangeLog7
-rw-r--r--media-gfx/iscan/files/digest-iscan-2.10.036
-rw-r--r--media-gfx/iscan/iscan-2.10.0.ebuild301
3 files changed, 343 insertions, 1 deletions
diff --git a/media-gfx/iscan/ChangeLog b/media-gfx/iscan/ChangeLog
index 239d9078eeac..feb52f9a013e 100644
--- a/media-gfx/iscan/ChangeLog
+++ b/media-gfx/iscan/ChangeLog
@@ -1,6 +1,11 @@
# ChangeLog for media-gfx/iscan
# Copyright 1999-2007 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/media-gfx/iscan/ChangeLog,v 1.22 2007/09/03 20:59:34 sbriesen Exp $
+# $Header: /var/cvsroot/gentoo-x86/media-gfx/iscan/ChangeLog,v 1.23 2007/11/17 20:47:33 sbriesen Exp $
+
+*iscan-2.10.0 (17 Nov 2007)
+
+ 17 Nov 2007; Stefan Briesenick <sbriesen@gentoo.org> +iscan-2.10.0.ebuild:
+ version bump, solving bug #199433.
03 Sep 2007; Stefan Briesenick <sbriesen@gentoo.org>
iscan-2.4.0-r1.ebuild, iscan-2.6.0.ebuild, iscan-2.7.0.ebuild:
diff --git a/media-gfx/iscan/files/digest-iscan-2.10.0 b/media-gfx/iscan/files/digest-iscan-2.10.0
new file mode 100644
index 000000000000..39c675917cd2
--- /dev/null
+++ b/media-gfx/iscan/files/digest-iscan-2.10.0
@@ -0,0 +1,36 @@
+MD5 7e4b7b049797035303ffc687aca02f2f iscan-plugin-cx4400-2.0.0-0.c2.i386.rpm 94530
+RMD160 df07c891df3429d94676307ee61816fab9a7fc28 iscan-plugin-cx4400-2.0.0-0.c2.i386.rpm 94530
+SHA256 c8c073679dad0febadb8a19cebd25676f2a5897f4e4a3f34ee2333f0513e3ba8 iscan-plugin-cx4400-2.0.0-0.c2.i386.rpm 94530
+MD5 08e81ee1d522c5e33edaac26afd0ded8 iscan-plugin-gt-7200-1.0.0-1.c2.i386.rpm 62336
+RMD160 7862ae8f8e4362ba9535b9d492e742d9716da91d iscan-plugin-gt-7200-1.0.0-1.c2.i386.rpm 62336
+SHA256 11789e2074670b1098cea9366b3e33bb72ce316c0ced6e09086f3a13eeccb86f iscan-plugin-gt-7200-1.0.0-1.c2.i386.rpm 62336
+MD5 060e7ab5b38371a681facae2995b8a74 iscan-plugin-gt-7300-1.0.0-1.c2.i386.rpm 77271
+RMD160 9d3a95a1eefd5a63b991d06ed58356aeb814b7d8 iscan-plugin-gt-7300-1.0.0-1.c2.i386.rpm 77271
+SHA256 a6cfce5c1da99ee34b4186cdf7e611a685be8da95b08f8295fdeafcb4d0fc339 iscan-plugin-gt-7300-1.0.0-1.c2.i386.rpm 77271
+MD5 f76725766f44debe3f3fec06d0e2023b iscan-plugin-gt-9400-1.0.0-1.c2.i386.rpm 140610
+RMD160 aaa768cffc851d2168e358c6f4e30b8125ef8e86 iscan-plugin-gt-9400-1.0.0-1.c2.i386.rpm 140610
+SHA256 0172f3331dfefac27fffe3723b7b403b1fbc5d0cd0c3e835bdef7d925dfeab3e iscan-plugin-gt-9400-1.0.0-1.c2.i386.rpm 140610
+MD5 8b1c398ef58769d9ceb77ad771515de3 iscan-plugin-gt-f500-1.0.0-1.c2.i386.rpm 126130
+RMD160 a5ea991156fb8fbe460c5a8198467837eedfa6bc iscan-plugin-gt-f500-1.0.0-1.c2.i386.rpm 126130
+SHA256 fe87d16ce22c28e2c320286758bea32ea4cad75c83debd6fe95670b704701464 iscan-plugin-gt-f500-1.0.0-1.c2.i386.rpm 126130
+MD5 b72a512a927b9f2020af817c5a541ae8 iscan-plugin-gt-f520-1.0.0-1.c2.i386.rpm 125919
+RMD160 8743c98fb45b055adc1db38cfd312de9517cccee iscan-plugin-gt-f520-1.0.0-1.c2.i386.rpm 125919
+SHA256 2f0dd2257e19c808062ddbaa4a1f4cf6899944cacce67f46136008fbe60ae61a iscan-plugin-gt-f520-1.0.0-1.c2.i386.rpm 125919
+MD5 5f4137fd69198617b95bd59261affd75 iscan-plugin-gt-f600-1.0.0-1.c2.i386.rpm 151280
+RMD160 2779029ea507525042122a0ca5581a3b0fd5cbc8 iscan-plugin-gt-f600-1.0.0-1.c2.i386.rpm 151280
+SHA256 4735e468c060250a2e6b9adca72ed43c9e8523db5b95d8edad7d0e91f0ac13d2 iscan-plugin-gt-f600-1.0.0-1.c2.i386.rpm 151280
+MD5 bb623b47fd457e94f8d6b878b5d9ad99 iscan-plugin-gt-f670-2.0.0-1.c2.i386.rpm 173098
+RMD160 f3dec4db07db8213d3d6248cff7eaadf8dbe06b4 iscan-plugin-gt-f670-2.0.0-1.c2.i386.rpm 173098
+SHA256 2b5db6830b5918f5c71f8e9a5d967fbc5abdbc74735705a01d0356d9994830da iscan-plugin-gt-f670-2.0.0-1.c2.i386.rpm 173098
+MD5 cf191e84b03b28a8b0f629d60ba0b36e iscan-plugin-gt-f700-2.0.0-0.c2.i386.rpm 150711
+RMD160 52a0aee4787c5dd8b64a87a40c988f4c5242cde5 iscan-plugin-gt-f700-2.0.0-0.c2.i386.rpm 150711
+SHA256 c3f31a4b9c07c0a9a83033de0d9b873d282f267dc7de2855083c1a8413c4c591 iscan-plugin-gt-f700-2.0.0-0.c2.i386.rpm 150711
+MD5 bda9d1dfe5c9524084b01e46a7a9f5e3 iscan-plugin-gt-s600-2.0.0-1.c2.i386.rpm 140478
+RMD160 4a86fa7626c895e90e7a77ef1d07c93165a5afe3 iscan-plugin-gt-s600-2.0.0-1.c2.i386.rpm 140478
+SHA256 75d66ae95407b879ad4ea14d67e5ecf11e0e12159fd5a8521b4589299dffdb0f iscan-plugin-gt-s600-2.0.0-1.c2.i386.rpm 140478
+MD5 02c151a49608ae911b1e200672ed236f iscan-plugin-gt-x750-1.0.0-1.c2.i386.rpm 163386
+RMD160 aeb024f903c79d64cb79ab8c15d3f6fb0c7ece8d iscan-plugin-gt-x750-1.0.0-1.c2.i386.rpm 163386
+SHA256 7ebd3a9cf7f35b5abc5cd8c6b5c27dd98b2b6c39ad621c9ab753f3046b9578a4 iscan-plugin-gt-x750-1.0.0-1.c2.i386.rpm 163386
+MD5 8e44dac50f51b4c0a2f2e60624edfedb iscan_2.10.0-1.tar.gz 1437822
+RMD160 0ce7c7d88b93f7881558d7d9ca556f87e0684a23 iscan_2.10.0-1.tar.gz 1437822
+SHA256 8930ef9c41951bb2b229160e832fce9bef520bcb578af5c3c7cc7f58d378ec43 iscan_2.10.0-1.tar.gz 1437822
diff --git a/media-gfx/iscan/iscan-2.10.0.ebuild b/media-gfx/iscan/iscan-2.10.0.ebuild
new file mode 100644
index 000000000000..2bf83c8ad5d0
--- /dev/null
+++ b/media-gfx/iscan/iscan-2.10.0.ebuild
@@ -0,0 +1,301 @@
+# Copyright 1999-2007 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/media-gfx/iscan/iscan-2.10.0.ebuild,v 1.1 2007/11/17 20:47:33 sbriesen Exp $
+
+WANT_AUTOCONF="latest"
+WANT_AUTOMAKE="latest"
+
+inherit eutils toolchain-funcs flag-o-matic autotools rpm
+
+SRC_REV="1" # revision used by upstream
+
+# HINTS:
+# -> non-free modules are x86 only
+# -> isane frontend needs non-free modules
+# -> sane-epkowa should be usable on every arch
+# -> ${P}-${SRC_REV}.tar.gz (for gcc 3.2/3.3)
+# -> ${P}-${SRC_REV}.c2.tar.gz (for gcc 3.4 or later)
+
+# PLUGINS:
+# -> iscan-plugin-gt-7200 == Perfection 1250 PHOTO
+# -> iscan-plugin-gt-7300 == Perfection 1260 PHOTO
+# -> iscan-plugin-gt-9400 == Perfection 3170 PHOTO (esfw32.bin)
+# -> iscan-plugin-gt-f500 == Perfection 2480/2580 PHOTO (esfw41.bin)
+# -> iscan-plugin-gt-f520 == Perfection 3490/3590 PHOTO (esfw52.bin)
+# -> iscan-plugin-gt-f600 == Perfection 4180 PHOTO (esfw43.bin)
+# -> iscan-plugin-gt-x750 == Perfection 4490 PHOTO (esfw54.bin)
+# -> iscan-plugin-gt-s600 == Perfection V10/V100 PHOTO (esfw66.bin)
+# -> iscan-plugin-gt-f700 == Perfection V350 PHOTO (esfw68.bin)
+# -> iscan-plugin-gt-f670 == Perfection V200 PHOTO (esfw7A.bin)
+# -> iscan-plugin-cx4400 == Stylus CX4300/CX4400/CX4450/CX5500/CX5600/DX4400/DX4450
+
+# FIXME:
+# Make jpeg/png optional. The problem is, that the
+# configure script ignores --disable-*, if the
+# corresponding lib is found on the system.
+# Furthermore, isane doesn't compile w/o libusb,
+# this should be fixed somehow.
+
+# available x86 plugins (will be assembled below)
+PLUGINS="
+ v1180/gt-7200-1.0.0-1
+ v1180/gt-7300-1.0.0-1
+ v1180/gt-9400-1.0.0-1
+ v1180/gt-f500-1.0.0-1
+ v1180/gt-f520-1.0.0-1
+ v1180/gt-f600-1.0.0-1
+ v1180/gt-x750-1.0.0-1
+ 2.3.0/gt-f700-2.0.0-0
+ 2.3.0/gt-s600-2.0.0-1
+ 2.8.0/gt-f670-2.0.0-1
+ 2.10.0/cx4400-2.0.0-0"
+
+# Firmware files within plugin RPMs
+FIRMWARE=( "esfw41.bin Perfection 2480/2580 PHOTO"
+ "esfw32.bin Perfection 3170 PHOTO"
+ "esfw52.bin Perfection 3490/3590 PHOTO"
+ "esfw43.bin Perfection 4180 PHOTO"
+ "esfw54.bin Perfection 4490 PHOTO"
+ "esfw66.bin Perfection V10/V100 PHOTO"
+ "esfw68.bin Perfection V350 PHOTO"
+ "esfw7A.bin Perfection V200 PHOTO" )
+
+SRC_GCC34="http://lx1.avasys.jp/iscan/${PV}/${PN}_${PV}-${SRC_REV}.tar.gz"
+BIN_GCC34=""
+
+for X in ${PLUGINS}; do
+ BIN_GCC34="${BIN_GCC34} http://lx1.avasys.jp/iscan/${X%%/*}/iscan-plugin-${X##*/}.c2.i386.rpm"
+done
+
+# feel free to add your arch, every non-x86
+# arch doesn't install any x86-only stuff.
+KEYWORDS="~amd64 ~x86"
+
+DESCRIPTION="EPSON Image Scan! for Linux (including sane-epkowa backend and firmware)"
+HOMEPAGE="http://www.avasys.jp/english/linux_e/dl_scan.html"
+SRC_URI="${SRC_GCC34} ${BIN_GCC34}"
+LICENSE="GPL-2 EAPL EPSON"
+SLOT="0"
+
+IUSE="X gimp unicode"
+IUSE_LINGUAS="de es fr it ja ko nl pt zh_CN zh_TW"
+
+for X in ${IUSE_LINGUAS}; do IUSE="${IUSE} linguas_${X}"; done
+
+QA_TEXTRELS="
+ usr/lib/iscan/libesint41.so.2.0.0
+ usr/lib/iscan/libesint52.so.2.0.0"
+
+DEPEND="media-gfx/sane-backends
+ media-libs/libpng
+ media-libs/jpeg
+ >=sys-fs/udev-103
+ >=dev-libs/libusb-0.1.12
+ x86? (
+ X? (
+ sys-devel/gettext
+ >=x11-libs/gtk+-2.0
+ gimp? ( media-gfx/gimp )
+ )
+ )"
+
+snapscan_firmware() {
+ local i
+ echo "#-------------- EPSON Image Scan! for Linux Scanner-Firmware --------------"
+ for i in "${FIRMWARE[@]}"; do
+ echo
+ echo "# ${i#* } (${i%% *})"
+ echo "#firmware /usr/share/iscan/${i%% *}"
+ done
+ echo
+ cat 2>/dev/null "${1}"
+}
+
+usermap_to_udev() {
+ local ACTION='MODE="0660", GROUP="scanner"'
+ local DEVICE='\1ATTRS{idVendor}=="\L\2\E", ATTRS{idProduct}=="\L\3\E"'
+ echo '# udev rules file for iscan devices (udev >= 0.98)'
+ echo '#'
+ echo 'ACTION!="add", GOTO="iscan_rules_end"'
+ echo 'SUBSYSTEM!="usb*", GOTO="iscan_rules_end"'
+ echo 'KERNEL=="lp[0-9]*", GOTO="iscan_rules_end"'
+ echo
+ sed -n -e "s|^\(# SEIKO EPSON.*\)|\1|p" \
+ -e "s|^\(#*\)i*scan-device *0x0003 *0x\([^ ]\+\) *0x\([^ ]\+\)*.*|${DEVICE}, ${ACTION}|p" "${1}"
+ echo
+ echo 'LABEL="iscan_rules_end"'
+}
+
+pkg_setup() {
+ local i
+ if ! use x86 && ( use X || use gimp ); then
+ ewarn
+ ewarn "The iscan application needs CSS x86-only libs and"
+ ewarn "thus can't be built currently. You can still use"
+ ewarn "'xscanimage', 'xsane' or 'kooka' with sane-epkowa"
+ ewarn "backend. But some low-end scanners are also not"
+ ewarn "supported, because they need these x86 libs, too."
+ ewarn
+ fi
+
+ # Select correct tarball for installed GCC. This is not a perfect
+ # solution and should be expanded to other working GCC versions.
+ einfo "GCC version: $(gcc-fullversion)"
+ case "$(gcc-version)" in
+ 3.4|4.[01234]) # 4.x seems to work (tested with Perfection 3490 PHOTO)
+ MY_A="${SRC_GCC34##*/}"
+ for i in ${BIN_GCC34}; do MY_A="${MY_A} ${i##*/}"; done
+ ;;
+ *)
+ if use x86; then
+ die "Your GCC version is not supported. You need either 3.4 or 4.x!"
+ else
+ MY_A="${SRC_GCC34##*/}" # fallback to GCC 3.4, should not harm.
+ for i in ${BIN_GCC34}; do MY_A="${MY_A} ${i##*/}"; done
+ fi
+ ;;
+ esac
+}
+
+src_unpack() {
+ local i
+
+ cd "${WORKDIR}"
+ for i in ${MY_A}; do
+ case "${i}" in
+ *.rpm)
+ echo ">>> Unpacking ${i}"
+ rpm_unpack "${DISTDIR}/${i}" || die "failure unpacking ${i}"
+ ;;
+ *)
+ unpack "${i}"
+ ;;
+ esac
+ done
+
+ cd "${S}"
+
+ # convert japanese docs to UTF-8
+ if use unicode && use linguas_ja; then
+ for i in {NEWS,README}.ja non-free/*.ja.txt; do
+ if [ -f "${i}" ]; then
+ echo ">>> Converting ${i} to UTF-8"
+ iconv -f eucjp -t utf8 -o "${i}~" "${i}" && mv -f "${i}~" "${i}" || rm -f "${i}~"
+ fi
+ done
+ fi
+
+ # disable iscan frontend + none-free modules
+ if ! ( use x86 && use X ); then
+ sed -i -e "s:PKG_CHECK_MODULES(GTK,.*):AC_DEFINE([HAVE_GTK_2], 0):g" \
+ -e "s:\(PKG_CHECK_MODULES(GDK_IMLIB,.*)\):#\1:g" configure.ac
+ sed -i -e 's:^\([[:space:]]*\)frontend[[:space:]]*\\:\1\\:g' \
+ -e 's:^\([[:space:]]*\)non-free[[:space:]]*\\:\1\\:g' \
+ -e 's:^\([[:space:]]*\)po[[:space:]]*\\:\1\\:g' Makefile*
+ sed -i -e 's:iscan.1::g' doc/Makefile*
+ fi
+
+ # autotool stuff
+ eautoconf
+}
+
+src_compile() {
+ append-flags -D_GNU_SOURCE # needed for 'strndup'
+ # hint: dirty hack, look into 'configure.ac' for 'PACKAGE_CXX_ABI'
+ CXX="g++" econf --enable-jpeg --enable-png --with-pic || die "econf failed"
+ emake CXX="$(tc-getCXX)" || die "emake failed"
+}
+
+src_install() {
+ local MY_LIB="/usr/$(get_libdir)"
+ make DESTDIR="${D}" install || die "make install failed"
+
+ # --disable-static doesn't work, so we just remove obsolete static lib
+ sed -i -e "s:^\(old_library=\):# \1:g" "${D}${MY_LIB}/sane/libsane-epkowa.la"
+ rm -f "${D}${MY_LIB}/sane/libsane-epkowa.a"
+
+ # install scanner plugins (x86-only)
+ if use x86; then
+ dodir ${MY_LIB}/iscan
+ cp -df "${WORKDIR}"/usr/lib/iscan/* "${D}${MY_LIB}"/iscan/.
+ fi
+
+ # install scanner firmware (could be used by sane-backends)
+ insinto /usr/share/iscan
+ doins "${WORKDIR}"/usr/share/iscan/*
+
+ # install docs
+ dodoc AUTHORS NEWS README doc/epkowa.desc
+ use linguas_ja && dodoc NEWS.ja README.ja
+
+ # remove 'make-udev-rules', we use our own stuff below
+ rm -f "${D}usr/lib/iscan/make-udev-rules"
+
+ # install USB hotplug stuff
+ dodir /etc/udev/rules.d
+ usermap_to_udev utils/hotplug/iscan.usermap \
+ > "${D}etc/udev/rules.d/99-iscan.rules"
+
+ # install sane config
+ insinto /etc/sane.d
+ doins backend/epkowa.conf
+
+ # link iscan so it is seen as a plugin in gimp
+ if use x86 && use X && use gimp; then
+ local plugindir
+ if [ -x /usr/bin/gimptool ]; then
+ plugindir="$(gimptool --gimpplugindir)/plug-ins"
+ elif [ -x /usr/bin/gimptool-2.0 ]; then
+ plugindir="$(gimptool-2.0 --gimpplugindir)/plug-ins"
+ else
+ die "Can't find GIMP plugin directory."
+ fi
+ dodir "${plugindir}"
+ dosym /usr/bin/iscan "${plugindir}"
+ fi
+
+ # install desktop entry
+ if use x86 && use X; then
+ make_desktop_entry iscan "Image Scan! for Linux ${PV}" scanner.png
+ fi
+}
+
+pkg_postinst() {
+ local i
+ local DLL_CONF="/etc/sane.d/dll.conf"
+ local EPKOWA_CONF="/etc/sane.d/epkowa.conf"
+ local SNAPSCAN_CONF="/etc/sane.d/snapscan.conf"
+ elog
+ if grep -q "^[ \t]*\<epkowa\>" ${DLL_CONF}; then
+ elog "Please edit ${EPKOWA_CONF} to suit your needs."
+ elif grep -q "\<epkowa\>" ${DLL_CONF}; then
+ elog "Hint: to enable the backend, add 'epkowa' to ${DLL_CONF}"
+ elog "Then edit ${EPKOWA_CONF} to suit your needs."
+ else
+ echo "epkowa" >> ${DLL_CONF}
+ elog "A new entry 'epkowa' was added to ${DLL_CONF}"
+ elog "Please edit ${EPKOWA_CONF} to suit your needs."
+ fi
+ elog
+ elog "You can also use the 'snapscan' backend if you have a recent"
+ elog "sane-backend installation. Firmware files for some newer"
+ elog "EPSON scanners were installed into /usr/share/iscan:"
+ elog
+ for i in "${FIRMWARE[@]}"; do
+ elog " ${i%% *}: ${i#* }"
+ done
+ elog
+ if ! grep 2>/dev/null -q "/usr/share/iscan/.*\.bin" "${SNAPSCAN_CONF}"; then
+ snapscan_firmware "${SNAPSCAN_CONF}" > "${SNAPSCAN_CONF}~~~" \
+ && mv -f "${SNAPSCAN_CONF}~~~" "${SNAPSCAN_CONF}" \
+ || rm -f "${SNAPSCAN_CONF}~~~"
+ elog "The firmware entries were added to ${SNAPSCAN_CONF}"
+ else
+ elog "Please edit ${SNAPSCAN_CONF} to suit your needs."
+ fi
+ elog "Hint: not all models are supported by 'snapscan' yet!"
+ elog
+ elog "You can check which backend fits best for your scanner:"
+ elog "http://www.sane-project.org/cgi-bin/driver.pl?manu=Epson&bus=any"
+ elog
+}