git: c7d712568cc4 - main - www/netsurf: Fix preferences dialog bug and fix build warnings
Neel Chauhan
nc at FreeBSD.org
Tue Apr 6 16:26:59 UTC 2021
The branch main has been updated by nc:
URL: https://cgit.FreeBSD.org/ports/commit/?id=c7d712568cc4dbe35df64f48f576498361160333
commit c7d712568cc4dbe35df64f48f576498361160333
Author: Neel Chauhan <nc at FreeBSD.org>
AuthorDate: 2021-04-06 16:23:54 +0000
Commit: Neel Chauhan <nc at FreeBSD.org>
CommitDate: 2021-04-06 16:26:55 +0000
www/netsurf: Fix preferences dialog bug and fix build warnings
PR: 254702
Submitted by: waitman AT waitman DOT net
---
www/netsurf/Makefile | 39 +++++-----
www/netsurf/files/Makefile.config | 2 +-
www/netsurf/files/buildui.pl | 82 ++++++++++++++++++++++
www/netsurf/files/patch-Makefile | 50 ++++++++++++-
.../files/patch-frontends_gtk_Makefile.defaults | 8 ++-
.../files/patch-frontends_gtk_preferences.c | 33 +++++++++
www/netsurf/files/patch-frontends_gtk_resources.c | 22 ++++++
www/netsurf/pkg-plist | 5 ++
8 files changed, 218 insertions(+), 23 deletions(-)
diff --git a/www/netsurf/Makefile b/www/netsurf/Makefile
index d773d30dbb4a..1a875df95350 100644
--- a/www/netsurf/Makefile
+++ b/www/netsurf/Makefile
@@ -29,14 +29,15 @@ LIB_DEPENDS= libcurl.so:ftp/curl \
libwapcaplet.so:textproc/libwapcaplet \
libhubbub.so:www/libhubbub \
libexpat.so:textproc/expat2 \
- libnspsl.so:dns/libnspsl
+ libnspsl.so:dns/libnspsl \
+ libwebp.so:graphics/webp
RUN_DEPENDS= duk:lang/duktape \
${LOCALBASE}/share/certs/ca-root-nss.crt:security/ca_root_nss
-USES= bison desktop-file-utils gettext-runtime gmake gnome iconv jpeg \
- localbase pkgconfig shebangfix ssl
+USES= bison desktop-file-utils gmake gnome jpeg \
+ localbase pkgconfig shebangfix ssl iconv:translit
ALL_TARGET= #empty
-LDFLAGS+= -L${OPENSSLLIB} -lssl -lcrypto ${ICONV_LIB}
+LDFLAGS+= -L${OPENSSLLIB} -lssl -lcrypto
CFLAGS+= -I${OPENSSLINC}
MAKE_ARGS= HOST_CC="${CC}" CC="${CC}" CCOPT="" HOST="${OPSYS}" \
TARGET="gtk3" \
@@ -47,30 +48,18 @@ USE_GNOME= glib20 gtk30 cairo librsvg2
WRKSRC= ${WRKDIR}/${DISTNAME:S/-src//}
SHEBANG_FILES= utils/split-messages.pl
-perl_CMD= ${SETENV} perl
+perl_CMD= ${PERL}
-OPTIONS_DEFINE= GSTREAMER
-OPTIONS_EXCLUDE= GSTREAMER
-GSTREAMER_USE= GSTREAMER=yes, good
+NLS_USES= gettext
+NLS_CONFIGURE_ENABLE= nls
post-patch:
@${REINPLACE_CMD} '/CFLAGS/d' \
${WRKSRC}//Makefile.defaults
- @${REINPLACE_CMD} 's| -O2||' \
- ${WRKSRC}/frontends/gtk/Makefile.defaults
- @${REINPLACE_CMD} -e 's|%%PREFIX%%|${PREFIX}|' \
- ${WRKSRC}/frontends/gtk/gui.c
+ @${CP} ${FILESDIR}/buildui.pl ${WRKSRC}/utils/
do-configure:
@${CP} ${FILESDIR}/Makefile.config ${WRKSRC}
-.if empty(ICONV_LIB)
- @${REINPLACE_CMD} '/NETSURF_USE_LIBICONV_PLUG/ s|NO|YES|' \
- ${WRKSRC}/Makefile.config
-.endif
-
-do-configure-GSTREAMER-on:
- @${REINPLACE_CMD} '/NETSURF_USE_VIDEO/ s|NO|YES|' \
- ${WRKSRC}/Makefile.config
post-install:
cd ${STAGEDIR}${PREFIX}/bin && ${LN} -sf netsurf-gtk3 \
@@ -78,6 +67,16 @@ post-install:
.for d in applications pixmaps
${MKDIR} ${STAGEDIR}${PREFIX}/share/${d}
.endfor
+ ${INSTALL_DATA} ${WRKSRC}/frontends/gtk/res/deoptions.gtk3.ui \
+ ${STAGEDIR}${PREFIX}/share/netsurf
+ ${INSTALL_DATA} ${WRKSRC}/frontends/gtk/res/enoptions.gtk3.ui \
+ ${STAGEDIR}${PREFIX}/share/netsurf
+ ${INSTALL_DATA} ${WRKSRC}/frontends/gtk/res/froptions.gtk3.ui \
+ ${STAGEDIR}${PREFIX}/share/netsurf
+ ${INSTALL_DATA} ${WRKSRC}/frontends/gtk/res/itoptions.gtk3.ui \
+ ${STAGEDIR}${PREFIX}/share/netsurf
+ ${INSTALL_DATA} ${WRKSRC}/frontends/gtk/res/nloptions.gtk3.ui \
+ ${STAGEDIR}${PREFIX}/share/netsurf
${INSTALL_DATA} ${WRKSRC}/frontends/gtk/res/netsurf-gtk.desktop \
${STAGEDIR}${PREFIX}/share/applications
${INSTALL_DATA} ${WRKSRC}/frontends/gtk/res/netsurf.xpm \
diff --git a/www/netsurf/files/Makefile.config b/www/netsurf/files/Makefile.config
index 60c2e1328a0c..cd7852143c08 100644
--- a/www/netsurf/files/Makefile.config
+++ b/www/netsurf/files/Makefile.config
@@ -1,4 +1,4 @@
-NETSURF_USE_LIBICONV_PLUG=NO
+NETSURF_USE_LIBICONV_PLUG=YES
NETSURF_USE_NSSVG=NO
NETSURF_USE_RSVG=YES
NETSURF_USE_VIDEO=NO
diff --git a/www/netsurf/files/buildui.pl b/www/netsurf/files/buildui.pl
new file mode 100644
index 000000000000..17aab0711c6b
--- /dev/null
+++ b/www/netsurf/files/buildui.pl
@@ -0,0 +1,82 @@
+#!
+#
+# Create ui files for each language listed in FatMessages
+
+my $inputfn = $ARGV[0]; # path to FatMessages
+my $templatefn = $ARGV[1]; # path to UI Template
+my $output = $ARGV[2]; # output path
+my $stub = $ARGV[3]; # filename stub. like options.gtk3.ui will become enoptions.gtk3.ui
+
+if (length($stub)<3) {
+ print "invalid stub.\n";
+ exit;
+}
+
+my $template;
+my %langs = {'en'=>1};
+my %trans;
+$trans{'en'}{'foo'}='bar';
+
+open(my $fh, '<', $templatefn) or die "cannot open template file $templatefn";
+{
+ local $/;
+ $template = <$fh>;
+}
+close($fh);
+
+$template =~ s/translatable="yes"/translatable="no"/g;
+
+open(my $input, '<', $inputfn) or die "cannot open FatMessages file $inputfn";
+
+while (<$input>)
+{
+ # skip comment and empty lines
+ /^#/ && next;
+ /^\s*$/ && next;
+
+ # only parsing things that look like message lines:
+ if( /^([a-z]{2}).([^.]+).([^:]+):(.*)/ )
+ {
+ my( $lang, $plat, $key, $val ) = ( $1, $2, $3, $4 );
+ if ($plat == 'gtk')
+ {
+ $val =~ s|<.+?>||g; #remove HTML
+ $langs{$lang}=1;
+ $trans{$lang}{$key}=$val;
+ }
+ }
+
+}
+
+# load up langs hash with copy of the template for each lang
+
+foreach $key (keys %langs)
+{
+ if (length($key)==2)
+ {
+ $langs{$key} = $template
+ }
+}
+
+# iterate through each and key replace with translated text
+
+foreach my $tran (keys %trans)
+{
+ foreach my $key (keys %{$trans{$tran}})
+ {
+ $langs{$tran} =~ s/\>$key\</\>$trans{$tran}{$key}\</g;
+ }
+}
+
+# save the ui file for each language
+
+foreach $key (keys %langs)
+{
+ if (length($key)==2)
+ {
+ open (OFN, '>', $output.'/'.$key.$stub) or die "cannot open output file ".$output.'/'.$key.$stub;
+ print OFN $langs{$key};
+ close (OFN);
+ }
+}
+
diff --git a/www/netsurf/files/patch-Makefile b/www/netsurf/files/patch-Makefile
index 2ce2a9a724f5..e976dd322efd 100644
--- a/www/netsurf/files/patch-Makefile
+++ b/www/netsurf/files/patch-Makefile
@@ -1,6 +1,23 @@
--- Makefile.orig 2020-05-24 20:55:29 UTC
+++ Makefile
-@@ -547,7 +547,6 @@ ifeq ($(HOST),mint)
+@@ -484,16 +484,6 @@ ifneq ($(CC_MAJOR),2)
+ COMMON_WARNFLAGS += -Wno-unused-parameter
+ endif
+
+-# deal with lots of unwanted warnings from javascript
+-ifeq ($(call cc_ver_ge,4,6),1)
+- COMMON_WARNFLAGS += -Wno-unused-but-set-variable
+-endif
+-
+-# Implicit fallthrough warnings suppressed by comment
+-ifeq ($(call cc_ver_ge,7,1),1)
+- COMMON_WARNFLAGS += -Wimplicit-fallthrough=3
+-endif
+-
+ # deal with chaging warning flags for different platforms
+ ifeq ($(HOST),OpenBSD)
+ # OpenBSD headers are not compatible with redundant declaration warning
+@@ -547,7 +537,6 @@ ifeq ($(HOST),mint)
else
$(eval $(call pkg_config_find_and_add_enabled,CURL,libcurl,Curl))
endif
@@ -8,3 +25,34 @@
$(eval $(call pkg_config_find_and_add_enabled,UTF8PROC,libutf8proc,utf8))
$(eval $(call pkg_config_find_and_add_enabled,WEBP,libwebp,WEBP))
+@@ -680,14 +669,21 @@ $$(MESSAGES_TARGET)/$(1)/Messages: resources/FatMessag
+ $$(Q)$$(SPLIT_MESSAGES) -l $(1) -p $$(MESSAGES_FILTER) -f messages -o $$@ -z $$<
+
+ CLEAN_MESSAGES += $$(MESSAGES_TARGET)/$(1)/Messages
++CLEAN_MESSAGES += $$(MESSAGES_TARGET)/$(1)options.gtk3.ui
+ MESSAGES += $$(MESSAGES_TARGET)/$(1)/Messages
+
+ endef
+
++buildui:
++ @echo "BUILDUI: options ui for each language in resources/FatMessages"
++ @$(PERL) utils/buildui.pl resources/FatMessages frontends/gtk/res/options.gtk3.ui $(MESSAGES_TARGET) options.gtk3.ui
++
+ # generate the message file rules
+ $(eval $(foreach LANG,$(MESSAGES_LANGUAGES), \
+ $(call split_messages,$(LANG))))
+
++MESSAGES += buildui
++
+ clean-messages:
+ $(VQ)echo " CLEAN: $(CLEAN_MESSAGES)"
+ $(Q)$(RM) $(CLEAN_MESSAGES)
+@@ -710,7 +706,7 @@ OBJECTS := $(sort $(addprefix $(OBJROOT)/,$(subst /,_,
+ # Include directory flags
+ IFLAGS = $(addprefix -I,$(INCLUDE_DIRS))
+
+-$(EXETARGET): $(OBJECTS) $(RESOURCES) $(MESSAGES)
++$(EXETARGET): $(OBJECTS) $(RESOURCES) $(MESSAGES)
+ $(VQ)echo " LINK: $(EXETARGET)"
+ ifneq ($(TARGET)$(SUBTARGET),riscos-elf)
+ $(Q)$(CC) -o $(EXETARGET) $(OBJECTS) $(LDFLAGS)
diff --git a/www/netsurf/files/patch-frontends_gtk_Makefile.defaults b/www/netsurf/files/patch-frontends_gtk_Makefile.defaults
index 0db9fd17a985..0b7f7cacbeae 100644
--- a/www/netsurf/files/patch-frontends_gtk_Makefile.defaults
+++ b/www/netsurf/files/patch-frontends_gtk_Makefile.defaults
@@ -1,4 +1,4 @@
---- frontends/gtk/Makefile.defaults.orig 2016-11-19 13:37:41 UTC
+--- frontends/gtk/Makefile.defaults.orig 2020-05-24 20:55:29 UTC
+++ frontends/gtk/Makefile.defaults
@@ -4,7 +4,7 @@
@@ -9,3 +9,9 @@
# Where to install the netsurf binary
NETSURF_GTK_BIN := $(PREFIX)/bin/
+@@ -39,4 +39,4 @@ NETSURF_FS_BACKING_STORE := YES
+ NETSURF_GTK_MAJOR ?= 2
+
+ # Optimisation levels
+-CFLAGS += -O2
++CFLAGS +=
diff --git a/www/netsurf/files/patch-frontends_gtk_preferences.c b/www/netsurf/files/patch-frontends_gtk_preferences.c
new file mode 100644
index 000000000000..337e1bf73f03
--- /dev/null
+++ b/www/netsurf/files/patch-frontends_gtk_preferences.c
@@ -0,0 +1,33 @@
+--- frontends/gtk/preferences.c.orig 2021-04-01 17:51:28 UTC
++++ frontends/gtk/preferences.c
+@@ -962,11 +962,26 @@ GtkWidget* nsgtk_preferences(struct browser_window *bw
+ return GTK_WIDGET(priv->dialog);
+ }
+
+- res = nsgtk_builder_new_from_resname("options", &preferences_builder);
+- if (res != NSERROR_OK) {
+- NSLOG(netsurf, INFO, "Preferences UI builder init failed");
+- return NULL;
++ const char *client_lang;
++ char ui_lang[10] = "en";
++ client_lang = getenv("LANG");
++
++ if (strlen(client_lang)>1)
++ {
++ strncpy(ui_lang,client_lang,2);
+ }
++
++ strcat(ui_lang,"options");
++
++ res = nsgtk_builder_new_from_resname(ui_lang, &preferences_builder);
++ if (res != NSERROR_OK) {
++ //LANG not found, so fall back to english i guess
++ res = nsgtk_builder_new_from_resname("enoption", &preferences_builder);
++ }
++ if (res != NSERROR_OK) {
++ NSLOG(netsurf, INFO, "Preferences UI builder init failed");
++ return NULL;
++ }
+
+ priv->dialog = gtk_builder_get_object(preferences_builder,
+ "dialogPreferences");
diff --git a/www/netsurf/files/patch-frontends_gtk_resources.c b/www/netsurf/files/patch-frontends_gtk_resources.c
new file mode 100644
index 000000000000..dc812f85081a
--- /dev/null
+++ b/www/netsurf/files/patch-frontends_gtk_resources.c
@@ -0,0 +1,22 @@
+--- frontends/gtk/resources.c.orig 2021-04-01 19:00:43 UTC
++++ frontends/gtk/resources.c
+@@ -82,6 +82,11 @@ static struct nsgtk_resource_s ui_resource[] = {
+ RES_ENTRY("globalhistory"),
+ RES_ENTRY("localhistory"),
+ RES_ENTRY("options"),
++ RES_ENTRY("deoptions"),
++ RES_ENTRY("enoptions"),
++ RES_ENTRY("froptions"),
++ RES_ENTRY("itoptions"),
++ RES_ENTRY("nloptions"),
+ RES_ENTRY("hotlist"),
+ RES_ENTRY("cookies"),
+ RES_ENTRY("viewdata"),
+@@ -552,6 +557,7 @@ nsgtk_builder_new_from_resname(const char *resname, Gt
+ error->message);
+ g_error_free(error);
+ g_object_unref(G_OBJECT(new_builder));
++
+ return NSERROR_INIT_FAILED;
+ }
+ } else {
diff --git a/www/netsurf/pkg-plist b/www/netsurf/pkg-plist
index 5b73aae723c5..53d10f0688f5 100644
--- a/www/netsurf/pkg-plist
+++ b/www/netsurf/pkg-plist
@@ -47,6 +47,11 @@ share/applications/netsurf-gtk.desktop
%%DATADIR%%/nl/licence.html
%%DATADIR%%/nl/welcome.html
%%DATADIR%%/options.gtk3.ui
+%%DATADIR%%/deoptions.gtk3.ui
+%%DATADIR%%/enoptions.gtk3.ui
+%%DATADIR%%/froptions.gtk3.ui
+%%DATADIR%%/itoptions.gtk3.ui
+%%DATADIR%%/nloptions.gtk3.ui
%%DATADIR%%/pageinfo.gtk3.ui
%%DATADIR%%/password.gtk3.ui
%%DATADIR%%/quirks.css
More information about the dev-commits-ports-all
mailing list