devel/electron4: Fix build after snappy update

While here, add several internal reogranization and make electron4 not in
conflict with electron6

Submitted by:	maintainer (via github)
This commit is contained in:
Luca Pizzamiglio 2020-01-27 20:57:06 +00:00
parent 34593efd5d
commit af2e3cb51a
Notes: svn2git 2021-03-31 03:12:20 +00:00
svn path=/head/; revision=524445
5 changed files with 85 additions and 61 deletions

View file

@ -3,15 +3,17 @@
PORTNAME= electron
DISTVERSIONPREFIX= v
DISTVERSION= ${ELECTRON_VER:S/-beta./.b/}
PORTREVISION= 1
CATEGORIES= devel
MASTER_SITES= https://github.com/tagattie/FreeBSD-Electron/releases/download/v4.1.0/:chromium \
https://commondatastorage.googleapis.com/chromium-browser-official/:chromium_official \
https://commondatastorage.googleapis.com/chromium-nodejs/:chromium_node \
https://commondatastorage.googleapis.com/chromium-fonts/:chromium_testfonts
PKGNAMESUFFIX= 4
PKGNAMESUFFIX= ${ELECTRON_VER:C/^([0-9]+)\..+$$/\1/}
DISTFILES= chromium-${CHROMIUM_VER}${EXTRACT_SUFX}:chromium \
chromium-${CHROMIUM_OFFICIAL_VER}${EXTRACT_SUFX}:chromium_official \
${CHROMIUM_NODE_MODULES_HASH}:chromium_node \
${CHROMIUM_TEST_FONTS_HASH}:chromium_testfonts \
electron-npm-modules-${ELECTRON_VER}${EXTRACT_SUFX}:prefetch
DIST_SUBDIR= ${PORTNAME}
@ -48,12 +50,11 @@ LIB_DEPENDS= libatk-bridge-2.0.so:accessibility/at-spi2-atk \
libexpat.so:textproc/expat2 \
libfontconfig.so:x11-fonts/fontconfig
RUN_DEPENDS= xdg-open:devel/xdg-utils
TEST_DEPENDS= npm:www/npm-node10
TEST_DEPENDS= ${PYTHON_PKGNAMEPREFIX}python-dbusmock>0:devel/py-python-dbusmock@${PY_FLAVOR} \
npm:www/npm-node10
USES= bison dos2unix gettext-tools gl gnome jpeg localbase:ldflags \
ninja pkgconfig python:2.7,build tar:xz xorg
CONFLICTS_INSTALL= electron5
ninja pkgconfig python:2.7,build,test tar:xz xorg
USE_GITHUB= yes
GH_TAGNAME= ${DISTVERSIONPREFIX}${ELECTRON_VER}
@ -63,7 +64,7 @@ GH_TUPLE= electron:node:8bc5d171a0873c0ba49f9433798bc8b67399788c:node
# yaml:pyyaml:3.12:pyyaml \
# kennethreitz:requests:e4d59bedfd3c7f4f254f4f5d036587bcd8152458:requests
ELECTRON_VER= 4.2.12
#ELECTRON_VER= 4.2.12
# Official chromium version containing "gn" which is known to work
CHROMIUM_OFFICIAL_VER= 76.0.3809.132
# See ${WRKSRC}/electron/DEPS for CHROMIUM_VER
@ -76,6 +77,8 @@ CHROMIUM_TEST_FONTS_HASH= a22de844e32a3f720d219e3911c3da3478039f89
NO_WRKSUBDIR= yes
WRKSRC_SUBDIR= src
DATADIR= ${PREFIX}/share/${PORTNAME}${PKGNAMESUFFIX}
DOS2UNIX_FILES= third_party/skia/third_party/vulkanmemoryallocator/include/vk_mem_alloc.h
BINARY_ALIAS= python=${PYTHON_CMD}
@ -110,12 +113,12 @@ GN_ARGS+= clang_use_chrome_plugins=false \
extra_ldflags="${LDFLAGS}"
GN_BOOTSTRAP_FLAGS= --no-clean --no-rebuild --skip-generate-buildfiles
ALL_TARGET= electron
ALL_TARGET= electron third_party/electron_node:headers
MAKE_ARGS= -C out/${BUILDTYPE}
MAKE_ENV+= C_INCLUDE_PATH=${LOCALBASE}/include \
CPLUS_INCLUDE_PATH=${LOCALBASE}/include
OPTIONS_DEFINE= CUPS DEBUG DIST DRIVER KERBEROS TEST
OPTIONS_DEFINE= CUPS DEBUG DIST DRIVER KERBEROS
DIST_DESC= Build distribution zip files
DRIVER_DESC= Install chromedriver
OPTIONS_GROUP= AUDIO
@ -123,10 +126,6 @@ OPTIONS_GROUP_AUDIO= ALSA PULSEAUDIO
OPTIONS_DEFAULT= CUPS DRIVER KERBEROS ALSA
OPTIONS_SUB= yes
.if make(makesum)
.MAKEFLAGS: WITH="${OPTIONS_DEFINE}"
.endif
ALSA_LIB_DEPENDS= libasound.so:audio/alsa-lib
ALSA_RUN_DEPENDS= ${LOCALBASE}/lib/alsa-lib/libasound_module_pcm_oss.so:audio/alsa-plugins
ALSA_VARS= GN_ARGS+=use_alsa=true
@ -151,18 +150,16 @@ PULSEAUDIO_LIB_DEPENDS= libpulse.so:audio/pulseaudio
PULSEAUDIO_VARS= GN_ARGS+=use_pulseaudio=true
PULSEAUDIO_VARS_OFF= GN_ARGS+=use_pulseaudio=false
.include "Makefile.tests"
TEST_DISTFILES= ${CHROMIUM_TEST_FONTS_HASH}:chromium_testfonts
TEST_ALL_TARGET= ${TEST_TARGETS}
TEST_ALL_TARGET+= third_party/electron_node:headers
POST_BUILD_TARGETS= licenses version
POST_BUILD_DIST_TARGETS= dist.zip chromedriver.zip mksnapshot.zip
POST_BUILD_DIST_TARGETS= electron_dist_zip electron_chromedriver_zip electron_mksnapshot_zip
NPM_TIMESTAMP= 1573298347
PLIST_SUB= ELECTRON_VER=${ELECTRON_VER}
PLIST_SUB= ELECTRON_VER=${ELECTRON_VER} \
PKGNAMESUFFIX=${PKGNAMESUFFIX}
.include "Makefile.version"
.include "Makefile.tests"
.include <bsd.port.pre.mk>
.if ${ARCH} == "amd64"
@ -213,10 +210,8 @@ post-extract:
# ${MV} ${WRKDIR}/${PORTNAME}-${ELECTRON_VER}/${GH_PROJECT_requests}-${GH_TAGNAME_requests} \
# ${WRKSRC}/electron/vendor/${GH_PROJECT_requests}
${MV} ${WRKDIR}/${PORTNAME}-${ELECTRON_VER}/node_modules ${WRKSRC}/third_party/node
${MV} ${WRKDIR}/${PORTNAME}-${ELECTRON_VER}/npm_modules ${WRKSRC}/electron/node_modules
post-extract-TEST-on:
${MV} ${WRKDIR}/${PORTNAME}-${ELECTRON_VER}/test_fonts ${WRKSRC}/third_party/test_fonts
${MV} ${WRKDIR}/${PORTNAME}-${ELECTRON_VER}/npm_modules ${WRKSRC}/electron/node_modules
pre-patch:
${SH} ${FILESDIR}/apply-electron-patches.sh ${WRKSRC}
@ -288,7 +283,8 @@ do-install:
.for f in default_app.asar electron.asar
${INSTALL_DATA} ${WRKSRC}/out/${BUILDTYPE}/resources/${f} ${STAGEDIR}${DATADIR}/resources
.endfor
${RLN} ${STAGEDIR}${DATADIR}/electron ${STAGEDIR}${PREFIX}/bin
cd ${WRKSRC}/out/${BUILDTYPE}/gen && ${COPYTREE_SHARE} node_headers ${STAGEDIR}${DATADIR}
${RLN} ${STAGEDIR}${DATADIR}/electron ${STAGEDIR}${PREFIX}/bin/electron${PKGNAMESUFFIX}
post-install-DIST-on:
${MKDIR} ${STAGEDIR}${DATADIR}/releases
@ -298,13 +294,7 @@ post-install-DIST-on:
post-install-DRIVER-on:
${INSTALL_PROGRAM} ${WRKSRC}/out/${BUILDTYPE}/chromedriver ${STAGEDIR}${DATADIR}
do-test-TEST-on:
# chromium unit tests
# .for t in ${TEST_ALL_TARGET}
# cd ${WRKSRC}/out/${BUILDTYPE} && ${SETENV} LC_ALL=en_US.UTF-8 \
# ./${t} --gtest_filter=-${EXCLUDE_${t}:ts:} || ${TRUE}
# .endfor
# electron unit tests
do-test:
# Note 1: "npm install" will run before actual tests are executed
# Note 2: Xvfb or something similar is necessary for headless testing
.for t in ${TEST_MODULES}

