diff options
author | Bernard Cafarelli <voyageur@gentoo.org> | 2009-10-01 11:51:45 +0000 |
---|---|---|
committer | Bernard Cafarelli <voyageur@gentoo.org> | 2009-10-01 11:51:45 +0000 |
commit | 7544920cc9d1cac64491cbabd33be9f40eb2bdaf (patch) | |
tree | 103811683e43643d37a749f2c34be410887749cd /www-client | |
parent | Add www-client/chromium-9999 mask (diff) | |
download | historical-7544920cc9d1cac64491cbabd33be9f40eb2bdaf.tar.gz historical-7544920cc9d1cac64491cbabd33be9f40eb2bdaf.tar.bz2 historical-7544920cc9d1cac64491cbabd33be9f40eb2bdaf.zip |
Add live ebuild for those who wonder what to do of their free diskspace
Package-Manager: portage-2.2_rc42/cvs/Linux x86_64
Diffstat (limited to 'www-client')
-rw-r--r-- | www-client/chromium/ChangeLog | 8 | ||||
-rw-r--r-- | www-client/chromium/Manifest | 3 | ||||
-rw-r--r-- | www-client/chromium/chromium-9999.ebuild | 178 |
3 files changed, 187 insertions, 2 deletions
diff --git a/www-client/chromium/ChangeLog b/www-client/chromium/ChangeLog index 664b29c1e694..dffe97548b82 100644 --- a/www-client/chromium/ChangeLog +++ b/www-client/chromium/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for www-client/chromium # Copyright 1999-2009 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/www-client/chromium/ChangeLog,v 1.10 2009/09/30 12:36:10 voyageur Exp $ +# $Header: /var/cvsroot/gentoo-x86/www-client/chromium/ChangeLog,v 1.11 2009/10/01 11:51:45 voyageur Exp $ + +*chromium-9999 (01 Oct 2009) + + 01 Oct 2009; Bernard Cafarelli <voyageur@gentoo.org> + +chromium-9999.ebuild: + Add live ebuild for those who wonder what to do of their free diskspace 30 Sep 2009; Bernard Cafarelli <voyageur@gentoo.org> chromium-4.0.212.0_p26805.ebuild, chromium-4.0.219.4_p27359.ebuild: diff --git a/www-client/chromium/Manifest b/www-client/chromium/Manifest index b2c2ce751767..f1caf9623e0f 100644 --- a/www-client/chromium/Manifest +++ b/www-client/chromium/Manifest @@ -5,5 +5,6 @@ DIST chromium-4.0.212.0_p26805.tar.bz2 124934581 RMD160 b09ca8b91fa19ccd8b48f41b DIST chromium-4.0.219.4_p27359.tar.bz2 124727820 RMD160 c504b1c76703f006afc70432934d42ffc2c02fa6 SHA1 070859cf677c6d249455206d19eaf85cad7924cd SHA256 380d792ed4db3a43e151834e583f144263166e4ad09a2cfa00ad22a6a552e4c0 EBUILD chromium-4.0.212.0_p26805.ebuild 4330 RMD160 f2608a81077a32f368f3c1a9a9b02188e86f2e28 SHA1 97609e139375cfd7104c9ad7ac5fd9482d580578 SHA256 5c9a3110b68e54f67e5b354c47865a64d7b88a46f39bd3e6fdf1b75270c68b0e EBUILD chromium-4.0.219.4_p27359.ebuild 4330 RMD160 6121148ae5a7f7ed875b0b3d511fc684390d90e5 SHA1 b674f50c891069dfc9035933c1b183768234e8d2 SHA256 656b8fbb1f7a067788019cbb68e90ed18f1f9dd1ef7ac59a6f6db4abb6551155 -MISC ChangeLog 2359 RMD160 4c98d6abe1fdc692d9f0f51b8dbdb0938a2cdde4 SHA1 88dfdb83b478c3bf4ded08a064c52f27d7781d5b SHA256 2f42953c9a9e8abd13c754c65af502db6113c6edb93573ed9552e0bdf1fffc8e +EBUILD chromium-9999.ebuild 5925 RMD160 e37badf1f77f04d074f43eb601de2353a42b891e SHA1 d2de7868377737c6eb6fea8f2cd26a05922ca0f8 SHA256 b852b64407b1881524239384f7cfb26dcad505d7e307a87ed3e0738484837b7e +MISC ChangeLog 2544 RMD160 af91037f458e74cf474823cd6c912d4bbd328261 SHA1 885510232977a208893a68b7285519de0e7ec8a4 SHA256 c5b6f7a108f1b11fb7f840e0c40c30dd0781dfb43f7eb118ea8dd977a6cd3bba MISC metadata.xml 365 RMD160 82a744318b3662d5cca5d912b98551f9fb193235 SHA1 2bbbeed534cb3b497e11df6be9f1e27a3c6abc44 SHA256 7547574cd9d8ae8c392a7e88180cb035c879d035250808d2939256617ce3d601 diff --git a/www-client/chromium/chromium-9999.ebuild b/www-client/chromium/chromium-9999.ebuild new file mode 100644 index 000000000000..be686bec8c24 --- /dev/null +++ b/www-client/chromium/chromium-9999.ebuild @@ -0,0 +1,178 @@ +# Copyright 1999-2009 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/www-client/chromium/chromium-9999.ebuild,v 1.1 2009/10/01 11:51:45 voyageur Exp $ + +EAPI="2" +inherit eutils multilib toolchain-funcs subversion + +DESCRIPTION="Open-source version of Google Chrome web browser" +HOMEPAGE="http://chromium.org/" +# subversion eclass fetches gclient, which will then fetch chromium itself +ESVN_REPO_URI="http://src.chromium.org/svn/trunk/tools/depot_tools" +EGCLIENT_REPO_URI="http://src.chromium.org/svn/trunk/src/" + +LICENSE="BSD" +SLOT="0" +KEYWORDS="~amd64 ~x86" +IUSE="" + +RDEPEND="app-arch/bzip2 + dev-libs/libxml2 + dev-libs/libxslt + >=dev-libs/nss-3.12.2 + >=gnome-base/gconf-2.24.0 + media-fonts/corefonts + >=media-libs/alsa-lib-1.0.19 + media-libs/jpeg + media-libs/libpng + >=media-video/ffmpeg-0.5_p19787 + sys-libs/zlib + >=x11-libs/gtk+-2.14.7" +# >=dev-libs/libevent-1.4.13 +# dev-db/sqlite:3 +DEPEND="${RDEPEND} + >=dev-util/gperf-3.0.3 + >=dev-util/pkgconfig-0.23" + +export CHROMIUM_HOME=/usr/$(get_libdir)/chromium-browser + +src_unpack() { + subversion_src_unpack + mv "${S}" "${WORKDIR}"/depot_tools + + # Most subversion checks and configurations were already run + EGCLIENT="${WORKDIR}"/depot_tools/gclient + cd "${ESVN_STORE_DIR}" || die "gclient: can't chdir to ${ESVN_STORE_DIR}" + + if [[ ! -d ${PN} ]]; then + mkdir -p "${PN}" || die "gclient: can't mkdir ${PN}." + fi + + cd "${PN}" || die "gclient: can't chdir to ${PN}" + + if [[ ! -f .gclient ]]; then + einfo "gclient config -->" + ${EGCLIENT} config ${EGCLIENT_REPO_URI} || die "gclient: error creating config" + fi + + einfo "gclient sync start -->" + einfo " repository: ${EGCLIENT_REPO_URI}" + ${EGCLIENT} sync || die "gclient: can't fetch to ${PN} from ${EGCLIENT_REPO_URI}." + einfo " working copy: ${ESVN_STORE_DIR}/${PN}" + + mkdir -p "${S}" + # From export_tarball.py + CHROMIUM_EXCLUDES="--exclude=src/chrome/test/data + --exclude=src/chrome/tools/test/reference_build + --exclude=src/chrome_frame --exclude=src/gears/binaries + --exclude=src/net/data/cache_tests --exclude=src/o3d/documentation + --exclude=src/o3d/samples --exclude=src/third_party/lighttpd + --exclude=src/third_party/WebKit/LayoutTests + --exclude=src/webkit/data/layout_tests + --exclude=src/webkit/tools/test/reference_build" + rsync -rlpgo --exclude=".svn/" ${CHROMIUM_EXCLUDES} src/ "${S}" || die "gclient: can't export to ${S}." + + # Display correct svn revision in about box, and log new version + CREV=$(subversion__svn_info "src" "Revision") + echo ${CREV} > "${S}"/build/LASTCHANGE.in || die "setting revision failed" + . src/chrome/VERSION + elog "Installing/updating to version ${MAJOR}.${MINOR}.${BUILD}.${PATCH}_p${CREV} " +} + +src_prepare() { + # Needed until we add back "rootdir=.", see below + for i in app webkit third_party/ffmpeg build/util base chrome v8/tools/gyp + do + ln -s "${S}"/out ${i}/out + done + + # Changing this in ~/include.gypi does not work + sed -i "s/'-Werror'/''/" build/common.gypi || die "Werror sed failed" + # Prevent automatic -march=pentium4 -msse2 enabling on x86, http://crbug.com/9007 + epatch "${FILESDIR}"/${PN}-drop_sse2.patch + # Add configuration flag to use system libevent + epatch "${FILESDIR}"/${PN}-use_system_libevent.patch +} + +src_configure() { + # CFLAGS/LDFLAGS + mkdir -p "${S}"/.gyp + cat << EOF > "${S}"/.gyp/include.gypi +{ + 'target_defaults': { + 'cflags': [ '${CFLAGS// /','}' ], + 'ldflags': [ '${LDFLAGS// /','}' ], + }, +} +EOF + export HOME="${S}" + + # Configuration options (system libraries) + local myconf="-Duse_system_bzip2=1 -Duse_system_zlib=1 -Duse_system_libjpeg=1 -Duse_system_libpng=1 -Duse_system_libxml=1 -Duse_system_libxslt=1 -Duse_system_ffmpeg=1 -Dlinux_use_tcmalloc=1" + # -Duse_system_libevent=1: http://crbug.com/22140 + # -Duse_system_sqlite=1 : http://crbug.com/22208 + # Others still bundled: icu (not possible?), hunspell (changes required for sandbox support) + + # Sandbox paths + myconf="${myconf} -Dlinux_sandbox_path=${CHROMIUM_HOME}/chrome_sandbox -Dlinux_sandbox_chrome_path=${CHROMIUM_HOME}/chrome" + + if use amd64; then + myconf="${myconf} -Dtarget_arch=x64" + fi + if [[ "$(gcc-major-version)$(gcc-minor-version)" == "44" ]]; then + myconf="${myconf} -Dno_strict_aliasing=1 -Dgcc_version=44" + fi + + build/gyp_chromium -f make build/all.gyp ${myconf} --depth=. || die "gyp failed" +} + +src_compile() { + # Broken for "Argument list too long": + # http://code.google.com/p/chromium/issues/detail?id=19854 + # http://code.google.com/p/gyp/issues/detail?id=71 + # When this is fixed, remove the src_prepare + # and add back "rootdir=${S}" + emake -r V=1 chrome chrome_sandbox BUILDTYPE=Release \ + CC=$(tc-getCC) \ + CXX=$(tc-getCXX) \ + AR=$(tc-getAR) \ + RANLIB=$(tc-getRANLIB) \ + || die "compilation failed" +} + +src_install() { + # Chromium does not have "install" target in the build system. + + dodir ${CHROMIUM_HOME} + + exeinto ${CHROMIUM_HOME} + doexe out/Release/chrome + doexe out/Release/chrome_sandbox + fperms 4755 ${CHROMIUM_HOME}/chrome_sandbox + doexe out/Release/xdg-settings + doexe "${FILESDIR}"/chromium-launcher.sh + + insinto ${CHROMIUM_HOME} + doins out/Release/chrome.pak + + doins -r out/Release/locales + doins -r out/Release/resources + doins -r out/Release/themes + + newman out/Release/chromium-browser.1 chrome.1 + + # Chromium looks for these in its folder + # See media_posix.cc and base_paths_linux.cc + dosym /usr/$(get_libdir)/libavcodec.so.52 ${CHROMIUM_HOME} + dosym /usr/$(get_libdir)/libavformat.so.52 ${CHROMIUM_HOME} + dosym /usr/$(get_libdir)/libavutil.so.50 ${CHROMIUM_HOME} + + # Plugins symlink + dosym /usr/$(get_libdir)/nsbrowser/plugins ${CHROMIUM_HOME}/plugins + + newicon out/Release/product_logo_48.png ${PN}-browser.png + dosym ${CHROMIUM_HOME}/chromium-launcher.sh /usr/bin/chromium + make_desktop_entry chromium "Chromium" ${PN}-browser "Network;WebBrowser" + sed -e "/^Exec/s/$/ %U/" -i "${D}"/usr/share/applications/*.desktop \ + || die "desktop file sed failed" +} |