Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 18 Aug 2014 19:07:12 +0000 (UTC)
From:      Rene Ladan <rene@FreeBSD.org>
To:        ports-committers@freebsd.org, svn-ports-all@freebsd.org, svn-ports-head@freebsd.org
Subject:   svn commit: r365341 - in head/www/chromium: . files
Message-ID:  <201408181907.s7IJ7CrZ038764@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: rene
Date: Mon Aug 18 19:07:11 2014
New Revision: 365341
URL: http://svnweb.freebsd.org/changeset/ports/365341
QAT: https://qat.redports.org/buildarchive/r365341/

Log:
  www/chromium: Enable build on FreeBSD < 10 and enable file chooser dialog [1].
  
  - Spell out full path to /sbin/sysctl [2]
  - Build with OpenSSL from base to avoid a link conflict on FreeBSD < 10
  - Fix build with libusb on FreeBSD < 10 [3]
  - Fix build with GCC 4.7 (for 8.4 / 9.1)
  - Bump PORTREVISION
  
  PR:		192742 [1]
  Submitted by:	cmt@burggraben.net [1]
  Submitted by:	J. R. Oldroyd [2]
  Submitted by:	db@ [3]
  MFH:		2014Q3

Added:
  head/www/chromium/files/extra-patch-libusb-pc   (contents, props changed)
  head/www/chromium/files/patch-build__linux__unbundle__openssl.gyp   (contents, props changed)
  head/www/chromium/files/patch-ui__shell_dialogs__select_file_dialog.cc   (contents, props changed)
Modified:
  head/www/chromium/Makefile
  head/www/chromium/files/chrome.in
  head/www/chromium/files/extra-patch-gcc
  head/www/chromium/files/patch-components__usb_service__usb_device_handle.cc

Modified: head/www/chromium/Makefile
==============================================================================
--- head/www/chromium/Makefile	Mon Aug 18 18:53:16 2014	(r365340)
+++ head/www/chromium/Makefile	Mon Aug 18 19:07:11 2014	(r365341)
@@ -3,6 +3,7 @@
 
 PORTNAME=	chromium
 PORTVERSION=	36.0.1985.143
+PORTREVISION=	1
 CATEGORIES=	www
 MASTER_SITES=	http://commondatastorage.googleapis.com/chromium-browser-official/
 DISTFILES=	${DISTNAME}${EXTRACT_SUFX}