View file

@ -1,35 +1,5 @@
# $FreeBSD$
TEST_TARGETS= base_unittests \
chromedriver_unittests \
crypto_unittests \
printing_unittests \
url_unittests
# capture_unittests \
# cc_unittests \
# compositor_unittests \
# content_unittests \
# dbus_unittests \
# display_unittests \
# events_unittests \
# gin_unittests \
# gl_unittests \
# gpu_unittests \
# headless_unittests \
# media_unittests \
# media_mojo_unittests \
# midi_unittests \
# mojo_unittests \
# net_unittests \
# ppapi_unittests \
# skia_unittests \
# sql_unittests \
# storage_unittests \
# ui_base_unittests \
# url_ipc_unittests \
# unittests \
TEST_MODULES= electron\ module \
app\ module \
autoUpdater\ module \

View file

@ -0,0 +1,3 @@
# $FreeBSD$
ELECTRON_VER= 4.2.12

View file

@ -0,0 +1,20 @@
--- third_party/snappy/src/snappy.h.orig 2019-03-19 09:09:00 UTC
+++ third_party/snappy/src/snappy.h
@@ -73,7 +73,7 @@ namespace snappy {
// Original contents of *output are lost.
//
// REQUIRES: "input[]" is not an alias of "*output".
- size_t Compress(const char* input, size_t input_length, string* output);
+ size_t Compress(const char* input, size_t input_length, std::string* output);
// Decompresses "compressed[0,compressed_length-1]" to "*uncompressed".
// Original contents of "*uncompressed" are lost.
@@ -82,7 +82,7 @@ namespace snappy {
//
// returns false if the message is corrupted and could not be decompressed
bool Uncompress(const char* compressed, size_t compressed_length,
- string* uncompressed);
+ std::string* uncompressed);
// Decompresses "compressed" to "*uncompressed".
//

View file

@ -1,4 +1,4 @@
bin/electron
bin/electron%%PKGNAMESUFFIX%%
%%DATADIR%%/LICENSE
%%DATADIR%%/LICENSES.chromium.html
%%DATADIR%%/chrome_100_percent.pak
@ -63,6 +63,47 @@ bin/electron
%%DATADIR%%/locales/zh-TW.pak
%%DATADIR%%/mksnapshot
%%DATADIR%%/natives_blob.bin
%%DATADIR%%/node_headers/include/node/common.gypi
%%DATADIR%%/node_headers/include/node/config.gypi
%%DATADIR%%/node_headers/include/node/libplatform/libplatform-export.h
%%DATADIR%%/node_headers/include/node/libplatform/libplatform.h
%%DATADIR%%/node_headers/include/node/libplatform/v8-tracing.h
%%DATADIR%%/node_headers/include/node/node.h
%%DATADIR%%/node_headers/include/node/node_api.h
%%DATADIR%%/node_headers/include/node/node_api_types.h
%%DATADIR%%/node_headers/include/node/node_buffer.h
%%DATADIR%%/node_headers/include/node/node_object_wrap.h
%%DATADIR%%/node_headers/include/node/node_version.h
%%DATADIR%%/node_headers/include/node/uv.h
%%DATADIR%%/node_headers/include/node/uv/aix.h
%%DATADIR%%/node_headers/include/node/uv/android-ifaddrs.h
%%DATADIR%%/node_headers/include/node/uv/bsd.h
%%DATADIR%%/node_headers/include/node/uv/darwin.h
%%DATADIR%%/node_headers/include/node/uv/errno.h
%%DATADIR%%/node_headers/include/node/uv/linux.h
%%DATADIR%%/node_headers/include/node/uv/os390.h
%%DATADIR%%/node_headers/include/node/uv/posix.h
%%DATADIR%%/node_headers/include/node/uv/pthread-barrier.h
%%DATADIR%%/node_headers/include/node/uv/stdint-msvc2008.h
%%DATADIR%%/node_headers/include/node/uv/sunos.h
%%DATADIR%%/node_headers/include/node/uv/threadpool.h
%%DATADIR%%/node_headers/include/node/uv/tree.h
%%DATADIR%%/node_headers/include/node/uv/unix.h
%%DATADIR%%/node_headers/include/node/uv/version.h
%%DATADIR%%/node_headers/include/node/uv/win.h
%%DATADIR%%/node_headers/include/node/v8-inspector-protocol.h
%%DATADIR%%/node_headers/include/node/v8-inspector.h
%%DATADIR%%/node_headers/include/node/v8-platform.h
%%DATADIR%%/node_headers/include/node/v8-profiler.h
%%DATADIR%%/node_headers/include/node/v8-testing.h
%%DATADIR%%/node_headers/include/node/v8-util.h
%%DATADIR%%/node_headers/include/node/v8-value-serializer-version.h
%%DATADIR%%/node_headers/include/node/v8-version-string.h
%%DATADIR%%/node_headers/include/node/v8-version.h
%%DATADIR%%/node_headers/include/node/v8.h
%%DATADIR%%/node_headers/include/node/v8config.h
%%DATADIR%%/node_headers/include/node/zconf.h
%%DATADIR%%/node_headers/include/node/zlib.h
%%DIST%%%%DATADIR%%/releases/SHASUMS256.txt
%%DIST%%%%AMD64%%%%DATADIR%%/releases/chromedriver-v%%ELECTRON_VER%%-freebsd-x64.zip
%%DIST%%%%I386%%%%DATADIR%%/releases/chromedriver-v%%ELECTRON_VER%%-freebsd-ia32.zip