diff --git a/ChangeLog b/ChangeLog index c6a0ad4..c8edbf9 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,6 +1,13 @@ E-MailRelay Change Log ====================== +2.2 -> 2.2.1 +------------ +* Unix domain sockets supported (eg. "--interface=/tmp/smtp.s"). +* Windows event log not used for verbose logging (prefer "--log-file"). +* New admin 'forward' command to trigger forwarding without waiting. +* Support for MbedTLS version 3. + 2.1 -> 2.2 ---------- * Connections from IPv4 'private use' addresses are allowed by default (see "--remote-clients"). @@ -24,7 +31,7 @@ E-MailRelay Change Log * New "--idle-timeout" option for server-side connections. * Support for RFC-5782 DNSBL blocking ("--dnsbl"). * Filter scripts are given the path of the envelope file in argv2. -* Message files can be editied by "--client-filter" scripts. +* Message files can be edited by "--client-filter" scripts. * Better support for CRAM-SHAx authentication. * New "--client-auth-config" and "--server-auth-config" options. * New "--show" option on windows to better control the user interface style. diff --git a/Makefile.in b/Makefile.in index db9ce43..54124f9 100644 --- a/Makefile.in +++ b/Makefile.in @@ -1,7 +1,7 @@ -# Makefile.in generated by automake 1.15 from Makefile.am. +# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ -# Copyright (C) 1994-2014 Free Software Foundation, Inc. +# Copyright (C) 1994-2018 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -134,7 +134,7 @@ DIST_COMMON = $(srcdir)/Makefile.am $(top_srcdir)/configure \ am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \ configure.lineno config.status.lineno mkinstalldirs = $(install_sh) -d -CONFIG_HEADER = gconfig_defs.h +CONFIG_HEADER = $(top_builddir)/src/gconfig_defs.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) @@ -200,9 +200,8 @@ am__recursive_targets = \ $(RECURSIVE_CLEAN_TARGETS) \ $(am__extra_recursive_targets) AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ - cscope distdir dist dist-all distcheck -am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) \ - $(LISP)gconfig_defs.h.in + cscope distdir distdir-am dist dist-all distcheck +am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. @@ -223,9 +222,8 @@ ETAGS = etags CTAGS = ctags CSCOPE = cscope DIST_SUBDIRS = $(SUBDIRS) -am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/gconfig_defs.h.in \ - AUTHORS COPYING ChangeLog INSTALL NEWS README compile \ - install-sh missing +am__DIST_COMMON = $(srcdir)/Makefile.in AUTHORS COPYING ChangeLog \ + INSTALL NEWS README compile depcomp install-sh missing DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) distdir = $(PACKAGE)-$(VERSION) top_distdir = $(distdir) @@ -330,6 +328,7 @@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ QT_CFLAGS = @QT_CFLAGS@ QT_LIBS = @QT_LIBS@ +QT_LRELEASE = @QT_LRELEASE@ QT_MOC = @QT_MOC@ RANLIB = @RANLIB@ SED = @SED@ @@ -366,6 +365,7 @@ e_rundir = @e_rundir@ e_spooldir = @e_spooldir@ e_sysconfdir = @e_sysconfdir@ e_systemddir = @e_systemddir@ +e_trdir = @e_trdir@ exec_prefix = @exec_prefix@ host_alias = @host_alias@ htmldir = @htmldir@ @@ -414,8 +414,7 @@ e_doc_DATA = COPYING AUTHORS INSTALL NEWS README ChangeLog RPM = $(RPM_ROOT)/RPMS/$(ARCH)/emailrelay-$(VERSION)-1.$(ARCH).rpm TAR = emailrelay-$(VERSION).tar.gz DEB = emailrelay_$(VERSION)_$(ARCH).deb -all: gconfig_defs.h - $(MAKE) $(AM_MAKEFLAGS) all-recursive +all: all-recursive .SUFFIXES: am--refresh: Makefile @@ -439,8 +438,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status echo ' $(SHELL) ./config.status'; \ $(SHELL) ./config.status;; \ *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \ + echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles)'; \ + cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) @@ -451,21 +450,6 @@ $(top_srcdir)/configure: @MAINTAINER_MODE_TRUE@ $(am__configure_deps) $(ACLOCAL_M4): @MAINTAINER_MODE_TRUE@ $(am__aclocal_m4_deps) $(am__cd) $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS) $(am__aclocal_m4_deps): - -gconfig_defs.h: stamp-h1 - @test -f $@ || rm -f stamp-h1 - @test -f $@ || $(MAKE) $(AM_MAKEFLAGS) stamp-h1 - -stamp-h1: $(srcdir)/gconfig_defs.h.in $(top_builddir)/config.status - @rm -f stamp-h1 - cd $(top_builddir) && $(SHELL) ./config.status gconfig_defs.h -$(srcdir)/gconfig_defs.h.in: @MAINTAINER_MODE_TRUE@ $(am__configure_deps) - ($(am__cd) $(top_srcdir) && $(AUTOHEADER)) - rm -f stamp-h1 - touch $@ - -distclean-hdr: - -rm -f gconfig_defs.h stamp-h1 install-e_docDATA: $(e_doc_DATA) @$(NORMAL_INSTALL) @list='$(e_doc_DATA)'; test -n "$(e_docdir)" || list=; \ @@ -594,7 +578,10 @@ distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags -rm -f cscope.out cscope.in.out cscope.po.out cscope.files -distdir: $(DISTFILES) +distdir: $(BUILT_SOURCES) + $(MAKE) $(AM_MAKEFLAGS) distdir-am + +distdir-am: $(DISTFILES) $(am__remove_distdir) test -d "$(distdir)" || mkdir "$(distdir)" @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ @@ -659,7 +646,7 @@ distdir: $(DISTFILES) ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \ || chmod -R a+r "$(distdir)" dist-gzip: distdir - tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz + tardir=$(distdir) && $(am__tar) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).tar.gz $(am__post_remove_distdir) dist-bzip2: distdir @@ -685,7 +672,7 @@ dist-shar: distdir @echo WARNING: "Support for shar distribution archives is" \ "deprecated." >&2 @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 - shar $(distdir) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).shar.gz + shar $(distdir) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).shar.gz $(am__post_remove_distdir) dist-zip: distdir @@ -703,7 +690,7 @@ dist dist-all: distcheck: dist case '$(DIST_ARCHIVES)' in \ *.tar.gz*) \ - GZIP=$(GZIP_ENV) gzip -dc $(distdir).tar.gz | $(am__untar) ;;\ + eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).tar.gz | $(am__untar) ;;\ *.tar.bz2*) \ bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\ *.tar.lz*) \ @@ -713,7 +700,7 @@ distcheck: dist *.tar.Z*) \ uncompress -c $(distdir).tar.Z | $(am__untar) ;;\ *.shar.gz*) \ - GZIP=$(GZIP_ENV) gzip -dc $(distdir).shar.gz | unshar ;;\ + eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).shar.gz | unshar ;;\ *.zip*) \ unzip $(distdir).zip ;;\ esac @@ -784,7 +771,7 @@ distcleancheck: distclean exit 1; } >&2 check-am: all-am check: check-recursive -all-am: Makefile $(DATA) gconfig_defs.h +all-am: Makefile $(DATA) installdirs: installdirs-recursive installdirs-am: for dir in "$(DESTDIR)$(e_docdir)"; do \ @@ -827,7 +814,7 @@ clean-am: clean-generic mostlyclean-am distclean: distclean-recursive -rm -f $(am__CONFIG_DISTCLEAN_FILES) -rm -f Makefile -distclean-am: clean-am distclean-generic distclean-hdr distclean-tags +distclean-am: clean-am distclean-generic distclean-tags dvi: dvi-recursive @@ -889,24 +876,23 @@ ps-am: uninstall-am: uninstall-e_docDATA uninstall-local -.MAKE: $(am__recursive_targets) all install-am install-strip +.MAKE: $(am__recursive_targets) install-am install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am \ am--refresh check check-am clean clean-cscope clean-generic \ cscope cscopelist-am ctags ctags-am dist dist-all dist-bzip2 \ dist-gzip dist-lzip dist-shar dist-tarZ dist-xz dist-zip \ - distcheck distclean distclean-generic distclean-hdr \ - distclean-tags distcleancheck distdir distuninstallcheck dvi \ - dvi-am html html-am info info-am install install-am \ - install-data install-data-am install-dvi install-dvi-am \ - install-e_docDATA install-exec install-exec-am install-html \ - install-html-am install-info install-info-am install-man \ - install-pdf install-pdf-am install-ps install-ps-am \ - install-strip installcheck installcheck-am installdirs \ - installdirs-am maintainer-clean maintainer-clean-generic \ - mostlyclean mostlyclean-generic pdf pdf-am ps ps-am tags \ - tags-am uninstall uninstall-am uninstall-e_docDATA \ - uninstall-local + distcheck distclean distclean-generic distclean-tags \ + distcleancheck distdir distuninstallcheck dvi dvi-am html \ + html-am info info-am install install-am install-data \ + install-data-am install-dvi install-dvi-am install-e_docDATA \ + install-exec install-exec-am install-html install-html-am \ + install-info install-info-am install-man install-pdf \ + install-pdf-am install-ps install-ps-am install-strip \ + installcheck installcheck-am installdirs installdirs-am \ + maintainer-clean maintainer-clean-generic mostlyclean \ + mostlyclean-generic pdf pdf-am ps ps-am tags tags-am uninstall \ + uninstall-am uninstall-e_docDATA uninstall-local .PRECIOUS: Makefile diff --git a/NEWS b/NEWS index 08ca19a..3cd8551 100644 --- a/NEWS +++ b/NEWS @@ -22,3 +22,7 @@ as an "examples" file. Use "e_systemddir=/usr/lib/systemd/system" on the This release has a new "make tidy" option that runs "clang-tidy" over the code and also "make cmake" to generate simple cmake files for a unix build. + +Version 2.2.1 adds support for unix-domain sockets. + +Thanks to Per-Arne Christensen for the Norwegian translation of the GUI. diff --git a/VERSION b/VERSION index 8bbe6cf..c043eea 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -2.2 +2.2.1 diff --git a/aclocal.m4 b/aclocal.m4 index a99cd41..7050dbb 100644 --- a/aclocal.m4 +++ b/aclocal.m4 @@ -1,6 +1,6 @@ -# generated automatically by aclocal 1.15 -*- Autoconf -*- +# generated automatically by aclocal 1.16.1 -*- Autoconf -*- -# Copyright (C) 1996-2014 Free Software Foundation, Inc. +# Copyright (C) 1996-2018 Free Software Foundation, Inc. # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -20,7 +20,7 @@ You have another version of autoconf. It may work, but is not guaranteed to. If you have problems, you may need to regenerate the build system entirely. To do so, use the procedure documented by the package, typically 'autoreconf'.])]) -# Copyright (C) 2002-2014 Free Software Foundation, Inc. +# Copyright (C) 2002-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -32,10 +32,10 @@ To do so, use the procedure documented by the package, typically 'autoreconf'.]) # generated from the m4 files accompanying Automake X.Y. # (This private macro should not be called outside this file.) AC_DEFUN([AM_AUTOMAKE_VERSION], -[am__api_version='1.15' +[am__api_version='1.16' dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to dnl require some minimum version. Point them to the right macro. -m4_if([$1], [1.15], [], +m4_if([$1], [1.16.1], [], [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl ]) @@ -51,14 +51,14 @@ m4_define([_AM_AUTOCONF_VERSION], []) # Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced. # This function is AC_REQUIREd by AM_INIT_AUTOMAKE. AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], -[AM_AUTOMAKE_VERSION([1.15])dnl +[AM_AUTOMAKE_VERSION([1.16.1])dnl m4_ifndef([AC_AUTOCONF_VERSION], [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl _AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))]) # AM_AUX_DIR_EXPAND -*- Autoconf -*- -# Copyright (C) 2001-2014 Free Software Foundation, Inc. +# Copyright (C) 2001-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -110,7 +110,7 @@ am_aux_dir=`cd "$ac_aux_dir" && pwd` # AM_CONDITIONAL -*- Autoconf -*- -# Copyright (C) 1997-2014 Free Software Foundation, Inc. +# Copyright (C) 1997-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -141,7 +141,7 @@ AC_CONFIG_COMMANDS_PRE( Usually this means the macro was only invoked conditionally.]]) fi])]) -# Copyright (C) 1999-2014 Free Software Foundation, Inc. +# Copyright (C) 1999-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -332,13 +332,12 @@ _AM_SUBST_NOTMAKE([am__nodep])dnl # Generate code to set up dependency tracking. -*- Autoconf -*- -# Copyright (C) 1999-2014 Free Software Foundation, Inc. +# Copyright (C) 1999-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. - # _AM_OUTPUT_DEPENDENCY_COMMANDS # ------------------------------ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], @@ -346,49 +345,41 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], # Older Autoconf quotes --file arguments for eval, but not when files # are listed without --file. Let's play safe and only enable the eval # if we detect the quoting. - case $CONFIG_FILES in - *\'*) eval set x "$CONFIG_FILES" ;; - *) set x $CONFIG_FILES ;; - esac + # TODO: see whether this extra hack can be removed once we start + # requiring Autoconf 2.70 or later. + AS_CASE([$CONFIG_FILES], + [*\'*], [eval set x "$CONFIG_FILES"], + [*], [set x $CONFIG_FILES]) shift - for mf + # Used to flag and report bootstrapping failures. + am_rc=0 + for am_mf do # Strip MF so we end up with the name of the file. - mf=`echo "$mf" | sed -e 's/:.*$//'` - # Check whether this is an Automake generated Makefile or not. - # We used to match only the files named 'Makefile.in', but - # some people rename them; so instead we look at the file content. - # Grep'ing the first line is not enough: some people post-process - # each Makefile.in and add a new line on top of each file to say so. - # Grep'ing the whole file is not good either: AIX grep has a line + am_mf=`AS_ECHO(["$am_mf"]) | sed -e 's/:.*$//'` + # Check whether this is an Automake generated Makefile which includes + # dependency-tracking related rules and includes. + # Grep'ing the whole file directly is not great: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. - if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then - dirpart=`AS_DIRNAME("$mf")` - else - continue - fi - # Extract the definition of DEPDIR, am__include, and am__quote - # from the Makefile without running 'make'. - DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` - test -z "$DEPDIR" && continue - am__include=`sed -n 's/^am__include = //p' < "$mf"` - test -z "$am__include" && continue - am__quote=`sed -n 's/^am__quote = //p' < "$mf"` - # Find all dependency output files, they are included files with - # $(DEPDIR) in their names. We invoke sed twice because it is the - # simplest approach to changing $(DEPDIR) to its actual value in the - # expansion. - for file in `sed -n " - s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ - sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do - # Make sure the directory exists. - test -f "$dirpart/$file" && continue - fdir=`AS_DIRNAME(["$file"])` - AS_MKDIR_P([$dirpart/$fdir]) - # echo "creating $dirpart/$file" - echo '# dummy' > "$dirpart/$file" - done + sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \ + || continue + am_dirpart=`AS_DIRNAME(["$am_mf"])` + am_filepart=`AS_BASENAME(["$am_mf"])` + AM_RUN_LOG([cd "$am_dirpart" \ + && sed -e '/# am--include-marker/d' "$am_filepart" \ + | $MAKE -f - am--depfiles]) || am_rc=$? done + if test $am_rc -ne 0; then + AC_MSG_FAILURE([Something went wrong bootstrapping makefile fragments + for automatic dependency tracking. Try re-running configure with the + '--disable-dependency-tracking' option to at least be able to build + the package (albeit without support for automatic dependency tracking).]) + fi + AS_UNSET([am_dirpart]) + AS_UNSET([am_filepart]) + AS_UNSET([am_mf]) + AS_UNSET([am_rc]) + rm -f conftest-deps.mk } ])# _AM_OUTPUT_DEPENDENCY_COMMANDS @@ -397,18 +388,17 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], # ----------------------------- # This macro should only be invoked once -- use via AC_REQUIRE. # -# This code is only required when automatic dependency tracking -# is enabled. FIXME. This creates each '.P' file that we will -# need in order to bootstrap the dependency handling code. +# This code is only required when automatic dependency tracking is enabled. +# This creates each '.Po' and '.Plo' makefile fragment that we'll need in +# order to bootstrap the dependency handling code. AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS], [AC_CONFIG_COMMANDS([depfiles], [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS], - [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"]) -]) + [AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"])]) # Do all the work for Automake. -*- Autoconf -*- -# Copyright (C) 1996-2014 Free Software Foundation, Inc. +# Copyright (C) 1996-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -495,8 +485,8 @@ AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl AC_REQUIRE([AC_PROG_MKDIR_P])dnl # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: -# -# +# +# AC_SUBST([mkdir_p], ['$(MKDIR_P)']) # We need awk for the "check" target (and possibly the TAP driver). The # system "awk" is bad on some platforms. @@ -563,7 +553,7 @@ END Aborting the configuration process, to ensure you take notice of the issue. You can download and install GNU coreutils to get an 'rm' implementation -that behaves properly: . +that behaves properly: . If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM @@ -605,7 +595,7 @@ for _am_header in $config_headers :; do done echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count]) -# Copyright (C) 2001-2014 Free Software Foundation, Inc. +# Copyright (C) 2001-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -626,7 +616,7 @@ if test x"${install_sh+set}" != xset; then fi AC_SUBST([install_sh])]) -# Copyright (C) 2003-2014 Free Software Foundation, Inc. +# Copyright (C) 2003-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -648,7 +638,7 @@ AC_SUBST([am__leading_dot])]) # Add --enable-maintainer-mode option to configure. -*- Autoconf -*- # From Jim Meyering -# Copyright (C) 1996-2014 Free Software Foundation, Inc. +# Copyright (C) 1996-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -683,7 +673,7 @@ AC_MSG_CHECKING([whether to enable maintainer-specific portions of Makefiles]) # Check to see how 'make' treats includes. -*- Autoconf -*- -# Copyright (C) 2001-2014 Free Software Foundation, Inc. +# Copyright (C) 2001-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -691,49 +681,42 @@ AC_MSG_CHECKING([whether to enable maintainer-specific portions of Makefiles]) # AM_MAKE_INCLUDE() # ----------------- -# Check to see how make treats includes. +# Check whether make has an 'include' directive that can support all +# the idioms we need for our automatic dependency tracking code. AC_DEFUN([AM_MAKE_INCLUDE], -[am_make=${MAKE-make} -cat > confinc << 'END' +[AC_MSG_CHECKING([whether ${MAKE-make} supports the include directive]) +cat > confinc.mk << 'END' am__doit: - @echo this is the am__doit target + @echo this is the am__doit target >confinc.out .PHONY: am__doit END -# If we don't find an include directive, just comment out the code. -AC_MSG_CHECKING([for style of include used by $am_make]) am__include="#" am__quote= -_am_result=none -# First try GNU make style include. -echo "include confinc" > confmf -# Ignore all kinds of additional output from 'make'. -case `$am_make -s -f confmf 2> /dev/null` in #( -*the\ am__doit\ target*) - am__include=include - am__quote= - _am_result=GNU - ;; -esac -# Now try BSD make style include. -if test "$am__include" = "#"; then - echo '.include "confinc"' > confmf - case `$am_make -s -f confmf 2> /dev/null` in #( - *the\ am__doit\ target*) - am__include=.include - am__quote="\"" - _am_result=BSD - ;; - esac -fi -AC_SUBST([am__include]) -AC_SUBST([am__quote]) -AC_MSG_RESULT([$_am_result]) -rm -f confinc confmf -]) +# BSD make does it like this. +echo '.include "confinc.mk" # ignored' > confmf.BSD +# Other make implementations (GNU, Solaris 10, AIX) do it like this. +echo 'include confinc.mk # ignored' > confmf.GNU +_am_result=no +for s in GNU BSD; do + AM_RUN_LOG([${MAKE-make} -f confmf.$s && cat confinc.out]) + AS_CASE([$?:`cat confinc.out 2>/dev/null`], + ['0:this is the am__doit target'], + [AS_CASE([$s], + [BSD], [am__include='.include' am__quote='"'], + [am__include='include' am__quote=''])]) + if test "$am__include" != "#"; then + _am_result="yes ($s style)" + break + fi +done +rm -f confinc.* confmf.* +AC_MSG_RESULT([${_am_result}]) +AC_SUBST([am__include])]) +AC_SUBST([am__quote])]) # Fake the existence of programs that GNU maintainers use. -*- Autoconf -*- -# Copyright (C) 1997-2014 Free Software Foundation, Inc. +# Copyright (C) 1997-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -772,7 +755,7 @@ fi # Helper functions for option handling. -*- Autoconf -*- -# Copyright (C) 2001-2014 Free Software Foundation, Inc. +# Copyright (C) 2001-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -801,7 +784,7 @@ AC_DEFUN([_AM_SET_OPTIONS], AC_DEFUN([_AM_IF_OPTION], [m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) -# Copyright (C) 1999-2014 Free Software Foundation, Inc. +# Copyright (C) 1999-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -848,7 +831,7 @@ AC_LANG_POP([C])]) # For backward compatibility. AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])]) -# Copyright (C) 2001-2014 Free Software Foundation, Inc. +# Copyright (C) 2001-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -867,7 +850,7 @@ AC_DEFUN([AM_RUN_LOG], # Check to make sure that the build environment is sane. -*- Autoconf -*- -# Copyright (C) 1996-2014 Free Software Foundation, Inc. +# Copyright (C) 1996-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -948,7 +931,7 @@ AC_CONFIG_COMMANDS_PRE( rm -f conftest.file ]) -# Copyright (C) 2009-2014 Free Software Foundation, Inc. +# Copyright (C) 2009-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -1008,7 +991,7 @@ AC_SUBST([AM_BACKSLASH])dnl _AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl ]) -# Copyright (C) 2001-2014 Free Software Foundation, Inc. +# Copyright (C) 2001-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -1036,7 +1019,7 @@ fi INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" AC_SUBST([INSTALL_STRIP_PROGRAM])]) -# Copyright (C) 2006-2014 Free Software Foundation, Inc. +# Copyright (C) 2006-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -1055,7 +1038,7 @@ AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)]) # Check how to create a tarball. -*- Autoconf -*- -# Copyright (C) 2004-2014 Free Software Foundation, Inc. +# Copyright (C) 2004-2018 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, diff --git a/autogen.sh b/autogen.sh old mode 100755 new mode 100644 diff --git a/bin/AutoMakeParser.pm b/bin/AutoMakeParser.pm index e19f3aa..15fc9dc 100644 --- a/bin/AutoMakeParser.pm +++ b/bin/AutoMakeParser.pm @@ -35,6 +35,7 @@ # $makefile->libraries() ; # $makefile->includes() ; # $makefile->definitions() ; +# $makefile->compile_options() ; # $makefile->sources('foo') ; # $makefile->our_libs('foo') ; # $makefile->sys_libs('foo') ; @@ -51,19 +52,20 @@ our $debug = 0 ; sub new { - my ( $classname , $path , $switches , $ro_vars ) = @_ ; + my ( $classname , $path , $switches , $vars_in ) = @_ ; my %me = ( m_path => simplepath($path) , + m_switches => $switches , + m_vars => {} , m_depth => undef , # from readall() m_lines => [] , - m_vars => {} , - m_switches => $switches , m_stack => [] , ) ; my $this = bless \%me , $classname ; $this->read( $path ) ; $this->parse( $path ) ; - $this->expand_all( $ro_vars ) ; + $this->expand_all( $vars_in ) ; + $this->copy( $vars_in ) ; return $this ; } @@ -74,22 +76,23 @@ sub path sub readall { - my ( $base_dir , $switches , $vars , $verbose ) = @_ ; + my ( $base_dir , $switches , $vars , $verbose , $verbose_prefix ) = @_ ; my @makefiles = () ; - _readall_imp( \@makefiles , 0 , $base_dir , $switches , $vars , $verbose ) ; # recursive + _readall_imp( \@makefiles , 0 , $base_dir , $switches , $vars , $verbose , $verbose_prefix ) ; # recursive return @makefiles ; } sub _readall_imp { - my ( $makefiles , $depth , $dir , $switches , $vars , $verbose ) = @_ ; + my ( $makefiles , $depth , $dir , $switches , $vars , $verbose , $verbose_prefix ) = @_ ; + $verbose_prefix ||= "" ; my $m = new AutoMakeParser( "$dir/Makefile.am" , $switches , $vars ) ; $m->{m_depth} = $depth ; - print "makefile=[" , $m->path() , "] ($depth)\n" if $verbose ; + print "${verbose_prefix}makefile=[" , $m->path() , "] ($depth)\n" if $verbose ; push @$makefiles , $m ; for my $subdir ( $m->value("SUBDIRS") ) { - _readall_imp( $makefiles , $depth+1 , "$dir/$subdir" , $switches , $vars , $verbose ) ; + _readall_imp( $makefiles , $depth+1 , "$dir/$subdir" , $switches , $vars , $verbose , $verbose_prefix ) ; } } @@ -159,10 +162,15 @@ sub sys_libs { my ( $this , $program ) = @_ ; ( my $prefix = $program ) =~ s/[-.]/_/g ; - return + my @a = + map { s/-l// ; $_ } + grep { m/^-l/ } + $this->value( "LIBS" ) ; + my @b = map { s/-l// ; $_ } grep { m/^-l/ } $this->value( "${prefix}_LDADD" ) ; + return ( @a , @b ) ; } sub sources @@ -174,11 +182,51 @@ sub sources $this->value( "${prefix}_SOURCES" ) ; } +sub link_options +{ + my ( $this ) = @_ ; + my @a = $this->value( "AM_LDFLAGS" ) ; + my @b = $this->value( "LDFLAGS" ) ; + my @options = ( @a , @b ) ; + return wantarray ? @options : join(" ",@options) ; +} + +sub compile_options +{ + my ( $this ) = @_ ; + my @a = $this->_compile_options_imp( "AM_CPPFLAGS" , $this->{m_vars} ) ; + my @b = $this->_compile_options_imp( "CXXFLAGS" , $this->{m_vars} ) ; + my @options = ( @a , @b ) ; + return wantarray ? @options : join(" ",@options) ; +} + +sub _compile_options_imp +{ + my ( $this , $var , $vars ) = @_ ; + $vars ||= $this->{m_vars} ; + my $s = protect_quoted_spaces( simple_spaces( $vars->{$var} ) ) ; + $s =~ s/-D /-D/g ; + $s =~ s/-I /-I/g ; + return + map { s/\t/ /g ; $_ } + grep { !m/-I/ } + grep { !m/-D/ } + split( " " , $s ) ; +} + sub definitions { - my ( $this , $am_cppflags ) = @_ ; - $am_cppflags ||= "AM_CPPFLAGS" ; - my $s = protect_quoted_spaces( simple_spaces( $this->{m_vars}->{$am_cppflags} ) ) ; + my ( $this ) = @_ ; + my @a = $this->_definitions_imp( "AM_CPPFLAGS" , $this->{m_vars} ) ; + my @b = $this->_definitions_imp( "CXXFLAGS" , $this->{m_vars} ) ; + my @defs = ( @a , @b ) ; + return wantarray ? @defs : join(" ",@defs) ; +} + +sub _definitions_imp +{ + my ( $this , $var , $vars ) = @_ ; + my $s = protect_quoted_spaces( simple_spaces( $vars->{$var} ) ) ; $s =~ s/-D /-D/g ; return map { s/\t/ /g ; $_ } @@ -194,29 +242,41 @@ sub includes # with the 'top_srcdir' variable defined as "." gives # ("./one/two","./three"). # - # However, since the 'top_srcdir' expansion is fixed, and the + # However, since the 'top_srcdir' expansion is fixed, and # relative include paths need to vary through the source - # tree, a prefix parameter ('top') can be passed in here. - # So then "-I$(top_srcdir)/one/two" becomes "/./one/two". + # tree, a prefix parameter ('top') should be passed in as + # the current value for expanding "$(top_srcdir)". So then + # "-I$(top_srcdir)/one/two" becomes "/./one/two". + # (Absolute paths do not get the 'top' prefixed by 'top'.) # - # The 'top' parameter can be from top() as long as readall() - # started at the 'top_srcdir' directory and the 'top_srcdir' - # variable is defined as ".". Otherwise, a simple approach - # is to still use top() for the 'top' parameter but define - # the 'top_srcdir' variable as the difference between the - # readall() base and the actual 'top_srcdir' directory. + # The "top()" method provides a candidate for the 'top' + # parameter but will only work if readall() started at the + # 'top_srcdir' directory and the 'top_srcdir' variable is + # defined as ".". Otherwise, a simple approach is to still + # use top() for the 'top' parameter but define the 'top_srcdir' + # variable as the difference between the readall() base and + # the actual 'top_srcdir' directory. # - my ( $this , $top , $am_cppflags , $extra_includes , $full_paths ) = @_ ; + my ( $this , $top , $full_paths , $no_top_dir ) = @_ ; $top ||= "" ; - $am_cppflags ||= "AM_CPPFLAGS" ; - $extra_includes ||= "" ; - my $cppflags = join( " " , $extra_includes , $this->{m_vars}->{$am_cppflags} ) ; - my $s = protect_quoted_spaces( simple_spaces( $cppflags ) ) ; + my $add_top = !$no_top_dir ; + my $real_top = simplepath( join( "/" , $this->value("top_srcdir") , $top ) ) ; + my @a = $this->_includes_imp( $top , "AM_CPPFLAGS" , $this->{m_vars} , $full_paths ) ; + my @b = $this->_includes_imp( $top , "CXXFLAGS" , $this->{m_vars} , $full_paths ) ; + my @c = ( $real_top && $add_top ) ? ( $real_top ) : () ; + my @incs = ( @c , @a , @b ) ; + return wantarray ? @incs : join(" ",@incs) ; +} + +sub _includes_imp +{ + my ( $this , $top , $var , $vars , $full_paths ) = @_ ; + my $s = protect_quoted_spaces( simple_spaces( $vars->{$var} ) ) ; $s =~ s/-I /-I/g ; return map { $full_paths?$this->fullpath($_):$_ } map { simplepath($_) } - map { $top?join("/",$top,$_):$_ } + map { my $p=$_ ; ($top&&($p!~m;^/;))?join("/",$top,$p):$p } map { s/\t/ /g ; $_ } map { s:-I:: ; $_ } grep { m/-I\S+/ } split( " " , $s ) ; @@ -319,6 +379,19 @@ sub add push @{$this->{m_lines}} , $line ; } +sub copy +{ + my ( $this , $vars_in ) = @_ ; + return if !defined($vars_in) ; + for my $k ( keys %$vars_in ) + { + if( !exists($this->{m_vars}->{$k}) ) + { + $this->{m_vars}->{$k} = $vars_in->{$k} ; + } + } +} + sub read { my ( $this , $path ) = @_ ; @@ -357,7 +430,7 @@ sub parse last ; # (new) } } - debug_( "$$this{m_path}($n): " , $this->enabled() ? $line : "..." ) ; + debug_( "$$this{m_path}($n): " , $line ) if ( $this->enabled() && ( $line =~ m/\S/ ) && ( $line !~ m/^#/ ) ) ; } for my $k ( sort keys %{$this->{m_vars}} ) { @@ -469,7 +542,9 @@ sub do_assign_more sub debug_ { - print @_ , "\n" if $debug ; + my $line = join( " " , @_ ) ; + $line =~ s/ *\t */ /g ; + print $line , "\n" if $debug ; } 1 ; diff --git a/bin/CompilationDatabase.pm b/bin/CompilationDatabase.pm index 9d09d06..dd1ad33 100644 --- a/bin/CompilationDatabase.pm +++ b/bin/CompilationDatabase.pm @@ -26,8 +26,7 @@ # Synopsis: # # use CompilationDatabase ; -# my $cdb = new CompilationDatabase( $src_dir , -# ["-DFOO=BAR",...] , ["-I_TOP_"] , ["-Wall"] , {WINDOWS=>0,...} , {top_srcdir=>'..'} ) ; +# my $cdb = new CompilationDatabase( $src_dir , {WINDOWS=>0,...} , {top_srcdir=>'..'} , {} ) ; # my @files = $cdb->list() ; # my @stanzas = $cdb->stanzas() ; # $cdb->print() ; @@ -42,16 +41,16 @@ our $debug = 0 ; sub new { - my ( $classname , $base_makefile_dir , $dflags , $iflags , $cxxflags , $switches , $ro_vars ) = @_ ; + my ( $classname , $base_makefile_dir , $switches , $ro_vars , $config ) = @_ ; $AutoMakeParser::debug = 1 if $debug > 1 ; + $config ||= {} ; + $config->{test_mode} ||= 0 ; + $config->{full_paths} ||= 0 ; my %me = ( m_base_dir => $base_makefile_dir , - m_dflags => $dflags , - m_iflags => $iflags , - m_cxxflags => $cxxflags , m_switches => $switches , m_ro_vars => $ro_vars , - m_full_paths => 0 , + m_config => $config , ) ; return bless \%me , $classname ; } @@ -95,26 +94,28 @@ sub stanzas for my $m ( @makefiles ) { my $dir = File::Basename::dirname( $m->path() ) ; - my @includes = map { "-I$_" } $m->includes( $m->top() , undef , join(" ",@{$this->{m_iflags}}) , $this->{m_full_paths} ) ; + my @includes = map { "-I$_" } $m->includes( $m->top() , undef , undef , $this->{m_config}->{full_paths} ) ; my @definitions = map { "-D$_" } $m->definitions() ; - push @definitions , @{$this->{m_dflags}} ; + my @compile_options = $m->compile_options() ; + my @link_options = $m->link_options() ; if( $debug ) { print "cdb: makefile=" , $m->path() , "\n" ; - print "cdb: AM_CPPFLAGS=[",join("|",$m->value("AM_CPPFLAGS")),"]\n" ; print "cdb: top=",$m->top(),"\n" ; print "cdb: \@includes=" , join("|",@includes) , "\n" ; print "cdb: \@definitions=" , join("|",@definitions) , "\n" ; + print "cdb: \@compile_options=" , join("|",@compile_options) , "\n" ; + print "cdb: \@link_options=" , join("|",@link_options) , "\n" ; } for my $library ( $m->libraries() ) { - map { push @output , $this->_stanza($dir,$_,\@includes,\@definitions) } $m->sources($library) ; + map { push @output , $this->_stanza($dir,$_,\@includes,\@definitions,\@compile_options) } $m->sources($library) ; } for my $program ( $m->programs() ) { - map { push @output , $this->_stanza($dir,$_,\@includes,\@definitions) } $m->sources($program) ; + map { push @output , $this->_stanza($dir,$_,\@includes,\@definitions,\@compile_options) } $m->sources($program) ; } } return @output ; @@ -122,15 +123,20 @@ sub stanzas sub _stanza { - my ( $this , $dir , $source , $includes , $definitions ) = @_ ; + my ( $this , $dir , $source , $includes , $definitions , $options ) = @_ ; - my @all_flags = ( @{$this->{m_cxxflags}} , @$definitions , @$includes ) ; + my @all_flags = ( @$definitions , @$includes , @$options ) ; my $directory = Cwd::realpath( $dir ) ; - $source = join("/",$directory,$source) if $this->{m_full_paths} ; + $source = join("/",$directory,$source) if $this->{m_config}->{full_paths} ; my $command = "/usr/bin/c++ @all_flags -c $source" ; - $command =~ s/"/\\"/g ; + $command =~ s/"/\\"/g unless $this->{m_config}->{test_mode} ; + + if( $this->{m_config}->{test_mode} ) + { + return "cd $directory && $command\n" ; + } return "{\n" . diff --git a/bin/ConfigStatus.pm b/bin/ConfigStatus.pm new file mode 100644 index 0000000..f5ef715 --- /dev/null +++ b/bin/ConfigStatus.pm @@ -0,0 +1,124 @@ +#!/usr/bin/perl +# +# Copyright (C) 2001-2021 Graeme Walker +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . +# === +# +# ConfigStatus.pm +# +# Provides 'switches' and 'vars' parsed out of a "config.status" +# file (as generated by an autoconf configure script). +# +# Synopsis: +# use ConfigStatus ; +# my $cs = new ConfigStatus( "config.status" ) ; +# my %vars = $cs->vars() ; +# my %switches = $cs->switches() ; +# +# See also: AutoMakeParser +# + +use strict ; +use FileHandle ; + +package ConfigStatus ; + +sub new +{ + my ( $classname , $filename ) = @_ ; + my $this = bless { + m_vars => {} , + m_switches => {} , + } , $classname ; + $this->parse( $filename ) if $filename ; + return $this ; +} + +sub vars +{ + my ( $this ) = @_ ; + return %{$this->{m_vars}} ; +} + +sub switches +{ + my ( $this ) = @_ ; + return %{$this->{m_switches}} ; +} + +sub parse +{ + my ( $this , $filename ) = @_ ; + $filename ||= "config.status" ; + $this->{m_vars} = {} ; + $this->{m_switches} = {} ; + my $fh = new FileHandle( $filename , "r" ) or die "error: cannot open [$filename]: " . lc($!) . "\n" ; + while(<$fh>) + { + chomp( my $line = $_ ) ; + while( $line =~ m/\\$/ ) + { + $line = substr( $line , 0 , length($line)-2 ) ; # remove doublequote-backslash + my $next = <$fh> ; + chomp( $next ) ; + $next =~ s/^"// ; + $line .= $next ; + } + my ( $k , $v ) = ( $line =~ m/^S\["([^"]+)"\]="([^"]*)"\s*$/ ) ; + if( $k && defined($v) ) + { + if( $k =~ m/_TRUE$/ ) + { + ( my $kk = $k ) =~ s/_TRUE$// ; + my $vv = ( $v eq "" ? 1 : 0 ) ; + $this->{m_switches}->{$kk} = $vv ; + } + elsif( $k =~ m/_FALSE$/ ) + { + ( my $kk = $k ) =~ s/_FALSE$// ; + my $vv = ( $v eq "" ? 0 : 1 ) ; + $this->{m_switches}->{$kk} = $vv ; + } + else + { + $this->{m_vars}->{$k} = $v ; + } + } + } + $this->_expand() ; + return $this ; +} + +sub _expand +{ + my ( $this ) = @_ ; + for my $k ( sort keys %{$this->{m_vars}} ) + { + my $v = $this->{m_vars}->{$k} ; + for my $i ( 0 .. 10 ) + { + my ( $subkey ) = ( $v =~ m/\$\{([^}]*)\}/ ) ; + if( $subkey && exists($this->{m_vars}->{$subkey}) ) + { + my $new = $this->{m_vars}->{$subkey} ; + $v =~ s/\$\{$subkey\}/$new/ ; + } + } + $this->{m_vars}->{$k} = $v ; + } + return $this ; +} + +1 ; diff --git a/bin/Makefile.am b/bin/Makefile.am index bb2a534..3b6b7ee 100644 --- a/bin/Makefile.am +++ b/bin/Makefile.am @@ -52,6 +52,7 @@ work_scripts = \ make2cdb \ AutoMakeParser.pm \ CompilationDatabase.pm \ + ConfigStatus.pm \ winbuild.pm js_scripts = \ diff --git a/bin/Makefile.in b/bin/Makefile.in index e51ecb1..79dea1e 100644 --- a/bin/Makefile.in +++ b/bin/Makefile.in @@ -1,7 +1,7 @@ -# Makefile.in generated by automake 1.15 from Makefile.am. +# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ -# Copyright (C) 1994-2014 Free Software Foundation, Inc. +# Copyright (C) 1994-2018 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -100,7 +100,7 @@ am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d -CONFIG_HEADER = $(top_builddir)/gconfig_defs.h +CONFIG_HEADER = $(top_builddir)/src/gconfig_defs.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; @@ -218,6 +218,7 @@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ QT_CFLAGS = @QT_CFLAGS@ QT_LIBS = @QT_LIBS@ +QT_LRELEASE = @QT_LRELEASE@ QT_MOC = @QT_MOC@ RANLIB = @RANLIB@ SED = @SED@ @@ -254,6 +255,7 @@ e_rundir = @e_rundir@ e_spooldir = @e_spooldir@ e_sysconfdir = @e_sysconfdir@ e_systemddir = @e_systemddir@ +e_trdir = @e_trdir@ exec_prefix = @exec_prefix@ host_alias = @host_alias@ htmldir = @htmldir@ @@ -317,6 +319,7 @@ work_scripts = \ make2cdb \ AutoMakeParser.pm \ CompilationDatabase.pm \ + ConfigStatus.pm \ winbuild.pm js_scripts = \ @@ -369,8 +372,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ + echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) @@ -479,7 +482,10 @@ ctags CTAGS: cscope cscopelist: -distdir: $(DISTFILES) +distdir: $(BUILT_SOURCES) + $(MAKE) $(AM_MAKEFLAGS) distdir-am + +distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ diff --git a/bin/emailrelay-deliver.sh.in b/bin/emailrelay-deliver.sh.in old mode 100755 new mode 100644 diff --git a/bin/emailrelay-notify.sh.in b/bin/emailrelay-notify.sh.in old mode 100755 new mode 100644 diff --git a/bin/emailrelay-resubmit.sh.in b/bin/emailrelay-resubmit.sh.in old mode 100755 new mode 100644 diff --git a/bin/emailrelay-sendmail.pl b/bin/emailrelay-sendmail.pl index c6b0a4f..903f9b0 100755 --- a/bin/emailrelay-sendmail.pl +++ b/bin/emailrelay-sendmail.pl @@ -15,15 +15,61 @@ # use strict ; +use FileHandle ; use Getopt::Std ; -# parse and mostly ignore sendmail command-line options -my $usage = "usage: emailrelay-sendmail [-intUv] [-BbCdFhNOopqRrVX ] [-f ] [ ...]" ; -my %opt = () ; -getopts( 'B:b:C:d:F:f:h:iN:nO:o:p:q:R:r:tUV:vX:' , \%opt ) or die "$usage\n" ; - -# submit into the emailrelay spool directory -my $from = defined($opt{f}) ? $opt{f} : $ENV{USER} ; my $exe = "/usr/sbin/emailrelay-submit" ; -my @args = ( $exe , "-f" , $from , @ARGV ) ; # also consider using "--copy" and "--content-date" -exec { $exe } @args ; + +# parse and mostly ignore sendmail command-line options +my $usage = "usage: emailrelay-sendmail [-intUv] [-ABbCDdFfGhiLNnOopqRrtUVvX ] [-f ] [ ...]" ; +my %opt = () ; +getopts( 'A:B:b:C:D:d:F:f:Gh:iL:N:nO:o:p:q:R:r:tUV:vX:' , \%opt ) or die "$usage\n" ; +my $from = defined($opt{f}) ? $opt{f} : $ENV{USER} ; +my @submit_args = ( "--content-date" , @ARGV ) ; # also consider using "--copy" + +# if "-t" read envelope 'to' addresses from content headers +if( $opt{t} ) +{ + # read content headers + my %h = () ; + my @h = () ; + my $k = "" ; + while() + { + chomp( my $line = $_ ) ; + $line =~ s/\r$// ; + last if ( $line eq "" ) ; + my ( $a , $b , $c , $d ) = ( $line =~ m/^(\S*):\s*(.*)|^(\s)(.*)/ ) ; + if( $a ) { $k = lc($a) ; $h{$k} = $b } + if( $k && $d ) { $h{$k} .= "$c$d" } # folding + push @h , $line unless ( lc($k) eq 'bcc' ) ; # remove Bcc + } + + # extract 'to' addresses + my @to = () ; + push @to , split(" ",$h{to}) if exists($h{to}) ; + push @to , split(" ",$h{cc}) if exists($h{cc}) ; + push @to , split(" ",$h{bcc}) if exists($h{bcc}) ; + + # write headers and copy body into temp file + my $tmp = "/tmp/emailrelay-sendmail.$$.tmp" ; + my $fh = new FileHandle( $tmp , "w" ) or die ; + map { print $fh $_ , "\r\n" } @h ; + print $fh "\r\n" ; + while() { print $fh $_ } + $fh->close() or die ; + + # make stdin read from the temp file + open STDIN , '<' , $tmp or die ; + unlink $tmp or die ; + + # run emailrelay-submit + my @args = ( $exe , "-f" , $from , @to ) ; + exec { $exe } @args ; +} +else +{ + # run emailrelay-submit + my @args = ( $exe , "-f" , $from , @submit_args ) ; + exec { $exe } @args ; +} diff --git a/bin/emailrelay-set-from.js b/bin/emailrelay-set-from.js index 35ad6c8..55336b7 100755 --- a/bin/emailrelay-set-from.js +++ b/bin/emailrelay-set-from.js @@ -83,7 +83,7 @@ try WScript.Quit( 0 ) ; } -catch +catch( e ) { WScript.StdOut.WriteLine( "<>" ) ; WScript.StdOut.WriteLine( "<<" + e + ">>" ) ; diff --git a/bin/emailrelay-submit.sh.in b/bin/emailrelay-submit.sh.in old mode 100755 new mode 100644 diff --git a/bin/make2cdb b/bin/make2cdb index 740dd96..b098be2 100755 --- a/bin/make2cdb +++ b/bin/make2cdb @@ -38,74 +38,38 @@ use File::Find ; use File::Basename ; use File::Spec ; use File::Copy ; +use Getopt::Long ; use lib dirname($0) ; +use ConfigStatus ; use CompilationDatabase ; -$CompilationDatabase::debug = 0 ; -my $show_list = $ARGV[0] eq "--list" ; -shift @ARGV if $show_list ; +my %opt = () ; +GetOptions( \%opt , "list" , "test" , "debug" ) or die "$0: usage error\n" ; +my $cfg_show_list = exists( $opt{list} ) ; +my $cfg_test_mode = exists( $opt{test} ) ; +my $cfg_debug = exists( $opt{debug} ) ; +$CompilationDatabase::debug = $cfg_debug ; +$AutoMakeParser::debug = $cfg_debug ; my $src_dir = @ARGV ? $ARGV[0] : dirname($0)."/../src" ; my $top_dir = @ARGV >= 1 ? $ARGV[1] : "$src_dir/.." ; my $src_to_top = @ARGV >= 2 ? $ARGV[2] : ".." ; -my @dflags = ( - "-DG_UNIX=1" , -) ; +my $cs = new ConfigStatus( "$top_dir/config.status" ) ; +my %switches = $cs->switches() ; +my %vars = $cs->vars() ; +$vars{top_srcdir} = $src_to_top ; +$vars{top_builddir} = "." ; -# makefile conditionals -my %switches = ( - GCONFIG_BSD => 0 , - GCONFIG_GUI => 0 , - GCONFIG_ICONV => 0 , - GCONFIG_INSTALL_HOOK => 0 , - GCONFIG_INTERFACE_NAMES => 1 , - GCONFIG_MAC => 0 , - GCONFIG_PAM => 0 , - GCONFIG_TESTING => 0 , - GCONFIG_TLS_USE_BOTH => 0 , - GCONFIG_TLS_USE_MBEDTLS => 0 , - GCONFIG_TLS_USE_NONE => 0 , - GCONFIG_TLS_USE_OPENSSL => 1 , - GCONFIG_WINDOWS => 0 , -) ; - -# makefile expansion variables -- many are required but not relevant -my %vars = ( - top_srcdir => $src_to_top , - top_builddir => "." , - sbindir => "." , - mandir => "." , - localedir => "." , - e_spooldir => "/var/spool/emailrelay" , - e_docdir => "." , - e_initdir => "." , - e_bsdinitdir => "." , - e_rundir => "." , - e_icondir => "." , - e_examplesdir => "." , - e_libexecdir => "." , - e_pamdir => "." , - e_sysconfdir => "/etc" , - GCONFIG_WINDRES => "" , - GCONFIG_WINDMC => "" , - GCONFIG_QT_LIBS => "" , - GCONFIG_QT_CFLAGS => "" , - GCONFIG_QT_MOC => "" , - GCONFIG_TLS_LIBS => "" , - GCONFIG_STATIC_START => "" , - GCONFIG_STATIC_END => "" , - RPM_ARCH => "x86" , - RPM_ROOT => "rpm" , -) ; - -my $cdb = new CompilationDatabase( $src_dir , ["-DG_UNIX=1"], ["-I$src_to_top"] , ["-std=c++11","-pthread"] , \%switches , \%vars ) ; -$cdb->{m_full_paths} = 1 ; # grr - -if( $show_list ) +my $cdb = new CompilationDatabase( $src_dir , \%switches , \%vars , {test_mode=>$cfg_test_mode,full_paths=>1} ) ; +if( $cfg_show_list ) { print join( "\n" , $cdb->list() , "" ) ; } +elsif( $cfg_test_mode ) +{ + print join( "" , $cdb->stanzas() ) ; +} else { print "[\n" ; diff --git a/bin/make2cmake b/bin/make2cmake index f0fff04..056588e 100755 --- a/bin/make2cmake +++ b/bin/make2cmake @@ -18,16 +18,21 @@ # # make2cmake # -# Parses automake files throughout the source tree and generates -# simplistic cmake files for a unix build. +# Parses the autoconf/automake artifacts throughout the source tree +# in order to generates simplistic 'cmake' files. # # Eg: -# $ ./make2cmake +# $ CXXFLAGS="-X" ./configure --with-whatever +# $ bin/make2cmake # $ mkdir build # $ cd build -# $ cmake -DCMAKE_MAKE_PROGRAM:FILEPATH=/usr/bin/make .. +# $ cmake .. # $ make VERBOSE=1 # +# The autoconf CXXFLAGS flow through to 'target_compile_options()' (etc) +# directives in the 'CMakeLists' files; other autoconf options flow +# through the 'config.status' file. +# # See also: winbuild.pl # @@ -39,87 +44,62 @@ use File::Basename ; use File::Spec ; use File::Copy ; use lib dirname($0) ; +use ConfigStatus ; use AutoMakeParser ; $AutoMakeParser::debug = 0 ; +my $cfg_verbose = 1 ; +my $cfg_project = "emailrelay" ; -# makefile conditionals -my %switches = ( - GCONFIG_BSD => 0 , - GCONFIG_GUI => 0 , - GCONFIG_ICONV => 0 , - GCONFIG_INSTALL_HOOK => 0 , - GCONFIG_INTERFACE_NAMES => 1 , - GCONFIG_MAC => 0 , - GCONFIG_PAM => 0 , - GCONFIG_TESTING => 0 , - GCONFIG_TLS_USE_BOTH => 0 , - GCONFIG_TLS_USE_MBEDTLS => 0 , - GCONFIG_TLS_USE_NONE => 0 , - GCONFIG_TLS_USE_OPENSSL => 1 , - GCONFIG_WINDOWS => 0 , +my $cs = new ConfigStatus( "config.status" ) ; +my %switches = $cs->switches() ; +my %vars = $cs->vars() ; +my %qt_config = ( + dirs => { "gui" => 1 } , + targets => { "emailrelay-gui.real" => 1 } , ) ; -# makefile expansion variables -- many are required but not relevant -my %vars = ( - top_srcdir => "." , - top_builddir => "." , - sbindir => "." , - mandir => "." , - localedir => "." , - e_spooldir => "/var/spool/emailrelay" , - e_docdir => "." , - e_initdir => "." , - e_bsdinitdir => "." , - e_rundir => "." , - e_icondir => "." , - e_examplesdir => "." , - e_libexecdir => "." , - e_pamdir => "." , - e_sysconfdir => "/etc" , - GCONFIG_WINDRES => "" , - GCONFIG_WINDMC => "" , - GCONFIG_QT_LIBS => "" , - GCONFIG_QT_CFLAGS => "" , - GCONFIG_QT_MOC => "" , - GCONFIG_TLS_LIBS => "-lssl -lcrypto" , - GCONFIG_STATIC_START => "" , - GCONFIG_STATIC_END => "" , - RPM_ARCH => "x86" , - RPM_ROOT => "rpm" , - VERSION => FileHandle->new("VERSION")->gets() , -) ; +$vars{top_srcdir} = "." ; +$vars{top_builddir} = "." ; -run_generate( "emailrelay" , \%switches , \%vars ) ; +create_cmake_files( $cfg_project , \%switches , \%vars , \%qt_config ) ; +create_empty_gconfig_header() ; # == sub create_cmake_file { - my ( $project , $m , $switches ) = @_ ; + my ( $project , $m , $switches , $vars , $qt_config ) = @_ ; my $path = join( "/" , dirname($m->path()) , "CMakeLists.txt" ) ; - print "cmake-file=[$path]\n" ; + _log( "cmake-file=[$path]" ) ; my $fh = new FileHandle( $path , "w" ) or die ; - my $compile_options = "-std=c++11 -pthread" ; - my $link_options = "-pthread" ; + my $link_options = $m->link_options() ; + my $compile_options = $m->compile_options() ; + $compile_options = join(" ",$compile_options,"-std=c++11") if( $compile_options !~ m/std=c++/ ) ; print $fh "# $path -- generated by $0\n" ; if( $project ) { - print $fh "cmake_minimum_required(VERSION 2.8.11)\n" ; + print $fh "cmake_minimum_required(VERSION 3.12)\n" ; print $fh "project($project)\n" ; print $fh "add_compile_options($compile_options)\n" ; } - print $fh "\n" ; + if( exists $qt_config->{dirs}->{basename(dirname($m->path()))} ) + { + print $fh "\n" ; + print $fh "find_package(Qt5 REQUIRED COMPONENTS Widgets Gui Core)\n" ; + } + + print $fh "\n" if $m->subdirs() ; for my $subdir ( $m->subdirs() ) { print $fh "add_subdirectory($subdir)\n" ; } - my $definitions = join( " " , "G_UNIX=1" , $m->definitions() ) ; + my $definitions = join( " " , $m->definitions() ) ; my $includes = join( " " , "." , ".." , $m->includes($m->top()) ) ; my @libraries = $m->libraries() ; @@ -130,8 +110,10 @@ sub create_cmake_file ( my $library_key = $library ) =~ s/\.a$// ; $library_key =~ s/^lib// ; print $fh "\n" ; print $fh "add_library($library_key $sources)\n" ; + print $fh "target_compile_options($library_key PUBLIC $compile_options)\n" ; print $fh "target_include_directories($library_key PUBLIC $includes)\n" ; print $fh "target_compile_definitions($library_key PUBLIC $definitions)\n" ; + print $fh "set_target_properties($library_key PROPERTIES AUTOMOC ON)\n" if exists $qt_config->{targets}->{$library_key} ; } my @programs = $m->programs() ; @@ -147,9 +129,11 @@ sub create_cmake_file print $fh "\n" ; print $fh "add_executable($program $program_sources)\n" ; + print $fh "target_link_options($program PUBLIC $link_options)\n" ; # cmake 3.13 print $fh "target_include_directories($program PUBLIC $program_includes)\n" ; print $fh "target_compile_definitions($program PUBLIC $definitions)\n" ; - print $fh "target_link_libraries($program $link_options $program_libs)\n" ; + print $fh "target_link_libraries($program $program_libs)\n" ; + print $fh "set_target_properties($program PROPERTIES AUTOMOC ON)\n" if exists $qt_config->{targets}->{$program} ; } $fh->close() or die ; @@ -157,25 +141,18 @@ sub create_cmake_file sub create_cmake_files { - my ( $project , $switches , $vars ) = @_ ; + my ( $project , $switches , $vars , $qt_config ) = @_ ; - my @makefiles = AutoMakeParser::readall( "." , $switches , $vars , 1 ) ; + my @makefiles = AutoMakeParser::readall( "." , $switches , $vars , $cfg_verbose , "make2cmake: " ) ; my $first = 1 ; for my $m ( @makefiles ) { - create_cmake_file( $first?$project:undef , $m , $switches ) ; + create_cmake_file( $first?$project:undef , $m , $switches , $vars , $qt_config ) ; $first = 0 ; } } -sub run_generate -{ - my ( $project , $switches , $vars ) = @_ ; - create_cmake_files( $project , $switches , $vars ) ; - create_gconfig_header() ; -} - -sub create_gconfig_header +sub create_empty_gconfig_header { my $path = "src/gconfig_defs.h" ; if( ! -f $path ) @@ -185,3 +162,8 @@ sub create_gconfig_header } } +sub _log +{ + print "make2cmake: " , @_ , "\n" if $cfg_verbose ; +} + diff --git a/bin/winbuild.pm b/bin/winbuild.pm index d1d906a..2cd9a1f 100644 --- a/bin/winbuild.pm +++ b/bin/winbuild.pm @@ -34,6 +34,7 @@ # winbuild::clean_cmake_cache_files(...) ; # winbuild::deltree(...) ; # winbuild::run_msbuild(...) ; +# winbuild::translate(...) ; # winbuild::create_touchfile(...) ; # winbuild::read_makefiles(...) ; # winbuild::read_makefiles_imp(...) ; @@ -145,7 +146,9 @@ sub default_touchfile sub _path_dirs { - return split( ";" , $ENV{PATH} ) ; + my $path = $ENV{PATH} ; + my $sep = ( $path =~ m/;/ ) ? ";" : ":" ; + return split( $sep , $path ) ; } sub _sanepath @@ -175,6 +178,7 @@ sub _find_under my $result ; for my $dir ( map {_sanepath($_)} @dirs ) { + next if !$dir ; my @find_list = () ; File::Find::find( sub { push @find_list , $File::Find::name if lc($_) eq $fname } , $dir ) ; if( @find_list ) { $result = Cwd::realpath($find_list[0]) ; last } @@ -326,6 +330,19 @@ sub run_msbuild die unless $rc == 0 ; } +sub translate +{ + my ( $arch , $qt_dirs , $xx_XX , $xx ) = @_ ; + my $dir = $qt_dirs->{$arch} ; + $dir = File::Basename::dirname( $dir ) ; + $dir = File::Basename::dirname( $dir ) ; + $dir = File::Basename::dirname( $dir ) ; + my $tool = join( "/" , $dir , "bin" , "lrelease.exe" ) ; + my $rc = system( $tool , "src/gui/emailrelay_tr.$xx_XX.ts" , "-qm" , "src/gui/emailrelay.$xx.qm" ) ; + print "lrelease-exit=[$rc]\n" ; + die unless $rc == 0 ; +} + sub create_touchfile { my ( $touchfile ) = @_ ; diff --git a/bootstrap b/bootstrap old mode 100755 new mode 100644 diff --git a/bsd/Makefile.in b/bsd/Makefile.in index 679723a..2614825 100644 --- a/bsd/Makefile.in +++ b/bsd/Makefile.in @@ -1,7 +1,7 @@ -# Makefile.in generated by automake 1.15 from Makefile.am. +# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ -# Copyright (C) 1994-2014 Free Software Foundation, Inc. +# Copyright (C) 1994-2018 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -99,7 +99,7 @@ am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d -CONFIG_HEADER = $(top_builddir)/gconfig_defs.h +CONFIG_HEADER = $(top_builddir)/src/gconfig_defs.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; @@ -215,6 +215,7 @@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ QT_CFLAGS = @QT_CFLAGS@ QT_LIBS = @QT_LIBS@ +QT_LRELEASE = @QT_LRELEASE@ QT_MOC = @QT_MOC@ RANLIB = @RANLIB@ SED = @SED@ @@ -251,6 +252,7 @@ e_rundir = @e_rundir@ e_spooldir = @e_spooldir@ e_sysconfdir = @e_sysconfdir@ e_systemddir = @e_systemddir@ +e_trdir = @e_trdir@ exec_prefix = @exec_prefix@ host_alias = @host_alias@ htmldir = @htmldir@ @@ -304,8 +306,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ + echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) @@ -358,7 +360,10 @@ ctags CTAGS: cscope cscopelist: -distdir: $(DISTFILES) +distdir: $(BUILT_SOURCES) + $(MAKE) $(AM_MAKEFLAGS) distdir-am + +distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ diff --git a/configure b/configure index de76254..1fbdf65 100755 --- a/configure +++ b/configure @@ -1,6 +1,6 @@ #! /bin/sh # Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.69 for E-MailRelay 2.2. +# Generated by GNU Autoconf 2.69 for E-MailRelay 2.2.1. # # # Copyright (C) 1992-1996, 1998-2012 Free Software Foundation, Inc. @@ -577,8 +577,8 @@ MAKEFLAGS= # Identity of this package. PACKAGE_NAME='E-MailRelay' PACKAGE_TARNAME='emailrelay' -PACKAGE_VERSION='2.2' -PACKAGE_STRING='E-MailRelay 2.2' +PACKAGE_VERSION='2.2.1' +PACKAGE_STRING='E-MailRelay 2.2.1' PACKAGE_BUGREPORT='' PACKAGE_URL='' @@ -631,10 +631,13 @@ e_pamdir e_libexecdir e_examplesdir e_spooldir +e_trdir e_icondir e_bsdinitdir e_initdir e_docdir +GCONFIG_UDS_FALSE +GCONFIG_UDS_TRUE GCONFIG_PAM_FALSE GCONFIG_PAM_TRUE GCONFIG_TLS_USE_NONE_FALSE @@ -646,6 +649,8 @@ GCONFIG_TLS_USE_OPENSSL_TRUE GCONFIG_TLS_USE_BOTH_FALSE GCONFIG_TLS_USE_BOTH_TRUE GCONFIG_TLS_LIBS +GCONFIG_GETTEXT_FALSE +GCONFIG_GETTEXT_TRUE GCONFIG_WINDOWS_FALSE GCONFIG_WINDOWS_TRUE GCONFIG_TESTING_FALSE @@ -667,6 +672,7 @@ GCONFIG_EPOLL_FALSE GCONFIG_EPOLL_TRUE GCONFIG_BSD_FALSE GCONFIG_BSD_TRUE +QT_LRELEASE QT_MOC QT_LIBS QT_CFLAGS @@ -699,7 +705,6 @@ am__nodep AMDEPBACKSLASH AMDEP_FALSE AMDEP_TRUE -am__quote am__include DEPDIR OBJEXT @@ -777,7 +782,8 @@ PACKAGE_VERSION PACKAGE_TARNAME PACKAGE_NAME PATH_SEPARATOR -SHELL' +SHELL +am__quote' ac_subst_files='' ac_user_opts=' enable_option_checking @@ -802,6 +808,7 @@ with_man2html with_openssl with_mbedtls with_pam +with_uds ' ac_precious_vars='build_alias host_alias @@ -1371,7 +1378,7 @@ if test "$ac_init_help" = "long"; then # Omit some internal or obsolete options to make the list less imposing. # This message is too long to be a string in the A/UX 3.1 sh. cat <<_ACEOF -\`configure' configures E-MailRelay 2.2 to adapt to many kinds of systems. +\`configure' configures E-MailRelay 2.2.1 to adapt to many kinds of systems. Usage: $0 [OPTION]... [VAR=VALUE]... @@ -1438,7 +1445,7 @@ fi if test -n "$ac_init_help"; then case $ac_init_help in - short | recursive ) echo "Configuration of E-MailRelay 2.2:";; + short | recursive ) echo "Configuration of E-MailRelay 2.2.1:";; esac cat <<\_ACEOF @@ -1484,6 +1491,7 @@ Optional Packages: --with-openssl use openssl for tls layer (default auto) --with-mbedtls use mbedtls for tls layer (default auto) --with-pam use linux pam for authentication (default auto) + --with-uds enable unix domain sockets (default auto) Some influential environment variables: CC C compiler command @@ -1571,7 +1579,7 @@ fi test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF -E-MailRelay configure 2.2 +E-MailRelay configure 2.2.1 generated by GNU Autoconf 2.69 Copyright (C) 2012 Free Software Foundation, Inc. @@ -2007,7 +2015,7 @@ cat >config.log <<_ACEOF This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. -It was created by E-MailRelay $as_me 2.2, which was +It was created by E-MailRelay $as_me 2.2.1, which was generated by GNU Autoconf 2.69. Invocation command line was $ $0 $@ @@ -2357,7 +2365,7 @@ ac_compiler_gnu=$ac_cv_c_compiler_gnu -am__api_version='1.15' +am__api_version='1.16' ac_aux_dir= for ac_dir in "$srcdir" "$srcdir/.." "$srcdir/../.."; do @@ -2872,7 +2880,7 @@ fi # Define the identity of the package. PACKAGE='emailrelay' - VERSION='2.2' + VERSION='2.2.1' # Some tools Automake needs. @@ -2893,8 +2901,8 @@ MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"} # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: -# -# +# +# mkdir_p='$(MKDIR_P)' # We need awk for the "check" target (and possibly the TAP driver). The @@ -2945,7 +2953,7 @@ END Aborting the configuration process, to ensure you take notice of the issue. You can download and install GNU coreutils to get an 'rm' implementation -that behaves properly: . +that behaves properly: . If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM @@ -2956,7 +2964,7 @@ END fi fi -ac_config_headers="$ac_config_headers gconfig_defs.h" +ac_config_headers="$ac_config_headers src/gconfig_defs.h" { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to enable maintainer-specific portions of Makefiles" >&5 @@ -3643,45 +3651,45 @@ DEPDIR="${am__leading_dot}deps" ac_config_commands="$ac_config_commands depfiles" - -am_make=${MAKE-make} -cat > confinc << 'END' +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} supports the include directive" >&5 +$as_echo_n "checking whether ${MAKE-make} supports the include directive... " >&6; } +cat > confinc.mk << 'END' am__doit: - @echo this is the am__doit target + @echo this is the am__doit target >confinc.out .PHONY: am__doit END -# If we don't find an include directive, just comment out the code. -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5 -$as_echo_n "checking for style of include used by $am_make... " >&6; } am__include="#" am__quote= -_am_result=none -# First try GNU make style include. -echo "include confinc" > confmf -# Ignore all kinds of additional output from 'make'. -case `$am_make -s -f confmf 2> /dev/null` in #( -*the\ am__doit\ target*) - am__include=include - am__quote= - _am_result=GNU - ;; -esac -# Now try BSD make style include. -if test "$am__include" = "#"; then - echo '.include "confinc"' > confmf - case `$am_make -s -f confmf 2> /dev/null` in #( - *the\ am__doit\ target*) - am__include=.include - am__quote="\"" - _am_result=BSD +# BSD make does it like this. +echo '.include "confinc.mk" # ignored' > confmf.BSD +# Other make implementations (GNU, Solaris 10, AIX) do it like this. +echo 'include confinc.mk # ignored' > confmf.GNU +_am_result=no +for s in GNU BSD; do + { echo "$as_me:$LINENO: ${MAKE-make} -f confmf.$s && cat confinc.out" >&5 + (${MAKE-make} -f confmf.$s && cat confinc.out) >&5 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } + case $?:`cat confinc.out 2>/dev/null` in #( + '0:this is the am__doit target') : + case $s in #( + BSD) : + am__include='.include' am__quote='"' ;; #( + *) : + am__include='include' am__quote='' ;; +esac ;; #( + *) : ;; - esac -fi - - -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5 -$as_echo "$_am_result" >&6; } -rm -f confinc confmf +esac + if test "$am__include" != "#"; then + _am_result="yes ($s style)" + break + fi +done +rm -f confinc.* confmf.* +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: ${_am_result}" >&5 +$as_echo "${_am_result}" >&6; } # Check whether --enable-dependency-tracking was given. if test "${enable_dependency_tracking+set}" = set; then : @@ -6496,6 +6504,55 @@ $as_echo "#define GCONFIG_HAVE_STATBUF_NSEC 0" >>confdefs.h fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for iovec layout" >&5 +$as_echo_n "checking for iovec layout... " >&6; } +if ${gconfig_cv_iovec_is_simple+:} false; then : + $as_echo_n "(cached) " >&6 +else + + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + #include + #include + #include + struct simple { const char * p ; std::size_t n ; } ; + +int +main () +{ + + static_assert( sizeof(simple) == sizeof(::iovec) , "" ) ; + static_assert( alignof(simple) == alignof(::iovec) , "" ) ; + static_assert( sizeof(simple::p) == sizeof(::iovec::iov_base) , "" ) ; + static_assert( sizeof(simple::n) == sizeof(::iovec::iov_len) , "" ) ; + static_assert( offsetof(simple,p) == offsetof(::iovec,iov_base) , "" ) ; + static_assert( offsetof(simple,n) == offsetof(::iovec,iov_len) , "" ) ; + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + gconfig_cv_iovec_is_simple=yes +else + gconfig_cv_iovec_is_simple=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_iovec_is_simple" >&5 +$as_echo "$gconfig_cv_iovec_is_simple" >&6; } + if test "$gconfig_cv_iovec_is_simple" = "yes" ; then + +$as_echo "#define GCONFIG_HAVE_IOVEC_SIMPLE 1" >>confdefs.h + + else + +$as_echo "#define GCONFIG_HAVE_IOVEC_SIMPLE 0" >>confdefs.h + + fi + @@ -6555,339 +6612,6 @@ fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ nullptr" >&5 -$as_echo_n "checking for c++ nullptr... " >&6; } -if ${gconfig_cv_cxx_nullptr+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - void * p = nullptr ; - -int -main () -{ - - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_nullptr=yes -else - gconfig_cv_cxx_nullptr=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_nullptr" >&5 -$as_echo "$gconfig_cv_cxx_nullptr" >&6; } - if test "$gconfig_cv_cxx_nullptr" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_NULLPTR 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_NULLPTR 0" >>confdefs.h - - fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ constexpr" >&5 -$as_echo_n "checking for c++ constexpr... " >&6; } -if ${gconfig_cv_cxx_constexpr+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - template struct Foo {static constexpr int foo = 1;} ; - -int -main () -{ - - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_constexpr=yes -else - gconfig_cv_cxx_constexpr=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_constexpr" >&5 -$as_echo "$gconfig_cv_cxx_constexpr" >&6; } - if test "$gconfig_cv_cxx_constexpr" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_CONSTEXPR 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_CONSTEXPR 0" >>confdefs.h - - fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ class enums" >&5 -$as_echo_n "checking for c++ class enums... " >&6; } -if ${gconfig_cv_cxx_enum_class+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - enum class Type { t1 , t2 } ; - Type t = Type::t1 ; - -int -main () -{ - - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_enum_class=yes -else - gconfig_cv_cxx_enum_class=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_enum_class" >&5 -$as_echo "$gconfig_cv_cxx_enum_class" >&6; } - if test "$gconfig_cv_cxx_enum_class" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_ENUM_CLASS 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_ENUM_CLASS 0" >>confdefs.h - - fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ noexcept" >&5 -$as_echo_n "checking for c++ noexcept... " >&6; } -if ${gconfig_cv_cxx_noexcept+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - void fn() noexcept ; - -int -main () -{ - - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_noexcept=yes -else - gconfig_cv_cxx_noexcept=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_noexcept" >&5 -$as_echo "$gconfig_cv_cxx_noexcept" >&6; } - if test "$gconfig_cv_cxx_noexcept" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_NOEXCEPT 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_NOEXCEPT 0" >>confdefs.h - - fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ override" >&5 -$as_echo_n "checking for c++ override... " >&6; } -if ${gconfig_cv_cxx_override+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - #if defined(__GNUC__) && __cplusplus < 200000L - #error gcc is too noisy when using override/final without std=c++11 - #endif - struct base { virtual void fn() {} } ; - struct derived : public base { virtual void fn() override {} } ; - derived d ; - -int -main () -{ - - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_override=yes -else - gconfig_cv_cxx_override=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_override" >&5 -$as_echo "$gconfig_cv_cxx_override" >&6; } - if test "$gconfig_cv_cxx_override" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_OVERRIDE 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_OVERRIDE 0" >>confdefs.h - - fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ final keyword" >&5 -$as_echo_n "checking for c++ final keyword... " >&6; } -if ${gconfig_cv_cxx_final+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - #if defined(__GNUC__) && __cplusplus < 200000L - #error gcc is too noisy when using override/final without std=c++11 - #endif - struct base { virtual void fn() {} } ; - struct derived : public base { virtual void fn() final {} } ; - derived d ; - -int -main () -{ - - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_final=yes -else - gconfig_cv_cxx_final=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_final" >&5 -$as_echo "$gconfig_cv_cxx_final" >&6; } - if test "$gconfig_cv_cxx_final" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_FINAL 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_FINAL 0" >>confdefs.h - - fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ type_traits" >&5 -$as_echo_n "checking for c++ type_traits... " >&6; } -if ${gconfig_cv_cxx_type_traits_make_unsigned+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - #include - std::make_unsigned::type i = 0U ; - -int -main () -{ - - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_type_traits_make_unsigned=yes -else - gconfig_cv_cxx_type_traits_make_unsigned=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_type_traits_make_unsigned" >&5 -$as_echo "$gconfig_cv_cxx_type_traits_make_unsigned" >&6; } - if test "$gconfig_cv_cxx_type_traits_make_unsigned" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_TYPE_TRAITS_MAKE_UNSIGNED 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_TYPE_TRAITS_MAKE_UNSIGNED 0" >>confdefs.h - - fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ emplace_back and friends" >&5 -$as_echo_n "checking for c++ emplace_back and friends... " >&6; } -if ${gconfig_cv_cxx_emplace+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - #include - std::vector v ; - -int -main () -{ - - v.emplace_back(1) ; - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_emplace=yes -else - gconfig_cv_cxx_emplace=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_emplace" >&5 -$as_echo "$gconfig_cv_cxx_emplace" >&6; } - if test "$gconfig_cv_cxx_emplace" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_EMPLACE 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_EMPLACE 0" >>confdefs.h - - fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ std::align" >&5 $as_echo_n "checking for c++ std::align... " >&6; } @@ -6936,90 +6660,6 @@ $as_echo "#define GCONFIG_HAVE_CXX_ALIGNMENT 0" >>confdefs.h fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ std::move" >&5 -$as_echo_n "checking for c++ std::move... " >&6; } -if ${gconfig_cv_cxx_move+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - #include - struct X {} x ; - void fn( X&& ) ; - -int -main () -{ - - fn( std::move(x) ) ; - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_move=yes -else - gconfig_cv_cxx_move=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_move" >&5 -$as_echo "$gconfig_cv_cxx_move" >&6; } - if test "$gconfig_cv_cxx_move" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_MOVE 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_MOVE 0" >>confdefs.h - - fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ std::shared_ptr and friends" >&5 -$as_echo_n "checking for c++ std::shared_ptr and friends... " >&6; } -if ${gconfig_cv_cxx_std_shared_ptr+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - #include - typedef std::shared_ptr ptr ; - -int -main () -{ - - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_std_shared_ptr=yes -else - gconfig_cv_cxx_std_shared_ptr=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_std_shared_ptr" >&5 -$as_echo "$gconfig_cv_cxx_std_shared_ptr" >&6; } - if test "$gconfig_cv_cxx_std_shared_ptr" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_SHARED_PTR 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_SHARED_PTR 0" >>confdefs.h - - fi - { $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ std::make_unique" >&5 $as_echo_n "checking for c++ std::make_unique... " >&6; } if ${gconfig_cv_cxx_std_make_unique+:} false; then : @@ -7189,188 +6829,6 @@ $as_echo "#define GCONFIG_HAVE_CXX_STD_THREAD 0" >>confdefs.h fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ std::wstring" >&5 -$as_echo_n "checking for c++ std::wstring... " >&6; } -if ${gconfig_cv_cxx_std_wstring+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - #include - std::wstring ws; - -int -main () -{ - - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_std_wstring=yes -else - gconfig_cv_cxx_std_wstring=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_std_wstring" >&5 -$as_echo "$gconfig_cv_cxx_std_wstring" >&6; } - if test "$gconfig_cv_cxx_std_wstring" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_STD_WSTRING 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_STD_WSTRING 0" >>confdefs.h - - fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ eq delete" >&5 -$as_echo_n "checking for c++ eq delete... " >&6; } -if ${gconfig_cv_cxx_deleted+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - #if defined(__GNUC__) && __cplusplus < 200000L - #error gcc is too noisy when using =delete without std=c++11 - #endif - struct X { X(const X&) = delete ; } ; - -int -main () -{ - - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_deleted=yes -else - gconfig_cv_cxx_deleted=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_deleted" >&5 -$as_echo "$gconfig_cv_cxx_deleted" >&6; } - if test "$gconfig_cv_cxx_deleted" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_DELETED 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_DELETED 0" >>confdefs.h - - fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ eq default" >&5 -$as_echo_n "checking for c++ eq default... " >&6; } -if ${gconfig_cv_cxx_defaulted+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - #if defined(__GNUC__) && __cplusplus < 200000L - #error gcc is too noisy when using =delete without std=c++11 - #endif - struct X { X() = default ; } ; - -int -main () -{ - - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_defaulted=yes -else - gconfig_cv_cxx_defaulted=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_defaulted" >&5 -$as_echo "$gconfig_cv_cxx_defaulted" >&6; } - if test "$gconfig_cv_cxx_defaulted" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_DEFAULTED 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_DEFAULTED 0" >>confdefs.h - - fi - -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for c++ initializer_list" >&5 -$as_echo_n "checking for c++ initializer_list... " >&6; } -if ${gconfig_cv_cxx_initializer_list+:} false; then : - $as_echo_n "(cached) " >&6 -else - - cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h. */ - - #include - struct X { X( std::initializer_list ) {} } ; - -int -main () -{ - - - ; - return 0; -} -_ACEOF -if ac_fn_cxx_try_compile "$LINENO"; then : - gconfig_cv_cxx_initializer_list=yes -else - gconfig_cv_cxx_initializer_list=no -fi -rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext - -fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_cxx_initializer_list" >&5 -$as_echo "$gconfig_cv_cxx_initializer_list" >&6; } - if test "$gconfig_cv_cxx_initializer_list" = "yes" ; then - -$as_echo "#define GCONFIG_HAVE_CXX_INITIALIZER_LIST 1" >>confdefs.h - - else - -$as_echo "#define GCONFIG_HAVE_CXX_INITIALIZER_LIST 0" >>confdefs.h - - fi - - - - - - - - - - - - - - - @@ -7698,7 +7156,7 @@ int main () { - int fd = socket( PF_ROUTE , SOCK_RAW , AF_INET ) ; + (void) socket( PF_ROUTE , SOCK_RAW , AF_INET ) ; header1.rtm_msglen = header2.ifam_msglen = 0 ; header1.rtm_type = RTM_ADD ; header2.ifam_type = RTM_NEWADDR ; @@ -7880,6 +7338,53 @@ $as_echo "#define GCONFIG_HAVE_GAISTRERROR 0" >>confdefs.h fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for unix domain sockets" >&5 +$as_echo_n "checking for unix domain sockets... " >&6; } +if ${gconfig_cv_uds+:} false; then : + $as_echo_n "(cached) " >&6 +else + + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + #include + #include + #include + struct sockaddr_un a ; + +int +main () +{ + + a.sun_family = AF_UNIX | PF_UNIX ; + a.sun_path[0] = '\0' ; + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_compile "$LINENO"; then : + gconfig_cv_uds=yes +else + gconfig_cv_uds=no +fi +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_uds" >&5 +$as_echo "$gconfig_cv_uds" >&6; } + if test "$gconfig_cv_uds" = "yes" + then + +$as_echo "#define GCONFIG_HAVE_UDS 1" >>confdefs.h + + else + +$as_echo "#define GCONFIG_HAVE_UDS 0" >>confdefs.h + + fi + + @@ -8068,6 +7573,44 @@ $as_echo "#define GCONFIG_HAVE_GETGRNAM_R 0" >>confdefs.h fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for gettext" >&5 +$as_echo_n "checking for gettext... " >&6; } +if ${gconfig_cv_gettext+:} false; then : + $as_echo_n "(cached) " >&6 +else + + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + #include + const char * p = 0; + const char * dir = 0; + const char * md = 0; + +int +main () +{ + + p = gettext( "foo" ); + dir = bindtextdomain( "foo" , "bar" ); + md = textdomain( "foo" ); + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_link "$LINENO"; then : + gconfig_cv_gettext=yes +else + gconfig_cv_gettext=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_gettext" >&5 +$as_echo "$gconfig_cv_gettext" >&6; } + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for gmtime_r" >&5 $as_echo_n "checking for gmtime_r... " >&6; } if ${gconfig_cv_gmtime_r+:} false; then : @@ -8794,6 +8337,7 @@ else /* end confdefs.h. */ #include + #include sigset_t set ; int rc ; @@ -8803,7 +8347,7 @@ main () sigemptyset( &set ) ; sigaddset( &set , SIGTERM ) ; - rc = sigprocmask( SIG_BLOCK|SIG_UNBLOCK|SIG_SETMASK , &set , &set ) ; + rc = sigprocmask( SIG_BLOCK|SIG_UNBLOCK|SIG_SETMASK , &set , NULL ) ; ; return 0; @@ -8839,6 +8383,7 @@ else /* end confdefs.h. */ #include + #include sigset_t set ; int rc ; @@ -8848,7 +8393,7 @@ main () sigemptyset( &set ) ; sigaddset( &set , SIGTERM ) ; - rc = pthread_sigmask( SIG_BLOCK|SIG_UNBLOCK|SIG_SETMASK , &set , &set ) ; + rc = pthread_sigmask( SIG_BLOCK|SIG_UNBLOCK|SIG_SETMASK , &set , NULL ) ; ; return 0; @@ -9041,6 +8586,8 @@ $as_echo "#define GCONFIG_HAVE_WINDOWS_INIT_COMMON_CONTROLS_EX 0" >>confdefs.h + +# if the configure script fails in this area then you are probably missing pkg.m4 @@ -9162,7 +8709,8 @@ $as_echo "no" >&6; } fi fi - # try pkg-config + + # try pkg-config -- this says 'checking for QT' pkg_failed=no { $as_echo "$as_me:${as_lineno-$LINENO}: checking for QT" >&5 @@ -9248,23 +8796,36 @@ $as_echo "yes" >&6; } fi # allow the moc command to be defined with QT_MOC on the configure - # command-line, typically with CXXFLAGS and LIBS pointing to Qt + # command-line, typically also with CXXFLAGS and LIBS pointing to Qt # headers and libraries + if echo "$QT_MOC" | grep -q / + then + QT_LRELEASE="`dirname \"$QT_MOC\"`/lrelease" + else + QT_LRELEASE="lrelease" + fi + # or build the moc command using pkg-config results if test "$QT_MOC" = "" then if test "$gconfig_pkgconfig_qt" = "yes" then QT_MOC="`$PKG_CONFIG --variable=host_bins Qt5Core`/moc" + QT_LRELEASE="`$PKG_CONFIG --variable=host_bins Qt5Core`/lrelease" QT_CHOOSER="`$PKG_CONFIG --variable=exec_prefix Qt5Core`/bin/qtchooser" if test -x "$QT_MOC" ; then : ; else QT_MOC="" ; fi + if test -x "$QT_LRELEASE" ; then : ; else QT_LRELEASE="" ; fi if test -x "$QT_CHOOSER" ; then : ; else QT_CHOOSER="" ; fi if test "$QT_MOC" = "" -a "$QT_CHOOSER" != "" then QT_MOC="$QT_CHOOSER -run-tool=moc -qt=qt5" fi + if test "$QT_LRELEASE" = "" -a "$QT_CHOOSER" != "" + then + QT_LRELEASE="$QT_CHOOSER -run-tool=lrelease -qt=qt5" + fi fi fi @@ -9313,6 +8874,60 @@ fi fi + if test "$QT_LRELEASE" = "" + then + # Extract the first word of "lrelease", so it can be a program name with args. +set dummy lrelease; ac_word=$2 +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 +$as_echo_n "checking for $ac_word... " >&6; } +if ${ac_cv_path_QT_LRELEASE+:} false; then : + $as_echo_n "(cached) " >&6 +else + case $QT_LRELEASE in + [\\/]* | ?:[\\/]*) + ac_cv_path_QT_LRELEASE="$QT_LRELEASE" # Let the user override the test with a path. + ;; + *) + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then + ac_cv_path_QT_LRELEASE="$as_dir/$ac_word$ac_exec_ext" + $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done + done +IFS=$as_save_IFS + + ;; +esac +fi +QT_LRELEASE=$ac_cv_path_QT_LRELEASE +if test -n "$QT_LRELEASE"; then + { $as_echo "$as_me:${as_lineno-$LINENO}: result: $QT_LRELEASE" >&5 +$as_echo "$QT_LRELEASE" >&6; } +else + { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 +$as_echo "no" >&6; } +fi + + + if test "$QT_LRELEASE" = "" + then + QT_LRELEASE=false + fi + fi + + if test "$QT_MOC" != "" + then + { $as_echo "$as_me:${as_lineno-$LINENO}: QT moc command: $QT_MOC" >&5 +$as_echo "$as_me: QT moc command: $QT_MOC" >&6;} + fi + # set gconfig_have_qt, QT_CFLAGS and QT_LIBS iff we have a moc command if test "$QT_MOC" != "" then @@ -9337,6 +8952,57 @@ fi QT_LIBS="-F $QT_DIR/lib -framework QtWidgets -framework QtGui -framework QtCore" fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for QT compilation" >&5 +$as_echo_n "checking for QT compilation... " >&6; } +if ${gconfig_cv_qt_build+:} false; then : + $as_echo_n "(cached) " >&6 +else + + if test "$gconfig_have_qt" = "yes" + then + gconfig_save_LIBS="$LIBS" + gconfig_save_CXXFLAGS="$CXXFLAGS" + LIBS="$LIBS $QT_LIBS" + CXXFLAGS="$CXXFLAGS $QT_CFLAGS" + cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h. */ + + #include + #if QT_VERSION < 0x050000 + #error Qt is too old + #endif + #include + #include + #include + +int +main () +{ + + throw QSize(1,1).width() ; + + ; + return 0; +} +_ACEOF +if ac_fn_cxx_try_link "$LINENO"; then : + gconfig_cv_qt_build=yes +else + gconfig_cv_qt_build=no +fi +rm -f core conftest.err conftest.$ac_objext \ + conftest$ac_exeext conftest.$ac_ext + LIBS="$gconfig_save_LIBS" + CXXFLAGS="$gconfig_save_CXXFLAGS" + else + gconfig_cv_qt_build=no + fi + +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $gconfig_cv_qt_build" >&5 +$as_echo "$gconfig_cv_qt_build" >&6; } + gconfig_qt_build="$gconfig_cv_qt_build" + { $as_echo "$as_me:${as_lineno-$LINENO}: checking for openssl" >&5 $as_echo_n "checking for openssl... " >&6; } if ${gconfig_cv_ssl_openssl+:} false; then : @@ -9545,128 +9211,6 @@ $as_echo "#define GCONFIG_HAVE_MBEDTLS_NET_H 0" >>confdefs.h fi -# if the configure script fails in this area then you are probably missing pkg.m4 - - - - - - - -if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then - if test -n "$ac_tool_prefix"; then - # Extract the first word of "${ac_tool_prefix}pkg-config", so it can be a program name with args. -set dummy ${ac_tool_prefix}pkg-config; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_PKG_CONFIG+:} false; then : - $as_echo_n "(cached) " >&6 -else - case $PKG_CONFIG in - [\\/]* | ?:[\\/]*) - ac_cv_path_PKG_CONFIG="$PKG_CONFIG" # Let the user override the test with a path. - ;; - *) - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then - ac_cv_path_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - - ;; -esac -fi -PKG_CONFIG=$ac_cv_path_PKG_CONFIG -if test -n "$PKG_CONFIG"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $PKG_CONFIG" >&5 -$as_echo "$PKG_CONFIG" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - -fi -if test -z "$ac_cv_path_PKG_CONFIG"; then - ac_pt_PKG_CONFIG=$PKG_CONFIG - # Extract the first word of "pkg-config", so it can be a program name with args. -set dummy pkg-config; ac_word=$2 -{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 -$as_echo_n "checking for $ac_word... " >&6; } -if ${ac_cv_path_ac_pt_PKG_CONFIG+:} false; then : - $as_echo_n "(cached) " >&6 -else - case $ac_pt_PKG_CONFIG in - [\\/]* | ?:[\\/]*) - ac_cv_path_ac_pt_PKG_CONFIG="$ac_pt_PKG_CONFIG" # Let the user override the test with a path. - ;; - *) - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then - ac_cv_path_ac_pt_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext" - $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done - done -IFS=$as_save_IFS - - ;; -esac -fi -ac_pt_PKG_CONFIG=$ac_cv_path_ac_pt_PKG_CONFIG -if test -n "$ac_pt_PKG_CONFIG"; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_pt_PKG_CONFIG" >&5 -$as_echo "$ac_pt_PKG_CONFIG" >&6; } -else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } -fi - - if test "x$ac_pt_PKG_CONFIG" = x; then - PKG_CONFIG="" - else - case $cross_compiling:$ac_tool_warned in -yes:) -{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 -$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} -ac_tool_warned=yes ;; -esac - PKG_CONFIG=$ac_pt_PKG_CONFIG - fi -else - PKG_CONFIG="$ac_cv_path_PKG_CONFIG" -fi - -fi -if test -n "$PKG_CONFIG"; then - _pkg_min_version=0.9.0 - { $as_echo "$as_me:${as_lineno-$LINENO}: checking pkg-config is at least version $_pkg_min_version" >&5 -$as_echo_n "checking pkg-config is at least version $_pkg_min_version... " >&6; } - if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then - { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 -$as_echo "yes" >&6; } - else - { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5 -$as_echo "no" >&6; } - PKG_CONFIG="" - fi -fi - # Check whether --enable-bsd was given. if test "${enable_bsd+set}" = set; then : @@ -9748,30 +9292,36 @@ fi if test "$enable_gui" = "no" then - QT_MOC="" - fi - - if test "$enable_gui" = "yes" + gconfig_gui="no" + : + elif test "$enable_gui" = "yes" then + gconfig_gui="yes" if test "$gconfig_have_qt" = "no" then - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: ignoring --enable-gui: set QT_MOC to override" >&5 -$as_echo "$as_me: WARNING: ignoring --enable-gui: set QT_MOC to override" >&2;} - QT_MOC="" + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: gui enabled but no qt tools found" >&5 +$as_echo "$as_me: WARNING: gui enabled but no qt tools found" >&2;} + fi + if test "$gconfig_qt_build" = "no" + then + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: gui enabled but qt does not compile" >&5 +$as_echo "$as_me: WARNING: gui enabled but qt does not compile" >&2;} + fi + : + else + if test "$gconfig_have_qt" = "yes" -a "$gconfig_qt_build" = "yes" + then + gconfig_gui="yes" + else + gconfig_gui="no" fi fi - if test "$enable_gui" != "no" -a "$QT_MOC" = "" + if test "$gconfig_gui" = "no" -a "$enable_gui" != "no" then gconfig_warnings="$gconfig_warnings qt_graphical_user_interface" fi - if test "$QT_MOC" != "" - then - { $as_echo "$as_me:${as_lineno-$LINENO}: QT moc command: $QT_MOC" >&5 -$as_echo "$as_me: QT moc command: $QT_MOC" >&6;} - fi - GCONFIG_QT_LIBS=$QT_LIBS GCONFIG_QT_CFLAGS=$QT_CFLAGS @@ -9779,7 +9329,7 @@ $as_echo "$as_me: QT moc command: $QT_MOC" >&6;} GCONFIG_QT_MOC=$QT_MOC - if test "$QT_MOC" != ""; then + if test "$gconfig_gui" = "yes"; then GCONFIG_GUI_TRUE= GCONFIG_GUI_FALSE='#' else @@ -10005,14 +9555,21 @@ if test "${with_gettext+set}" = set; then : fi - if test "$with_gettext" = "yes" + if test "$with_gettext" = "no" then - gconfig_use_gettext="yes" - else - gconfig_use_gettext="no" + gconfig_cv_gettext="no" + : + elif test "$with_gettext" = "yes" + then + if test "$gconfig_cv_gettext" = "no" + then + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: forcing use of gettext even though not detected" >&5 +$as_echo "$as_me: WARNING: forcing use of gettext even though not detected" >&2;} + gconfig_cv_gettext="yes" + fi fi - if test "$gconfig_use_gettext" = "yes" ; then + if test "$gconfig_cv_gettext" = "yes" ; then $as_echo "#define GCONFIG_HAVE_GETTEXT 1" >>confdefs.h @@ -10021,6 +9578,14 @@ $as_echo "#define GCONFIG_HAVE_GETTEXT 1" >>confdefs.h $as_echo "#define GCONFIG_HAVE_GETTEXT 0" >>confdefs.h fi + if test "$gconfig_cv_gettext" = "yes"; then + GCONFIG_GETTEXT_TRUE= + GCONFIG_GETTEXT_FALSE='#' +else + GCONFIG_GETTEXT_TRUE='#' + GCONFIG_GETTEXT_FALSE= +fi + # Check whether --with-man2html was given. @@ -10080,6 +9645,8 @@ fi gconfig_ssl_notice="openssl and mbedtls" gconfig_ssl_use_none=no gconfig_ssl_use_both=yes + gconfig_ssl_use_openssl_only=no + gconfig_ssl_use_mbedtls_only=no GCONFIG_TLS_LIBS="$gconfig_ssl_mbedtls_libs $gconfig_ssl_openssl_libs" fi if test "$gconfig_ssl_use_openssl" = "yes" -a "$gconfig_ssl_use_mbedtls" = "no" @@ -10087,6 +9654,8 @@ fi gconfig_ssl_notice="openssl" gconfig_ssl_use_none=no gconfig_ssl_use_both=no + gconfig_ssl_use_openssl_only=yes + gconfig_ssl_use_mbedtls_only=no GCONFIG_TLS_LIBS="$gconfig_ssl_openssl_libs" fi if test "$gconfig_ssl_use_openssl" = "no" -a "$gconfig_ssl_use_mbedtls" = "yes" @@ -10094,6 +9663,8 @@ fi gconfig_ssl_notice="mbedtls" gconfig_ssl_use_none=no gconfig_ssl_use_both=no + gconfig_ssl_use_openssl_only=no + gconfig_ssl_use_mbedtls_only=yes GCONFIG_TLS_LIBS="$gconfig_ssl_mbedtls_libs" fi if test "$gconfig_ssl_use_openssl" = "no" -a "$gconfig_ssl_use_mbedtls" = "no" @@ -10101,6 +9672,8 @@ fi gconfig_ssl_notice="none" gconfig_ssl_use_none=yes gconfig_ssl_use_both=no + gconfig_ssl_use_openssl_only=no + gconfig_ssl_use_mbedtls_only=no GCONFIG_TLS_LIBS="" fi @@ -10118,7 +9691,7 @@ else GCONFIG_TLS_USE_BOTH_FALSE= fi - if test "$gconfig_ssl_use_openssl" = "yes"; then + if test "$gconfig_ssl_use_openssl_only" = "yes"; then GCONFIG_TLS_USE_OPENSSL_TRUE= GCONFIG_TLS_USE_OPENSSL_FALSE='#' else @@ -10126,7 +9699,7 @@ else GCONFIG_TLS_USE_OPENSSL_FALSE= fi - if test "$gconfig_ssl_use_mbedtls" = "yes"; then + if test "$gconfig_ssl_use_mbedtls_only" = "yes"; then GCONFIG_TLS_USE_MBEDTLS_TRUE= GCONFIG_TLS_USE_MBEDTLS_FALSE='#' else @@ -10491,6 +10064,40 @@ fi +# Check whether --with-uds was given. +if test "${with_uds+set}" = set; then : + withval=$with_uds; +fi + + + + if test "$with_uds" = "no" + then + if false; then + GCONFIG_UDS_TRUE= + GCONFIG_UDS_FALSE='#' +else + GCONFIG_UDS_TRUE='#' + GCONFIG_UDS_FALSE= +fi + + else + if test "$with_uds" = "yes" -a "$gconfig_cv_uds" = "no" + then + { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: forcing use of unix domain sockets even though not detected" >&5 +$as_echo "$as_me: WARNING: forcing use of unix domain sockets even though not detected" >&2;} + fi + if true; then + GCONFIG_UDS_TRUE= + GCONFIG_UDS_FALSE='#' +else + GCONFIG_UDS_TRUE='#' + GCONFIG_UDS_FALSE= +fi + + fi + + if test "$e_libexecdir" = "" then @@ -10537,6 +10144,10 @@ fi then e_icondir="$datadir/$PACKAGE" fi + if test "$e_trdir" = "" + then + e_trdir="$datadir/$PACKAGE" + fi if test "$e_rundir" = "" then # (linux fhs says "/run", not "/var/run") @@ -10562,6 +10173,7 @@ fi + ac_config_files="$ac_config_files Makefile src/Makefile src/glib/Makefile src/gssl/Makefile src/gnet/Makefile src/gauth/Makefile src/gsmtp/Makefile src/gpop/Makefile src/main/Makefile src/main/icon/Makefile src/win32/Makefile src/gui/Makefile bin/Makefile doc/Makefile etc/Makefile test/Makefile test/certificates/Makefile m4/Makefile bsd/Makefile debian/Makefile po/Makefile" cat >confcache <<\_ACEOF @@ -10741,6 +10353,10 @@ if test -z "${GCONFIG_WINDOWS_TRUE}" && test -z "${GCONFIG_WINDOWS_FALSE}"; then as_fn_error $? "conditional \"GCONFIG_WINDOWS\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi +if test -z "${GCONFIG_GETTEXT_TRUE}" && test -z "${GCONFIG_GETTEXT_FALSE}"; then + as_fn_error $? "conditional \"GCONFIG_GETTEXT\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi if test -z "${GCONFIG_TLS_USE_BOTH_TRUE}" && test -z "${GCONFIG_TLS_USE_BOTH_FALSE}"; then as_fn_error $? "conditional \"GCONFIG_TLS_USE_BOTH\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 @@ -10761,6 +10377,14 @@ if test -z "${GCONFIG_PAM_TRUE}" && test -z "${GCONFIG_PAM_FALSE}"; then as_fn_error $? "conditional \"GCONFIG_PAM\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi +if test -z "${GCONFIG_UDS_TRUE}" && test -z "${GCONFIG_UDS_FALSE}"; then + as_fn_error $? "conditional \"GCONFIG_UDS\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi +if test -z "${GCONFIG_UDS_TRUE}" && test -z "${GCONFIG_UDS_FALSE}"; then + as_fn_error $? "conditional \"GCONFIG_UDS\" was never defined. +Usually this means the macro was only invoked conditionally." "$LINENO" 5 +fi : "${CONFIG_STATUS=./config.status}" ac_write_fail=0 @@ -11158,7 +10782,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" -This file was extended by E-MailRelay $as_me 2.2, which was +This file was extended by E-MailRelay $as_me 2.2.1, which was generated by GNU Autoconf 2.69. Invocation command line was CONFIG_FILES = $CONFIG_FILES @@ -11224,7 +10848,7 @@ _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" ac_cs_version="\\ -E-MailRelay config.status 2.2 +E-MailRelay config.status 2.2.1 configured by $0, generated by GNU Autoconf 2.69, with options \\"\$ac_cs_config\\" @@ -11343,7 +10967,7 @@ cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 # # INIT-COMMANDS # -AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir" +AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}" _ACEOF @@ -11353,7 +10977,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 for ac_config_target in $ac_config_targets do case $ac_config_target in - "gconfig_defs.h") CONFIG_HEADERS="$CONFIG_HEADERS gconfig_defs.h" ;; + "src/gconfig_defs.h") CONFIG_HEADERS="$CONFIG_HEADERS src/gconfig_defs.h" ;; "depfiles") CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; "Makefile") CONFIG_FILES="$CONFIG_FILES Makefile" ;; "src/Makefile") CONFIG_FILES="$CONFIG_FILES src/Makefile" ;; @@ -11975,29 +11599,35 @@ $as_echo "$as_me: executing $ac_file commands" >&6;} # Older Autoconf quotes --file arguments for eval, but not when files # are listed without --file. Let's play safe and only enable the eval # if we detect the quoting. - case $CONFIG_FILES in - *\'*) eval set x "$CONFIG_FILES" ;; - *) set x $CONFIG_FILES ;; - esac + # TODO: see whether this extra hack can be removed once we start + # requiring Autoconf 2.70 or later. + case $CONFIG_FILES in #( + *\'*) : + eval set x "$CONFIG_FILES" ;; #( + *) : + set x $CONFIG_FILES ;; #( + *) : + ;; +esac shift - for mf + # Used to flag and report bootstrapping failures. + am_rc=0 + for am_mf do # Strip MF so we end up with the name of the file. - mf=`echo "$mf" | sed -e 's/:.*$//'` - # Check whether this is an Automake generated Makefile or not. - # We used to match only the files named 'Makefile.in', but - # some people rename them; so instead we look at the file content. - # Grep'ing the first line is not enough: some people post-process - # each Makefile.in and add a new line on top of each file to say so. - # Grep'ing the whole file is not good either: AIX grep has a line + am_mf=`$as_echo "$am_mf" | sed -e 's/:.*$//'` + # Check whether this is an Automake generated Makefile which includes + # dependency-tracking related rules and includes. + # Grep'ing the whole file directly is not great: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. - if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then - dirpart=`$as_dirname -- "$mf" || -$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$mf" : 'X\(//\)[^/]' \| \ - X"$mf" : 'X\(//\)$' \| \ - X"$mf" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X"$mf" | + sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \ + || continue + am_dirpart=`$as_dirname -- "$am_mf" || +$as_expr X"$am_mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$am_mf" : 'X\(//\)[^/]' \| \ + X"$am_mf" : 'X\(//\)$' \| \ + X"$am_mf" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X"$am_mf" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q @@ -12015,53 +11645,48 @@ $as_echo X"$mf" | q } s/.*/./; q'` - else - continue - fi - # Extract the definition of DEPDIR, am__include, and am__quote - # from the Makefile without running 'make'. - DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"` - test -z "$DEPDIR" && continue - am__include=`sed -n 's/^am__include = //p' < "$mf"` - test -z "$am__include" && continue - am__quote=`sed -n 's/^am__quote = //p' < "$mf"` - # Find all dependency output files, they are included files with - # $(DEPDIR) in their names. We invoke sed twice because it is the - # simplest approach to changing $(DEPDIR) to its actual value in the - # expansion. - for file in `sed -n " - s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \ - sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do - # Make sure the directory exists. - test -f "$dirpart/$file" && continue - fdir=`$as_dirname -- "$file" || -$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X"$file" : 'X\(//\)[^/]' \| \ - X"$file" : 'X\(//\)$' \| \ - X"$file" : 'X\(/\)' \| . 2>/dev/null || -$as_echo X"$file" | - sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ + am_filepart=`$as_basename -- "$am_mf" || +$as_expr X/"$am_mf" : '.*/\([^/][^/]*\)/*$' \| \ + X"$am_mf" : 'X\(//\)$' \| \ + X"$am_mf" : 'X\(/\)' \| . 2>/dev/null || +$as_echo X/"$am_mf" | + sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/ q } - /^X\(\/\/\)[^/].*/{ + /^X\/\(\/\/\)$/{ s//\1/ q } - /^X\(\/\/\)$/{ - s//\1/ - q - } - /^X\(\/\).*/{ + /^X\/\(\/\).*/{ s//\1/ q } s/.*/./; q'` - as_dir=$dirpart/$fdir; as_fn_mkdir_p - # echo "creating $dirpart/$file" - echo '# dummy' > "$dirpart/$file" - done + { echo "$as_me:$LINENO: cd "$am_dirpart" \ + && sed -e '/# am--include-marker/d' "$am_filepart" \ + | $MAKE -f - am--depfiles" >&5 + (cd "$am_dirpart" \ + && sed -e '/# am--include-marker/d' "$am_filepart" \ + | $MAKE -f - am--depfiles) >&5 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } || am_rc=$? done + if test $am_rc -ne 0; then + { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 +$as_echo "$as_me: error: in \`$ac_pwd':" >&2;} +as_fn_error $? "Something went wrong bootstrapping makefile fragments + for automatic dependency tracking. Try re-running configure with the + '--disable-dependency-tracking' option to at least be able to build + the package (albeit without support for automatic dependency tracking). +See \`config.log' for more details" "$LINENO" 5; } + fi + { am_dirpart=; unset am_dirpart;} + { am_filepart=; unset am_filepart;} + { am_mf=; unset am_mf;} + { am_rc=; unset am_rc;} + rm -f conftest-deps.mk } ;; diff --git a/configure.ac b/configure.ac old mode 100644 new mode 100755 index 79ca098..d04917d --- a/configure.ac +++ b/configure.ac @@ -19,11 +19,11 @@ dnl dnl Process this file with autoconf to produce a configure script. dnl -AC_INIT([E-MailRelay],[2.2],[],[emailrelay]) +AC_INIT([E-MailRelay],[2.2.1],[],[emailrelay]) AC_CONFIG_SRCDIR([src/glib/gdef.h]) AC_CONFIG_MACRO_DIR([m4]) AM_INIT_AUTOMAKE([no-define]) -AC_CONFIG_HEADERS([gconfig_defs.h]) +AC_CONFIG_HEADERS([src/gconfig_defs.h]) AM_MAINTAINER_MODE AC_DISABLE_OPTION_CHECKING @@ -59,17 +59,18 @@ GCONFIG_FN_CHECK_CXX GCONFIG_FN_CHECK_NET GCONFIG_FN_CHECK_FUNCTIONS -dnl check for packages -dnl -GCONFIG_FN_QT -GCONFIG_FN_TLS_OPENSSL -GCONFIG_FN_TLS_MBEDTLS - dnl initialise aclocal/pkg.m4 dnl # if the configure script fails in this area then you are probably missing pkg.m4 PKG_PROG_PKG_CONFIG([0.9.0]) +dnl check for packages +dnl +GCONFIG_FN_QT +GCONFIG_FN_QT_BUILD +GCONFIG_FN_TLS_OPENSSL +GCONFIG_FN_TLS_MBEDTLS + dnl possibly enable full gettext support -- uncomment this after running dnl 'gettextize' and remove the other gettext lines below dnl @@ -115,6 +116,8 @@ AC_ARG_WITH([mbedtls],AS_HELP_STRING([--with-mbedtls],[use mbedtls for tls layer GCONFIG_FN_TLS AC_ARG_WITH([pam],AS_HELP_STRING([--with-pam],[use linux pam for authentication (default auto)])) GCONFIG_FN_WITH_PAM +AC_ARG_WITH([uds],AS_HELP_STRING([--with-uds],[enable unix domain sockets (default auto)])) +GCONFIG_FN_WITH_UDS dnl directory tweaking -- define e_ prefixed directory variables dnl diff --git a/configure.sh b/configure.sh index 274bb61..a26b2d1 100755 --- a/configure.sh +++ b/configure.sh @@ -22,13 +22,15 @@ # directories depending on the host environment and simplifies # cross-compilation. # -# usage: configure.sh [-g] [{-d|-s <>}] [{-o|-m|-p}] -- [] -# -d add debug compiler flags -# -s add sanitiser compiler flags (eg. -s address) -# -o cross-compile for openwrt (edit as required) -# -m cross-compile for windows with mingw-w64 -# -p cross-compile for rpi -# -g git-clone mbedtls +# usage: configure.sh [-g] [{-d|-s <>}] [{-o|-w|-p}] -- [] +# -d add debug compiler flags +# -s add sanitiser compiler flags (eg. -s address) +# -o cross-compile for openwrt (edit as required) +# -w cross-compile for windows 32-bit with mingw-w64 +# -w32 cross-compile for windows 32-bit with mingw-w64 +# -w64 cross-compile for windows 64-bit with mingw-w64 +# -p cross-compile for rpi +# -g git-clone mbedtls and exit # # For systemd add "e_systemddir=/usr/lib/systemd/system". # @@ -39,16 +41,18 @@ thisdir="`cd \`dirname $0\` && pwd`" -usage="[-g] [{-d|-s <>}] [{-o|-m|-p}] -- " +usage="[-g] [{-d|-s <>}] [{-o|-w|-p}] -- " while expr "x$1" : "x-" >/dev/null do valued=0 - case "`echo \"$1\" | sed 's/^-//'`" in + case "`echo \"$1\" | sed 's/^--*//'`" in g) opt_git=1 ;; d) opt_debug=1 ;; s) opt_sanitise="$2" ; valued=1 ;; o) opt_openwrt=1 ;; - m) opt_mingw=1 ;; + w) opt_mingw=1 ; opt_win=32 ;; + w32) opt_mingw=1 ; opt_win=32 ;; + w64) opt_mingw=1 ; opt_win=64 ;; p) opt_rpi=1 ;; h) echo usage: `basename $0` $usage "..." ; $thisdir/configure --help=short ; exit 0 ;; #\?) echo usage: `basename $0` $usage >&2 ; exit 2 ;; @@ -71,6 +75,14 @@ fi if test "0$opt_git" -eq 1 then git clone https://salsa.debian.org/debian/mbedtls.git + e="$?" + sed -i 's/defined._TRUNCATE./0/' mbedtls/library/platform.c + if test "$e" -eq 0 -a "0$opt_mingw" -eq 0 + then + echo build with... + echo " make -C mbedtls/library WINDOWS=0" + fi + exit "$e" fi enable_debug="" @@ -114,7 +126,12 @@ fi if test "0$opt_mingw" -eq 1 then - TARGET="i686-w64-mingw32" + if test "$opt_win" -eq 32 + then + TARGET="i686-w64-mingw32" # 32-bit binaries + else + TARGET="x86_64-w64-mingw32" # 64-bit binaries + fi export CXX="$TARGET-g++-posix" export CC="$TARGET-gcc-posix" export AR="$TARGET-ar" diff --git a/debian/Makefile.in b/debian/Makefile.in index 1d086f6..05c388a 100644 --- a/debian/Makefile.in +++ b/debian/Makefile.in @@ -1,7 +1,7 @@ -# Makefile.in generated by automake 1.15 from Makefile.am. +# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ -# Copyright (C) 1994-2014 Free Software Foundation, Inc. +# Copyright (C) 1994-2018 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -98,7 +98,7 @@ am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d -CONFIG_HEADER = $(top_builddir)/gconfig_defs.h +CONFIG_HEADER = $(top_builddir)/src/gconfig_defs.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) @@ -185,6 +185,7 @@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ QT_CFLAGS = @QT_CFLAGS@ QT_LIBS = @QT_LIBS@ +QT_LRELEASE = @QT_LRELEASE@ QT_MOC = @QT_MOC@ RANLIB = @RANLIB@ SED = @SED@ @@ -221,6 +222,7 @@ e_rundir = @e_rundir@ e_spooldir = @e_spooldir@ e_sysconfdir = @e_sysconfdir@ e_systemddir = @e_systemddir@ +e_trdir = @e_trdir@ exec_prefix = @exec_prefix@ host_alias = @host_alias@ htmldir = @htmldir@ @@ -281,8 +283,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ + echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) @@ -300,7 +302,10 @@ ctags CTAGS: cscope cscopelist: -distdir: $(DISTFILES) +distdir: $(BUILT_SOURCES) + $(MAKE) $(AM_MAKEFLAGS) distdir-am + +distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ diff --git a/debian/changelog b/debian/changelog index 802f1c3..293fd35 100644 --- a/debian/changelog +++ b/debian/changelog @@ -1,3 +1,10 @@ +emailrelay (2.2.1) unstable; urgency=low + * Unix domain sockets supported (eg. "--interface=/tmp/smtp.s"). + * Windows event log not used for verbose logging (prefer "--log-file"). + * New admin 'forward' command to trigger forwarding without waiting. + * Support for MbedTLS version 3. + -- maintainer graeme_walker Tue, 14 Feb 2022 00:00:00 +0000 + emailrelay (2.2) unstable; urgency=low * Connections from IPv4 'private use' addresses are allowed by default (see "--remote-clients"). * Interface names can be used with "--interface" (eg. "--interface=eth0"). diff --git a/debian/emailrelay.service b/debian/emailrelay.service index da16a1e..52a519e 100644 --- a/debian/emailrelay.service +++ b/debian/emailrelay.service @@ -12,3 +12,7 @@ ExecStart=/etc/init.d/emailrelay start ExecStop=/etc/init.d/emailrelay stop PIDFile=/run/emailrelay/emailrelay.pid SuccessExitStatus=0 143 + +[Install] +WantedBy=multi-user.target + diff --git a/debian/postinst b/debian/postinst old mode 100755 new mode 100644 diff --git a/debian/postrm b/debian/postrm old mode 100755 new mode 100644 diff --git a/debian/preinst b/debian/preinst old mode 100755 new mode 100644 diff --git a/debian/prerm b/debian/prerm old mode 100755 new mode 100644 diff --git a/doc/Makefile.in b/doc/Makefile.in index 3b774fb..5557800 100644 --- a/doc/Makefile.in +++ b/doc/Makefile.in @@ -1,7 +1,7 @@ -# Makefile.in generated by automake 1.15 from Makefile.am. +# Makefile.in generated by automake 1.16.1 from Makefile.am. # @configure_input@ -# Copyright (C) 1994-2014 Free Software Foundation, Inc. +# Copyright (C) 1994-2018 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -100,7 +100,7 @@ am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d -CONFIG_HEADER = $(top_builddir)/gconfig_defs.h +CONFIG_HEADER = $(top_builddir)/src/gconfig_defs.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = SCRIPTS = $(noinst_SCRIPTS) @@ -220,6 +220,7 @@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ QT_CFLAGS = @QT_CFLAGS@ QT_LIBS = @QT_LIBS@ +QT_LRELEASE = @QT_LRELEASE@ QT_MOC = @QT_MOC@ RANLIB = @RANLIB@ SED = @SED@ @@ -256,6 +257,7 @@ e_rundir = @e_rundir@ e_spooldir = @e_spooldir@ e_sysconfdir = @e_sysconfdir@ e_systemddir = @e_systemddir@ +e_trdir = @e_trdir@ exec_prefix = @exec_prefix@ host_alias = @host_alias@ htmldir = @htmldir@ @@ -372,8 +374,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ - echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \ - cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \ + echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ + cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) @@ -453,7 +455,10 @@ ctags CTAGS: cscope cscopelist: -distdir: $(DISTFILES) +distdir: $(BUILT_SOURCES) + $(MAKE) $(AM_MAKEFLAGS) distdir-am + +distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ diff --git a/doc/changelog.html b/doc/changelog.html index 004af99..a11da41 100644 --- a/doc/changelog.html +++ b/doc/changelog.html @@ -8,8 +8,15 @@
-