@@ -20,7 +21,6 @@ BUILD_DEPENDS=	${LOCALBASE}/bin/gperf:${
 		yasm:${PORTSDIR}/devel/yasm \
 		flock:${PORTSDIR}/sysutils/flock \
 		${LOCALBASE}/include/linux/videodev2.h:${PORTSDIR}/multimedia/v4l_compat \
-		protoc:${PORTSDIR}/devel/protobuf \
 		${LOCALBASE}/share/usbids/usb.ids:${PORTSDIR}/misc/usbids
 
 LIB_DEPENDS=	libcairo.so:${PORTSDIR}/graphics/cairo \
@@ -43,6 +43,7 @@ LIB_DEPENDS=	libcairo.so:${PORTSDIR}/gra
 		libjsoncpp.so:${PORTSDIR}/devel/jsoncpp \
 		libminizip.so:${PORTSDIR}/archivers/minizip \
 		libnspr4.so:${PORTSDIR}/devel/nspr \
+		libprotobuf.so:${PORTSDIR}/devel/protobuf \
 		libpng.so:${PORTSDIR}/graphics/png \
 		libre2.so:${PORTSDIR}/devel/re2 \
 		libsnappy.so:${PORTSDIR}/archivers/snappy \
@@ -63,8 +64,7 @@ CPE_PRODUCT=	chrome
 USE_PERL5=	build
 USE_XORG=	scrnsaverproto x11 xproto xscrnsaver xtst
 USE_GNOME=	glib20 gtk20 dconf libxslt
-USE_OPENSSL=	yes
-WITH_OPENSSL_PORT=	yes # simplify for pkg-config in configure phase
+USE_OPENSSL=	yes # must be from base to prevent a link failure against cups
 SHEBANG_FILES=	chrome/tools/build/linux/chrome-wrapper
 ALL_TARGET=	chrome
 INSTALLS_ICONS=	yes
@@ -166,6 +166,9 @@ GYP_DEFINES+=	use_pulseaudio=0
 GYP_DEFINES+=	disable_sse2=1
 .endif
 
+.if !exists(/usr/libdata/pkgconfig/libusb-1.0.pc)
+EXTRA_PATCHES+=	${FILESDIR}/extra-patch-libusb-pc
+.endif
 .if ${OSVERSION} >= 1000052 && !exists(${LOCALBASE}/include/execinfo.h)
 EXTRA_PATCHES+=	${FILESDIR}/extra-patch-fixup-execinfo
 .endif
@@ -188,13 +191,15 @@ CONFIGURE_ENV+=	CC="${CC}" \
 		GYP_DEFINES="${GYP_DEFINES}"
 MAKE_ENV+=	BUILDTYPE=${BUILDTYPE} \
 		GPERF="${LOCALBASE}/bin/gperf"
-MAKE_ARGS+=	-C out/${BUILDTYPE}
 
 .include <bsd.port.pre.mk>
 
+#XXX redefine MAKE_ARGS after bsd.port.pre.mk to avoid OPENSSL flags
+# leaking in which confuses ninja
+MAKE_ARGS=	-C out/${BUILDTYPE}
+
 .if ${CHOSEN_COMPILER_TYPE} == gcc
 GYP_DEFINES+=	gcc_version=${CXX:S/g++//}
-CFLAGS+=	-Wno-unknown-warning
 EXTRA_PATCHES+=	${FILESDIR}/extra-patch-gcc
 .else
 GYP_DEFINES+=	clang=1

Modified: head/www/chromium/files/chrome.in
==============================================================================
--- head/www/chromium/files/chrome.in	Mon Aug 18 18:53:16 2014	(r365340)
+++ head/www/chromium/files/chrome.in	Mon Aug 18 19:07:11 2014	(r365341)
@@ -1,7 +1,7 @@
 #!/bin/sh
 
 SYSCTL=kern.ipc.shm_allow_removed
-if [ `sysctl -n $SYSCTL` = 0 ] ; then
+if [ "`/sbin/sysctl -n $SYSCTL`" = 0 ] ; then
 	cat << EOMSG
 For correct operation, shared memory support has to be enabled
 in Chromium by performing the following command as root :

Modified: head/www/chromium/files/extra-patch-gcc
==============================================================================
--- head/www/chromium/files/extra-patch-gcc	Mon Aug 18 18:53:16 2014	(r365340)
+++ head/www/chromium/files/extra-patch-gcc	Mon Aug 18 19:07:11 2014	(r365341)
@@ -86,3 +86,13 @@
  #include "third_party/libjpeg_turbo/jpeglib.h"
  #else
  #include "third_party/libjpeg/jpeglib.h"
+--- ui/gfx/codec/jpeg_codec.cc.orig	2014-08-12 21:02:29.000000000 +0200
++++ ui/gfx/codec/jpeg_codec.cc	2014-08-17 19:32:18.000000000 +0200
+@@ -13,6 +13,7 @@
+ 
+ extern "C" {
+ #if defined(USE_SYSTEM_LIBJPEG)
++#include <stdio.h>
+ #include <jpeglib.h>
+ #elif defined(USE_LIBJPEG_TURBO)
+ #include "third_party/libjpeg_turbo/jpeglib.h"

Added: head/www/chromium/files/extra-patch-libusb-pc
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/www/chromium/files/extra-patch-libusb-pc	Mon Aug 18 19:07:11 2014	(r365341)
@@ -0,0 +1,20 @@
+--- build/linux/unbundle/libusb.gyp.orig	2014-08-12 21:02:52.000000000 +0200
++++ build/linux/unbundle/libusb.gyp	2014-08-17 16:21:03.000000000 +0200
+@@ -18,14 +18,14 @@
+       ],
+       'direct_dependent_settings': {
+         'cflags': [
+-          '<!@(pkg-config --cflags libusb-1.0)',
++          '',
+         ],
+         'link_settings': {
+           'ldflags': [
+-            '<!@(pkg-config --libs-only-L --libs-only-other libusb-1.0)',
++            '',
+           ],
+           'libraries': [
+-            '<!@(pkg-config --libs-only-l libusb-1.0)',
++            '-lusb',
+           ],
+         },
+       },

Added: head/www/chromium/files/patch-build__linux__unbundle__openssl.gyp
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/www/chromium/files/patch-build__linux__unbundle__openssl.gyp	Mon Aug 18 19:07:11 2014	(r365341)
@@ -0,0 +1,21 @@
+--- build/linux/unbundle/openssl.gyp.orig	2014-08-12 21:02:52.000000000 +0200
++++ build/linux/unbundle/openssl.gyp	2014-08-18 17:16:23.000000000 +0200
+@@ -9,15 +9,15 @@
+       'type': 'none',
+       'direct_dependent_settings': {
+         'cflags': [
+-          '<!@(pkg-config --cflags openssl)',
++          '',
+         ],
+       },
+       'link_settings': {
+         'ldflags': [
+-          '<!@(pkg-config --libs-only-L --libs-only-other openssl)',
++          '',
+         ],
+         'libraries': [
+-          '<!@(pkg-config --libs-only-l openssl)',
++          '-lssl',
+         ],
+       },
+     }

Modified: head/www/chromium/files/patch-components__usb_service__usb_device_handle.cc
==============================================================================
--- head/www/chromium/files/patch-components__usb_service__usb_device_handle.cc	Mon Aug 18 18:53:16 2014	(r365340)
+++ head/www/chromium/files/patch-components__usb_service__usb_device_handle.cc	Mon Aug 18 19:07:11 2014	(r365341)
@@ -1,6 +1,6 @@
 --- ./components/usb_service/usb_device_handle.cc.orig	2014-08-12 21:02:37.000000000 +0200
-+++ ./components/usb_service/usb_device_handle.cc	2014-08-13 09:56:57.000000000 +0200
-@@ -16,7 +16,12 @@
++++ ./components/usb_service/usb_device_handle.cc	2014-08-17 16:54:01.000000000 +0200
+@@ -16,7 +16,24 @@
  #include "components/usb_service/usb_interface.h"
  #include "components/usb_service/usb_service.h"
  #include "content/public/browser/browser_thread.h"
@@ -10,6 +10,18 @@
 +#else
  #include "third_party/libusb/src/libusb/libusb.h"
 +#endif
++
++/* Define for FreeBSD < 9.3, thanks to db@freebsd.org */
++#if defined(OS_FREEBSD) && __FreeBSD_version < 903000
++int libusb_get_string_descriptor(libusb_device_handle *dev,
++  uint8_t descriptor_index, uint16_t lang_id, unsigned char* data, int length) {
++  return libusb_control_transfer(dev,
++    LIBUSB_ENDPOINT_IN | 0x0, /* Endpoint 0 IN */
++    LIBUSB_REQUEST_GET_DESCRIPTOR,
++    (LIBUSB_DT_STRING << 8) | descriptor_index,
++    lang_id, data, (uint16_t)length, 1000);
++}
++#endif
  
  using content::BrowserThread;
  

Added: head/www/chromium/files/patch-ui__shell_dialogs__select_file_dialog.cc
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/www/chromium/files/patch-ui__shell_dialogs__select_file_dialog.cc	Mon Aug 18 19:07:11 2014	(r365341)
@@ -0,0 +1,20 @@
+--- ui/shell_dialogs/select_file_dialog.cc.orig	2014-08-12 21:02:27.000000000 +0200
++++ ui/shell_dialogs/select_file_dialog.cc	2014-08-17 19:43:29.000000000 +0200
+@@ -20,7 +20,7 @@
+ #include "ui/shell_dialogs/select_file_dialog_mac.h"
+ #elif defined(OS_ANDROID)
+ #include "ui/shell_dialogs/select_file_dialog_android.h"
+-#elif defined(USE_AURA) && !defined(USE_ASH) && defined(OS_LINUX)
++#elif defined(USE_AURA) && !defined(USE_ASH) && (defined(OS_LINUX) || defined(OS_FREEBSD))
+ #include "ui/shell_dialogs/linux_shell_dialog.h"
+ #endif
+ 
+@@ -76,7 +76,7 @@
+       return dialog;
+   }
+ 
+-#if defined(USE_AURA) && !defined(USE_ASH) && defined(OS_LINUX)
++#if defined(USE_AURA) && !defined(USE_ASH) && (defined(OS_LINUX) || defined(OS_FREEBSD))
+   const ui::LinuxShellDialog* shell_dialogs = ui::LinuxShellDialog::instance();
+   if (shell_dialogs)
+     return shell_dialogs->CreateSelectFileDialog(listener, policy);



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201408181907.s7IJ7CrZ038764>