diff options
| -rw-r--r-- | Makefile.am | 12 | ||||
| -rw-r--r-- | acinclude.m4 | 312 | ||||
| -rw-r--r-- | aminclude.am | 186 | ||||
| -rw-r--r-- | configure.ac | 21 | ||||
| -rw-r--r-- | doxygen.cfg | 212 | 
5 files changed, 726 insertions, 17 deletions
diff --git a/Makefile.am b/Makefile.am index f59f886..31c54c4 100644 --- a/Makefile.am +++ b/Makefile.am @@ -16,14 +16,16 @@  # License along with avahi; if not, write to the Free Software  # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307  # USA. +include aminclude.am -EXTRA_DIST = bootstrap.sh LICENSE -SUBDIRS = avahi-common avahi-core avahi-discover avahi-client avahi-daemon doxygen initscript avahi-dnsconfd +EXTRA_DIST = bootstrap.sh LICENSE $(DX_CONFIG) +SUBDIRS = avahi-common avahi-core avahi-discover avahi-client avahi-daemon initscript avahi-dnsconfd  pkgconfigdir = $(libdir)/pkgconfig  pkgconfig_DATA = avahi-core.pc -doxygen: -	$(MAKE) -C doxygen doxygen +MOSTLYCLEANFILES = $(DX_CLEANFILES) -.PHONY: distcleancheck doxygen +all: doxygen-doc + +.PHONY: distcleancheck diff --git a/acinclude.m4 b/acinclude.m4 new file mode 100644 index 0000000..e4688de --- /dev/null +++ b/acinclude.m4 @@ -0,0 +1,312 @@ +# This file is part of Autoconf.                       -*- Autoconf -*- + +# Copyright (C) 2004 Oren Ben-Kiki +# This file is distributed under the same terms as the Autoconf macro files. + +# Generate automatic documentation using Doxygen. Works in concert with the +# aminclude.m4 file and a compatible doxygen configuration file. Defines the +# following public macros: +# +# DX_???_FEATURE(ON|OFF) - control the default setting fo a Doxygen feature. +# Supported features are 'DOXYGEN' itself, 'DOT' for generating graphics, +# 'HTML' for plain HTML, 'CHM' for compressed HTML help (for MS users), 'CHI' +# for generating a seperate .chi file by the .chm file, and 'MAN', 'RTF', +# 'XML', 'PDF' and 'PS' for the appropriate output formats. The environment +# variable DOXYGEN_PAPER_SIZE may be specified to override the default 'a4wide' +# paper size. +# +# By default, HTML, PDF and PS documentation is generated as this seems to be +# the most popular and portable combination. MAN pages created by Doxygen are +# usually problematic, though by picking an appropriate subset and doing some +# massaging they might be better than nothing. CHM and RTF are specific for MS +# (note that you can't generate both HTML and CHM at the same time). The XML is +# rather useless unless you apply specialized post-processing to it. +# +# The macro mainly controls the default state of the feature. The use can +# override the default by specifying --enable or --disable. The macros ensure +# that contradictory flags are not given (e.g., --enable-doxygen-html and +# --enable-doxygen-chm, --enable-doxygen-anything with --disable-doxygen, etc.) +# Finally, each feature will be automatically disabled (with a warning) if the +# required programs are missing. +# +# Once all the feature defaults have been specified, call DX_INIT_DOXYGEN with +# the following parameters: a one-word name for the project for use as a +# filename base etc., an optional configuration file name (the default is +# 'Doxyfile', the same as Doxygen's default), and an optional output directory +# name (the default is 'doxygen-doc'). + +## ----------## +## Defaults. ## +## ----------## + +DX_ENV="" +AC_DEFUN([DX_FEATURE_doc],  ON) +AC_DEFUN([DX_FEATURE_dot],  ON) +AC_DEFUN([DX_FEATURE_man],  OFF) +AC_DEFUN([DX_FEATURE_html], ON) +AC_DEFUN([DX_FEATURE_chm],  OFF) +AC_DEFUN([DX_FEATURE_chi],  OFF) +AC_DEFUN([DX_FEATURE_rtf],  OFF) +AC_DEFUN([DX_FEATURE_xml],  OFF) +AC_DEFUN([DX_FEATURE_pdf],  ON) +AC_DEFUN([DX_FEATURE_ps],   ON) + +## --------------- ## +## Private macros. ## +## --------------- ## + +# DX_ENV_APPEND(VARIABLE, VALUE) +# ------------------------------ +# Append VARIABLE="VALUE" to DX_ENV for invoking doxygen. +AC_DEFUN([DX_ENV_APPEND], [AC_SUBST([DX_ENV], ["$DX_ENV $1='$2'"])]) + +# DX_DIRNAME_EXPR +# --------------- +# Expand into a shell expression prints the directory part of a path. +AC_DEFUN([DX_DIRNAME_EXPR], +         [[expr ".$1" : '\(\.\)[^/]*$' \| "x$1" : 'x\(.*\)/[^/]*$']]) + +# DX_IF_FEATURE(FEATURE, IF-ON, IF-OFF) +# ------------------------------------- +# Expands according to the M4 (static) status of the feature. +AC_DEFUN([DX_IF_FEATURE], [ifelse(DX_FEATURE_$1, ON, [$2], [$3])]) + +# DX_REQUIRE_PROG(VARIABLE, PROGRAM) +# ---------------------------------- +# Require the specified program to be found for the DX_CURRENT_FEATURE to work. +AC_DEFUN([DX_REQUIRE_PROG], [ +AC_PATH_TOOL([$1], [$2]) +if test "$DX_FLAG_[]DX_CURRENT_FEATURE$$1" = 1; then +    AC_MSG_WARN([$2 not found - will not DX_CURRENT_DESCRIPTION]) +    AC_SUBST([DX_FLAG_[]DX_CURRENT_FEATURE], 0) +fi +]) + +# DX_TEST_FEATURE(FEATURE) +# ------------------------ +# Expand to a shell expression testing whether the feature is active. +AC_DEFUN([DX_TEST_FEATURE], [test "$DX_FLAG_$1" = 1]) + +# DX_CHECK_DEPEND(REQUIRED_FEATURE, REQUIRED_STATE) +# ------------------------------------------------- +# Verify that a required features has the right state before trying to turn on +# the DX_CURRENT_FEATURE. +AC_DEFUN([DX_CHECK_DEPEND], [ +test "$DX_FLAG_$1" = "$2" \ +|| AC_MSG_ERROR([doxygen-DX_CURRENT_FEATURE ifelse([$2], 1, +                            requires, contradicts) doxygen-DX_CURRENT_FEATURE]) +]) + +# DX_CLEAR_DEPEND(FEATURE, REQUIRED_FEATURE, REQUIRED_STATE) +# ---------------------------------------------------------- +# Turn off the DX_CURRENT_FEATURE if the required feature is off. +AC_DEFUN([DX_CLEAR_DEPEND], [ +test "$DX_FLAG_$1" = "$2" || AC_SUBST([DX_FLAG_[]DX_CURRENT_FEATURE], 0) +]) + +# DX_FEATURE_ARG(FEATURE, DESCRIPTION, +#                CHECK_DEPEND, CLEAR_DEPEND, +#                REQUIRE, DO-IF-ON, DO-IF-OFF) +# -------------------------------------------- +# Parse the command-line option controlling a feature. CHECK_DEPEND is called +# if the user explicitly turns the feature on (and invokes DX_CHECK_DEPEND), +# otherwise CLEAR_DEPEND is called to turn off the default state if a required +# feature is disabled (using DX_CLEAR_DEPEND). REQUIRE performs additional +# requirement tests (DX_REQUIRE_PROG). Finally, an automake flag is set and +# DO-IF-ON or DO-IF-OFF are called according to the final state of the feature. +AC_DEFUN([DX_ARG_ABLE], [ +    AC_DEFUN([DX_CURRENT_FEATURE], [$1]) +    AC_DEFUN([DX_CURRENT_DESCRIPTION], [$2]) +    AC_ARG_ENABLE(doxygen-$1, +                  [AS_HELP_STRING(DX_IF_FEATURE([$1], [--disable-doxygen-$1], +                                                      [--enable-doxygen-$1]), +                                  DX_IF_FEATURE([$1], [don't $2], [$2]))], +                  [ +case "$enableval" in +#( +y|Y|yes|Yes|YES) +    AC_SUBST([DX_FLAG_$1], 1) +    $3 +;; #( +n|N|no|No|NO) +    AC_SUBST([DX_FLAG_$1], 0) +;; #( +*) +    AC_MSG_ERROR([invalid value '$enableval' given to doxygen-$1]) +;; +esac +], [ +AC_SUBST([DX_FLAG_$1], [DX_IF_FEATURE([$1], 1, 0)]) +$4 +]) +if DX_TEST_FEATURE([$1]); then +    $5 +    : +fi +if DX_TEST_FEATURE([$1]); then +    AM_CONDITIONAL(DX_COND_$1, :) +    $6 +    : +else +    AM_CONDITIONAL(DX_COND_$1, false) +    $7 +    : +fi +]) + +## -------------- ## +## Public macros. ## +## -------------- ## + +# DX_XXX_FEATURE(DEFAULT_STATE) +# ----------------------------- +AC_DEFUN([DX_DOXYGEN_FEATURE], [AC_DEFUN([DX_FEATURE_doc],  [$1])]) +AC_DEFUN([DX_MAN_FEATURE],     [AC_DEFUN([DX_FEATURE_man],  [$1])]) +AC_DEFUN([DX_HTML_FEATURE],    [AC_DEFUN([DX_FEATURE_html], [$1])]) +AC_DEFUN([DX_CHM_FEATURE],     [AC_DEFUN([DX_FEATURE_chm],  [$1])]) +AC_DEFUN([DX_CHI_FEATURE],     [AC_DEFUN([DX_FEATURE_chi],  [$1])]) +AC_DEFUN([DX_RTF_FEATURE],     [AC_DEFUN([DX_FEATURE_rtf],  [$1])]) +AC_DEFUN([DX_XML_FEATURE],     [AC_DEFUN([DX_FEATURE_xml],  [$1])]) +AC_DEFUN([DX_XML_FEATURE],     [AC_DEFUN([DX_FEATURE_xml],  [$1])]) +AC_DEFUN([DX_PDF_FEATURE],     [AC_DEFUN([DX_FEATURE_pdf],  [$1])]) +AC_DEFUN([DX_PS_FEATURE],      [AC_DEFUN([DX_FEATURE_ps],   [$1])]) + +# DX_INIT_DOXYGEN(PROJECT, [CONFIG-FILE], [OUTPUT-DOC-DIR]) +# --------------------------------------------------------- +# PROJECT also serves as the base name for the documentation files. +# The default CONFIG-FILE is "Doxyfile" and OUTPUT-DOC-DIR is "doxygen-doc". +AC_DEFUN([DX_INIT_DOXYGEN], [ + +# Files: +AC_SUBST([DX_PROJECT], [$1]) +AC_SUBST([DX_CONFIG], [ifelse([$2], [], Doxyfile, [$2])]) +AC_SUBST([DX_DOCDIR], [ifelse([$3], [], doxygen-doc, [$3])]) + +# Environment variables used inside doxygen.cfg: +DX_ENV_APPEND(SRCDIR, $srcdir) +DX_ENV_APPEND(PROJECT, $DX_PROJECT) +DX_ENV_APPEND(DOCDIR, $DX_DOCDIR) +DX_ENV_APPEND(VERSION, $PACKAGE_VERSION) + +# Doxygen itself: +DX_ARG_ABLE(doc, [generate any doxygen documentation], +            [], +            [], +            [DX_REQUIRE_PROG([DX_DOXYGEN], doxygen) +             DX_REQUIRE_PROG([DX_PERL], perl)], +            [DX_ENV_APPEND(PERL_PATH, $DX_PERL)]) + +# Dot for graphics: +DX_ARG_ABLE(dot, [generate graphics for doxygen documentation], +            [DX_CHECK_DEPEND(doc, 1)], +            [DX_CLEAR_DEPEND(doc, 1)], +            [DX_REQUIRE_PROG([DX_DOT], dot)], +            [DX_ENV_APPEND(HAVE_DOT, YES) +             DX_ENV_APPEND(DOT_PATH, [`DX_DIRNAME_EXPR($DX_DOT)`])], +            [DX_ENV_APPEND(HAVE_DOT, NO)]) + +# Man pages generation: +DX_ARG_ABLE(man, [generate doxygen manual pages], +            [DX_CHECK_DEPEND(doc, 1)], +            [DX_CLEAR_DEPEND(doc, 1)], +            [], +            [DX_ENV_APPEND(GENERATE_MAN, YES)], +            [DX_ENV_APPEND(GENERATE_MAN, NO)]) + +# RTF file generation: +DX_ARG_ABLE(rtf, [generate doxygen RTF documentation], +            [DX_CHECK_DEPEND(doc, 1)], +            [DX_CLEAR_DEPEND(doc, 1)], +            [], +            [DX_ENV_APPEND(GENERATE_RTF, YES)], +            [DX_ENV_APPEND(GENERATE_RTF, NO)]) + +# XML file generation: +DX_ARG_ABLE(xml, [generate doxygen XML documentation], +            [DX_CHECK_DEPEND(doc, 1)], +            [DX_CLEAR_DEPEND(doc, 1)], +            [], +            [DX_ENV_APPEND(GENERATE_XML, YES)], +            [DX_ENV_APPEND(GENERATE_XML, NO)]) + +# (Compressed) HTML help generation: +DX_ARG_ABLE(chm, [generate doxygen compressed HTML help documentation], +            [DX_CHECK_DEPEND(doc, 1)], +            [DX_CLEAR_DEPEND(doc, 1)], +            [DX_REQUIRE_PROG([DX_HHC], hhc)], +            [DX_ENV_APPEND(HHC_PATH, $DX_HHC) +             DX_ENV_APPEND(GENERATE_HTML, YES) +             DX_ENV_APPEND(GENERATE_HTMLHELP, YES)], +            [DX_ENV_APPEND(GENERATE_HTMLHELP, NO)]) + +# Seperate CHI file generation. +DX_ARG_ABLE(chi, [generate doxygen seperate compressed HTML help index file], +            [DX_CHECK_DEPEND(chm, 1)], +            [DX_CLEAR_DEPEND(chm, 1)], +            [], +            [DX_ENV_APPEND(GENERATE_CHI, YES)], +            [DX_ENV_APPEND(GENERATE_CHI, NO)]) + +# Plain HTML pages generation: +DX_ARG_ABLE(html, [generate doxygen plain HTML documentation], +            [DX_CHECK_DEPEND(doc, 1) DX_CHECK_DEPEND(chm, 0)], +            [DX_CLEAR_DEPEND(doc, 1) DX_CLEAR_DEPEND(chm, 0)], +            [], +            [DX_ENV_APPEND(GENERATE_HTML, YES)], +            [DX_TEST_FEATURE(chm) || DX_ENV_APPEND(GENERATE_HTML, NO)]) + +# PostScript file generation: +DX_ARG_ABLE(ps, [generate doxygen PostScript documentation], +            [DX_CHECK_DEPEND(doc, 1)], +            [DX_CLEAR_DEPEND(doc, 1)], +            [DX_REQUIRE_PROG([DX_LATEX], latex) +             DX_REQUIRE_PROG([DX_MAKEINDEX], makeindex) +             DX_REQUIRE_PROG([DX_DVIPS], dvips) +             DX_REQUIRE_PROG([DX_EGREP], egrep)]) + +# PDF file generation: +DX_ARG_ABLE(pdf, [generate doxygen PDF documentation], +            [DX_CHECK_DEPEND(doc, 1)], +            [DX_CLEAR_DEPEND(doc, 1)], +            [DX_REQUIRE_PROG([DX_PDFLATEX], pdflatex) +             DX_REQUIRE_PROG([DX_MAKEINDEX], makeindex) +             DX_REQUIRE_PROG([DX_EGREP], egrep)]) + +# LaTeX generation for PS and/or PDF: +if DX_TEST_FEATURE(ps) || DX_TEST_FEATURE(pdf); then +    AM_CONDITIONAL(DX_COND_latex, :) +    DX_ENV_APPEND(GENERATE_LATEX, YES) +else +    AM_CONDITIONAL(DX_COND_latex, false) +    DX_ENV_APPEND(GENERATE_LATEX, NO) +fi + +# Paper size for PS and/or PDF: +AC_ARG_VAR(DOXYGEN_PAPER_SIZE, +           [a4wide (default), a4, letter, legal or executive]) +case "$DOXYGEN_PAPER_SIZE" in +#( +"") +    AC_SUBST(DOXYGEN_PAPER_SIZE, "") +;; #( +a4wide|a4|letter|legal|executive) +    DX_ENV_APPEND(PAPER_SIZE, $DOXYGEN_PAPER_SIZE) +;; #( +*) +    AC_MSG_ERROR([unknown DOXYGEN_PAPER_SIZE='$DOXYGEN_PAPER_SIZE']) +;; +esac + +#For debugging: +#echo DX_FLAG_doc=$DX_FLAG_doc +#echo DX_FLAG_dot=$DX_FLAG_dot +#echo DX_FLAG_man=$DX_FLAG_man +#echo DX_FLAG_html=$DX_FLAG_html +#echo DX_FLAG_chm=$DX_FLAG_chm +#echo DX_FLAG_chi=$DX_FLAG_chi +#echo DX_FLAG_rtf=$DX_FLAG_rtf +#echo DX_FLAG_xml=$DX_FLAG_xml +#echo DX_FLAG_pdf=$DX_FLAG_pdf +#echo DX_FLAG_ps=$DX_FLAG_ps +#echo DX_ENV=$DX_ENV +]) diff --git a/aminclude.am b/aminclude.am new file mode 100644 index 0000000..420049e --- /dev/null +++ b/aminclude.am @@ -0,0 +1,186 @@ +# Copyright (C) 2004 Oren Ben-Kiki +# This file is distributed under the same terms as the Automake macro files. + +# Generate automatic documentation using Doxygen. Goals and variables values +# are controlled by the various DX_COND_??? conditionals set by autoconf. +# +# The provided goals are: +# doxygen-doc: Generate all doxygen documentation. +# doxygen-run: Run doxygen, which will generate some of the documentation +#              (HTML, CHM, CHI, MAN, RTF, XML) but will not do the post +#              processing required for the rest of it (PS, PDF, and some MAN). +# doxygen-man: Rename some doxygen generated man pages. +# doxygen-ps: Generate doxygen PostScript documentation. +# doxygen-pdf: Generate doxygen PDF documentation. +# +# Note that by default these are not integrated into the automake goals. If +# doxygen is used to generate man pages, you can achieve this integration by +# setting man3_MANS to the list of man pages generated and then adding the +# dependency: +# +#   $(man3_MANS): doxygen-doc +# +# This will cause make to run doxygen and generate all the documentation. +# +# The following variable is intended for use in Makefile.am: +# +# DX_CLEANFILES = everything to clean. +# +# This is usually added to MOSTLYCLEANFILES. + +## --------------------------------- ## +## Format-independent Doxygen rules. ## +## --------------------------------- ## + +if DX_COND_doc + +## ------------------------------- ## +## Rules specific for HTML output. ## +## ------------------------------- ## + +if DX_COND_html + +DX_CLEAN_HTML = @DX_DOCDIR@/html + +endif DX_COND_html + +## ------------------------------ ## +## Rules specific for CHM output. ## +## ------------------------------ ## + +if DX_COND_chm + +DX_CLEAN_CHM = @DX_DOCDIR@/chm + +if DX_COND_chi + +DX_CLEAN_CHI = @DX_DOCDIR@/@PACKAGE@.chi + +endif DX_COND_chi + +endif DX_COND_chm + +## ------------------------------ ## +## Rules specific for MAN output. ## +## ------------------------------ ## + +if DX_COND_man + +DX_CLEAN_MAN = @DX_DOCDIR@/man + +endif DX_COND_man + +## ------------------------------ ## +## Rules specific for RTF output. ## +## ------------------------------ ## + +if DX_COND_rtf + +DX_CLEAN_RTF = @DX_DOCDIR@/rtf + +endif DX_COND_rtf + +## ------------------------------ ## +## Rules specific for XML output. ## +## ------------------------------ ## + +if DX_COND_xml + +DX_CLEAN_XML = @DX_DOCDIR@/xml + +endif DX_COND_xml + +## ----------------------------- ## +## Rules specific for PS output. ## +## ----------------------------- ## + +if DX_COND_ps + +DX_CLEAN_PS = @DX_DOCDIR@/@PACKAGE@.ps + +DX_PS_GOAL = doxygen-ps + +doxygen-ps: @DX_DOCDIR@/@PACKAGE@.ps + +@DX_DOCDIR@/@PACKAGE@.ps: @DX_DOCDIR@/@PACKAGE@.tag +	cd @DX_DOCDIR@/latex; \ +	rm -f *.aux *.toc *.idx *.ind *.ilg *.log *.out; \ +	$(DX_LATEX) refman.tex; \ +	$(MAKEINDEX_PATH) refman.idx; \ +	$(DX_LATEX) refman.tex; \ +	countdown=5; \ +	while $(DX_EGREP) 'Rerun (LaTeX|to get cross-references right)' \ +	                  refman.log > /dev/null 2>&1 \ +	   && test $$countdown -gt 0; do \ +	    $(DX_LATEX) refman.tex; \ +	    countdown=`expr $$countdown - 1`; \ +	done; \ +	$(DX_DVIPS) -o ../@PACKAGE@.ps refman.dvi + +endif DX_COND_ps + +## ------------------------------ ## +## Rules specific for PDF output. ## +## ------------------------------ ## + +if DX_COND_pdf + +DX_CLEAN_PDF = @DX_DOCDIR@/@PACKAGE@.pdf + +DX_PDF_GOAL = doxygen-pdf + +doxygen-pdf: @DX_DOCDIR@/@PACKAGE@.pdf + +@DX_DOCDIR@/@PACKAGE@.pdf: @DX_DOCDIR@/@PACKAGE@.tag +	cd @DX_DOCDIR@/latex; \ +	rm -f *.aux *.toc *.idx *.ind *.ilg *.log *.out; \ +	$(DX_PDFLATEX) refman.tex; \ +	$(DX_MAKEINDEX) refman.idx; \ +	$(DX_PDFLATEX) refman.tex; \ +	countdown=5; \ +	while $(DX_EGREP) 'Rerun (LaTeX|to get cross-references right)' \ +	                  refman.log > /dev/null 2>&1 \ +	   && test $$countdown -gt 0; do \ +	    $(DX_PDFLATEX) refman.tex; \ +	    countdown=`expr $$countdown - 1`; \ +	done; \ +	mv refman.pdf ../@PACKAGE@.pdf + +endif DX_COND_pdf + +## ------------------------------------------------- ## +## Rules specific for LaTeX (shared for PS and PDF). ## +## ------------------------------------------------- ## + +if DX_COND_latex + +DX_CLEAN_LATEX = @DX_DOCDIR@/latex + +endif DX_COND_latex + +.PHONY: doxygen-run doxygen-doc $(DX_PS_GOAL) $(DX_PDF_GOAL) + +.INTERMEDIATE: doxygen-run $(DX_PS_GOAL) $(DX_PDF_GOAL) + +doxygen-run: @DX_DOCDIR@/@PACKAGE@.tag + +doxygen-doc: doxygen-run $(DX_PS_GOAL) $(DX_PDF_GOAL) + +@DX_DOCDIR@/@PACKAGE@.tag: $(DX_CONFIG) $(pkginclude_HEADERS) +	rm -rf @DX_DOCDIR@ +	$(DX_ENV) $(DX_DOXYGEN) $(srcdir)/$(DX_CONFIG) + +DX_CLEANFILES = \ +    @DX_DOCDIR@/@PACKAGE@.tag \ +    -r \ +    $(DX_CLEAN_HTML) \ +    $(DX_CLEAN_CHM) \ +    $(DX_CLEAN_CHI) \ +    $(DX_CLEAN_MAN) \ +    $(DX_CLEAN_RTF) \ +    $(DX_CLEAN_XML) \ +    $(DX_CLEAN_PS) \ +    $(DX_CLEAN_PDF) \ +    $(DX_CLEAN_LATEX) + +endif DX_COND_doc diff --git a/configure.ac b/configure.ac index e64fcde..e162452 100644 --- a/configure.ac +++ b/configure.ac @@ -96,16 +96,15 @@ if test "x$ENABLE_GTK" = "xyes"; then  fi  AM_CONDITIONAL(ENABLE_GTK, test "x$ENABLE_GTK" = "xyes") -AC_ARG_ENABLE(doxygen, -        AC_HELP_STRING([--enable-doxygen],[use doxygen to generate API docs (default=yes)]), -        [case "${enableval}" in -                yes) ENABLE_DOXYGEN=yes ;; -                no)  ENABLE_DOXYGEN=no ;; -                *) AC_MSG_ERROR(bad value ${enableval} for --enable-gtk) ;; -        esac], -        [ENABLE_DOXYGEN=yes]) dnl Default value - -AM_CONDITIONAL(ENABLE_DOXYGEN, test "x$ENABLE_DOXYGEN" = "xyes") +DX_HTML_FEATURE(ON) +DX_CHM_FEATURE(OFF) +DX_CHI_FEATURE(OFF) +DX_MAN_FEATURE(OFF) +DX_RTF_FEATURE(OFF) +DX_XML_FEATURE(OFF) +DX_PDF_FEATURE(ON) +DX_PS_FEATURE(OFF) +DX_INIT_DOXYGEN(avahi, doxygen.cfg, doxygen-doc)  AC_ARG_ENABLE(dbus,          AC_HELP_STRING([--enable-dbus],[use DBus (default=yes)]), @@ -220,8 +219,6 @@ AC_SUBST(avahi_socket)  AC_CONFIG_FILES([  Makefile   avahi-core.pc  -doxygen/Makefile  -doxygen/doxygen.conf   avahi-common/Makefile   avahi-core/Makefile   avahi-daemon/Makefile  diff --git a/doxygen.cfg b/doxygen.cfg new file mode 100644 index 0000000..a751c6a --- /dev/null +++ b/doxygen.cfg @@ -0,0 +1,212 @@ +# Doxyfile 1.3.7 + +#--------------------------------------------------------------------------- +# Project related configuration options +#--------------------------------------------------------------------------- +PROJECT_NAME           = $(PROJECT) +PROJECT_NUMBER         = $(VERSION) +OUTPUT_DIRECTORY       = $(DOCDIR) +CREATE_SUBDIRS         = NO +OUTPUT_LANGUAGE        = English +USE_WINDOWS_ENCODING   = NO +BRIEF_MEMBER_DESC      = YES +REPEAT_BRIEF           = YES +ABBREVIATE_BRIEF       =  +ALWAYS_DETAILED_SEC    = NO +INLINE_INHERITED_MEMB  = NO +STRIP_FROM_INC_PATH    = $(SRCDIR) +FULL_PATH_NAMES        = YES +STRIP_FROM_PATH        = $(SRCDIR) +SHORT_NAMES            = NO +JAVADOC_AUTOBRIEF      = YES +MULTILINE_CPP_IS_BRIEF = NO +DETAILS_AT_TOP         = YES +INHERIT_DOCS           = YES +DISTRIBUTE_GROUP_DOC   = NO +TAB_SIZE               = 8 +ALIASES                =  +OPTIMIZE_OUTPUT_FOR_C  = YES +OPTIMIZE_OUTPUT_JAVA   = NO +SUBGROUPING            = YES +#--------------------------------------------------------------------------- +# Build related configuration options +#--------------------------------------------------------------------------- +EXTRACT_ALL            = YES +EXTRACT_PRIVATE        = NO +EXTRACT_STATIC         = NO +EXTRACT_LOCAL_CLASSES  = YES +EXTRACT_LOCAL_METHODS  = NO +HIDE_UNDOC_MEMBERS     = NO +HIDE_UNDOC_CLASSES     = NO +HIDE_FRIEND_COMPOUNDS  = NO +HIDE_IN_BODY_DOCS      = NO +INTERNAL_DOCS          = NO +CASE_SENSE_NAMES       = NO +HIDE_SCOPE_NAMES       = NO +SHOW_INCLUDE_FILES     = YES +INLINE_INFO            = YES +SORT_MEMBER_DOCS       = YES +SORT_BRIEF_DOCS        = NO +SORT_BY_SCOPE_NAME     = NO +GENERATE_TODOLIST      = YES +GENERATE_TESTLIST      = YES +GENERATE_BUGLIST       = YES +GENERATE_DEPRECATEDLIST= YES +ENABLED_SECTIONS       =  +MAX_INITIALIZER_LINES  = 30 +SHOW_USED_FILES        = YES +#--------------------------------------------------------------------------- +# configuration options related to warning and progress messages +#--------------------------------------------------------------------------- +QUIET                  = YES +WARNINGS               = YES +WARN_IF_UNDOCUMENTED   = YES +WARN_IF_DOC_ERROR      = YES +WARN_FORMAT            = "$file:$line: $text" +WARN_LOGFILE           =  +#--------------------------------------------------------------------------- +# configuration options related to the input files +#--------------------------------------------------------------------------- +INPUT                  = $(SRCDIR)/avahi-common/cdecl.h $(SRCDIR)/avahi-core/core.h $(SRCDIR)/avahi-common/address.h $(SRCDIR)/avahi-common/rr.h $(SRCDIR)/avahi-common/strlst.h $(SRCDIR)/avahi-common/alternative.h $(SRCDIR)/avahi-core/log.h +FILE_PATTERNS          = +RECURSIVE              = NO +EXCLUDE                =  +EXCLUDE_SYMLINKS       = NO +EXCLUDE_PATTERNS       =  +EXAMPLE_PATH           = $(SRCDIR) +EXAMPLE_PATTERNS       =  +EXAMPLE_RECURSIVE      = NO +IMAGE_PATH             =  +INPUT_FILTER           =  +FILTER_SOURCE_FILES    = NO +#--------------------------------------------------------------------------- +# configuration options related to source browsing +#--------------------------------------------------------------------------- +SOURCE_BROWSER         = NO +INLINE_SOURCES         = NO +STRIP_CODE_COMMENTS    = YES +REFERENCED_BY_RELATION = YES +REFERENCES_RELATION    = YES +VERBATIM_HEADERS       = YES +#--------------------------------------------------------------------------- +# configuration options related to the alphabetical class index +#--------------------------------------------------------------------------- +ALPHABETICAL_INDEX     = NO +COLS_IN_ALPHA_INDEX    = 5 +IGNORE_PREFIX          =  +#--------------------------------------------------------------------------- +# configuration options related to the HTML output +#--------------------------------------------------------------------------- +GENERATE_HTML          = $(GENERATE_HTML) +HTML_OUTPUT            = html +HTML_FILE_EXTENSION    = .html +HTML_HEADER            =  +HTML_FOOTER            =  +HTML_STYLESHEET        =  +HTML_ALIGN_MEMBERS     = YES +GENERATE_HTMLHELP      = $(GENERATE_CHM) +CHM_FILE               = ../$(PROJECT).chm +HHC_LOCATION           = $(HHC_PATH) +GENERATE_CHI           = $(GENERATE_CHI) +BINARY_TOC             = NO +TOC_EXPAND             = NO +DISABLE_INDEX          = NO +ENUM_VALUES_PER_LINE   = 4 +GENERATE_TREEVIEW      = YES +TREEVIEW_WIDTH         = 250 +#--------------------------------------------------------------------------- +# configuration options related to the LaTeX output +#--------------------------------------------------------------------------- +GENERATE_LATEX         = $(GENERATE_LATEX) +LATEX_OUTPUT           = latex +LATEX_CMD_NAME         = latex +MAKEINDEX_CMD_NAME     = makeindex +COMPACT_LATEX          = NO +PAPER_TYPE             = $(PAPER_SIZE) +EXTRA_PACKAGES         =  +LATEX_HEADER           =  +PDF_HYPERLINKS         = NO +USE_PDFLATEX           = NO +LATEX_BATCHMODE        = YES +LATEX_HIDE_INDICES     = NO +#--------------------------------------------------------------------------- +# configuration options related to the RTF output +#--------------------------------------------------------------------------- +GENERATE_RTF           = $(GENERATE_RTF) +RTF_OUTPUT             = rtf +COMPACT_RTF            = NO +RTF_HYPERLINKS         = NO +RTF_STYLESHEET_FILE    =  +RTF_EXTENSIONS_FILE    =  +#--------------------------------------------------------------------------- +# configuration options related to the man page output +#--------------------------------------------------------------------------- +GENERATE_MAN           = $(GENERATE_MAN) +MAN_OUTPUT             = man +MAN_EXTENSION          = .1 +MAN_LINKS              = NO +#--------------------------------------------------------------------------- +# configuration options related to the XML output +#--------------------------------------------------------------------------- +GENERATE_XML           = $(GENERATE_XML) +XML_OUTPUT             = xml +XML_SCHEMA             =  +XML_DTD                =  +XML_PROGRAMLISTING     = YES +#--------------------------------------------------------------------------- +# configuration options for the AutoGen Definitions output +#--------------------------------------------------------------------------- +GENERATE_AUTOGEN_DEF   = NO +#--------------------------------------------------------------------------- +# configuration options related to the Perl module output +#--------------------------------------------------------------------------- +GENERATE_PERLMOD       = NO +PERLMOD_LATEX          = NO +PERLMOD_PRETTY         = YES +PERLMOD_MAKEVAR_PREFIX =  +#--------------------------------------------------------------------------- +# Configuration options related to the preprocessor    +#--------------------------------------------------------------------------- +ENABLE_PREPROCESSING   = YES +MACRO_EXPANSION        = NO +EXPAND_ONLY_PREDEF     = NO +SEARCH_INCLUDES        = YES +INCLUDE_PATH           =  +INCLUDE_FILE_PATTERNS  =  +PREDEFINED             =  +EXPAND_AS_DEFINED      =  +SKIP_FUNCTION_MACROS   = YES +#--------------------------------------------------------------------------- +# Configuration::additions related to external references    +#--------------------------------------------------------------------------- +TAGFILES               =  +GENERATE_TAGFILE       = $(DOCDIR)/$(PROJECT).tag +ALLEXTERNALS           = NO +EXTERNAL_GROUPS        = YES +PERL_PATH              = $(PERL_PATH) +#--------------------------------------------------------------------------- +# Configuration options related to the dot tool    +#--------------------------------------------------------------------------- +CLASS_DIAGRAMS         = YES +HIDE_UNDOC_RELATIONS   = YES +HAVE_DOT               = $(HAVE_DOT) +CLASS_GRAPH            = YES +COLLABORATION_GRAPH    = YES +UML_LOOK               = NO +TEMPLATE_RELATIONS     = NO +INCLUDE_GRAPH          = YES +INCLUDED_BY_GRAPH      = YES +CALL_GRAPH             = NO +GRAPHICAL_HIERARCHY    = YES +DOT_IMAGE_FORMAT       = png +DOT_PATH               = $(DOT_PATH) +DOTFILE_DIRS           =  +MAX_DOT_GRAPH_WIDTH    = 1024 +MAX_DOT_GRAPH_HEIGHT   = 1024 +MAX_DOT_GRAPH_DEPTH    = 0 +GENERATE_LEGEND        = YES +DOT_CLEANUP            = YES +#--------------------------------------------------------------------------- +# Configuration::additions related to the search engine    +#--------------------------------------------------------------------------- +SEARCHENGINE           = NO  | 
