1*a466cc55SCy Schubert# =========================================================================== 2*a466cc55SCy Schubert# https://www.gnu.org/software/autoconf-archive/ax_prog_doxygen.html 3*a466cc55SCy Schubert# =========================================================================== 4*a466cc55SCy Schubert# 5*a466cc55SCy Schubert# SYNOPSIS 6*a466cc55SCy Schubert# 7*a466cc55SCy Schubert# DX_INIT_DOXYGEN(PROJECT-NAME, [DOXYFILE-PATH], [OUTPUT-DIR], ...) 8*a466cc55SCy Schubert# DX_DOXYGEN_FEATURE(ON|OFF) 9*a466cc55SCy Schubert# DX_DOT_FEATURE(ON|OFF) 10*a466cc55SCy Schubert# DX_HTML_FEATURE(ON|OFF) 11*a466cc55SCy Schubert# DX_CHM_FEATURE(ON|OFF) 12*a466cc55SCy Schubert# DX_CHI_FEATURE(ON|OFF) 13*a466cc55SCy Schubert# DX_MAN_FEATURE(ON|OFF) 14*a466cc55SCy Schubert# DX_RTF_FEATURE(ON|OFF) 15*a466cc55SCy Schubert# DX_XML_FEATURE(ON|OFF) 16*a466cc55SCy Schubert# DX_PDF_FEATURE(ON|OFF) 17*a466cc55SCy Schubert# DX_PS_FEATURE(ON|OFF) 18*a466cc55SCy Schubert# 19*a466cc55SCy Schubert# DESCRIPTION 20*a466cc55SCy Schubert# 21*a466cc55SCy Schubert# The DX_*_FEATURE macros control the default setting for the given 22*a466cc55SCy Schubert# Doxygen feature. Supported features are 'DOXYGEN' itself, 'DOT' for 23*a466cc55SCy Schubert# generating graphics, 'HTML' for plain HTML, 'CHM' for compressed HTML 24*a466cc55SCy Schubert# help (for MS users), 'CHI' for generating a separate .chi file by the 25*a466cc55SCy Schubert# .chm file, and 'MAN', 'RTF', 'XML', 'PDF' and 'PS' for the appropriate 26*a466cc55SCy Schubert# output formats. The environment variable DOXYGEN_PAPER_SIZE may be 27*a466cc55SCy Schubert# specified to override the default 'a4wide' paper size. 28*a466cc55SCy Schubert# 29*a466cc55SCy Schubert# By default, HTML, PDF and PS documentation is generated as this seems to 30*a466cc55SCy Schubert# be the most popular and portable combination. MAN pages created by 31*a466cc55SCy Schubert# Doxygen are usually problematic, though by picking an appropriate subset 32*a466cc55SCy Schubert# and doing some massaging they might be better than nothing. CHM and RTF 33*a466cc55SCy Schubert# are specific for MS (note that you can't generate both HTML and CHM at 34*a466cc55SCy Schubert# the same time). The XML is rather useless unless you apply specialized 35*a466cc55SCy Schubert# post-processing to it. 36*a466cc55SCy Schubert# 37*a466cc55SCy Schubert# The macros mainly control the default state of the feature. The use can 38*a466cc55SCy Schubert# override the default by specifying --enable or --disable. The macros 39*a466cc55SCy Schubert# ensure that contradictory flags are not given (e.g., 40*a466cc55SCy Schubert# --enable-doxygen-html and --enable-doxygen-chm, 41*a466cc55SCy Schubert# --enable-doxygen-anything with --disable-doxygen, etc.) Finally, each 42*a466cc55SCy Schubert# feature will be automatically disabled (with a warning) if the required 43*a466cc55SCy Schubert# programs are missing. 44*a466cc55SCy Schubert# 45*a466cc55SCy Schubert# Once all the feature defaults have been specified, call DX_INIT_DOXYGEN 46*a466cc55SCy Schubert# with the following parameters: a one-word name for the project for use 47*a466cc55SCy Schubert# as a filename base etc., an optional configuration file name (the 48*a466cc55SCy Schubert# default is '$(srcdir)/Doxyfile', the same as Doxygen's default), and an 49*a466cc55SCy Schubert# optional output directory name (the default is 'doxygen-doc'). To run 50*a466cc55SCy Schubert# doxygen multiple times for different configuration files and output 51*a466cc55SCy Schubert# directories provide more parameters: the second, forth, sixth, etc 52*a466cc55SCy Schubert# parameter are configuration file names and the third, fifth, seventh, 53*a466cc55SCy Schubert# etc parameter are output directories. No checking is done to catch 54*a466cc55SCy Schubert# duplicates. 55*a466cc55SCy Schubert# 56*a466cc55SCy Schubert# Automake Support 57*a466cc55SCy Schubert# 58*a466cc55SCy Schubert# The DX_RULES substitution can be used to add all needed rules to the 59*a466cc55SCy Schubert# Makefile. Note that this is a substitution without being a variable: 60*a466cc55SCy Schubert# only the @DX_RULES@ syntax will work. 61*a466cc55SCy Schubert# 62*a466cc55SCy Schubert# The provided targets are: 63*a466cc55SCy Schubert# 64*a466cc55SCy Schubert# doxygen-doc: Generate all doxygen documentation. 65*a466cc55SCy Schubert# 66*a466cc55SCy Schubert# doxygen-run: Run doxygen, which will generate some of the 67*a466cc55SCy Schubert# documentation (HTML, CHM, CHI, MAN, RTF, XML) 68*a466cc55SCy Schubert# but will not do the post processing required 69*a466cc55SCy Schubert# for the rest of it (PS, PDF). 70*a466cc55SCy Schubert# 71*a466cc55SCy Schubert# doxygen-ps: Generate doxygen PostScript documentation. 72*a466cc55SCy Schubert# 73*a466cc55SCy Schubert# doxygen-pdf: Generate doxygen PDF documentation. 74*a466cc55SCy Schubert# 75*a466cc55SCy Schubert# Note that by default these are not integrated into the automake targets. 76*a466cc55SCy Schubert# If doxygen is used to generate man pages, you can achieve this 77*a466cc55SCy Schubert# integration by setting man3_MANS to the list of man pages generated and 78*a466cc55SCy Schubert# then adding the dependency: 79*a466cc55SCy Schubert# 80*a466cc55SCy Schubert# $(man3_MANS): doxygen-doc 81*a466cc55SCy Schubert# 82*a466cc55SCy Schubert# This will cause make to run doxygen and generate all the documentation. 83*a466cc55SCy Schubert# 84*a466cc55SCy Schubert# The following variable is intended for use in Makefile.am: 85*a466cc55SCy Schubert# 86*a466cc55SCy Schubert# DX_CLEANFILES = everything to clean. 87*a466cc55SCy Schubert# 88*a466cc55SCy Schubert# Then add this variable to MOSTLYCLEANFILES. 89*a466cc55SCy Schubert# 90*a466cc55SCy Schubert# LICENSE 91*a466cc55SCy Schubert# 92*a466cc55SCy Schubert# Copyright (c) 2009 Oren Ben-Kiki <oren@ben-kiki.org> 93*a466cc55SCy Schubert# Copyright (c) 2015 Olaf Mandel <olaf@mandel.name> 94*a466cc55SCy Schubert# 95*a466cc55SCy Schubert# Copying and distribution of this file, with or without modification, are 96*a466cc55SCy Schubert# permitted in any medium without royalty provided the copyright notice 97*a466cc55SCy Schubert# and this notice are preserved. This file is offered as-is, without any 98*a466cc55SCy Schubert# warranty. 99*a466cc55SCy Schubert 100*a466cc55SCy Schubert#serial 24 101*a466cc55SCy Schubert 102*a466cc55SCy Schubert## ----------## 103*a466cc55SCy Schubert## Defaults. ## 104*a466cc55SCy Schubert## ----------## 105*a466cc55SCy Schubert 106*a466cc55SCy SchubertDX_ENV="" 107*a466cc55SCy SchubertAC_DEFUN([DX_FEATURE_doc], OFF) 108*a466cc55SCy SchubertAC_DEFUN([DX_FEATURE_dot], OFF) 109*a466cc55SCy SchubertAC_DEFUN([DX_FEATURE_man], OFF) 110*a466cc55SCy SchubertAC_DEFUN([DX_FEATURE_html], ON) 111*a466cc55SCy SchubertAC_DEFUN([DX_FEATURE_chm], OFF) 112*a466cc55SCy SchubertAC_DEFUN([DX_FEATURE_chi], OFF) 113*a466cc55SCy SchubertAC_DEFUN([DX_FEATURE_rtf], OFF) 114*a466cc55SCy SchubertAC_DEFUN([DX_FEATURE_xml], OFF) 115*a466cc55SCy SchubertAC_DEFUN([DX_FEATURE_pdf], ON) 116*a466cc55SCy SchubertAC_DEFUN([DX_FEATURE_ps], ON) 117*a466cc55SCy Schubert 118*a466cc55SCy Schubert## --------------- ## 119*a466cc55SCy Schubert## Private macros. ## 120*a466cc55SCy Schubert## --------------- ## 121*a466cc55SCy Schubert 122*a466cc55SCy Schubert# DX_ENV_APPEND(VARIABLE, VALUE) 123*a466cc55SCy Schubert# ------------------------------ 124*a466cc55SCy Schubert# Append VARIABLE="VALUE" to DX_ENV for invoking doxygen and add it 125*a466cc55SCy Schubert# as a substitution (but not a Makefile variable). The substitution 126*a466cc55SCy Schubert# is skipped if the variable name is VERSION. 127*a466cc55SCy SchubertAC_DEFUN([DX_ENV_APPEND], 128*a466cc55SCy Schubert[AC_SUBST([DX_ENV], ["$DX_ENV $1='$2'"])dnl 129*a466cc55SCy Schubertm4_if([$1], [VERSION], [], [AC_SUBST([$1], [$2])dnl 130*a466cc55SCy SchubertAM_SUBST_NOTMAKE([$1])])dnl 131*a466cc55SCy Schubert]) 132*a466cc55SCy Schubert 133*a466cc55SCy Schubert# DX_DIRNAME_EXPR 134*a466cc55SCy Schubert# --------------- 135*a466cc55SCy Schubert# Expand into a shell expression prints the directory part of a path. 136*a466cc55SCy SchubertAC_DEFUN([DX_DIRNAME_EXPR], 137*a466cc55SCy Schubert [[expr ".$1" : '\(\.\)[^/]*$' \| "x$1" : 'x\(.*\)/[^/]*$']]) 138*a466cc55SCy Schubert 139*a466cc55SCy Schubert# DX_IF_FEATURE(FEATURE, IF-ON, IF-OFF) 140*a466cc55SCy Schubert# ------------------------------------- 141*a466cc55SCy Schubert# Expands according to the M4 (static) status of the feature. 142*a466cc55SCy SchubertAC_DEFUN([DX_IF_FEATURE], [ifelse(DX_FEATURE_$1, ON, [$2], [$3])]) 143*a466cc55SCy Schubert 144*a466cc55SCy Schubert# DX_REQUIRE_PROG(VARIABLE, PROGRAM) 145*a466cc55SCy Schubert# ---------------------------------- 146*a466cc55SCy Schubert# Require the specified program to be found for the DX_CURRENT_FEATURE to work. 147*a466cc55SCy SchubertAC_DEFUN([DX_REQUIRE_PROG], [ 148*a466cc55SCy SchubertAC_PATH_TOOL([$1], [$2]) 149*a466cc55SCy Schubertif test "$DX_FLAG_[]DX_CURRENT_FEATURE$$1" = 1; then 150*a466cc55SCy Schubert if test "x$2" = "xdoxygen"; then 151*a466cc55SCy Schubert AC_MSG_ERROR([$2 not found - will not DX_CURRENT_DESCRIPTION]) 152*a466cc55SCy Schubert else 153*a466cc55SCy Schubert AC_MSG_WARN([$2 not found - will not DX_CURRENT_DESCRIPTION]) 154*a466cc55SCy Schubert fi 155*a466cc55SCy Schubert AC_SUBST(DX_FLAG_[]DX_CURRENT_FEATURE, 0) 156*a466cc55SCy Schubertfi 157*a466cc55SCy Schubert]) 158*a466cc55SCy Schubert 159*a466cc55SCy Schubert# DX_TEST_FEATURE(FEATURE) 160*a466cc55SCy Schubert# ------------------------ 161*a466cc55SCy Schubert# Expand to a shell expression testing whether the feature is active. 162*a466cc55SCy SchubertAC_DEFUN([DX_TEST_FEATURE], [test "$DX_FLAG_$1" = 1]) 163*a466cc55SCy Schubert 164*a466cc55SCy Schubert# DX_CHECK_DEPEND(REQUIRED_FEATURE, REQUIRED_STATE) 165*a466cc55SCy Schubert# ------------------------------------------------- 166*a466cc55SCy Schubert# Verify that a required features has the right state before trying to turn on 167*a466cc55SCy Schubert# the DX_CURRENT_FEATURE. 168*a466cc55SCy SchubertAC_DEFUN([DX_CHECK_DEPEND], [ 169*a466cc55SCy Schuberttest "$DX_FLAG_$1" = "$2" \ 170*a466cc55SCy Schubert|| AC_MSG_ERROR([doxygen-DX_CURRENT_FEATURE ifelse([$2], 1, 171*a466cc55SCy Schubert requires, contradicts) doxygen-$1]) 172*a466cc55SCy Schubert]) 173*a466cc55SCy Schubert 174*a466cc55SCy Schubert# DX_CLEAR_DEPEND(FEATURE, REQUIRED_FEATURE, REQUIRED_STATE) 175*a466cc55SCy Schubert# ---------------------------------------------------------- 176*a466cc55SCy Schubert# Turn off the DX_CURRENT_FEATURE if the required feature is off. 177*a466cc55SCy SchubertAC_DEFUN([DX_CLEAR_DEPEND], [ 178*a466cc55SCy Schuberttest "$DX_FLAG_$1" = "$2" || AC_SUBST(DX_FLAG_[]DX_CURRENT_FEATURE, 0) 179*a466cc55SCy Schubert]) 180*a466cc55SCy Schubert 181*a466cc55SCy Schubert# DX_FEATURE_ARG(FEATURE, DESCRIPTION, 182*a466cc55SCy Schubert# CHECK_DEPEND, CLEAR_DEPEND, 183*a466cc55SCy Schubert# REQUIRE, DO-IF-ON, DO-IF-OFF) 184*a466cc55SCy Schubert# -------------------------------------------- 185*a466cc55SCy Schubert# Parse the command-line option controlling a feature. CHECK_DEPEND is called 186*a466cc55SCy Schubert# if the user explicitly turns the feature on (and invokes DX_CHECK_DEPEND), 187*a466cc55SCy Schubert# otherwise CLEAR_DEPEND is called to turn off the default state if a required 188*a466cc55SCy Schubert# feature is disabled (using DX_CLEAR_DEPEND). REQUIRE performs additional 189*a466cc55SCy Schubert# requirement tests (DX_REQUIRE_PROG). Finally, an automake flag is set and 190*a466cc55SCy Schubert# DO-IF-ON or DO-IF-OFF are called according to the final state of the feature. 191*a466cc55SCy SchubertAC_DEFUN([DX_ARG_ABLE], [ 192*a466cc55SCy Schubert AC_DEFUN([DX_CURRENT_FEATURE], [$1]) 193*a466cc55SCy Schubert AC_DEFUN([DX_CURRENT_DESCRIPTION], [$2]) 194*a466cc55SCy Schubert AC_ARG_ENABLE(doxygen-$1, 195*a466cc55SCy Schubert [AS_HELP_STRING(DX_IF_FEATURE([$1], [--disable-doxygen-$1], 196*a466cc55SCy Schubert [--enable-doxygen-$1]), 197*a466cc55SCy Schubert DX_IF_FEATURE([$1], [don't $2], [$2]))], 198*a466cc55SCy Schubert [ 199*a466cc55SCy Schubertcase "$enableval" in 200*a466cc55SCy Schubert#( 201*a466cc55SCy Schuberty|Y|yes|Yes|YES) 202*a466cc55SCy Schubert AC_SUBST([DX_FLAG_$1], 1) 203*a466cc55SCy Schubert $3 204*a466cc55SCy Schubert;; #( 205*a466cc55SCy Schubertn|N|no|No|NO) 206*a466cc55SCy Schubert AC_SUBST([DX_FLAG_$1], 0) 207*a466cc55SCy Schubert;; #( 208*a466cc55SCy Schubert*) 209*a466cc55SCy Schubert AC_MSG_ERROR([invalid value '$enableval' given to doxygen-$1]) 210*a466cc55SCy Schubert;; 211*a466cc55SCy Schubertesac 212*a466cc55SCy Schubert], [ 213*a466cc55SCy SchubertAC_SUBST([DX_FLAG_$1], [DX_IF_FEATURE([$1], 1, 0)]) 214*a466cc55SCy Schubert$4 215*a466cc55SCy Schubert]) 216*a466cc55SCy Schubertif DX_TEST_FEATURE([$1]); then 217*a466cc55SCy Schubert $5 218*a466cc55SCy Schubert : 219*a466cc55SCy Schubertfi 220*a466cc55SCy Schubertif DX_TEST_FEATURE([$1]); then 221*a466cc55SCy Schubert $6 222*a466cc55SCy Schubert : 223*a466cc55SCy Schubertelse 224*a466cc55SCy Schubert $7 225*a466cc55SCy Schubert : 226*a466cc55SCy Schubertfi 227*a466cc55SCy Schubert]) 228*a466cc55SCy Schubert 229*a466cc55SCy Schubert## -------------- ## 230*a466cc55SCy Schubert## Public macros. ## 231*a466cc55SCy Schubert## -------------- ## 232*a466cc55SCy Schubert 233*a466cc55SCy Schubert# DX_XXX_FEATURE(DEFAULT_STATE) 234*a466cc55SCy Schubert# ----------------------------- 235*a466cc55SCy SchubertAC_DEFUN([DX_DOXYGEN_FEATURE], [AC_DEFUN([DX_FEATURE_doc], [$1])]) 236*a466cc55SCy SchubertAC_DEFUN([DX_DOT_FEATURE], [AC_DEFUN([DX_FEATURE_dot], [$1])]) 237*a466cc55SCy SchubertAC_DEFUN([DX_MAN_FEATURE], [AC_DEFUN([DX_FEATURE_man], [$1])]) 238*a466cc55SCy SchubertAC_DEFUN([DX_HTML_FEATURE], [AC_DEFUN([DX_FEATURE_html], [$1])]) 239*a466cc55SCy SchubertAC_DEFUN([DX_CHM_FEATURE], [AC_DEFUN([DX_FEATURE_chm], [$1])]) 240*a466cc55SCy SchubertAC_DEFUN([DX_CHI_FEATURE], [AC_DEFUN([DX_FEATURE_chi], [$1])]) 241*a466cc55SCy SchubertAC_DEFUN([DX_RTF_FEATURE], [AC_DEFUN([DX_FEATURE_rtf], [$1])]) 242*a466cc55SCy SchubertAC_DEFUN([DX_XML_FEATURE], [AC_DEFUN([DX_FEATURE_xml], [$1])]) 243*a466cc55SCy SchubertAC_DEFUN([DX_XML_FEATURE], [AC_DEFUN([DX_FEATURE_xml], [$1])]) 244*a466cc55SCy SchubertAC_DEFUN([DX_PDF_FEATURE], [AC_DEFUN([DX_FEATURE_pdf], [$1])]) 245*a466cc55SCy SchubertAC_DEFUN([DX_PS_FEATURE], [AC_DEFUN([DX_FEATURE_ps], [$1])]) 246*a466cc55SCy Schubert 247*a466cc55SCy Schubert# DX_INIT_DOXYGEN(PROJECT, [CONFIG-FILE], [OUTPUT-DOC-DIR], ...) 248*a466cc55SCy Schubert# -------------------------------------------------------------- 249*a466cc55SCy Schubert# PROJECT also serves as the base name for the documentation files. 250*a466cc55SCy Schubert# The default CONFIG-FILE is "$(srcdir)/Doxyfile" and OUTPUT-DOC-DIR is 251*a466cc55SCy Schubert# "doxygen-doc". 252*a466cc55SCy Schubert# More arguments are interpreted as interleaved CONFIG-FILE and 253*a466cc55SCy Schubert# OUTPUT-DOC-DIR values. 254*a466cc55SCy SchubertAC_DEFUN([DX_INIT_DOXYGEN], [ 255*a466cc55SCy Schubert 256*a466cc55SCy Schubert# Files: 257*a466cc55SCy SchubertAC_SUBST([DX_PROJECT], [$1]) 258*a466cc55SCy SchubertAC_SUBST([DX_CONFIG], ['ifelse([$2], [], [$(srcdir)/Doxyfile], [$2])']) 259*a466cc55SCy SchubertAC_SUBST([DX_DOCDIR], ['ifelse([$3], [], [doxygen-doc], [$3])']) 260*a466cc55SCy Schubertm4_if(m4_eval(3 < m4_count($@)), 1, [m4_for([DX_i], 4, m4_count($@), 2, 261*a466cc55SCy Schubert [AC_SUBST([DX_CONFIG]m4_eval(DX_i[/2]), 262*a466cc55SCy Schubert 'm4_default_nblank_quoted(m4_argn(DX_i, $@), 263*a466cc55SCy Schubert [$(srcdir)/Doxyfile])')])])dnl 264*a466cc55SCy Schubertm4_if(m4_eval(3 < m4_count($@)), 1, [m4_for([DX_i], 5, m4_count($@,), 2, 265*a466cc55SCy Schubert [AC_SUBST([DX_DOCDIR]m4_eval([(]DX_i[-1)/2]), 266*a466cc55SCy Schubert 'm4_default_nblank_quoted(m4_argn(DX_i, $@), 267*a466cc55SCy Schubert [doxygen-doc])')])])dnl 268*a466cc55SCy Schubertm4_define([DX_loop], m4_dquote(m4_if(m4_eval(3 < m4_count($@)), 1, 269*a466cc55SCy Schubert [m4_for([DX_i], 4, m4_count($@), 2, [, m4_eval(DX_i[/2])])], 270*a466cc55SCy Schubert [])))dnl 271*a466cc55SCy Schubert 272*a466cc55SCy Schubert# Environment variables used inside doxygen.cfg: 273*a466cc55SCy SchubertDX_ENV_APPEND(SRCDIR, $srcdir) 274*a466cc55SCy SchubertDX_ENV_APPEND(PROJECT, $DX_PROJECT) 275*a466cc55SCy SchubertDX_ENV_APPEND(VERSION, $PACKAGE_VERSION) 276*a466cc55SCy Schubert 277*a466cc55SCy Schubert# Doxygen itself: 278*a466cc55SCy SchubertDX_ARG_ABLE(doc, [generate any doxygen documentation], 279*a466cc55SCy Schubert [], 280*a466cc55SCy Schubert [], 281*a466cc55SCy Schubert [DX_REQUIRE_PROG([DX_DOXYGEN], doxygen) 282*a466cc55SCy Schubert DX_REQUIRE_PROG([DX_PERL], perl)], 283*a466cc55SCy Schubert [DX_ENV_APPEND(PERL_PATH, $DX_PERL)]) 284*a466cc55SCy Schubert 285*a466cc55SCy Schubert# Dot for graphics: 286*a466cc55SCy SchubertDX_ARG_ABLE(dot, [generate graphics for doxygen documentation], 287*a466cc55SCy Schubert [DX_CHECK_DEPEND(doc, 1)], 288*a466cc55SCy Schubert [DX_CLEAR_DEPEND(doc, 1)], 289*a466cc55SCy Schubert [DX_REQUIRE_PROG([DX_DOT], dot)], 290*a466cc55SCy Schubert [DX_ENV_APPEND(HAVE_DOT, YES) 291*a466cc55SCy Schubert DX_ENV_APPEND(DOT_PATH, [`DX_DIRNAME_EXPR($DX_DOT)`])], 292*a466cc55SCy Schubert [DX_ENV_APPEND(HAVE_DOT, NO)]) 293*a466cc55SCy Schubert 294*a466cc55SCy Schubert# Man pages generation: 295*a466cc55SCy SchubertDX_ARG_ABLE(man, [generate doxygen manual pages], 296*a466cc55SCy Schubert [DX_CHECK_DEPEND(doc, 1)], 297*a466cc55SCy Schubert [DX_CLEAR_DEPEND(doc, 1)], 298*a466cc55SCy Schubert [], 299*a466cc55SCy Schubert [DX_ENV_APPEND(GENERATE_MAN, YES)], 300*a466cc55SCy Schubert [DX_ENV_APPEND(GENERATE_MAN, NO)]) 301*a466cc55SCy Schubert 302*a466cc55SCy Schubert# RTF file generation: 303*a466cc55SCy SchubertDX_ARG_ABLE(rtf, [generate doxygen RTF documentation], 304*a466cc55SCy Schubert [DX_CHECK_DEPEND(doc, 1)], 305*a466cc55SCy Schubert [DX_CLEAR_DEPEND(doc, 1)], 306*a466cc55SCy Schubert [], 307*a466cc55SCy Schubert [DX_ENV_APPEND(GENERATE_RTF, YES)], 308*a466cc55SCy Schubert [DX_ENV_APPEND(GENERATE_RTF, NO)]) 309*a466cc55SCy Schubert 310*a466cc55SCy Schubert# XML file generation: 311*a466cc55SCy SchubertDX_ARG_ABLE(xml, [generate doxygen XML documentation], 312*a466cc55SCy Schubert [DX_CHECK_DEPEND(doc, 1)], 313*a466cc55SCy Schubert [DX_CLEAR_DEPEND(doc, 1)], 314*a466cc55SCy Schubert [], 315*a466cc55SCy Schubert [DX_ENV_APPEND(GENERATE_XML, YES)], 316*a466cc55SCy Schubert [DX_ENV_APPEND(GENERATE_XML, NO)]) 317*a466cc55SCy Schubert 318*a466cc55SCy Schubert# (Compressed) HTML help generation: 319*a466cc55SCy SchubertDX_ARG_ABLE(chm, [generate doxygen compressed HTML help documentation], 320*a466cc55SCy Schubert [DX_CHECK_DEPEND(doc, 1)], 321*a466cc55SCy Schubert [DX_CLEAR_DEPEND(doc, 1)], 322*a466cc55SCy Schubert [DX_REQUIRE_PROG([DX_HHC], hhc)], 323*a466cc55SCy Schubert [DX_ENV_APPEND(HHC_PATH, $DX_HHC) 324*a466cc55SCy Schubert DX_ENV_APPEND(GENERATE_HTML, YES) 325*a466cc55SCy Schubert DX_ENV_APPEND(GENERATE_HTMLHELP, YES)], 326*a466cc55SCy Schubert [DX_ENV_APPEND(GENERATE_HTMLHELP, NO)]) 327*a466cc55SCy Schubert 328*a466cc55SCy Schubert# Separate CHI file generation. 329*a466cc55SCy SchubertDX_ARG_ABLE(chi, [generate doxygen separate compressed HTML help index file], 330*a466cc55SCy Schubert [DX_CHECK_DEPEND(chm, 1)], 331*a466cc55SCy Schubert [DX_CLEAR_DEPEND(chm, 1)], 332*a466cc55SCy Schubert [], 333*a466cc55SCy Schubert [DX_ENV_APPEND(GENERATE_CHI, YES)], 334*a466cc55SCy Schubert [DX_ENV_APPEND(GENERATE_CHI, NO)]) 335*a466cc55SCy Schubert 336*a466cc55SCy Schubert# Plain HTML pages generation: 337*a466cc55SCy SchubertDX_ARG_ABLE(html, [generate doxygen plain HTML documentation], 338*a466cc55SCy Schubert [DX_CHECK_DEPEND(doc, 1) DX_CHECK_DEPEND(chm, 0)], 339*a466cc55SCy Schubert [DX_CLEAR_DEPEND(doc, 1) DX_CLEAR_DEPEND(chm, 0)], 340*a466cc55SCy Schubert [], 341*a466cc55SCy Schubert [DX_ENV_APPEND(GENERATE_HTML, YES)], 342*a466cc55SCy Schubert [DX_TEST_FEATURE(chm) || DX_ENV_APPEND(GENERATE_HTML, NO)]) 343*a466cc55SCy Schubert 344*a466cc55SCy Schubert# PostScript file generation: 345*a466cc55SCy SchubertDX_ARG_ABLE(ps, [generate doxygen PostScript documentation], 346*a466cc55SCy Schubert [DX_CHECK_DEPEND(doc, 1)], 347*a466cc55SCy Schubert [DX_CLEAR_DEPEND(doc, 1)], 348*a466cc55SCy Schubert [DX_REQUIRE_PROG([DX_LATEX], latex) 349*a466cc55SCy Schubert DX_REQUIRE_PROG([DX_MAKEINDEX], makeindex) 350*a466cc55SCy Schubert DX_REQUIRE_PROG([DX_DVIPS], dvips) 351*a466cc55SCy Schubert DX_REQUIRE_PROG([DX_EGREP], egrep)]) 352*a466cc55SCy Schubert 353*a466cc55SCy Schubert# PDF file generation: 354*a466cc55SCy SchubertDX_ARG_ABLE(pdf, [generate doxygen PDF documentation], 355*a466cc55SCy Schubert [DX_CHECK_DEPEND(doc, 1)], 356*a466cc55SCy Schubert [DX_CLEAR_DEPEND(doc, 1)], 357*a466cc55SCy Schubert [DX_REQUIRE_PROG([DX_PDFLATEX], pdflatex) 358*a466cc55SCy Schubert DX_REQUIRE_PROG([DX_MAKEINDEX], makeindex) 359*a466cc55SCy Schubert DX_REQUIRE_PROG([DX_EGREP], egrep)]) 360*a466cc55SCy Schubert 361*a466cc55SCy Schubert# LaTeX generation for PS and/or PDF: 362*a466cc55SCy Schubertif DX_TEST_FEATURE(ps) || DX_TEST_FEATURE(pdf); then 363*a466cc55SCy Schubert DX_ENV_APPEND(GENERATE_LATEX, YES) 364*a466cc55SCy Schubertelse 365*a466cc55SCy Schubert DX_ENV_APPEND(GENERATE_LATEX, NO) 366*a466cc55SCy Schubertfi 367*a466cc55SCy Schubert 368*a466cc55SCy Schubert# Paper size for PS and/or PDF: 369*a466cc55SCy SchubertAC_ARG_VAR(DOXYGEN_PAPER_SIZE, 370*a466cc55SCy Schubert [a4wide (default), a4, letter, legal or executive]) 371*a466cc55SCy Schubertcase "$DOXYGEN_PAPER_SIZE" in 372*a466cc55SCy Schubert#( 373*a466cc55SCy Schubert"") 374*a466cc55SCy Schubert AC_SUBST(DOXYGEN_PAPER_SIZE, "") 375*a466cc55SCy Schubert;; #( 376*a466cc55SCy Schuberta4wide|a4|letter|legal|executive) 377*a466cc55SCy Schubert DX_ENV_APPEND(PAPER_SIZE, $DOXYGEN_PAPER_SIZE) 378*a466cc55SCy Schubert;; #( 379*a466cc55SCy Schubert*) 380*a466cc55SCy Schubert AC_MSG_ERROR([unknown DOXYGEN_PAPER_SIZE='$DOXYGEN_PAPER_SIZE']) 381*a466cc55SCy Schubert;; 382*a466cc55SCy Schubertesac 383*a466cc55SCy Schubert 384*a466cc55SCy Schubert# Rules: 385*a466cc55SCy SchubertAS_IF([[test $DX_FLAG_html -eq 1]], 386*a466cc55SCy Schubert[[DX_SNIPPET_html="## ------------------------------- ## 387*a466cc55SCy Schubert## Rules specific for HTML output. ## 388*a466cc55SCy Schubert## ------------------------------- ## 389*a466cc55SCy Schubert 390*a466cc55SCy SchubertDX_CLEAN_HTML = \$(DX_DOCDIR)/html]dnl 391*a466cc55SCy Schubertm4_foreach([DX_i], [m4_shift(DX_loop)], [[\\ 392*a466cc55SCy Schubert \$(DX_DOCDIR]DX_i[)/html]])[ 393*a466cc55SCy Schubert 394*a466cc55SCy Schubert"]], 395*a466cc55SCy Schubert[[DX_SNIPPET_html=""]]) 396*a466cc55SCy SchubertAS_IF([[test $DX_FLAG_chi -eq 1]], 397*a466cc55SCy Schubert[[DX_SNIPPET_chi=" 398*a466cc55SCy SchubertDX_CLEAN_CHI = \$(DX_DOCDIR)/\$(PACKAGE).chi]dnl 399*a466cc55SCy Schubertm4_foreach([DX_i], [m4_shift(DX_loop)], [[\\ 400*a466cc55SCy Schubert \$(DX_DOCDIR]DX_i[)/\$(PACKAGE).chi]])["]], 401*a466cc55SCy Schubert[[DX_SNIPPET_chi=""]]) 402*a466cc55SCy SchubertAS_IF([[test $DX_FLAG_chm -eq 1]], 403*a466cc55SCy Schubert[[DX_SNIPPET_chm="## ------------------------------ ## 404*a466cc55SCy Schubert## Rules specific for CHM output. ## 405*a466cc55SCy Schubert## ------------------------------ ## 406*a466cc55SCy Schubert 407*a466cc55SCy SchubertDX_CLEAN_CHM = \$(DX_DOCDIR)/chm]dnl 408*a466cc55SCy Schubertm4_foreach([DX_i], [m4_shift(DX_loop)], [[\\ 409*a466cc55SCy Schubert \$(DX_DOCDIR]DX_i[)/chm]])[\ 410*a466cc55SCy Schubert${DX_SNIPPET_chi} 411*a466cc55SCy Schubert 412*a466cc55SCy Schubert"]], 413*a466cc55SCy Schubert[[DX_SNIPPET_chm=""]]) 414*a466cc55SCy SchubertAS_IF([[test $DX_FLAG_man -eq 1]], 415*a466cc55SCy Schubert[[DX_SNIPPET_man="## ------------------------------ ## 416*a466cc55SCy Schubert## Rules specific for MAN output. ## 417*a466cc55SCy Schubert## ------------------------------ ## 418*a466cc55SCy Schubert 419*a466cc55SCy SchubertDX_CLEAN_MAN = \$(DX_DOCDIR)/man]dnl 420*a466cc55SCy Schubertm4_foreach([DX_i], [m4_shift(DX_loop)], [[\\ 421*a466cc55SCy Schubert \$(DX_DOCDIR]DX_i[)/man]])[ 422*a466cc55SCy Schubert 423*a466cc55SCy Schubert"]], 424*a466cc55SCy Schubert[[DX_SNIPPET_man=""]]) 425*a466cc55SCy SchubertAS_IF([[test $DX_FLAG_rtf -eq 1]], 426*a466cc55SCy Schubert[[DX_SNIPPET_rtf="## ------------------------------ ## 427*a466cc55SCy Schubert## Rules specific for RTF output. ## 428*a466cc55SCy Schubert## ------------------------------ ## 429*a466cc55SCy Schubert 430*a466cc55SCy SchubertDX_CLEAN_RTF = \$(DX_DOCDIR)/rtf]dnl 431*a466cc55SCy Schubertm4_foreach([DX_i], [m4_shift(DX_loop)], [[\\ 432*a466cc55SCy Schubert \$(DX_DOCDIR]DX_i[)/rtf]])[ 433*a466cc55SCy Schubert 434*a466cc55SCy Schubert"]], 435*a466cc55SCy Schubert[[DX_SNIPPET_rtf=""]]) 436*a466cc55SCy SchubertAS_IF([[test $DX_FLAG_xml -eq 1]], 437*a466cc55SCy Schubert[[DX_SNIPPET_xml="## ------------------------------ ## 438*a466cc55SCy Schubert## Rules specific for XML output. ## 439*a466cc55SCy Schubert## ------------------------------ ## 440*a466cc55SCy Schubert 441*a466cc55SCy SchubertDX_CLEAN_XML = \$(DX_DOCDIR)/xml]dnl 442*a466cc55SCy Schubertm4_foreach([DX_i], [m4_shift(DX_loop)], [[\\ 443*a466cc55SCy Schubert \$(DX_DOCDIR]DX_i[)/xml]])[ 444*a466cc55SCy Schubert 445*a466cc55SCy Schubert"]], 446*a466cc55SCy Schubert[[DX_SNIPPET_xml=""]]) 447*a466cc55SCy SchubertAS_IF([[test $DX_FLAG_ps -eq 1]], 448*a466cc55SCy Schubert[[DX_SNIPPET_ps="## ----------------------------- ## 449*a466cc55SCy Schubert## Rules specific for PS output. ## 450*a466cc55SCy Schubert## ----------------------------- ## 451*a466cc55SCy Schubert 452*a466cc55SCy SchubertDX_CLEAN_PS = \$(DX_DOCDIR)/\$(PACKAGE).ps]dnl 453*a466cc55SCy Schubertm4_foreach([DX_i], [m4_shift(DX_loop)], [[\\ 454*a466cc55SCy Schubert \$(DX_DOCDIR]DX_i[)/\$(PACKAGE).ps]])[ 455*a466cc55SCy Schubert 456*a466cc55SCy SchubertDX_PS_GOAL = doxygen-ps 457*a466cc55SCy Schubert 458*a466cc55SCy Schubertdoxygen-ps: \$(DX_CLEAN_PS) 459*a466cc55SCy Schubert 460*a466cc55SCy Schubert]m4_foreach([DX_i], [DX_loop], 461*a466cc55SCy Schubert[[\$(DX_DOCDIR]DX_i[)/\$(PACKAGE).ps: \$(DX_DOCDIR]DX_i[)/\$(PACKAGE).tag 462*a466cc55SCy Schubert \$(DX_V_LATEX)cd \$(DX_DOCDIR]DX_i[)/latex; \\ 463*a466cc55SCy Schubert rm -f *.aux *.toc *.idx *.ind *.ilg *.log *.out; \\ 464*a466cc55SCy Schubert \$(DX_LATEX) refman.tex; \\ 465*a466cc55SCy Schubert \$(DX_MAKEINDEX) refman.idx; \\ 466*a466cc55SCy Schubert \$(DX_LATEX) refman.tex; \\ 467*a466cc55SCy Schubert countdown=5; \\ 468*a466cc55SCy Schubert while \$(DX_EGREP) 'Rerun (LaTeX|to get cross-references right)' \\ 469*a466cc55SCy Schubert refman.log > /dev/null 2>&1 \\ 470*a466cc55SCy Schubert && test \$\$countdown -gt 0; do \\ 471*a466cc55SCy Schubert \$(DX_LATEX) refman.tex; \\ 472*a466cc55SCy Schubert countdown=\`expr \$\$countdown - 1\`; \\ 473*a466cc55SCy Schubert done; \\ 474*a466cc55SCy Schubert \$(DX_DVIPS) -o ../\$(PACKAGE).ps refman.dvi 475*a466cc55SCy Schubert 476*a466cc55SCy Schubert]])["]], 477*a466cc55SCy Schubert[[DX_SNIPPET_ps=""]]) 478*a466cc55SCy SchubertAS_IF([[test $DX_FLAG_pdf -eq 1]], 479*a466cc55SCy Schubert[[DX_SNIPPET_pdf="## ------------------------------ ## 480*a466cc55SCy Schubert## Rules specific for PDF output. ## 481*a466cc55SCy Schubert## ------------------------------ ## 482*a466cc55SCy Schubert 483*a466cc55SCy SchubertDX_CLEAN_PDF = \$(DX_DOCDIR)/\$(PACKAGE).pdf]dnl 484*a466cc55SCy Schubertm4_foreach([DX_i], [m4_shift(DX_loop)], [[\\ 485*a466cc55SCy Schubert \$(DX_DOCDIR]DX_i[)/\$(PACKAGE).pdf]])[ 486*a466cc55SCy Schubert 487*a466cc55SCy SchubertDX_PDF_GOAL = doxygen-pdf 488*a466cc55SCy Schubert 489*a466cc55SCy Schubertdoxygen-pdf: \$(DX_CLEAN_PDF) 490*a466cc55SCy Schubert 491*a466cc55SCy Schubert]m4_foreach([DX_i], [DX_loop], 492*a466cc55SCy Schubert[[\$(DX_DOCDIR]DX_i[)/\$(PACKAGE).pdf: \$(DX_DOCDIR]DX_i[)/\$(PACKAGE).tag 493*a466cc55SCy Schubert \$(DX_V_LATEX)cd \$(DX_DOCDIR]DX_i[)/latex; \\ 494*a466cc55SCy Schubert rm -f *.aux *.toc *.idx *.ind *.ilg *.log *.out; \\ 495*a466cc55SCy Schubert \$(DX_PDFLATEX) refman.tex; \\ 496*a466cc55SCy Schubert \$(DX_MAKEINDEX) refman.idx; \\ 497*a466cc55SCy Schubert \$(DX_PDFLATEX) refman.tex; \\ 498*a466cc55SCy Schubert countdown=5; \\ 499*a466cc55SCy Schubert while \$(DX_EGREP) 'Rerun (LaTeX|to get cross-references right)' \\ 500*a466cc55SCy Schubert refman.log > /dev/null 2>&1 \\ 501*a466cc55SCy Schubert && test \$\$countdown -gt 0; do \\ 502*a466cc55SCy Schubert \$(DX_PDFLATEX) refman.tex; \\ 503*a466cc55SCy Schubert countdown=\`expr \$\$countdown - 1\`; \\ 504*a466cc55SCy Schubert done; \\ 505*a466cc55SCy Schubert mv refman.pdf ../\$(PACKAGE).pdf 506*a466cc55SCy Schubert 507*a466cc55SCy Schubert]])["]], 508*a466cc55SCy Schubert[[DX_SNIPPET_pdf=""]]) 509*a466cc55SCy SchubertAS_IF([[test $DX_FLAG_ps -eq 1 -o $DX_FLAG_pdf -eq 1]], 510*a466cc55SCy Schubert[[DX_SNIPPET_latex="## ------------------------------------------------- ## 511*a466cc55SCy Schubert## Rules specific for LaTeX (shared for PS and PDF). ## 512*a466cc55SCy Schubert## ------------------------------------------------- ## 513*a466cc55SCy Schubert 514*a466cc55SCy SchubertDX_V_LATEX = \$(_DX_v_LATEX_\$(V)) 515*a466cc55SCy Schubert_DX_v_LATEX_ = \$(_DX_v_LATEX_\$(AM_DEFAULT_VERBOSITY)) 516*a466cc55SCy Schubert_DX_v_LATEX_0 = @echo \" LATEX \" \$][@; 517*a466cc55SCy Schubert 518*a466cc55SCy SchubertDX_CLEAN_LATEX = \$(DX_DOCDIR)/latex]dnl 519*a466cc55SCy Schubertm4_foreach([DX_i], [m4_shift(DX_loop)], [[\\ 520*a466cc55SCy Schubert \$(DX_DOCDIR]DX_i[)/latex]])[ 521*a466cc55SCy Schubert 522*a466cc55SCy Schubert"]], 523*a466cc55SCy Schubert[[DX_SNIPPET_latex=""]]) 524*a466cc55SCy Schubert 525*a466cc55SCy SchubertAS_IF([[test $DX_FLAG_doc -eq 1]], 526*a466cc55SCy Schubert[[DX_SNIPPET_doc="## --------------------------------- ## 527*a466cc55SCy Schubert## Format-independent Doxygen rules. ## 528*a466cc55SCy Schubert## --------------------------------- ## 529*a466cc55SCy Schubert 530*a466cc55SCy Schubert${DX_SNIPPET_html}\ 531*a466cc55SCy Schubert${DX_SNIPPET_chm}\ 532*a466cc55SCy Schubert${DX_SNIPPET_man}\ 533*a466cc55SCy Schubert${DX_SNIPPET_rtf}\ 534*a466cc55SCy Schubert${DX_SNIPPET_xml}\ 535*a466cc55SCy Schubert${DX_SNIPPET_ps}\ 536*a466cc55SCy Schubert${DX_SNIPPET_pdf}\ 537*a466cc55SCy Schubert${DX_SNIPPET_latex}\ 538*a466cc55SCy SchubertDX_V_DXGEN = \$(_DX_v_DXGEN_\$(V)) 539*a466cc55SCy Schubert_DX_v_DXGEN_ = \$(_DX_v_DXGEN_\$(AM_DEFAULT_VERBOSITY)) 540*a466cc55SCy Schubert_DX_v_DXGEN_0 = @echo \" DXGEN \" \$<; 541*a466cc55SCy Schubert 542*a466cc55SCy Schubert.PHONY: doxygen-run doxygen-doc \$(DX_PS_GOAL) \$(DX_PDF_GOAL) 543*a466cc55SCy Schubert 544*a466cc55SCy Schubert.INTERMEDIATE: doxygen-run \$(DX_PS_GOAL) \$(DX_PDF_GOAL) 545*a466cc55SCy Schubert 546*a466cc55SCy Schubertdoxygen-run:]m4_foreach([DX_i], [DX_loop], 547*a466cc55SCy Schubert [[ \$(DX_DOCDIR]DX_i[)/\$(PACKAGE).tag]])[ 548*a466cc55SCy Schubert 549*a466cc55SCy Schubertdoxygen-doc: doxygen-run \$(DX_PS_GOAL) \$(DX_PDF_GOAL) 550*a466cc55SCy Schubert 551*a466cc55SCy Schubert]m4_foreach([DX_i], [DX_loop], 552*a466cc55SCy Schubert[[\$(DX_DOCDIR]DX_i[)/\$(PACKAGE).tag: \$(DX_CONFIG]DX_i[) \$(pkginclude_HEADERS) 553*a466cc55SCy Schubert \$(A""M_V_at)rm -rf \$(DX_DOCDIR]DX_i[) 554*a466cc55SCy Schubert \$(DX_V_DXGEN)\$(DX_ENV) DOCDIR=\$(DX_DOCDIR]DX_i[) \$(DX_DOXYGEN) \$(DX_CONFIG]DX_i[) 555*a466cc55SCy Schubert \$(A""M_V_at)echo Timestamp >\$][@ 556*a466cc55SCy Schubert 557*a466cc55SCy Schubert]])dnl 558*a466cc55SCy Schubert[DX_CLEANFILES = \\] 559*a466cc55SCy Schubertm4_foreach([DX_i], [DX_loop], 560*a466cc55SCy Schubert[[ \$(DX_DOCDIR]DX_i[)/doxygen_sqlite3.db \\ 561*a466cc55SCy Schubert \$(DX_DOCDIR]DX_i[)/\$(PACKAGE).tag \\ 562*a466cc55SCy Schubert]])dnl 563*a466cc55SCy Schubert[ -r \\ 564*a466cc55SCy Schubert \$(DX_CLEAN_HTML) \\ 565*a466cc55SCy Schubert \$(DX_CLEAN_CHM) \\ 566*a466cc55SCy Schubert \$(DX_CLEAN_CHI) \\ 567*a466cc55SCy Schubert \$(DX_CLEAN_MAN) \\ 568*a466cc55SCy Schubert \$(DX_CLEAN_RTF) \\ 569*a466cc55SCy Schubert \$(DX_CLEAN_XML) \\ 570*a466cc55SCy Schubert \$(DX_CLEAN_PS) \\ 571*a466cc55SCy Schubert \$(DX_CLEAN_PDF) \\ 572*a466cc55SCy Schubert \$(DX_CLEAN_LATEX) 573*a466cc55SCy SchubertDX_INSTALL_DOCS = \\ 574*a466cc55SCy Schubert \$(DX_CLEAN_HTML) \\ 575*a466cc55SCy Schubert \$(DX_CLEAN_CHM) \\ 576*a466cc55SCy Schubert \$(DX_CLEAN_CHI) \\ 577*a466cc55SCy Schubert \$(DX_CLEAN_RTF) \\ 578*a466cc55SCy Schubert \$(DX_CLEAN_XML) \\ 579*a466cc55SCy Schubert \$(DX_CLEAN_PS) \\ 580*a466cc55SCy Schubert \$(DX_CLEAN_PDF) \\ 581*a466cc55SCy Schubert \$(DX_CLEAN_LATEX) 582*a466cc55SCy Schubert "]], 583*a466cc55SCy Schubert[[DX_SNIPPET_doc=""]]) 584*a466cc55SCy SchubertAC_SUBST([DX_RULES], 585*a466cc55SCy Schubert["${DX_SNIPPET_doc}"])dnl 586*a466cc55SCy SchubertAM_SUBST_NOTMAKE([DX_RULES]) 587*a466cc55SCy Schubert 588*a466cc55SCy Schubert#For debugging: 589*a466cc55SCy Schubert#echo DX_FLAG_doc=$DX_FLAG_doc 590*a466cc55SCy Schubert#echo DX_FLAG_dot=$DX_FLAG_dot 591*a466cc55SCy Schubert#echo DX_FLAG_man=$DX_FLAG_man 592*a466cc55SCy Schubert#echo DX_FLAG_html=$DX_FLAG_html 593*a466cc55SCy Schubert#echo DX_FLAG_chm=$DX_FLAG_chm 594*a466cc55SCy Schubert#echo DX_FLAG_chi=$DX_FLAG_chi 595*a466cc55SCy Schubert#echo DX_FLAG_rtf=$DX_FLAG_rtf 596*a466cc55SCy Schubert#echo DX_FLAG_xml=$DX_FLAG_xml 597*a466cc55SCy Schubert#echo DX_FLAG_pdf=$DX_FLAG_pdf 598*a466cc55SCy Schubert#echo DX_FLAG_ps=$DX_FLAG_ps 599*a466cc55SCy Schubert#echo DX_ENV=$DX_ENV 600*a466cc55SCy Schubert]) 601