diff options
| -rw-r--r-- | Makefile.in | 321 | ||||
| -rw-r--r-- | aclocal.m4 | 692 | ||||
| -rw-r--r-- | config.h.in | 3 | ||||
| -rwxr-xr-x | configure | 764 | ||||
| -rw-r--r-- | configure.ac | 2 | ||||
| -rw-r--r-- | lib/Makefile.in | 262 | ||||
| -rw-r--r-- | lib/farsync/Makefile.in | 101 | ||||
| -rw-r--r-- | src/DabMux.cpp | 54 | ||||
| -rw-r--r-- | src/DabMux.h | 2 | ||||
| -rw-r--r-- | src/Makefile.am | 8 | ||||
| -rw-r--r-- | src/Makefile.in | 366 | ||||
| -rw-r--r-- | src/MuxElements.h | 16 | ||||
| -rw-r--r-- | src/ParserCmdline.cpp | 26 | ||||
| -rw-r--r-- | src/ParserConfigfile.cpp | 29 | ||||
| -rw-r--r-- | src/dabOutput.cpp | 1112 | ||||
| -rw-r--r-- | src/dabOutput.h | 72 | ||||
| -rw-r--r-- | src/dabOutput/dabOutput.cpp | 109 | ||||
| -rw-r--r-- | src/dabOutput/dabOutput.h | 248 | ||||
| -rw-r--r-- | src/dabOutput/dabOutputFifo.cpp | 48 | ||||
| -rw-r--r-- | src/dabOutput/dabOutputFile.cpp | 111 | ||||
| -rw-r--r-- | src/dabOutput/dabOutputRaw.cpp | 366 | ||||
| -rw-r--r-- | src/dabOutput/dabOutputSimul.cpp | 70 | ||||
| -rw-r--r-- | src/dabOutput/dabOutputTcp.cpp | 154 | ||||
| -rw-r--r-- | src/dabOutput/dabOutputUdp.cpp | 82 | ||||
| -rw-r--r-- | src/utils.cpp | 4 | 
25 files changed, 2701 insertions, 2321 deletions
| diff --git a/Makefile.in b/Makefile.in index c317eed..e3ebd78 100644 --- a/Makefile.in +++ b/Makefile.in @@ -1,9 +1,8 @@ -# Makefile.in generated by automake 1.11.6 from Makefile.am. +# Makefile.in generated by automake 1.14 from Makefile.am.  # @configure_input@ -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Free Software -# Foundation, Inc. +# Copyright (C) 1994-2013 Free Software Foundation, Inc. +  # This Makefile.in 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. @@ -33,23 +32,51 @@  # You should have received a copy of the GNU General Public License  # along with CRC-DabMux.  If not, see <http://www.gnu.org/licenses/>.  VPATH = @srcdir@ -am__make_dryrun = \ -  { \ -    am__dry=no; \ +am__is_gnu_make = test -n '$(MAKEFILE_LIST)' && test -n '$(MAKELEVEL)' +am__make_running_with_option = \ +  case $${target_option-} in \ +      ?) ;; \ +      *) echo "am__make_running_with_option: internal error: invalid" \ +              "target option '$${target_option-}' specified" >&2; \ +         exit 1;; \ +  esac; \ +  has_opt=no; \ +  sane_makeflags=$$MAKEFLAGS; \ +  if $(am__is_gnu_make); then \ +    sane_makeflags=$$MFLAGS; \ +  else \      case $$MAKEFLAGS in \        *\\[\ \	]*) \ -        echo 'am--echo: ; @echo "AM"  OK' | $(MAKE) -f - 2>/dev/null \ -          | grep '^AM OK$$' >/dev/null || am__dry=yes;; \ -      *) \ -        for am__flg in $$MAKEFLAGS; do \ -          case $$am__flg in \ -            *=*|--*) ;; \ -            *n*) am__dry=yes; break;; \ -          esac; \ -        done;; \ +        bs=\\; \ +        sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ +          | sed "s/$$bs$$bs[$$bs $$bs	]*//g"`;; \ +    esac; \ +  fi; \ +  skip_next=no; \ +  strip_trailopt () \ +  { \ +    flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ +  }; \ +  for flg in $$sane_makeflags; do \ +    test $$skip_next = yes && { skip_next=no; continue; }; \ +    case $$flg in \ +      *=*|--*) continue;; \ +        -*I) strip_trailopt 'I'; skip_next=yes;; \ +      -*I?*) strip_trailopt 'I';; \ +        -*O) strip_trailopt 'O'; skip_next=yes;; \ +      -*O?*) strip_trailopt 'O';; \ +        -*l) strip_trailopt 'l'; skip_next=yes;; \ +      -*l?*) strip_trailopt 'l';; \ +      -[dEDm]) skip_next=yes;; \ +      -[JT]) skip_next=yes;; \      esac; \ -    test $$am__dry = yes; \ -  } +    case $$flg in \ +      *$$target_option*) has_opt=yes; break;; \ +    esac; \ +  done; \ +  test $$has_opt = yes +am__make_dryrun = (target_option=n; $(am__make_running_with_option)) +am__make_keepgoing = (target_option=k; $(am__make_running_with_option))  pkgdatadir = $(datadir)/@PACKAGE@  pkgincludedir = $(includedir)/@PACKAGE@  pkglibdir = $(libdir)/@PACKAGE@ @@ -70,12 +97,17 @@ build_triplet = @build@  host_triplet = @host@  target_triplet = @target@  subdir = . -DIST_COMMON = README $(am__configure_deps) $(srcdir)/Makefile.am \ -	$(srcdir)/Makefile.in $(srcdir)/config.h.in \ -	$(top_srcdir)/configure AUTHORS COPYING ChangeLog INSTALL NEWS \ -	TODO build-aux/compile build-aux/config.guess \ -	build-aux/config.sub build-aux/depcomp build-aux/install-sh \ -	build-aux/missing +DIST_COMMON = INSTALL NEWS README AUTHORS ChangeLog \ +	$(srcdir)/Makefile.in $(srcdir)/Makefile.am \ +	$(top_srcdir)/configure $(am__configure_deps) \ +	$(srcdir)/config.h.in COPYING TODO build-aux/compile \ +	build-aux/config.guess build-aux/config.sub build-aux/depcomp \ +	build-aux/install-sh build-aux/missing \ +	$(top_srcdir)/build-aux/compile \ +	$(top_srcdir)/build-aux/config.guess \ +	$(top_srcdir)/build-aux/config.sub \ +	$(top_srcdir)/build-aux/install-sh \ +	$(top_srcdir)/build-aux/missing  ACLOCAL_M4 = $(top_srcdir)/aclocal.m4  am__aclocal_m4_deps = $(top_srcdir)/m4/ax_boost_base.m4 \  	$(top_srcdir)/configure.ac @@ -87,21 +119,28 @@ mkinstalldirs = $(install_sh) -d  CONFIG_HEADER = config.h  CONFIG_CLEAN_FILES =  CONFIG_CLEAN_VPATH_FILES = +AM_V_P = $(am__v_P_@AM_V@) +am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) +am__v_P_0 = false +am__v_P_1 = :  AM_V_GEN = $(am__v_GEN_@AM_V@)  am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) -am__v_GEN_0 = @echo "  GEN   " $@; +am__v_GEN_0 = @echo "  GEN     " $@; +am__v_GEN_1 =   AM_V_at = $(am__v_at_@AM_V@)  am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)  am__v_at_0 = @ +am__v_at_1 =   SOURCES =  DIST_SOURCES = -RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \ -	html-recursive info-recursive install-data-recursive \ -	install-dvi-recursive install-exec-recursive \ -	install-html-recursive install-info-recursive \ -	install-pdf-recursive install-ps-recursive install-recursive \ -	installcheck-recursive installdirs-recursive pdf-recursive \ -	ps-recursive uninstall-recursive +RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ +	ctags-recursive dvi-recursive html-recursive info-recursive \ +	install-data-recursive install-dvi-recursive \ +	install-exec-recursive install-html-recursive \ +	install-info-recursive install-pdf-recursive \ +	install-ps-recursive install-recursive installcheck-recursive \ +	installdirs-recursive pdf-recursive ps-recursive \ +	tags-recursive uninstall-recursive  am__can_run_installinfo = \    case $$AM_UPDATE_INFO_DIR in \      n|no|NO) false;; \ @@ -109,11 +148,33 @@ am__can_run_installinfo = \    esac  RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive	\    distclean-recursive maintainer-clean-recursive -AM_RECURSIVE_TARGETS = $(RECURSIVE_TARGETS:-recursive=) \ -	$(RECURSIVE_CLEAN_TARGETS:-recursive=) tags TAGS ctags CTAGS \ -	distdir dist dist-all distcheck +am__recursive_targets = \ +  $(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)config.h.in +# Read a list of newline-separated strings from the standard input, +# and print each of them once, without duplicates.  Input order is +# *not* preserved. +am__uniquify_input = $(AWK) '\ +  BEGIN { nonempty = 0; } \ +  { items[$$0] = 1; nonempty = 1; } \ +  END { if (nonempty) { for (i in items) print i; }; } \ +' +# Make sure the list of sources is unique.  This is necessary because, +# e.g., the same source file might be shared among _SOURCES variables +# for different programs/libraries. +am__define_uniq_tagged_files = \ +  list='$(am__tagged_files)'; \ +  unique=`for i in $$list; do \ +    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ +  done | $(am__uniquify_input)`  ETAGS = etags  CTAGS = ctags +CSCOPE = cscope  DIST_SUBDIRS = $(SUBDIRS)  DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)  distdir = $(PACKAGE)-$(VERSION) @@ -124,6 +185,7 @@ am__remove_distdir = \        && rm -rf "$(distdir)" \        || { sleep 5 && rm -rf "$(distdir)"; }; \    else :; fi +am__post_remove_distdir = $(am__remove_distdir)  am__relativize = \    dir0=`pwd`; \    sed_first='s,^\([^/]*\)/.*$$,\1,'; \ @@ -151,6 +213,7 @@ am__relativize = \    reldir="$$dir2"  DIST_ARCHIVES = $(distdir).tar.gz  GZIP_ENV = --best +DIST_TARGETS = dist-gzip  distuninstallcheck_listfiles = find . -type f -print  am__distuninstallcheck_listfiles = $(distuninstallcheck_listfiles) \    | sed 's|^\./|$(prefix)/|' | grep -v '$(infodir)/dir$$' @@ -308,8 +371,8 @@ $(ACLOCAL_M4):  $(am__aclocal_m4_deps)  $(am__aclocal_m4_deps):  config.h: stamp-h1 -	@if test ! -f $@; then rm -f stamp-h1; else :; fi -	@if test ! -f $@; then $(MAKE) $(AM_MAKEFLAGS) stamp-h1; else :; fi +	@test -f $@ || rm -f stamp-h1 +	@test -f $@ || $(MAKE) $(AM_MAKEFLAGS) stamp-h1  stamp-h1: $(srcdir)/config.h.in $(top_builddir)/config.status  	@rm -f stamp-h1 @@ -323,22 +386,25 @@ distclean-hdr:  	-rm -f config.h stamp-h1  # This directory's subdirectories are mostly independent; you can cd -# into them and run `make' without going through this Makefile. -# To change the values of `make' variables: instead of editing Makefiles, -# (1) if the variable is set in `config.status', edit `config.status' -#     (which will cause the Makefiles to be regenerated when you run `make'); -# (2) otherwise, pass the desired values on the `make' command line. -$(RECURSIVE_TARGETS): -	@fail= failcom='exit 1'; \ -	for f in x $$MAKEFLAGS; do \ -	  case $$f in \ -	    *=* | --[!k]*);; \ -	    *k*) failcom='fail=yes';; \ -	  esac; \ -	done; \ +# into them and run 'make' without going through this Makefile. +# To change the values of 'make' variables: instead of editing Makefiles, +# (1) if the variable is set in 'config.status', edit 'config.status' +#     (which will cause the Makefiles to be regenerated when you run 'make'); +# (2) otherwise, pass the desired values on the 'make' command line. +$(am__recursive_targets): +	@fail=; \ +	if $(am__make_keepgoing); then \ +	  failcom='fail=yes'; \ +	else \ +	  failcom='exit 1'; \ +	fi; \  	dot_seen=no; \  	target=`echo $@ | sed s/-recursive//`; \ -	list='$(SUBDIRS)'; for subdir in $$list; do \ +	case "$@" in \ +	  distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ +	  *) list='$(SUBDIRS)' ;; \ +	esac; \ +	for subdir in $$list; do \  	  echo "Making $$target in $$subdir"; \  	  if test "$$subdir" = "."; then \  	    dot_seen=yes; \ @@ -353,57 +419,12 @@ $(RECURSIVE_TARGETS):  	  $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \  	fi; test -z "$$fail" -$(RECURSIVE_CLEAN_TARGETS): -	@fail= failcom='exit 1'; \ -	for f in x $$MAKEFLAGS; do \ -	  case $$f in \ -	    *=* | --[!k]*);; \ -	    *k*) failcom='fail=yes';; \ -	  esac; \ -	done; \ -	dot_seen=no; \ -	case "$@" in \ -	  distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ -	  *) list='$(SUBDIRS)' ;; \ -	esac; \ -	rev=''; for subdir in $$list; do \ -	  if test "$$subdir" = "."; then :; else \ -	    rev="$$subdir $$rev"; \ -	  fi; \ -	done; \ -	rev="$$rev ."; \ -	target=`echo $@ | sed s/-recursive//`; \ -	for subdir in $$rev; do \ -	  echo "Making $$target in $$subdir"; \ -	  if test "$$subdir" = "."; then \ -	    local_target="$$target-am"; \ -	  else \ -	    local_target="$$target"; \ -	  fi; \ -	  ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ -	  || eval $$failcom; \ -	done && test -z "$$fail" -tags-recursive: -	list='$(SUBDIRS)'; for subdir in $$list; do \ -	  test "$$subdir" = . || ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \ -	done -ctags-recursive: -	list='$(SUBDIRS)'; for subdir in $$list; do \ -	  test "$$subdir" = . || ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \ -	done +ID: $(am__tagged_files) +	$(am__define_uniq_tagged_files); mkid -fID $$unique +tags: tags-recursive +TAGS: tags -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) -	list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ -	unique=`for i in $$list; do \ -	    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -	  done | \ -	  $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ -	      END { if (nonempty) { for (i in files) print i; }; }'`; \ -	mkid -fID $$unique -tags: TAGS - -TAGS: tags-recursive $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \ -		$(TAGS_FILES) $(LISP) +tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)  	set x; \  	here=`pwd`; \  	if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ @@ -419,12 +440,7 @@ TAGS: tags-recursive $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \  	      set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \  	  fi; \  	done; \ -	list='$(SOURCES) $(HEADERS) config.h.in $(LISP) $(TAGS_FILES)'; \ -	unique=`for i in $$list; do \ -	    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -	  done | \ -	  $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ -	      END { if (nonempty) { for (i in files) print i; }; }'`; \ +	$(am__define_uniq_tagged_files); \  	shift; \  	if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \  	  test -n "$$unique" || unique=$$empty_fix; \ @@ -436,15 +452,11 @@ TAGS: tags-recursive $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \  	      $$unique; \  	  fi; \  	fi -ctags: CTAGS -CTAGS: ctags-recursive $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \ -		$(TAGS_FILES) $(LISP) -	list='$(SOURCES) $(HEADERS) config.h.in $(LISP) $(TAGS_FILES)'; \ -	unique=`for i in $$list; do \ -	    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -	  done | \ -	  $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ -	      END { if (nonempty) { for (i in files) print i; }; }'`; \ +ctags: ctags-recursive + +CTAGS: ctags +ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) +	$(am__define_uniq_tagged_files); \  	test -z "$(CTAGS_ARGS)$$unique" \  	  || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \  	     $$unique @@ -453,9 +465,31 @@ GTAGS:  	here=`$(am__cd) $(top_builddir) && pwd` \  	  && $(am__cd) $(top_srcdir) \  	  && gtags -i $(GTAGS_ARGS) "$$here" +cscope: cscope.files +	test ! -s cscope.files \ +	  || $(CSCOPE) -b -q $(AM_CSCOPEFLAGS) $(CSCOPEFLAGS) -i cscope.files $(CSCOPE_ARGS) +clean-cscope: +	-rm -f cscope.files +cscope.files: clean-cscope cscopelist +cscopelist: cscopelist-recursive + +cscopelist-am: $(am__tagged_files) +	list='$(am__tagged_files)'; \ +	case "$(srcdir)" in \ +	  [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ +	  *) sdir=$(subdir)/$(srcdir) ;; \ +	esac; \ +	for i in $$list; do \ +	  if test -f "$$i"; then \ +	    echo "$(subdir)/$$i"; \ +	  else \ +	    echo "$$sdir/$$i"; \ +	  fi; \ +	done >> $(top_builddir)/cscope.files  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)  	$(am__remove_distdir) @@ -523,40 +557,42 @@ distdir: $(DISTFILES)  	|| chmod -R a+r "$(distdir)"  dist-gzip: distdir  	tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz -	$(am__remove_distdir) +	$(am__post_remove_distdir)  dist-bzip2: distdir  	tardir=$(distdir) && $(am__tar) | BZIP2=$${BZIP2--9} bzip2 -c >$(distdir).tar.bz2 -	$(am__remove_distdir) +	$(am__post_remove_distdir)  dist-lzip: distdir  	tardir=$(distdir) && $(am__tar) | lzip -c $${LZIP_OPT--9} >$(distdir).tar.lz -	$(am__remove_distdir) - -dist-lzma: distdir -	tardir=$(distdir) && $(am__tar) | lzma -9 -c >$(distdir).tar.lzma -	$(am__remove_distdir) +	$(am__post_remove_distdir)  dist-xz: distdir  	tardir=$(distdir) && $(am__tar) | XZ_OPT=$${XZ_OPT--e} xz -c >$(distdir).tar.xz -	$(am__remove_distdir) +	$(am__post_remove_distdir)  dist-tarZ: distdir +	@echo WARNING: "Support for shar distribution archives is" \ +	               "deprecated." >&2 +	@echo WARNING: "It will be removed altogether in Automake 2.0" >&2  	tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z -	$(am__remove_distdir) +	$(am__post_remove_distdir)  dist-shar: distdir +	@echo WARNING: "Support for distribution archives compressed with" \ +		       "legacy program 'compress' 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 -	$(am__remove_distdir) +	$(am__post_remove_distdir)  dist-zip: distdir  	-rm -f $(distdir).zip  	zip -rq $(distdir).zip $(distdir) -	$(am__remove_distdir) +	$(am__post_remove_distdir) -dist dist-all: distdir -	tardir=$(distdir) && $(am__tar) | GZIP=$(GZIP_ENV) gzip -c >$(distdir).tar.gz -	$(am__remove_distdir) +dist dist-all: +	$(MAKE) $(AM_MAKEFLAGS) $(DIST_TARGETS) am__post_remove_distdir='@:' +	$(am__post_remove_distdir)  # This target untars the dist file and tries a VPATH configuration.  Then  # it guarantees that the distribution is self-contained by making another @@ -567,8 +603,6 @@ distcheck: dist  	  GZIP=$(GZIP_ENV) gzip -dc $(distdir).tar.gz | $(am__untar) ;;\  	*.tar.bz2*) \  	  bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\ -	*.tar.lzma*) \ -	  lzma -dc $(distdir).tar.lzma | $(am__untar) ;;\  	*.tar.lz*) \  	  lzip -dc $(distdir).tar.lz | $(am__untar) ;;\  	*.tar.xz*) \ @@ -580,9 +614,9 @@ distcheck: dist  	*.zip*) \  	  unzip $(distdir).zip ;;\  	esac -	chmod -R a-w $(distdir); chmod u+w $(distdir) -	mkdir $(distdir)/_build -	mkdir $(distdir)/_inst +	chmod -R a-w $(distdir) +	chmod u+w $(distdir) +	mkdir $(distdir)/_build $(distdir)/_inst  	chmod a-w $(distdir)  	test -d $(distdir)/_build || exit 0; \  	dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \ @@ -614,7 +648,7 @@ distcheck: dist  	  && $(MAKE) $(AM_MAKEFLAGS) distcleancheck \  	  && cd "$$am__cwd" \  	  || exit 1 -	$(am__remove_distdir) +	$(am__post_remove_distdir)  	@(echo "$(distdir) archives ready for distribution: "; \  	  list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \  	  sed -e 1h -e 1s/./=/g -e 1p -e 1x -e '$$p' -e '$$x' @@ -748,13 +782,12 @@ ps-am:  uninstall-am: -.MAKE: $(RECURSIVE_CLEAN_TARGETS) $(RECURSIVE_TARGETS) all \ -	ctags-recursive install-am install-strip tags-recursive +.MAKE: $(am__recursive_targets) all install-am install-strip -.PHONY: $(RECURSIVE_CLEAN_TARGETS) $(RECURSIVE_TARGETS) CTAGS GTAGS \ -	all all-am am--refresh check check-am clean clean-generic \ -	ctags ctags-recursive dist dist-all dist-bzip2 dist-gzip \ -	dist-lzip dist-lzma dist-shar dist-tarZ dist-xz dist-zip \ +.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 \ @@ -764,8 +797,8 @@ uninstall-am:  	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-recursive \ -	uninstall uninstall-am +	mostlyclean-generic pdf pdf-am ps ps-am tags tags-am uninstall \ +	uninstall-am  # Tell versions [3.59,3.63) of GNU make to not export all variables. @@ -1,8 +1,7 @@ -# generated automatically by aclocal 1.11.6 -*- Autoconf -*- +# generated automatically by aclocal 1.14 -*- Autoconf -*- + +# Copyright (C) 1996-2013 Free Software Foundation, Inc. -# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, -# 2005, 2006, 2007, 2008, 2009, 2010, 2011 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. @@ -12,33 +11,31 @@  # even the implied warranty of MERCHANTABILITY or FITNESS FOR A  # PARTICULAR PURPOSE. +m4_ifndef([AC_CONFIG_MACRO_DIRS], [m4_defun([_AM_CONFIG_MACRO_DIRS], [])m4_defun([AC_CONFIG_MACRO_DIRS], [_AM_CONFIG_MACRO_DIRS($@)])])  m4_ifndef([AC_AUTOCONF_VERSION],    [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl -m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.68],, -[m4_warning([this file was generated for autoconf 2.68. +m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.69],, +[m4_warning([this file was generated for autoconf 2.69.  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'.])]) +To do so, use the procedure documented by the package, typically 'autoreconf'.])]) -# Copyright (C) 2002, 2003, 2005, 2006, 2007, 2008, 2011 Free Software -# Foundation, Inc. +# Copyright (C) 2002-2013 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. -# serial 1 -  # AM_AUTOMAKE_VERSION(VERSION)  # ----------------------------  # Automake X.Y traces this macro to ensure aclocal.m4 has been  # 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.11' +[am__api_version='1.14'  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.11.6], [], +m4_if([$1], [1.14], [],        [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl  ]) @@ -54,24 +51,22 @@ 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.11.6])dnl +[AM_AUTOMAKE_VERSION([1.14])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, 2003, 2005, 2011 Free Software Foundation, Inc. +# Copyright (C) 2001-2013 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. -# serial 1 -  # For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets -# $ac_aux_dir to `$srcdir/foo'.  In other projects, it is set to -# `$srcdir', `$srcdir/..', or `$srcdir/../..'. +# $ac_aux_dir to '$srcdir/foo'.  In other projects, it is set to +# '$srcdir', '$srcdir/..', or '$srcdir/../..'.  #  # Of course, Automake must honor this variable whenever it calls a  # tool from the auxiliary directory.  The problem is that $srcdir (and @@ -90,7 +85,7 @@ _AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))])  #  # The reason of the latter failure is that $top_srcdir and $ac_aux_dir  # are both prefixed by $srcdir.  In an in-source build this is usually -# harmless because $srcdir is `.', but things will broke when you +# harmless because $srcdir is '.', but things will broke when you  # start a VPATH build or use an absolute $srcdir.  #  # So we could use something similar to $top_srcdir/$ac_aux_dir/missing, @@ -116,22 +111,19 @@ am_aux_dir=`cd $ac_aux_dir && pwd`  # AM_CONDITIONAL                                            -*- Autoconf -*- -# Copyright (C) 1997, 2000, 2001, 2003, 2004, 2005, 2006, 2008 -# Free Software Foundation, Inc. +# Copyright (C) 1997-2013 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. -# serial 9 -  # AM_CONDITIONAL(NAME, SHELL-CONDITION)  # -------------------------------------  # Define a conditional.  AC_DEFUN([AM_CONDITIONAL], -[AC_PREREQ(2.52)dnl - ifelse([$1], [TRUE],  [AC_FATAL([$0: invalid condition: $1])], -	[$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl +[AC_PREREQ([2.52])dnl + m4_if([$1], [TRUE],  [AC_FATAL([$0: invalid condition: $1])], +       [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl  AC_SUBST([$1_TRUE])dnl  AC_SUBST([$1_FALSE])dnl  _AM_SUBST_NOTMAKE([$1_TRUE])dnl @@ -150,16 +142,14 @@ AC_CONFIG_COMMANDS_PRE(  Usually this means the macro was only invoked conditionally.]])  fi])]) -# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2009, -# 2010, 2011 Free Software Foundation, Inc. +# Copyright (C) 1999-2013 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. -# serial 12 -# There are a few dirty hacks below to avoid letting `AC_PROG_CC' be +# There are a few dirty hacks below to avoid letting 'AC_PROG_CC' be  # written in clear, in which case automake, when reading aclocal.m4,  # will think it sees a *use*, and therefore will trigger all it's  # C support machinery.  Also note that it means that autoscan, seeing @@ -169,7 +159,7 @@ fi])])  # _AM_DEPENDENCIES(NAME)  # ----------------------  # See how the compiler implements dependency checking. -# NAME is "CC", "CXX", "GCJ", or "OBJC". +# NAME is "CC", "CXX", "OBJC", "OBJCXX", "UPC", or "GJC".  # We try a few techniques and use that to set a single cache variable.  #  # We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was @@ -182,12 +172,13 @@ AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl  AC_REQUIRE([AM_MAKE_INCLUDE])dnl  AC_REQUIRE([AM_DEP_TRACK])dnl -ifelse([$1], CC,   [depcc="$CC"   am_compiler_list=], -       [$1], CXX,  [depcc="$CXX"  am_compiler_list=], -       [$1], OBJC, [depcc="$OBJC" am_compiler_list='gcc3 gcc'], -       [$1], UPC,  [depcc="$UPC"  am_compiler_list=], -       [$1], GCJ,  [depcc="$GCJ"  am_compiler_list='gcc3 gcc'], -                   [depcc="$$1"   am_compiler_list=]) +m4_if([$1], [CC],   [depcc="$CC"   am_compiler_list=], +      [$1], [CXX],  [depcc="$CXX"  am_compiler_list=], +      [$1], [OBJC], [depcc="$OBJC" am_compiler_list='gcc3 gcc'], +      [$1], [OBJCXX], [depcc="$OBJCXX" am_compiler_list='gcc3 gcc'], +      [$1], [UPC],  [depcc="$UPC"  am_compiler_list=], +      [$1], [GCJ],  [depcc="$GCJ"  am_compiler_list='gcc3 gcc'], +                    [depcc="$$1"   am_compiler_list=])  AC_CACHE_CHECK([dependency style of $depcc],                 [am_cv_$1_dependencies_compiler_type], @@ -195,8 +186,8 @@ AC_CACHE_CHECK([dependency style of $depcc],    # We make a subdir and do the tests there.  Otherwise we can end up    # making bogus files that we don't know about and never remove.  For    # instance it was reported that on HP-UX the gcc test will end up -  # making a dummy file named `D' -- because `-MD' means `put the output -  # in D'. +  # making a dummy file named 'D' -- because '-MD' means "put the output +  # in D".    rm -rf conftest.dir    mkdir conftest.dir    # Copy depcomp to subdir because otherwise we won't find it if we're @@ -236,16 +227,16 @@ AC_CACHE_CHECK([dependency style of $depcc],      : > sub/conftest.c      for i in 1 2 3 4 5 6; do        echo '#include "conftst'$i'.h"' >> sub/conftest.c -      # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with -      # Solaris 8's {/usr,}/bin/sh. -      touch sub/conftst$i.h +      # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with +      # Solaris 10 /bin/sh. +      echo '/* dummy */' > sub/conftst$i.h      done      echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf -    # We check with `-c' and `-o' for the sake of the "dashmstdout" +    # We check with '-c' and '-o' for the sake of the "dashmstdout"      # mode.  It turns out that the SunPro C++ compiler does not properly -    # handle `-M -o', and we need to detect this.  Also, some Intel -    # versions had trouble with output in subdirs +    # handle '-M -o', and we need to detect this.  Also, some Intel +    # versions had trouble with output in subdirs.      am__obj=sub/conftest.${OBJEXT-o}      am__minus_obj="-o $am__obj"      case $depmode in @@ -254,8 +245,8 @@ AC_CACHE_CHECK([dependency style of $depcc],        test "$am__universal" = false || continue        ;;      nosideeffect) -      # after this tag, mechanisms are not by side-effect, so they'll -      # only be used when explicitly requested +      # After this tag, mechanisms are not by side-effect, so they'll +      # only be used when explicitly requested.        if test "x$enable_dependency_tracking" = xyes; then  	continue        else @@ -263,7 +254,7 @@ AC_CACHE_CHECK([dependency style of $depcc],        fi        ;;      msvc7 | msvc7msys | msvisualcpp | msvcmsys) -      # This compiler won't grok `-c -o', but also, the minuso test has +      # This compiler won't grok '-c -o', but also, the minuso test has        # not run yet.  These depmodes are late enough in the game, and        # so weak that their functioning should not be impacted.        am__obj=conftest.${OBJEXT-o} @@ -311,7 +302,7 @@ AM_CONDITIONAL([am__fastdep$1], [  # AM_SET_DEPDIR  # -------------  # Choose a directory name for dependency files. -# This macro is AC_REQUIREd in _AM_DEPENDENCIES +# This macro is AC_REQUIREd in _AM_DEPENDENCIES.  AC_DEFUN([AM_SET_DEPDIR],  [AC_REQUIRE([AM_SET_LEADING_DOT])dnl  AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl @@ -321,9 +312,13 @@ AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl  # AM_DEP_TRACK  # ------------  AC_DEFUN([AM_DEP_TRACK], -[AC_ARG_ENABLE(dependency-tracking, -[  --disable-dependency-tracking  speeds up one-time build -  --enable-dependency-tracking   do not reject slow dependency extractors]) +[AC_ARG_ENABLE([dependency-tracking], [dnl +AS_HELP_STRING( +  [--enable-dependency-tracking], +  [do not reject slow dependency extractors]) +AS_HELP_STRING( +  [--disable-dependency-tracking], +  [speeds up one-time build])])  if test "x$enable_dependency_tracking" != xno; then    am_depcomp="$ac_aux_dir/depcomp"    AMDEPBACKSLASH='\' @@ -338,20 +333,18 @@ _AM_SUBST_NOTMAKE([am__nodep])dnl  # Generate code to set up dependency tracking.              -*- Autoconf -*- -# Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2008 -# Free Software Foundation, Inc. +# Copyright (C) 1999-2013 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. -#serial 5  # _AM_OUTPUT_DEPENDENCY_COMMANDS  # ------------------------------  AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],  [{ -  # Autoconf 2.62 quotes --file arguments for eval, but not when files +  # 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 @@ -364,7 +357,7 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],      # 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 +    # 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. @@ -376,21 +369,19 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],        continue      fi      # Extract the definition of DEPDIR, am__include, and am__quote -    # from the Makefile without running `make'. +    # 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 +    test -z "$am__include" && continue      am__quote=`sed -n 's/^am__quote = //p' < "$mf"` -    # When using ansi2knr, U may be empty or an underscore; expand it -    U=`sed -n 's/^U = //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' -e 's/\$U/'"$U"'/g'`; do +	 sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do        # Make sure the directory exists.        test -f "$dirpart/$file" && continue        fdir=`AS_DIRNAME(["$file"])` @@ -408,7 +399,7 @@ 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 +# is enabled.  FIXME.  This creates each '.P' file that we will  # need in order to bootstrap the dependency handling code.  AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],  [AC_CONFIG_COMMANDS([depfiles], @@ -418,18 +409,21 @@ AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],  # Do all the work for Automake.                             -*- Autoconf -*- -# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, -# 2005, 2006, 2008, 2009 Free Software Foundation, Inc. +# Copyright (C) 1996-2013 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. -# serial 16 -  # This macro actually does too much.  Some checks are only needed if  # your package does certain things.  But this isn't really a big deal. +dnl Redefine AC_PROG_CC to automatically invoke _AM_PROG_CC_C_O. +m4_define([AC_PROG_CC], +m4_defn([AC_PROG_CC]) +[_AM_PROG_CC_C_O +]) +  # AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE])  # AM_INIT_AUTOMAKE([OPTIONS])  # ----------------------------------------------- @@ -442,7 +436,7 @@ AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],  # arguments mandatory, and then we can depend on a new Autoconf  # release and drop the old call support.  AC_DEFUN([AM_INIT_AUTOMAKE], -[AC_PREREQ([2.62])dnl +[AC_PREREQ([2.65])dnl  dnl Autoconf wants to disallow AM_ names.  We explicitly allow  dnl the ones we care about.  m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl @@ -471,31 +465,40 @@ AC_SUBST([CYGPATH_W])  # Define the identity of the package.  dnl Distinguish between old-style and new-style calls.  m4_ifval([$2], -[m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl +[AC_DIAGNOSE([obsolete], +             [$0: two- and three-arguments forms are deprecated.]) +m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl   AC_SUBST([PACKAGE], [$1])dnl   AC_SUBST([VERSION], [$2])],  [_AM_SET_OPTIONS([$1])dnl  dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT. -m4_if(m4_ifdef([AC_PACKAGE_NAME], 1)m4_ifdef([AC_PACKAGE_VERSION], 1), 11,, +m4_if( +  m4_ifdef([AC_PACKAGE_NAME], [ok]):m4_ifdef([AC_PACKAGE_VERSION], [ok]), +  [ok:ok],,    [m4_fatal([AC_INIT should be called with package and version arguments])])dnl   AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl   AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl  _AM_IF_OPTION([no-define],, -[AC_DEFINE_UNQUOTED(PACKAGE, "$PACKAGE", [Name of package]) - AC_DEFINE_UNQUOTED(VERSION, "$VERSION", [Version number of package])])dnl +[AC_DEFINE_UNQUOTED([PACKAGE], ["$PACKAGE"], [Name of package]) + AC_DEFINE_UNQUOTED([VERSION], ["$VERSION"], [Version number of package])])dnl  # Some tools Automake needs.  AC_REQUIRE([AM_SANITY_CHECK])dnl  AC_REQUIRE([AC_ARG_PROGRAM])dnl -AM_MISSING_PROG(ACLOCAL, aclocal-${am__api_version}) -AM_MISSING_PROG(AUTOCONF, autoconf) -AM_MISSING_PROG(AUTOMAKE, automake-${am__api_version}) -AM_MISSING_PROG(AUTOHEADER, autoheader) -AM_MISSING_PROG(MAKEINFO, makeinfo) +AM_MISSING_PROG([ACLOCAL], [aclocal-${am__api_version}]) +AM_MISSING_PROG([AUTOCONF], [autoconf]) +AM_MISSING_PROG([AUTOMAKE], [automake-${am__api_version}]) +AM_MISSING_PROG([AUTOHEADER], [autoheader]) +AM_MISSING_PROG([MAKEINFO], [makeinfo])  AC_REQUIRE([AM_PROG_INSTALL_SH])dnl  AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl -AC_REQUIRE([AM_PROG_MKDIR_P])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: +# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html> +# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html> +AC_SUBST([mkdir_p], ['$(MKDIR_P)'])  # We need awk for the "check" target.  The system "awk" is bad on  # some platforms.  AC_REQUIRE([AC_PROG_AWK])dnl @@ -506,34 +509,78 @@ _AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])],  			     [_AM_PROG_TAR([v7])])])  _AM_IF_OPTION([no-dependencies],,  [AC_PROVIDE_IFELSE([AC_PROG_CC], -		  [_AM_DEPENDENCIES(CC)], -		  [define([AC_PROG_CC], -			  defn([AC_PROG_CC])[_AM_DEPENDENCIES(CC)])])dnl +		  [_AM_DEPENDENCIES([CC])], +		  [m4_define([AC_PROG_CC], +			     m4_defn([AC_PROG_CC])[_AM_DEPENDENCIES([CC])])])dnl  AC_PROVIDE_IFELSE([AC_PROG_CXX], -		  [_AM_DEPENDENCIES(CXX)], -		  [define([AC_PROG_CXX], -			  defn([AC_PROG_CXX])[_AM_DEPENDENCIES(CXX)])])dnl +		  [_AM_DEPENDENCIES([CXX])], +		  [m4_define([AC_PROG_CXX], +			     m4_defn([AC_PROG_CXX])[_AM_DEPENDENCIES([CXX])])])dnl  AC_PROVIDE_IFELSE([AC_PROG_OBJC], -		  [_AM_DEPENDENCIES(OBJC)], -		  [define([AC_PROG_OBJC], -			  defn([AC_PROG_OBJC])[_AM_DEPENDENCIES(OBJC)])])dnl +		  [_AM_DEPENDENCIES([OBJC])], +		  [m4_define([AC_PROG_OBJC], +			     m4_defn([AC_PROG_OBJC])[_AM_DEPENDENCIES([OBJC])])])dnl +AC_PROVIDE_IFELSE([AC_PROG_OBJCXX], +		  [_AM_DEPENDENCIES([OBJCXX])], +		  [m4_define([AC_PROG_OBJCXX], +			     m4_defn([AC_PROG_OBJCXX])[_AM_DEPENDENCIES([OBJCXX])])])dnl  ]) -_AM_IF_OPTION([silent-rules], [AC_REQUIRE([AM_SILENT_RULES])])dnl -dnl The `parallel-tests' driver may need to know about EXEEXT, so add the -dnl `am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen.  This macro -dnl is hooked onto _AC_COMPILER_EXEEXT early, see below. +AC_REQUIRE([AM_SILENT_RULES])dnl +dnl The testsuite driver may need to know about EXEEXT, so add the +dnl 'am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen.  This +dnl macro is hooked onto _AC_COMPILER_EXEEXT early, see below.  AC_CONFIG_COMMANDS_PRE(dnl  [m4_provide_if([_AM_COMPILER_EXEEXT],    [AM_CONDITIONAL([am__EXEEXT], [test -n "$EXEEXT"])])])dnl -]) -dnl Hook into `_AC_COMPILER_EXEEXT' early to learn its expansion.  Do not +# POSIX will say in a future version that running "rm -f" with no argument +# is OK; and we want to be able to make that assumption in our Makefile +# recipes.  So use an aggressive probe to check that the usage we want is +# actually supported "in the wild" to an acceptable degree. +# See automake bug#10828. +# To make any issue more visible, cause the running configure to be aborted +# by default if the 'rm' program in use doesn't match our expectations; the +# user can still override this though. +if rm -f && rm -fr && rm -rf; then : OK; else +  cat >&2 <<'END' +Oops! + +Your 'rm' program seems unable to run without file operands specified +on the command line, even when the '-f' option is present.  This is contrary +to the behaviour of most rm programs out there, and not conforming with +the upcoming POSIX standard: <http://austingroupbugs.net/view.php?id=542> + +Please tell bug-automake@gnu.org about your system, including the value +of your $PATH and any error possibly output before this message.  This +can help us improve future automake versions. + +END +  if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then +    echo 'Configuration will proceed anyway, since you have set the' >&2 +    echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 +    echo >&2 +  else +    cat >&2 <<'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: <http://www.gnu.org/software/coreutils/>. + +If you want to complete the configuration process using your problematic +'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM +to "yes", and re-run configure. + +END +    AC_MSG_ERROR([Your 'rm' program is bad, sorry.]) +  fi +fi]) + +dnl Hook into '_AC_COMPILER_EXEEXT' early to learn its expansion.  Do not  dnl add the conditional right here, as _AC_COMPILER_EXEEXT may be further  dnl mangled by Autoconf and run in a shell conditional statement.  m4_define([_AC_COMPILER_EXEEXT],  m4_defn([_AC_COMPILER_EXEEXT])[m4_provide([_AM_COMPILER_EXEEXT])]) -  # When config.status generates a header, we must update the stamp-h file.  # This file resides in the same directory as the config header  # that is generated.  The stamp files are numbered to have different names. @@ -555,15 +602,12 @@ 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, 2003, 2005, 2008, 2011 Free Software Foundation, -# Inc. +# Copyright (C) 2001-2013 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. -# serial 1 -  # AM_PROG_INSTALL_SH  # ------------------  # Define $install_sh. @@ -577,16 +621,14 @@ if test x"${install_sh}" != xset; then      install_sh="\${SHELL} $am_aux_dir/install-sh"    esac  fi -AC_SUBST(install_sh)]) +AC_SUBST([install_sh])]) -# Copyright (C) 2003, 2005  Free Software Foundation, Inc. +# Copyright (C) 2003-2013 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. -# serial 2 -  # Check whether the underlying file-system supports filenames  # with a leading dot.  For instance MS-DOS doesn't.  AC_DEFUN([AM_SET_LEADING_DOT], @@ -602,14 +644,12 @@ AC_SUBST([am__leading_dot])])  # Check to see how 'make' treats includes.	            -*- Autoconf -*- -# Copyright (C) 2001, 2002, 2003, 2005, 2009  Free Software Foundation, Inc. +# Copyright (C) 2001-2013 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. -# serial 4 -  # AM_MAKE_INCLUDE()  # -----------------  # Check to see how make treats includes. @@ -627,7 +667,7 @@ am__quote=  _am_result=none  # First try GNU make style include.  echo "include confinc" > confmf -# Ignore all kinds of additional output from `make'. +# 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 @@ -652,52 +692,14 @@ AC_MSG_RESULT([$_am_result])  rm -f confinc confmf  ]) -# Copyright (C) 1999, 2000, 2001, 2003, 2004, 2005, 2008 -# 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. - -# serial 6 - -# AM_PROG_CC_C_O -# -------------- -# Like AC_PROG_CC_C_O, but changed for automake. -AC_DEFUN([AM_PROG_CC_C_O], -[AC_REQUIRE([AC_PROG_CC_C_O])dnl -AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl -AC_REQUIRE_AUX_FILE([compile])dnl -# FIXME: we rely on the cache variable name because -# there is no other way. -set dummy $CC -am_cc=`echo $[2] | sed ['s/[^a-zA-Z0-9_]/_/g;s/^[0-9]/_/']` -eval am_t=\$ac_cv_prog_cc_${am_cc}_c_o -if test "$am_t" != yes; then -   # Losing compiler, so override with the script. -   # FIXME: It is wrong to rewrite CC. -   # But if we don't then we get into trouble of one sort or another. -   # A longer-term fix would be to have automake use am__CC in this case, -   # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" -   CC="$am_aux_dir/compile $CC" -fi -dnl Make sure AC_PROG_CC is never called again, or it will override our -dnl setting of CC. -m4_define([AC_PROG_CC], -          [m4_fatal([AC_PROG_CC cannot be called after AM_PROG_CC_C_O])]) -]) -  # Fake the existence of programs that GNU maintainers use.  -*- Autoconf -*- -# Copyright (C) 1997, 1999, 2000, 2001, 2003, 2004, 2005, 2008 -# Free Software Foundation, Inc. +# Copyright (C) 1997-2013 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. -# serial 6 -  # AM_MISSING_PROG(NAME, PROGRAM)  # ------------------------------  AC_DEFUN([AM_MISSING_PROG], @@ -705,11 +707,10 @@ AC_DEFUN([AM_MISSING_PROG],  $1=${$1-"${am_missing_run}$2"}  AC_SUBST($1)]) -  # AM_MISSING_HAS_RUN  # ------------------ -# Define MISSING if not defined so far and test if it supports --run. -# If it does, set am_missing_run to use it, otherwise, to nothing. +# Define MISSING if not defined so far and test if it is modern enough. +# If it is, set am_missing_run to use it, otherwise, to nothing.  AC_DEFUN([AM_MISSING_HAS_RUN],  [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl  AC_REQUIRE_AUX_FILE([missing])dnl @@ -722,54 +723,22 @@ if test x"${MISSING+set}" != xset; then    esac  fi  # Use eval to expand $SHELL -if eval "$MISSING --run true"; then -  am_missing_run="$MISSING --run " +if eval "$MISSING --is-lightweight"; then +  am_missing_run="$MISSING "  else    am_missing_run= -  AC_MSG_WARN([`missing' script is too old or missing]) +  AC_MSG_WARN(['missing' script is too old or missing])  fi  ]) -# Copyright (C) 2003, 2004, 2005, 2006, 2011 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. - -# serial 1 - -# AM_PROG_MKDIR_P -# --------------- -# Check for `mkdir -p'. -AC_DEFUN([AM_PROG_MKDIR_P], -[AC_PREREQ([2.60])dnl -AC_REQUIRE([AC_PROG_MKDIR_P])dnl -dnl Automake 1.8 to 1.9.6 used to define mkdir_p.  We now use MKDIR_P, -dnl while keeping a definition of mkdir_p for backward compatibility. -dnl @MKDIR_P@ is magic: AC_OUTPUT adjusts its value for each Makefile. -dnl However we cannot define mkdir_p as $(MKDIR_P) for the sake of -dnl Makefile.ins that do not define MKDIR_P, so we do our own -dnl adjustment using top_builddir (which is defined more often than -dnl MKDIR_P). -AC_SUBST([mkdir_p], ["$MKDIR_P"])dnl -case $mkdir_p in -  [[\\/$]]* | ?:[[\\/]]*) ;; -  */*) mkdir_p="\$(top_builddir)/$mkdir_p" ;; -esac -]) -  # Helper functions for option handling.                     -*- Autoconf -*- -# Copyright (C) 2001, 2002, 2003, 2005, 2008, 2010 Free Software -# Foundation, Inc. +# Copyright (C) 2001-2013 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. -# serial 5 -  # _AM_MANGLE_OPTION(NAME)  # -----------------------  AC_DEFUN([_AM_MANGLE_OPTION], @@ -779,7 +748,7 @@ AC_DEFUN([_AM_MANGLE_OPTION],  # --------------------  # Set option NAME.  Presently that only means defining a flag for this option.  AC_DEFUN([_AM_SET_OPTION], -[m4_define(_AM_MANGLE_OPTION([$1]), 1)]) +[m4_define(_AM_MANGLE_OPTION([$1]), [1])])  # _AM_SET_OPTIONS(OPTIONS)  # ------------------------ @@ -793,24 +762,82 @@ AC_DEFUN([_AM_SET_OPTIONS],  AC_DEFUN([_AM_IF_OPTION],  [m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) -# Check to make sure that the build environment is sane.    -*- Autoconf -*- +# Copyright (C) 1999-2013 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. -# Copyright (C) 1996, 1997, 2000, 2001, 2003, 2005, 2008 -# Free Software Foundation, Inc. +# _AM_PROG_CC_C_O +# --------------- +# Like AC_PROG_CC_C_O, but changed for automake.  We rewrite AC_PROG_CC +# to automatically call this. +AC_DEFUN([_AM_PROG_CC_C_O], +[AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl +AC_REQUIRE_AUX_FILE([compile])dnl +AC_LANG_PUSH([C])dnl +AC_CACHE_CHECK( +  [whether $CC understands -c and -o together], +  [am_cv_prog_cc_c_o], +  [AC_LANG_CONFTEST([AC_LANG_PROGRAM([])]) +  # Make sure it works both with $CC and with simple cc. +  # Following AC_PROG_CC_C_O, we do the test twice because some +  # compilers refuse to overwrite an existing .o file with -o, +  # though they will create one. +  am_cv_prog_cc_c_o=yes +  for am_i in 1 2; do +    if AM_RUN_LOG([$CC -c conftest.$ac_ext -o conftest2.$ac_objext]) \ +         && test -f conftest2.$ac_objext; then +      : OK +    else +      am_cv_prog_cc_c_o=no +      break +    fi +  done +  rm -f core conftest* +  unset am_i]) +if test "$am_cv_prog_cc_c_o" != yes; then +   # Losing compiler, so override with the script. +   # FIXME: It is wrong to rewrite CC. +   # But if we don't then we get into trouble of one sort or another. +   # A longer-term fix would be to have automake use am__CC in this case, +   # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" +   CC="$am_aux_dir/compile $CC" +fi +AC_LANG_POP([C])]) + +# For backward compatibility. +AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])]) + +# Copyright (C) 2001-2013 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. -# serial 5 +# AM_RUN_LOG(COMMAND) +# ------------------- +# Run COMMAND, save the exit status in ac_status, and log it. +# (This has been adapted from Autoconf's _AC_RUN_LOG macro.) +AC_DEFUN([AM_RUN_LOG], +[{ echo "$as_me:$LINENO: $1" >&AS_MESSAGE_LOG_FD +   ($1) >&AS_MESSAGE_LOG_FD 2>&AS_MESSAGE_LOG_FD +   ac_status=$? +   echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD +   (exit $ac_status); }]) + +# Check to make sure that the build environment is sane.    -*- Autoconf -*- + +# Copyright (C) 1996-2013 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_SANITY_CHECK  # ---------------  AC_DEFUN([AM_SANITY_CHECK],  [AC_MSG_CHECKING([whether build environment is sane]) -# Just in case -sleep 1 -echo timestamp > conftest.file  # Reject unsafe characters in $srcdir or the absolute working directory  # name.  Accept space and tab only in the latter.  am_lf=' @@ -821,32 +848,40 @@ case `pwd` in  esac  case $srcdir in    *[[\\\"\#\$\&\'\`$am_lf\ \	]]*) -    AC_MSG_ERROR([unsafe srcdir value: `$srcdir']);; +    AC_MSG_ERROR([unsafe srcdir value: '$srcdir']);;  esac -# Do `set' in a subshell so we don't clobber the current shell's +# Do 'set' in a subshell so we don't clobber the current shell's  # arguments.  Must try -L first in case configure is actually a  # symlink; some systems play weird games with the mod time of symlinks  # (eg FreeBSD returns the mod time of the symlink's containing  # directory).  if ( -   set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` -   if test "$[*]" = "X"; then -      # -L didn't work. -      set X `ls -t "$srcdir/configure" conftest.file` -   fi -   rm -f conftest.file -   if test "$[*]" != "X $srcdir/configure conftest.file" \ -      && test "$[*]" != "X conftest.file $srcdir/configure"; then - -      # If neither matched, then we have a broken ls.  This can happen -      # if, for instance, CONFIG_SHELL is bash and it inherits a -      # broken ls alias from the environment.  This has actually -      # happened.  Such a system could not be considered "sane". -      AC_MSG_ERROR([ls -t appears to fail.  Make sure there is not a broken -alias in your environment]) -   fi - +   am_has_slept=no +   for am_try in 1 2; do +     echo "timestamp, slept: $am_has_slept" > conftest.file +     set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` +     if test "$[*]" = "X"; then +	# -L didn't work. +	set X `ls -t "$srcdir/configure" conftest.file` +     fi +     if test "$[*]" != "X $srcdir/configure conftest.file" \ +	&& test "$[*]" != "X conftest.file $srcdir/configure"; then + +	# If neither matched, then we have a broken ls.  This can happen +	# if, for instance, CONFIG_SHELL is bash and it inherits a +	# broken ls alias from the environment.  This has actually +	# happened.  Such a system could not be considered "sane". +	AC_MSG_ERROR([ls -t appears to fail.  Make sure there is not a broken +  alias in your environment]) +     fi +     if test "$[2]" = conftest.file || test $am_try -eq 2; then +       break +     fi +     # Just in case. +     sleep 1 +     am_has_slept=yes +   done     test "$[2]" = conftest.file     )  then @@ -856,31 +891,50 @@ else     AC_MSG_ERROR([newly created file is older than distributed files!  Check your system clock])  fi -AC_MSG_RESULT(yes)]) +AC_MSG_RESULT([yes]) +# If we didn't sleep, we still need to ensure time stamps of config.status and +# generated files are strictly newer. +am_sleep_pid= +if grep 'slept: no' conftest.file >/dev/null 2>&1; then +  ( sleep 1 ) & +  am_sleep_pid=$! +fi +AC_CONFIG_COMMANDS_PRE( +  [AC_MSG_CHECKING([that generated files are newer than configure]) +   if test -n "$am_sleep_pid"; then +     # Hide warnings about reused PIDs. +     wait $am_sleep_pid 2>/dev/null +   fi +   AC_MSG_RESULT([done])]) +rm -f conftest.file +]) -# Copyright (C) 2009, 2011  Free Software Foundation, Inc. +# Copyright (C) 2009-2013 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. -# serial 2 -  # AM_SILENT_RULES([DEFAULT])  # --------------------------  # Enable less verbose build rules; with the default set to DEFAULT -# (`yes' being less verbose, `no' or empty being verbose). +# ("yes" being less verbose, "no" or empty being verbose).  AC_DEFUN([AM_SILENT_RULES], -[AC_ARG_ENABLE([silent-rules], -[  --enable-silent-rules          less verbose build output (undo: `make V=1') -  --disable-silent-rules         verbose build output (undo: `make V=0')]) -case $enable_silent_rules in -yes) AM_DEFAULT_VERBOSITY=0;; -no)  AM_DEFAULT_VERBOSITY=1;; -*)   AM_DEFAULT_VERBOSITY=m4_if([$1], [yes], [0], [1]);; +[AC_ARG_ENABLE([silent-rules], [dnl +AS_HELP_STRING( +  [--enable-silent-rules], +  [less verbose build output (undo: "make V=1")]) +AS_HELP_STRING( +  [--disable-silent-rules], +  [verbose build output (undo: "make V=0")])dnl +]) +case $enable_silent_rules in @%:@ ((( +  yes) AM_DEFAULT_VERBOSITY=0;; +   no) AM_DEFAULT_VERBOSITY=1;; +    *) AM_DEFAULT_VERBOSITY=m4_if([$1], [yes], [0], [1]);;  esac  dnl -dnl A few `make' implementations (e.g., NonStop OS and NextStep) +dnl A few 'make' implementations (e.g., NonStop OS and NextStep)  dnl do not support nested variable expansions.  dnl See automake bug#9928 and bug#10237.  am_make=${MAKE-make} @@ -898,7 +952,7 @@ else    am_cv_make_support_nested_variables=no  fi])  if test $am_cv_make_support_nested_variables = yes; then -  dnl Using `$V' instead of `$(V)' breaks IRIX make. +  dnl Using '$V' instead of '$(V)' breaks IRIX make.    AM_V='$(V)'    AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)'  else @@ -915,44 +969,40 @@ AC_SUBST([AM_BACKSLASH])dnl  _AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl  ]) -# Copyright (C) 2001, 2003, 2005, 2011 Free Software Foundation, Inc. +# Copyright (C) 2001-2013 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. -# serial 1 -  # AM_PROG_INSTALL_STRIP  # --------------------- -# One issue with vendor `install' (even GNU) is that you can't +# One issue with vendor 'install' (even GNU) is that you can't  # specify the program used to strip binaries.  This is especially  # annoying in cross-compiling environments, where the build's strip  # is unlikely to handle the host's binaries.  # Fortunately install-sh will honor a STRIPPROG variable, so we -# always use install-sh in `make install-strip', and initialize +# always use install-sh in "make install-strip", and initialize  # STRIPPROG with the value of the STRIP variable (set by the user).  AC_DEFUN([AM_PROG_INSTALL_STRIP],  [AC_REQUIRE([AM_PROG_INSTALL_SH])dnl -# Installed binaries are usually stripped using `strip' when the user -# run `make install-strip'.  However `strip' might not be the right +# Installed binaries are usually stripped using 'strip' when the user +# run "make install-strip".  However 'strip' might not be the right  # tool to use in cross-compilation environments, therefore Automake -# will honor the `STRIP' environment variable to overrule this program. -dnl Don't test for $cross_compiling = yes, because it might be `maybe'. +# will honor the 'STRIP' environment variable to overrule this program. +dnl Don't test for $cross_compiling = yes, because it might be 'maybe'.  if test "$cross_compiling" != no; then    AC_CHECK_TOOL([STRIP], [strip], :)  fi  INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s"  AC_SUBST([INSTALL_STRIP_PROGRAM])]) -# Copyright (C) 2006, 2008, 2010 Free Software Foundation, Inc. +# Copyright (C) 2006-2013 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. -# serial 3 -  # _AM_SUBST_NOTMAKE(VARIABLE)  # ---------------------------  # Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in. @@ -966,18 +1016,16 @@ AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)])  # Check how to create a tarball.                            -*- Autoconf -*- -# Copyright (C) 2004, 2005, 2012 Free Software Foundation, Inc. +# Copyright (C) 2004-2013 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. -# serial 2 -  # _AM_PROG_TAR(FORMAT)  # --------------------  # Check how to create a tarball in format FORMAT. -# FORMAT should be one of `v7', `ustar', or `pax'. +# FORMAT should be one of 'v7', 'ustar', or 'pax'.  #  # Substitute a variable $(am__tar) that is a command  # writing to stdout a FORMAT-tarball containing the directory @@ -987,76 +1035,114 @@ AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)])  # Substitute a variable $(am__untar) that extract such  # a tarball read from stdin.  #     $(am__untar) < result.tar +#  AC_DEFUN([_AM_PROG_TAR],  [# Always define AMTAR for backward compatibility.  Yes, it's still used  # in the wild :-(  We should find a proper way to deprecate it ...  AC_SUBST([AMTAR], ['$${TAR-tar}']) -m4_if([$1], [v7], -     [am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -'], -     [m4_case([$1], [ustar],, [pax],, -              [m4_fatal([Unknown tar format])]) -AC_MSG_CHECKING([how to create a $1 tar archive]) -# Loop over all known methods to create a tar archive until one works. + +# We'll loop over all known methods to create a tar archive until one works.  _am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none' -_am_tools=${am_cv_prog_tar_$1-$_am_tools} -# Do not fold the above two line into one, because Tru64 sh and -# Solaris sh will not grok spaces in the rhs of `-'. -for _am_tool in $_am_tools -do -  case $_am_tool in -  gnutar) -    for _am_tar in tar gnutar gtar; -    do -      AM_RUN_LOG([$_am_tar --version]) && break -    done -    am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' -    am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' -    am__untar="$_am_tar -xf -" -    ;; -  plaintar) -    # Must skip GNU tar: if it does not support --format= it doesn't create -    # ustar tarball either. -    (tar --version) >/dev/null 2>&1 && continue -    am__tar='tar chf - "$$tardir"' -    am__tar_='tar chf - "$tardir"' -    am__untar='tar xf -' -    ;; -  pax) -    am__tar='pax -L -x $1 -w "$$tardir"' -    am__tar_='pax -L -x $1 -w "$tardir"' -    am__untar='pax -r' -    ;; -  cpio) -    am__tar='find "$$tardir" -print | cpio -o -H $1 -L' -    am__tar_='find "$tardir" -print | cpio -o -H $1 -L' -    am__untar='cpio -i -H $1 -d' -    ;; -  none) -    am__tar=false -    am__tar_=false -    am__untar=false -    ;; -  esac -  # If the value was cached, stop now.  We just wanted to have am__tar -  # and am__untar set. -  test -n "${am_cv_prog_tar_$1}" && break +m4_if([$1], [v7], +  [am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -'], + +  [m4_case([$1], +    [ustar], +     [# The POSIX 1988 'ustar' format is defined with fixed-size fields. +      # There is notably a 21 bits limit for the UID and the GID.  In fact, +      # the 'pax' utility can hang on bigger UID/GID (see automake bug#8343 +      # and bug#13588). +      am_max_uid=2097151 # 2^21 - 1 +      am_max_gid=$am_max_uid +      # The $UID and $GID variables are not portable, so we need to resort +      # to the POSIX-mandated id(1) utility.  Errors in the 'id' calls +      # below are definitely unexpected, so allow the users to see them +      # (that is, avoid stderr redirection). +      am_uid=`id -u || echo unknown` +      am_gid=`id -g || echo unknown` +      AC_MSG_CHECKING([whether UID '$am_uid' is supported by ustar format]) +      if test $am_uid -le $am_max_uid; then +         AC_MSG_RESULT([yes]) +      else +         AC_MSG_RESULT([no]) +         _am_tools=none +      fi +      AC_MSG_CHECKING([whether GID '$am_gid' is supported by ustar format]) +      if test $am_gid -le $am_max_gid; then +         AC_MSG_RESULT([yes]) +      else +        AC_MSG_RESULT([no]) +        _am_tools=none +      fi], + +  [pax], +    [], + +  [m4_fatal([Unknown tar format])]) + +  AC_MSG_CHECKING([how to create a $1 tar archive]) + +  # Go ahead even if we have the value already cached.  We do so because we +  # need to set the values for the 'am__tar' and 'am__untar' variables. +  _am_tools=${am_cv_prog_tar_$1-$_am_tools} + +  for _am_tool in $_am_tools; do +    case $_am_tool in +    gnutar) +      for _am_tar in tar gnutar gtar; do +        AM_RUN_LOG([$_am_tar --version]) && break +      done +      am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' +      am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' +      am__untar="$_am_tar -xf -" +      ;; +    plaintar) +      # Must skip GNU tar: if it does not support --format= it doesn't create +      # ustar tarball either. +      (tar --version) >/dev/null 2>&1 && continue +      am__tar='tar chf - "$$tardir"' +      am__tar_='tar chf - "$tardir"' +      am__untar='tar xf -' +      ;; +    pax) +      am__tar='pax -L -x $1 -w "$$tardir"' +      am__tar_='pax -L -x $1 -w "$tardir"' +      am__untar='pax -r' +      ;; +    cpio) +      am__tar='find "$$tardir" -print | cpio -o -H $1 -L' +      am__tar_='find "$tardir" -print | cpio -o -H $1 -L' +      am__untar='cpio -i -H $1 -d' +      ;; +    none) +      am__tar=false +      am__tar_=false +      am__untar=false +      ;; +    esac -  # tar/untar a dummy directory, and stop if the command works -  rm -rf conftest.dir -  mkdir conftest.dir -  echo GrepMe > conftest.dir/file -  AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) +    # If the value was cached, stop now.  We just wanted to have am__tar +    # and am__untar set. +    test -n "${am_cv_prog_tar_$1}" && break + +    # tar/untar a dummy directory, and stop if the command works. +    rm -rf conftest.dir +    mkdir conftest.dir +    echo GrepMe > conftest.dir/file +    AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) +    rm -rf conftest.dir +    if test -s conftest.tar; then +      AM_RUN_LOG([$am__untar <conftest.tar]) +      AM_RUN_LOG([cat conftest.dir/file]) +      grep GrepMe conftest.dir/file >/dev/null 2>&1 && break +    fi +  done    rm -rf conftest.dir -  if test -s conftest.tar; then -    AM_RUN_LOG([$am__untar <conftest.tar]) -    grep GrepMe conftest.dir/file >/dev/null 2>&1 && break -  fi -done -rm -rf conftest.dir -AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) -AC_MSG_RESULT([$am_cv_prog_tar_$1])]) +  AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) +  AC_MSG_RESULT([$am_cv_prog_tar_$1])]) +  AC_SUBST([am__tar])  AC_SUBST([am__untar])  ]) # _AM_PROG_TAR diff --git a/config.h.in b/config.h.in index c16e5e5..41e4aaf 100644 --- a/config.h.in +++ b/config.h.in @@ -185,9 +185,6 @@  /* Define to 1 if the system has the type `_Bool'. */  #undef HAVE__BOOL -/* Define to 1 if your C compiler doesn't accept -c and -o together. */ -#undef NO_MINUS_C_MINUS_O -  /* Name of package */  #undef PACKAGE @@ -1,13 +1,11 @@  #! /bin/sh  # Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.68 for CRC-DabMux 0.3.0.4-r7. +# Generated by GNU Autoconf 2.69 for CRC-DabMux 0.3.0.4-r7.  #  # Report bugs to <pascal.charest@crc.ca>.  #  # -# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001, -# 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010 Free Software -# Foundation, Inc. +# Copyright (C) 1992-1996, 1998-2012 Free Software Foundation, Inc.  #  #  # This configure script is free software; the Free Software Foundation @@ -136,6 +134,31 @@ export LANGUAGE  # CDPATH.  (unset CDPATH) >/dev/null 2>&1 && unset CDPATH +# Use a proper internal environment variable to ensure we don't fall +  # into an infinite loop, continuously re-executing ourselves. +  if test x"${_as_can_reexec}" != xno && test "x$CONFIG_SHELL" != x; then +    _as_can_reexec=no; export _as_can_reexec; +    # We cannot yet assume a decent shell, so we have to provide a +# neutralization value for shells without unset; and this also +# works around shells that cannot unset nonexistent variables. +# Preserve -v and -x to the replacement shell. +BASH_ENV=/dev/null +ENV=/dev/null +(unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV +case $- in # (((( +  *v*x* | *x*v* ) as_opts=-vx ;; +  *v* ) as_opts=-v ;; +  *x* ) as_opts=-x ;; +  * ) as_opts= ;; +esac +exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} +# Admittedly, this is quite paranoid, since all the known shells bail +# out after a failed `exec'. +$as_echo "$0: could not re-execute with $CONFIG_SHELL" >&2 +as_fn_exit 255 +  fi +  # We don't want this to propagate to other subprocesses. +          { _as_can_reexec=; unset _as_can_reexec;}  if test "x$CONFIG_SHELL" = x; then    as_bourne_compatible="if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then :    emulate sh @@ -169,7 +192,8 @@ if ( set x; as_fn_ret_success y && test x = \"\$1\" ); then :  else    exitcode=1; echo positional parameters were not saved.  fi -test x\$exitcode = x0 || exit 1" +test x\$exitcode = x0 || exit 1 +test -x / || exit 1"    as_suggested="  as_lineno_1=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_1a=\$LINENO    as_lineno_2=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_2a=\$LINENO    eval 'test \"x\$as_lineno_1'\$as_run'\" != \"x\$as_lineno_2'\$as_run'\" && @@ -214,21 +238,25 @@ IFS=$as_save_IFS        if test "x$CONFIG_SHELL" != x; then : -  # We cannot yet assume a decent shell, so we have to provide a -	# neutralization value for shells without unset; and this also -	# works around shells that cannot unset nonexistent variables. -	# Preserve -v and -x to the replacement shell. -	BASH_ENV=/dev/null -	ENV=/dev/null -	(unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV -	export CONFIG_SHELL -	case $- in # (((( -	  *v*x* | *x*v* ) as_opts=-vx ;; -	  *v* ) as_opts=-v ;; -	  *x* ) as_opts=-x ;; -	  * ) as_opts= ;; -	esac -	exec "$CONFIG_SHELL" $as_opts "$as_myself" ${1+"$@"} +  export CONFIG_SHELL +             # We cannot yet assume a decent shell, so we have to provide a +# neutralization value for shells without unset; and this also +# works around shells that cannot unset nonexistent variables. +# Preserve -v and -x to the replacement shell. +BASH_ENV=/dev/null +ENV=/dev/null +(unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV +case $- in # (((( +  *v*x* | *x*v* ) as_opts=-vx ;; +  *v* ) as_opts=-v ;; +  *x* ) as_opts=-x ;; +  * ) as_opts= ;; +esac +exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} +# Admittedly, this is quite paranoid, since all the known shells bail +# out after a failed `exec'. +$as_echo "$0: could not re-execute with $CONFIG_SHELL" >&2 +exit 255  fi      if test x$as_have_required = xno; then : @@ -331,6 +359,14 @@ $as_echo X"$as_dir" |  } # as_fn_mkdir_p + +# as_fn_executable_p FILE +# ----------------------- +# Test if FILE is an executable regular file. +as_fn_executable_p () +{ +  test -f "$1" && test -x "$1" +} # as_fn_executable_p  # as_fn_append VAR VALUE  # ----------------------  # Append the text in VALUE to the end of the definition contained in VAR. Take @@ -452,6 +488,10 @@ as_cr_alnum=$as_cr_Letters$as_cr_digits    chmod +x "$as_me.lineno" ||      { $as_echo "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2; as_fn_exit 1; } +  # If we had to re-execute with $CONFIG_SHELL, we're ensured to have +  # already done that, so ensure we don't try to do so again and fall +  # in an infinite loop.  This has already happened in practice. +  _as_can_reexec=no; export _as_can_reexec    # Don't try to exec as it changes $[0], causing all sort of problems    # (the dirname of $[0] is not the place where we might find the    # original and so on.  Autoconf is especially sensitive to this). @@ -486,16 +526,16 @@ if (echo >conf$$.file) 2>/dev/null; then      # ... but there are two gotchas:      # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail.      # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. -    # In both cases, we have to default to `cp -p'. +    # In both cases, we have to default to `cp -pR'.      ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || -      as_ln_s='cp -p' +      as_ln_s='cp -pR'    elif ln conf$$.file conf$$ 2>/dev/null; then      as_ln_s=ln    else -    as_ln_s='cp -p' +    as_ln_s='cp -pR'    fi  else -  as_ln_s='cp -p' +  as_ln_s='cp -pR'  fi  rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file  rmdir conf$$.dir 2>/dev/null @@ -507,28 +547,8 @@ else    as_mkdir_p=false  fi -if test -x / >/dev/null 2>&1; then -  as_test_x='test -x' -else -  if ls -dL / >/dev/null 2>&1; then -    as_ls_L_option=L -  else -    as_ls_L_option= -  fi -  as_test_x=' -    eval sh -c '\'' -      if test -d "$1"; then -	test -d "$1/."; -      else -	case $1 in #( -	-*)set "./$1";; -	esac; -	case `ls -ld'$as_ls_L_option' "$1" 2>/dev/null` in #(( -	???[sx]*):;;*)false;;esac;fi -    '\'' sh -  ' -fi -as_executable_p=$as_test_x +as_test_x='test -x' +as_executable_p=as_fn_executable_p  # Sed expression to map a string onto a valid CPP name.  as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" @@ -1212,8 +1232,6 @@ target=$target_alias  if test "x$host_alias" != x; then    if test "x$build_alias" = x; then      cross_compiling=maybe -    $as_echo "$as_me: WARNING: if you wanted to set the --build type, don't use --host. -    If a cross compiler is detected then cross compile mode will be used" >&2    elif test "x$build_alias" != "x$host_alias"; then      cross_compiling=yes    fi @@ -1378,10 +1396,12 @@ Optional Features:    --disable-option-checking  ignore unrecognized --enable/--with options    --disable-FEATURE       do not include FEATURE (same as --enable-FEATURE=no)    --enable-FEATURE[=ARG]  include FEATURE [ARG=yes] -  --enable-silent-rules          less verbose build output (undo: `make V=1') -  --disable-silent-rules         verbose build output (undo: `make V=0') -  --disable-dependency-tracking  speeds up one-time build -  --enable-dependency-tracking   do not reject slow dependency extractors +  --enable-silent-rules   less verbose build output (undo: "make V=1") +  --disable-silent-rules  verbose build output (undo: "make V=0") +  --enable-dependency-tracking +                          do not reject slow dependency extractors +  --disable-dependency-tracking +                          speeds up one-time build    --disable-input-prbs    Disable PRBS input    --disable-input-test    Disable TEST input    --disable-input-slip    Disable SLIP input @@ -1495,9 +1515,9 @@ test -n "$ac_init_help" && exit $ac_status  if $ac_init_version; then    cat <<\_ACEOF  CRC-DabMux configure 0.3.0.4-r7 -generated by GNU Autoconf 2.68 +generated by GNU Autoconf 2.69 -Copyright (C) 2010 Free Software Foundation, Inc. +Copyright (C) 2012 Free Software Foundation, Inc.  This configure script is free software; the Free Software Foundation  gives unlimited permission to copy, distribute and modify it.  _ACEOF @@ -1611,7 +1631,7 @@ $as_echo "$ac_try_echo"; } >&5  	 test ! -s conftest.err         } && test -s conftest$ac_exeext && {  	 test "$cross_compiling" = yes || -	 $as_test_x conftest$ac_exeext +	 test -x conftest$ac_exeext         }; then :    ac_retval=0  else @@ -1909,7 +1929,8 @@ int  main ()  {  static int test_array [1 - 2 * !((($ac_type) -1 >> ($2 / 2 - 1)) >> ($2 / 2 - 1) == 3)]; -test_array [0] = 0 +test_array [0] = 0; +return test_array [0];    ;    return 0; @@ -2009,7 +2030,7 @@ This file contains any messages produced by compilers while  running configure, to aid debugging if configure makes a mistake.  It was created by CRC-DabMux $as_me 0.3.0.4-r7, which was -generated by GNU Autoconf 2.68.  Invocation command line was +generated by GNU Autoconf 2.69.  Invocation command line was    $ $0 $@ @@ -2496,7 +2517,7 @@ test -n "$target_alias" &&      NONENONEs,x,x, &&    program_prefix=${target_alias}- -am__api_version='1.11' +am__api_version='1.14'  # Find a good install program.  We prefer a C program (faster),  # so one script is as good as another.  But avoid the broken or @@ -2535,7 +2556,7 @@ case $as_dir/ in #((      # by default.      for ac_prog in ginstall scoinst install; do        for ac_exec_ext in '' $ac_executable_extensions; do -	if { test -f "$as_dir/$ac_prog$ac_exec_ext" && $as_test_x "$as_dir/$ac_prog$ac_exec_ext"; }; then +	if as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext"; then  	  if test $ac_prog = install &&  	    grep dspmsg "$as_dir/$ac_prog$ac_exec_ext" >/dev/null 2>&1; then  	    # AIX install.  It has an incompatible calling convention. @@ -2593,9 +2614,6 @@ test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644'  { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether build environment is sane" >&5  $as_echo_n "checking whether build environment is sane... " >&6; } -# Just in case -sleep 1 -echo timestamp > conftest.file  # Reject unsafe characters in $srcdir or the absolute working directory  # name.  Accept space and tab only in the latter.  am_lf=' @@ -2606,32 +2624,40 @@ case `pwd` in  esac  case $srcdir in    *[\\\"\#\$\&\'\`$am_lf\ \	]*) -    as_fn_error $? "unsafe srcdir value: \`$srcdir'" "$LINENO" 5;; +    as_fn_error $? "unsafe srcdir value: '$srcdir'" "$LINENO" 5;;  esac -# Do `set' in a subshell so we don't clobber the current shell's +# Do 'set' in a subshell so we don't clobber the current shell's  # arguments.  Must try -L first in case configure is actually a  # symlink; some systems play weird games with the mod time of symlinks  # (eg FreeBSD returns the mod time of the symlink's containing  # directory).  if ( -   set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` -   if test "$*" = "X"; then -      # -L didn't work. -      set X `ls -t "$srcdir/configure" conftest.file` -   fi -   rm -f conftest.file -   if test "$*" != "X $srcdir/configure conftest.file" \ -      && test "$*" != "X conftest.file $srcdir/configure"; then - -      # If neither matched, then we have a broken ls.  This can happen -      # if, for instance, CONFIG_SHELL is bash and it inherits a -      # broken ls alias from the environment.  This has actually -      # happened.  Such a system could not be considered "sane". -      as_fn_error $? "ls -t appears to fail.  Make sure there is not a broken -alias in your environment" "$LINENO" 5 -   fi - +   am_has_slept=no +   for am_try in 1 2; do +     echo "timestamp, slept: $am_has_slept" > conftest.file +     set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` +     if test "$*" = "X"; then +	# -L didn't work. +	set X `ls -t "$srcdir/configure" conftest.file` +     fi +     if test "$*" != "X $srcdir/configure conftest.file" \ +	&& test "$*" != "X conftest.file $srcdir/configure"; then + +	# If neither matched, then we have a broken ls.  This can happen +	# if, for instance, CONFIG_SHELL is bash and it inherits a +	# broken ls alias from the environment.  This has actually +	# happened.  Such a system could not be considered "sane". +	as_fn_error $? "ls -t appears to fail.  Make sure there is not a broken +  alias in your environment" "$LINENO" 5 +     fi +     if test "$2" = conftest.file || test $am_try -eq 2; then +       break +     fi +     # Just in case. +     sleep 1 +     am_has_slept=yes +   done     test "$2" = conftest.file     )  then @@ -2643,6 +2669,16 @@ Check your system clock" "$LINENO" 5  fi  { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5  $as_echo "yes" >&6; } +# If we didn't sleep, we still need to ensure time stamps of config.status and +# generated files are strictly newer. +am_sleep_pid= +if grep 'slept: no' conftest.file >/dev/null 2>&1; then +  ( sleep 1 ) & +  am_sleep_pid=$! +fi + +rm -f conftest.file +  test "$program_prefix" != NONE &&    program_transform_name="s&^&$program_prefix&;$program_transform_name"  # Use a double $ so make ignores it. @@ -2665,12 +2701,12 @@ if test x"${MISSING+set}" != xset; then    esac  fi  # Use eval to expand $SHELL -if eval "$MISSING --run true"; then -  am_missing_run="$MISSING --run " +if eval "$MISSING --is-lightweight"; then +  am_missing_run="$MISSING "  else    am_missing_run= -  { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: \`missing' script is too old or missing" >&5 -$as_echo "$as_me: WARNING: \`missing' script is too old or missing" >&2;} +  { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: 'missing' script is too old or missing" >&5 +$as_echo "$as_me: WARNING: 'missing' script is too old or missing" >&2;}  fi  if test x"${install_sh}" != xset; then @@ -2682,10 +2718,10 @@ if test x"${install_sh}" != xset; then    esac  fi -# Installed binaries are usually stripped using `strip' when the user -# run `make install-strip'.  However `strip' might not be the right +# Installed binaries are usually stripped using 'strip' when the user +# run "make install-strip".  However 'strip' might not be the right  # tool to use in cross-compilation environments, therefore Automake -# will honor the `STRIP' environment variable to overrule this program. +# will honor the 'STRIP' environment variable to overrule this program.  if test "$cross_compiling" != no; then    if test -n "$ac_tool_prefix"; then    # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. @@ -2704,7 +2740,7 @@ do    IFS=$as_save_IFS    test -z "$as_dir" && as_dir=.      for ac_exec_ext in '' $ac_executable_extensions; do -  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then +  if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then      ac_cv_prog_STRIP="${ac_tool_prefix}strip"      $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5      break 2 @@ -2744,7 +2780,7 @@ do    IFS=$as_save_IFS    test -z "$as_dir" && as_dir=.      for ac_exec_ext in '' $ac_executable_extensions; do -  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then +  if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then      ac_cv_prog_ac_ct_STRIP="strip"      $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5      break 2 @@ -2795,7 +2831,7 @@ do    test -z "$as_dir" && as_dir=.      for ac_prog in mkdir gmkdir; do  	 for ac_exec_ext in '' $ac_executable_extensions; do -	   { test -f "$as_dir/$ac_prog$ac_exec_ext" && $as_test_x "$as_dir/$ac_prog$ac_exec_ext"; } || continue +	   as_fn_executable_p "$as_dir/$ac_prog$ac_exec_ext" || continue  	   case `"$as_dir/$ac_prog$ac_exec_ext" --version 2>&1` in #(  	     'mkdir (GNU coreutils) '* | \  	     'mkdir (coreutils) '* | \ @@ -2824,12 +2860,6 @@ fi  { $as_echo "$as_me:${as_lineno-$LINENO}: result: $MKDIR_P" >&5  $as_echo "$MKDIR_P" >&6; } -mkdir_p="$MKDIR_P" -case $mkdir_p in -  [\\/$]* | ?:[\\/]*) ;; -  */*) mkdir_p="\$(top_builddir)/$mkdir_p" ;; -esac -  for ac_prog in gawk mawk nawk awk  do    # Extract the first word of "$ac_prog", so it can be a program name with args. @@ -2848,7 +2878,7 @@ do    IFS=$as_save_IFS    test -z "$as_dir" && as_dir=.      for ac_exec_ext in '' $ac_executable_extensions; do -  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then +  if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then      ac_cv_prog_AWK="$ac_prog"      $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5      break 2 @@ -2912,6 +2942,45 @@ else  fi  rmdir .tst 2>/dev/null +# Check whether --enable-silent-rules was given. +if test "${enable_silent_rules+set}" = set; then : +  enableval=$enable_silent_rules; +fi + +case $enable_silent_rules in # ((( +  yes) AM_DEFAULT_VERBOSITY=0;; +   no) AM_DEFAULT_VERBOSITY=1;; +    *) AM_DEFAULT_VERBOSITY=1;; +esac +am_make=${MAKE-make} +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 +$as_echo_n "checking whether $am_make supports nested variables... " >&6; } +if ${am_cv_make_support_nested_variables+:} false; then : +  $as_echo_n "(cached) " >&6 +else +  if $as_echo 'TRUE=$(BAR$(V)) +BAR0=false +BAR1=true +V=1 +am__doit: +	@$(TRUE) +.PHONY: am__doit' | $am_make -f - >/dev/null 2>&1; then +  am_cv_make_support_nested_variables=yes +else +  am_cv_make_support_nested_variables=no +fi +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_make_support_nested_variables" >&5 +$as_echo "$am_cv_make_support_nested_variables" >&6; } +if test $am_cv_make_support_nested_variables = yes; then +    AM_V='$(V)' +  AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' +else +  AM_V=$AM_DEFAULT_VERBOSITY +  AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY +fi +AM_BACKSLASH='\' +  if test "`cd $srcdir && pwd`" != "`pwd`"; then    # Use -I$(srcdir) only when $(srcdir) != ., so that make's output    # is not polluted with repeated "-I." @@ -2962,12 +3031,22 @@ AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"}  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: +# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html> +# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html> +mkdir_p='$(MKDIR_P)' +  # We need awk for the "check" target.  The system "awk" is bad on  # some platforms.  # Always define AMTAR for backward compatibility.  Yes, it's still used  # in the wild :-(  We should find a proper way to deprecate it ...  AMTAR='$${TAR-tar}' + +# We'll loop over all known methods to create a tar archive until one works. +_am_tools='gnutar  pax cpio none' +  am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -' @@ -2975,6 +3054,48 @@ am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -' +# POSIX will say in a future version that running "rm -f" with no argument +# is OK; and we want to be able to make that assumption in our Makefile +# recipes.  So use an aggressive probe to check that the usage we want is +# actually supported "in the wild" to an acceptable degree. +# See automake bug#10828. +# To make any issue more visible, cause the running configure to be aborted +# by default if the 'rm' program in use doesn't match our expectations; the +# user can still override this though. +if rm -f && rm -fr && rm -rf; then : OK; else +  cat >&2 <<'END' +Oops! + +Your 'rm' program seems unable to run without file operands specified +on the command line, even when the '-f' option is present.  This is contrary +to the behaviour of most rm programs out there, and not conforming with +the upcoming POSIX standard: <http://austingroupbugs.net/view.php?id=542> + +Please tell bug-automake@gnu.org about your system, including the value +of your $PATH and any error possibly output before this message.  This +can help us improve future automake versions. + +END +  if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then +    echo 'Configuration will proceed anyway, since you have set the' >&2 +    echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 +    echo >&2 +  else +    cat >&2 <<'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: <http://www.gnu.org/software/coreutils/>. + +If you want to complete the configuration process using your problematic +'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM +to "yes", and re-run configure. + +END +    as_fn_error $? "Your 'rm' program is bad, sorry." "$LINENO" 5 +  fi +fi +  ac_config_headers="$ac_config_headers config.h"  # Check whether --enable-silent-rules was given. @@ -2982,10 +3103,10 @@ if test "${enable_silent_rules+set}" = set; then :    enableval=$enable_silent_rules;  fi -case $enable_silent_rules in -yes) AM_DEFAULT_VERBOSITY=0;; -no)  AM_DEFAULT_VERBOSITY=1;; -*)   AM_DEFAULT_VERBOSITY=0;; +case $enable_silent_rules in # ((( +  yes) AM_DEFAULT_VERBOSITY=0;; +   no) AM_DEFAULT_VERBOSITY=1;; +    *) AM_DEFAULT_VERBOSITY=0;;  esac  am_make=${MAKE-make}  { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 @@ -3077,7 +3198,7 @@ do    IFS=$as_save_IFS    test -z "$as_dir" && as_dir=.      for ac_exec_ext in '' $ac_executable_extensions; do -  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then +  if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then      ac_cv_prog_CXX="$ac_tool_prefix$ac_prog"      $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5      break 2 @@ -3121,7 +3242,7 @@ do    IFS=$as_save_IFS    test -z "$as_dir" && as_dir=.      for ac_exec_ext in '' $ac_executable_extensions; do -  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then +  if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then      ac_cv_prog_ac_ct_CXX="$ac_prog"      $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5      break 2 @@ -3574,7 +3695,7 @@ am__quote=  _am_result=none  # First try GNU make style include.  echo "include confinc" > confmf -# Ignore all kinds of additional output from `make'. +# 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 @@ -3630,8 +3751,8 @@ else    # We make a subdir and do the tests there.  Otherwise we can end up    # making bogus files that we don't know about and never remove.  For    # instance it was reported that on HP-UX the gcc test will end up -  # making a dummy file named `D' -- because `-MD' means `put the output -  # in D'. +  # making a dummy file named 'D' -- because '-MD' means "put the output +  # in D".    rm -rf conftest.dir    mkdir conftest.dir    # Copy depcomp to subdir because otherwise we won't find it if we're @@ -3666,16 +3787,16 @@ else      : > sub/conftest.c      for i in 1 2 3 4 5 6; do        echo '#include "conftst'$i'.h"' >> sub/conftest.c -      # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with -      # Solaris 8's {/usr,}/bin/sh. -      touch sub/conftst$i.h +      # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with +      # Solaris 10 /bin/sh. +      echo '/* dummy */' > sub/conftst$i.h      done      echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf -    # We check with `-c' and `-o' for the sake of the "dashmstdout" +    # We check with '-c' and '-o' for the sake of the "dashmstdout"      # mode.  It turns out that the SunPro C++ compiler does not properly -    # handle `-M -o', and we need to detect this.  Also, some Intel -    # versions had trouble with output in subdirs +    # handle '-M -o', and we need to detect this.  Also, some Intel +    # versions had trouble with output in subdirs.      am__obj=sub/conftest.${OBJEXT-o}      am__minus_obj="-o $am__obj"      case $depmode in @@ -3684,8 +3805,8 @@ else        test "$am__universal" = false || continue        ;;      nosideeffect) -      # after this tag, mechanisms are not by side-effect, so they'll -      # only be used when explicitly requested +      # After this tag, mechanisms are not by side-effect, so they'll +      # only be used when explicitly requested.        if test "x$enable_dependency_tracking" = xyes; then  	continue        else @@ -3693,7 +3814,7 @@ else        fi        ;;      msvc7 | msvc7msys | msvisualcpp | msvcmsys) -      # This compiler won't grok `-c -o', but also, the minuso test has +      # This compiler won't grok '-c -o', but also, the minuso test has        # not run yet.  These depmodes are late enough in the game, and        # so weak that their functioning should not be impacted.        am__obj=conftest.${OBJEXT-o} @@ -3769,7 +3890,7 @@ do    IFS=$as_save_IFS    test -z "$as_dir" && as_dir=.      for ac_exec_ext in '' $ac_executable_extensions; do -  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then +  if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then      ac_cv_prog_CC="${ac_tool_prefix}gcc"      $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5      break 2 @@ -3809,7 +3930,7 @@ do    IFS=$as_save_IFS    test -z "$as_dir" && as_dir=.      for ac_exec_ext in '' $ac_executable_extensions; do -  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then +  if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then      ac_cv_prog_ac_ct_CC="gcc"      $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5      break 2 @@ -3862,7 +3983,7 @@ do    IFS=$as_save_IFS    test -z "$as_dir" && as_dir=.      for ac_exec_ext in '' $ac_executable_extensions; do -  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then +  if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then      ac_cv_prog_CC="${ac_tool_prefix}cc"      $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5      break 2 @@ -3903,7 +4024,7 @@ do    IFS=$as_save_IFS    test -z "$as_dir" && as_dir=.      for ac_exec_ext in '' $ac_executable_extensions; do -  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then +  if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then      if test "$as_dir/$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then         ac_prog_rejected=yes         continue @@ -3961,7 +4082,7 @@ do    IFS=$as_save_IFS    test -z "$as_dir" && as_dir=.      for ac_exec_ext in '' $ac_executable_extensions; do -  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then +  if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then      ac_cv_prog_CC="$ac_tool_prefix$ac_prog"      $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5      break 2 @@ -4005,7 +4126,7 @@ do    IFS=$as_save_IFS    test -z "$as_dir" && as_dir=.      for ac_exec_ext in '' $ac_executable_extensions; do -  if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then +  if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then      ac_cv_prog_ac_ct_CC="$ac_prog"      $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5      break 2 @@ -4201,8 +4322,7 @@ cat confdefs.h - <<_ACEOF >conftest.$ac_ext  /* end confdefs.h.  */  #include <stdarg.h>  #include <stdio.h> -#include <sys/types.h> -#include <sys/stat.h> +struct stat;  /* Most of the following tests are stolen from RCS 5.7's src/conf.sh.  */  struct buf { int x; };  FILE * (*rcsopen) (struct buf *, struct stat *, int); @@ -4287,6 +4407,65 @@ ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'  ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'  ac_compiler_gnu=$ac_cv_c_compiler_gnu +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC understands -c and -o together" >&5 +$as_echo_n "checking whether $CC understands -c and -o together... " >&6; } +if ${am_cv_prog_cc_c_o+:} false; then : +  $as_echo_n "(cached) " >&6 +else +  cat confdefs.h - <<_ACEOF >conftest.$ac_ext +/* end confdefs.h.  */ + +int +main () +{ + +  ; +  return 0; +} +_ACEOF +  # Make sure it works both with $CC and with simple cc. +  # Following AC_PROG_CC_C_O, we do the test twice because some +  # compilers refuse to overwrite an existing .o file with -o, +  # though they will create one. +  am_cv_prog_cc_c_o=yes +  for am_i in 1 2; do +    if { echo "$as_me:$LINENO: $CC -c conftest.$ac_ext -o conftest2.$ac_objext" >&5 +   ($CC -c conftest.$ac_ext -o conftest2.$ac_objext) >&5 2>&5 +   ac_status=$? +   echo "$as_me:$LINENO: \$? = $ac_status" >&5 +   (exit $ac_status); } \ +         && test -f conftest2.$ac_objext; then +      : OK +    else +      am_cv_prog_cc_c_o=no +      break +    fi +  done +  rm -f core conftest* +  unset am_i +fi +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $am_cv_prog_cc_c_o" >&5 +$as_echo "$am_cv_prog_cc_c_o" >&6; } +if test "$am_cv_prog_cc_c_o" != yes; then +   # Losing compiler, so override with the script. +   # FIXME: It is wrong to rewrite CC. +   # But if we don't then we get into trouble of one sort or another. +   # A longer-term fix would be to have automake use am__CC in this case, +   # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" +   CC="$am_aux_dir/compile $CC" +fi +ac_ext=c +ac_cpp='$CPP $CPPFLAGS' +ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' +ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' +ac_compiler_gnu=$ac_cv_c_compiler_gnu + +  depcc="$CC"   am_compiler_list=  { $as_echo "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 @@ -4298,8 +4477,8 @@ else    # We make a subdir and do the tests there.  Otherwise we can end up    # making bogus files that we don't know about and never remove.  For    # instance it was reported that on HP-UX the gcc test will end up -  # making a dummy file named `D' -- because `-MD' means `put the output -  # in D'. +  # making a dummy file named 'D' -- because '-MD' means "put the output +  # in D".    rm -rf conftest.dir    mkdir conftest.dir    # Copy depcomp to subdir because otherwise we won't find it if we're @@ -4334,16 +4513,16 @@ else      : > sub/conftest.c      for i in 1 2 3 4 5 6; do        echo '#include "conftst'$i'.h"' >> sub/conftest.c -      # Using `: > sub/conftst$i.h' creates only sub/conftst1.h with -      # Solaris 8's {/usr,}/bin/sh. -      touch sub/conftst$i.h +      # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with +      # Solaris 10 /bin/sh. +      echo '/* dummy */' > sub/conftst$i.h      done      echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf -    # We check with `-c' and `-o' for the sake of the "dashmstdout" +    # We check with '-c' and '-o' for the sake of the "dashmstdout"      # mode.  It turns out that the SunPro C++ compiler does not properly -    # handle `-M -o', and we need to detect this.  Also, some Intel -    # versions had trouble with output in subdirs +    # handle '-M -o', and we need to detect this.  Also, some Intel +    # versions had trouble with output in subdirs.      am__obj=sub/conftest.${OBJEXT-o}      am__minus_obj="-o $am__obj"      case $depmode in @@ -4352,8 +4531,8 @@ else        test "$am__universal" = false || continue        ;;      nosideeffect) -      # after this tag, mechanisms are not by side-effect, so they'll -      # only be used when explicitly requested +      # After this tag, mechanisms are not by side-effect, so they'll +      # only be used when explicitly requested.        if test "x$enable_dependency_tracking" = xyes; then  	continue        else @@ -4361,7 +4540,7 @@ else        fi        ;;      msvc7 | msvc7msys | msvisualcpp | msvcmsys) -      # This compiler won't grok `-c -o', but also, the minuso test has +      # This compiler won't grok '-c -o', but also, the minuso test has        # not run yet.  These depmodes are late enough in the game, and        # so weak that their functioning should not be impacted.        am__obj=conftest.${OBJEXT-o} @@ -4415,131 +4594,6 @@ else  fi -if test "x$CC" != xcc; then -  { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC and cc understand -c and -o together" >&5 -$as_echo_n "checking whether $CC and cc understand -c and -o together... " >&6; } -else -  { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether cc understands -c and -o together" >&5 -$as_echo_n "checking whether cc understands -c and -o together... " >&6; } -fi -set dummy $CC; ac_cc=`$as_echo "$2" | -		      sed 's/[^a-zA-Z0-9_]/_/g;s/^[0-9]/_/'` -if eval \${ac_cv_prog_cc_${ac_cc}_c_o+:} false; then : -  $as_echo_n "(cached) " >&6 -else -  cat confdefs.h - <<_ACEOF >conftest.$ac_ext -/* end confdefs.h.  */ - -int -main () -{ - -  ; -  return 0; -} -_ACEOF -# Make sure it works both with $CC and with simple cc. -# We do the test twice because some compilers refuse to overwrite an -# existing .o file with -o, though they will create one. -ac_try='$CC -c conftest.$ac_ext -o conftest2.$ac_objext >&5' -rm -f conftest2.* -if { { case "(($ac_try" in -  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; -  *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 -  (eval "$ac_try") 2>&5 -  ac_status=$? -  $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 -  test $ac_status = 0; } && -   test -f conftest2.$ac_objext && { { case "(($ac_try" in -  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; -  *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 -  (eval "$ac_try") 2>&5 -  ac_status=$? -  $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 -  test $ac_status = 0; }; -then -  eval ac_cv_prog_cc_${ac_cc}_c_o=yes -  if test "x$CC" != xcc; then -    # Test first that cc exists at all. -    if { ac_try='cc -c conftest.$ac_ext >&5' -  { { case "(($ac_try" in -  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; -  *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 -  (eval "$ac_try") 2>&5 -  ac_status=$? -  $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 -  test $ac_status = 0; }; }; then -      ac_try='cc -c conftest.$ac_ext -o conftest2.$ac_objext >&5' -      rm -f conftest2.* -      if { { case "(($ac_try" in -  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; -  *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 -  (eval "$ac_try") 2>&5 -  ac_status=$? -  $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 -  test $ac_status = 0; } && -	 test -f conftest2.$ac_objext && { { case "(($ac_try" in -  *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; -  *) ac_try_echo=$ac_try;; -esac -eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" -$as_echo "$ac_try_echo"; } >&5 -  (eval "$ac_try") 2>&5 -  ac_status=$? -  $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 -  test $ac_status = 0; }; -      then -	# cc works too. -	: -      else -	# cc exists but doesn't like -o. -	eval ac_cv_prog_cc_${ac_cc}_c_o=no -      fi -    fi -  fi -else -  eval ac_cv_prog_cc_${ac_cc}_c_o=no -fi -rm -f core conftest* - -fi -if eval test \$ac_cv_prog_cc_${ac_cc}_c_o = yes; 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; } - -$as_echo "#define NO_MINUS_C_MINUS_O 1" >>confdefs.h - -fi - -# FIXME: we rely on the cache variable name because -# there is no other way. -set dummy $CC -am_cc=`echo $2 | sed 's/[^a-zA-Z0-9_]/_/g;s/^[0-9]/_/'` -eval am_t=\$ac_cv_prog_cc_${am_cc}_c_o -if test "$am_t" != yes; then -   # Losing compiler, so override with the script. -   # FIXME: It is wrong to rewrite CC. -   # But if we don't then we get into trouble of one sort or another. -   # A longer-term fix would be to have automake use am__CC in this case, -   # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" -   CC="$am_aux_dir/compile $CC" -fi - @@ -5047,7 +5101,7 @@ do      for ac_prog in grep ggrep; do      for ac_exec_ext in '' $ac_executable_extensions; do        ac_path_GREP="$as_dir/$ac_prog$ac_exec_ext" -      { test -f "$ac_path_GREP" && $as_test_x "$ac_path_GREP"; } || continue +      as_fn_executable_p "$ac_path_GREP" || continue  # Check for GNU ac_path_GREP and select it if it is found.    # Check for GNU $ac_path_GREP  case `"$ac_path_GREP" --version 2>&1` in @@ -5113,7 +5167,7 @@ do      for ac_prog in egrep; do      for ac_exec_ext in '' $ac_executable_extensions; do        ac_path_EGREP="$as_dir/$ac_prog$ac_exec_ext" -      { test -f "$ac_path_EGREP" && $as_test_x "$ac_path_EGREP"; } || continue +      as_fn_executable_p "$ac_path_EGREP" || continue  # Check for GNU ac_path_EGREP and select it if it is found.    # Check for GNU $ac_path_EGREP  case `"$ac_path_EGREP" --version 2>&1` in @@ -5354,60 +5408,60 @@ else    cat confdefs.h - <<_ACEOF >conftest.$ac_ext  /* end confdefs.h.  */ -#include <stdbool.h> -#ifndef bool - "error: bool is not defined" -#endif -#ifndef false - "error: false is not defined" -#endif -#if false - "error: false is not 0" -#endif -#ifndef true - "error: true is not defined" -#endif -#if true != 1 - "error: true is not 1" -#endif -#ifndef __bool_true_false_are_defined - "error: __bool_true_false_are_defined is not defined" -#endif - -	struct s { _Bool s: 1; _Bool t; } s; - -	char a[true == 1 ? 1 : -1]; -	char b[false == 0 ? 1 : -1]; -	char c[__bool_true_false_are_defined == 1 ? 1 : -1]; -	char d[(bool) 0.5 == true ? 1 : -1]; -	/* See body of main program for 'e'.  */ -	char f[(_Bool) 0.0 == false ? 1 : -1]; -	char g[true]; -	char h[sizeof (_Bool)]; -	char i[sizeof s.t]; -	enum { j = false, k = true, l = false * true, m = true * 256 }; -	/* The following fails for -	   HP aC++/ANSI C B3910B A.05.55 [Dec 04 2003]. */ -	_Bool n[m]; -	char o[sizeof n == m * sizeof n[0] ? 1 : -1]; -	char p[-1 - (_Bool) 0 < 0 && -1 - (bool) 0 < 0 ? 1 : -1]; -	/* Catch a bug in an HP-UX C compiler.  See -	   http://gcc.gnu.org/ml/gcc-patches/2003-12/msg02303.html -	   http://lists.gnu.org/archive/html/bug-coreutils/2005-11/msg00161.html -	 */ -	_Bool q = true; -	_Bool *pq = &q; +             #include <stdbool.h> +             #ifndef bool +              "error: bool is not defined" +             #endif +             #ifndef false +              "error: false is not defined" +             #endif +             #if false +              "error: false is not 0" +             #endif +             #ifndef true +              "error: true is not defined" +             #endif +             #if true != 1 +              "error: true is not 1" +             #endif +             #ifndef __bool_true_false_are_defined +              "error: __bool_true_false_are_defined is not defined" +             #endif + +             struct s { _Bool s: 1; _Bool t; } s; + +             char a[true == 1 ? 1 : -1]; +             char b[false == 0 ? 1 : -1]; +             char c[__bool_true_false_are_defined == 1 ? 1 : -1]; +             char d[(bool) 0.5 == true ? 1 : -1]; +             /* See body of main program for 'e'.  */ +             char f[(_Bool) 0.0 == false ? 1 : -1]; +             char g[true]; +             char h[sizeof (_Bool)]; +             char i[sizeof s.t]; +             enum { j = false, k = true, l = false * true, m = true * 256 }; +             /* The following fails for +                HP aC++/ANSI C B3910B A.05.55 [Dec 04 2003]. */ +             _Bool n[m]; +             char o[sizeof n == m * sizeof n[0] ? 1 : -1]; +             char p[-1 - (_Bool) 0 < 0 && -1 - (bool) 0 < 0 ? 1 : -1]; +             /* Catch a bug in an HP-UX C compiler.  See +                http://gcc.gnu.org/ml/gcc-patches/2003-12/msg02303.html +                http://lists.gnu.org/archive/html/bug-coreutils/2005-11/msg00161.html +              */ +             _Bool q = true; +             _Bool *pq = &q;  int  main ()  { -	bool e = &s; -	*pq |= q; -	*pq |= ! q; -	/* Refer to every declared value, to avoid compiler optimizations.  */ -	return (!a + !b + !c + !d + !e + !f + !g + !h + !i + !!j + !k + !!l -		+ !m + !n + !o + !p + !q + !pq); +             bool e = &s; +             *pq |= q; +             *pq |= ! q; +             /* Refer to every declared value, to avoid compiler optimizations.  */ +             return (!a + !b + !c + !d + !e + !f + !g + !h + !i + !!j + !k + !!l +                     + !m + !n + !o + !p + !q + !pq);    ;    return 0; @@ -5422,7 +5476,7 @@ rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext  fi  { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_header_stdbool_h" >&5  $as_echo "$ac_cv_header_stdbool_h" >&6; } -ac_fn_c_check_type "$LINENO" "_Bool" "ac_cv_type__Bool" "$ac_includes_default" +   ac_fn_c_check_type "$LINENO" "_Bool" "ac_cv_type__Bool" "$ac_includes_default"  if test "x$ac_cv_type__Bool" = xyes; then :  cat >>confdefs.h <<_ACEOF @@ -5432,6 +5486,7 @@ _ACEOF  fi +  if test $ac_cv_header_stdbool_h = yes; then  $as_echo "#define HAVE_STDBOOL_H 1" >>confdefs.h @@ -5449,11 +5504,11 @@ else  int  main ()  { -/* FIXME: Include the comments suggested by Paul. */ +  #ifndef __cplusplus -  /* Ultrix mips cc rejects this.  */ +  /* Ultrix mips cc rejects this sort of thing.  */    typedef int charset[2]; -  const charset cs; +  const charset cs = { 0, 0 };    /* SunOS 4.1.1 cc rejects this.  */    char const *const *pcpcc;    char **ppc; @@ -5470,8 +5525,9 @@ main ()    ++pcpcc;    ppc = (char**) pcpcc;    pcpcc = (char const *const *) ppc; -  { /* SCO 3.2v4 cc rejects this.  */ -    char *t; +  { /* SCO 3.2v4 cc rejects this sort of thing.  */ +    char tx; +    char *t = &tx;      char const *s = 0 ? (char *) 0 : (char const *) 0;      *t++ = 0; @@ -5487,10 +5543,10 @@ main ()      iptr p = 0;      ++p;    } -  { /* AIX XL C 1.02.0.0 rejects this saying +  { /* AIX XL C 1.02.0.0 rejects this sort of thing, saying         "k.c", line 2.27: 1506-025 (S) Operand must be a modifiable lvalue. */ -    struct s { int j; const int *ap[3]; }; -    struct s *b; b->j = 5; +    struct s { int j; const int *ap[3]; } bx; +    struct s *b = &bx; b->j = 5;    }    { /* ULTRIX-32 V3.1 (Rev 9) vcc rejects this */      const int foo = 10; @@ -6354,6 +6410,14 @@ LIBOBJS=$ac_libobjs  LTLIBOBJS=$ac_ltlibobjs +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking that generated files are newer than configure" >&5 +$as_echo_n "checking that generated files are newer than configure... " >&6; } +   if test -n "$am_sleep_pid"; then +     # Hide warnings about reused PIDs. +     wait $am_sleep_pid 2>/dev/null +   fi +   { $as_echo "$as_me:${as_lineno-$LINENO}: result: done" >&5 +$as_echo "done" >&6; }   if test -n "$EXEEXT"; then    am__EXEEXT_TRUE=    am__EXEEXT_FALSE='#' @@ -6676,16 +6740,16 @@ if (echo >conf$$.file) 2>/dev/null; then      # ... but there are two gotchas:      # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail.      # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. -    # In both cases, we have to default to `cp -p'. +    # In both cases, we have to default to `cp -pR'.      ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || -      as_ln_s='cp -p' +      as_ln_s='cp -pR'    elif ln conf$$.file conf$$ 2>/dev/null; then      as_ln_s=ln    else -    as_ln_s='cp -p' +    as_ln_s='cp -pR'    fi  else -  as_ln_s='cp -p' +  as_ln_s='cp -pR'  fi  rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file  rmdir conf$$.dir 2>/dev/null @@ -6745,28 +6809,16 @@ else    as_mkdir_p=false  fi -if test -x / >/dev/null 2>&1; then -  as_test_x='test -x' -else -  if ls -dL / >/dev/null 2>&1; then -    as_ls_L_option=L -  else -    as_ls_L_option= -  fi -  as_test_x=' -    eval sh -c '\'' -      if test -d "$1"; then -	test -d "$1/."; -      else -	case $1 in #( -	-*)set "./$1";; -	esac; -	case `ls -ld'$as_ls_L_option' "$1" 2>/dev/null` in #(( -	???[sx]*):;;*)false;;esac;fi -    '\'' sh -  ' -fi -as_executable_p=$as_test_x + +# as_fn_executable_p FILE +# ----------------------- +# Test if FILE is an executable regular file. +as_fn_executable_p () +{ +  test -f "$1" && test -x "$1" +} # as_fn_executable_p +as_test_x='test -x' +as_executable_p=as_fn_executable_p  # Sed expression to map a string onto a valid CPP name.  as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" @@ -6788,7 +6840,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1  # values after options handling.  ac_log="  This file was extended by CRC-DabMux $as_me 0.3.0.4-r7, which was -generated by GNU Autoconf 2.68.  Invocation command line was +generated by GNU Autoconf 2.69.  Invocation command line was    CONFIG_FILES    = $CONFIG_FILES    CONFIG_HEADERS  = $CONFIG_HEADERS @@ -6854,10 +6906,10 @@ cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1  ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`"  ac_cs_version="\\  CRC-DabMux config.status 0.3.0.4-r7 -configured by $0, generated by GNU Autoconf 2.68, +configured by $0, generated by GNU Autoconf 2.69,    with options \\"\$ac_cs_config\\" -Copyright (C) 2010 Free Software Foundation, Inc. +Copyright (C) 2012 Free Software Foundation, Inc.  This config.status script is free software; the Free Software Foundation  gives unlimited permission to copy, distribute and modify it." @@ -6948,7 +7000,7 @@ fi  _ACEOF  cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1  if \$ac_cs_recheck; then -  set X '$SHELL' '$0' $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion +  set X $SHELL '$0' $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion    shift    \$as_echo "running CONFIG_SHELL=$SHELL \$*" >&6    CONFIG_SHELL='$SHELL' @@ -7584,7 +7636,7 @@ $as_echo "$as_me: executing $ac_file commands" >&6;}    case $ac_file$ac_mode in      "depfiles":C) test x"$AMDEP_TRUE" != x"" || { -  # Autoconf 2.62 quotes --file arguments for eval, but not when files +  # 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 @@ -7597,7 +7649,7 @@ $as_echo "$as_me: executing $ac_file commands" >&6;}      # 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 +    # 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. @@ -7631,21 +7683,19 @@ $as_echo X"$mf" |        continue      fi      # Extract the definition of DEPDIR, am__include, and am__quote -    # from the Makefile without running `make'. +    # 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 +    test -z "$am__include" && continue      am__quote=`sed -n 's/^am__quote = //p' < "$mf"` -    # When using ansi2knr, U may be empty or an underscore; expand it -    U=`sed -n 's/^U = //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' -e 's/\$U/'"$U"'/g'`; do +	 sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do        # Make sure the directory exists.        test -f "$dirpart/$file" && continue        fdir=`$as_dirname -- "$file" || diff --git a/configure.ac b/configure.ac index 9106a57..fbcfe3c 100644 --- a/configure.ac +++ b/configure.ac @@ -20,7 +20,7 @@ AC_PREREQ(2.61)  AC_INIT([CRC-DabMux], [0.3.0.4-r7], [pascal.charest@crc.ca])  AC_CONFIG_AUX_DIR([build-aux])  AC_CANONICAL_SYSTEM -AM_INIT_AUTOMAKE([-Wall]) +AM_INIT_AUTOMAKE([-Wall subdir-objects])  AC_CONFIG_SRCDIR([src/DabMux.cpp])  AC_CONFIG_HEADER([config.h])  AM_SILENT_RULES([yes]) diff --git a/lib/Makefile.in b/lib/Makefile.in index 4a7524d..1edad99 100644 --- a/lib/Makefile.in +++ b/lib/Makefile.in @@ -1,9 +1,8 @@ -# Makefile.in generated by automake 1.11.6 from Makefile.am. +# Makefile.in generated by automake 1.14 from Makefile.am.  # @configure_input@ -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Free Software -# Foundation, Inc. +# Copyright (C) 1994-2013 Free Software Foundation, Inc. +  # This Makefile.in 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. @@ -33,23 +32,51 @@  # You should have received a copy of the GNU General Public License  # along with CRC-DabMux.  If not, see <http://www.gnu.org/licenses/>.  VPATH = @srcdir@ -am__make_dryrun = \ -  { \ -    am__dry=no; \ +am__is_gnu_make = test -n '$(MAKEFILE_LIST)' && test -n '$(MAKELEVEL)' +am__make_running_with_option = \ +  case $${target_option-} in \ +      ?) ;; \ +      *) echo "am__make_running_with_option: internal error: invalid" \ +              "target option '$${target_option-}' specified" >&2; \ +         exit 1;; \ +  esac; \ +  has_opt=no; \ +  sane_makeflags=$$MAKEFLAGS; \ +  if $(am__is_gnu_make); then \ +    sane_makeflags=$$MFLAGS; \ +  else \      case $$MAKEFLAGS in \        *\\[\ \	]*) \ -        echo 'am--echo: ; @echo "AM"  OK' | $(MAKE) -f - 2>/dev/null \ -          | grep '^AM OK$$' >/dev/null || am__dry=yes;; \ -      *) \ -        for am__flg in $$MAKEFLAGS; do \ -          case $$am__flg in \ -            *=*|--*) ;; \ -            *n*) am__dry=yes; break;; \ -          esac; \ -        done;; \ +        bs=\\; \ +        sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ +          | sed "s/$$bs$$bs[$$bs $$bs	]*//g"`;; \ +    esac; \ +  fi; \ +  skip_next=no; \ +  strip_trailopt () \ +  { \ +    flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ +  }; \ +  for flg in $$sane_makeflags; do \ +    test $$skip_next = yes && { skip_next=no; continue; }; \ +    case $$flg in \ +      *=*|--*) continue;; \ +        -*I) strip_trailopt 'I'; skip_next=yes;; \ +      -*I?*) strip_trailopt 'I';; \ +        -*O) strip_trailopt 'O'; skip_next=yes;; \ +      -*O?*) strip_trailopt 'O';; \ +        -*l) strip_trailopt 'l'; skip_next=yes;; \ +      -*l?*) strip_trailopt 'l';; \ +      -[dEDm]) skip_next=yes;; \ +      -[JT]) skip_next=yes;; \ +    esac; \ +    case $$flg in \ +      *$$target_option*) has_opt=yes; break;; \      esac; \ -    test $$am__dry = yes; \ -  } +  done; \ +  test $$has_opt = yes +am__make_dryrun = (target_option=n; $(am__make_running_with_option)) +am__make_keepgoing = (target_option=k; $(am__make_running_with_option))  pkgdatadir = $(datadir)/@PACKAGE@  pkgincludedir = $(includedir)/@PACKAGE@  pkglibdir = $(libdir)/@PACKAGE@ @@ -70,7 +97,7 @@ build_triplet = @build@  host_triplet = @host@  target_triplet = @target@  subdir = lib -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in +DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/Makefile.am  ACLOCAL_M4 = $(top_srcdir)/aclocal.m4  am__aclocal_m4_deps = $(top_srcdir)/m4/ax_boost_base.m4 \  	$(top_srcdir)/configure.ac @@ -80,21 +107,28 @@ mkinstalldirs = $(install_sh) -d  CONFIG_HEADER = $(top_builddir)/config.h  CONFIG_CLEAN_FILES =  CONFIG_CLEAN_VPATH_FILES = +AM_V_P = $(am__v_P_@AM_V@) +am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) +am__v_P_0 = false +am__v_P_1 = :  AM_V_GEN = $(am__v_GEN_@AM_V@)  am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) -am__v_GEN_0 = @echo "  GEN   " $@; +am__v_GEN_0 = @echo "  GEN     " $@; +am__v_GEN_1 =   AM_V_at = $(am__v_at_@AM_V@)  am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)  am__v_at_0 = @ +am__v_at_1 =   SOURCES =  DIST_SOURCES = -RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \ -	html-recursive info-recursive install-data-recursive \ -	install-dvi-recursive install-exec-recursive \ -	install-html-recursive install-info-recursive \ -	install-pdf-recursive install-ps-recursive install-recursive \ -	installcheck-recursive installdirs-recursive pdf-recursive \ -	ps-recursive uninstall-recursive +RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ +	ctags-recursive dvi-recursive html-recursive info-recursive \ +	install-data-recursive install-dvi-recursive \ +	install-exec-recursive install-html-recursive \ +	install-info-recursive install-pdf-recursive \ +	install-ps-recursive install-recursive installcheck-recursive \ +	installdirs-recursive pdf-recursive ps-recursive \ +	tags-recursive uninstall-recursive  am__can_run_installinfo = \    case $$AM_UPDATE_INFO_DIR in \      n|no|NO) false;; \ @@ -102,9 +136,29 @@ am__can_run_installinfo = \    esac  RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive	\    distclean-recursive maintainer-clean-recursive -AM_RECURSIVE_TARGETS = $(RECURSIVE_TARGETS:-recursive=) \ -	$(RECURSIVE_CLEAN_TARGETS:-recursive=) tags TAGS ctags CTAGS \ +am__recursive_targets = \ +  $(RECURSIVE_TARGETS) \ +  $(RECURSIVE_CLEAN_TARGETS) \ +  $(am__extra_recursive_targets) +AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \  	distdir +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. +am__uniquify_input = $(AWK) '\ +  BEGIN { nonempty = 0; } \ +  { items[$$0] = 1; nonempty = 1; } \ +  END { if (nonempty) { for (i in items) print i; }; } \ +' +# Make sure the list of sources is unique.  This is necessary because, +# e.g., the same source file might be shared among _SOURCES variables +# for different programs/libraries. +am__define_uniq_tagged_files = \ +  list='$(am__tagged_files)'; \ +  unique=`for i in $$list; do \ +    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ +  done | $(am__uniquify_input)`  ETAGS = etags  CTAGS = ctags  DIST_SUBDIRS = $(SUBDIRS) @@ -280,22 +334,25 @@ $(ACLOCAL_M4):  $(am__aclocal_m4_deps)  $(am__aclocal_m4_deps):  # This directory's subdirectories are mostly independent; you can cd -# into them and run `make' without going through this Makefile. -# To change the values of `make' variables: instead of editing Makefiles, -# (1) if the variable is set in `config.status', edit `config.status' -#     (which will cause the Makefiles to be regenerated when you run `make'); -# (2) otherwise, pass the desired values on the `make' command line. -$(RECURSIVE_TARGETS): -	@fail= failcom='exit 1'; \ -	for f in x $$MAKEFLAGS; do \ -	  case $$f in \ -	    *=* | --[!k]*);; \ -	    *k*) failcom='fail=yes';; \ -	  esac; \ -	done; \ +# into them and run 'make' without going through this Makefile. +# To change the values of 'make' variables: instead of editing Makefiles, +# (1) if the variable is set in 'config.status', edit 'config.status' +#     (which will cause the Makefiles to be regenerated when you run 'make'); +# (2) otherwise, pass the desired values on the 'make' command line. +$(am__recursive_targets): +	@fail=; \ +	if $(am__make_keepgoing); then \ +	  failcom='fail=yes'; \ +	else \ +	  failcom='exit 1'; \ +	fi; \  	dot_seen=no; \  	target=`echo $@ | sed s/-recursive//`; \ -	list='$(SUBDIRS)'; for subdir in $$list; do \ +	case "$@" in \ +	  distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ +	  *) list='$(SUBDIRS)' ;; \ +	esac; \ +	for subdir in $$list; do \  	  echo "Making $$target in $$subdir"; \  	  if test "$$subdir" = "."; then \  	    dot_seen=yes; \ @@ -310,57 +367,12 @@ $(RECURSIVE_TARGETS):  	  $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \  	fi; test -z "$$fail" -$(RECURSIVE_CLEAN_TARGETS): -	@fail= failcom='exit 1'; \ -	for f in x $$MAKEFLAGS; do \ -	  case $$f in \ -	    *=* | --[!k]*);; \ -	    *k*) failcom='fail=yes';; \ -	  esac; \ -	done; \ -	dot_seen=no; \ -	case "$@" in \ -	  distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ -	  *) list='$(SUBDIRS)' ;; \ -	esac; \ -	rev=''; for subdir in $$list; do \ -	  if test "$$subdir" = "."; then :; else \ -	    rev="$$subdir $$rev"; \ -	  fi; \ -	done; \ -	rev="$$rev ."; \ -	target=`echo $@ | sed s/-recursive//`; \ -	for subdir in $$rev; do \ -	  echo "Making $$target in $$subdir"; \ -	  if test "$$subdir" = "."; then \ -	    local_target="$$target-am"; \ -	  else \ -	    local_target="$$target"; \ -	  fi; \ -	  ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ -	  || eval $$failcom; \ -	done && test -z "$$fail" -tags-recursive: -	list='$(SUBDIRS)'; for subdir in $$list; do \ -	  test "$$subdir" = . || ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) tags); \ -	done -ctags-recursive: -	list='$(SUBDIRS)'; for subdir in $$list; do \ -	  test "$$subdir" = . || ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) ctags); \ -	done +ID: $(am__tagged_files) +	$(am__define_uniq_tagged_files); mkid -fID $$unique +tags: tags-recursive +TAGS: tags -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) -	list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ -	unique=`for i in $$list; do \ -	    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -	  done | \ -	  $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ -	      END { if (nonempty) { for (i in files) print i; }; }'`; \ -	mkid -fID $$unique -tags: TAGS - -TAGS: tags-recursive $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \ -		$(TAGS_FILES) $(LISP) +tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)  	set x; \  	here=`pwd`; \  	if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ @@ -376,12 +388,7 @@ TAGS: tags-recursive $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \  	      set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \  	  fi; \  	done; \ -	list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \ -	unique=`for i in $$list; do \ -	    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -	  done | \ -	  $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ -	      END { if (nonempty) { for (i in files) print i; }; }'`; \ +	$(am__define_uniq_tagged_files); \  	shift; \  	if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \  	  test -n "$$unique" || unique=$$empty_fix; \ @@ -393,15 +400,11 @@ TAGS: tags-recursive $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \  	      $$unique; \  	  fi; \  	fi -ctags: CTAGS -CTAGS: ctags-recursive $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \ -		$(TAGS_FILES) $(LISP) -	list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \ -	unique=`for i in $$list; do \ -	    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -	  done | \ -	  $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ -	      END { if (nonempty) { for (i in files) print i; }; }'`; \ +ctags: ctags-recursive + +CTAGS: ctags +ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) +	$(am__define_uniq_tagged_files); \  	test -z "$(CTAGS_ARGS)$$unique" \  	  || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \  	     $$unique @@ -410,6 +413,21 @@ GTAGS:  	here=`$(am__cd) $(top_builddir) && pwd` \  	  && $(am__cd) $(top_srcdir) \  	  && gtags -i $(GTAGS_ARGS) "$$here" +cscopelist: cscopelist-recursive + +cscopelist-am: $(am__tagged_files) +	list='$(am__tagged_files)'; \ +	case "$(srcdir)" in \ +	  [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ +	  *) sdir=$(subdir)/$(srcdir) ;; \ +	esac; \ +	for i in $$list; do \ +	  if test -f "$$i"; then \ +	    echo "$(subdir)/$$i"; \ +	  else \ +	    echo "$$sdir/$$i"; \ +	  fi; \ +	done >> $(top_builddir)/cscope.files  distclean-tags:  	-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags @@ -570,21 +588,19 @@ ps-am:  uninstall-am: -.MAKE: $(RECURSIVE_CLEAN_TARGETS) $(RECURSIVE_TARGETS) ctags-recursive \ -	install-am install-strip tags-recursive - -.PHONY: $(RECURSIVE_CLEAN_TARGETS) $(RECURSIVE_TARGETS) CTAGS GTAGS \ -	all all-am check check-am clean clean-generic ctags \ -	ctags-recursive distclean distclean-generic distclean-tags \ -	distdir dvi dvi-am html html-am info info-am install \ -	install-am install-data install-data-am install-dvi \ -	install-dvi-am 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-recursive uninstall uninstall-am +.MAKE: $(am__recursive_targets) install-am install-strip + +.PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am check \ +	check-am clean clean-generic cscopelist-am ctags ctags-am \ +	distclean distclean-generic distclean-tags distdir dvi dvi-am \ +	html html-am info info-am install install-am install-data \ +	install-data-am install-dvi install-dvi-am 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  # Tell versions [3.59,3.63) of GNU make to not export all variables. diff --git a/lib/farsync/Makefile.in b/lib/farsync/Makefile.in index 6824efd..50eee7e 100644 --- a/lib/farsync/Makefile.in +++ b/lib/farsync/Makefile.in @@ -1,9 +1,8 @@ -# Makefile.in generated by automake 1.11.6 from Makefile.am. +# Makefile.in generated by automake 1.14 from Makefile.am.  # @configure_input@ -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Free Software -# Foundation, Inc. +# Copyright (C) 1994-2013 Free Software Foundation, Inc. +  # This Makefile.in 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. @@ -15,23 +14,51 @@  @SET_MAKE@  VPATH = @srcdir@ -am__make_dryrun = \ -  { \ -    am__dry=no; \ +am__is_gnu_make = test -n '$(MAKEFILE_LIST)' && test -n '$(MAKELEVEL)' +am__make_running_with_option = \ +  case $${target_option-} in \ +      ?) ;; \ +      *) echo "am__make_running_with_option: internal error: invalid" \ +              "target option '$${target_option-}' specified" >&2; \ +         exit 1;; \ +  esac; \ +  has_opt=no; \ +  sane_makeflags=$$MAKEFLAGS; \ +  if $(am__is_gnu_make); then \ +    sane_makeflags=$$MFLAGS; \ +  else \      case $$MAKEFLAGS in \        *\\[\ \	]*) \ -        echo 'am--echo: ; @echo "AM"  OK' | $(MAKE) -f - 2>/dev/null \ -          | grep '^AM OK$$' >/dev/null || am__dry=yes;; \ -      *) \ -        for am__flg in $$MAKEFLAGS; do \ -          case $$am__flg in \ -            *=*|--*) ;; \ -            *n*) am__dry=yes; break;; \ -          esac; \ -        done;; \ +        bs=\\; \ +        sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ +          | sed "s/$$bs$$bs[$$bs $$bs	]*//g"`;; \ +    esac; \ +  fi; \ +  skip_next=no; \ +  strip_trailopt () \ +  { \ +    flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ +  }; \ +  for flg in $$sane_makeflags; do \ +    test $$skip_next = yes && { skip_next=no; continue; }; \ +    case $$flg in \ +      *=*|--*) continue;; \ +        -*I) strip_trailopt 'I'; skip_next=yes;; \ +      -*I?*) strip_trailopt 'I';; \ +        -*O) strip_trailopt 'O'; skip_next=yes;; \ +      -*O?*) strip_trailopt 'O';; \ +        -*l) strip_trailopt 'l'; skip_next=yes;; \ +      -*l?*) strip_trailopt 'l';; \ +      -[dEDm]) skip_next=yes;; \ +      -[JT]) skip_next=yes;; \ +    esac; \ +    case $$flg in \ +      *$$target_option*) has_opt=yes; break;; \      esac; \ -    test $$am__dry = yes; \ -  } +  done; \ +  test $$has_opt = yes +am__make_dryrun = (target_option=n; $(am__make_running_with_option)) +am__make_keepgoing = (target_option=k; $(am__make_running_with_option))  pkgdatadir = $(datadir)/@PACKAGE@  pkgincludedir = $(includedir)/@PACKAGE@  pkglibdir = $(libdir)/@PACKAGE@ @@ -52,7 +79,7 @@ build_triplet = @build@  host_triplet = @host@  target_triplet = @target@  subdir = lib/farsync -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in +DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/Makefile.am  ACLOCAL_M4 = $(top_srcdir)/aclocal.m4  am__aclocal_m4_deps = $(top_srcdir)/m4/ax_boost_base.m4 \  	$(top_srcdir)/configure.ac @@ -62,12 +89,18 @@ mkinstalldirs = $(install_sh) -d  CONFIG_HEADER = $(top_builddir)/config.h  CONFIG_CLEAN_FILES =  CONFIG_CLEAN_VPATH_FILES = +AM_V_P = $(am__v_P_@AM_V@) +am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) +am__v_P_0 = false +am__v_P_1 = :  AM_V_GEN = $(am__v_GEN_@AM_V@)  am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) -am__v_GEN_0 = @echo "  GEN   " $@; +am__v_GEN_0 = @echo "  GEN     " $@; +am__v_GEN_1 =   AM_V_at = $(am__v_at_@AM_V@)  am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)  am__v_at_0 = @ +am__v_at_1 =   SOURCES =  DIST_SOURCES =  am__can_run_installinfo = \ @@ -75,6 +108,7 @@ am__can_run_installinfo = \      n|no|NO) false;; \      *) (install-info --version) >/dev/null 2>&1;; \    esac +am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)  DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)  ACLOCAL = @ACLOCAL@  AMTAR = @AMTAR@ @@ -220,11 +254,11 @@ $(top_srcdir)/configure:  $(am__configure_deps)  $(ACLOCAL_M4):  $(am__aclocal_m4_deps)  	cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh  $(am__aclocal_m4_deps): -tags: TAGS -TAGS: +tags TAGS: + +ctags CTAGS: -ctags: CTAGS -CTAGS: +cscope cscopelist:  distdir: $(DISTFILES) @@ -359,15 +393,16 @@ uninstall-am:  .MAKE: install-am install-strip -.PHONY: all all-am check check-am clean clean-generic distclean \ -	distclean-generic distdir dvi dvi-am html html-am info info-am \ -	install install-am install-data install-data-am install-dvi \ -	install-dvi-am 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 \ -	maintainer-clean maintainer-clean-generic mostlyclean \ -	mostlyclean-generic pdf pdf-am ps ps-am uninstall uninstall-am +.PHONY: all all-am check check-am clean clean-generic cscopelist-am \ +	ctags-am distclean distclean-generic distdir dvi dvi-am html \ +	html-am info info-am install install-am install-data \ +	install-data-am install-dvi install-dvi-am 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 maintainer-clean \ +	maintainer-clean-generic mostlyclean mostlyclean-generic pdf \ +	pdf-am ps ps-am tags-am uninstall uninstall-am  # Tell versions [3.59,3.63) of GNU make to not export all variables. diff --git a/src/DabMux.cpp b/src/DabMux.cpp index 8a065a0..0e97340 100644 --- a/src/DabMux.cpp +++ b/src/DabMux.cpp @@ -72,6 +72,7 @@ typedef DWORD32 uint32_t;  #   include <sys/socket.h>  #   include <sys/ioctl.h>  #   include <sys/times.h> +#   include <sys/resource.h>  #   include <linux/if_packet.h>  #   include <linux/netdevice.h> @@ -105,7 +106,7 @@ typedef DWORD32 uint32_t;  #include "dabInputDmbUdp.h" -#include "dabOutput.h" +#include "dabOutput/dabOutput.h"  #include "crc.h"  #include "UdpSocket.h"  #include "InetAddress.h" @@ -363,15 +364,10 @@ int main(int argc, char *argv[])      if (outputs.size() == 0) {          etiLog.printHeader(TcpLog::WARNING, "no output defined\n"); -        outputs.push_back(new dabOutput); +        // initialise a new dabOutput +        outputs.push_back(new dabOutput("simul", NULL));          output = outputs.end() - 1; -        memset(*output, 0, sizeof(dabOutput)); -        (*output)->outputProto = "simul"; -        (*output)->outputName = NULL; -        (*output)->data = NULL; -        (*output)->operations = dabOutputDefaultOperations; -          printf("Press enter to continue\n");          getchar();      } @@ -473,46 +469,46 @@ int main(int argc, char *argv[])      for (output = outputs.begin(); output != outputs.end() ; ++output) {  #if defined(HAVE_OUTPUT_FILE) -        if (strcmp((*output)->outputProto, "file") == 0) { -            (*output)->operations = dabOutputFileOperations; +        if ((*output)->outputProto == "file") { +            (*output)->output = new DabOutputFile();  #else // !defined(HAVE_OUTPUT_FILE)          if (0) {  #endif // defined(HAVE_OUTPUT_FILE)  #if defined(HAVE_OUTPUT_FIFO) -        } else if (strcmp((*output)->outputProto, "fifo") == 0) { -            (*output)->operations = dabOutputFifoOperations; +        } else if ((*output)->outputProto == "fifo") { +            (*output)->output = new DabOutputFifo();  #endif // !defined(HAVE_OUTPUT_FIFO)  #if defined(HAVE_OUTPUT_RAW) -        } else if (strcmp((*output)->outputProto, "raw") == 0) { -            (*output)->operations = dabOutputRawOperations; +        } else if ((*output)->outputProto == "raw") { +            (*output)->output = new DabOutputRaw();  #endif // defined(HAVE_OUTPUT_RAW)  #if defined(HAVE_OUTPUT_UDP) -        } else if (strcmp((*output)->outputProto, "udp") == 0) { -            (*output)->operations = dabOutputUdpOperations; +        } else if ((*output)->outputProto == "udp") { +            (*output)->output = new DabOutputUdp();  #endif // defined(HAVE_OUTPUT_UDP)  #if defined(HAVE_OUTPUT_TCP) -        } else if (strcmp((*output)->outputProto, "tcp") == 0) { -            (*output)->operations = dabOutputTcpOperations; +        } else if ((*output)->outputProto == "tcp") { +            (*output)->output = new DabOutputTcp();  #endif // defined(HAVE_OUTPUT_TCP)  #if defined(HAVE_OUTPUT_SIMUL) -        } else if (strcmp((*output)->outputProto, "simul") == 0) { -            (*output)->operations = dabOutputSimulOperations; +        } else if ((*output)->outputProto == "simul") { +            (*output)->output = new DabOutputSimul();  #endif // defined(HAVE_OUTPUT_SIMUL)          } else {              etiLog.printHeader(TcpLog::ERR, "Output protcol unknown: %s\n", -                    (*output)->outputProto); +                    (*output)->outputProto.c_str());              goto EXIT;          } -        if ((*output)->operations.init(&(*output)->data) == -1) { +        if ((*output)->output == NULL) {              etiLog.printHeader(TcpLog::ERR, "Unable to init output %s://%s\n", -                    (*output)->outputProto, (*output)->outputName); +                    (*output)->outputProto.c_str(), (*output)->outputName.c_str());              return -1;          } -        if ((*output)->operations.open((*output)->data, (*output)->outputName) +        if ((*output)->output->Open((*output)->outputName)                  == -1) {              etiLog.printHeader(TcpLog::ERR, "Unable to open output %s://%s\n", -                    (*output)->outputProto, (*output)->outputName); +                    (*output)->outputProto.c_str(), (*output)->outputName.c_str());              return -1;          }      } @@ -1788,10 +1784,10 @@ int main(int argc, char *argv[])          // Give the data to the outputs          for (output = outputs.begin() ; output != outputs.end(); ++output) { -            if ((*output)->operations.write((*output)->data, etiFrame, index) +            if ((*output)->output->Write(etiFrame, index)                      == -1) {                  etiLog.print(TcpLog::ERR, "Can't write to output %s://%s\n", -                        (*output)->outputProto, (*output)->outputName); +                        (*output)->outputProto.c_str(), (*output)->outputName.c_str());              }          } @@ -1823,8 +1819,8 @@ EXIT:          (*subchannel)->operations.clean(&(*subchannel)->data);      }      for (output = outputs.begin() ; output != outputs.end(); ++output) { -        (*output)->operations.close((*output)->data); -        (*output)->operations.clean(&(*output)->data); +        (*output)->output->Close(); +        delete ((*output)->output);      }      for_each(ensemble->components.begin(), ensemble->components.end(), free); diff --git a/src/DabMux.h b/src/DabMux.h index be5c25a..517e36b 100644 --- a/src/DabMux.h +++ b/src/DabMux.h @@ -32,7 +32,7 @@  #include <functional>  #include <algorithm>  #include <stdint.h> -#include "dabOutput.h" +#include "dabOutput/dabOutput.h"  #include "dabInput.h"  #include "Eti.h"  #include "MuxElements.h" diff --git a/src/Makefile.am b/src/Makefile.am index 8a63e83..b67a09c 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -46,7 +46,13 @@ CRC_DabMux_SOURCES  =DabMux.cpp \                       dabInputSlip.h dabInputSlip.cpp \                       dabInputTest.h dabInputTest.cpp \                       dabInputUdp.h dabInputUdp.cpp \ -                     dabOutput.h dabOutput.cpp \ +                     dabOutput/dabOutput.h \ +                     dabOutput/dabOutputFile.cpp \ +                     dabOutput/dabOutputFifo.cpp \ +                     dabOutput/dabOutputRaw.cpp \ +                     dabOutput/dabOutputSimul.cpp \ +                     dabOutput/dabOutputTcp.cpp \ +                     dabOutput/dabOutputUdp.cpp \                       bridge.h bridge.c \                       utils.cpp utils.h \                       MuxElements.cpp MuxElements.h \ diff --git a/src/Makefile.in b/src/Makefile.in index 5343fb3..0daffbd 100644 --- a/src/Makefile.in +++ b/src/Makefile.in @@ -1,9 +1,8 @@ -# Makefile.in generated by automake 1.11.6 from Makefile.am. +# Makefile.in generated by automake 1.14 from Makefile.am.  # @configure_input@ -# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Free Software -# Foundation, Inc. +# Copyright (C) 1994-2013 Free Software Foundation, Inc. +  # This Makefile.in 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. @@ -37,23 +36,51 @@  # along with CRC-DabMux.  If not, see <http://www.gnu.org/licenses/>.  VPATH = @srcdir@ -am__make_dryrun = \ -  { \ -    am__dry=no; \ +am__is_gnu_make = test -n '$(MAKEFILE_LIST)' && test -n '$(MAKELEVEL)' +am__make_running_with_option = \ +  case $${target_option-} in \ +      ?) ;; \ +      *) echo "am__make_running_with_option: internal error: invalid" \ +              "target option '$${target_option-}' specified" >&2; \ +         exit 1;; \ +  esac; \ +  has_opt=no; \ +  sane_makeflags=$$MAKEFLAGS; \ +  if $(am__is_gnu_make); then \ +    sane_makeflags=$$MFLAGS; \ +  else \      case $$MAKEFLAGS in \        *\\[\ \	]*) \ -        echo 'am--echo: ; @echo "AM"  OK' | $(MAKE) -f - 2>/dev/null \ -          | grep '^AM OK$$' >/dev/null || am__dry=yes;; \ -      *) \ -        for am__flg in $$MAKEFLAGS; do \ -          case $$am__flg in \ -            *=*|--*) ;; \ -            *n*) am__dry=yes; break;; \ -          esac; \ -        done;; \ +        bs=\\; \ +        sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ +          | sed "s/$$bs$$bs[$$bs $$bs	]*//g"`;; \ +    esac; \ +  fi; \ +  skip_next=no; \ +  strip_trailopt () \ +  { \ +    flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ +  }; \ +  for flg in $$sane_makeflags; do \ +    test $$skip_next = yes && { skip_next=no; continue; }; \ +    case $$flg in \ +      *=*|--*) continue;; \ +        -*I) strip_trailopt 'I'; skip_next=yes;; \ +      -*I?*) strip_trailopt 'I';; \ +        -*O) strip_trailopt 'O'; skip_next=yes;; \ +      -*O?*) strip_trailopt 'O';; \ +        -*l) strip_trailopt 'l'; skip_next=yes;; \ +      -*l?*) strip_trailopt 'l';; \ +      -[dEDm]) skip_next=yes;; \ +      -[JT]) skip_next=yes;; \ +    esac; \ +    case $$flg in \ +      *$$target_option*) has_opt=yes; break;; \      esac; \ -    test $$am__dry = yes; \ -  } +  done; \ +  test $$has_opt = yes +am__make_dryrun = (target_option=n; $(am__make_running_with_option)) +am__make_keepgoing = (target_option=k; $(am__make_running_with_option))  pkgdatadir = $(datadir)/@PACKAGE@  pkgincludedir = $(includedir)/@PACKAGE@  pkglibdir = $(libdir)/@PACKAGE@ @@ -75,7 +102,8 @@ host_triplet = @host@  target_triplet = @target@  bin_PROGRAMS = CRC-DabMux$(EXEEXT) CRC-BridgeTest$(EXEEXT)  subdir = src -DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in +DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/Makefile.am \ +	$(top_srcdir)/build-aux/depcomp  ACLOCAL_M4 = $(top_srcdir)/aclocal.m4  am__aclocal_m4_deps = $(top_srcdir)/m4/ax_boost_base.m4 \  	$(top_srcdir)/configure.ac @@ -93,6 +121,7 @@ CRC_BridgeTest_OBJECTS = $(am_CRC_BridgeTest_OBJECTS)  CRC_BridgeTest_LDADD = $(LDADD)  CRC_BridgeTest_LINK = $(CCLD) $(CRC_BridgeTest_CFLAGS) $(CFLAGS) \  	$(AM_LDFLAGS) $(LDFLAGS) -o $@ +am__dirstamp = $(am__leading_dot)dirstamp  am_CRC_DabMux_OBJECTS = CRC_DabMux-DabMux.$(OBJEXT) \  	CRC_DabMux-dabInput.$(OBJEXT) \  	CRC_DabMux-dabInputBridgeUdp.$(OBJEXT) \ @@ -113,8 +142,14 @@ am_CRC_DabMux_OBJECTS = CRC_DabMux-DabMux.$(OBJEXT) \  	CRC_DabMux-dabInputSlip.$(OBJEXT) \  	CRC_DabMux-dabInputTest.$(OBJEXT) \  	CRC_DabMux-dabInputUdp.$(OBJEXT) \ -	CRC_DabMux-dabOutput.$(OBJEXT) CRC_DabMux-bridge.$(OBJEXT) \ -	CRC_DabMux-utils.$(OBJEXT) CRC_DabMux-MuxElements.$(OBJEXT) \ +	dabOutput/CRC_DabMux-dabOutputFile.$(OBJEXT) \ +	dabOutput/CRC_DabMux-dabOutputFifo.$(OBJEXT) \ +	dabOutput/CRC_DabMux-dabOutputRaw.$(OBJEXT) \ +	dabOutput/CRC_DabMux-dabOutputSimul.$(OBJEXT) \ +	dabOutput/CRC_DabMux-dabOutputTcp.$(OBJEXT) \ +	dabOutput/CRC_DabMux-dabOutputUdp.$(OBJEXT) \ +	CRC_DabMux-bridge.$(OBJEXT) CRC_DabMux-utils.$(OBJEXT) \ +	CRC_DabMux-MuxElements.$(OBJEXT) \  	CRC_DabMux-ParserCmdline.$(OBJEXT) \  	CRC_DabMux-ParserConfigfile.$(OBJEXT) CRC_DabMux-Eti.$(OBJEXT) \  	CRC_DabMux-TcpLog.$(OBJEXT) CRC_DabMux-UdpSocket.$(OBJEXT) \ @@ -126,6 +161,18 @@ am_CRC_DabMux_OBJECTS = CRC_DabMux-DabMux.$(OBJEXT) \  CRC_DabMux_OBJECTS = $(am_CRC_DabMux_OBJECTS)  am__DEPENDENCIES_1 =  CRC_DabMux_DEPENDENCIES = $(am__DEPENDENCIES_1) +AM_V_P = $(am__v_P_@AM_V@) +am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) +am__v_P_0 = false +am__v_P_1 = : +AM_V_GEN = $(am__v_GEN_@AM_V@) +am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) +am__v_GEN_0 = @echo "  GEN     " $@; +am__v_GEN_1 =  +AM_V_at = $(am__v_at_@AM_V@) +am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) +am__v_at_0 = @ +am__v_at_1 =   DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)  depcomp = $(SHELL) $(top_srcdir)/build-aux/depcomp  am__depfiles_maybe = depfiles @@ -133,33 +180,32 @@ am__mv = mv -f  AM_V_lt = $(am__v_lt_@AM_V@)  am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)  am__v_lt_0 = --silent +am__v_lt_1 =   COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \  	$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)  AM_V_CC = $(am__v_CC_@AM_V@)  am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) -am__v_CC_0 = @echo "  CC    " $@; -AM_V_at = $(am__v_at_@AM_V@) -am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) -am__v_at_0 = @ +am__v_CC_0 = @echo "  CC      " $@; +am__v_CC_1 =   CCLD = $(CC)  LINK = $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@  AM_V_CCLD = $(am__v_CCLD_@AM_V@)  am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) -am__v_CCLD_0 = @echo "  CCLD  " $@; +am__v_CCLD_0 = @echo "  CCLD    " $@; +am__v_CCLD_1 =   CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \  	$(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS)  AM_V_CXX = $(am__v_CXX_@AM_V@)  am__v_CXX_ = $(am__v_CXX_@AM_DEFAULT_V@) -am__v_CXX_0 = @echo "  CXX   " $@; +am__v_CXX_0 = @echo "  CXX     " $@; +am__v_CXX_1 =   CXXLD = $(CXX)  CXXLINK = $(CXXLD) $(AM_CXXFLAGS) $(CXXFLAGS) $(AM_LDFLAGS) $(LDFLAGS) \  	-o $@  AM_V_CXXLD = $(am__v_CXXLD_@AM_V@)  am__v_CXXLD_ = $(am__v_CXXLD_@AM_DEFAULT_V@) -am__v_CXXLD_0 = @echo "  CXXLD " $@; -AM_V_GEN = $(am__v_GEN_@AM_V@) -am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) -am__v_GEN_0 = @echo "  GEN   " $@; +am__v_CXXLD_0 = @echo "  CXXLD   " $@; +am__v_CXXLD_1 =   SOURCES = $(CRC_BridgeTest_SOURCES) $(CRC_DabMux_SOURCES)  DIST_SOURCES = $(CRC_BridgeTest_SOURCES) $(CRC_DabMux_SOURCES)  am__can_run_installinfo = \ @@ -167,6 +213,23 @@ am__can_run_installinfo = \      n|no|NO) false;; \      *) (install-info --version) >/dev/null 2>&1;; \    esac +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. +am__uniquify_input = $(AWK) '\ +  BEGIN { nonempty = 0; } \ +  { items[$$0] = 1; nonempty = 1; } \ +  END { if (nonempty) { for (i in items) print i; }; } \ +' +# Make sure the list of sources is unique.  This is necessary because, +# e.g., the same source file might be shared among _SOURCES variables +# for different programs/libraries. +am__define_uniq_tagged_files = \ +  list='$(am__tagged_files)'; \ +  unique=`for i in $$list; do \ +    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ +  done | $(am__uniquify_input)`  ETAGS = etags  CTAGS = ctags  DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) @@ -304,7 +367,13 @@ CRC_DabMux_SOURCES = DabMux.cpp \                       dabInputSlip.h dabInputSlip.cpp \                       dabInputTest.h dabInputTest.cpp \                       dabInputUdp.h dabInputUdp.cpp \ -                     dabOutput.h dabOutput.cpp \ +                     dabOutput/dabOutput.h \ +                     dabOutput/dabOutputFile.cpp \ +                     dabOutput/dabOutputFifo.cpp \ +                     dabOutput/dabOutputRaw.cpp \ +                     dabOutput/dabOutputSimul.cpp \ +                     dabOutput/dabOutputTcp.cpp \ +                     dabOutput/dabOutputUdp.cpp \                       bridge.h bridge.c \                       utils.cpp utils.h \                       MuxElements.cpp MuxElements.h \ @@ -372,10 +441,11 @@ install-binPROGRAMS: $(bin_PROGRAMS)  	fi; \  	for p in $$list; do echo "$$p $$p"; done | \  	sed 's/$(EXEEXT)$$//' | \ -	while read p p1; do if test -f $$p; \ -	  then echo "$$p"; echo "$$p"; else :; fi; \ +	while read p p1; do if test -f $$p \ +	  ; then echo "$$p"; echo "$$p"; else :; fi; \  	done | \ -	sed -e 'p;s,.*/,,;n;h' -e 's|.*|.|' \ +	sed -e 'p;s,.*/,,;n;h' \ +	    -e 's|.*|.|' \  	    -e 'p;x;s,.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/' | \  	sed 'N;N;N;s,\n, ,g' | \  	$(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1 } \ @@ -396,22 +466,44 @@ uninstall-binPROGRAMS:  	@list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \  	files=`for p in $$list; do echo "$$p"; done | \  	  sed -e 'h;s,^.*/,,;s/$(EXEEXT)$$//;$(transform)' \ -	      -e 's/$$/$(EXEEXT)/' `; \ +	      -e 's/$$/$(EXEEXT)/' \ +	`; \  	test -n "$$list" || exit 0; \  	echo " ( cd '$(DESTDIR)$(bindir)' && rm -f" $$files ")"; \  	cd "$(DESTDIR)$(bindir)" && rm -f $$files  clean-binPROGRAMS:  	-test -z "$(bin_PROGRAMS)" || rm -f $(bin_PROGRAMS) +  CRC-BridgeTest$(EXEEXT): $(CRC_BridgeTest_OBJECTS) $(CRC_BridgeTest_DEPENDENCIES) $(EXTRA_CRC_BridgeTest_DEPENDENCIES)   	@rm -f CRC-BridgeTest$(EXEEXT)  	$(AM_V_CCLD)$(CRC_BridgeTest_LINK) $(CRC_BridgeTest_OBJECTS) $(CRC_BridgeTest_LDADD) $(LIBS) +dabOutput/$(am__dirstamp): +	@$(MKDIR_P) dabOutput +	@: > dabOutput/$(am__dirstamp) +dabOutput/$(DEPDIR)/$(am__dirstamp): +	@$(MKDIR_P) dabOutput/$(DEPDIR) +	@: > dabOutput/$(DEPDIR)/$(am__dirstamp) +dabOutput/CRC_DabMux-dabOutputFile.$(OBJEXT):  \ +	dabOutput/$(am__dirstamp) dabOutput/$(DEPDIR)/$(am__dirstamp) +dabOutput/CRC_DabMux-dabOutputFifo.$(OBJEXT):  \ +	dabOutput/$(am__dirstamp) dabOutput/$(DEPDIR)/$(am__dirstamp) +dabOutput/CRC_DabMux-dabOutputRaw.$(OBJEXT):  \ +	dabOutput/$(am__dirstamp) dabOutput/$(DEPDIR)/$(am__dirstamp) +dabOutput/CRC_DabMux-dabOutputSimul.$(OBJEXT):  \ +	dabOutput/$(am__dirstamp) dabOutput/$(DEPDIR)/$(am__dirstamp) +dabOutput/CRC_DabMux-dabOutputTcp.$(OBJEXT):  \ +	dabOutput/$(am__dirstamp) dabOutput/$(DEPDIR)/$(am__dirstamp) +dabOutput/CRC_DabMux-dabOutputUdp.$(OBJEXT):  \ +	dabOutput/$(am__dirstamp) dabOutput/$(DEPDIR)/$(am__dirstamp) +  CRC-DabMux$(EXEEXT): $(CRC_DabMux_OBJECTS) $(CRC_DabMux_DEPENDENCIES) $(EXTRA_CRC_DabMux_DEPENDENCIES)   	@rm -f CRC-DabMux$(EXEEXT)  	$(AM_V_CXXLD)$(CXXLINK) $(CRC_DabMux_OBJECTS) $(CRC_DabMux_LDADD) $(LIBS)  mostlyclean-compile:  	-rm -f *.$(OBJEXT) +	-rm -f dabOutput/*.$(OBJEXT)  distclean-compile:  	-rm -f *.tab.c @@ -452,25 +544,32 @@ distclean-compile:  @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/CRC_DabMux-dabInputSlip.Po@am__quote@  @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/CRC_DabMux-dabInputTest.Po@am__quote@  @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/CRC_DabMux-dabInputUdp.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/CRC_DabMux-dabOutput.Po@am__quote@  @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/CRC_DabMux-dabUtils.Po@am__quote@  @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/CRC_DabMux-mpeg.Po@am__quote@  @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/CRC_DabMux-prbs.Po@am__quote@  @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/CRC_DabMux-utils.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFifo.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFile.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputRaw.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputSimul.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputTcp.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputUdp.Po@am__quote@  .c.o: -@am__fastdepCC_TRUE@	$(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< -@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po +@am__fastdepCC_TRUE@	$(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ +@am__fastdepCC_TRUE@	$(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ +@am__fastdepCC_TRUE@	$(am__mv) $$depbase.Tpo $$depbase.Po  @AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@  @AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c $< +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $<  .c.obj: -@am__fastdepCC_TRUE@	$(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` -@am__fastdepCC_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po +@am__fastdepCC_TRUE@	$(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ +@am__fastdepCC_TRUE@	$(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ +@am__fastdepCC_TRUE@	$(am__mv) $$depbase.Tpo $$depbase.Po  @AMDEP_TRUE@@am__fastdepCC_FALSE@	$(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@  @AMDEP_TRUE@@am__fastdepCC_FALSE@	DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c `$(CYGPATH_W) '$<'` +@am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'`  CRC_BridgeTest-bridge.o: bridge.c  @am__fastdepCC_TRUE@	$(AM_V_CC)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(CRC_BridgeTest_CFLAGS) $(CFLAGS) -MT CRC_BridgeTest-bridge.o -MD -MP -MF $(DEPDIR)/CRC_BridgeTest-bridge.Tpo -c -o CRC_BridgeTest-bridge.o `test -f 'bridge.c' || echo '$(srcdir)/'`bridge.c @@ -557,15 +656,17 @@ CRC_DabMux-mpeg.obj: mpeg.c  @am__fastdepCC_FALSE@	$(AM_V_CC@am__nodep@)$(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o CRC_DabMux-mpeg.obj `if test -f 'mpeg.c'; then $(CYGPATH_W) 'mpeg.c'; else $(CYGPATH_W) '$(srcdir)/mpeg.c'; fi`  .cpp.o: -@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXXCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< -@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po +@am__fastdepCXX_TRUE@	$(AM_V_CXX)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\ +@am__fastdepCXX_TRUE@	$(CXXCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\ +@am__fastdepCXX_TRUE@	$(am__mv) $$depbase.Tpo $$depbase.Po  @AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@  @AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@  @am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXXCOMPILE) -c -o $@ $<  .cpp.obj: -@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXXCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` -@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po +@am__fastdepCXX_TRUE@	$(AM_V_CXX)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\ +@am__fastdepCXX_TRUE@	$(CXXCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\ +@am__fastdepCXX_TRUE@	$(am__mv) $$depbase.Tpo $$depbase.Po  @AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@  @AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@  @am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` @@ -850,19 +951,89 @@ CRC_DabMux-dabInputUdp.obj: dabInputUdp.cpp  @AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@  @am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o CRC_DabMux-dabInputUdp.obj `if test -f 'dabInputUdp.cpp'; then $(CYGPATH_W) 'dabInputUdp.cpp'; else $(CYGPATH_W) '$(srcdir)/dabInputUdp.cpp'; fi` -CRC_DabMux-dabOutput.o: dabOutput.cpp -@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT CRC_DabMux-dabOutput.o -MD -MP -MF $(DEPDIR)/CRC_DabMux-dabOutput.Tpo -c -o CRC_DabMux-dabOutput.o `test -f 'dabOutput.cpp' || echo '$(srcdir)/'`dabOutput.cpp -@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/CRC_DabMux-dabOutput.Tpo $(DEPDIR)/CRC_DabMux-dabOutput.Po -@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput.cpp' object='CRC_DabMux-dabOutput.o' libtool=no @AMDEPBACKSLASH@ +dabOutput/CRC_DabMux-dabOutputFile.o: dabOutput/dabOutputFile.cpp +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT dabOutput/CRC_DabMux-dabOutputFile.o -MD -MP -MF dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFile.Tpo -c -o dabOutput/CRC_DabMux-dabOutputFile.o `test -f 'dabOutput/dabOutputFile.cpp' || echo '$(srcdir)/'`dabOutput/dabOutputFile.cpp +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFile.Tpo dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFile.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput/dabOutputFile.cpp' object='dabOutput/CRC_DabMux-dabOutputFile.o' libtool=no @AMDEPBACKSLASH@  @AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o CRC_DabMux-dabOutput.o `test -f 'dabOutput.cpp' || echo '$(srcdir)/'`dabOutput.cpp +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o dabOutput/CRC_DabMux-dabOutputFile.o `test -f 'dabOutput/dabOutputFile.cpp' || echo '$(srcdir)/'`dabOutput/dabOutputFile.cpp -CRC_DabMux-dabOutput.obj: dabOutput.cpp -@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT CRC_DabMux-dabOutput.obj -MD -MP -MF $(DEPDIR)/CRC_DabMux-dabOutput.Tpo -c -o CRC_DabMux-dabOutput.obj `if test -f 'dabOutput.cpp'; then $(CYGPATH_W) 'dabOutput.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput.cpp'; fi` -@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) $(DEPDIR)/CRC_DabMux-dabOutput.Tpo $(DEPDIR)/CRC_DabMux-dabOutput.Po -@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput.cpp' object='CRC_DabMux-dabOutput.obj' libtool=no @AMDEPBACKSLASH@ +dabOutput/CRC_DabMux-dabOutputFile.obj: dabOutput/dabOutputFile.cpp +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT dabOutput/CRC_DabMux-dabOutputFile.obj -MD -MP -MF dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFile.Tpo -c -o dabOutput/CRC_DabMux-dabOutputFile.obj `if test -f 'dabOutput/dabOutputFile.cpp'; then $(CYGPATH_W) 'dabOutput/dabOutputFile.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput/dabOutputFile.cpp'; fi` +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFile.Tpo dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFile.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput/dabOutputFile.cpp' object='dabOutput/CRC_DabMux-dabOutputFile.obj' libtool=no @AMDEPBACKSLASH@  @AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ -@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o CRC_DabMux-dabOutput.obj `if test -f 'dabOutput.cpp'; then $(CYGPATH_W) 'dabOutput.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput.cpp'; fi` +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o dabOutput/CRC_DabMux-dabOutputFile.obj `if test -f 'dabOutput/dabOutputFile.cpp'; then $(CYGPATH_W) 'dabOutput/dabOutputFile.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput/dabOutputFile.cpp'; fi` + +dabOutput/CRC_DabMux-dabOutputFifo.o: dabOutput/dabOutputFifo.cpp +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT dabOutput/CRC_DabMux-dabOutputFifo.o -MD -MP -MF dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFifo.Tpo -c -o dabOutput/CRC_DabMux-dabOutputFifo.o `test -f 'dabOutput/dabOutputFifo.cpp' || echo '$(srcdir)/'`dabOutput/dabOutputFifo.cpp +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFifo.Tpo dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFifo.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput/dabOutputFifo.cpp' object='dabOutput/CRC_DabMux-dabOutputFifo.o' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o dabOutput/CRC_DabMux-dabOutputFifo.o `test -f 'dabOutput/dabOutputFifo.cpp' || echo '$(srcdir)/'`dabOutput/dabOutputFifo.cpp + +dabOutput/CRC_DabMux-dabOutputFifo.obj: dabOutput/dabOutputFifo.cpp +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT dabOutput/CRC_DabMux-dabOutputFifo.obj -MD -MP -MF dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFifo.Tpo -c -o dabOutput/CRC_DabMux-dabOutputFifo.obj `if test -f 'dabOutput/dabOutputFifo.cpp'; then $(CYGPATH_W) 'dabOutput/dabOutputFifo.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput/dabOutputFifo.cpp'; fi` +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFifo.Tpo dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputFifo.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput/dabOutputFifo.cpp' object='dabOutput/CRC_DabMux-dabOutputFifo.obj' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o dabOutput/CRC_DabMux-dabOutputFifo.obj `if test -f 'dabOutput/dabOutputFifo.cpp'; then $(CYGPATH_W) 'dabOutput/dabOutputFifo.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput/dabOutputFifo.cpp'; fi` + +dabOutput/CRC_DabMux-dabOutputRaw.o: dabOutput/dabOutputRaw.cpp +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT dabOutput/CRC_DabMux-dabOutputRaw.o -MD -MP -MF dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputRaw.Tpo -c -o dabOutput/CRC_DabMux-dabOutputRaw.o `test -f 'dabOutput/dabOutputRaw.cpp' || echo '$(srcdir)/'`dabOutput/dabOutputRaw.cpp +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputRaw.Tpo dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputRaw.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput/dabOutputRaw.cpp' object='dabOutput/CRC_DabMux-dabOutputRaw.o' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o dabOutput/CRC_DabMux-dabOutputRaw.o `test -f 'dabOutput/dabOutputRaw.cpp' || echo '$(srcdir)/'`dabOutput/dabOutputRaw.cpp + +dabOutput/CRC_DabMux-dabOutputRaw.obj: dabOutput/dabOutputRaw.cpp +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT dabOutput/CRC_DabMux-dabOutputRaw.obj -MD -MP -MF dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputRaw.Tpo -c -o dabOutput/CRC_DabMux-dabOutputRaw.obj `if test -f 'dabOutput/dabOutputRaw.cpp'; then $(CYGPATH_W) 'dabOutput/dabOutputRaw.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput/dabOutputRaw.cpp'; fi` +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputRaw.Tpo dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputRaw.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput/dabOutputRaw.cpp' object='dabOutput/CRC_DabMux-dabOutputRaw.obj' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o dabOutput/CRC_DabMux-dabOutputRaw.obj `if test -f 'dabOutput/dabOutputRaw.cpp'; then $(CYGPATH_W) 'dabOutput/dabOutputRaw.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput/dabOutputRaw.cpp'; fi` + +dabOutput/CRC_DabMux-dabOutputSimul.o: dabOutput/dabOutputSimul.cpp +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT dabOutput/CRC_DabMux-dabOutputSimul.o -MD -MP -MF dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputSimul.Tpo -c -o dabOutput/CRC_DabMux-dabOutputSimul.o `test -f 'dabOutput/dabOutputSimul.cpp' || echo '$(srcdir)/'`dabOutput/dabOutputSimul.cpp +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputSimul.Tpo dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputSimul.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput/dabOutputSimul.cpp' object='dabOutput/CRC_DabMux-dabOutputSimul.o' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o dabOutput/CRC_DabMux-dabOutputSimul.o `test -f 'dabOutput/dabOutputSimul.cpp' || echo '$(srcdir)/'`dabOutput/dabOutputSimul.cpp + +dabOutput/CRC_DabMux-dabOutputSimul.obj: dabOutput/dabOutputSimul.cpp +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT dabOutput/CRC_DabMux-dabOutputSimul.obj -MD -MP -MF dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputSimul.Tpo -c -o dabOutput/CRC_DabMux-dabOutputSimul.obj `if test -f 'dabOutput/dabOutputSimul.cpp'; then $(CYGPATH_W) 'dabOutput/dabOutputSimul.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput/dabOutputSimul.cpp'; fi` +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputSimul.Tpo dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputSimul.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput/dabOutputSimul.cpp' object='dabOutput/CRC_DabMux-dabOutputSimul.obj' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o dabOutput/CRC_DabMux-dabOutputSimul.obj `if test -f 'dabOutput/dabOutputSimul.cpp'; then $(CYGPATH_W) 'dabOutput/dabOutputSimul.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput/dabOutputSimul.cpp'; fi` + +dabOutput/CRC_DabMux-dabOutputTcp.o: dabOutput/dabOutputTcp.cpp +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT dabOutput/CRC_DabMux-dabOutputTcp.o -MD -MP -MF dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputTcp.Tpo -c -o dabOutput/CRC_DabMux-dabOutputTcp.o `test -f 'dabOutput/dabOutputTcp.cpp' || echo '$(srcdir)/'`dabOutput/dabOutputTcp.cpp +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputTcp.Tpo dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputTcp.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput/dabOutputTcp.cpp' object='dabOutput/CRC_DabMux-dabOutputTcp.o' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o dabOutput/CRC_DabMux-dabOutputTcp.o `test -f 'dabOutput/dabOutputTcp.cpp' || echo '$(srcdir)/'`dabOutput/dabOutputTcp.cpp + +dabOutput/CRC_DabMux-dabOutputTcp.obj: dabOutput/dabOutputTcp.cpp +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT dabOutput/CRC_DabMux-dabOutputTcp.obj -MD -MP -MF dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputTcp.Tpo -c -o dabOutput/CRC_DabMux-dabOutputTcp.obj `if test -f 'dabOutput/dabOutputTcp.cpp'; then $(CYGPATH_W) 'dabOutput/dabOutputTcp.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput/dabOutputTcp.cpp'; fi` +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputTcp.Tpo dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputTcp.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput/dabOutputTcp.cpp' object='dabOutput/CRC_DabMux-dabOutputTcp.obj' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o dabOutput/CRC_DabMux-dabOutputTcp.obj `if test -f 'dabOutput/dabOutputTcp.cpp'; then $(CYGPATH_W) 'dabOutput/dabOutputTcp.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput/dabOutputTcp.cpp'; fi` + +dabOutput/CRC_DabMux-dabOutputUdp.o: dabOutput/dabOutputUdp.cpp +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT dabOutput/CRC_DabMux-dabOutputUdp.o -MD -MP -MF dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputUdp.Tpo -c -o dabOutput/CRC_DabMux-dabOutputUdp.o `test -f 'dabOutput/dabOutputUdp.cpp' || echo '$(srcdir)/'`dabOutput/dabOutputUdp.cpp +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputUdp.Tpo dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputUdp.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput/dabOutputUdp.cpp' object='dabOutput/CRC_DabMux-dabOutputUdp.o' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o dabOutput/CRC_DabMux-dabOutputUdp.o `test -f 'dabOutput/dabOutputUdp.cpp' || echo '$(srcdir)/'`dabOutput/dabOutputUdp.cpp + +dabOutput/CRC_DabMux-dabOutputUdp.obj: dabOutput/dabOutputUdp.cpp +@am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT dabOutput/CRC_DabMux-dabOutputUdp.obj -MD -MP -MF dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputUdp.Tpo -c -o dabOutput/CRC_DabMux-dabOutputUdp.obj `if test -f 'dabOutput/dabOutputUdp.cpp'; then $(CYGPATH_W) 'dabOutput/dabOutputUdp.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput/dabOutputUdp.cpp'; fi` +@am__fastdepCXX_TRUE@	$(AM_V_at)$(am__mv) dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputUdp.Tpo dabOutput/$(DEPDIR)/CRC_DabMux-dabOutputUdp.Po +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	$(AM_V_CXX)source='dabOutput/dabOutputUdp.cpp' object='dabOutput/CRC_DabMux-dabOutputUdp.obj' libtool=no @AMDEPBACKSLASH@ +@AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ +@am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o dabOutput/CRC_DabMux-dabOutputUdp.obj `if test -f 'dabOutput/dabOutputUdp.cpp'; then $(CYGPATH_W) 'dabOutput/dabOutputUdp.cpp'; else $(CYGPATH_W) '$(srcdir)/dabOutput/dabOutputUdp.cpp'; fi`  CRC_DabMux-utils.o: utils.cpp  @am__fastdepCXX_TRUE@	$(AM_V_CXX)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -MT CRC_DabMux-utils.o -MD -MP -MF $(DEPDIR)/CRC_DabMux-utils.Tpo -c -o CRC_DabMux-utils.o `test -f 'utils.cpp' || echo '$(srcdir)/'`utils.cpp @@ -1060,26 +1231,15 @@ CRC_DabMux-TcpSocket.obj: TcpSocket.cpp  @AMDEP_TRUE@@am__fastdepCXX_FALSE@	DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@  @am__fastdepCXX_FALSE@	$(AM_V_CXX@am__nodep@)$(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(CRC_DabMux_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) -c -o CRC_DabMux-TcpSocket.obj `if test -f 'TcpSocket.cpp'; then $(CYGPATH_W) 'TcpSocket.cpp'; else $(CYGPATH_W) '$(srcdir)/TcpSocket.cpp'; fi` -ID: $(HEADERS) $(SOURCES) $(LISP) $(TAGS_FILES) -	list='$(SOURCES) $(HEADERS) $(LISP) $(TAGS_FILES)'; \ -	unique=`for i in $$list; do \ -	    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -	  done | \ -	  $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ -	      END { if (nonempty) { for (i in files) print i; }; }'`; \ -	mkid -fID $$unique -tags: TAGS - -TAGS:  $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \ -		$(TAGS_FILES) $(LISP) +ID: $(am__tagged_files) +	$(am__define_uniq_tagged_files); mkid -fID $$unique +tags: tags-am +TAGS: tags + +tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)  	set x; \  	here=`pwd`; \ -	list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \ -	unique=`for i in $$list; do \ -	    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -	  done | \ -	  $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ -	      END { if (nonempty) { for (i in files) print i; }; }'`; \ +	$(am__define_uniq_tagged_files); \  	shift; \  	if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \  	  test -n "$$unique" || unique=$$empty_fix; \ @@ -1091,15 +1251,11 @@ TAGS:  $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \  	      $$unique; \  	  fi; \  	fi -ctags: CTAGS -CTAGS:  $(HEADERS) $(SOURCES)  $(TAGS_DEPENDENCIES) \ -		$(TAGS_FILES) $(LISP) -	list='$(SOURCES) $(HEADERS)  $(LISP) $(TAGS_FILES)'; \ -	unique=`for i in $$list; do \ -	    if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ -	  done | \ -	  $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ -	      END { if (nonempty) { for (i in files) print i; }; }'`; \ +ctags: ctags-am + +CTAGS: ctags +ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) +	$(am__define_uniq_tagged_files); \  	test -z "$(CTAGS_ARGS)$$unique" \  	  || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \  	     $$unique @@ -1108,6 +1264,21 @@ GTAGS:  	here=`$(am__cd) $(top_builddir) && pwd` \  	  && $(am__cd) $(top_srcdir) \  	  && gtags -i $(GTAGS_ARGS) "$$here" +cscopelist: cscopelist-am + +cscopelist-am: $(am__tagged_files) +	list='$(am__tagged_files)'; \ +	case "$(srcdir)" in \ +	  [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ +	  *) sdir=$(subdir)/$(srcdir) ;; \ +	esac; \ +	for i in $$list; do \ +	  if test -f "$$i"; then \ +	    echo "$(subdir)/$$i"; \ +	  else \ +	    echo "$$sdir/$$i"; \ +	  fi; \ +	done >> $(top_builddir)/cscope.files  distclean-tags:  	-rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags @@ -1175,6 +1346,8 @@ clean-generic:  distclean-generic:  	-test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)  	-test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) +	-rm -f dabOutput/$(DEPDIR)/$(am__dirstamp) +	-rm -f dabOutput/$(am__dirstamp)  maintainer-clean-generic:  	@echo "This command is intended for maintainers to use" @@ -1184,7 +1357,7 @@ clean: clean-am  clean-am: clean-binPROGRAMS clean-generic clean-local mostlyclean-am  distclean: distclean-am -	-rm -rf ./$(DEPDIR) +	-rm -rf ./$(DEPDIR) dabOutput/$(DEPDIR)  	-rm -f Makefile  distclean-am: clean-am distclean-compile distclean-generic \  	distclean-tags @@ -1230,7 +1403,7 @@ install-ps-am:  installcheck-am:  maintainer-clean: maintainer-clean-am -	-rm -rf ./$(DEPDIR) +	-rm -rf ./$(DEPDIR) dabOutput/$(DEPDIR)  	-rm -f Makefile  maintainer-clean-am: distclean-am maintainer-clean-generic @@ -1250,17 +1423,18 @@ uninstall-am: uninstall-binPROGRAMS  .MAKE: install-am install-strip -.PHONY: CTAGS GTAGS all all-am check check-am clean clean-binPROGRAMS \ -	clean-generic clean-local ctags distclean distclean-compile \ -	distclean-generic distclean-tags distdir dvi dvi-am html \ -	html-am info info-am install install-am install-binPROGRAMS \ -	install-data install-data-am install-dvi install-dvi-am \ -	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 maintainer-clean \ +.PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \ +	clean-binPROGRAMS clean-generic clean-local cscopelist-am \ +	ctags ctags-am distclean distclean-compile distclean-generic \ +	distclean-tags distdir dvi dvi-am html html-am info info-am \ +	install install-am install-binPROGRAMS install-data \ +	install-data-am install-dvi install-dvi-am 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 maintainer-clean \  	maintainer-clean-generic mostlyclean mostlyclean-compile \ -	mostlyclean-generic pdf pdf-am ps ps-am tags uninstall \ +	mostlyclean-generic pdf pdf-am ps ps-am tags tags-am uninstall \  	uninstall-am uninstall-binPROGRAMS diff --git a/src/MuxElements.h b/src/MuxElements.h index a27f805..539d955 100644 --- a/src/MuxElements.h +++ b/src/MuxElements.h @@ -32,17 +32,23 @@  #include <functional>  #include <algorithm>  #include <stdint.h> -#include "dabOutput.h" +#include "dabOutput/dabOutput.h"  #include "dabInput.h"  #include "Eti.h"  using namespace std;  struct dabOutput { -    const char* outputProto; -    const char* outputName; -    void* data; -    dabOutputOperations operations; +    dabOutput(const char* proto, const char* name) : +        outputProto(proto), outputName(name), output(NULL) { } + +    // outputs are specified with outputProto://outputName +    // during config parsing +    std::string outputProto; +    std::string outputName; + +    // later, the corresponding output is then created +    DabOutput* output;  }; diff --git a/src/ParserCmdline.cpp b/src/ParserCmdline.cpp index 7fb2632..33896b6 100644 --- a/src/ParserCmdline.cpp +++ b/src/ParserCmdline.cpp @@ -34,7 +34,7 @@  #include <vector>  #include <stdint.h>  #include <cstring> -#include "dabOutput.h" +#include "dabOutput/dabOutput.h"  #include "dabInput.h"  #include "utils.h"  #include "dabInputFile.h" @@ -124,15 +124,6 @@ bool parse_cmdline(char **argv,          }          switch (c) {          case 'O': -            outputs.push_back(new dabOutput); -            output = outputs.end() - 1; - -            memset(*output, 0, sizeof(dabOutput)); -            (*output)->outputProto = NULL; -            (*output)->outputName = NULL; -            (*output)->data = NULL; -            (*output)->operations = dabOutputDefaultOperations; -              char* proto;              proto = strstr(optarg, "://"); @@ -141,10 +132,11 @@ bool parse_cmdline(char **argv,                          "No protocol defined for output\n");                  goto EXIT;              } else { -                (*output)->outputProto = optarg; -                (*output)->outputName = proto + 3; -                *proto = 0; +                *proto = 0; // terminate optarg +                outputs.push_back(new dabOutput(optarg, proto + 3)); +                output = outputs.end() - 1;              } +              subchannel = ensemble->subchannels.end();              protection = NULL;              component = ensemble->components.end(); @@ -803,15 +795,9 @@ bool parse_cmdline(char **argv,          case 'r':              etiLog.printHeader(TcpLog::INFO,                      "Enabling throttled output using simul, one frame every 24ms\n"); -            outputs.push_back(new dabOutput); +            outputs.push_back(new dabOutput("simul", NULL));              output = outputs.end() - 1; -            memset(*output, 0, sizeof(dabOutput)); -            (*output)->outputProto = "simul"; -            (*output)->outputName = ""; -            (*output)->data = NULL; -            (*output)->operations = dabOutputDefaultOperations; -              subchannel = ensemble->subchannels.end();              protection = NULL;              component = ensemble->components.end(); diff --git a/src/ParserConfigfile.cpp b/src/ParserConfigfile.cpp index 3746a1e..860b9b1 100644 --- a/src/ParserConfigfile.cpp +++ b/src/ParserConfigfile.cpp @@ -40,7 +40,7 @@  #include <string>  #include <map>  #include <cstring> -#include "dabOutput.h" +#include "dabOutput/dabOutput.h"  #include "dabInput.h"  #include "utils.h"  #include "dabInputFile.h" @@ -374,32 +374,23 @@ void parse_configfile(string configuration_file,          string outputuid = it->first;          string uri = pt_outputs.get<string>(outputuid); -        dabOutput* output = new dabOutput(); - -        outputs.push_back(output); - -        memset(output, 0, sizeof(dabOutput)); -        output->outputProto = NULL; -        output->outputName = NULL; -        output->data = NULL; -        output->operations = dabOutputDefaultOperations; -          int proto_pos = uri.find("://");          if (proto_pos == std::string::npos) {              stringstream ss;              ss << "Output with uid " << outputuid << " no protocol defined!";              throw runtime_error(ss.str()); -        } else { +        } -            char* uri_c = new char[512]; -            memset(uri_c, 0, 512); -            uri.copy(uri_c, 511); +        char* uri_c = new char[512]; +        memset(uri_c, 0, 512); +        uri.copy(uri_c, 511); -            uri_c[proto_pos] = '\0'; +        uri_c[proto_pos] = '\0'; -            output->outputProto = uri_c; -            output->outputName = output->outputProto + proto_pos + 3; -        } +        char* outputName = uri_c + proto_pos + 3; + +        dabOutput* output = new dabOutput(uri_c, outputName); +        outputs.push_back(output);          // keep outputs in map, and check for uniqueness of the uid          if (alloutputs.count(outputuid) == 0) { diff --git a/src/dabOutput.cpp b/src/dabOutput.cpp deleted file mode 100644 index 5351501..0000000 --- a/src/dabOutput.cpp +++ /dev/null @@ -1,1112 +0,0 @@ -/* -   Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009 Her Majesty the Queen in -   Right of Canada (Communications Research Center Canada) -   */ -/* -   This file is part of CRC-DabMux. - -   CRC-DabMux 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. - -   CRC-DabMux 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 CRC-DabMux.  If not, see <http://www.gnu.org/licenses/>. -   */ - -#include "dabOutput.h" -#include "UdpSocket.h" - -#include <string.h> -#include <stdio.h> -#include <fcntl.h> -#include <limits.h> - -#ifdef _WIN32 -#   include <io.h> -#   ifdef __MINGW32__ -#       define FS_DECLARE_CFG_ARRAYS -#       include <winioctl.h> -#   endif -#   include <sdci.h> -#else -#   include <farsync.h> -#   include <unistd.h> -#   include <sys/time.h> -#   ifndef O_BINARY -#       define O_BINARY 0 -#   endif // O_BINARY -#endif - - -int dabOutputDefaultInit(void** args) { -    return -1; -} - - -int dabOutputDefaultOpen(void* args, const char* filename) -{ -    return -1; -} - - -int dabOutputDefaultWrite(void* args, void* buffer, int size) -{ -    return -1; -} - - -int dabOutputDefaultClose(void* args) -{ -    return -1; -} - - -int dabOutputDefaultClean(void** args) -{ -    return -1; -} - - -struct dabOutputOperations dabOutputDefaultOperations  = { -    dabOutputDefaultInit, -    dabOutputDefaultOpen, -    dabOutputDefaultWrite, -    dabOutputDefaultClose, -    dabOutputDefaultClean -}; - - -enum EtiFileType { -    ETI_FILE_TYPE_NONE = 0, -    ETI_FILE_TYPE_RAW, -    ETI_FILE_TYPE_STREAMED, -    ETI_FILE_TYPE_FRAMED -}; - - -struct dabOutputFifoData { -    int file; -    EtiFileType type; -    unsigned long nbFrames; -}; - - -int dabOutputFifoInit(void** args) -{ -    dabOutputFifoData* data = new dabOutputFifoData; - -    *args = data; -    data->file = -1; -    data->type = ETI_FILE_TYPE_STREAMED; -    data->nbFrames = 0; -    return 0; -} - - -int dabOutputFifoOpen(void* args, const char* filename) -{ -    dabOutputFifoData* data = (dabOutputFifoData*)args; - -    char* token = strchr((char*)filename, '?'); -    if (token != NULL) { -        *(token++) = 0; -        char* nextPair; -        char* key; -        char* value; -        do { -            nextPair = strchr(token, '&'); -            if (nextPair != NULL) { -                *nextPair = 0; -            } -            key = token; -            value = strchr(token, '='); -            if (value != NULL) { -                *(value++) = 0; -                if (strcmp(key, "type") == 0) { -                    if (strcmp(value, "raw") == 0) { -                        data->type = ETI_FILE_TYPE_RAW; -                        break; -                    } else if (strcmp(value, "framed") == 0) { -                        data->type = ETI_FILE_TYPE_FRAMED; -                        break; -                    } else if (strcmp(value, "streamed") == 0) { -                        data->type = ETI_FILE_TYPE_STREAMED; -                        break; -                    } else { -                        etiLog.printHeader(TcpLog::ERR, -                                "File type '%s' is not supported.\n", value); -                        return -1; -                    } -                } -            } -        } while (nextPair != NULL); -    } - -    data->file = open(filename, O_WRONLY | O_CREAT | O_TRUNC | O_BINARY, 0666); -    if (data->file == -1) { -        perror(filename); -        return -1; -    } -    return 0; -} - - -int dabOutputFifoWrite(void* args, void* buffer, int size) -{ -    dabOutputFifoData* data = (dabOutputFifoData*)args; -    uint8_t padding[6144]; - -    switch (data->type) { -    case ETI_FILE_TYPE_FRAMED: -        if (data->nbFrames == 0) { -            uint32_t nbFrames = (uint32_t)-1; -            // Writting nb frame -            if (write(data->file, &nbFrames, 4) == -1) goto FIFO_WRITE_ERROR; -        } -    case ETI_FILE_TYPE_STREAMED: -        // Writting frame length -        if (write(data->file, &size, 2) == -1) goto FIFO_WRITE_ERROR; -        // Appending data -        if (write(data->file, buffer, size) == -1) goto FIFO_WRITE_ERROR; -        break; -    case ETI_FILE_TYPE_RAW: -        // Appending data -        if (write(data->file, buffer, size) == -1) goto FIFO_WRITE_ERROR; -        // Appending padding -        memset(padding, 0x55, 6144 - size); -        if (write(data->file, padding, 6144 - size) == -1) goto FIFO_WRITE_ERROR; -        break; -    default: -        etiLog.printHeader(TcpLog::ERR, "File type is not supported.\n"); -        return -1; -    } - - -    return size; - -FIFO_WRITE_ERROR: -    perror("Error while writting to file"); -    return -1; -} - - -int dabOutputFifoClose(void* args) -{ -    dabOutputFifoData* data = (dabOutputFifoData*)args; - -    if (close(data->file) == 0) { -        data->file = -1; -        return 0; -    } -    perror("Can't close file"); -    return -1; -} - - -int dabOutputFifoClean(void** args) -{ -    delete (dabOutputFifoData*)(*args); -    return 0; -} - - -struct dabOutputOperations dabOutputFifoOperations  = { -    dabOutputFifoInit, -    dabOutputFifoOpen, -    dabOutputFifoWrite, -    dabOutputFifoClose, -    dabOutputFifoClean -}; - - -struct dabOutputFileData { -    int file; -    EtiFileType type; -    unsigned long nbFrames; -}; - - -int dabOutputFileInit(void** args) -{ -    dabOutputFileData* data = new dabOutputFileData; - -    *args = data; -    data->file = -1; -    data->type = ETI_FILE_TYPE_FRAMED; -    data->nbFrames = 0; -    return 0; -} - - -int dabOutputFileWrite(void* args, void* buffer, int size) -{ -    dabOutputFileData* data = (dabOutputFileData*)args; - -    uint8_t padding[6144]; -    ++data->nbFrames; - -    switch (data->type) { -    case ETI_FILE_TYPE_FRAMED: -        // Writting nb of frames at beginning of file -        if (lseek(data->file, 0, SEEK_SET) == -1) goto FILE_WRITE_ERROR; -        if (write(data->file, &data->nbFrames, 4) == -1) goto FILE_WRITE_ERROR; - -        // Writting nb frame length at end of file -        if (lseek(data->file, 0, SEEK_END) == -1) goto FILE_WRITE_ERROR; -        if (write(data->file, &size, 2) == -1) goto FILE_WRITE_ERROR; - -        // Appending data -        if (write(data->file, buffer, size) == -1) goto FILE_WRITE_ERROR; -        break; -    case ETI_FILE_TYPE_STREAMED: -        // Writting nb frame length at end of file -        if (write(data->file, &size, 2) == -1) goto FILE_WRITE_ERROR; - -        // Appending data -        if (write(data->file, buffer, size) == -1) goto FILE_WRITE_ERROR; -        break; -    case ETI_FILE_TYPE_RAW: -        // Appending data -        if (write(data->file, buffer, size) == -1) goto FILE_WRITE_ERROR; - -        // Appending padding -        memset(padding, 0x55, 6144 - size); -        if (write(data->file, padding, 6144 - size) == -1) goto FILE_WRITE_ERROR; -        break; -    default: -        etiLog.printHeader(TcpLog::ERR, "File type is not supported.\n"); -        return -1; -    } - -    return size; - -FILE_WRITE_ERROR: -    perror("Error while writting to file"); -    return -1; -} - - -int dabOutputFileClean(void** args) -{ -    delete (dabOutputFileData*)(*args); -    return 0; -} - - -struct dabOutputOperations dabOutputFileOperations  = { -    dabOutputFileInit, -    dabOutputFifoOpen, -    dabOutputFileWrite, -    dabOutputFifoClose, -    dabOutputFileClean -}; - - -struct dabOutputRawData { -#ifdef _WIN32 -    HANDLE socket; -#else -    int socket; -    bool isCyclades; -#endif -    unsigned char* buffer; -}; - - -const unsigned char revTable[] = { -    0x00, 0x80, 0x40, 0xc0, 0x20, 0xa0, 0x60, 0xe0, -    0x10, 0x90, 0x50, 0xd0, 0x30, 0xb0, 0x70, 0xf0, -    0x08, 0x88, 0x48, 0xc8, 0x28, 0xa8, 0x68, 0xe8, -    0x18, 0x98, 0x58, 0xd8, 0x38, 0xb8, 0x78, 0xf8, -    0x04, 0x84, 0x44, 0xc4, 0x24, 0xa4, 0x64, 0xe4, -    0x14, 0x94, 0x54, 0xd4, 0x34, 0xb4, 0x74, 0xf4, -    0x0c, 0x8c, 0x4c, 0xcc, 0x2c, 0xac, 0x6c, 0xec, -    0x1c, 0x9c, 0x5c, 0xdc, 0x3c, 0xbc, 0x7c, 0xfc, -    0x02, 0x82, 0x42, 0xc2, 0x22, 0xa2, 0x62, 0xe2, -    0x12, 0x92, 0x52, 0xd2, 0x32, 0xb2, 0x72, 0xf2, -    0x0a, 0x8a, 0x4a, 0xca, 0x2a, 0xaa, 0x6a, 0xea, -    0x1a, 0x9a, 0x5a, 0xda, 0x3a, 0xba, 0x7a, 0xfa, -    0x06, 0x86, 0x46, 0xc6, 0x26, 0xa6, 0x66, 0xe6, -    0x16, 0x96, 0x56, 0xd6, 0x36, 0xb6, 0x76, 0xf6, -    0x0e, 0x8e, 0x4e, 0xce, 0x2e, 0xae, 0x6e, 0xee, -    0x1e, 0x9e, 0x5e, 0xde, 0x3e, 0xbe, 0x7e, 0xfe, -    0x01, 0x81, 0x41, 0xc1, 0x21, 0xa1, 0x61, 0xe1, -    0x11, 0x91, 0x51, 0xd1, 0x31, 0xb1, 0x71, 0xf1, -    0x09, 0x89, 0x49, 0xc9, 0x29, 0xa9, 0x69, 0xe9, -    0x19, 0x99, 0x59, 0xd9, 0x39, 0xb9, 0x79, 0xf9, -    0x05, 0x85, 0x45, 0xc5, 0x25, 0xa5, 0x65, 0xe5, -    0x15, 0x95, 0x55, 0xd5, 0x35, 0xb5, 0x75, 0xf5, -    0x0d, 0x8d, 0x4d, 0xcd, 0x2d, 0xad, 0x6d, 0xed, -    0x1d, 0x9d, 0x5d, 0xdd, 0x3d, 0xbd, 0x7d, 0xfd, -    0x03, 0x83, 0x43, 0xc3, 0x23, 0xa3, 0x63, 0xe3, -    0x13, 0x93, 0x53, 0xd3, 0x33, 0xb3, 0x73, 0xf3, -    0x0b, 0x8b, 0x4b, 0xcb, 0x2b, 0xab, 0x6b, 0xeb, -    0x1b, 0x9b, 0x5b, 0xdb, 0x3b, 0xbb, 0x7b, 0xfb, -    0x07, 0x87, 0x47, 0xc7, 0x27, 0xa7, 0x67, 0xe7, -    0x17, 0x97, 0x57, 0xd7, 0x37, 0xb7, 0x77, 0xf7, -    0x0f, 0x8f, 0x4f, 0xcf, 0x2f, 0xaf, 0x6f, 0xef, -    0x1f, 0x9f, 0x5f, 0xdf, 0x3f, 0xbf, 0x7f, 0xff -}; - - -int dabOutputRawInit(void** args) -{ -    dabOutputRawData* data = new dabOutputRawData; - -    *args = data; -#ifdef _WIN32 -    data->socket = INVALID_HANDLE_VALUE; -#else -    data->socket = -1; -    data->isCyclades = false; -#endif -    data->buffer = new unsigned char[6144]; -    return 0; -} - - -#ifdef _WIN32 -#   include <fscfg.h> -#   include <sdci.h> -#else -#   include <netinet/in.h> -#   include <sys/types.h> -#   include <sys/socket.h> -#   include <sys/ioctl.h> -#   include <linux/if_packet.h> -#   include <linux/netdevice.h> -#   include <net/if_arp.h> -#endif -int dabOutputRawOpen(void* args, const char* filename) -{ -    dabOutputRawData* data = (dabOutputRawData*)args; - -    if (filename == NULL) { -        etiLog.printHeader(TcpLog::ERR, "Socket name must be provided!\n"); -        return -1; -    } - -#ifdef _WIN32 -    // Opening device -    data->socket = CreateFile(filename, GENERIC_WRITE, 0, NULL, OPEN_EXISTING, -        FILE_ATTRIBUTE_NORMAL, NULL); -    if (data->socket == INVALID_HANDLE_VALUE) { -        etiLog.printHeader(TcpLog::ERR, "Can't open raw device '%s': %i\n", -            filename, GetLastError()); -        return -1; -    } - -    // Configuring device -    DWORD result; -    FS_TE1_CONFIG config; -    if (!DeviceIoControl(data->socket, IoctlCodeFarSyncGetTE1Config, NULL, 0, -                &config, sizeof(config), &result, NULL)) { -        etiLog.printHeader(TcpLog::ERR, -                "Can't get raw device '%s' config: %i\n", -                filename, GetLastError()); -        return -1; -    } -    config.dataRate = 2048000; -    config.clocking = CLOCKING_MASTER; -    config.framing = FRAMING_E1; -    config.structure = STRUCTURE_UNFRAMED; -    config.iface = INTERFACE_BNC; -    config.coding = CODING_HDB3; -    config.lineBuildOut = LBO_0dB; -    config.equalizer = EQUALIZER_SHORT; -    config.transparentMode = TRUE; -    config.loopMode = LOOP_NONE; -    config.range = RANGE_0_40_M; -    config.txBufferMode = BUFFER_2_FRAME; -    config.rxBufferMode = BUFFER_2_FRAME; -    config.startingTimeSlot = 0; -    config.losThreshold = 2; -    config.enableIdleCode = TRUE; -    config.idleCode = 0xff; -    if (!DeviceIoControl(data->socket, IoctlCodeFarSyncSetTE1Config, -                &config, sizeof(config), NULL, 0, &result, NULL)) { -        etiLog.printHeader(TcpLog::ERR, -                "Can't set raw device '%s' config: %i\n", -                filename, GetLastError()); -        return -1; -    } - -    // Starting device -    if (!DeviceIoControl(data->socket, IoctlCodeFarSyncQuickStart, NULL, 0, -                NULL, 0, &result, NULL)) { -        etiLog.printHeader(TcpLog::ERR, "Can't start raw device '%s': %i\n", -                filename, GetLastError()); -        return -1; -    } -#else -    data->socket = socket(PF_INET, SOCK_DGRAM, IPPROTO_IP); -    if (data->socket == -1) { -        etiLog.printHeader(TcpLog::ERR, "Are you logged as root?\n"); -        perror(filename); -        return -1; -    } - -    struct ifreq ifr; -    struct sockaddr_ll saddr; -    memset(&ifr, 0, sizeof(struct ifreq)); -    (void)strncpy(ifr.ifr_name, filename, sizeof(ifr.ifr_name)); - -    // Get current Farsync configuration -    struct fstioc_info info; -    memset(&info, 0, sizeof(info)); -    ifr.ifr_data = (char*)&info; -    if (ioctl(data->socket, FSTGETCONF, &ifr) == -1) { -        etiLog.printHeader(TcpLog::DBG, "Cyclades card identified.\n"); -        data->isCyclades = true; - -        // Set the interface MTU if needed -        if (ioctl(data->socket, SIOCGIFMTU, &ifr) == -1) { -            etiLog.printHeader(TcpLog::ERR, "Can't get raw device MTU!\n"); -            perror(filename); -            return -1; -        } else { -            if (ifr.ifr_mtu != 6143) { -                ifr.ifr_mtu = 6143; -                if (ioctl(data->socket, SIOCSIFMTU, &ifr) == -1) { -                    etiLog.printHeader(TcpLog::ERR, -                            "Can't Cyclades device MTU!\n"); -                    perror(filename); -                    return -1; -                } -            } -        } -    } else { -        etiLog.printHeader(TcpLog::DBG, "Farsync card identified.\n"); -        data->isCyclades = false; - -        info.lineInterface = E1; -        info.proto = FST_RAW; -        info.internalClock = EXTCLK; -        info.lineSpeed = 2048000; -        //info.debug = DBG_INIT | DBG_OPEN | DBG_PCI | DBG_IOCTL | DBG_TX; -        info.transparentMode = 1; -        info.ignoreCarrier = 1; -        info.numTxBuffers = 8; -        info.numRxBuffers = 8; -        info.txBufferSize = 6144; -        info.rxBufferSize = 6144; -        // E1 specific config -        info.clockSource = CLOCKING_SLAVE; -        info.structure = STRUCTURE_UNFRAMED; -        info.interface = INTERFACE_BNC; //RJ48C; -        info.coding = CODING_HDB3; -        info.txBufferMode = BUFFER_2_FRAME; -        info.idleCode = 0xff; -        info.valid = FSTVAL_ALL; - -        // Setting configuration -        etiLog.printHeader(TcpLog::DBG, "Set configuration.\n"); -        ifr.ifr_data = (char*)&info; -        if (ioctl(data->socket, FSTSETCONF, &ifr) == -1) { -            etiLog.printHeader(TcpLog::ERR, -                    "Can't set Farsync configurationi!\n"); -            perror(filename); -            return -1; -        } - -        // Disabling notify -        etiLog.printHeader(TcpLog::DBG, "Disable notify.\n"); -        int notify = 0; -        ifr.ifr_data = (char*)¬ify; -        if (ioctl(data->socket, FSTSNOTIFY, &ifr) == -1) { -            etiLog.printHeader(TcpLog::ERR, "Can't disable Farsync notify!\n"); -            perror(filename); -            return -1; -        } - -        // Apply the new configuration -        // Set the interface down if needed -        etiLog.printHeader(TcpLog::DBG, "Get flags.\n"); -        if (ioctl(data->socket, SIOCGIFFLAGS, &ifr) == -1) { -            etiLog.printHeader(TcpLog::ERR, "Can't get Farsync flags!\n"); -            perror(filename); -            return -1; -        } else { -            if (ifr.ifr_flags & IFF_UP) { -                etiLog.printHeader(TcpLog::DBG, "Set flags.\n"); -                ifr.ifr_flags &= ~IFF_UP; -                if (ioctl(data->socket, SIOCSIFFLAGS, &ifr) == -1) { -                    etiLog.printHeader(TcpLog::ERR, -                            "Can't turn down Farsync device!\n"); -                    perror(filename); -                    return -1; -                } -            } -        } - -        // Set the interface MTU if needed -        etiLog.printHeader(TcpLog::DBG, "Get MTU.\n"); -        if (ioctl(data->socket, SIOCGIFMTU, &ifr) == -1) { -            etiLog.printHeader(TcpLog::ERR, "Can't get Farsync MTU!\n"); -            perror(filename); -            return -1; -        } else { -            if (ifr.ifr_mtu != 6144) { -                etiLog.printHeader(TcpLog::DBG, "Set MTU.\n"); -                ifr.ifr_mtu = 6144; -                if (ioctl(data->socket, SIOCSIFMTU, &ifr) == -1) { -                    etiLog.printHeader(TcpLog::ERR, "Can't set Farsync MTU!\n"); -                    perror(filename); -                    return -1; -                } -            } -        } -    } - -    // Set the interface up if needed -    etiLog.printHeader(TcpLog::DBG, "Get flags.\n"); -    if (ioctl(data->socket, SIOCGIFFLAGS, &ifr) == -1) { -        etiLog.printHeader(TcpLog::ERR, "Can't get raw device flags!\n"); -        perror(filename); -        return -1; -    } else { -        if (!(ifr.ifr_flags & IFF_UP)) { -            ifr.ifr_flags |= IFF_UP; -            etiLog.printHeader(TcpLog::DBG, "Set flags.\n"); -            if (ioctl(data->socket, SIOCSIFFLAGS, &ifr) == -1) { -                etiLog.printHeader(TcpLog::ERR, "Can't turn up raw device!\n"); -                perror(filename); -                return -1; -            } -        } -    } - -    close(data->socket); - -    //////////////////// -    // Opening device // -    //////////////////// - -    if ((data->socket = socket(PF_PACKET, SOCK_RAW, htons(ETH_P_CUST))) == -1) { -        etiLog.printHeader(TcpLog::ERR, "Are you logged as root?\n"); -        perror(filename); -        return -1; -    } - -    // ioctl to read the interface number -    etiLog.printHeader(TcpLog::DBG, "Get index.\n"); -    memset(&ifr, 0, sizeof(struct ifreq)); -    strncpy(ifr.ifr_name, filename, sizeof(ifr.ifr_name)); -    if (ioctl(data->socket, SIOCGIFINDEX, (char *) &ifr) == -1) { -        perror(filename); -        return -1; -    } - -    // Bind to the interface name -    etiLog.printHeader(TcpLog::DBG, "Bind interface.\n"); -    memset(&saddr, 0, sizeof(struct sockaddr_ll)); -    saddr.sll_family = AF_PACKET; -    saddr.sll_protocol = ARPHRD_RAWHDLC; -    saddr.sll_ifindex = ifr.ifr_ifindex; -    if (bind(data->socket, (struct sockaddr *) &saddr, sizeof(saddr)) == -1) { -        etiLog.printHeader(TcpLog::ERR, "Can't bind raw device!\n"); -        perror(filename); -        return -1; -    } -#endif - -    return 0; -} - - -int dabOutputRawWrite(void* args, void* buffer, int size) -{ -    dabOutputRawData* data = (dabOutputRawData*)args; - -    // Encoding data -    memcpy(data->buffer, buffer, size); -    memset(data->buffer + size, 0x55, 6144 - size); -    for (int i = 0; i < 6144; ++i) { -        data->buffer[i] = revTable[data->buffer[i]]; -    } - -    // Writting data -#ifdef _WIN32 -    DWORD result; -    if(!DeviceIoControl(data->socket, IoctlCodeTxFrame, data->buffer, 6144, -        NULL, 0, &result, NULL)) { -            goto RAW_WRITE_ERROR; -    } -#else -    /* -    if (write(data->socket, data->buffer + 1, 6143) != 6143) { -        goto RAW_WRITE_ERROR; -    } -    */ -    if (data->isCyclades) { -        if (write(data->socket, data->buffer + 1, 6143) != 6143) { -            goto RAW_WRITE_ERROR; -        } -    } else { -        int ret = send(data->socket, data->buffer, 6144, 0); -        if (ret != 6144) { -            fprintf(stderr, "%i/6144 bytes written\n", ret); -            goto RAW_WRITE_ERROR; -        } -    } -#endif - -    return size; - -RAW_WRITE_ERROR: -#ifdef _WIN32 -    DWORD err = GetLastError(); -    LPSTR errMsg; -    if(FormatMessage( -        FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM, -        NULL, -        err, -        0, -        (LPTSTR)&errMsg, -        0, -        NULL) == 0) { -            fprintf(stderr, "Error while writting to raw socket: %i\n", err); -    } else { -        fprintf(stderr, "Error while writting to raw socket: %s\n", errMsg); -        LocalFree(errMsg); -    } -#else -    perror("Error while writting to raw socket"); -#endif - -    return -1; -} - - -int dabOutputRawClose(void* args) -{ -    dabOutputRawData* data = (dabOutputRawData*)args; - -#ifdef _WIN32 -    CancelIo(data->socket); -    CloseHandle(data->socket); -    return 0; -#else -    if (close(data->socket) == 0) { -        data->socket = -1; -        return 0; -    } -    perror("Can't close raw socket"); -#endif - -    return -1; -} - - -int dabOutputRawClean(void** args) -{ -    dabOutputRawData* data = *((dabOutputRawData**)args); - -    delete []data->buffer; -    delete data; -    return 0; -} - - -struct dabOutputOperations dabOutputRawOperations  = { -    dabOutputRawInit, -    dabOutputRawOpen, -    dabOutputRawWrite, -    dabOutputRawClose, -    dabOutputRawClean -}; - - -struct dabOutputUdpData { -    UdpSocket* socket; -    UdpPacket* packet; -}; - - -int dabOutputUdpInit(void** args) -{ -    dabOutputUdpData* data = new dabOutputUdpData; - -    *args = data; -    UdpSocket::init(); -    data->packet = new UdpPacket(6144); -    data->socket = new UdpSocket(); - -    return 0; -} - - -int dabOutputUdpOpen(void* args, const char* filename) -{ -    dabOutputUdpData* data = (dabOutputUdpData*)args; -    filename = strdup(filename); - -    char* address; -    long port; -    address = strchr((char*)filename, ':'); -    if (address == NULL) { -        etiLog.printHeader(TcpLog::ERR, -                "\"%s\" is an invalid format for udp address: " -                "should be [address]:port - > aborting\n", -                filename); -        return -1; -    } -    *(address++) = 0; -    port = strtol(address, (char **)NULL, 10); -    if ((port == LONG_MIN) || (port == LONG_MAX)) { -        etiLog.printHeader(TcpLog::ERR, -                "can't convert port number in udp address %s\n", address); -        return -1; -    } -    if (port == 0) { -        etiLog.printHeader(TcpLog::ERR, -                "can't use port number 0 in udp address\n"); -        return -1; -    } -    address = (char*)filename; -    if (strlen(address) > 0) { -        if (data->packet->getAddress().setAddress(address) == -1) { -            etiLog.printHeader(TcpLog::ERR, "can't set address %s (%s: %s) " -                    "-> aborting\n", address, inetErrDesc, inetErrMsg); -            return -1; -        } -    } -    data->packet->getAddress().setPort(port); - -    if (data->socket->create() == -1) { -        etiLog.printHeader(TcpLog::ERR, "can't create Udp socket (%s: %s) " -                "-> aborting\n)", inetErrDesc, inetErrMsg); -        return -1; -    } - -    //sprintf(filename, "%s:%i", data->packet->getAddress().getHostAddress(), -    //        data->packet->getAddress().getPort()); -    return 0; -} - - -int dabOutputUdpWrite(void* args, void* buffer, int size) -{ -    dabOutputUdpData* data = (dabOutputUdpData*)args; - -    data->packet->setLength(0); -    data->packet->addData(buffer, size); -    return data->socket->send(*data->packet); -} - - -int dabOutputUdpClose(void* args) -{ -    //dabOutputUdpData* data = (dabOutputUdpData*)args; - -    return 0; -} - - -int dabOutputUdpClean(void** args) -{ -    dabOutputUdpData* data = *((dabOutputUdpData**)args); - -    delete data->socket; -    delete data->packet; -    delete data; - -    return 0; -} - - -struct dabOutputOperations dabOutputUdpOperations  = { -    dabOutputUdpInit, -    dabOutputUdpOpen, -    dabOutputUdpWrite, -    dabOutputUdpClose, -    dabOutputUdpClean -}; - - -#include "TcpServer.h" -struct dabOutputTcpData { -    TcpServer* server; -    TcpSocket* client; -    pthread_t thread; -}; - - -int dabOutputTcpInit(void** args) -{ -    dabOutputTcpData* data = new dabOutputTcpData; - -    *args = data; -    TcpSocket::init(); -    data->server = new TcpServer(); -    data->client = NULL; - -    return 0; -} - - -void* dabOutputTcpThread(void* args) -{ -    dabOutputTcpData* data = (dabOutputTcpData*)args; -    TcpSocket* client; - -    while ((client = data->server->accept()) != NULL) { -        etiLog.print(TcpLog::INFO, "TCP server got a new client.\n"); -        if (data->client != NULL) { -            delete data->client; -        } -        data->client = client; -    } -    etiLog.print(TcpLog::ERR, "TCP thread can't accept new client (%s)\n", -            inetErrDesc, inetErrMsg); - -    return NULL; -} - - -int dabOutputTcpOpen(void* args, const char* filename) -{ -    dabOutputTcpData* data = (dabOutputTcpData*)args; -    filename = strdup(filename); - -    char* address; -    long port; -    address = strchr((char*)filename, ':'); -    if (address == NULL) { -        etiLog.printHeader(TcpLog::ERR, -                "\"%s\" is an invalid format for tcp address: " -                "should be [address]:port - > aborting\n", -                filename); -        return -1; -    } -    *(address++) = 0; -    port = strtol(address, (char **)NULL, 10); -    if ((port == LONG_MIN) || (port == LONG_MAX)) { -        etiLog.printHeader(TcpLog::ERR, -                "can't convert port number in tcp address %s\n", address); -        return -1; -    } -    if (port == 0) { -        etiLog.printHeader(TcpLog::ERR, -                "can't use port number 0 in tcp address\n"); -        return -1; -    } -    address = (char*)filename; -    if (strlen(address) > 0) { -        if (data->server->create(port, address) == -1) { -            etiLog.printHeader(TcpLog::ERR, "Can't create Tcp server on %s:%i " -                    "(%s: %s) -> aborting\n", -                    address, port, inetErrDesc, inetErrMsg); -            return -1; -        } -    } else { -        if (data->server->create(port) == -1) { -            etiLog.printHeader(TcpLog::ERR, "Can't create Tcp server on :%i " -                    "(%s: %s) -> aborting\n", -                    port, inetErrDesc, inetErrMsg); -            return -1; -        } -    } - -    //sprintf(filename, "%s:%i", data->packet->getAddress().getHostAddress(), -    //        data->packet->getAddress().getPort()); - -    if (data->server->listen() == -1) { -        etiLog.printHeader(TcpLog::ERR, "Can't listen on Tcp socket (%s: %s)\n", -                inetErrDesc, inetErrMsg); -        return -1; -    } -#ifdef _WIN32 -    data->thread = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)dabOutputTcpThread, data, 0, NULL); -    if (data->thread == NULL) { -        fprintf(stderr, "Can't create TCP child"); -        return -1; -    } -#else -    if (pthread_create(&data->thread, NULL, dabOutputTcpThread, data)) { -        perror("Can't create TCP child"); -        return -1; -    } -#endif - -    return 0; -} - - -int dabOutputTcpWrite(void* args, void* buffer, int size) -{ -    dabOutputTcpData* data = (dabOutputTcpData*)args; - -    if (data->client != NULL) { -        if (data->client->write(&size, 2) == 2) { -            if (data->client->write(buffer, size) != size) { -                return size; -            } -        } -        else { -            etiLog.print(TcpLog::INFO, "TCP server client disconnected.\n"); -            delete data->client; -            data->client = NULL; -        } -    } -    return size; -} - - -#include <signal.h> -int dabOutputTcpClose(void* args) -{ -    dabOutputTcpData* data = (dabOutputTcpData*)args; - -    data->server->close(); -    if( data->client != NULL ) -        data->client->close(); -#ifdef WIN32 -    DWORD status; -    for (int i = 0; i < 5; ++i) { -        if (GetExitCodeThread(data->thread, &status)) { -            break; -        } -        Sleep(100); -    } -    TerminateThread(data->thread, 1); -#else -    pthread_kill(data->thread, SIGPIPE); -#endif - -    return 0; -} - - -int dabOutputTcpClean(void** args) -{ -    dabOutputTcpData* data = *((dabOutputTcpData**)args); - -#ifdef _WIN32 -    CloseHandle(data->thread); -#endif - -    delete data->server; -    delete data->client; -    delete data; - -    return 0; -} - - -struct dabOutputOperations dabOutputTcpOperations  = { -    dabOutputTcpInit, -    dabOutputTcpOpen, -    dabOutputTcpWrite, -    dabOutputTcpClose, -    dabOutputTcpClean -}; - - -struct dabOutputSimulData { -#ifdef _WIN32 -    DWORD startTime; -#else -    timeval startTime; -#endif -}; - - -int dabOutputSimulInit(void** args) { -    dabOutputSimulData* data = new dabOutputSimulData; - -    *args = data; - -    return 0; -} - - -int dabOutputSimulOpen(void* args, const char* filename) -{ -    dabOutputSimulData* data = (dabOutputSimulData*)args; - -#ifdef _WIN32 -    data->startTime = GetTickCount(); -#else -    gettimeofday(&data->startTime, NULL); -#endif - -    return 0; -} - - -int dabOutputSimulWrite(void* args, void* buffer, int size) -{ -    dabOutputSimulData* data = (dabOutputSimulData*)args; - -    unsigned long current; -    unsigned long start; -    unsigned long waiting; - -#ifdef _WIN32 -    current = GetTickCount(); -    start = data->startTime; -    if (current < start) { -        waiting = start - current + 24; -        Sleep(waiting); -    } else { -        waiting = 24 - (current - start); -        if ((current - start) < 24) { -            Sleep(waiting); -        } -    } -    data->startTime += 24; -#else -    timeval curTime; -    gettimeofday(&curTime, NULL); -    current = (1000000ul * curTime.tv_sec) + curTime.tv_usec; -    start = (1000000ul * data->startTime.tv_sec) + data->startTime.tv_usec; -    waiting = 24000ul - (current - start); -    if ((current - start) < 24000ul) { -        usleep(waiting); -    } - -    data->startTime.tv_usec += 24000; -    if (data->startTime.tv_usec >= 1000000) { -        data->startTime.tv_usec -= 1000000; -        ++data->startTime.tv_sec; -    } -#endif - -    return size; -} - - -int dabOutputSimulClose(void* args) -{ -    //dabOutputSimulData* data = (dabOutputSimulData*)args); - -    return 0; -} - - -int dabOutputSimulClean(void** args) -{ -    dabOutputSimulData* data = *((dabOutputSimulData**)args); - -    delete data; - -    return 0; -} - - -struct dabOutputOperations dabOutputSimulOperations  = { -    dabOutputSimulInit, -    dabOutputSimulOpen, -    dabOutputSimulWrite, -    dabOutputSimulClose, -    dabOutputSimulClean -}; - - diff --git a/src/dabOutput.h b/src/dabOutput.h deleted file mode 100644 index 26c154a..0000000 --- a/src/dabOutput.h +++ /dev/null @@ -1,72 +0,0 @@ -/* -   Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009 Her Majesty the Queen in -   Right of Canada (Communications Research Center Canada) -   */ -/* -   This file is part of CRC-DabMux. - -   CRC-DabMux 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. - -   CRC-DabMux 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 CRC-DabMux.  If not, see <http://www.gnu.org/licenses/>. -   */ - -#ifndef _DABOUTPUT -#define _DABOUTPUT - -#ifdef HAVE_CONFIG_H -#   include "config.h" -#endif - - -struct dabOutputOperations { -    int (*init)(void** args); -    int (*open)(void* args, const char* name); -    int (*write)(void* args, void* buffer, int size); -    int (*close)(void* args); -    int (*clean)(void** args); -}; - -extern struct dabOutputOperations dabOutputDefaultOperations; - -#if defined(HAVE_OUTPUT_FILE) -extern struct dabOutputOperations dabOutputFileOperations; -#endif // defined(HAVE_OUTPUT_FILE) - -#if defined(HAVE_OUTPUT_FIFO) -extern struct dabOutputOperations dabOutputFifoOperations; -#endif // defined(HAVE_OUTPUT_FIFO) - -#if defined(HAVE_OUTPUT_UDP) -extern struct dabOutputOperations dabOutputUdpOperations; -#endif // defined(HAVE_OUTPUT_UDP) - -#if defined(HAVE_OUTPUT_TCP) -extern struct dabOutputOperations dabOutputTcpOperations; -#endif // defined(HAVE_OUTPUT_TCP) - -#if defined(HAVE_OUTPUT_RAW) -extern struct dabOutputOperations dabOutputRawOperations; -#endif // defined(HAVE_OUTPUT_RAW) - -#if defined(HAVE_OUTPUT_SIMUL) -extern struct dabOutputOperations dabOutputSimulOperations; -#endif // defined(HAVE_OUTPUT_SIMUL) - - -extern const unsigned char revTable[]; - - -#include "TcpLog.h" -extern TcpLog etiLog; - - -#endif // _DABOUTPUT diff --git a/src/dabOutput/dabOutput.cpp b/src/dabOutput/dabOutput.cpp new file mode 100644 index 0000000..18da57e --- /dev/null +++ b/src/dabOutput/dabOutput.cpp @@ -0,0 +1,109 @@ +#include <cstdio> +#include <cstring> +#include <fcntl.h> +#include <limits.h> +#include "dabOutput.h" + + + +DabOutputFifo::open(const char* name) +{ +    char* token = strchr((char*)filename, '?'); +    if (token != NULL) { +        *(token++) = 0; +        char* nextPair; +        char* key; +        char* value; +        // Go through all the &stuff=foo pairs +        // Only the key "type" is supported +        do { +            nextPair = strchr(token, '&'); +            if (nextPair != NULL) { +                *nextPair = 0; +            } +            key = token; +            value = strchr(token, '='); +            if (value != NULL) { +                *(value++) = 0; +                if (strcmp(key, "type") == 0) { +                    if (strcmp(value, "raw") == 0) { +                        this->type_ = ETI_FILE_TYPE_RAW; +                        break; +                    } else if (strcmp(value, "framed") == 0) { +                        this->type = ETI_FILE_TYPE_FRAMED; +                        break; +                    } else if (strcmp(value, "streamed") == 0) { +                        this->type = ETI_FILE_TYPE_STREAMED; +                        break; +                    } else { +                        etiLog.printHeader(TcpLog::ERR, +                                "File type '%s' is not supported.\n", value); +                        return -1; +                    } +                } +                else { +                    etiLog.printHeader(TcpLog::WARNING, "Parameter '%s' unknown\n", key); +                } +            } +        } while (nextPair != NULL); +    } + +    this->file_ = open(filename, O_WRONLY | O_CREAT | O_TRUNC | O_BINARY, 0666); +    if (this->file_ == -1) { +        perror(filename); +        return -1; +    } +    return 0; +} + +int DabOutputFifo::write(void* buffer, int size) +{ +    uint8_t padding[6144]; + +    switch (this->type_) { +        case ETI_FILE_TYPE_FRAMED: +            if (this->nbFrames_ == 0) { +                uint32_t nbFrames = (uint32_t)-1; +                // Writing nb frames +                if (write(this->file_, &nbFrames, 4) == -1) +                    goto FIFO_WRITE_ERROR; +            } +        case ETI_FILE_TYPE_STREAMED: +            // Writting frame length +            if (write(this->file_, &size, 2) == -1) +                goto FIFO_WRITE_ERROR; +            // Appending data +            if (write(this->file_, buffer, size) == -1) +                goto FIFO_WRITE_ERROR; +            break; +        case ETI_FILE_TYPE_RAW: +            // Appending data +            if (write(this->file_, buffer, size) == -1) +                goto FIFO_WRITE_ERROR; +            // Appending padding +            memset(padding, 0x55, 6144 - size); +            if (write(this->file_, padding, 6144 - size) == -1) +                goto FIFO_WRITE_ERROR; +            break; +        default: +            etiLog.printHeader(TcpLog::ERR, "File type is not supported.\n"); +            return -1; +    } + +    return size; + +FIFO_WRITE_ERROR: +    perror("Error while writting to file"); +    return -1; +} + +int DabOutputFifo::close() +{ +    if (close(this->file_) == 0) { +        this->file_ = -1; +        return 0; +    } +    perror("Can't close file"); +    return -1; +} + diff --git a/src/dabOutput/dabOutput.h b/src/dabOutput/dabOutput.h new file mode 100644 index 0000000..7f295b4 --- /dev/null +++ b/src/dabOutput/dabOutput.h @@ -0,0 +1,248 @@ +/* +   Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009 Her Majesty the Queen in +   Right of Canada (Communications Research Center Canada) + +   Copyright (C) 2013 Matthias P. Braendli +   http://mpb.li + +   An object-oriented version of the output channels. +   */ +/* +   This file is part of CRC-DabMux. + +   CRC-DabMux 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. + +   CRC-DabMux 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 CRC-DabMux.  If not, see <http://www.gnu.org/licenses/>. +   */ + +#ifndef __DAB_OUTPUT_H +#define __DAB_OUTPUT_H + +#include "UdpSocket.h" +#include "TcpServer.h" +#include "TcpLog.h" +#include <signal.h> +#ifdef _WIN32 +#   include <io.h> +#   ifdef __MINGW32__ +#       define FS_DECLARE_CFG_ARRAYS +#       include <winioctl.h> +#   endif +#   include <sdci.h> +#else +#   include <unistd.h> +#   include <sys/time.h> +#   ifndef O_BINARY +#       define O_BINARY 0 +#   endif // O_BINARY +#endif + +extern TcpLog etiLog; + +// Abstract base class for all outputs +class DabOutput +{ +    public: +        virtual int Open(const char* name) = 0; +        int Open(std::string name) +        { +            return Open(name.c_str()); +        } +        virtual int Write(void* buffer, int size) = 0; +        virtual int Close() = 0; + +        virtual ~DabOutput() {}; +}; + +// ----- used in File and Fifo outputs +enum EtiFileType { +    ETI_FILE_TYPE_NONE = 0, +    ETI_FILE_TYPE_RAW, +    ETI_FILE_TYPE_STREAMED, +    ETI_FILE_TYPE_FRAMED +}; + +// ---------- File output ------------ +class DabOutputFile : public DabOutput +{ +    public: +        DabOutputFile() { +            nbFrames_ = 0; +            file_ = -1; +            type_ = ETI_FILE_TYPE_FRAMED; +        } + +        DabOutputFile(const DabOutputFile& other) +        { +            file_ = other.file_; +            nbFrames_ = other.nbFrames_; +            type_ = other.type_; +        } + +        ~DabOutputFile() {} + +        int Open(const char* filename); +        int Write(void* buffer, int size); +        int Close(); + +    protected: +        int file_; +        EtiFileType type_; +        unsigned long nbFrames_; +}; + +// ---------- FIFO output ------------ +// only write is different for the FIFO output +class DabOutputFifo : public DabOutputFile +{ +    public: +        DabOutputFifo() : DabOutputFile() {} +        ~DabOutputFifo() {} + +        int Write(void* buffer, int size); +}; + +// -------------- RAW socket ----------- +class DabOutputRaw : public DabOutput +{ +    public: +        DabOutputRaw() +        { +#ifdef _WIN32 +            socket_ = INVALID_HANDLE_VALUE; +#else +            socket_ = -1; +            isCyclades_ = false; +#endif +            buffer_ = new unsigned char[6144]; +        } + +        DabOutputRaw(const DabOutputRaw& other) +        { +            socket_ = other.socket_; +#ifndef _WIN32 +            isCyclades_ = other.isCyclades_; +#endif +            buffer_ = other.buffer_; +        } + +        ~DabOutputRaw() { +            delete[] buffer_; +        } + +        int Open(const char* name); +        int Write(void* buffer, int size); +        int Close(); +    private: +#ifdef _WIN32 +        HANDLE socket_; +#else +        int socket_; +        bool isCyclades_; +#endif +        unsigned char* buffer_; +}; + +// -------------- UDP ------------------ +class DabOutputUdp : public DabOutput +{ +    public: +        DabOutputUdp() { +            UdpSocket::init(); +            packet_ = new UdpPacket(6144); +            socket_ = new UdpSocket(); +        } + +        DabOutputUdp(const DabOutputUdp& other) +        { +            packet_ = other.packet_; +            socket_ = other.socket_; +        } + +        ~DabOutputUdp() { +            delete socket_; +            delete packet_; +        } + +        int Open(const char* name); +        int Write(void* buffer, int size); +        int Close() { return 0; } + +    private: +        UdpSocket* socket_; +        UdpPacket* packet_; +}; + +// -------------- TCP ------------------ +class DabOutputTcp : public DabOutput +{ +    public: +        DabOutputTcp() +        { +            TcpSocket::init(); +            server = new TcpServer(); +            client = NULL; +        } + +        DabOutputTcp(const DabOutputTcp& other) +        { +            server = other.server; +            client = other.client; +            thread_ = other.thread_; +        } + +        ~DabOutputTcp() { + +#ifdef _WIN32 +            CloseHandle(this->thread_); +#endif + +            delete this->server; +            delete this->client; +        } + +        int Open(const char* name); +        int Write(void* buffer, int size); +        int Close(); + +        TcpServer* server; +        TcpSocket* client; +    private: +        pthread_t thread_; +}; + +// -------------- Simul ------------------ +class DabOutputSimul : public DabOutput +{ +    public: +        DabOutputSimul() {} + +        DabOutputSimul(const DabOutputSimul& other) +        { +            startTime_ = other.startTime_; +        } + +        ~DabOutputSimul() { } + +        int Open(const char* name); +        int Write(void* buffer, int size); +        int Close() { return 0; } +    private: +#ifdef _WIN32 +        DWORD startTime_; +#else +        timeval startTime_; +#endif +}; + +#endif + diff --git a/src/dabOutput/dabOutputFifo.cpp b/src/dabOutput/dabOutputFifo.cpp new file mode 100644 index 0000000..49fc331 --- /dev/null +++ b/src/dabOutput/dabOutputFifo.cpp @@ -0,0 +1,48 @@ +#include <cstdio> +#include <cstring> +#include <fcntl.h> +#include <limits.h> +#include "dabOutput.h" + + +int DabOutputFifo::Write(void* buffer, int size) +{ +    uint8_t padding[6144]; + +    switch (this->type_) { +        case ETI_FILE_TYPE_FRAMED: +            if (this->nbFrames_ == 0) { +                uint32_t nbFrames = (uint32_t)-1; +                // Writing nb frames +                if (write(this->file_, &nbFrames, 4) == -1) +                    goto FIFO_WRITE_ERROR; +            } +        case ETI_FILE_TYPE_STREAMED: +            // Writting frame length +            if (write(this->file_, &size, 2) == -1) +                goto FIFO_WRITE_ERROR; +            // Appending data +            if (write(this->file_, buffer, size) == -1) +                goto FIFO_WRITE_ERROR; +            break; +        case ETI_FILE_TYPE_RAW: +            // Appending data +            if (write(this->file_, buffer, size) == -1) +                goto FIFO_WRITE_ERROR; +            // Appending padding +            memset(padding, 0x55, 6144 - size); +            if (write(this->file_, padding, 6144 - size) == -1) +                goto FIFO_WRITE_ERROR; +            break; +        default: +            etiLog.printHeader(TcpLog::ERR, "File type is not supported.\n"); +            return -1; +    } + +    return size; + +FIFO_WRITE_ERROR: +    perror("Error while writting to file"); +    return -1; +} + diff --git a/src/dabOutput/dabOutputFile.cpp b/src/dabOutput/dabOutputFile.cpp new file mode 100644 index 0000000..349a308 --- /dev/null +++ b/src/dabOutput/dabOutputFile.cpp @@ -0,0 +1,111 @@ +#include <cstdio> +#include <cstring> +#include <fcntl.h> +#include <limits.h> +#include "dabOutput.h" + +int DabOutputFile::Open(const char* filename) +{ +    char* token = strchr((char*)filename, '?'); +    if (token != NULL) { +        *(token++) = 0; +        char* nextPair; +        char* key; +        char* value; +        // Go through all the &stuff=foo pairs +        // Only the key "type" is supported +        do { +            nextPair = strchr(token, '&'); +            if (nextPair != NULL) { +                *nextPair = 0; +            } +            key = token; +            value = strchr(token, '='); +            if (value != NULL) { +                *(value++) = 0; +                if (strcmp(key, "type") == 0) { +                    if (strcmp(value, "raw") == 0) { +                        this->type_ = ETI_FILE_TYPE_RAW; +                        break; +                    } else if (strcmp(value, "framed") == 0) { +                        this->type_ = ETI_FILE_TYPE_FRAMED; +                        break; +                    } else if (strcmp(value, "streamed") == 0) { +                        this->type_ = ETI_FILE_TYPE_STREAMED; +                        break; +                    } else { +                        etiLog.printHeader(TcpLog::ERR, +                                "File type '%s' is not supported.\n", value); +                        return -1; +                    } +                } +                else { +                    etiLog.printHeader(TcpLog::WARNING, "Parameter '%s' unknown\n", key); +                } +            } +        } while (nextPair != NULL); +    } + +    this->file_ = open(filename, O_WRONLY | O_CREAT | O_TRUNC | O_BINARY, 0666); +    if (this->file_ == -1) { +        perror(filename); +        return -1; +    } +    return 0; +} + +int DabOutputFile::Write(void* buffer, int size) +{ +    uint8_t padding[6144]; +    ++nbFrames_; + +    switch (this->type_) { +    case ETI_FILE_TYPE_FRAMED: +        // Writting nb of frames at beginning of file +        if (lseek(this->file_, 0, SEEK_SET) == -1) goto FILE_WRITE_ERROR; +        if (write(this->file_, &this->nbFrames_, 4) == -1) goto FILE_WRITE_ERROR; + +        // Writting nb frame length at end of file +        if (lseek(this->file_, 0, SEEK_END) == -1) goto FILE_WRITE_ERROR; +        if (write(this->file_, &size, 2) == -1) goto FILE_WRITE_ERROR; + +        // Appending data +        if (write(this->file_, buffer, size) == -1) goto FILE_WRITE_ERROR; +        break; +    case ETI_FILE_TYPE_STREAMED: +        // Writting nb frame length at end of file +        if (write(this->file_, &size, 2) == -1) goto FILE_WRITE_ERROR; + +        // Appending data +        if (write(this->file_, buffer, size) == -1) goto FILE_WRITE_ERROR; +        break; +    case ETI_FILE_TYPE_RAW: +        // Appending data +        if (write(this->file_, buffer, size) == -1) goto FILE_WRITE_ERROR; + +        // Appending padding +        memset(padding, 0x55, 6144 - size); +        if (write(this->file_, padding, 6144 - size) == -1) goto FILE_WRITE_ERROR; +        break; +    default: +        etiLog.printHeader(TcpLog::ERR, "File type is not supported.\n"); +        return -1; +    } + +    return size; + +FILE_WRITE_ERROR: +    perror("Error while writting to file"); +    return -1; +} + +int DabOutputFile::Close() +{ +    if (close(this->file_) == 0) { +        this->file_ = -1; +        return 0; +    } +    perror("Can't close file"); +    return -1; +} + diff --git a/src/dabOutput/dabOutputRaw.cpp b/src/dabOutput/dabOutputRaw.cpp new file mode 100644 index 0000000..1a78b63 --- /dev/null +++ b/src/dabOutput/dabOutputRaw.cpp @@ -0,0 +1,366 @@ +#include <cstdio> +#include <cstring> +#include "dabOutput.h" +#ifdef _WIN32 +#   include <fscfg.h> +#   include <sdci.h> +#else +#   include <farsync.h> +#   include <netinet/in.h> +#   include <sys/types.h> +#   include <sys/socket.h> +#   include <sys/ioctl.h> +#   include <linux/if_packet.h> +#   include <linux/netdevice.h> +#   include <net/if_arp.h> +#endif + +const unsigned char revTable[] = { +    0x00, 0x80, 0x40, 0xc0, 0x20, 0xa0, 0x60, 0xe0, +    0x10, 0x90, 0x50, 0xd0, 0x30, 0xb0, 0x70, 0xf0, +    0x08, 0x88, 0x48, 0xc8, 0x28, 0xa8, 0x68, 0xe8, +    0x18, 0x98, 0x58, 0xd8, 0x38, 0xb8, 0x78, 0xf8, +    0x04, 0x84, 0x44, 0xc4, 0x24, 0xa4, 0x64, 0xe4, +    0x14, 0x94, 0x54, 0xd4, 0x34, 0xb4, 0x74, 0xf4, +    0x0c, 0x8c, 0x4c, 0xcc, 0x2c, 0xac, 0x6c, 0xec, +    0x1c, 0x9c, 0x5c, 0xdc, 0x3c, 0xbc, 0x7c, 0xfc, +    0x02, 0x82, 0x42, 0xc2, 0x22, 0xa2, 0x62, 0xe2, +    0x12, 0x92, 0x52, 0xd2, 0x32, 0xb2, 0x72, 0xf2, +    0x0a, 0x8a, 0x4a, 0xca, 0x2a, 0xaa, 0x6a, 0xea, +    0x1a, 0x9a, 0x5a, 0xda, 0x3a, 0xba, 0x7a, 0xfa, +    0x06, 0x86, 0x46, 0xc6, 0x26, 0xa6, 0x66, 0xe6, +    0x16, 0x96, 0x56, 0xd6, 0x36, 0xb6, 0x76, 0xf6, +    0x0e, 0x8e, 0x4e, 0xce, 0x2e, 0xae, 0x6e, 0xee, +    0x1e, 0x9e, 0x5e, 0xde, 0x3e, 0xbe, 0x7e, 0xfe, +    0x01, 0x81, 0x41, 0xc1, 0x21, 0xa1, 0x61, 0xe1, +    0x11, 0x91, 0x51, 0xd1, 0x31, 0xb1, 0x71, 0xf1, +    0x09, 0x89, 0x49, 0xc9, 0x29, 0xa9, 0x69, 0xe9, +    0x19, 0x99, 0x59, 0xd9, 0x39, 0xb9, 0x79, 0xf9, +    0x05, 0x85, 0x45, 0xc5, 0x25, 0xa5, 0x65, 0xe5, +    0x15, 0x95, 0x55, 0xd5, 0x35, 0xb5, 0x75, 0xf5, +    0x0d, 0x8d, 0x4d, 0xcd, 0x2d, 0xad, 0x6d, 0xed, +    0x1d, 0x9d, 0x5d, 0xdd, 0x3d, 0xbd, 0x7d, 0xfd, +    0x03, 0x83, 0x43, 0xc3, 0x23, 0xa3, 0x63, 0xe3, +    0x13, 0x93, 0x53, 0xd3, 0x33, 0xb3, 0x73, 0xf3, +    0x0b, 0x8b, 0x4b, 0xcb, 0x2b, 0xab, 0x6b, 0xeb, +    0x1b, 0x9b, 0x5b, 0xdb, 0x3b, 0xbb, 0x7b, 0xfb, +    0x07, 0x87, 0x47, 0xc7, 0x27, 0xa7, 0x67, 0xe7, +    0x17, 0x97, 0x57, 0xd7, 0x37, 0xb7, 0x77, 0xf7, +    0x0f, 0x8f, 0x4f, 0xcf, 0x2f, 0xaf, 0x6f, 0xef, +    0x1f, 0x9f, 0x5f, 0xdf, 0x3f, 0xbf, 0x7f, 0xff +}; + +int DabOutputRaw::Open(const char* filename) +{ +    if (filename == NULL) { +        etiLog.printHeader(TcpLog::ERR, "Socket name must be provided!\n"); +        return -1; +    } + +#ifdef _WIN32 +    // Opening device +    this->socket_ = CreateFile(filename, GENERIC_WRITE, 0, NULL, OPEN_EXISTING, +        FILE_ATTRIBUTE_NORMAL, NULL); +    if (this->socket_ == INVALID_HANDLE_VALUE) { +        etiLog.printHeader(TcpLog::ERR, "Can't open raw device '%s': %i\n", +            filename, GetLastError()); +        return -1; +    } + +    // Configuring device +    DWORD result; +    FS_TE1_CONFIG config; +    if (!DeviceIoControl(this->socket_, IoctlCodeFarSyncGetTE1Config, NULL, 0, +                &config, sizeof(config), &result, NULL)) { +        etiLog.printHeader(TcpLog::ERR, +                "Can't get raw device '%s' config: %i\n", +                filename, GetLastError()); +        return -1; +    } +    config.dataRate = 2048000; +    config.clocking = CLOCKING_MASTER; +    config.framing = FRAMING_E1; +    config.structure = STRUCTURE_UNFRAMED; +    config.iface = INTERFACE_BNC; +    config.coding = CODING_HDB3; +    config.lineBuildOut = LBO_0dB; +    config.equalizer = EQUALIZER_SHORT; +    config.transparentMode = TRUE; +    config.loopMode = LOOP_NONE; +    config.range = RANGE_0_40_M; +    config.txBufferMode = BUFFER_2_FRAME; +    config.rxBufferMode = BUFFER_2_FRAME; +    config.startingTimeSlot = 0; +    config.losThreshold = 2; +    config.enableIdleCode = TRUE; +    config.idleCode = 0xff; +    if (!DeviceIoControl(this->socket_, IoctlCodeFarSyncSetTE1Config, +                &config, sizeof(config), NULL, 0, &result, NULL)) { +        etiLog.printHeader(TcpLog::ERR, +                "Can't set raw device '%s' config: %i\n", +                filename, GetLastError()); +        return -1; +    } + +    // Starting device +    if (!DeviceIoControl(this->socket_, IoctlCodeFarSyncQuickStart, NULL, 0, +                NULL, 0, &result, NULL)) { +        etiLog.printHeader(TcpLog::ERR, "Can't start raw device '%s': %i\n", +                filename, GetLastError()); +        return -1; +    } +#else +    this->socket_ = socket(PF_INET, SOCK_DGRAM, IPPROTO_IP); +    if (this->socket_ == -1) { +        etiLog.printHeader(TcpLog::ERR, "Are you logged as root?\n"); +        perror(filename); +        return -1; +    } + +    struct ifreq ifr; +    struct sockaddr_ll saddr; +    memset(&ifr, 0, sizeof(struct ifreq)); +    (void)strncpy(ifr.ifr_name, filename, sizeof(ifr.ifr_name)); + +    // Get current Farsync configuration +    struct fstioc_info info; +    memset(&info, 0, sizeof(info)); +    ifr.ifr_data = (char*)&info; +    if (ioctl(this->socket_, FSTGETCONF, &ifr) == -1) { +        etiLog.printHeader(TcpLog::DBG, "Cyclades card identified.\n"); +        this->isCyclades_ = true; + +        // Set the interface MTU if needed +        if (ioctl(this->socket_, SIOCGIFMTU, &ifr) == -1) { +            etiLog.printHeader(TcpLog::ERR, "Can't get raw device MTU!\n"); +            perror(filename); +            return -1; +        } else { +            if (ifr.ifr_mtu != 6143) { +                ifr.ifr_mtu = 6143; +                if (ioctl(this->socket_, SIOCSIFMTU, &ifr) == -1) { +                    etiLog.printHeader(TcpLog::ERR, +                            "Can't Cyclades device MTU!\n"); +                    perror(filename); +                    return -1; +                } +            } +        } +    } else { +        etiLog.printHeader(TcpLog::DBG, "Farsync card identified.\n"); +        this->isCyclades_ = false; + +        info.lineInterface = E1; +        info.proto = FST_RAW; +        info.internalClock = EXTCLK; +        info.lineSpeed = 2048000; +        //info.debug = DBG_INIT | DBG_OPEN | DBG_PCI | DBG_IOCTL | DBG_TX; +        info.transparentMode = 1; +        info.ignoreCarrier = 1; +        info.numTxBuffers = 8; +        info.numRxBuffers = 8; +        info.txBufferSize = 6144; +        info.rxBufferSize = 6144; +        // E1 specific config +        info.clockSource = CLOCKING_SLAVE; +        info.structure = STRUCTURE_UNFRAMED; +        info.interface = INTERFACE_BNC; //RJ48C; +        info.coding = CODING_HDB3; +        info.txBufferMode = BUFFER_2_FRAME; +        info.idleCode = 0xff; +        info.valid = FSTVAL_ALL; + +        // Setting configuration +        etiLog.printHeader(TcpLog::DBG, "Set configuration.\n"); +        ifr.ifr_data = (char*)&info; +        if (ioctl(this->socket_, FSTSETCONF, &ifr) == -1) { +            etiLog.printHeader(TcpLog::ERR, +                    "Can't set Farsync configurationi!\n"); +            perror(filename); +            return -1; +        } + +        // Disabling notify +        etiLog.printHeader(TcpLog::DBG, "Disable notify.\n"); +        int notify = 0; +        ifr.ifr_data = (char*)¬ify; +        if (ioctl(this->socket_, FSTSNOTIFY, &ifr) == -1) { +            etiLog.printHeader(TcpLog::ERR, "Can't disable Farsync notify!\n"); +            perror(filename); +            return -1; +        } + +        // Apply the new configuration +        // Set the interface down if needed +        etiLog.printHeader(TcpLog::DBG, "Get flags.\n"); +        if (ioctl(this->socket_, SIOCGIFFLAGS, &ifr) == -1) { +            etiLog.printHeader(TcpLog::ERR, "Can't get Farsync flags!\n"); +            perror(filename); +            return -1; +        } else { +            if (ifr.ifr_flags & IFF_UP) { +                etiLog.printHeader(TcpLog::DBG, "Set flags.\n"); +                ifr.ifr_flags &= ~IFF_UP; +                if (ioctl(this->socket_, SIOCSIFFLAGS, &ifr) == -1) { +                    etiLog.printHeader(TcpLog::ERR, +                            "Can't turn down Farsync device!\n"); +                    perror(filename); +                    return -1; +                } +            } +        } + +        // Set the interface MTU if needed +        etiLog.printHeader(TcpLog::DBG, "Get MTU.\n"); +        if (ioctl(this->socket_, SIOCGIFMTU, &ifr) == -1) { +            etiLog.printHeader(TcpLog::ERR, "Can't get Farsync MTU!\n"); +            perror(filename); +            return -1; +        } else { +            if (ifr.ifr_mtu != 6144) { +                etiLog.printHeader(TcpLog::DBG, "Set MTU.\n"); +                ifr.ifr_mtu = 6144; +                if (ioctl(this->socket_, SIOCSIFMTU, &ifr) == -1) { +                    etiLog.printHeader(TcpLog::ERR, "Can't set Farsync MTU!\n"); +                    perror(filename); +                    return -1; +                } +            } +        } +    } + +    // Set the interface up if needed +    etiLog.printHeader(TcpLog::DBG, "Get flags.\n"); +    if (ioctl(this->socket_, SIOCGIFFLAGS, &ifr) == -1) { +        etiLog.printHeader(TcpLog::ERR, "Can't get raw device flags!\n"); +        perror(filename); +        return -1; +    } else { +        if (!(ifr.ifr_flags & IFF_UP)) { +            ifr.ifr_flags |= IFF_UP; +            etiLog.printHeader(TcpLog::DBG, "Set flags.\n"); +            if (ioctl(this->socket_, SIOCSIFFLAGS, &ifr) == -1) { +                etiLog.printHeader(TcpLog::ERR, "Can't turn up raw device!\n"); +                perror(filename); +                return -1; +            } +        } +    } + +    close(this->socket_); + +    //////////////////// +    // Opening device // +    //////////////////// + +    if ((this->socket_ = socket(PF_PACKET, SOCK_RAW, htons(ETH_P_CUST))) == -1) { +        etiLog.printHeader(TcpLog::ERR, "Are you logged as root?\n"); +        perror(filename); +        return -1; +    } + +    // ioctl to read the interface number +    etiLog.printHeader(TcpLog::DBG, "Get index.\n"); +    memset(&ifr, 0, sizeof(struct ifreq)); +    strncpy(ifr.ifr_name, filename, sizeof(ifr.ifr_name)); +    if (ioctl(this->socket_, SIOCGIFINDEX, (char *) &ifr) == -1) { +        perror(filename); +        return -1; +    } + +    // Bind to the interface name +    etiLog.printHeader(TcpLog::DBG, "Bind interface.\n"); +    memset(&saddr, 0, sizeof(struct sockaddr_ll)); +    saddr.sll_family = AF_PACKET; +    saddr.sll_protocol = ARPHRD_RAWHDLC; +    saddr.sll_ifindex = ifr.ifr_ifindex; +    if (bind(this->socket_, (struct sockaddr *) &saddr, sizeof(saddr)) == -1) { +        etiLog.printHeader(TcpLog::ERR, "Can't bind raw device!\n"); +        perror(filename); +        return -1; +    } +#endif + +    return 0; +} + + +int DabOutputRaw::Write(void* buffer, int size) +{ +    // Encoding data +    memcpy(this->buffer_, buffer, size); +    memset(this->buffer_ + size, 0x55, 6144 - size); +    for (int i = 0; i < 6144; ++i) { +        this->buffer_[i] = revTable[this->buffer_[i]]; +    } + +    // Writting data +#ifdef _WIN32 +    DWORD result; +    if(!DeviceIoControl(this->socket_, IoctlCodeTxFrame, this->buffer_, 6144, +        NULL, 0, &result, NULL)) { +            goto RAW_WRITE_ERROR; +    } +#else +    /* +    if (write(this->socket_, this->buffer_ + 1, 6143) != 6143) { +        goto RAW_WRITE_ERROR; +    } +    */ +    if (this->isCyclades_) { +        if (write(this->socket_, this->buffer_ + 1, 6143) != 6143) { +            goto RAW_WRITE_ERROR; +        } +    } else { +        int ret = send(this->socket_, this->buffer_, 6144, 0); +        if (ret != 6144) { +            fprintf(stderr, "%i/6144 bytes written\n", ret); +            goto RAW_WRITE_ERROR; +        } +    } +#endif + +    return size; + +RAW_WRITE_ERROR: +#ifdef _WIN32 +    DWORD err = GetLastError(); +    LPSTR errMsg; +    if(FormatMessage( +        FORMAT_MESSAGE_ALLOCATE_BUFFER | FORMAT_MESSAGE_FROM_SYSTEM, +        NULL, +        err, +        0, +        (LPTSTR)&errMsg, +        0, +        NULL) == 0) { +            fprintf(stderr, "Error while writting to raw socket: %i\n", err); +    } else { +        fprintf(stderr, "Error while writting to raw socket: %s\n", errMsg); +        LocalFree(errMsg); +    } +#else +    perror("Error while writting to raw socket"); +#endif + +    return -1; +} + + +int DabOutputRaw::Close() +{ +#ifdef _WIN32 +    CancelIo(this->socket_); +    CloseHandle(this->socket_); +    return 0; +#else +    if (close(this->socket_) == 0) { +        this->socket_ = -1; +        return 0; +    } +    perror("Can't close raw socket"); +#endif + +    return -1; +} + diff --git a/src/dabOutput/dabOutputSimul.cpp b/src/dabOutput/dabOutputSimul.cpp new file mode 100644 index 0000000..e53b4ba --- /dev/null +++ b/src/dabOutput/dabOutputSimul.cpp @@ -0,0 +1,70 @@ +#include "dabOutput.h" +#include <cstring> +#include <cstdio> +#include <fcntl.h> +#include <limits.h> +#ifdef _WIN32 +#   include <io.h> +#   ifdef __MINGW32__ +#       define FS_DECLARE_CFG_ARRAYS +#       include <winioctl.h> +#   endif +#   include <sdci.h> +#else +#   include <unistd.h> +#   include <sys/time.h> +#   ifndef O_BINARY +#       define O_BINARY 0 +#   endif // O_BINARY +#endif + + +int DabOutputSimul::Open(const char* name) +{ +#ifdef _WIN32 +    startTime_ = GetTickCount(); +#else +    gettimeofday(&startTime_, NULL); +#endif + +    return 0; +} + +int DabOutputSimul::Write(void* buffer, int size) +{ +    unsigned long current; +    unsigned long start; +    unsigned long waiting; + +#ifdef _WIN32 +    current = GetTickCount(); +    start = this->startTime_; +    if (current < start) { +        waiting = start - current + 24; +        Sleep(waiting); +    } else { +        waiting = 24 - (current - start); +        if ((current - start) < 24) { +            Sleep(waiting); +        } +    } +    this->startTime_ += 24; +#else +    timeval curTime; +    gettimeofday(&curTime, NULL); +    current = (1000000ul * curTime.tv_sec) + curTime.tv_usec; +    start = (1000000ul * this->startTime_.tv_sec) + this->startTime_.tv_usec; +    waiting = 24000ul - (current - start); +    if ((current - start) < 24000ul) { +        usleep(waiting); +    } + +    this->startTime_.tv_usec += 24000; +    if (this->startTime_.tv_usec >= 1000000) { +        this->startTime_.tv_usec -= 1000000; +        ++this->startTime_.tv_sec; +    } +#endif + +    return size; +} diff --git a/src/dabOutput/dabOutputTcp.cpp b/src/dabOutput/dabOutputTcp.cpp new file mode 100644 index 0000000..a3d7a5a --- /dev/null +++ b/src/dabOutput/dabOutputTcp.cpp @@ -0,0 +1,154 @@ +#include <cstring> +#include <cstdio> +#include <signal.h> +#include <limits.h> +#include "dabOutput.h" +#include "TcpServer.h" + +#ifdef _WIN32 +#   include <io.h> +#   ifdef __MINGW32__ +#       define FS_DECLARE_CFG_ARRAYS +#       include <winioctl.h> +#   endif +#   include <sdci.h> +#else +#   include <unistd.h> +#   include <sys/time.h> +#   ifndef O_BINARY +#       define O_BINARY 0 +#   endif // O_BINARY +#endif + +void* tcpThread(void* param) +{ +    TcpSocket* client; + +    DabOutputTcp* tcp = (DabOutputTcp*)param; + +    while ((client = tcp->server->accept()) != NULL) { +        etiLog.print(TcpLog::INFO, "TCP server got a new client.\n"); +        if (tcp->client != NULL) { +            delete tcp->client; +        } +        tcp->client = client; +    } +    etiLog.print(TcpLog::ERR, "TCP thread can't accept new client (%s)\n", +            inetErrDesc, inetErrMsg); + +    return NULL; +} + +int DabOutputTcp::Open(const char* name) +{ +    char* hostport = strdup(name); // the name is actually an tuple host:port + +    char* address; +    long port; +    address = strchr((char*)hostport, ':'); +    if (address == NULL) { +        etiLog.printHeader(TcpLog::ERR, +                "\"%s\" is an invalid format for tcp address: " +                "should be [address]:port - > aborting\n", +                hostport); +        goto tcp_open_fail; +    } + +    // terminate string hostport after the host, and advance address to the port number +    *(address++) = 0; + +    port = strtol(address, (char **)NULL, 10); +    if ((port == LONG_MIN) || (port == LONG_MAX)) { +        etiLog.printHeader(TcpLog::ERR, +                "can't convert port number in tcp address %s\n", address); +        goto tcp_open_fail; +    } +    if (port == 0) { +        etiLog.printHeader(TcpLog::ERR, +                "can't use port number 0 in tcp address\n"); +        goto tcp_open_fail; +    } +    address = hostport; +    if (strlen(address) > 0) { +        if (this->server->create(port, address) == -1) { +            etiLog.printHeader(TcpLog::ERR, "Can't create Tcp server on %s:%i " +                    "(%s: %s) -> aborting\n", +                    address, port, inetErrDesc, inetErrMsg); +            goto tcp_open_fail; +        } +    } else { +        if (this->server->create(port) == -1) { +            etiLog.printHeader(TcpLog::ERR, "Can't create Tcp server on :%i " +                    "(%s: %s) -> aborting\n", +                    port, inetErrDesc, inetErrMsg); +            goto tcp_open_fail; +        } +    } + +    //sprintf(name, "%s:%i", this->packet_->getAddress().getHostAddress(), +    //        this->packet_->getAddress().getPort()); + +    if (this->server->listen() == -1) { +        etiLog.printHeader(TcpLog::ERR, "Can't listen on Tcp socket (%s: %s)\n", +                inetErrDesc, inetErrMsg); +        goto tcp_open_fail; +    } +#ifdef _WIN32 +    this->thread_ = CreateThread(NULL, 0, (LPTHREAD_START_ROUTINE)tcpThread, this, 0, NULL); +    if (this->thread_ == NULL) { +        fprintf(stderr, "Can't create TCP child"); +        goto tcp_open_fail; +    } +#else +    if (pthread_create(&this->thread_, NULL, tcpThread, this)) { +        perror("Can't create TCP child"); +        goto tcp_open_fail; +    } +#endif + +    return 0; + +tcp_open_fail: +    free(hostport); +    return -1; +} + + +int DabOutputTcp::Write(void* buffer, int size) +{ + +    if (this->client != NULL) { +        if (this->client->write(&size, 2) == 2) { +            if (this->client->write(buffer, size) != size) { +                return size; +            } +        } +        else { +            etiLog.print(TcpLog::INFO, "TCP server client disconnected.\n"); +            delete this->client; +            this->client = NULL; +        } +    } +    return size; +} + + +int DabOutputTcp::Close() +{ +    this->server->close(); +    if( this->client != NULL ) +        this->client->close(); +#ifdef WIN32 +    DWORD status; +    for (int i = 0; i < 5; ++i) { +        if (GetExitCodeThread(this->thread_, &status)) { +            break; +        } +        Sleep(100); +    } +    TerminateThread(this->thread_, 1); +#else +    pthread_kill(this->thread_, SIGPIPE); +#endif +    return 0; +} diff --git a/src/dabOutput/dabOutputUdp.cpp b/src/dabOutput/dabOutputUdp.cpp new file mode 100644 index 0000000..1410071 --- /dev/null +++ b/src/dabOutput/dabOutputUdp.cpp @@ -0,0 +1,82 @@ +#include <cstring> +#include <cstdio> +#include <limits.h> +#include "dabOutput.h" +#include "UdpSocket.h" + +#ifdef _WIN32 +#   include <fscfg.h> +#   include <sdci.h> +#else +#   include <netinet/in.h> +#   include <sys/types.h> +#   include <sys/socket.h> +#   include <sys/ioctl.h> +#   include <linux/if_packet.h> +#   include <linux/netdevice.h> +#   include <net/if_arp.h> +#endif + +int DabOutputUdp::Open(const char* name) +{ +    // we are going to modify it +    char* hostport = strdup(name); // the name is actually an tuple host:port + +    char* address; +    long port; +    address = strchr(hostport, ':'); +    if (address == NULL) { +        etiLog.printHeader(TcpLog::ERR, +                "\"%s\" is an invalid format for UDP address: " +                "should be [address]:port - > aborting\n", +                hostport); +        goto udp_open_fail; +    } + +    // terminate string hostport after the host, and advance address to the port number +    *(address++) = 0; + +    port = strtol(address, (char **)NULL, 10); +    if ((port == LONG_MIN) || (port == LONG_MAX)) { +        etiLog.printHeader(TcpLog::ERR, +                "can't convert port number in UDP address %s\n", address); +        goto udp_open_fail; +    } +    if (port == 0) { +        etiLog.printHeader(TcpLog::ERR, +                "can't use port number 0 in UDP address\n"); +        goto udp_open_fail; +    } +    address = hostport; +    if (strlen(address) > 0) { +        if (this->packet_->getAddress().setAddress(address) == -1) { +            etiLog.printHeader(TcpLog::ERR, "can't set address %s (%s: %s) " +                    "-> aborting\n", address, inetErrDesc, inetErrMsg); +            goto udp_open_fail; +        } +    } +    this->packet_->getAddress().setPort(port); + +    if (this->socket_->create() == -1) { +        etiLog.printHeader(TcpLog::ERR, "can't create UDP socket (%s: %s) " +                "-> aborting\n)", inetErrDesc, inetErrMsg); +        goto udp_open_fail; +    } + +    //sprintf(hostport, "%s:%i", this->packet_->getAddress().getHostAddress(), +    //        this->packet_->getAddress().getPort()); +    return 0; + +udp_open_fail: +    // strdup forces us to free +    free(hostport); +    return -1; +} + + +int DabOutputUdp::Write(void* buffer, int size) +{ +    this->packet_->setLength(0); +    this->packet_->addData(buffer, size); +    return this->socket_->send(*this->packet_); +} diff --git a/src/utils.cpp b/src/utils.cpp index 270e7f5..9e87337 100644 --- a/src/utils.cpp +++ b/src/utils.cpp @@ -285,9 +285,9 @@ void printOutputs(vector<dabOutput*>& outputs)      for (output = outputs.begin(); output != outputs.end(); ++output) {          etiLog.printHeader(TcpLog::INFO, "Output      %i\n", index);          etiLog.printHeader(TcpLog::INFO, "  protocol: %s\n", -                (*output)->outputProto); +                (*output)->outputProto.c_str());          etiLog.printHeader(TcpLog::INFO, "  name:     %s\n", -                (*output)->outputName); +                (*output)->outputName.c_str());          ++index;      }  } | 
