# NOTE
# - to look and update to new version, use update-source.sh script
-%define svnrev 138391
+%define flashv 11.3.31.232
+%define svnrev 154005
+#define rel %{nil}
%define state stable
-%define rel 1
Summary: Google Chrome
Name: google-chrome
-Version: 19.0.1084.52
-Release: %{svnrev}.%{rel}
+Version: 21.0.1180.89
+Release: %{svnrev}%{?rel:.%{rel}}
License: Multiple, see http://chrome.google.com/
Group: Applications/Networking
Source0: http://dl.google.com/linux/chrome/rpm/stable/i386/%{name}-%{state}-%{version}-%{svnrev}.i386.rpm
-# Source0-md5: 113c4fe26c9ffda69b695d3e4c7a638f
+# NoSource0-md5: 8b65abb5ec81e03d8365a22eaf68a953
+NoSource: 0
Source1: http://dl.google.com/linux/chrome/rpm/stable/x86_64/%{name}-%{state}-%{version}-%{svnrev}.x86_64.rpm
-# Source1-md5: c6e08d3019a42499f999e8f18a2e8ea4
+# NoSource1-md5: 1c729bc2e378d229966c90159a73fdc9
+NoSource: 1
Source2: %{name}.sh
Source4: find-lang.sh
Patch0: chrome-desktop.patch
Requires: browser-plugins >= 2.0
Requires: hicolor-icon-theme
Requires: xdg-utils >= 1.0.2-4
+Suggests: browser-plugin-adobe-flash
+Suggests: browser-plugin-chrome-pdf
Provides: wwwbrowser
ExclusiveArch: %{ix86} %{x8664}
BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
+%{expand:%%define crver %{version}}
+
%define find_lang sh find-lang.sh %{buildroot}
%define _enable_debug_packages 0
%define no_install_post_strip 1
%define ffmpeg_caps libffmpegsumo.so
-%define jpeg_caps libpng12.so.0(PNG12_0)
-%define flash_caps libflashplayer.so
+%define flash_caps libpepflashplayer.so
%define chrome_caps libpdf.so libppGoogleNaClPluginChrome.so
# list of script capabilities (regexps) not to be used in Provides
-%define _noautoprov %{ffmpeg_caps} %{jpeg_caps} %{flash_caps} %{chrome_caps}
+%define _noautoprov %{ffmpeg_caps} %{flash_caps} %{chrome_caps}
# do not require them either
%define _noautoreq %{_noautoprov}
a kifinomult technológiával, hogy a webböngészés gyorsabb,
biztonságosabb és könnyebb legyen.
+%package l10n
+Summary: google chrome language packages
+Group: I18n
+Requires: %{name} = %{version}-%{release}
+
+%description l10n
+This package contains language packages for 50 languages:
+
+ar, bg, bn, ca, cs, da, de, el, en-GB, es-LA, es, et, fi, fil, fr, gu,
+he, hi, hr, hu, id, it, ja, kn, ko, lt, lv, ml, mr, nb, nl, or, pl,
+pt-BR, pt-PT, ro, ru, sk, sl, sr, sv, ta, te, th, tr, uk, vi, zh-CN,
+zh-TW
+
+%package -n browser-plugin-chrome-pdf
+Summary: Chrome PDF Viewer
+Summary(pl.UTF-8): Wtyczka PDF z Google Chrome
+Group: X11/Applications/Graphics
+Requires: browser-plugins >= 2.0
+Conflicts: google-chrome < 19.0.1084.52
+
+%description -n browser-plugin-chrome-pdf
+Google Chrome PDF Viewer.
+
+%description -n browser-plugin-chrome-pdf -l pl.UTF-8
+Wtyczka PDF z Google Chrome.
+
+# IMPORTANT: keep flash plugin defined as last package
+%package -n browser-plugin-adobe-flash
+Summary: Adobe Flash plugin from Google Chrome
+Summary(pl.UTF-8): Wtyczka Adobe Flash z Google Chrome
+Version: %{flashv}
+Release: %{!?rel:1}%{?rel:%{rel}}
+License: Free to use, non-distributable
+Group: X11/Applications/Multimedia
+Requires: browser-plugins >= 2.0
+Conflicts: google-chrome < 19.0.1084.52
+
+%description -n browser-plugin-adobe-flash
+Adobe Flash plugin from Google Chrome, which is not available in
+Chromium.
+
+%description -n browser-plugin-adobe-flash -l pl.UTF-8
+Wtyczka Adobe Flash z Google Chrome, która nie jest dostępna w
+Chromium.
+
%prep
%setup -qcT
%ifarch %{ix86}
V=$(rpm -qp --nodigest --nosignature --qf '%{V}' $SOURCE)
R=$(rpm -qp --nodigest --nosignature --qf '%{R}' $SOURCE)
-if [ version:$V != version:%{version} -o svnrev:$R != svnrev:%{svnrev} ]; then
+if [ version:$V != version:%{crver} -o svnrev:$R != svnrev:%{svnrev} ]; then
exit 1
fi
rpm2cpio $SOURCE | cpio -i -d
mv chrome/google-chrome .
chmod a+x chrome/lib*.so*
+# separate to subpackage
+install -d browser-plugins
+mv chrome/libpdf.so browser-plugins
+mv chrome/PepperFlash browser-plugins
+chmod a+rx browser-plugins/PepperFlash/*.so
+
# included in gnome-control-center-2.28.1-3
rm default-app-block default-apps/google-chrome.xml
%{__sed} -i 's;/opt/google/chrome/product_logo_48.png;%{name}.png;' google-chrome.desktop
%{__sed} -i 's;/opt/google/chrome;%{_bindir};' google-chrome.desktop
+%build
+v=$(awk -F'"' '/version/{print $4}' browser-plugins/PepperFlash/manifest.json)
+if [ "$v" != "%{flashv}" ]; then
+ : wrong version
+ exit 1
+fi
+
+# create extra file, for simplier scripting in chromium-browser.sh
+echo "version=%{flashv}" > browser-plugins/PepperFlash/manifest.ver
+
%install
rm -rf $RPM_BUILD_ROOT
install -d $RPM_BUILD_ROOT{%{_bindir},%{_libdir}/%{name}/plugins,%{_mandir}/man1,%{_desktopdir},%{_libdir}/%{name}/themes}
cp -p $icon $RPM_BUILD_ROOT%{_iconsdir}/hicolor/${size}x${size}/apps/%{name}.png
done
+install -d $RPM_BUILD_ROOT%{_browserpluginsdir}
+cp -a browser-plugins/* $RPM_BUILD_ROOT%{_browserpluginsdir}
+
%browser_plugins_add_browser %{name} -p %{_libdir}/%{name}/plugins
# binary needs to be at that specific location, or it will abort:
# find locales
%find_lang %{name}.lang
+# always package en-US (in main package)
+%{__sed} -i -e '/en-US.pak/d' %{name}.lang
%clean
rm -rf $RPM_BUILD_ROOT
%update_browser_plugins
fi
+%post -n browser-plugin-adobe-flash
+%update_browser_plugins
+
+%postun -n browser-plugin-adobe-flash
+if [ "$1" = 0 ]; then
+ %update_browser_plugins
+fi
+
+%post -n browser-plugin-chrome-pdf
+%update_browser_plugins
+
+%postun -n browser-plugin-chrome-pdf
+if [ "$1" = 0 ]; then
+ %update_browser_plugins
+fi
+
+# FIXME: chrome *needs* it to be in application dir. add symlink until it can load from other places
+# FIXME: link PepperFlash, browser-plugins ignores subdirs, and currently nothing else than chrome browsers can do pepper
+%triggerin -n browser-plugin-adobe-flash -- google-chrome
+test -L %{_libdir}/google-chrome/PepperFlash || ln -sf %{_browserpluginsdir}/PepperFlash %{_libdir}/google-chrome/PepperFlash
+
+%triggerun -n browser-plugin-adobe-flash -- google-chrome
+if [ "$1" = "0" ] || [ "$2" = "0" ] && [ -L %{_libdir}/google-chrome/PepperFlash ]; then
+ rm -f %{_libdir}/google-chrome/PepperFlash
+fi
+
+%triggerin -n browser-plugin-chrome-pdf -- google-chrome
+test -L %{_libdir}/google-chrome/libpdf.so || ln -sf plugins/libpdf.so %{_libdir}/google-chrome/libpdf.so
+
+%triggerun -n browser-plugin-chrome-pdf -- google-chrome
+if [ "$1" = "0" ] || [ "$2" = "0" ] && [ -L %{_libdir}/google-chrome/libpdf.so ]; then
+ rm -f %{_libdir}/google-chrome/libpdf.so
+fi
+
+%triggerin -n browser-plugin-adobe-flash -- chromium-browser-bin
+test -L %{_libdir}/chromium-browser-bin/PepperFlash || ln -sf %{_browserpluginsdir}/PepperFlash %{_libdir}/chromium-browser-bin/PepperFlash
+
+%triggerun -n browser-plugin-adobe-flash -- chromium-browser-bin
+if [ "$1" = "0" ] || [ "$2" = "0" ] && [ -L %{_libdir}/chromium-browser-bin/PepperFlash ]; then
+ rm -f %{_libdir}/chromium-browser-bin/PepperFlash
+fi
+
+%triggerin -n browser-plugin-chrome-pdf -- chromium-browser-bin
+test -L %{_libdir}/chromium-browser-bin/libpdf.so || ln -sf plugins/libpdf.so %{_libdir}/chromium-browser-bin/libpdf.so
+
+%triggerun -n browser-plugin-chrome-pdf -- chromium-browser-bin
+if [ "$1" = "0" ] || [ "$2" = "0" ] && [-L %{_libdir}/chromium-browser-bin/libpdf.so ]; then
+ rm -f %{_libdir}/chromium-browser-bin/libpdf.so
+fi
+
%files -f %{name}.lang
%defattr(644,root,root,755)
%dir %{_libdir}/%{name}
%{_libdir}/%{name}/chrome.pak
%{_libdir}/%{name}/resources.pak
+%{_libdir}/%{name}/theme_resources_standard.pak
+%{_libdir}/%{name}/ui_resources_standard.pak
%dir %{_libdir}/%{name}/locales
+%{_libdir}/%{name}/locales/en-US.pak
%dir %{_libdir}/%{name}/plugins
%{_libdir}/%{name}/default_apps
%{_libdir}/%{name}/themes
# Native Client plugin, to use launch with --enable-nacl
%attr(755,root,root) %{_libdir}/%{name}/libppGoogleNaClPluginChrome.so
-%attr(755,root,root) %{_libdir}/%{name}/libpdf.so
-
-%ifarch %{ix86}
-# flash player
-%{_libdir}/%{name}/plugin.vch
-%attr(755,root,root) %{_libdir}/%{name}/libgcflashplayer.so
-%endif
-
# nacl
%attr(755,root,root) %{_libdir}/%{name}/nacl_helper
%attr(755,root,root) %{_libdir}/%{name}/nacl_helper_bootstrap
# hack
%dir /opt/google
/opt/google/chrome
+
+%files l10n -f %{name}.lang
+%defattr(644,root,root,755)
+
+%files -n browser-plugin-chrome-pdf
+%defattr(644,root,root,755)
+%attr(755,root,root) %{_browserpluginsdir}/libpdf.so
+
+%files -n browser-plugin-adobe-flash
+%defattr(644,root,root,755)
+%dir %{_browserpluginsdir}/PepperFlash
+%{_browserpluginsdir}/PepperFlash/manifest.json
+%{_browserpluginsdir}/PepperFlash/manifest.ver
+%attr(755,root,root) %{_browserpluginsdir}/PepperFlash/libpepflashplayer.so