X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=chromium-browser.spec;h=1ae7b3e39a809cbf38d07860c73eac8a98d5a8e6;hb=8099609f6a3387e9d53c7d1b906f82626559bb7c;hp=b2e68317a1bd3265d0069abe6a1cb16f2fb2b91d;hpb=ffb057546dfdf6af32508d6fca0d1925e8bc975c;p=packages%2Fchromium-browser.git diff --git a/chromium-browser.spec b/chromium-browser.spec index b2e6831..1ae7b3e 100644 --- a/chromium-browser.spec +++ b/chromium-browser.spec @@ -2,13 +2,14 @@ # Conditional build: %bcond_without cups # with cups %bcond_without debuginfo # disable debuginfo creation (it is huge) +%bcond_with dev # with dev optimizations (skip clean source) %bcond_without gconf # with GConf %bcond_without kerberos # build with kerberos support (dlopened if support compiled, library names in net/http/http_auth_gssapi_posix.cc) %bcond_without keyring # with keyring support (gnome-keyring dlopened, kwalletd via dbus) %bcond_with gps # with gps support (linked), if enabled must use exactly same gpsd as shm structures may change leading to unexpected results (crash) %bcond_without libjpegturbo # use libjpeg-turbo features %bcond_with nacl # build Native Client support, disabled: http://crbug.com/269560 -%bcond_with ninja # use Ninja instead of make to build +%bcond_without ninja # use Ninja instead of make to build %bcond_without pulseaudio # with pulseaudio %bcond_without sandboxing # with sandboxing %bcond_with selinux # with SELinux (need policy first) @@ -17,6 +18,7 @@ %bcond_without system_flac # system flac %bcond_with system_ffmpeg # system ffmpeg instead of ffmpegsumo %bcond_without system_harfbuzz # system harfbuzz +%bcond_without system_icu # system icu %bcond_without system_jsoncpp # system jsoncpp %bcond_without system_libexif # system libexif %bcond_without system_libmtp # system libmtp @@ -26,22 +28,33 @@ %bcond_with system_mesa # system Mesa %bcond_without system_minizip # system minizip %bcond_without system_opus # system opus codec support, http://www.opus-codec.org/examples/ -%bcond_without system_protobuf # system protobuf +# protobuf broken: https://bugs.gentoo.org/show_bug.cgi?id=525560 +%bcond_with system_protobuf # system protobuf %bcond_without system_re2 # system re2 %bcond_without system_snappy # system snappy %bcond_without system_speex # system speex %bcond_with system_sqlite # system sqlite WebSQL (http://www.w3.org/TR/webdatabase/) will not work %bcond_without system_libsrtp # system srtp (can be used if using bundled libjingle) %bcond_with system_v8 # system v8 -%bcond_without system_libvpx # system libvpx +%bcond_with system_libvpx # system libvpx %bcond_without system_yasm # system yasm %bcond_without system_zlib # system zlib -%bcond_without tcmalloc # use tcmalloc +%bcond_with tcmalloc # use tcmalloc %bcond_without verbose # verbose build (V=1) %ifarch %{ix86} # GLsizeiptr different size, track: http://bugs.gentoo.org/457130 %undefine with_system_mesa + +# unable build with debuginfo on 32bit build systems +# /usr/bin/ld.gold: fatal error: chrome: mmap: failed to allocate 2994044872 bytes for output file: Cannot allocate memory +%undefine with_debuginfo +%endif + +%ifarch %{x8664} +# x86_64 systems fail with debugedit crashing +# /usr/lib/rpm/bin/debugedit: canonicalization unexpectedly shrank by one character +%undefine with_debuginfo %endif # TODO @@ -60,9 +73,9 @@ # - http://code.google.com/p/chromium/wiki/LinuxBuildInstructionsPrerequisites # - to look for new tarball, use update-source.sh script -%define branch 35.0.1916 -%define basever 114 -#define patchver 132 +%define branch 42.0.2311 +%define basever 82 +#define patchver 118 %define gyp_rev 1014 Summary: A WebKit powered web browser Name: chromium-browser @@ -74,11 +87,11 @@ Version: %{branch}.%{basever} Release: 0.1 License: BSD%{!?with_system_ffmpeg:, LGPL v2+ (ffmpeg)} Group: X11/Applications/Networking -Source0: http://carme.pld-linux.org/~glen/chromium-browser/src/stable/%{name}-%{branch}.%{basever}.tar.xz -# Source0-md5: 987b25c0a3aa7bc2354c573113e94e04 +Source0: http://carme.pld-linux.org/~glen/chromium-browser/src/beta/%{name}-%{branch}.%{basever}.tar.gz +# Source0-md5: 7bdbf015d663e082f5bbe4cf24907049 %if "%{?patchver}" != "" Patch0: http://carme.pld-linux.org/~glen/chromium-browser/src/stable/%{name}-%{version}.patch.xz -# Patch0-md5: 4eafe1e64bd47a11dbfaf61a2dd50b6e +# Patch0-md5: fc9cd6fd3392142db2ada6b98b89fa80 %endif Source1: %{name}.default Source2: %{name}.sh @@ -88,9 +101,8 @@ Source6: update-source.sh Source7: clean-source.sh Source8: get-source.sh Source9: master_preferences.json -Patch1: plugin-searchdirs.patch +# https://github.com/Kelvin-Ng/Kelvin-Gentoo-Overlay/tree/master/www-client/chromium/files Patch2: enable-video-decode-accel.patch -Patch4: path-libpdf.patch Patch7: dlopen_sonamed_gl.patch Patch8: chromium_useragent.patch.in # https://bugs.gentoo.org/show_bug.cgi?id=393471 @@ -103,10 +115,13 @@ Patch24: nacl-verbose.patch Patch25: gnome3-volume-control.patch Patch26: master-prefs-path.patch Patch28: system-mesa.patch -Patch30: system-ply.patch Patch31: system-jinja.patch Patch32: remove_bundled_libraries-stale.patch Patch35: etc-dir.patch +Patch36: angle.patch +Patch37: %{name}-build.patch +Patch38: vaapi_include.patch +Patch39: libsecret.patch URL: http://www.chromium.org/Home %{?with_gconf:BuildRequires: GConf2-devel} %{?with_system_mesa:BuildRequires: Mesa-libGL-devel >= 9.1} @@ -141,11 +156,12 @@ BuildRequires: hicolor-icon-theme BuildRequires: libevent-devel %{?with_system_libexif:BuildRequires: libexif-devel >= 1:0.6.21} %{?with_keyring:BuildRequires: libgnome-keyring-devel} -BuildRequires: libicu-devel >= 4.6 +%{?with_system_icu:BuildRequires: libicu-devel >= 4.6} %{!?with_libjpegturbo:BuildRequires: libjpeg-devel} %{?with_libjpegturbo:BuildRequires: libjpeg-turbo-devel >= 1.2.0} %{?with_system_libmtp:BuildRequires: libmtp-devel >= 1.1.3} BuildRequires: libpng-devel +BuildRequires: libsecret-devel %{?with_selinux:BuildRequires: libselinux-devel} BuildRequires: libstdc++-devel %{?with_system_libusb:BuildRequires: libusb-devel >= 1.0} @@ -168,6 +184,7 @@ BuildRequires: pkgconfig %{?with_system_protobuf:BuildRequires: protobuf-devel} %{?with_pulseaudio:BuildRequires: pulseaudio-devel} BuildRequires: python +BuildRequires: python-BeautifulSoup #BuildRequires: python-gyp >= 1-%{gyp_rev} BuildRequires: python-jinja2 >= 2.7 BuildRequires: python-modules @@ -202,6 +219,7 @@ Requires: libevent >= 2.0.21 %{?with_system_libvpx:Requires: libvpx >= 1.3.0} Requires: lsb-release %{?with_system_re2:Requires: re2 >= 20130115-2} +%{?with_system_protobuf:Requires: protobuf-libs >= 2.5.0-2} Requires: shared-mime-info %{?with_system_sqlite:Requires: sqlite3(icu)} Requires: xdg-utils >= 1.0.2-4 @@ -295,9 +313,7 @@ sed -e 's/@BUILD_DIST@/PLD %{pld_version}/g' \ %{__sed} -e 's,@localedir@,%{_datadir}/%{name},' %{SOURCE5} > find-lang.sh ln -s %{SOURCE7} . -%patch1 -p1 -#%patch2 -p1 NOT COMPILING -%patch4 -p3 +#%patch2 -p1 CHECK %patch7 -p1 %patch15 -p2 %{!?with_libjpegturbo:%patch11 -p0} @@ -307,10 +323,15 @@ ln -s %{SOURCE7} . %{?with_nacl:%patch18 -p1} %patch24 -p1 %patch26 -p2 -#%patch30 -p1 -#%patch31 -p0 +%patch31 -p0 %patch32 -p1 %patch35 -p1 +%patch36 -p1 +%patch37 -p1 +#%patch38 -p1 CHECK +%patch39 -p1 + +%{?with_dev:exit 0} sh -x clean-source.sh \ %{!?with_nacl:nacl=0} \ @@ -368,24 +389,29 @@ fi if [ ! -d third_party/ffmpeg/build.%{target_arch}.linux ]; then # Re-configure bundled ffmpeg cd third_party/ffmpeg - chromium/scripts/build_ffmpeg.sh linux %{target_arch} "$PWD" config-only + chromium/scripts/build_ffmpeg.py linux %{target_arch} \ + --branding Chromium chromium/scripts/copy_config.sh + chromium/scripts/generate_gyp.py cd - fi %endif +third_party/libaddressinput/chromium/tools/update-strings.py + flags=" -Dtarget_arch=%{target_arch} \ -Dpython_arch=%{target_arch} \ + -Dffmpeg_branding=Chromium \ -Dsystem_libdir=%{_lib} \ -Dpython_ver=%{py_ver} \ %if "%{cc_version}" >= "4.4.0" && "%{cc_version}" < "4.5.0" -Dno_strict_aliasing=1 -Dgcc_version=44 \ %endif - %{!?debug:-Dwerror=} \ + %{!?debug:-Dwerror= -Ddisable_fatal_linker_warnings=} \ %{!?debuginfo:-Dfastbuild=1 -Dremove_webcore_debug_symbols=1} \ %{?with_shared_libs:-Dlibrary=shared_library} \ - %{!?with_system_ffmpeg:-Dbuild_ffmpegsumo=1} -Dproprietary_codecs=1 \ + %{!?with_system_ffmpeg:-Dbuild_ffmpegsumo=1} \ -Dinclude_tests__=0 \ %if %{with nacl} -Dnaclsdk_mode=custom:/usr/x86_64-nacl \ @@ -403,9 +429,12 @@ flags=" -Dusb_ids_path=$(pkg-config --variable usbids usbutils) \ -Dlinux_link_libpci=1 \ -Dlinux_link_libspeechd=1 -Dlibspeechd_h_prefix=speech-dispatcher/ \ - %{!?with_tcmalloc:-Dlinux_use_tcmalloc=0} \ + -Duse_allocator=%{!?with_tcmalloc:none}%{?with_tcmalloc:tcmalloc} \ %{?with_gps:-Dlinux_use_libgps=1 -Dlinux_link_libgps=1} \ - -Dlinux_use_gold_binary=0 \ + -Dclang=0 \ + -Dhost_clang=0 \ + -Dlinux_use_bundled_binutils=0 \ + -Dlinux_use_bundled_gold=0 \ -Dlinux_use_gold_flags=0 \ -Dlogging_like_official_build=1 \ -Dgoogle_api_key=%{google_api_key} \ @@ -419,6 +448,7 @@ flags=" %{gyp_with system_ffmpeg} -Dmedia_use_ffmpeg=1 \ %{gyp_with system_flac} \ %{gyp_with system_harfbuzz} \ + %{gyp_with system_icu} %{?with_system_icu:-Dicu_use_data_file_flag=0} \ %{gyp_with system_jsoncpp} \ %{gyp_with system_libexif} \ %{gyp_with system_libmtp} \ @@ -440,7 +470,6 @@ flags=" %{gyp_with system_zlib} \ -Duse_system_bzip2=1 \ -Duse_system_expat=1 \ - -Duse_system_icu=1 \ -Duse_system_libevent=1 \ -Duse_system_libjpeg=1 \ -Duse_system_libpng=1 \ @@ -498,8 +527,6 @@ install -d $RPM_BUILD_ROOT%{_libdir}/%{name}/plugins \ $RPM_BUILD_ROOT{%{_bindir},%{_mandir}/man1,%{_desktopdir}} \ $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/{native-messaging-hosts,policies/managed} -cp -p third_party/icu/source/data/in/icudtl.dat $RPM_BUILD_ROOT%{_libdir}/%{name} - cd %{builddir} cp -p %{SOURCE1} $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/default install -p %{SOURCE2} $RPM_BUILD_ROOT%{_bindir}/%{name} @@ -512,7 +539,7 @@ install -p %{SOURCE2} $RPM_BUILD_ROOT%{_bindir}/%{name} } ' $RPM_BUILD_ROOT%{_bindir}/%{name} cp -a locales resources $RPM_BUILD_ROOT%{_datadir}/%{name} -cp -p *.pak $RPM_BUILD_ROOT%{_libdir}/%{name} +cp -p *.pak *.bin $RPM_BUILD_ROOT%{_libdir}/%{name} ln -s %{_datadir}/%{name}/locales $RPM_BUILD_ROOT%{_libdir}/%{name}/locales ln -s %{_datadir}/%{name}/resources $RPM_BUILD_ROOT%{_libdir}/%{name}/resources cp -p chrome.1 $RPM_BUILD_ROOT%{_mandir}/man1/%{name}.1 @@ -602,9 +629,11 @@ fi %{_iconsdir}/hicolor/*/apps/%{name}.png %dir %{_libdir}/%{name} %{_libdir}/%{name}/chrome*.pak -%{_libdir}/%{name}/icudtl.dat %{_libdir}/%{name}/content_resources.pak +%{_libdir}/%{name}/keyboard_resources.pak %{_libdir}/%{name}/resources.pak +%{_libdir}/%{name}/natives_blob.bin +%{_libdir}/%{name}/snapshot_blob.bin %{_libdir}/%{name}/locales %{_libdir}/%{name}/resources