E-MailRelay Change Log

-

2.1 -> 2.2

+

E-MailRelay Change Log

+

2.2 -> 2.2.1

+
    +
  • Unix domain sockets supported (eg. --interface=/tmp/smtp.s.
  • +
  • Windows event log not used for verbose logging (prefer --log-file).
  • +
  • New admin forward command to trigger forwarding without waiting.
  • +
  • Support for MbedTLS version 3.
  • +
+

2.1 -> 2.2

  • Connections from IPv4 'private use' addresses are allowed by default (see --remote-clients).
  • Interface names can be used with --interface (eg. --interface=eth0).
  • @@ -25,14 +32,14 @@
  • Support for Windows XP restored when built with mingw-w64.
  • C++ 2011 compiler is required.
-

2.0.1 -> 2.1

+

2.0.1 -> 2.1

  • Backwards compatibility features for 1.9-to-2.0 transition removed.
  • Better handling of too-many-connections on Windows.
  • New --idle-timeout option for server-side connections.
  • Support for RFC-5782 DNSBL blocking (--dnsbl).
  • Filter scripts are given the path of the envelope file in argv2.
  • -
  • Message files can be editied by --client-filter scripts.
  • +
  • Message files can be edited by --client-filter scripts.
  • Better support for CRAM-SHAx authentication.
  • New --client-auth-config and --server-auth-config options.
  • New --show option on windows to better control the user interface style.
  • @@ -42,11 +49,11 @@
  • Certificate contents are not logged.
  • Timestamp parts of spool filenames no longer limited to six digits.
-

2.0 -> 2.0.1

+

2.0 -> 2.0.1

  • Make PLAIN client authentication work against servers with broken 334 responses.
-

1.9.2 -> 2.0

+

1.9.2 -> 2.0

  • Improved IPv6 support, with IPv4 and IPv6 used independently at run-time (see --interface).
  • Server process is not blocked during --filter or --address-verifier execution, if multi-threaded.
  • @@ -77,7 +84,7 @@
  • C++ 2011 is preferred, and required for multi-threading.
  • Support for very old versions of Windows is dropped.
-

1.9.1 -> 1.9.2

+

1.9.1 -> 1.9.2

  • Fixed a leak in the event-loop garbage collection.
  • A local hostname that fails to resolve is not an error.
  • @@ -93,11 +100,11 @@
  • Qt4 or Qt5 selected by the configure script.
  • Improved the RPM spec file.
-

1.9 -> 1.9.1

+

1.9 -> 1.9.1

  • Updated OpenSSL from 1.0.1e to 1.0.1g in the Windows build.
-

1.8.2 -> 1.9

+

1.8.2 -> 1.9

  • Added negotiated TLS/SSL for POP (ie. STLS).
  • The first two fields in the secrets files are reordered (with backwards compatibility).
  • @@ -122,17 +129,17 @@
  • Added Windows --peer-lookup option.
  • Fix for MD5 code in 64-bit builds.
-

1.8.1 -> 1.8.2

+

1.8.1 -> 1.8.2

  • Fix namespaces for gcc 3.4.
-

1.8 -> 1.8.1

+

1.8 -> 1.8.1

  • Changed the definition of --as-proxy to use --poll 0 rather than --immediate [bug-id 1961652].
  • Fixed stalling bug when using server-side TLS/SSL (--server-tls) [bug-id 1961655].
  • Improved Debian packaging for Linux (make deb).
-

1.7 -> 1.8

+

1.7 -> 1.8

  • Speed optimisations (as identified by KCachegrind/valgrind in KDevelop).
  • Build-time size optimisations (eg. ./configure --disable-exec --enable-small-exceptions ...).
  • @@ -148,7 +155,7 @@
  • Improved native support for Mac OS X (10.5) with graphical installation from disk image.
  • Compatibility with gcc 2.95 restored.
-

1.6 -> 1.7

+

1.6 -> 1.7

  • TLS/SSL support for SMTP using OpenSSL (./configure --with-openssl with --client-tls and --server-tls).
  • Authentication mechanism PLAIN added.
  • @@ -156,7 +163,7 @@
  • Windows service wrapper has an --uninstall option.
  • Windows installation GUI uninstalls the service before reinstalling it.
-

1.5 -> 1.6

+

1.5 -> 1.6

  • GPLv3 licence (see http://gplv3.fsf.org).
  • New --prompt-timeout switch for the timeout when waiting for the initial 220 prompt from the SMTP server.
  • @@ -176,7 +183,7 @@
  • Experimental SpamAssassin spamc/spamd protocol support.
  • Acceptance tests added to the distribution.
-

1.4 -> 1.5

+

1.4 -> 1.5

  • New installation and configuration GUI using TrollTech Qt 4.x (./configure --enable-gui)
  • Default address verifier accepts all addresses as valid and never treats them as local mailboxes.
  • @@ -191,7 +198,7 @@
  • Documentation also created in docbook format (requires xmlto).
  • Windows installation document revised.
-

1.3.3 -> 1.4

+

1.3.3 -> 1.4

  • POP3 server (enable with --pop, disable at build-time with ./configure --disable-pop).
  • Fix for logging reentrancy bug (affects ./configure --enable-debug with --debug).
  • @@ -205,7 +212,7 @@
  • The --dont-listen switch is now --no-smtp.
  • Better IPv6 support (Linux only).
-

1.3.2 -> 1.3.3

+

1.3.2 -> 1.3.3

  • No bind() for outgoing connections [bug-id 1051689].
  • Updated rpm spec file [bug-id 1224850].
  • @@ -214,21 +221,21 @@
  • Documentation of auth switches corrected.
  • State-machine template type declaration modernised, possibly breaking older compilers.
-

1.3.1 -> 1.3.2

+

1.3.1 -> 1.3.2

  • Fix for core dump when --client-filter pre-processing fails.
  • Revised code structure to prepare for asynchronous pre-processing.
  • Better diagnostics when pre-processor exec() fails.
  • Better cleanup of empty and orphaned files.
-

1.3 -> 1.3.1

+

1.3 -> 1.3.1

  • Windows resource leak from CreateProcess() fixed.
  • Windows dialog box double-close fix.
  • Some documentation for the --scanner switch.
  • New usage patterns section in the user guide.
-

1.2 -> 1.3

+

1.2 -> 1.3

  • Client protocol waits for a greeting from the server on startup [bug-id 842156].
  • Fix for incorrect backslash normalisation on --verifier command-lines containing spaces [bug-id 890646].
  • @@ -241,7 +248,7 @@
  • New switches for the configure script.
  • More JavaScript example scripts.
-

1.1.2 -> 1.2

+

1.1.2 -> 1.2

  • The --filter and --verifier arguments interpreted as command-lines; spaces in executable paths now need escaping.
  • The --interface switch applies to outgoing connections too.
  • @@ -250,7 +257,7 @@
  • Fix for dangling reference bug, seen after quit command on Windows.
  • JavaScript examples in the documentation.
-

1.1.1 -> 1.1.2

+

1.1.1 -> 1.1.2

  • Earlier check for un-bindable ports on startup, and later fork()ing [bug-id 776972].
  • Resolved the file-descriptor kludge for --verifier on Windows.
  • @@ -259,7 +266,7 @@
  • Pre-processor (--filter) program's standard output searched for a failure reason string.
  • Undocumented --scanner switch added for asynchronous processing by a separate network server.
-

1.1.0 -> 1.1.1

+

1.1.0 -> 1.1.1

  • Restored the fix for building with gcc2.96.
  • Support for MinGW builds on Windows.
  • @@ -269,7 +276,7 @@
  • Fix for make install when man2html is not available.
  • Updated init script.
-

1.0.2 -> 1.1.0

+

1.0.2 -> 1.1.0

  • In proxy mode unexpected client-side disconnects and timeouts do not leave .bad files [see also bug-id 659039].
  • By default proxy mode does not interpret addresses for local delivery (--postmaster).
  • @@ -284,14 +291,14 @@
  • Support for Sun WorkShop 5.0 added.
  • Documentation overhaul.
-

1.0.0 -> 1.0.2

+

1.0.0 -> 1.0.2

  • Support for trusted IP addresses, allowing certain clients to avoid authentication.
  • Address verifier interface extended to include authentication information.
  • New public mail relay section added to the user guide.
  • Example verifier scripts etc. added to the reference guide.
-

1.0.0 -> 1.0.1

+

1.0.0 -> 1.0.1

  • In proxy mode unexpected client-side disconnects and timeouts result in .bad files [bug-id 659039].
  • Require successful AUTH before MAIL FROM when using --server-auth.
  • @@ -304,7 +311,7 @@
  • Fix build when using gcc2.96 rather than gcc2.95 (1.0.0-pl1).
  • Fix default spool directory in example scripts (1.0.0-pl1).
-

0.9.9 -> 1.0.0

+

0.9.9 -> 1.0.0

  • Briefer --help output; works with --verbose.
  • Option to listen on a specific network interface (--interface).
  • @@ -317,7 +324,7 @@
  • EHLO response parsing is now case-insensitive [bug-id 561522].
  • Fewer missing-secrets warnings [bug-id 564987].
-

0.9.8 -> 0.9.9

+

0.9.8 -> 0.9.9

  • More flexible logging options (--verbose and --debug work better).
  • File Hierarchy Standard (FHS) option for configure (--enable-fhs).
  • @@ -333,14 +340,14 @@
  • Submit utility works under Windows. [rc2]
  • Improved Windows project files. [rc2]
-

0.9.7 -> 0.9.8

+

0.9.7 -> 0.9.8

  • Fix for running pre-processor (--filter) as root.
  • Ignore bogus AUTH=LOGIN lines in EHLO response.
  • Submit utility improved to work with mutt.
  • Installation of submit man page.
-

0.9.6 -> 0.9.7

+

0.9.6 -> 0.9.7

  • CRAM-MD5 authentication mechanism added.
  • Revoke root permissions at start up, and reclaim them when needed.
  • @@ -356,7 +363,7 @@
  • Submission utility emailrelay-submit added.
  • HTML4.0 compliant HTML documentation, using CSS.
-

0.9.5 -> 0.9.6

+

0.9.5 -> 0.9.6

  • SMTP AUTHentication extension -- LOGIN mechanism only.
  • Client-side protocol timeout.
  • @@ -366,7 +373,7 @@
  • Multiple hard-coded listening addresses supported at compile-time.
  • Fix for automatic reopening of stderr stream.
-

0.9.4 -> 0.9.5

+

0.9.4 -> 0.9.5

Windows fixes and improvements...

@@ -376,14 +383,14 @@
  • fix for content file deletion
  • fix for directory iterator
  • -

    0.9.3 -> 0.9.4

    +

    0.9.3 -> 0.9.4

    • Fixed memory leak when no --log switch.
    • Windows build is more gui and less command-line.
    • Info command added to the administration interface.
    • Doxygen files removed from binary RPM.
    -

    0.9.2 -> 0.9.3

    +

    0.9.2 -> 0.9.3

    • Proxy mode (--immediate and --as-proxy).
    • Message pre-processing (--filter).
    • @@ -391,7 +398,7 @@
    • Improved notification script, with MIME encoding.
    • Builds with old 2.91 version of gcc.
    -

    0.9.1 -> 0.9.2

    +

    0.9.1 -> 0.9.2

    • Better autoconf detection.
    • Workround for FreeBSD uname() feature.
    • @@ -399,7 +406,7 @@
    • Fixed a benign directory iterator bug.
    • Use of gcc's exception header.
    -

    0.9 -> 0.9.1

    +

    0.9 -> 0.9.1

    • Improved documentation from doxygen.
    • More complete use of namespaces.
    • diff --git a/doc/changelog.md b/doc/changelog.md index af5f00f..398e380 100644 --- a/doc/changelog.md +++ b/doc/changelog.md @@ -1,6 +1,14 @@ E-MailRelay Change Log ====================== +2.2 -> 2.2.1 +------------ + +* Unix domain sockets supported (eg. `--interface=/tmp/smtp.s`). +* Windows event log not used for verbose logging (prefer `--log-file`). +* New admin `forward` command to trigger forwarding without waiting. +* Support for MbedTLS version 3. + 2.1 -> 2.2 ---------- diff --git a/doc/changelog.rst b/doc/changelog.rst index 82cf4a0..241978f 100644 --- a/doc/changelog.rst +++ b/doc/changelog.rst @@ -2,6 +2,14 @@ E-MailRelay Change Log ********************** +2.2 -> 2.2.1 +============ + +* Unix domain sockets supported (eg. *--interface=/tmp/smtp.s*). +* Windows event log not used for verbose logging (prefer *--log-file*). +* New admin *forward* command to trigger forwarding without waiting. +* Support for MbedTLS version 3. + 2.1 -> 2.2 ========== @@ -27,7 +35,7 @@ E-MailRelay Change Log * New *--idle-timeout* option for server-side connections. * Support for RFC-5782_ DNSBL_ blocking (\ *--dnsbl*\ ). * Filter scripts are given the path of the envelope file in argv2. -* Message files can be editied by *--client-filter* scripts. +* Message files can be edited by *--client-filter* scripts. * Better support for CRAM-SHAx authentication. * New *--client-auth-config* and *--server-auth-config* options. * New *--show* option on windows to better control the user interface style. diff --git a/doc/changelog.txt b/doc/changelog.txt index c6a0ad4..242e721 100644 --- a/doc/changelog.txt +++ b/doc/changelog.txt @@ -1,6 +1,13 @@ E-MailRelay Change Log ====================== +2.2 -> 2.2.1 +------------ +* Unix domain sockets supported (eg. "--interface=/tmp/smtp.s"). +* Windows event log not used for verbose logging (prefer "--log-file"). +* New admin "forward" command to trigger forwarding without waiting. +* Support for MbedTLS version 3. + 2.1 -> 2.2 ---------- * Connections from IPv4 'private use' addresses are allowed by default (see "--remote-clients"). @@ -24,7 +31,7 @@ E-MailRelay Change Log * New "--idle-timeout" option for server-side connections. * Support for RFC-5782 DNSBL blocking ("--dnsbl"). * Filter scripts are given the path of the envelope file in argv2. -* Message files can be editied by "--client-filter" scripts. +* Message files can be edited by "--client-filter" scripts. * Better support for CRAM-SHAx authentication. * New "--client-auth-config" and "--server-auth-config" options. * New "--show" option on windows to better control the user interface style. diff --git a/doc/emailrelay-man.html b/doc/emailrelay-man.html index 09fed71..24dd93d 100644 --- a/doc/emailrelay-man.html +++ b/doc/emailrelay-man.html @@ -366,8 +366,7 @@ Graeme Walker, mailto:graem
      This document was created by -
      man2html, +man2html, using the manual pages.
      - diff --git a/doc/reference.html b/doc/reference.html index 8403f3e..2c6df19 100644 --- a/doc/reference.html +++ b/doc/reference.html @@ -15,7 +15,7 @@

      -
      emailrelay [

      @@ -595,9 +595,9 @@ envelope="${2}" ip="`awk '/MailRelay-Client:/ {print $2;exit}' \"${envelope}\"`" if test "${ip}" = "192.168.0.2" then - /usr/sbin/sendmail -t < "${content}" + /usr/sbin/sendmail -t < "${content}" rm -f "${envelope}" "${content}" - exit 100 # <= cancel further processing by emailrelay + exit 100 # <= cancel further processing by emailrelay fi exit 0 @@ -1083,6 +1083,49 @@ password required pam_deny.so

      --as-client ipv4or6.example.com:25 --client-interface 0.0.0.0
       --as-client ipv4or6.example.com:25 --client-interface ::
    +

    Unix domain sockets

    +

    + E-MailRelay on Unix will listen on unix-domain sockets instead of IPv4 or IPv6 + if the --interface option is given as an absolute file-system path: +

    + +

    + Eg: +

    +
    +
    --interface=/run/smtp.s --port=0
    +
    +

    + When listening on more than one unix-domain socket use the extended form of the + "--interface" option with a prefix of "smtp=", "pop=", or "admin=": +

    +

    + Eg: +

    +
    +
    --interface=smtp=/run/smtp.s --port=0 --interface=pop=/run/pop.s --pop --pop-port=0
    +
    +

    + The forwarding address can also be a unix-domain address: +

    +

    + Eg: +

    +
    +
    --forward-to=/run/smtp.s
    +
    +

    + And it is also possible to communicate with message filters over a unix-domain + socket: +

    +

    + Eg: +

    +
    +
    --filter=net:/run/filter.s
    +--filter=spam:/run/spamd.s
    +--filter=spam-edit:/run/spamd.s
    +

    SOCKS

    E-MailRelay can use a SOCKS 4a proxy for establishing outgoing SMTP @@ -1167,7 +1210,7 @@ exit 1

    #!/bin/sh
     # address verifier -- accept as local (250)
    -echo Local Postmaster ''
    +echo Local Postmaster '<postmaster@localhost>'
     echo postmaster
     exit 0
     
    @@ -1229,7 +1272,7 @@ exit 100
    #!/bin/sh
     # address verifier -- accept only if containing an at sign
     address="$1"
    -expr "$address" : ".*@" > /dev/null || exit 2
    +expr "$address" : ".*@" > /dev/null || exit 2
     echo ""
     echo "$address"
     exit 1 # accept
    @@ -1444,13 +1487,14 @@ catch( e )
           
    $ emailrelay --as-server --port=125 --forward-to=localhost:25 --admin=10026
     $ telnet localhost 10026
    -E-MailRelay> help
    -E-MailRelay> quit
    +E-MailRelay> help
    +E-MailRelay> quit
     

    The flush command is used to get the E-MailRelay server to forward spooled - mail to the next SMTP server. + mail to the next SMTP server. The forward command does the same but without + waiting for completion.

    @@ -1497,6 +1541,7 @@ E-MailRelay> quit

  • e_docdir=<dir>
  • e_examplesdir=<dir>
  • e_icondir=<dir>
  • +
  • e_trdir=<dir>
  • e_initdir=<dir>
  • e_libexecdir=<dir>
  • e_pamdir=<dir>
  • diff --git a/doc/reference.md b/doc/reference.md index 25d3977..1da955c 100644 --- a/doc/reference.md +++ b/doc/reference.md @@ -210,7 +210,7 @@ where <option> is: * \-\-hidden (-H) Windows only. Hides the application window and disables all message boxes, - overriding any ``--show`` option. This is useful when running as a windows + overriding any `--show` option. This is useful when running as a windows service. * \-\-idle-timeout <time> @@ -895,6 +895,37 @@ Eg: --as-client ipv4or6.example.com:25 --client-interface 0.0.0.0 --as-client ipv4or6.example.com:25 --client-interface :: +Unix domain sockets +------------------- +E-MailRelay on Unix will listen on unix-domain sockets instead of IPv4 or IPv6 +if the `--interface` option is given as an absolute file-system path: + +Eg: + + --interface=/run/smtp.s --port=0 + +When listening on more than one unix-domain socket use the extended form of the +`--interface` option with a prefix of `smtp=`, `pop=`, or `admin=`: + +Eg: + + --interface=smtp=/run/smtp.s --port=0 --interface=pop=/run/pop.s --pop --pop-port=0 + +The forwarding address can also be a unix-domain address: + +Eg: + + --forward-to=/run/smtp.s + +And it is also possible to communicate with message filters over a unix-domain +socket: + +Eg: + + --filter=net:/run/filter.s + --filter=spam:/run/spamd.s + --filter=spam-edit:/run/spamd.s + SOCKS ----- E-MailRelay can use a [SOCKS][] 4a proxy for establishing outgoing SMTP @@ -1184,7 +1215,8 @@ simple command-line interface which is compatible with `netcat` and `telnet`: E-MailRelay> quit The `flush` command is used to get the E-MailRelay server to forward spooled -mail to the next SMTP server. +mail to the next SMTP server. The `forward` command does the same but without +waiting for completion. The `list` command lists the messages in the spool directory, `status` provides network status information and activity statistics, and `notify` enables @@ -1222,6 +1254,7 @@ Installation directories can be defined at build-time by the following * e_docdir=<dir> * e_examplesdir=<dir> * e_icondir=<dir> +* e_trdir=<dir> * e_initdir=<dir> * e_libexecdir=<dir> * e_pamdir=<dir> diff --git a/doc/reference.rst b/doc/reference.rst index c048e83..deb0950 100644 --- a/doc/reference.rst +++ b/doc/reference.rst @@ -213,7 +213,7 @@ where \ is: * --hidden (-H) Windows only. Hides the application window and disables all message boxes, - overriding any **--show** option. This is useful when running as a windows + overriding any *--show* option. This is useful when running as a windows service. * --idle-timeout \ @@ -938,6 +938,45 @@ Eg: --as-client ipv4or6.example.com:25 --client-interface 0.0.0.0 --as-client ipv4or6.example.com:25 --client-interface :: +Unix domain sockets +=================== +E-MailRelay on Unix will listen on unix-domain sockets instead of IPv4 or IPv6 +if the *--interface* option is given as an absolute file-system path: + +Eg: + +:: + + --interface=/run/smtp.s --port=0 + +When listening on more than one unix-domain socket use the extended form of the +*--interface* option with a prefix of *smtp=*, *pop=*, or *admin=*: + +Eg: + +:: + + --interface=smtp=/run/smtp.s --port=0 --interface=pop=/run/pop.s --pop --pop-port=0 + +The forwarding address can also be a unix-domain address: + +Eg: + +:: + + --forward-to=/run/smtp.s + +And it is also possible to communicate with message filters over a unix-domain +socket: + +Eg: + +:: + + --filter=net:/run/filter.s + --filter=spam:/run/spamd.s + --filter=spam-edit:/run/spamd.s + SOCKS ===== E-MailRelay can use a SOCKS_ 4a proxy for establishing outgoing SMTP @@ -1251,7 +1290,8 @@ simple command-line interface which is compatible with *netcat* and *telnet*: E-MailRelay> quit The *flush* command is used to get the E-MailRelay server to forward spooled -mail to the next SMTP server. +mail to the next SMTP server. The *forward* command does the same but without +waiting for completion. The *list* command lists the messages in the spool directory, *status* provides network status information and activity statistics, and *notify* enables @@ -1289,6 +1329,7 @@ Installation directories can be defined at build-time by the following * e_docdir=\ * e_examplesdir=\ * e_icondir=\ +* e_trdir=\ * e_initdir=\ * e_libexecdir=\ * e_pamdir=\ diff --git a/doc/reference.txt b/doc/reference.txt index 49715ca..1d6f335 100644 --- a/doc/reference.txt +++ b/doc/reference.txt @@ -178,7 +178,7 @@ where