# NOTE
# - to look and update to new version, use update-source.sh script
-%define svnrev 138391
+%define flashv 11.4.31.110
+%define svnrev 161065
+#define rel %{nil}
%define state stable
Summary: Google Chrome
Name: google-chrome
-Version: 19.0.1084.52
-Release: %{svnrev}
+Version: 22.0.1229.94
+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: 8f7e6178b33b0dcdf17347543d7ee3ff
+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: c28196952e7c94b5ab808f72b6a48951
+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
-Provides: wwwbrowser
-%ifarch %{ix86}
Suggests: browser-plugin-adobe-flash
-%endif
Suggests: browser-plugin-chrome-pdf
+Provides: wwwbrowser
+# add conflicts to trigger their update when main package is updated
+Conflicts: browser-plugin-adobe-flash < %{flashv}-%{!?rel:1}%{?rel:%{rel}}
+Conflicts: browser-plugin-chrome-pdf < %{version}-%{release}
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 -n browser-plugin-adobe-flash
-Summary: Adobe Flash plugin from Google Chrome
-Summary(pl.UTF-8): Wtyczka Adobe Flash z Google Chrome
-Group: X11/Applications/Multimedia
-Requires: browser-plugins >= 2.0
+%package l10n
+Summary: google chrome language packages
+Group: I18n
+Requires: %{name} = %{version}-%{release}
-%description -n browser-plugin-adobe-flash
-Adobe Flash plugin from Google Chrome, which is not available in
-Chromium.
+%description l10n
+This package contains language packages for 50 languages:
-%description -n browser-plugin-adobe-flash -l pl.UTF-8
-Wtyczka Adobe Flash z Google Chrome, która nie jest dostępna w
-Chromium.
+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
# separate to subpackage
install -d browser-plugins
mv chrome/libpdf.so browser-plugins
-%ifarch %{ix86}
-mv chrome/libgcflashplayer.so browser-plugins
-%endif
+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}
done
install -d $RPM_BUILD_ROOT%{_browserpluginsdir}
-install -p browser-plugins/*.so $RPM_BUILD_ROOT%{_browserpluginsdir}
+cp -a browser-plugins/* $RPM_BUILD_ROOT%{_browserpluginsdir}
%browser_plugins_add_browser %{name} -p %{_libdir}/%{name}/plugins
# 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
fi
# FIXME: chrome *needs* it to be in application dir. add symlink until it can load from other places
-# for chromium, we could likely patch source
+# 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 -s plugins/libpdf.so %{_libdir}/google-chrome/libpdf.so
+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
-rm -f %{_libdir}/google-chrome/libpdf.so
+if [ "$1" = "0" ] || [ "$2" = "0" ] && [ -L %{_libdir}/google-chrome/libpdf.so ]; then
+ rm -f %{_libdir}/google-chrome/libpdf.so
+fi
-%triggerin -n browser-plugin-chrome-pdf -- chromium-browser
-test -L %{_libdir}/chromium-browser/libpdf.so || ln -s plugins/libpdf.so %{_libdir}/chromium-browser/libpdf.so
+%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-chrome-pdf -- chromium-browser
-rm -f %{_libdir}/chromium-browser/libpdf.so
+%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 -s plugins/libpdf.so %{_libdir}/chromium-browser-bin/libpdf.so
+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
-rm -f %{_libdir}/chromium-browser-bin/libpdf.so
+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
+%files
%defattr(644,root,root,755)
%{_browserpluginsconfdir}/browsers.d/%{name}.*
%dir %{_libdir}/%{name}
%{_libdir}/%{name}/chrome.pak
%{_libdir}/%{name}/resources.pak
+%{_libdir}/%{name}/theme_resources_*.pak
+%{_libdir}/%{name}/ui_resources_*.pak
%dir %{_libdir}/%{name}/locales
+%{_libdir}/%{name}/locales/en-US.pak
%dir %{_libdir}/%{name}/plugins
%{_libdir}/%{name}/default_apps
%{_libdir}/%{name}/themes
%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
-%ifarch %{ix86}
%files -n browser-plugin-adobe-flash
%defattr(644,root,root,755)
-%{_libdir}/%{name}/plugin.vch
-%attr(755,root,root) %{_browserpluginsdir}/libgcflashplayer.so
-%endif
+%dir %{_browserpluginsdir}/PepperFlash
+%{_browserpluginsdir}/PepperFlash/manifest.json
+%{_browserpluginsdir}/PepperFlash/manifest.ver
+%attr(755,root,root) %{_browserpluginsdir}/PepperFlash/libpepflashplayer.so