From 216dd32ebf648c98456a1ffe1cbb7fb161d52ac9 Mon Sep 17 00:00:00 2001 From: Graeme Walker Date: Sat, 29 Mar 2008 12:00:00 +0000 Subject: [PATCH] v1.8 --- AUTHORS | 5 +- ChangeLog | 16 + INSTALL | 6 +- LICENSE | 92 +- Makefile.am | 43 +- Makefile.in | 69 +- README | 6 +- README.mac | 35 + README.mips | 24 + README.windows | 79 +- acinclude.m4 | 609 +++- aclocal.m4 | 38 +- autogen.sh | 10 + bin/Makefile.am | 92 +- bin/Makefile.in | 146 +- bin/configure-mac.sh | 55 + bin/doxygen.sh_ | 6 +- bin/emailrelay-change-auth.js | 47 + bin/emailrelay-deliver.sh_ | 10 +- bin/emailrelay-multicast.sh_ | 103 + bin/emailrelay-notify.sh_ | 56 +- bin/emailrelay-process.sh_ | 16 +- bin/emailrelay-resubmit.js | 40 +- bin/emailrelay-resubmit.sh_ | 6 +- bin/emailrelay-runperl.js | 34 +- bin/emailrelay-submit.sh_ | 28 +- bin/emailrelay.sh_ | 19 +- bin/expand.sh_ | 2 +- bin/fragment.pl_ | 270 ++ bin/make-bundle.sh_ | 87 + bin/make-qt-enabled.sh_ | 122 + bin/make-setup.sh_ | 101 + bin/mu2docbook.sh_ | 2 +- bin/mu2html.sh_ | 4 +- bin/startup-mac.plist | 12 + bin/txt2html.sh_ | 6 +- bin/txt2mu.sh_ | 4 +- bootstrap | 10 + config.h.in | 40 +- configure | 1287 +++++++-- configure.ac | 106 +- depcomp | 33 +- doc/Makefile.am | 34 +- doc/Makefile.in | 39 +- doc/developer.txt | 124 +- doc/doxygen_missing.html | 2 +- doc/emailrelay-filter-copy.1 | 2 +- doc/emailrelay-man.html | 7 +- doc/emailrelay-passwd.1 | 2 +- doc/emailrelay-poke.1 | 2 +- doc/emailrelay-submit.1 | 2 +- doc/emailrelay.1 | 5 +- doc/index.html | 2 +- doc/reference.txt | 17 +- doc/userguide.txt | 61 +- doc/windows.txt | 39 +- emailrelay-gui.xcodeproj/project.pbxproj | 613 ++++ emailrelay.spec | 5 +- emailrelay.xcodeproj/project.pbxproj | 2546 +++++++++++++++++ etc/Makefile.am | 8 +- etc/Makefile.in | 16 +- etc/emailrelay.conf.template | 13 +- {lib/sunpro5 => extra}/Makefile.am | 5 +- extra/Makefile.in | 480 ++++ extra/mips/Makefile.am | 17 + {lib/sunpro5 => extra/mips}/Makefile.in | 17 +- extra/mips/README | 24 + extra/mips/configure-mips.sh_ | 185 ++ extra/mips/toolchain.mak | 687 +++++ install-sh | 222 +- lib/Makefile.am | 6 +- lib/Makefile.in | 28 +- lib/gcc2.95/Makefile.am | 2 +- lib/gcc2.95/Makefile.in | 7 +- lib/gcc2.95/iostream | 2 +- lib/gcc2.95/limits | 2 +- lib/gcc2.95/sstream | 2 +- lib/gcc2.95/xlocale | 2 +- lib/msvc6.0/Makefile.am | 2 +- lib/msvc6.0/Makefile.in | 7 +- lib/msvc6.0/cmath | 2 +- lib/msvc6.0/cstddef | 2 +- lib/msvc6.0/cstdio | 2 +- lib/msvc6.0/cstdlib | 2 +- lib/msvc6.0/cstring | 2 +- lib/msvc6.0/ctime | 2 +- lib/sunpro5/xar | 39 - src/Makefile.am | 6 +- src/Makefile.in | 24 +- src/fragments/Makefile.am | 26 + src/fragments/Makefile.in | 422 +++ src/fragments/empty.cpp | 0 src/glib/Makefile.am | 79 +- src/glib/Makefile.in | 142 +- src/glib/garg.cpp | 70 +- src/glib/garg.h | 32 +- src/glib/garg_mac.cpp | 33 + src/glib/garg_unix.cpp | 32 +- src/glib/garg_win32.cpp | 87 +- src/glib/gassert.h | 2 +- src/glib/gcleanup.h | 2 +- src/glib/gcleanup_unix.cpp | 11 +- src/glib/gcleanup_win32.cpp | 2 +- src/glib/gconvert.h | 4 +- src/glib/gcounter.cpp | 4 +- src/glib/gcounter.h | 2 +- src/glib/gdaemon.h | 2 +- src/glib/gdaemon_unix.cpp | 7 +- src/glib/gdaemon_win32.cpp | 2 +- src/glib/gdate.cpp | 6 +- src/glib/gdate.h | 2 +- src/glib/gdatetime.cpp | 2 +- src/glib/gdatetime.h | 2 +- src/glib/gdatetime_unix.cpp | 2 +- src/glib/gdatetime_win32.cpp | 2 +- src/glib/gdebug.h | 2 +- src/glib/gdef.h | 50 +- src/glib/gdirectory.cpp | 43 +- src/glib/gdirectory.h | 27 +- src/glib/gdirectory_unix.cpp | 170 +- src/glib/gdirectory_unix_glob.cpp | 205 ++ src/glib/gdirectory_unix_noglob.cpp | 173 ++ src/glib/gdirectory_win32.cpp | 21 +- src/glib/gexception.cpp | 32 +- src/glib/gexception.h | 31 +- src/glib/gexecutable.cpp | 12 +- src/glib/gexecutable.h | 2 +- src/glib/gexecutable_unix.cpp | 2 +- src/glib/gexecutable_win32.cpp | 11 +- src/glib/gfile.cpp | 54 +- src/glib/gfile.h | 9 +- src/glib/gfile_unix.cpp | 40 +- src/glib/gfile_win32.cpp | 2 +- src/glib/gfs.h | 2 +- src/glib/gfs_unix.cpp | 4 +- src/glib/gfs_win32.cpp | 3 +- src/glib/ggetopt.cpp | 92 +- src/glib/ggetopt.h | 34 +- src/{gssl/gssl.cpp => glib/ghostname.h} | 26 +- src/glib/ghostname_unix.cpp | 52 + src/glib/ghostname_win32.cpp | 41 + src/glib/gidentity.h | 2 +- src/glib/gidentity_disabled.cpp | 128 + src/glib/gidentity_unix.cpp | 22 +- src/glib/gidentity_win32.cpp | 2 +- src/glib/glimits.h | 67 + src/glib/glog.cpp | 2 +- src/glib/glog.h | 9 +- src/glib/glogoutput.cpp | 33 +- src/glib/glogoutput.h | 7 +- src/glib/glogoutput_unix.cpp | 2 +- src/glib/glogoutput_win32.cpp | 8 +- src/glib/gmd5.h | 2 +- src/glib/gmd5_native.cpp | 4 +- src/glib/gmemory.h | 13 +- src/glib/gnewprocess.h | 104 + src/glib/gnewprocess_unix_exec_disabled.cpp | 52 + src/glib/gnewprocess_unix_exec_enabled.cpp | 354 +++ src/glib/gnewprocess_win32.cpp | 358 +++ src/glib/gnoncopyable.h | 2 +- src/glib/gpath.cpp | 148 +- src/glib/gpath.h | 49 +- src/glib/gpidfile.cpp | 2 +- src/glib/gpidfile.h | 2 +- src/glib/gprocess.h | 75 +- src/glib/gprocess_unix.cpp | 318 +- src/glib/gprocess_win32.cpp | 341 +-- src/glib/groot.cpp | 2 +- src/glib/groot.h | 22 +- src/glib/gsetter.h | 5 +- src/glib/gsignalsafe.h | 2 +- src/glib/gsleep.h | 4 +- src/glib/gslot.cpp | 2 +- src/glib/gslot.h | 10 +- src/glib/gstatemachine.h | 8 +- src/glib/gstr.cpp | 514 ++-- src/glib/gstr.h | 86 +- src/glib/gstrings.h | 2 +- src/glib/gtest.cpp | 2 +- src/glib/gtest.h | 2 +- src/glib/gtime.cpp | 2 +- src/glib/gtime.h | 2 +- src/glib/gxtext.cpp | 2 +- src/glib/gxtext.h | 2 +- src/glib/md5.cpp | 2 +- src/glib/md5.h | 2 +- src/glib/mingw.mak | 4 +- src/gnet/Makefile.am | 39 +- src/gnet/Makefile.in | 114 +- src/gnet/gaddress.h | 2 +- src/gnet/gaddress_ip.cpp | 6 +- src/gnet/gaddress_ipv4.cpp | 66 +- src/gnet/gaddress_ipv6.cpp | 6 +- src/gnet/gbufferedserverpeer.cpp | 12 +- src/gnet/gbufferedserverpeer.h | 2 +- src/gnet/gclient.cpp | 2 +- src/gnet/gclient.h | 2 +- src/gnet/gclientptr.h | 2 +- src/gnet/gconnection.cpp | 2 +- src/gnet/gconnection.h | 2 +- src/gnet/gdescriptor.h | 2 +- src/gnet/gdescriptor_unix.cpp | 2 +- src/gnet/gdescriptor_win32.cpp | 2 +- src/gnet/gevent.h | 2 +- src/gnet/geventhandler.cpp | 2 +- src/gnet/geventhandler.h | 2 +- src/gnet/geventloop.cpp | 2 +- src/gnet/geventloop.h | 2 +- src/gnet/geventloop_unix.cpp | 10 +- src/gnet/geventloop_win32.cpp | 2 +- src/gnet/gheapclient.cpp | 2 +- src/gnet/gheapclient.h | 2 +- src/gnet/glinebuffer.cpp | 92 +- src/gnet/glinebuffer.h | 62 +- src/gnet/glocal.cpp | 11 +- src/gnet/glocal.h | 38 +- src/gnet/glocal_dns_disabled.cpp | 45 + src/gnet/glocal_unix.cpp | 30 +- src/gnet/glocal_win32.cpp | 18 +- src/gnet/gmonitor.cpp | 16 +- src/gnet/gmonitor.h | 4 +- src/gnet/gmultiserver.cpp | 2 +- src/gnet/gmultiserver.h | 6 +- src/gnet/gnet.h | 2 +- src/gnet/grequest.h | 2 +- src/gnet/{grequest.cpp => grequest_win32.cpp} | 6 +- src/gnet/gresolver.cpp | 80 +- src/gnet/gresolver.h | 6 +- src/gnet/gresolver_dns_disabled.cpp | 80 + src/gnet/gresolver_ip.cpp | 6 +- src/gnet/gresolver_ipv4.cpp | 31 +- src/gnet/gresolver_ipv6.cpp | 25 +- src/gnet/gresolver_unix.cpp | 3 +- src/gnet/gresolver_win32.cpp | 2 +- src/gnet/gresolverinfo.cpp | 2 +- src/gnet/gresolverinfo.h | 18 +- src/gnet/gserver.cpp | 19 +- src/gnet/gserver.h | 12 +- src/gnet/gsimpleclient.cpp | 2 +- src/gnet/gsimpleclient.h | 14 +- src/gnet/gsimpleclient_unix.cpp | 2 +- src/gnet/gsimpleclient_win32.cpp | 2 +- src/gnet/gsocket.cpp | 7 +- src/gnet/gsocket.h | 15 +- src/gnet/gsocket_unix.cpp | 2 +- src/gnet/gsocket_win32.cpp | 2 +- src/gnet/gsocketprotocol.cpp | 47 +- src/gnet/gsocketprotocol.h | 4 +- src/gnet/gtimer.cpp | 2 +- src/gnet/gtimer.h | 2 +- src/gnet/gtimerlist.cpp | 5 +- src/gnet/gtimerlist.h | 2 +- src/gnet/mingw.mak | 4 +- src/gpop/Makefile.am | 41 +- src/gpop/Makefile.in | 83 +- src/gpop/gpop.h | 2 +- src/gpop/gpop_disabled.cpp | 94 + src/gpop/gpopauth.cpp | 2 +- src/gpop/gpopauth.h | 2 +- src/gpop/gpopsecrets.cpp | 6 +- src/gpop/gpopsecrets.h | 4 +- src/gpop/gpopsecrets_unix.cpp | 2 +- src/gpop/gpopsecrets_win32.cpp | 5 +- src/gpop/gpopserver.cpp | 18 +- src/gpop/gpopserver.h | 6 +- src/gpop/gpopserverprotocol.cpp | 13 +- src/gpop/gpopserverprotocol.h | 4 +- src/gpop/gpopstore.cpp | 8 +- src/gpop/gpopstore.h | 2 +- src/gpop/mingw.mak | 2 +- src/gsmtp/Makefile.am | 83 +- src/gsmtp/Makefile.in | 170 +- src/gsmtp/gadminserver.cpp | 12 +- src/gsmtp/gadminserver.h | 7 +- src/gsmtp/gbase64.cpp | 3 +- src/gsmtp/gbase64.h | 2 +- src/gsmtp/gclientprotocol.cpp | 51 +- src/gsmtp/gclientprotocol.h | 10 +- src/gsmtp/gexecutableprocessor.cpp | 6 +- src/gsmtp/gexecutableprocessor.h | 2 +- src/gsmtp/gexecutableverifier.cpp | 18 +- src/gsmtp/gexecutableverifier.h | 4 +- src/gsmtp/gfactoryparser.cpp | 2 +- src/gsmtp/gfactoryparser.h | 2 +- src/gsmtp/gfilestore.cpp | 26 +- src/gsmtp/gfilestore.h | 12 +- src/gsmtp/ginternalverifier.cpp | 60 + src/gsmtp/ginternalverifier.h | 67 + src/gsmtp/gmessagestore.cpp | 2 +- src/gsmtp/gmessagestore.h | 2 +- src/gsmtp/gmessagestore_unix.cpp | 2 +- src/gsmtp/gmessagestore_win32.cpp | 5 +- src/gsmtp/gnetworkprocessor.cpp | 2 +- src/gsmtp/gnetworkprocessor.h | 2 +- src/gsmtp/gnetworkverifier.cpp | 20 +- src/gsmtp/gnetworkverifier.h | 2 +- src/gsmtp/gnewfile.cpp | 35 +- src/gsmtp/gnewfile.h | 8 +- src/gsmtp/gnewmessage.cpp | 2 +- src/gsmtp/gnewmessage.h | 6 +- src/gsmtp/gnullprocessor.cpp | 2 +- src/gsmtp/gnullprocessor.h | 2 +- src/gsmtp/gprocessor.cpp | 2 +- src/gsmtp/gprocessor.h | 2 +- src/gsmtp/gprocessorfactory.h | 2 +- src/gsmtp/gprocessorfactory_exec_disabled.cpp | 41 + ...cpp => gprocessorfactory_exec_enabled.cpp} | 12 +- src/gsmtp/gprotocolmessage.cpp | 2 +- src/gsmtp/gprotocolmessage.h | 38 +- src/gsmtp/gprotocolmessageforward.cpp | 8 +- src/gsmtp/gprotocolmessageforward.h | 7 +- src/gsmtp/gprotocolmessagestore.cpp | 15 +- src/gsmtp/gprotocolmessagestore.h | 6 +- src/gsmtp/grequestclient.cpp | 2 +- src/gsmtp/grequestclient.h | 2 +- src/gsmtp/gsasl.h | 3 +- src/gsmtp/gsasl_gnu.cpp | 2 +- src/gsmtp/gsasl_native.cpp | 8 +- src/gsmtp/gsasl_none.cpp | 132 + src/gsmtp/gsecrets.h | 9 +- src/gsmtp/{gsecrets.cpp => gsecrets_full.cpp} | 22 +- src/gsmtp/gsecrets_none.cpp | 62 + src/gsmtp/gserverprotocol.cpp | 89 +- src/gsmtp/gserverprotocol.h | 14 +- src/gsmtp/gsmtp.h | 2 +- src/gsmtp/gsmtpclient.cpp | 17 +- src/gsmtp/gsmtpclient.h | 8 +- src/gsmtp/gsmtpserver.cpp | 29 +- src/gsmtp/gsmtpserver.h | 32 +- src/gsmtp/gspamclient.cpp | 8 +- src/gsmtp/gspamclient.h | 2 +- src/gsmtp/gspamprocessor.cpp | 2 +- src/gsmtp/gspamprocessor.h | 2 +- src/gsmtp/gstoredfile.cpp | 25 +- src/gsmtp/gstoredfile.h | 8 +- src/gsmtp/gstoredmessage.cpp | 2 +- src/gsmtp/gstoredmessage.h | 4 +- src/gsmtp/gverifier.cpp | 61 +- src/gsmtp/gverifier.h | 50 +- src/gsmtp/gverifierfactory.h | 2 +- src/gsmtp/gverifierfactory_exec_disabled.cpp | 41 + ....cpp => gverifierfactory_exec_enabled.cpp} | 11 +- src/gsmtp/gverifierstatus.cpp | 83 + src/gsmtp/gverifierstatus.h | 78 + src/gsmtp/mingw.mak | 10 +- src/gssl/Makefile.am | 15 +- src/gssl/Makefile.in | 41 +- src/gssl/gssl.h | 2 +- src/gssl/gssl_none.cpp | 2 +- src/gssl/gssl_openssl.cpp | 2 +- src/gssl/mingw.mak | 2 +- src/gui/Info.plist | 17 - src/gui/Makefile.am | 125 +- src/gui/Makefile.in | 246 +- src/gui/boot.h | 4 +- src/gui/boot_mac.cpp | 64 + src/gui/boot_unix.cpp | 63 + src/gui/{boot.cpp => boot_win32.cpp} | 34 +- src/gui/dir.cpp | 100 +- src/gui/dir.h | 82 +- src/gui/dir_mac.cpp | 144 + src/gui/dir_unix.cpp | 117 +- src/gui/dir_win32.cpp | 53 +- src/gui/emailrelay-icon.icns | Bin 0 -> 46906 bytes src/gui/emailrelay-icon.png | Bin 1740 -> 11856 bytes src/gui/gcominit.h | 5 +- src/gui/gdialog.cpp | 7 +- src/gui/gdialog.h | 7 +- src/gui/glink.h | 8 +- src/gui/glink_mac.cpp | 130 + src/gui/glink_unix.cpp | 188 ++ src/gui/{glink.cpp => glink_win32.cpp} | 119 +- src/gui/gpage.cpp | 24 +- src/gui/gpage.h | 10 +- src/gui/guimain.cpp | 202 +- src/gui/guistart.cpp | 124 + src/gui/gunpack.cpp | 63 +- src/gui/gunpack.h | 45 +- src/gui/installer.cpp | 617 ++-- src/gui/installer.h | 8 +- src/gui/legal.cpp | 4 +- src/gui/legal.h | 2 +- src/gui/mac.mak | 72 - src/gui/mingw.mak | 9 +- src/gui/mock | 2 +- src/gui/pack.cpp | 77 +- src/gui/pages.cpp | 507 ++-- src/gui/pages.h | 90 +- src/gui/qt.h | 2 +- src/gui/run.c | 14 +- src/gui/state.cpp | 129 + src/gui/state.h | 79 + src/gui/unpack.c | 75 +- src/gui/unpack.h | 17 +- src/gui/unpackmain.c | 68 + src/main/Makefile.am | 96 +- src/main/Makefile.in | 184 +- src/main/admin.h | 64 + src/main/admin_disabled.cpp | 46 + src/main/admin_enabled.cpp | 80 + src/main/commandline.cpp | 433 --- src/main/commandline.h | 65 +- src/main/commandline_full.cpp | 667 +++++ src/main/commandline_simple.cpp | 185 ++ src/main/common.dsp | 24 +- src/main/configuration.cpp | 262 +- src/main/configuration.h | 52 +- src/main/doxygen.cfg | 17 +- src/main/doxygen.h | 16 +- src/main/emailrelay.dsp | 6 +- src/main/emailrelay.rc | 3 +- src/main/filter.cpp | 6 +- src/main/filter.h | 2 +- src/main/filter_copy.cpp | 2 +- src/main/icon-32.ico | Bin 766 -> 0 bytes src/main/icon1.ico | Bin 0 -> 25214 bytes src/main/icon2.ico | Bin 767 -> 766 bytes src/main/icon3.ico | Bin 767 -> 767 bytes src/main/icon4.ico | Bin 767 -> 767 bytes src/main/icon5.ico | Bin 766 -> 0 bytes src/main/legal.cpp | 4 +- src/main/legal.h | 2 +- src/main/main.cpp | 2 +- src/main/mingw.c | 2 +- src/main/mingw.mak | 5 +- src/main/news.cpp | 2 +- src/main/news.h | 2 +- src/main/output.cpp | 2 +- src/main/output.h | 2 +- src/main/passwd.cpp | 2 +- src/main/poke.c | 2 +- src/main/run.cpp | 351 ++- src/main/run.h | 18 +- src/main/service_install.cpp | 2 +- src/main/service_install.h | 2 +- src/main/service_remove.cpp | 2 +- src/main/service_remove.h | 2 +- src/main/service_wrapper.cpp | 12 +- src/main/start.cpp | 244 ++ src/main/submit.cpp | 4 +- src/main/winapp.cpp | 2 +- src/main/winapp.h | 2 +- src/main/winform.cpp | 58 +- src/main/winform.h | 7 +- src/main/winmain.cpp | 6 +- src/main/winmenu.cpp | 2 +- src/main/winmenu.h | 8 +- src/mingw-common.mak | 14 +- src/mingw.mak | 2 +- src/win32/Makefile.am | 2 +- src/win32/Makefile.in | 7 +- src/win32/gappbase.cpp | 2 +- src/win32/gappbase.h | 2 +- src/win32/gappinst.cpp | 2 +- src/win32/gappinst.h | 2 +- src/win32/gcontrol.cpp | 11 +- src/win32/gcontrol.h | 2 +- src/win32/gcracker.cpp | 11 +- src/win32/gcracker.h | 5 +- src/win32/gdc.cpp | 14 +- src/win32/gdc.h | 2 +- src/win32/gdialog.cpp | 20 +- src/win32/gdialog.h | 13 +- src/win32/gpump.cpp | 2 +- src/win32/gpump.h | 2 +- src/win32/gpump_dialog.cpp | 3 +- src/win32/gscmap.cpp | 2 +- src/win32/gscmap.h | 5 +- src/win32/gsize.h | 2 +- src/win32/gtray.cpp | 6 +- src/win32/gtray.h | 2 +- src/win32/gwinbase.cpp | 5 +- src/win32/gwinbase.h | 2 +- src/win32/gwindow.cpp | 20 +- src/win32/gwindow.h | 2 +- src/win32/gwinhid.cpp | 2 +- src/win32/gwinhid.h | 2 +- src/win32/mingw.mak | 2 +- test/AdminClient.pm | 2 +- test/Check.pm | 2 +- test/Filter.pm | 2 +- test/Makefile.am | 29 +- test/Makefile.in | 60 +- test/PopClient.pm | 2 +- test/Port.pm | 2 +- test/Scanner.pm | 2 +- test/Server.pm | 27 +- test/SmtpClient.pm | 25 +- test/System.pm | 2 +- test/TestServer.pm | 2 +- test/emailrelay-chain-test.sh_ | 5 +- test/emailrelay-soak-test.sh_ | 2 +- test/emailrelay-test.pl_ | 171 +- test/emailrelay-test.sh_ | 2 +- test/emailrelay_test_scanner.cpp | 6 +- test/emailrelay_test_server.cpp | 26 +- 496 files changed, 18434 insertions(+), 5773 deletions(-) create mode 100644 README.mac create mode 100644 README.mips create mode 100644 autogen.sh create mode 100644 bin/configure-mac.sh create mode 100644 bin/emailrelay-change-auth.js create mode 100644 bin/emailrelay-multicast.sh_ create mode 100644 bin/fragment.pl_ create mode 100644 bin/make-bundle.sh_ create mode 100644 bin/make-qt-enabled.sh_ create mode 100644 bin/make-setup.sh_ create mode 100644 bin/startup-mac.plist create mode 100644 bootstrap create mode 100644 emailrelay-gui.xcodeproj/project.pbxproj create mode 100644 emailrelay.xcodeproj/project.pbxproj rename {lib/sunpro5 => extra}/Makefile.am (87%) create mode 100644 extra/Makefile.in create mode 100644 extra/mips/Makefile.am rename {lib/sunpro5 => extra/mips}/Makefile.in (95%) create mode 100644 extra/mips/README create mode 100644 extra/mips/configure-mips.sh_ create mode 100644 extra/mips/toolchain.mak delete mode 100644 lib/sunpro5/xar create mode 100644 src/fragments/Makefile.am create mode 100644 src/fragments/Makefile.in create mode 100644 src/fragments/empty.cpp create mode 100644 src/glib/garg_mac.cpp create mode 100644 src/glib/gdirectory_unix_glob.cpp create mode 100644 src/glib/gdirectory_unix_noglob.cpp rename src/{gssl/gssl.cpp => glib/ghostname.h} (72%) create mode 100644 src/glib/ghostname_unix.cpp create mode 100644 src/glib/ghostname_win32.cpp create mode 100644 src/glib/gidentity_disabled.cpp create mode 100644 src/glib/glimits.h create mode 100644 src/glib/gnewprocess.h create mode 100644 src/glib/gnewprocess_unix_exec_disabled.cpp create mode 100644 src/glib/gnewprocess_unix_exec_enabled.cpp create mode 100644 src/glib/gnewprocess_win32.cpp create mode 100644 src/gnet/glocal_dns_disabled.cpp rename src/gnet/{grequest.cpp => grequest_win32.cpp} (97%) create mode 100644 src/gnet/gresolver_dns_disabled.cpp create mode 100644 src/gpop/gpop_disabled.cpp create mode 100644 src/gsmtp/ginternalverifier.cpp create mode 100644 src/gsmtp/ginternalverifier.h create mode 100644 src/gsmtp/gprocessorfactory_exec_disabled.cpp rename src/gsmtp/{gprocessorfactory.cpp => gprocessorfactory_exec_enabled.cpp} (83%) create mode 100644 src/gsmtp/gsasl_none.cpp rename src/gsmtp/{gsecrets.cpp => gsecrets_full.cpp} (91%) create mode 100644 src/gsmtp/gsecrets_none.cpp create mode 100644 src/gsmtp/gverifierfactory_exec_disabled.cpp rename src/gsmtp/{gverifierfactory.cpp => gverifierfactory_exec_enabled.cpp} (85%) create mode 100644 src/gsmtp/gverifierstatus.cpp create mode 100644 src/gsmtp/gverifierstatus.h delete mode 100644 src/gui/Info.plist create mode 100644 src/gui/boot_mac.cpp create mode 100644 src/gui/boot_unix.cpp rename src/gui/{boot.cpp => boot_win32.cpp} (67%) create mode 100644 src/gui/dir_mac.cpp create mode 100644 src/gui/emailrelay-icon.icns create mode 100644 src/gui/glink_mac.cpp create mode 100644 src/gui/glink_unix.cpp rename src/gui/{glink.cpp => glink_win32.cpp} (65%) create mode 100644 src/gui/guistart.cpp delete mode 100644 src/gui/mac.mak create mode 100644 src/gui/state.cpp create mode 100644 src/gui/state.h create mode 100644 src/gui/unpackmain.c create mode 100644 src/main/admin.h create mode 100644 src/main/admin_disabled.cpp create mode 100644 src/main/admin_enabled.cpp delete mode 100644 src/main/commandline.cpp create mode 100644 src/main/commandline_full.cpp create mode 100644 src/main/commandline_simple.cpp delete mode 100644 src/main/icon-32.ico create mode 100644 src/main/icon1.ico delete mode 100644 src/main/icon5.ico create mode 100644 src/main/start.cpp diff --git a/AUTHORS b/AUTHORS index 853a322..e62e26b 100644 --- a/AUTHORS +++ b/AUTHORS @@ -4,10 +4,13 @@ Graeme Walker Binary distributions -------------------- -Binary distributions of E-MailRelay may include code from: +Binary distributions of E-MailRelay may include copyrighted code from: * OpenSSL Toolkit (http://www.openssl.org) * MinGW (http://www.mingw.org) * Trolltech Qt (http://trolltech.com) +These are distributed under licenses compatible with the GPLv3. Please +refer to their websites for further details. + This product includes software developed by the OpenSSL Project for use in the OpenSSL Toolkit. (http://www.openssl.org/) diff --git a/ChangeLog b/ChangeLog index 587a158..d6c3826 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,6 +1,22 @@ E-MailRelay Change Log ====================== +1.7 -> 1.8 +---------- +* Speed optimisations (as identified by KCachegrind/valgrind in KDevelop). +* Build-time size optimisations (eg. "./configure --disable-exec --enable-small-exceptions ..."). +* Build-time options to reduce runtime library dependencies (eg. "./configure --disable-dns --disable-identity"). +* New switch to limit the size of submitted messages ("--size"). +* New semantics for "--poll 0", providing a good alternative to "--immediate" when proxying. +* SMTP client protocol emits a RSET after a rejected recipient as a workround for broken server protocols. +* SMTP client protocol continues if the server advertises AUTH but the client has no authentication secrets. +* When a message cannot be forwarded the offending SMTP protocol response number, if any, is put in the envelope file. +* A warning is printed if logging is requested but both stderr and syslog are disabled. +* A cross-compiling toolchain builder script added for running on mips-based routers ("extra/mips"). +* New example scripts for SMTP multicasting and editing envelope files. +* Improved native support for Mac OS X (10.5) with graphical installation from disk image. +* Compatibility with gcc 2.95 restored. + 1.6 -> 1.7 ---------- * TLS/SSL support for SMTP using OpenSSL ("./configure --with-openssl" with "--client-tls" and "--server-tls"). diff --git a/INSTALL b/INSTALL index 30b8869..51424ee 100644 --- a/INSTALL +++ b/INSTALL @@ -8,9 +8,9 @@ FreeBSD etc. Windows specific installation instructions are in a separate document, "doc/windows.txt". The E-MailRelay "configure" script provides a few extra confiruation switches, -which are shown in the output of "./configure --help". The most important of -these is "--enable-fhs", which overrides all other directory modifiers, forcing -compliance with the File Hierarchy Standard. +which are shown in the output of "./configure --help". One of these is +"--enable-fhs", which sets the default directories to comply with the File +Hierarchy Standard. There are also a set of variables which can be defined on the "configure" command line for controlling all the installation directories in more detail, diff --git a/LICENSE b/LICENSE index 7055b7b..79443fd 100644 --- a/LICENSE +++ b/LICENSE @@ -1,93 +1,3 @@ Licenses ======== - -Source distributions --------------------- -Permission to copy E-MailRelay is under the terms of the GPLv3 license. The text -of the license is in the file "COPYING". - -Binary distributions --------------------- -Binary distributions of E-MailRelay may also include code from: -* OpenSSL Toolkit (http://www.openssl.org) -* MinGW (http://www.mingw.org) -* Trolltech Qt (http://trolltech.com) - -OpenSSL -------- -This product includes software developed by the OpenSSL Project -for use in the OpenSSL Toolkit. (http://www.openssl.org/) - -OpenSSL is dual-licensed, including the following: - - /* ==================================================================== - * Copyright (c) 1998-2007 The OpenSSL Project. All rights reserved. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in - * the documentation and/or other materials provided with the - * distribution. - * - * 3. All advertising materials mentioning features or use of this - * software must display the following acknowledgment: - * "This product includes software developed by the OpenSSL Project - * for use in the OpenSSL Toolkit. (http://www.openssl.org/)" - * - * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to - * endorse or promote products derived from this software without - * prior written permission. For written permission, please contact - * openssl-core@openssl.org. - * - * 5. Products derived from this software may not be called "OpenSSL" - * nor may "OpenSSL" appear in their names without prior written - * permission of the OpenSSL Project. - * - * 6. Redistributions of any form whatsoever must retain the following - * acknowledgment: - * "This product includes software developed by the OpenSSL Project - * for use in the OpenSSL Toolkit (http://www.openssl.org/)" - * - * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY - * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR - * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR - * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, - * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT - * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; - * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, - * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) - * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED - * OF THE POSSIBILITY OF SUCH DAMAGE. - * ==================================================================== - * - * This product includes cryptographic software written by Eric Young - * (eay@cryptsoft.com). This product includes software written by Tim - * Hudson (tjh@cryptsoft.com). - * - */ - -MinGW ------ -The MinGW runtime that is included in the Windows binary distributions of -E-MailRelay is uncopyrighted and in the public domain. - -Trolltech Qt ------------- -The Qt runtime that is included in the Windows binary distributions of -E-MailRelay is dual-licensed, including the GPLv2 (see http://www.gnu.org). -E-MailRelay is not a derived work and so the terms of the GPLv2 only apply to -the Qt runtime files within the E-MailRelay binary distribution. - -The Qt GUI Toolkit is Copyright (C) 1994-2006 Trolltech ASA. - -Qt source code is available from the Trolltech web site, -http://trolltech.com. - +See AUTHORS and COPYING. diff --git a/Makefile.am b/Makefile.am index 04ee43d..ceaa216 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1,5 +1,5 @@ # -## Copyright (C) 2001-2007 Graeme Walker +## Copyright (C) 2001-2008 Graeme Walker ## ## This program is free software: you can redistribute it and/or modify ## it under the terms of the GNU General Public License as published by @@ -14,8 +14,45 @@ ## You should have received a copy of the GNU General Public License ## along with this program. If not, see . # -EXTRA_DIST = emailrelay.spec ChangeLog README.windows LICENSE -SUBDIRS = src bin lib etc doc test + +EXTRA_DIST = \ + emailrelay.spec \ + ChangeLog \ + README.windows \ + README.mips \ + README.mac \ + LICENSE \ + bootstrap \ + autogen.sh \ + emailrelay-gui.xcodeproj/project.pbxproj \ + emailrelay.xcodeproj/project.pbxproj + +SUBDIRS = bin src lib etc doc test extra + e_doc_DATA = NEWS README ChangeLog + uninstall-local: -rmdir $(DESTDIR)$(e_docdir) 2>/dev/null + -for d in "$(DESTDIR)$(e_sysconfdir)" "$(DESTDIR)$(e_libexecdir)" "$(DESTDIR)$(e_examplesdir)" "$(DESTDIR)$(e_spooldir)" "$(DESTDIR)$(e_initdir)" "$(DESTDIR)$(e_docdir)/man/man1" "$(DESTDIR)$(e_docdir)/man" "$(DESTDIR)$(e_docdir)" ; do rmdir "$$d" 2>/dev/null ; done + +RPM_ROOT=/usr/src/rpm +RPM=$(RPM_ROOT)/RPMS/i386/emailrelay-$(VERSION)-1.i386.rpm +DEB=emailrelay_$(VERSION)-1_i386.deb +TAR=emailrelay-$(VERSION).tar.gz +.PHONY: rpm +rpm: $(RPM) +$(RPM): dist + -rm -rf $(RPM_ROOT)/BUILD/emailrelay-$(VERSION) + cp $(TAR) $(RPM_ROOT)/SOURCES/emailrelay-$(VERSION)-src.tar.gz + cp emailrelay.spec $(RPM_ROOT)/SPECS + chown root:root $(RPM_ROOT)/SPECS/emailrelay.spec + rpmbuild -ba $(RPM_ROOT)/SPECS/emailrelay.spec +.PHONY: deb +deb: $(DEB) +$(DEB): $(RPM) + -mv emailrelay-$(VERSION) emailrelay-$(VERSION).old.$$ + alien --to-deb --generate --single --keep-version $(RPM) + sed -i 's/^Section:.*/Section: mail/' emailrelay-$(VERSION)/debian/control + sed -i 's/^Maintainer:.*/Maintainer: Graeme Walker /' emailrelay-$(VERSION)/debian/control + cd emailrelay-$(VERSION) && debian/rules binary + diff --git a/Makefile.in b/Makefile.in index 5b11b5b..0119256 100644 --- a/Makefile.in +++ b/Makefile.in @@ -1,8 +1,8 @@ -# Makefile.in generated by automake 1.10 from Makefile.am. +# Makefile.in generated by automake 1.10.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004, 2005, 2006 Free Software Foundation, Inc. +# 2003, 2004, 2005, 2006, 2007, 2008 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. @@ -14,6 +14,9 @@ @SET_MAKE@ +# +# + VPATH = @srcdir@ pkgdatadir = $(datadir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ @@ -103,6 +106,7 @@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ +FRAGMENTS_LIST = @FRAGMENTS_LIST@ GREP = @GREP@ GZIP = @GZIP@ HAVE_DOXYGEN = @HAVE_DOXYGEN@ @@ -112,7 +116,6 @@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -IP = @IP@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ @@ -136,7 +139,6 @@ QT_LIBS = @QT_LIBS@ RANLIB = @RANLIB@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ -SSL = @SSL@ SSL_LIBS = @SSL_LIBS@ STATIC_END = @STATIC_END@ STATIC_START = @STATIC_START@ @@ -191,12 +193,24 @@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ +EXTRA_DIST = \ + emailrelay.spec \ + ChangeLog \ + README.windows \ + README.mips \ + README.mac \ + LICENSE \ + bootstrap \ + autogen.sh \ + emailrelay-gui.xcodeproj/project.pbxproj \ + emailrelay.xcodeproj/project.pbxproj -# -# -EXTRA_DIST = emailrelay.spec ChangeLog README.windows LICENSE -SUBDIRS = src bin lib etc doc test +SUBDIRS = bin src lib etc doc test extra e_doc_DATA = NEWS README ChangeLog +RPM_ROOT = /usr/src/rpm +RPM = $(RPM_ROOT)/RPMS/i386/emailrelay-$(VERSION)-1.i386.rpm +DEB = emailrelay_$(VERSION)-1_i386.deb +TAR = emailrelay-$(VERSION).tar.gz all: config.h $(MAKE) $(AM_MAKEFLAGS) all-recursive @@ -344,8 +358,8 @@ ID: $(HEADERS) $(SOURCES) $(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; } \ - END { for (i in files) print i; }'`; \ + $(AWK) '{ files[$$0] = 1; nonemtpy = 1; } \ + END { if (nonempty) { for (i in files) print i; }; }'`; \ mkid -fID $$unique tags: TAGS @@ -370,8 +384,8 @@ TAGS: tags-recursive $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | \ - $(AWK) ' { files[$$0] = 1; } \ - END { for (i in files) print i; }'`; \ + $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ + END { if (nonempty) { for (i in files) print i; }; }'`; \ if test -z "$(ETAGS_ARGS)$$tags$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ @@ -381,13 +395,12 @@ ctags: CTAGS CTAGS: ctags-recursive $(HEADERS) $(SOURCES) config.h.in $(TAGS_DEPENDENCIES) \ $(TAGS_FILES) $(LISP) tags=; \ - here=`pwd`; \ 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; } \ - END { for (i in files) print i; }'`; \ + $(AWK) '{ files[$$0] = 1; nonempty = 1; } \ + END { if (nonempty) { for (i in files) print i; }; }'`; \ test -z "$(CTAGS_ARGS)$$tags$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$tags $$unique @@ -458,6 +471,10 @@ dist-bzip2: distdir tardir=$(distdir) && $(am__tar) | bzip2 -9 -c >$(distdir).tar.bz2 $(am__remove_distdir) +dist-lzma: distdir + tardir=$(distdir) && $(am__tar) | lzma -9 -c >$(distdir).tar.lzma + $(am__remove_distdir) + dist-tarZ: distdir tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z $(am__remove_distdir) @@ -484,6 +501,8 @@ distcheck: dist GZIP=$(GZIP_ENV) gunzip -c $(distdir).tar.gz | $(am__untar) ;;\ *.tar.bz2*) \ bunzip2 -c $(distdir).tar.bz2 | $(am__untar) ;;\ + *.tar.lzma*) \ + unlzma -c $(distdir).tar.lzma | $(am__untar) ;;\ *.tar.Z*) \ uncompress -c $(distdir).tar.Z | $(am__untar) ;;\ *.shar.gz*) \ @@ -637,7 +656,7 @@ uninstall-am: uninstall-e_docDATA uninstall-local .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-shar dist-tarZ dist-zip distcheck distclean \ + dist-lzma dist-shar dist-tarZ dist-zip distcheck distclean \ distclean-generic distclean-hdr distclean-tags distcleancheck \ distdir distuninstallcheck dvi dvi-am html html-am info \ info-am install install-am install-data install-data-am \ @@ -650,8 +669,26 @@ uninstall-am: uninstall-e_docDATA uninstall-local pdf-am ps ps-am tags tags-recursive uninstall uninstall-am \ uninstall-e_docDATA uninstall-local + uninstall-local: -rmdir $(DESTDIR)$(e_docdir) 2>/dev/null + -for d in "$(DESTDIR)$(e_sysconfdir)" "$(DESTDIR)$(e_libexecdir)" "$(DESTDIR)$(e_examplesdir)" "$(DESTDIR)$(e_spooldir)" "$(DESTDIR)$(e_initdir)" "$(DESTDIR)$(e_docdir)/man/man1" "$(DESTDIR)$(e_docdir)/man" "$(DESTDIR)$(e_docdir)" ; do rmdir "$$d" 2>/dev/null ; done +.PHONY: rpm +rpm: $(RPM) +$(RPM): dist + -rm -rf $(RPM_ROOT)/BUILD/emailrelay-$(VERSION) + cp $(TAR) $(RPM_ROOT)/SOURCES/emailrelay-$(VERSION)-src.tar.gz + cp emailrelay.spec $(RPM_ROOT)/SPECS + chown root:root $(RPM_ROOT)/SPECS/emailrelay.spec + rpmbuild -ba $(RPM_ROOT)/SPECS/emailrelay.spec +.PHONY: deb +deb: $(DEB) +$(DEB): $(RPM) + -mv emailrelay-$(VERSION) emailrelay-$(VERSION).old.$$ + alien --to-deb --generate --single --keep-version $(RPM) + sed -i 's/^Section:.*/Section: mail/' emailrelay-$(VERSION)/debian/control + sed -i 's/^Maintainer:.*/Maintainer: Graeme Walker /' emailrelay-$(VERSION)/debian/control + cd emailrelay-$(VERSION) && debian/rules binary # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: diff --git a/README b/README index 80e4f85..df69c28 100644 --- a/README +++ b/README @@ -105,19 +105,21 @@ and on Windows 98 using: Versions of the code have also been built successfully on: * MacOS X 10.3.9 +* MacOS X 10.5.1 using gcc 4.0.1 on G4 PPC hardware * FreeBSD on Intel hardware * Linux on Alpha hardware (Debian 2.2) * Linux on Sparc hardware * Linux on RS6000 PPC hardware +* Linux using intel c++ 6.0 +* Linux using intel c++ 10.1 +* Linux 2.4.20 using gcc 3.4.6 on MIPS (mipsel) * Solaris 8 using gcc on Sparc hardware * Solaris 8 using WorkShop 5.0 -* Linux using intel c++ 6.0 * Windows NT 4.0 using MSVC 6.0 * Windows NT 4.0 using Cygwin (DLL 1.3.22) and gcc 3.2 * Windows NT 4.0 using MinGW 2.0.0 and gcc 3.2 * Windows XP using MinGW 3.1.0 gcc 3.4.2 - Feedback -------- Please feel free to e-mail the author at diff --git a/README.mac b/README.mac new file mode 100644 index 0000000..0f9383d --- /dev/null +++ b/README.mac @@ -0,0 +1,35 @@ +E-MailRelay on Mac OS X +======================= + +Building from source +-------------------- +E-MailRelay can be built on a Mac as if it is a vanilla unix system; the +standard "configure; make; sudo make install" procedure for building and +installing from source should work well enough. + +For best results use the "bin/configure-mac.sh" script to run "configure" with +directory paths that are more Mac-like (see below). + +The "make" step will only build executables for the native architecture. Xcode +can be used to build universal binaries. Project files for xcode 3 are supplied. + +Directories +----------- +The preferred installation directories are: +* "/Applications/E-MailRelay" for the application +* "/Applications/E-MailRelay/Documentation" for the documentation +* "/Applications/E-MailRelay" for the configuration (not "/Library/Preferences/E-MailRelay") +* "/Library/Mail/Spool" for the spool directory +* "/Library/StartupItems/E-MailRelay" for the boot-time startup script + +Installation can also be done into the User "domain", ie. under "~/Applications" +and "~/Library" using "make install DESTDIR=~", although starting up at +boot-time will not then work. + +Moving the system after installation, or installing to any other directories, +is not guaranteed to work correctly. + +Binary distribution +------------------- +Graphical installation from the disk image has been developed using Mac OS X +10.5 ("Leopard"). Bug reports for other versions of OS X are welcome. diff --git a/README.mips b/README.mips new file mode 100644 index 0000000..c23fbdf --- /dev/null +++ b/README.mips @@ -0,0 +1,24 @@ +E-MailRelay MIPS +================ +To help with running E-MailRelay on MIPS-based routers, such as the Buffalo +WHR-G54S, a makefile for building a cross-compiler toolchain is provided as +"extra/mips/toolchain.mak". + +The shell script "extra/mips/configure-mips.sh" can be used to run the main +E-MailRelay "configure" script with all the size optimisations suitable for an +embedded target system. + +These build-time size optimisations yield the following approximate savings for +the main executable: + +* "--disable-exec" 184k +* "--enable-small-config" 121k +* "--disable-pop" 121k +* "--disable-auth" 109k +* "--disable-debug" 67k +* "--disable-admin" 63k +* "--enable-small-exceptions" 46k +* "--enable-small-fragments" 32k +* "--disable-proxy" 30k +* "--disable-dns" 26k +* "--disable-verbose" 15k diff --git a/README.windows b/README.windows index d4cee60..75cd6f4 100644 --- a/README.windows +++ b/README.windows @@ -1 +1,78 @@ -See doc/windows.txt +E-MailRelay Windows +=================== + +Setup program +------------- +Installing E-MailRelay on Windows should be straightforward if you have +self-extracting archive program "emailrelay-setup.exe". Make sure that the +setup program is in a writeable directory with plenty of space on the disk +because when you run it it will extract an installation GUI program plus +dependent DLLs in into the same directory. + +The installation GUI will take you through the installation options and then +install the run-time files into your chosen directory. + +Manual installation +------------------- +In summary, the manual installation process for Windows for when you do not have +the self-extracting setup program, is as follows: +* Create a new program directory "Program Files\emailrelay" +* Unzip into "Program Files\emailrelay" +* Create a new spool directory "\spool\emailrelay" +* Create a new text file, eg. "c:\emailrelay.auth", to contain account details +* Add your ISP account details to "emailrelay.auth" with a line like "login client myaccount mypassword" +* Drag "emailrelay.exe" onto the desktop to create a shortcut for the server. +* Drag again to create a shortcut for the forwarding client. +* Add "--as-server --verbose" to the server shortcut properties. +* Add "--as-client myisp.net:smtp --hidden --client-auth c:/emailrelay.auth" to the client shortcut. + +Move shortcuts to "Startup" folders as necessary. + +Running as a service +-------------------- +To manually install E-MailRelay as a service so that it starts up automatically +at boot-time you must first create a one-line batch file called +"emailrelay-start.bat" in the main E-MailRelay directory containing +the full E-MailRelay server command-line. Then run "emailrelay-service --install" +to install the service. + +When the E-MailRelay server is run in this way the "--no-daemon" and "--hidden" +switches are added automatically to whatever is in the "emailrelay-start" batch +file, so that there is no user interface. (The "--no-daemon" switch on Windows +changes the interface from using the system-tray to using a normal window, and +the "--hidden" switch suppresses the window and any message boxes.) + +Note that the batch file and the main E-MailRelay executable must be in the same +directory. + +If you need to run multiple E-MailRelay services then pass a unique service name +on the "emailrelay-server --install " command-line. This name is used to +derive the name of the "-start.bat" batch file that contains the +E-MailRelay server's command-line switches so you will need to create this too. + +Diagnostics +----------- +E-MailRelay normally writes errors and warnings into the system event log, which +you can view by running "eventvwr.exe". You can increase the verbosity by adding +the "--verbose" switch to the E-MailRelay command-line, typically by editing the +"emailrelay-start.bat" batch script. + +The E-MailRelay server also logs to the standard error stream, however the +"--as-server" and "--as-proxy" switches implicitly incorporate "--close-stderr" +so with these switches the standard error logging will stop soon after startup. + +To get continuous logging to a log file you should replace "--as-server" with +"--log" and "--as-proxy" with "--immediate --forward-to" and then use "2>" to +redirect the standard error stream, eg: + + "c:\program files\emailrelay\emailrelay.exe" --log -v -L ... > c:\temp.out 2>&1 + +Building from source +-------------------- +E-MailRelay can be compiled using Microsoft Visual Studio C++ (MSVC) 6 or MinGW, +although the installation/configuration GUI can only be built with MinGW because +of its dependence on Qt. + +There is a Visual Studio workspace file for MSVC 6 in the "src" directory. For +MinGW please follow the guidelines in "mingw-common.mak" which is also in the +"src" directory. diff --git a/acinclude.m4 b/acinclude.m4 index 341e5b7..c6291b1 100644 --- a/acinclude.m4 +++ b/acinclude.m4 @@ -1,4 +1,4 @@ -dnl Copyright (C) 2001-2007 Graeme Walker +dnl Copyright (C) 2001-2008 Graeme Walker dnl dnl This program is free software: you can redistribute it and/or modify dnl it under the terms of the GNU General Public License as published by @@ -14,7 +14,9 @@ dnl You should have received a copy of the GNU General Public License dnl along with this program. If not, see . dnl === -dnl socketlen_t +dnl aclocal-type-socketlen-t +dnl +dnl Defines HAVE_SOCKLEN_T. dnl AC_DEFUN([ACLOCAL_TYPE_SOCKLEN_T], [AC_CACHE_CHECK([for socklen_t],[aclocal_type_socklen_t], @@ -27,13 +29,15 @@ AC_DEFUN([ACLOCAL_TYPE_SOCKLEN_T], aclocal_type_socklen_t=no ) ]) if test $aclocal_type_socklen_t = yes; then - AC_DEFINE(HAVE_SOCKLEN_T, 1,[Define to 1 if socklen_t type definition in sys/socket.h]) + AC_DEFINE(HAVE_SOCKLEN_T,1,[Define to 1 if socklen_t type definition in sys/socket.h]) else - AC_DEFINE(HAVE_SOCKLEN_T, 0,[Define to 1 if socklen_t type definition in sys/socket.h]) + AC_DEFINE(HAVE_SOCKLEN_T,0,[Define to 1 if socklen_t type definition in sys/socket.h]) fi ]) -dnl ipv6 +dnl aclocal-check-ipv6 +dnl +dnl Defines HAVE_IPV6. dnl AC_DEFUN([ACLOCAL_CHECK_IPV6], [AC_CACHE_CHECK([for ipv6],[aclocal_ipv6], @@ -54,7 +58,10 @@ AC_DEFUN([ACLOCAL_CHECK_IPV6], fi ]) -dnl getipnodebyname for ipv6 rfc2553 +dnl aclocal-check-getipnodebyname +dnl +dnl Defines HAVE_GETIPNODEBYNAME if the ipv6 function +dnl getipnodebyname() as per rfc2553 is available. dnl AC_DEFUN([ACLOCAL_CHECK_GETIPNODEBYNAME], [AC_CACHE_CHECK([for getipnodebyname],[aclocal_getipnodebyname], @@ -76,7 +83,9 @@ AC_DEFUN([ACLOCAL_CHECK_GETIPNODEBYNAME], fi ]) -dnl check for sin6_len in sockaddr_in6 +dnl aclocal-check-sin6-len +dnl +dnl Defines HAVE_SIN6_LEN if sin6_len is in sockaddr_in6. dnl AC_DEFUN([ACLOCAL_CHECK_SIN6_LEN], [AC_CACHE_CHECK([for sin6_len],[aclocal_sin6_len], @@ -96,7 +105,9 @@ AC_DEFUN([ACLOCAL_CHECK_SIN6_LEN], fi ]) -dnl setgroups +dnl aclocal-check-setgroups +dnl +dnl Defines HAVE_SETGROUPS. dnl AC_DEFUN([ACLOCAL_CHECK_SETGROUPS], [AC_CACHE_CHECK([for setgroups],[aclocal_setgroups], @@ -118,6 +129,8 @@ AC_DEFUN([ACLOCAL_CHECK_SETGROUPS], dnl gmtime_r dnl +dnl Defines HAVE_GMTIME_R. +dnl AC_DEFUN([ACLOCAL_CHECK_GMTIME_R], [AC_CACHE_CHECK([for gmtime_r],[aclocal_gmtime_r], [ @@ -134,7 +147,9 @@ AC_DEFUN([ACLOCAL_CHECK_GMTIME_R], fi ]) -dnl localtime_r +dnl aclocal-check-localtime_r +dnl +dnl Defines HAVE_LOCALTIME_R. dnl AC_DEFUN([ACLOCAL_CHECK_LOCALTIME_R], [AC_CACHE_CHECK([for localtime_r],[aclocal_localtime_r], @@ -152,8 +167,10 @@ AC_DEFUN([ACLOCAL_CHECK_LOCALTIME_R], fi ]) -dnl buggy ctime -dnl sunpro5 ctime + unistd.h doesnt compile -- fix with time.h first +dnl aclocal-check-buggy-ctime +dnl +dnl Defines HAVE_BUGGY_CTIME if ctime + unistd.h doesnt compile. +dnl Needed for old versions of sunpro. Remove soon. dnl AC_DEFUN([ACLOCAL_CHECK_BUGGY_CTIME], [AC_CACHE_CHECK([for buggy ctime],[aclocal_buggy_ctime], @@ -172,91 +189,320 @@ AC_DEFUN([ACLOCAL_CHECK_BUGGY_CTIME], fi ]) -dnl compiler name and version -dnl used for -Ilib/ -- only needed for pre 3.0 -dnl gcc -- maps gcc2.96 onto gcc2.95 +dnl aclocal-compiler-version +dnl +dnl Sets COMPILER_VERSION in makefiles. +dnl +dnl Used for -Ilib/. Doesnt work very well but only +dnl needed for pre 3.0 gcc. Maps gcc2.96 onto gcc2.95. dnl AC_DEFUN([ACLOCAL_COMPILER_VERSION], [ changequote(<<,>>) - COMPILER_VERSION=`$CXX --version 2>/dev/null | sed q | sed 's/[^0-9 .]*//g;s/\./ /g;s/^ *//;s/ /./;s/ .*//;s/^/gcc/' | sed 's/gcc2.96/gcc2.95/'` - if test -z "${COMPILER_VERSION}" - then - COMPILER_VERSION=`$CXX -V 2>&1 | sed q | grep WorkShop | sed 's/[^0-9]*//;s/[ \.].*//;s/^/sunpro/'` - fi + COMPILER_VERSION_GCC=`$CXX --version 2>/dev/null | sed q | grep GCC | sed 's/[a-zA-Z][a-zA-Z]*[0-9]*//g' | sed 's/[^0-9 .]*//g;s/\./ /g;s/^ *//;s/ /./;s/ .*//;s/^/gcc/' | sed 's/gcc2.96/gcc2.95/'` + COMPILER_VERSION_SUNPRO=`$CXX -V 2>&1 | sed q | grep WorkShop | sed 's/[^0-9]*//;s/[ \.].*//;s/^/sunpro/'` + COMPILER_VERSION_ICC=`$CXX --version 2>&1 | sed q | grep ICC | sed 's/[^0-9]*//;s/[ \.].*//;s/^/icc/'` changequote([,]) + COMPILER_VERSION="${COMPILER_VERSION_GCC}${COMPILER_VERSION_SUNPRO}${COMPILER_VERSION_ICC}" AC_SUBST(COMPILER_VERSION) ]) -dnl enable-debug +dnl aclocal-check-qt4 dnl -AC_DEFUN([ENABLE_DEBUG], +dnl Sets the $MOC variable and MOC in makefiles to the moc +dnl path if qt4 is found. Also sets the $aclocal_moc +dnl variable to the same value if the moc is from qt4. +dnl +dnl In the implementation remember that AC_PATH_PROG does +dnl nothing if the variable is already defined, and that +dnl it does an internal AC_SUBST. +dnl +dnl The PKG_CHECK_MODULES macro is used to modify CFLAGS etc. +dnl +AC_DEFUN([ACLOCAL_CHECK_QT4], [ -if test "$enable_debug" = "yes" -then - AC_DEFINE(_DEBUG,1,[Define to enable extra debug messages at compile-time]) -fi -]) + PKG_CHECK_MODULES(QT,QtGui >= 4.0.1,[qt4=yes],[AC_MSG_RESULT([no])]) -dnl enable-gui -dnl -AC_DEFUN([ENABLE_GUI], -[ -qt4="no" -qt4moc="no" -if test "$enable_gui" = "no" -then - AC_DEFINE(HAVE_GUI,0,[Define to 1 to enable gui code]) -else - PKG_CHECK_MODULES(QT,QtGui >= 4.0.1,[qt4=yes],[AC_MSG_RESULT([no])]) - if test "$qt4" = "yes" + MOC="${e_qtmoc}" + AC_PATH_PROG(MOC,moc) + + if test "$MOC" != "" then - MOC="${e_qtmoc}" - AC_PATH_PROG(MOC,moc) AC_MSG_CHECKING([moc is for qt 4]) if test x$GREP = x ; then GREP=grep ; fi if test -x "$MOC" -a "`$MOC -v 2>&1 | $GREP 'Qt 4'`" != "" ; then AC_MSG_RESULT([yes]) - qt4moc="yes" + aclocal_moc="$MOC" else AC_MSG_RESULT([no]) + aclocal_moc="" fi - else - QT_LIBS="" - AC_SUBST(QT_LIBS) fi -fi -if test "$qt4moc" = "yes" -then - AC_DEFINE(HAVE_GUI,1,[Define to 1 to enable gui code]) -else - AC_DEFINE(HAVE_GUI,0,[Define to 1 to enable gui code]) -fi -AC_SUBST(MOC) -AM_CONDITIONAL(GUI,test x$enable_gui != xno -a x$qt4moc = xyes ) +]) + +dnl enable-gui +dnl +dnl Sets QT_LIBS, MOC and "if GUI" in makefiles if a GUI build is required. +dnl +dnl Requires ACLOCAL_CHECK_QT4 to have been run first. +dnl +AC_DEFUN([ENABLE_GUI], +[ + if test "$enable_gui" = "no" + then + MOC="" + else + if test "$enable_gui" = "yes" -a "$aclocal_moc" = "" + then + AC_MSG_WARN([ignoring --enable-gui, set e_qtmoc to a Qt4 moc program to override]) + fi + MOC="$aclocal_moc" + fi + + if test "`uname`" = "Darwin" -a "$QT_LIBS" = "" + then + QT_LIBS="-framework QtGui -framework QtCore" + fi + + AC_SUBST(QT_LIBS) + AC_SUBST(MOC) + AM_CONDITIONAL(GUI,test x$MOC != x ) + + if test x$enable_exec = xno -a x$MOC != x + then + AC_MSG_ERROR([using --disable-exec requires --disable-gui]) + fi +]) + +dnl enable-debug +dnl +dnl Defines _DEBUG if requested. Defaults to "no" but +dnl allows "--enable-debug=full" as per kdevelop. +dnl +AC_DEFUN([ENABLE_DEBUG], +[ + if test "$enable_debug" = "no" -o -z "$enable_debug" + then + : + else + AC_DEFINE(_DEBUG,1,[Define to enable extra debug messages at compile-time]) + fi +]) + +dnl enable-verbose +dnl +dnl The "--disable-verbose" switch disables the verbose-logging macro. +dnl +AC_DEFUN([ENABLE_VERBOSE], +[ + if test x$enable_verbose != xno + then + : + else + AC_DEFINE(G_NO_LOG,1,[Define to disable the G_LOG macro]) + fi +]) + +dnl enable-pop +dnl +dnl The "--disable-pop" switch builds the pop library from +dnl do-nothing stubs. +dnl +AC_DEFUN([ENABLE_POP], +[ + if test x$enable_pop != xno + then + : + else + AC_DEFINE(USE_NO_POP,1,[Define to eliminate unused pop code as a size optimisation]) + fi + AM_CONDITIONAL(POP,test x$enable_pop != xno) +]) + +dnl enable-exec +dnl +dnl The "--disable-exec" switch removes source files are concerned +dnl with exec-ing external programs. +dnl +AC_DEFUN([ENABLE_EXEC], +[ + if test x$enable_exec != xno + then + : + else + AC_DEFINE(USE_NO_EXEC,1,[Define to eliminate unused exec-ing code as a size optimisation]) + fi + AM_CONDITIONAL(EXEC,test x$enable_exec != xno) +]) + +dnl enable-admin +dnl +dnl The "--disable-admin" switch removes source files that implement +dnl the admin interface. +dnl +AC_DEFUN([ENABLE_ADMIN], +[ + if test x$enable_admin != xno + then + : + else + AC_DEFINE(USE_NO_ADMIN,1,[Define to eliminate unused admin interface code as a size optimisation]) + fi + AM_CONDITIONAL(ADMIN,test x$enable_admin != xno) +]) + +dnl enable-auth +dnl +dnl The "--disable-admin" switch removes source files that implement authentication. +dnl +AC_DEFUN([ENABLE_AUTH], +[ + if test x$enable_auth != xno + then + : + else + AC_DEFINE(USE_NO_AUTH,1,[Define to eliminate unused authentication code as a size optimisation]) + fi + AM_CONDITIONAL(AUTH,test x$enable_auth != xno) + if test x$enable_auth = xno -a x$enable_pop != xno + then + AC_MSG_ERROR([using --disable-auth requires --disable-pop]) + fi +]) + +dnl enable-dns +dnl +dnl The "--disable-dns" switch disables dns lookup so host and service +dnl names must be given as ip addresses and port numbers. This can be +dnl make static linking easier, especially in embedded systems. +dnl +AC_DEFUN([ENABLE_DNS], +[ + AM_CONDITIONAL(DNS,test x$enable_dns != xno) +]) + +dnl enable-identity +dnl +dnl The "--disable-identity" switch disables userid switching thereby +dnl removing the dependence on getpwnam and /etc/passwd. This can +dnl make static linking easier, especially in embedded systems. +dnl +AC_DEFUN([ENABLE_IDENTITY], +[ + AM_CONDITIONAL(IDENTITY,test x$enable_identity != xno) +]) + +dnl enable-small-fragments +dnl +dnl The "--enable-small-fragments" sewitch compiles certain source files in +dnl lots of little pieces so the linker can throw away fragments that +dnl are not needed in the final executable. +dnl +dnl This requires perl on the path and probably messes up a lot of +dnl autoconf/automake features, so only use if really necessary. +dnl +AC_DEFUN([ENABLE_SMALL_FRAGMENTS], +[ + AM_CONDITIONAL(SMALL_FRAGMENTS,test x$enable_small_fragments = xyes) + if test x$enable_small_fragments = xyes + then + AC_MSG_NOTICE([creating source file fragments]) + FRAGMENTS_LIST="`perl $srcdir/bin/fragment.pl_ -r $srcdir/src $srcdir/src/fragments`" + for fragment in $FRAGMENTS_LIST "" ; do if test "$fragment" != "" ; then + AC_MSG_NOTICE([creating source file fragment for $fragment]) + fi ; done + fi + AC_SUBST(FRAGMENTS_LIST) +]) + +dnl enable-small-config +dnl +dnl The "--enable-small-config" switch replaces the complex command-line +dnl parsing code with something simpler and less functional. +dnl +AC_DEFUN([ENABLE_SMALL_CONFIG], +[ + if test x$enable_small_config = xyes + then + AC_DEFINE(USE_SMALL_CONFIG,1,[Define to eliminate unused config code as a size optimisation]) + else + : + fi + AM_CONDITIONAL(SMALL_CONFIG,test x$enable_small_config = xyes) +]) + +dnl enable-small-exceptions +dnl +dnl The "--enable-small-exceptions" defines exception classes as functions +dnl as a size optimisation. This should probably become the default when +dnl it has had more testing. +dnl +AC_DEFUN([ENABLE_SMALL_EXCEPTIONS], +[ + if test x$enable_small_exceptions = xyes + then + AC_DEFINE(USE_SMALL_EXCEPTIONS,1,[Define to have exception types as functions as a size optimisation]) + else + : + fi ]) dnl enable-ipv6 dnl +dnl The "--enable-ipv6" switch enables ipv6 as long as ipv6 is available. +dnl +dnl Note that this requires ACLOCAL_CHECK_IPV6 to have been run. +dnl AC_DEFUN([ENABLE_IPV6], [ -if test "$enable_ipv6" = "yes" -then - if test "$aclocal_ipv6" != "yes" + if test "$enable_ipv6" = "yes" then - AC_MSG_WARN([ignoring --enable-ipv6]) - IP="ipv4" + if test "$aclocal_ipv6" != "yes" + then + AC_MSG_WARN([ignoring --enable-ipv6]) + aclocal_use_ipv6="no" + else + AC_DEFINE(USE_IPV6,1,[Define to use IPv6]) + aclocal_use_ipv6="yes" + fi else - IP="ipv6" + aclocal_use_ipv6="no" fi -else - IP="ipv4" -fi -AC_SUBST(IP) + AM_CONDITIONAL(IPV6,test x$aclocal_use_ipv6 = xyes) +]) + +dnl enable-proxy +dnl +dnl The "--disable-proxy" switch disables smtp proxying as a size optimisation. +dnl +AC_DEFUN([ENABLE_PROXY], +[ + if test x$enable_proxy != xno + then + : + else + AC_DEFINE(USE_NO_PROXY,1,[Define to eliminate proxying code as a size optimisation]) + fi + AM_CONDITIONAL(PROXY,test x$enable_proxy != xno) +]) + +dnl enable-mac +dnl +dnl The "--enable-mac" switch tweaks things for a mac build. +dnl +AC_DEFUN([ENABLE_MAC], +[ + if test x$enable_mac = xyes -o "`uname`" = "Darwin" + then + AC_DEFINE(G_MAC,1,[Define for a mac build]) + fi + AM_CONDITIONAL(MAC,test x$enable_mac = xyes -o "`uname`" = "Darwin") ]) dnl with-openssl dnl +dnl Sets SSL_LIBS and "if OPENSSL" in makefiles. +dnl AC_DEFUN([WITH_OPENSSL], if test "$with_openssl" != "no" then @@ -270,129 +516,202 @@ then ]) if test "$aclocal_openssl" = "yes" then - AC_DEFINE(HAVE_OPENSSL,1,[Define to 1 to enable tls/ssh code using openssl]) SSL_LIBS="-lssl -lcrypto" - SSL="openssl" + aclocal_ssl="openssl" else if test "$with_openssl" = "yes" then AC_MSG_WARN([ignoring --with-openssl, check config.log and try setting CFLAGS]) fi - AC_DEFINE(HAVE_OPENSSL,0,[Define to 1 to enable tls/ssh code using openssl]) SSL_LIBS="" - SSL="none" + aclocal_ssl="none" fi else - AC_DEFINE(HAVE_OPENSSL,0,[Define to 1 to enable tls/ssh code using openssl]) SSL_LIBS="" - SSL="none" + aclocal_ssl="none" fi AC_SUBST(SSL_LIBS) -AC_SUBST(SSL) +AM_CONDITIONAL(OPENSSL,test x$aclocal_ssl = xopenssl) +]) + +dnl with-glob +dnl +dnl Sets "if GLOB" in makefiles. Defaults to auto. +dnl +AC_DEFUN([WITH_GLOB], +if test "$with_glob" != "no" +then +[AC_CACHE_CHECK([for glob],[aclocal_have_glob], +[ + AC_COMPILE_IFELSE([AC_LANG_PROGRAM( + [[#include ]], + [[glob_t * p = 0 ; globfree(p) ; return 1;]])], + aclocal_have_glob=yes, + aclocal_have_glob=no ) +]) + if test "$aclocal_have_glob" = "yes" + then + aclocal_use_glob="yes" + else + if test "$with_glob" = "yes" + then + AC_MSG_WARN([ignoring --with-glob]) + fi + aclocal_use_glob="no" + fi +else + if test "$aclocal_have_glob" = "yes" + then + AC_MSG_WARN([not using available glob()]) + fi + aclocal_use_glob="no" +fi +AM_CONDITIONAL(GLOB,test x$aclocal_use_glob = xyes) ]) dnl enable-static-linking dnl -dnl TODO remove -ldl +dnl The "--enable-static-linking" makes a half-hearted +dnl attempt at static linking. Only applicable to gcc. dnl AC_DEFUN([ENABLE_STATIC_LINKING], [ -if test "$enable_static_linking" = "yes" -then - STATIC_START="-Xlinker -Bstatic" - STATIC_END="-Xlinker -Bdynamic -ldl" -else - STATIC_START="" - STATIC_END="" -fi -AC_SUBST(STATIC_START) -AC_SUBST(STATIC_END) -]) - -dnl with-workshop -dnl -AC_DEFUN([WITH_WORKSHOP], -[ -if test "$with_workshop" = "yes" -then - chmod +x lib/sunpro5/xar - AR="`pwd`/lib/sunpro5/xar --cxx \"$CXX\"" - AC_SUBST(AR) -fi + if test "$enable_static_linking" = "yes" + then + STATIC_START="-Xlinker -Bstatic" + STATIC_END="-Xlinker -Bdynamic -ldl" + else + STATIC_START="" + STATIC_END="" + fi + AC_SUBST(STATIC_START) + AC_SUBST(STATIC_END) ]) dnl with-doxygen dnl +dnl Sets HAVE_DOXYGEN in makefiles if doxygen is to be used. +dnl +dnl Usually used after doing a doxygen program check to set +dnl the default value for $HAVE_DOXYGEN. +dnl AC_DEFUN([WITH_DOXYGEN], [ -if test "$with_doxygen" != "" -then - if test "$with_doxygen" = "yes" -a "$HAVE_DOXYGEN" != "yes" + if test "$with_doxygen" != "" then - AC_MSG_WARN([ignoring --with-doxygen]) - else + if test "$with_doxygen" = "yes" -a "$HAVE_DOXYGEN" != "yes" + then + AC_MSG_WARN([forcing use of doxygen even though not found]) + fi HAVE_DOXYGEN="$with_doxygen" - AC_SUBST(HAVE_DOXYGEN) fi -fi + AC_SUBST(HAVE_DOXYGEN) ]) dnl with-man2html dnl +dnl Sets HAVE_MAN2HTML in makefiles if man2html is to be used. +dnl +dnl Usually used after doing a man2html program check to set +dnl the default value for $HAVE_MAN2HTML. +dnl AC_DEFUN([WITH_MAN2HTML], [ -if test "$with_man2html" != "" -then - if test "$with_man2html" = "yes" -a "$HAVE_MAN2HTML" != "yes" + if test "$with_man2html" != "" then - AC_MSG_WARN([ignoring --with-man2html]) - else + if test "$with_man2html" = "yes" -a "$HAVE_MAN2HTML" != "yes" + then + AC_MSG_WARN([forcing use of man2html even though not found]) + fi HAVE_MAN2HTML="$with_man2html" - AC_SUBST(HAVE_MAN2HTML) fi -fi + AC_SUBST(HAVE_MAN2HTML) ]) -dnl enable-fhs +dnl set-directories dnl -AC_DEFUN([ENABLE_FHS], -[ -if test "$enable_fhs" = "yes" -then - FHS_COMPLIANCE -fi -]) - -dnl fhs +dnl Sets directory paths taking account of "--enable-fhs". dnl -AC_DEFUN([FHS_COMPLIANCE], +AC_DEFUN([SET_DIRECTORIES], [ - # tweaks for fhs compliance... - # - prefix='/usr' - exec_prefix='/usr' - # - sbindir='/usr/sbin' - libexecdir='/usr/lib' - localstatedir='/var' - mandir='/usr/share/man' - datadir='/usr/share' - sysconfdir='/etc' - # - # not used by emailrelay - #bindir= - #sharedstatedir= - #libdir= - #includedir= - #oldincludedir= - #infodir= - # - # emailrelay-specific - e_libexecdir="$libexecdir/$PACKAGE" - e_docdir="$datadir/doc/$PACKAGE" - e_initdir="/etc/init.d" - e_spooldir="$localstatedir/spool/$PACKAGE" - e_examplesdir="$libexecdir/$PACKAGE/examples" - e_sysconfdir="$sysconfdir" + # the following are used in the makefiles: + # * sbindir + # * e_libexecdir + # * e_examplesdir + # * e_sysconfdir + # * mandir + # * e_docdir + # * e_spooldir + # * e_initdir + + if test "$enable_fhs" = "yes" + then + prefix='/usr' + exec_prefix='/usr' + sbindir="/usr/sbin" + libexecdir="/usr/lib" + localstatedir="/var" + mandir="/usr/share/man" + datadir="/usr/share" + sysconfdir="/etc" + fi + if test "$e_libexecdir" = "" + then + if test "$enable_fhs" = "yes" + then + e_libexecdir="$libexecdir/$PACKAGE" + else + e_libexecdir="$libexecdir/$PACKAGE" + fi + fi + if test "$e_examplesdir" = "" + then + if test "$enable_fhs" = "yes" + then + e_examplesdir="$libexecdir/$PACKAGE/examples" + else + e_examplesdir="$libexecdir/$PACKAGE/examples" + fi + fi + if test "$e_sysconfdir" = "" + then + if test "$enable_fhs" = "yes" + then + e_sysconfdir="$sysconfdir" + else + e_sysconfdir="$sysconfdir" + fi + fi + if test "$e_docdir" = "" + then + if test "$enable_fhs" = "yes" + then + e_docdir="$datadir/doc/$PACKAGE" + else + e_docdir="$docdir" + if test "$e_docdir" = "" + then + e_docdir="$datadir/$PACKAGE/doc" + fi + fi + fi + if test "$e_spooldir" = "" + then + if test "$enable_fhs" = "yes" + then + e_spooldir="$localstatedir/spool/$PACKAGE" + else + e_spooldir="$localstatedir/spool/$PACKAGE" + fi + fi + if test "$e_initdir" = "" + then + if test "$enable_fhs" = "yes" + then + e_initdir="/etc/init.d" + else + e_initdir="$libexecdir/$PACKAGE/init" + fi + fi ]) diff --git a/aclocal.m4 b/aclocal.m4 index 32e6582..fb3f733 100644 --- a/aclocal.m4 +++ b/aclocal.m4 @@ -1,7 +1,7 @@ -# generated automatically by aclocal 1.10 -*- Autoconf -*- +# generated automatically by aclocal 1.10.1 -*- Autoconf -*- # Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, -# 2005, 2006 Free Software Foundation, Inc. +# 2005, 2006, 2007, 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. @@ -11,10 +11,13 @@ # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. -m4_if(m4_PACKAGE_VERSION, [2.61],, -[m4_fatal([this file was generated for autoconf 2.61. -You have another version of autoconf. If you want to use that, -you should regenerate the build system entirely.], [63])]) +m4_ifndef([AC_AUTOCONF_VERSION], + [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl +m4_if(AC_AUTOCONF_VERSION, [2.61],, +[m4_warning([this file was generated for autoconf 2.61. +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'.])]) # pkg.m4 - Macros to locate and utilise pkg-config. -*- Autoconf -*- # @@ -174,7 +177,7 @@ else fi[]dnl ])# PKG_CHECK_MODULES -# Copyright (C) 2002, 2003, 2005, 2006 Free Software Foundation, Inc. +# Copyright (C) 2002, 2003, 2005, 2006, 2007 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, @@ -189,7 +192,7 @@ AC_DEFUN([AM_AUTOMAKE_VERSION], [am__api_version='1.10' 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.10], [], +m4_if([$1], [1.10.1], [], [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl ]) @@ -205,8 +208,10 @@ m4_define([_AM_AUTOCONF_VERSION], []) # Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced. # This function is AC_REQUIREd by AC_INIT_AUTOMAKE. AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], -[AM_AUTOMAKE_VERSION([1.10])dnl -_AM_AUTOCONF_VERSION(m4_PACKAGE_VERSION)]) +[AM_AUTOMAKE_VERSION([1.10.1])dnl +m4_ifndef([AC_AUTOCONF_VERSION], + [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl +_AM_AUTOCONF_VERSION(AC_AUTOCONF_VERSION)]) # AM_AUX_DIR_EXPAND -*- Autoconf -*- @@ -478,7 +483,7 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], # each Makefile.in and add a new line on top of each file to say so. # Grep'ing the whole file is not good either: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. - if sed 10q "$mf" | grep '^#.*generated by automake' > /dev/null 2>&1; then + if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then dirpart=`AS_DIRNAME("$mf")` else continue @@ -538,13 +543,13 @@ AU_DEFUN([AM_CONFIG_HEADER], [AC_CONFIG_HEADERS($@)]) # Do all the work for Automake. -*- Autoconf -*- # Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, -# 2005, 2006 Free Software Foundation, Inc. +# 2005, 2006, 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 12 +# serial 13 # 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. @@ -649,16 +654,17 @@ AC_PROVIDE_IFELSE([AC_PROG_OBJC], # our stamp files there. AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK], [# Compute $1's index in $config_headers. +_am_arg=$1 _am_stamp_count=1 for _am_header in $config_headers :; do case $_am_header in - $1 | $1:* ) + $_am_arg | $_am_arg:* ) break ;; * ) _am_stamp_count=`expr $_am_stamp_count + 1` ;; esac done -echo "timestamp for $1" >`AS_DIRNAME([$1])`/stamp-h[]$_am_stamp_count]) +echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count]) # Copyright (C) 2001, 2003, 2005 Free Software Foundation, Inc. # @@ -959,7 +965,7 @@ AC_SUBST([INSTALL_STRIP_PROGRAM])]) # _AM_SUBST_NOTMAKE(VARIABLE) # --------------------------- -# Prevent Automake from outputing VARIABLE = @VARIABLE@ in Makefile.in. +# Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in. # This macro is traced by Automake. AC_DEFUN([_AM_SUBST_NOTMAKE]) diff --git a/autogen.sh b/autogen.sh new file mode 100644 index 0000000..9be3b55 --- /dev/null +++ b/autogen.sh @@ -0,0 +1,10 @@ +#!/bin/sh +# +# autogen.sh +# +# Autogenerates stuff. +# +aclocal +autoconf +autoheader +automake -a diff --git a/bin/Makefile.am b/bin/Makefile.am index dbac6ef..162fd71 100644 --- a/bin/Makefile.am +++ b/bin/Makefile.am @@ -1,5 +1,5 @@ # -## Copyright (C) 2001-2007 Graeme Walker +## Copyright (C) 2001-2008 Graeme Walker ## ## This program is free software: you can redistribute it and/or modify ## it under the terms of the GNU General Public License as published by @@ -15,31 +15,95 @@ ## along with this program. If not, see . # -EXTRA_DIST = emailrelay.sh_ doxygen.sh_ txt2html.sh_ txt2mu.sh_ mu2html.sh_ mu2docbook.sh_ expand.sh_ emailrelay-notify.sh_ emailrelay-resubmit.sh_ emailrelay-deliver.sh_ emailrelay-process.sh_ emailrelay-runperl.js emailrelay-resubmit.js emailrelay-submit.sh_ -work_scripts = doxygen.sh txt2mu.sh mu2html.sh mu2docbook.sh expand.sh txt2html.sh emailrelay.sh -noinst_SCRIPTS = emailrelay-runperl.js emailrelay-resubmit.js $(work_scripts) +if MAC +e_init_SCRIPTS = E-MailRelay +e_init_DATA = StartupParameters.plist +else e_init_SCRIPTS = emailrelay -e_examples_DATA = emailrelay-process.sh emailrelay-notify.sh emailrelay-deliver.sh emailrelay-resubmit.sh emailrelay-submit.sh +e_init_DATA = +endif -CLEANFILES = $(e_init_SCRIPTS) $(e_examples_DATA) $(work_scripts) +EXTRA_DIST = \ + emailrelay.sh_ \ + doxygen.sh_ \ + txt2html.sh_ \ + txt2mu.sh_ \ + mu2html.sh_ \ + mu2docbook.sh_ \ + expand.sh_ \ + emailrelay-notify.sh_ \ + emailrelay-resubmit.sh_ \ + emailrelay-deliver.sh_ \ + emailrelay-process.sh_ \ + emailrelay-runperl.js \ + emailrelay-resubmit.js \ + emailrelay-change-auth.js \ + emailrelay-submit.sh_ \ + emailrelay-multicast.sh_ \ + make-setup.sh_ \ + make-qt-enabled.sh_ \ + make-bundle.sh_ \ + configure-mac.sh \ + startup-mac.plist \ + fragment.pl_ + +work_scripts = \ + doxygen.sh \ + txt2mu.sh \ + mu2html.sh \ + mu2docbook.sh \ + expand.sh \ + txt2html.sh \ + emailrelay.sh \ + make-setup.sh \ + make-qt-enabled.sh \ + make-bundle.sh \ + fragment.pl + +noinst_SCRIPTS = \ + emailrelay-runperl.js \ + emailrelay-resubmit.js \ + emailrelay-change-auth.js \ + $(work_scripts) + +e_examples_DATA = \ + emailrelay-process.sh \ + emailrelay-notify.sh \ + emailrelay-deliver.sh \ + emailrelay-resubmit.sh \ + emailrelay-submit.sh \ + emailrelay-multicast.sh + +CLEANFILES = $(e_init_SCRIPTS) $(e_examples_DATA) $(work_scripts) $(e_init_SCRIPTS) SUFFIXES = .sh_ .sh .sh_.sh: - cat $(srcdir)/../bin/$*.sh_ | sed "s%__SPOOL_DIR__%${e_spooldir}%g;s%__SBIN_DIR__%${sbindir}%g;"'s/\[:digit:\]/0-9/g;s/\[:space:\]/ \\t/g' > $*.tmp && mv $*.tmp $*.sh - chmod ugo+x $*.sh + cat "$(top_srcdir)/bin/$*.sh_" | sed "s%__SPOOL_DIR__%${e_spooldir}%g;s%__SBIN_DIR__%${sbindir}%g;s%__SYSCONF_DIR__%${e_sysconfdir}%g;"'s/\[:digit:\]/0-9/g;s/\[:space:\]/ \\t/g' > "$*.tmp" && mv "$*.tmp" "$*.sh" + chmod ugo+x "$*.sh" + +.pl_.pl: + cp "$(top_srcdir)/bin/$*.pl_" "$*.pl" + chmod ugo+x "$*.pl" emailrelay: emailrelay.sh cp emailrelay.sh emailrelay chmod ugo+x emailrelay +E-MailRelay: emailrelay.sh + cp emailrelay.sh $@ + +StartupParameters.plist: startup-mac.plist + cp $(top_srcdir)/bin/startup-mac.plist $@ + install-data-local: install-e_examplesDATA install-e_initSCRIPTS - chmod ugo+x $(DESTDIR)$(e_examplesdir)/emailrelay-notify.sh - chmod ugo+x $(DESTDIR)$(e_examplesdir)/emailrelay-resubmit.sh - chmod ugo+x $(DESTDIR)$(e_examplesdir)/emailrelay-deliver.sh - chmod ugo+x $(DESTDIR)$(e_examplesdir)/emailrelay-submit.sh - chmod ugo+x $(DESTDIR)$(e_examplesdir)/emailrelay-process.sh + chmod ugo+x "$(DESTDIR)$(e_examplesdir)/emailrelay-process.sh" + chmod ugo+x "$(DESTDIR)$(e_examplesdir)/emailrelay-notify.sh" + chmod ugo+x "$(DESTDIR)$(e_examplesdir)/emailrelay-deliver.sh" + chmod ugo+x "$(DESTDIR)$(e_examplesdir)/emailrelay-resubmit.sh" + chmod ugo+x "$(DESTDIR)$(e_examplesdir)/emailrelay-submit.sh" + chmod ugo+x "$(DESTDIR)$(e_examplesdir)/emailrelay-multicast.sh" uninstall-local: - -rmdir $(DESTDIR)$(e_examplesdir) 2>/dev/null + -rmdir "$(DESTDIR)$(e_examplesdir)" 2>/dev/null diff --git a/bin/Makefile.in b/bin/Makefile.in index 3e3419b..db8157b 100644 --- a/bin/Makefile.in +++ b/bin/Makefile.in @@ -1,8 +1,8 @@ -# Makefile.in generated by automake 1.10 from Makefile.am. +# Makefile.in generated by automake 1.10.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004, 2005, 2006 Free Software Foundation, Inc. +# 2003, 2004, 2005, 2006, 2007, 2008 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. @@ -45,7 +45,7 @@ mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/config.h CONFIG_CLEAN_FILES = am__installdirs = "$(DESTDIR)$(e_initdir)" \ - "$(DESTDIR)$(e_examplesdir)" + "$(DESTDIR)$(e_examplesdir)" "$(DESTDIR)$(e_initdir)" e_initSCRIPT_INSTALL = $(INSTALL_SCRIPT) SCRIPTS = $(e_init_SCRIPTS) $(noinst_SCRIPTS) SOURCES = @@ -57,7 +57,8 @@ am__vpath_adj = case $$p in \ esac; am__strip_dir = `echo $$p | sed -e 's|^.*/||'`; e_examplesDATA_INSTALL = $(INSTALL_DATA) -DATA = $(e_examples_DATA) +e_initDATA_INSTALL = $(INSTALL_DATA) +DATA = $(e_examples_DATA) $(e_init_DATA) DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ @@ -83,6 +84,7 @@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ +FRAGMENTS_LIST = @FRAGMENTS_LIST@ GREP = @GREP@ GZIP = @GZIP@ HAVE_DOXYGEN = @HAVE_DOXYGEN@ @@ -92,7 +94,6 @@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -IP = @IP@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ @@ -116,7 +117,6 @@ QT_LIBS = @QT_LIBS@ RANLIB = @RANLIB@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ -SSL = @SSL@ SSL_LIBS = @SSL_LIBS@ STATIC_END = @STATIC_END@ STATIC_START = @STATIC_START@ @@ -171,17 +171,67 @@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ -EXTRA_DIST = emailrelay.sh_ doxygen.sh_ txt2html.sh_ txt2mu.sh_ mu2html.sh_ mu2docbook.sh_ expand.sh_ emailrelay-notify.sh_ emailrelay-resubmit.sh_ emailrelay-deliver.sh_ emailrelay-process.sh_ emailrelay-runperl.js emailrelay-resubmit.js emailrelay-submit.sh_ -work_scripts = doxygen.sh txt2mu.sh mu2html.sh mu2docbook.sh expand.sh txt2html.sh emailrelay.sh -noinst_SCRIPTS = emailrelay-runperl.js emailrelay-resubmit.js $(work_scripts) -e_init_SCRIPTS = emailrelay -e_examples_DATA = emailrelay-process.sh emailrelay-notify.sh emailrelay-deliver.sh emailrelay-resubmit.sh emailrelay-submit.sh -CLEANFILES = $(e_init_SCRIPTS) $(e_examples_DATA) $(work_scripts) +@MAC_FALSE@e_init_SCRIPTS = emailrelay +@MAC_TRUE@e_init_SCRIPTS = E-MailRelay +@MAC_FALSE@e_init_DATA = +@MAC_TRUE@e_init_DATA = StartupParameters.plist +EXTRA_DIST = \ + emailrelay.sh_ \ + doxygen.sh_ \ + txt2html.sh_ \ + txt2mu.sh_ \ + mu2html.sh_ \ + mu2docbook.sh_ \ + expand.sh_ \ + emailrelay-notify.sh_ \ + emailrelay-resubmit.sh_ \ + emailrelay-deliver.sh_ \ + emailrelay-process.sh_ \ + emailrelay-runperl.js \ + emailrelay-resubmit.js \ + emailrelay-change-auth.js \ + emailrelay-submit.sh_ \ + emailrelay-multicast.sh_ \ + make-setup.sh_ \ + make-qt-enabled.sh_ \ + make-bundle.sh_ \ + configure-mac.sh \ + startup-mac.plist \ + fragment.pl_ + +work_scripts = \ + doxygen.sh \ + txt2mu.sh \ + mu2html.sh \ + mu2docbook.sh \ + expand.sh \ + txt2html.sh \ + emailrelay.sh \ + make-setup.sh \ + make-qt-enabled.sh \ + make-bundle.sh \ + fragment.pl + +noinst_SCRIPTS = \ + emailrelay-runperl.js \ + emailrelay-resubmit.js \ + emailrelay-change-auth.js \ + $(work_scripts) + +e_examples_DATA = \ + emailrelay-process.sh \ + emailrelay-notify.sh \ + emailrelay-deliver.sh \ + emailrelay-resubmit.sh \ + emailrelay-submit.sh \ + emailrelay-multicast.sh + +CLEANFILES = $(e_init_SCRIPTS) $(e_examples_DATA) $(work_scripts) $(e_init_SCRIPTS) SUFFIXES = .sh_ .sh all: all-am .SUFFIXES: -.SUFFIXES: .sh_ .sh +.SUFFIXES: .sh_ .sh .pl .pl_ $(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ @@ -247,6 +297,23 @@ uninstall-e_examplesDATA: echo " rm -f '$(DESTDIR)$(e_examplesdir)/$$f'"; \ rm -f "$(DESTDIR)$(e_examplesdir)/$$f"; \ done +install-e_initDATA: $(e_init_DATA) + @$(NORMAL_INSTALL) + test -z "$(e_initdir)" || $(MKDIR_P) "$(DESTDIR)$(e_initdir)" + @list='$(e_init_DATA)'; for p in $$list; do \ + if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ + f=$(am__strip_dir) \ + echo " $(e_initDATA_INSTALL) '$$d$$p' '$(DESTDIR)$(e_initdir)/$$f'"; \ + $(e_initDATA_INSTALL) "$$d$$p" "$(DESTDIR)$(e_initdir)/$$f"; \ + done + +uninstall-e_initDATA: + @$(NORMAL_UNINSTALL) + @list='$(e_init_DATA)'; for p in $$list; do \ + f=$(am__strip_dir) \ + echo " rm -f '$(DESTDIR)$(e_initdir)/$$f'"; \ + rm -f "$(DESTDIR)$(e_initdir)/$$f"; \ + done tags: TAGS TAGS: @@ -284,7 +351,7 @@ check-am: all-am check: check-am all-am: Makefile $(SCRIPTS) $(DATA) installdirs: - for dir in "$(DESTDIR)$(e_initdir)" "$(DESTDIR)$(e_examplesdir)"; do \ + for dir in "$(DESTDIR)$(e_initdir)" "$(DESTDIR)$(e_examplesdir)" "$(DESTDIR)$(e_initdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am @@ -331,7 +398,7 @@ info: info-am info-am: install-data-am: install-data-local install-e_examplesDATA \ - install-e_initSCRIPTS + install-e_initDATA install-e_initSCRIPTS install-dvi: install-dvi-am @@ -365,8 +432,8 @@ ps: ps-am ps-am: -uninstall-am: uninstall-e_examplesDATA uninstall-e_initSCRIPTS \ - uninstall-local +uninstall-am: uninstall-e_examplesDATA uninstall-e_initDATA \ + uninstall-e_initSCRIPTS uninstall-local .MAKE: install-am install-strip @@ -374,34 +441,45 @@ uninstall-am: uninstall-e_examplesDATA uninstall-e_initSCRIPTS \ distclean-generic distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am \ install-data-local install-dvi install-dvi-am \ - install-e_examplesDATA install-e_initSCRIPTS 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 \ - uninstall-e_examplesDATA uninstall-e_initSCRIPTS \ - uninstall-local + install-e_examplesDATA install-e_initDATA \ + install-e_initSCRIPTS 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 uninstall-e_examplesDATA uninstall-e_initDATA \ + uninstall-e_initSCRIPTS uninstall-local .sh_.sh: - cat $(srcdir)/../bin/$*.sh_ | sed "s%__SPOOL_DIR__%${e_spooldir}%g;s%__SBIN_DIR__%${sbindir}%g;"'s/\[:digit:\]/0-9/g;s/\[:space:\]/ \\t/g' > $*.tmp && mv $*.tmp $*.sh - chmod ugo+x $*.sh + cat "$(top_srcdir)/bin/$*.sh_" | sed "s%__SPOOL_DIR__%${e_spooldir}%g;s%__SBIN_DIR__%${sbindir}%g;s%__SYSCONF_DIR__%${e_sysconfdir}%g;"'s/\[:digit:\]/0-9/g;s/\[:space:\]/ \\t/g' > "$*.tmp" && mv "$*.tmp" "$*.sh" + chmod ugo+x "$*.sh" + +.pl_.pl: + cp "$(top_srcdir)/bin/$*.pl_" "$*.pl" + chmod ugo+x "$*.pl" emailrelay: emailrelay.sh cp emailrelay.sh emailrelay chmod ugo+x emailrelay +E-MailRelay: emailrelay.sh + cp emailrelay.sh $@ + +StartupParameters.plist: startup-mac.plist + cp $(top_srcdir)/bin/startup-mac.plist $@ + install-data-local: install-e_examplesDATA install-e_initSCRIPTS - chmod ugo+x $(DESTDIR)$(e_examplesdir)/emailrelay-notify.sh - chmod ugo+x $(DESTDIR)$(e_examplesdir)/emailrelay-resubmit.sh - chmod ugo+x $(DESTDIR)$(e_examplesdir)/emailrelay-deliver.sh - chmod ugo+x $(DESTDIR)$(e_examplesdir)/emailrelay-submit.sh - chmod ugo+x $(DESTDIR)$(e_examplesdir)/emailrelay-process.sh + chmod ugo+x "$(DESTDIR)$(e_examplesdir)/emailrelay-process.sh" + chmod ugo+x "$(DESTDIR)$(e_examplesdir)/emailrelay-notify.sh" + chmod ugo+x "$(DESTDIR)$(e_examplesdir)/emailrelay-deliver.sh" + chmod ugo+x "$(DESTDIR)$(e_examplesdir)/emailrelay-resubmit.sh" + chmod ugo+x "$(DESTDIR)$(e_examplesdir)/emailrelay-submit.sh" + chmod ugo+x "$(DESTDIR)$(e_examplesdir)/emailrelay-multicast.sh" uninstall-local: - -rmdir $(DESTDIR)$(e_examplesdir) 2>/dev/null + -rmdir "$(DESTDIR)$(e_examplesdir)" 2>/dev/null # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: diff --git a/bin/configure-mac.sh b/bin/configure-mac.sh new file mode 100644 index 0000000..f9dd197 --- /dev/null +++ b/bin/configure-mac.sh @@ -0,0 +1,55 @@ +#!/bin/sh +# +# Copyright (C) 2001-2008 Graeme Walker +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . +# === +# +# configure-mac.sh +# +# A convenience script that runs the emailrelay "../configure" script for +# Mac OS X. +# +# $ cd src/emailrelay-1.99 +# $ mkdir build +# $ cd build +# $ sh ../bin/configure-mac.sh_ +# $ make +# +# After configuring with these switches the installation can be done +# with "make install" for a system-wide installation, or with +# "make install DESTDIR=~" for a private installation. +# +# The default definition of "e_initdir" ensures that the server starts +# up automatically at boot time. +# + +app="/Applications/E-MailRelay" +lib="/Library" + +configure="./configure" +if test ! -f "${configure}" ; then configure="../configure" ; fi +chmod +x "${configure}" 2> /dev/null + +${configure} \ + --enable-mac \ + --sbindir="${app}" \ + e_libexecdir="${app}" \ + e_examplesdir="${app}/Documentation/examples" \ + e_sysconfdir="${app}" \ + --mandir="${app}/Documentation/man" \ + e_docdir="${app}/Documentation" \ + e_spooldir="${lib}/Mail/Spool" \ + e_initdir="${lib}/StartupItems/E-MailRelay" + diff --git a/bin/doxygen.sh_ b/bin/doxygen.sh_ index e8c65a0..9a35230 100644 --- a/bin/doxygen.sh_ +++ b/bin/doxygen.sh_ @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (C) 2001-2007 Graeme Walker +# Copyright (C) 2001-2008 Graeme Walker # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -19,7 +19,7 @@ # doxygen.sh # # Used by doc/Makefile to run doxygen with a bit of -# post-processing. +# config-file pre-processing. # # usage: doxygen # @@ -28,7 +28,7 @@ HAVE_DOXYGEN="$1" top_srcdir="$2" top_builddir="$3" -if test "$HAVE_DOXYGEN" = "yes" -o -z "$HAVE_DOXYGEN" +if test "$HAVE_DOXYGEN" = "yes" then cat "${top_srcdir}/src/main/doxygen.cfg" | \ sed "s:__TOP_SRC__:${top_srcdir}:g" | \ diff --git a/bin/emailrelay-change-auth.js b/bin/emailrelay-change-auth.js new file mode 100644 index 0000000..a388199 --- /dev/null +++ b/bin/emailrelay-change-auth.js @@ -0,0 +1,47 @@ +// +// Copyright (C) 2001-2008 Graeme Walker +// +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see . +// === +// +// emailrelay-change-auth.js +// +// An example "--filter" script for Windows that changes the +// authentication field in the message's envelope file. This +// field is used as the AUTH parameter in the MAIL command +// when the emailrelay server forwards the message to the +// downstream server. By default it is the name used by the +// client when it authenticated with emailrelay. +// +try +{ + var auth = "secret" ; // change this + var content = WScript.Arguments(0) ; + var envelope = content.substr(0,content.length-7) + "envelope.new" ; + var fs = WScript.CreateObject( "Scripting.FileSystemObject" ) ; + var ts = fs.OpenTextFile( envelope , 1 , false ) ; + var txt = ts.ReadAll() ; + ts.Close() ; + var re = new RegExp( "X-MailRelay-Authentication: *\\w*" ) ; + txt = txt.replace( re , "X-MailRelay-Authentication: " + auth ) ; + ts = fs.OpenTextFile( envelope , 2 , false ) ; + ts.Write( txt ) ; + ts.Close() ; + WScript.Quit( 0 ) ; +} +catch( e ) +{ + WScript.Echo( "<<" + e + ">>" ) ; + WScript.Quit( 1 ) ; +} diff --git a/bin/emailrelay-deliver.sh_ b/bin/emailrelay-deliver.sh_ index a6eb550..4d4bc37 100644 --- a/bin/emailrelay-deliver.sh_ +++ b/bin/emailrelay-deliver.sh_ @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (C) 2001-2007 Graeme Walker +# Copyright (C) 2001-2008 Graeme Walker # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -45,11 +45,11 @@ fi # for each e-mail to a local recipient... # -for file in ${store}/emailrelay.*.envelope.local "" +for file in "${store}"/emailrelay.*.envelope.local "" do if test -f "${file}" then - content="`echo ${file} | sed 's/envelope/content/'`" + content="`echo \"${file}\" | sed 's/envelope/content/'`" deliver_to="`fgrep X-MailRelay-To-Local ${file} | sed 's/X-MailRelay-To-Local: //' | tr -d '\015' | sed \"s/postmaster/${postmaster}/g\"`" if test "${deliver_to}" = "" @@ -61,8 +61,8 @@ do # if test -f "${content}" then - echo `basename $0`: delivering `basename ${content}` to ${deliver_to} - ${procmail} -d ${deliver_to} < ${content} + echo `basename $0`: delivering `basename "${content}"` to ${deliver_to} + "${procmail}" -d "${deliver_to}" < "${content}" rc=$? if test "${rc}" -eq 0 then diff --git a/bin/emailrelay-multicast.sh_ b/bin/emailrelay-multicast.sh_ new file mode 100644 index 0000000..93a64c8 --- /dev/null +++ b/bin/emailrelay-multicast.sh_ @@ -0,0 +1,103 @@ +#!/bin/sh +# +# Copyright (C) 2001-2008 Graeme Walker +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . +# === +# +# emailrelay-multicast.sh +# +# An example filter script that copies/links each new message +# into all avaliable sub-directories of the main spool +# directory. The original message files are deleted if they +# were successfully copied/linked into all sub-directories. +# +# Typically used for smtp multicast with an emailrelay +# forwarding process polling each sub-directory (with +# eg. "--log -e --no-smtp --poll 10 --forward-to ..."). +# +# Hard links are used for the content files in order to +# conserve disk space. +# +# Log entries are written into the base envelope file +# to help with error recovery. +# +# Note that the remote smtp client which is submitting the +# message will be notified of any failures in this script. +# Alternatively an "exit 0" can be used to silently leave +# the message in the main spool directory (see below). +# +# (This script is similar to the emailrelay-filter-copy +# program that is used for "pop-by-name" -- ie. smtp to +# pop multicasting. However, in the pop case we exploit +# a feature of the pop server where the content file +# can stay in the parent directory without linking or +# copying into the sub-directory, which allows "pop-by-name" +# to be fully cross-platform while avoiding content-file +# bloat. The smtp server does not support that way of +# working so here we just link the content file and +# forget about windows.) +# + +# parse the command-line +# +content="$1" +envelope="`echo \"${content}\" | sed 's/content$/envelope.new/'`" +base_dir="`dirname \"${content}\"`" +if test "$1" = "" -o "${content}" = "${envelope}" -o "${base_dir}" = "." +then + echo usage: `basename $0` '' >&2 + exit 2 +fi + +# copy/link message files +# +list="`find \"${base_dir}\" -mount -maxdepth 1 -mindepth 1 -type d`" +error_list="" +subdir_exists="0" +for dir in ${list} "" +do + if test -d "${dir}" -a "${dir}" != ".." -a "${dir}" != "." -a "${dir}" != "${base_dir}" + then + subdir_exists="1" + envelope_tmp="${envelope}.`basename \"${dir}\"`.tmp" + envelope_dst="${dir}/`basename \"${envelope}\" .new`" + if ln "${content}" "${dir}" && cp "${envelope}" "${envelope_tmp}" && mv "${envelope_tmp}" "${envelope_dst}" + then + echo "X-MailRelay-Multicast: ${dir}>" | tr '>' '\r' >> "${envelope}" + else + error_list="${error_list} ${dir}" + echo "X-MailRelay-Multicast-Error: ${dir}>" | tr '>' '\r' >> "${envelope}" + fi + fi +done + +# error handling +# +if test "${subdir_exists}" = "0" +then + # no sub-directories created -- this script has no effect + exit 0 +elif test "${error_list}" = "" +then + # successfully copied -- delete the original + rm -f "${content}" "${envelope}" + exit 100 +else + # something failed -- tell the submitting smtp client + # replace these two lines with "exit 0" if the client should not know... + echo "<<`basename $0`: `basename "${content}"`: failed to copy message into${error_list}>>" + exit 1 +fi + diff --git a/bin/emailrelay-notify.sh_ b/bin/emailrelay-notify.sh_ index 355dfb6..a5b3833 100644 --- a/bin/emailrelay-notify.sh_ +++ b/bin/emailrelay-notify.sh_ @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (C) 2001-2007 Graeme Walker +# Copyright (C) 2001-2008 Graeme Walker # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -36,7 +36,7 @@ # tmp="/tmp/`basename $0`.$$.tmp" -trap "rm -f ${tmp} 2>/dev/null ; exit 0" 0 1 2 3 13 15 +trap "rm -f \"${tmp}\" 2>/dev/null ; exit 0" 0 1 2 3 13 15 procmail="procmail" # parse the command line @@ -57,15 +57,15 @@ fi # for each failed e-mail... # -for file in ${store}/emailrelay.*.envelope.bad "" +for file in "${store}"/emailrelay.*.envelope.bad "" do if test -f "${file}" then # parse out the failure reason and the original sender # - content="`echo ${file} | sed 's/envelope/content/' | sed 's/.bad//'`" - reason="`fgrep MailRelay-Reason ${file} | sed 's/X-[^ ]*Reason: //' | tr -d '\015'`" - from="`fgrep MailRelay-From ${file} | sed 's/X-MailRelay-From: //' | tr -d '\015'`" + content="`echo \"${file}\" | sed 's/envelope/content/' | sed 's/.bad//'`" + reason="`fgrep MailRelay-Reason \"${file}\" | sed 's/X-[^ ]*Reason: //' | tr -d '\015'`" + from="`fgrep MailRelay-From \"${file}\" | sed 's/X-MailRelay-From: //' | tr -d '\015'`" deliver_to="${from}" if test "${deliver_to}" = "" then @@ -74,46 +74,46 @@ do # create a notification message header # - boundary="--------------`basename ${file}`.$$" - echo "To: ${deliver_to}" > ${tmp} - echo "From: postmaster" >> ${tmp} - echo "Subject: Your e-mail could not be delivered" >> ${tmp} - echo "MIME-Version: 0.1" >> ${tmp} - echo "Content-Type: multipart/mixed; boundary=\"${boundary}\"" >> ${tmp} - echo "" >> ${tmp} + boundary="--------------`basename \"${file}\"`.$$" + echo "To: ${deliver_to}" > "${tmp}" + echo "From: postmaster" >> "${tmp}" + echo "Subject: Your e-mail could not be delivered" >> "${tmp}" + echo "MIME-Version: 0.1" >> "${tmp}" + echo "Content-Type: multipart/mixed; boundary=\"${boundary}\"" >> "${tmp}" + echo "" >> "${tmp}" # add the message text # - echo "" >> ${tmp} - echo "--${boundary}" >> ${tmp} - echo "Content-Type: text/plain; charset=us-ascii" >> ${tmp} - echo "" >> ${tmp} + echo "" >> "${tmp}" + echo "--${boundary}" >> "${tmp}" + echo "Content-Type: text/plain; charset=us-ascii" >> "${tmp}" + echo "" >> "${tmp}" if test -f "${content}" then - egrep -i '^To:|^Subject:' ${content} >> ${tmp} + egrep -i '^To:|^Subject:' ${content} >> "${tmp}" fi if test "${reason}" != "" then - echo "Reason: ${reason}" >> ${tmp} + echo "Reason: ${reason}" >> "${tmp}" fi # add the message attachment # if test -f "${content}" then - echo "--${boundary}" >> ${tmp} - echo "Content-Type: message/rfc822" >> ${tmp} - echo "Content-Transfer-Encoding: 8bit" >> ${tmp} - echo "Content-Description: `basename ${content}`" >> ${tmp} - echo "" >> ${tmp} - cat ${content} >> ${tmp} + echo "--${boundary}" >> "${tmp}" + echo "Content-Type: message/rfc822" >> "${tmp}" + echo "Content-Transfer-Encoding: 8bit" >> "${tmp}" + echo "Content-Description: `basename \"${content}\"`" >> "${tmp}" + echo "" >> "${tmp}" + cat "${content}" >> "${tmp}" fi - echo "--${boundary}--" >> ${tmp} + echo "--${boundary}--" >> "${tmp}" # deliver the notification using procmail # - echo `basename $0`: delivering `basename ${content}` to ${deliver_to} - ${procmail} -d "${deliver_to}" < ${tmp} + echo `basename $0`: delivering `basename "${content}"` to ${deliver_to} + "${procmail}" -d "${deliver_to}" < "${tmp}" rc=$? # clean up diff --git a/bin/emailrelay-process.sh_ b/bin/emailrelay-process.sh_ index 54d6451..8753b58 100644 --- a/bin/emailrelay-process.sh_ +++ b/bin/emailrelay-process.sh_ @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (C) 2001-2007 Graeme Walker +# Copyright (C) 2001-2008 Graeme Walker # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -27,7 +27,7 @@ awk="awk" tmp="/tmp/`basename $0`.$$.tmp" log="/tmp/`basename $0`.out" -trap "rm -f ${tmp} >/dev/null 2>&1 ; exit" 0 1 2 3 13 15 +trap "rm -f \"${tmp}\" >/dev/null 2>&1 ; exit" 0 1 2 3 13 15 ### # ProcessContent() @@ -36,7 +36,7 @@ trap "rm -f ${tmp} >/dev/null 2>&1 ; exit" 0 1 2 3 13 15 # ProcessContent() { - ${awk} ' + "${awk}" ' BEGIN { map_upper = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" map_lower = tolower(map_upper) @@ -81,7 +81,7 @@ ProcessContent() # Wrap() { - ${awk} -v boundary="-----`basename $0`.$$" -v message="$@" ' + "${awk}" -v boundary="-----`basename $0`.$$" -v message="$@" ' BEGIN { in_header = 1 n = 1 @@ -136,15 +136,15 @@ Wrap() Main() { - cat "${1}" | ProcessContent | Wrap "The original message has been encrypted..." > ${tmp} - cp ${tmp} "${1}" + cat "${1}" | ProcessContent | Wrap "The original message has been encrypted..." > "${tmp}" + cp "${tmp}" "${1}" } debug="0" if test "${debug}" -eq 1 then - Main $@ > ${log} 2>&1 + Main "$@" > "${log}" 2>&1 else - Main $@ + Main "$@" fi diff --git a/bin/emailrelay-resubmit.js b/bin/emailrelay-resubmit.js index b1388e1..5b56535 100644 --- a/bin/emailrelay-resubmit.js +++ b/bin/emailrelay-resubmit.js @@ -1,5 +1,5 @@ // -// Copyright (C) 2001-2007 Graeme Walker +// Copyright (C) 2001-2008 Graeme Walker // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by @@ -14,26 +14,32 @@ // You should have received a copy of the GNU General Public License // along with this program. If not, see . // === -/// -/// \file emailrelay-resubmit.js -/// +// +// emailrelay-resubmit.js +// +// Looks for all failed e-mails in the E-MailRelay spool directory +// and resubmits them. However, if an e-mail has been retried five +// times already then it is not submitted again. +// +// usage: cscript //nologo emailrelay-resubmit.js [] +// -/// configuration -/// +// configuration +// var cfg_store = "__SPOOL_DIR__" ; var cfg_retry_limit = 5 ; var cfg_debug = true ; -/// parse the command line -/// +// parse the command line +// var args = WScript.Arguments if( args.length >= 1 ) { cfg_store = args(0) ; } -/// debugging -/// +// debugging +// function debug( line ) { if( cfg_debug ) @@ -42,8 +48,8 @@ function debug( line ) } } -/// check the spool directory -/// +// check the spool directory +// var fso = WScript.CreateObject( "Scripting.FileSystemObject" ) ; if( ! fso.FolderExists( cfg_store ) ) { @@ -51,20 +57,20 @@ if( ! fso.FolderExists( cfg_store ) ) WScript.Quit( 1 ) ; } -/// for each file... -/// +// for each file... +// var folder = fso.GetFolder( cfg_store ) ; var re_reason = new RegExp( "MailRelay-Reason: " , "" ) ; var re_bad = new RegExp( ".*\.bad" , "i" ) ; var iter = new Enumerator( folder.Files ) ; for( ; ! iter.atEnd() ; iter.moveNext() ) { - ///< if a failed envelope file... + // if a failed envelope file... var path = new String(iter.item()) ; debug( "path: " + path ) ; if( path.match(re_bad) ) { - ///< count the failure lines + // count the failure lines var stream = fso.OpenTextFile( path , 1 ) ; var failures = 0 ; while( !stream.AtEndOfStream ) @@ -80,7 +86,7 @@ for( ; ! iter.atEnd() ; iter.moveNext() ) debug( "failures: " + failures ) ; if( failures < cfg_retry_limit ) { - ///< remove the ".bad" suffix + // remove the ".bad" suffix var new_path = path.substr( 0 , path.length-4 ) ; debug( "rename: " + path + " -> " + new_path ) ; fso.MoveFile( path , new_path ) ; diff --git a/bin/emailrelay-resubmit.sh_ b/bin/emailrelay-resubmit.sh_ index 62fbd41..4df9ef9 100644 --- a/bin/emailrelay-resubmit.sh_ +++ b/bin/emailrelay-resubmit.sh_ @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (C) 2001-2007 Graeme Walker +# Copyright (C) 2001-2008 Graeme Walker # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -45,11 +45,11 @@ fi # for each failed e-mail... # -for file in ${store}/emailrelay.*.envelope.bad "" +for file in "${store}"/emailrelay.*.envelope.bad "" do if test -f "${file}" then - failures="`fgrep MailRelay-Reason: < ${file} | wc -l`" + failures="`fgrep MailRelay-Reason: < \"${file}\" | wc -l`" if test "${failures}" -lt "${retry_limit}" then good_file="`echo \"${file}\" | sed 's/\.bad$//'`" diff --git a/bin/emailrelay-runperl.js b/bin/emailrelay-runperl.js index 91ea48a..c160b61 100644 --- a/bin/emailrelay-runperl.js +++ b/bin/emailrelay-runperl.js @@ -1,5 +1,5 @@ // -// Copyright (C) 2001-2007 Graeme Walker +// Copyright (C) 2001-2008 Graeme Walker // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by @@ -14,28 +14,44 @@ // You should have received a copy of the GNU General Public License // along with this program. If not, see . // === -/// -/// \file emailrelay-runperl.js -/// +// +// emailrelay-runperl.js +// +// An example "--filter" script for Windows that runs a perl script +// to process the message content via its standard input and standard +// output. +// +// The name of the perl script is hard-coded below: edit as necessary. +// +// The E-MailRelay command-line should look something like this: +// +// emailrelay --as-server --filter "c:/program\ files/emailrelay/emailrelay-runperl.js" +// +// Note the backslash to escape the space in the path. +// +// The implementation of this JavaScript makes use of "CMD.EXE", which may be +// not be available on some versions of Windows. +// +// Edit the next two lines as necessary, but avoid spaces in paths: var cfg_perl="perl -S -T -w" var cfg_perl_script="spamassassin" -/// parse our command line +// parse our command line var args = WScript.Arguments var filename = args(0) -/// prepare a command using CMD.EXE to do file redirection +// prepare a command using CMD.EXE to do file redirection var cmd_in = "\"" + filename + "\"" var cmd_out = "\"" + filename + ".tmp\"" var cmd_err = "\"" + filename + ".err\"" var cmd_perl = "cmd /c " + cfg_perl + " " + cfg_perl_script var cmd = cmd_perl + " < " + cmd_in + " > " + cmd_out + " 2> " + cmd_err -/// run the command +// run the command var sh = WScript.CreateObject("WScript.Shell") var rc = sh.Run( cmd , 0 , true ) -/// check the file redirection +// check the file redirection var fs = WScript.CreateObject("Scripting.FileSystemObject") if( !fs.FileExists(filename+".tmp") || !fs.FileExists(filename+".err") ) { @@ -43,7 +59,7 @@ if( !fs.FileExists(filename+".tmp") || !fs.FileExists(filename+".err") ) WScript.Quit( 2 ) } -/// success or failure +// success or failure if( rc == 0 ) { fs.DeleteFile( filename ) diff --git a/bin/emailrelay-submit.sh_ b/bin/emailrelay-submit.sh_ index 0e015bf..977c8d6 100644 --- a/bin/emailrelay-submit.sh_ +++ b/bin/emailrelay-submit.sh_ @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (C) 2001-2007 Graeme Walker +# Copyright (C) 2001-2008 Graeme Walker # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -18,15 +18,15 @@ # # emailrelay-submit.sh # -# An example wrapper script for the "emailrelay-submit" -# utility that adds the capability of copying messages -# into multiple subdirectories (eg. for "pop-by-name") -# based on the message content. -# -# Edit as required. -# -# Reads the message content from the standard input. -# All output goes to a log file. +# An example wrapper script for the "emailrelay-submit" utility +# that adds the capability of copying messages into multiple +# subdirectories based on the message content. This script +# should be used as a replacement for the "emailrelay-submit" +# utility so it reads the message content from the standard +# input. All output goes to a log file. +# +# Typically called by fetchmail as the local delivery agent +# with an emailrelay pop server running in "pop-by-name" mode. # # usage: emailrelay-submit.sh # @@ -36,8 +36,8 @@ log="/var/log/emailrelay-submit.out" awk="awk" # nawk tmp="/tmp/`basename $0.$$.tmp`" -trap "rm -f ${tmp} 2>/dev/null ; exit 0" 0 -trap "rm -f ${tmp} 2>/dev/null ; exit 1" 1 2 3 13 15 +trap "rm -f \"${tmp}\" 2>/dev/null ; exit 0" 0 +trap "rm -f \"${tmp}\" 2>/dev/null ; exit 1" 1 2 3 13 15 List() { @@ -74,8 +74,8 @@ Main() echo `basename $0`: to \"${to}\" # submit the message into the main spool directory - content="`cat \"${tmp}\" | ${sbin}emailrelay-submit --verbose --spool-dir \"${store}\" \"${to}\"`" - envelope="`echo ${content} | sed 's/content/envelope/'`" + content="`cat \"${tmp}\" | \"${sbin}emailrelay-submit\" --verbose --spool-dir \"${store}\" \"${to}\"`" + envelope="`echo \"${content}\" | sed 's/content/envelope/'`" if test \! -f "${content}" then echo `basename $0`: emailrelay-submit failed >&2 diff --git a/bin/emailrelay.sh_ b/bin/emailrelay.sh_ index f062cb6..50a39b0 100644 --- a/bin/emailrelay.sh_ +++ b/bin/emailrelay.sh_ @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (C) 2001-2007 Graeme Walker +# Copyright (C) 2001-2008 Graeme Walker # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -45,7 +45,7 @@ ### END INIT INFO ## -# choose an infrastructure style +# choose an infrastructure style -- linux-standard-base (lsb) or unix # if test -f /lib/lsb/init-functions then @@ -63,7 +63,8 @@ if test \! -d "${var_run}" ; then var_run="/tmp" ; fi if test \! -x "${emailrelay}" ; then emailrelay="`pwd`/emailrelay" ; fi pid_file="${var_run}/emailrelay.pid" PATH="${PATH}:/sbin:/bin:/usr/bin" -cfg_file="/etc/emailrelay.conf" +ECHO="echo" ; if test -x /bin/echo ; then ECHO="/bin/echo" ; fi +cfg_file="__SYSCONF_DIR__/emailrelay.conf" # server configuration using the config file # @@ -85,7 +86,7 @@ unix_reset() unix_cmd_start() { - echo -n "${1}" + $ECHO -n "${1}" shift "$@" unix_errno="$?" @@ -99,8 +100,8 @@ unix_cmd_start() unix_cmd_stop() { - echo -n "${1}" - if test -f "${pid_file}" && test "`cat ${pid_file}`" != "" + $ECHO -n "${1}" + if test -f "${pid_file}" && test "`cat \"${pid_file}\"`" != "" then kill "`cat ${pid_file}`" rm -f "${pid_file}" 2>/dev/null @@ -116,8 +117,8 @@ unix_cmd_restarted() unix_cmd_status() { - echo -n "${1}" - if test -f "${pid_file}" && test "`cat ${pid_file}`" != "" && kill -0 "`cat ${pid_file}`" 2>/dev/null + $ECHO -n "${1}" + if test -f "${pid_file}" && test "`cat \"${pid_file}\"`" != "" && kill -0 "`cat \"${pid_file}\"`" 2>/dev/null then echo " ... running" unix_errno="0" @@ -211,7 +212,7 @@ case "${1}" in start) shift - ${style}_cmd_start "Starting E-MailRelay server" ${emailrelay} ${start_switches} "$@" + ${style}_cmd_start "Starting E-MailRelay server" "${emailrelay}" ${start_switches} "$@" ;; stop) diff --git a/bin/expand.sh_ b/bin/expand.sh_ index 51ec9e6..9236e71 100644 --- a/bin/expand.sh_ +++ b/bin/expand.sh_ @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (C) 2001-2007 Graeme Walker +# Copyright (C) 2001-2008 Graeme Walker # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by diff --git a/bin/fragment.pl_ b/bin/fragment.pl_ new file mode 100644 index 0000000..d8acb20 --- /dev/null +++ b/bin/fragment.pl_ @@ -0,0 +1,270 @@ +#!/usr/bin/perl +# +# Copyright (C) 2001-2008 Graeme Walker +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . +# === +# +# fragment.pl +# +# Splits a source file into small fragments so that +# they can be compiled separately. +# +# Starts a fragment at the start of a namespace or +# a method. Ends a fragment at a blank line following +# a closing brace in column one. If there is a comment +# "//pragma fragments" in the source file then it marks +# the end of the common, unfragmented code (eg. local +# declarations). +# +# usage: fragment.sh [-r] +# +# Pokes inside "Makefile.am" files to get a lists of files. +# +# Logs all created files on stdout, suitable for backticks. +# + +use strict ; +use FileHandle ; + +sub makefile_variable +{ + return "FRAGMENTS_EXTRA_DIST" ; +} + +sub debug +{ + # print @_ , "\n" ; +} + +sub file_list_from_makefile +{ + my ( $dir_in ) = @_ ; + my $path = "$dir_in/Makefile.am" ; + debug( "makefile: $path" ) ; + my $f = new FileHandle( $path ) or return () ; + my %full_hash = () ; + while( <$f> ) + { + my $line = $_ ; + chomp $line ; + my $v = makefile_variable() ; + if( $line =~ m/^$v/ ) + { + $line =~ s/$v[[:space:]]*=[[:space:]]*// ; + my @list = split( '\s+' , $line ) ; + for my $l ( @list ) { $full_hash{$l} = 1 } + } + } + debug( "makefile: $path: [".join("][",keys %full_hash)."]" ) ; + return keys %full_hash ; +} + +sub sub_directory_list +{ + my ( $base ) = @_ ; + opendir( DIR , $base ) or return () ; + my @list = grep { !m/^\./ && -d "$base/$_" } readdir(DIR) ; + closedir( DIR ) ; + debug( "sub_directory_list: [".join("][",@list)."]" ) ; + return @list ; +} + +sub basename +{ + my ( $path ) = @_ ; + $path =~ s:.*/:: ; + return $path ; +} + +sub dirname +{ + my ( $path ) = @_ ; + $path =~ s:/[^/]*$:: ; + return $path eq "" ? "." : $path ; +} + +sub noextension +{ + my ( $name ) = @_ ; + $name =~ s/\.[a-z]*$// ; + return $name ; +} + +sub name_to_show +{ + my ( $path ) = @_ ; + $path =~ s/.cpp$/.o/ ; + return basename($path) ; +} + +sub mkdir_for +{ + my ( $path_out ) = @_ ; + my $dir_out = dirname( $path_out ) ; + if( ! -d $dir_out ) + { + debug( "mkdir [$dir_out]" ) ; + mkdir($dir_out) or die basename($0).": cannot create directory [$dir_out] ($!)" ; + } +} + +sub print_banner +{ + my ( $output , $file_in , $file_out ) = @_ ; + my $me = basename($0) ; + my $filename_out = basename( $file_out ) ; + my $filename_in = basename( $file_in ) ; + print $output "//\n" ; + print $output "// $filename_out -- autogenerated from $filename_in by $me\n" ; + print $output "//\n" ; + print $output "\n" ; +} + +sub print_header +{ + my ( $output , $head_ref ) = @_ ; + for my $h ( @$head_ref ) + { + print $output $h , "\n" ; + } +} + +my $n_ = 0 ; +sub first_file_out +{ + $n_ = 0 ; +} +sub next_file_out +{ + my ( $file_in , $dir_out ) = @_ ; + + my $name = noextension(basename($file_in)) ; + my $file_out = "$dir_out/$name.$n_.cpp" ; + $n_++ ; + debug( "next: [$file_in] [$dir_out] [$file_out]" ) ; + return $file_out ; +} + +sub is_pragma +{ + my ( $line ) = @_ ; + return $line =~ m:^ *//pragma *fragments: ; +} + +sub has_pragma +{ + my ( $file_in ) = @_ ; + my $input = new FileHandle( $file_in , "<" ) ; + while( <$input> ) { return 1 if is_pragma($_) } + return 0 ; +} + +sub fragment +{ + my ( $file_in , $dir_out ) = @_ ; + + my $has_pragma = has_pragma( $file_in ) ; + my $input = new FileHandle( $file_in , "<" ) or die basename($0).": cannot open input file [$file_in]" ; + my $output = undef ; + my @head = () ; + my $state = 0 ; + my $previous_line = "" ; + my $was_brace = 0 ; + my $was_hash_if = 0 ; + my $seen_pragma = 0 ; + my @file_list = () ; + first_file_out() ; + while( <$input> ) + { + my $line = $_ ; + chomp $line ; + + my $is_pragma = is_pragma($line) ; + my $is_namespace = $line =~ m/^namespace/ ; + my $is_method = $line =~ m/^[^[:space:]].*::.*\(/ ; + my $is_blank = $line =~ m/^[[:space:]]*$/ ; + my $is_brace = $line =~ m/^}/ ; + my $is_hash_if = $line =~ m/^#if/ ; + + if( ( $state == 0 || $state == 2 ) && ( ($seen_pragma || !$has_pragma) && ( $is_namespace || $is_method ) ) ) + { + $state = 1 ; + my $file_out = next_file_out( $file_in , $dir_out ) ; + mkdir_for( $file_out ) ; + $output = new FileHandle( $file_out , ">" ) or die basename($0).": cannot create output file [$file_out]" ; + push @file_list , name_to_show($file_out) ; + print_banner( $output , $file_in , $file_out ) ; + print_header( $output , \@head ) ; + if( $was_hash_if ) { print $output $previous_line , "\n" } + print $output $line , "\n" ; + } + elsif( $state == 1 && $was_brace && $is_blank ) + { + $state = 2 ; + } + elsif( $state == 1 ) + { + print $output $line , "\n" ; + } + elsif( $state == 0 ) + { + push @head , $line unless $is_pragma ; + } + $was_brace = $is_brace ; + $was_hash_if = $is_hash_if ; + $seen_pragma = $seen_pragma || $is_pragma ; + $previous_line = $line ; + } + close $input or die ; + if( defined($output) ) { close $output or die basename($0).": cannot close output file" } + return @file_list ; +} + +sub main +{ + my $recursive = scalar(@ARGV) && $ARGV[0] eq "-r" ; + shift @ARGV if $recursive ; + + my $dir_in = shift @ARGV ; + if( ! -d $dir_in ) + { + die basename($0) . ": not a valid directory [$dir_in]" ; + } + + my $dir_out = shift @ARGV ; + if( ! -d $dir_out ) + { + die basename($0) . ": not a valid directory [$dir_out]" ; + } + + my @list_out = () ; + my @dir_list_in = ( "." ) ; + push @dir_list_in , sub_directory_list($dir_in) if $recursive ; + + for my $subdir ( @dir_list_in ) + { + my $dir_in = "$dir_in/$subdir" ; + my @list_in = file_list_from_makefile( $dir_in ) ; + for my $file_in ( @list_in ) + { + my $path_in = $dir_in . "/" . $file_in ; + push @list_out , fragment( $path_in , $dir_out ) ; + } + } + print join(" ",@list_out) , "\n" ; +} + +main() ; + diff --git a/bin/make-bundle.sh_ b/bin/make-bundle.sh_ new file mode 100644 index 0000000..974db65 --- /dev/null +++ b/bin/make-bundle.sh_ @@ -0,0 +1,87 @@ +#!/bin/sh +# +# Copyright (C) 2001-2008 Graeme Walker +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . +# === +# +# make-bundle.sh +# +# Makes a Mac OS X application bundle. Called from make. +# +# usage: make-bundle.sh [-f] [] +# +# Silently does nothing on non-Mac systems. +# + +force="0" ; if test "$1" = "-f" ; then force="1" ; shift ; fi +name="$1" +exe="$2" +icon="$3" +version="$4" ; if test "${version}" = "" ; then version="1.8.0" ; fi + +if test "${name}" = "" +then + echo usage: `basename $0` '[-f] []' >&2 + exit 1 +fi + +if test "`uname`" != "Darwin" -a "$force" -eq 0 +then + exit 0 +fi + +if test ! -x "${exe}" +then + echo `basename $0`: invalid exe >&2 + exit 1 +fi + +yyyy="`date -u +'%Y'`" +copyright="Copyright (c) 2001-${yyyy} Graeme Walker <graeme_walker@users.sourceforge.net>>" +bundle_version="`date -u +'%Y.%m.%d.%H.%M.%S'`" +key="`basename \"${exe}\" | sed 's/\..*//'`" + +if test -d "${name}.app" +then + rm -rf "${name}.app" +fi + +dir="${name}.app/Contents" +mkdir -p "${dir}/MacOS" 2>/dev/null +mkdir -p "${dir}/Resources" 2>/dev/null + +ln -f "${exe}" "${dir}/MacOS/${name}" +cp "${icon}" "${dir}/Resources/${name}.icns" + +cat > "${dir}/Info.plist" < + + + + CFBundleDisplayName ${name} + CFBundleIconFile ${name}.icns + CFBundleIdentifier net.sourceforge.emailrelay.${key} + CFBundleName ${name} + CFBundlePackageType APPL + CFBundleShortVersionString ${version} + CFBundleSignature gwgw + CFBundleVersion ${bundle_version} + LSHasLocalizedDisplayName + NSHumanReadableCopyright ${copyright} + NSAppleScriptEnabled + + +EOF + diff --git a/bin/make-qt-enabled.sh_ b/bin/make-qt-enabled.sh_ new file mode 100644 index 0000000..52f0b36 --- /dev/null +++ b/bin/make-qt-enabled.sh_ @@ -0,0 +1,122 @@ +#!/bin/sh +# +# Copyright (C) 2001-2008 Graeme Walker +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . +# === +# +# make-qt-enabled.sh +# +# Adds Qt frameworks to a Mac OS X application bundle. Called from make. +# +# usage: make-qt-enabled.sh [-f] +# +# eg. make-qt-enabled.sh Foo.app/Contents/MacOS ../Frameworks +# eg. make-qt-enabled.sh foo.real Frameworks +# +# Silently does nothing on non-Mac systems. +# +# See "http://doc.trolltech.com/4.3/deployment-mac.html". +# + +force="0" ; if test "$1" = "-f" ; then force="1" ; shift ; fi +exe="$1" +fdir="$2" + +echo="echo" +do="" + +if test "`uname`" != "Darwin" -a "$force" -eq 0 +then + exit 0 +fi + +if test "$fdir" = "" +then + fdir="../Frameworks" +fi + +if test ! -x "$exe" +then + echo `basename $0`: no such exe >&2 + exit 1 +fi + +base="`dirname \"$1\"`" +src="/Library/Frameworks" + +rm -rf "$base/$fdir" 2>/dev/null +mkdir -p "$base/$fdir" 2>/dev/null + +$echo cp -f -R \"$src/QtCore.framework\" \"$base/$fdir\" +$do cp -f -R "$src/QtCore.framework" "$base/$fdir" + +$echo cp -f -R \"$src/QtGui.framework\" \"$base/$fdir\" +$do cp -f -R "$src/QtGui.framework" "$base/$fdir" + +Id() +{ + fk_="$1" + name_="$2" + if test "$name_" = "" ; then name_="`basename \"$fk_\" .framework`" ; fi + otool -D "$fk_/Versions/Current/$name_" | tail -1 +} + +SetId() +{ + base_="$1" + fdir_="$2" + id_="$3" + $echo install_name_tool -id \"@executable_path/$fdir_/$id_\" \"$base_/$fdir_/$id_\" + $do install_name_tool -id "@executable_path/$fdir_/$id_" "$base_/$fdir_/$id_" +} + +Path() +{ + exe_="$1" + key_="$2" + otool -L "$exe_" | fgrep "$key_" | tr '\t' ' ' | sed 's/^ *//' | sed 's/ .*//' +} + +SetPath() +{ + lib_or_exe_="$1" + fdir_="$2" + path_="$3" + if test "`echo \"$path_\" | fgrep @executable_path | wc -l`" -eq 0 + then + $echo install_name_tool -change \"$path_\" \"@executable_path/$fdir_/$path_\" \"$lib_or_exe_\" + $do install_name_tool -change "$path_" "@executable_path/$fdir_/$path_" "$lib_or_exe_" + else + true + fi +} + +id_core="`Id \"$base/$fdir/QtCore.framework\"`" +id_gui="`Id \"$base/$fdir/QtGui.framework\"`" + +SetId "$base" "$fdir" "$id_core" +SetId "$base" "$fdir" "$id_gui" + +core_lib="$base/$fdir/QtCore.framework/Versions/Current/QtCore" +gui_lib="$base/$fdir/QtGui.framework/Versions/Current/QtGui" + +gui_path_in_exe="`Path \"$exe\" QtGui`" +core_path_in_exe="`Path \"$exe\" QtCore`" +core_path_in_gui="`Path \"$gui_lib\" QtCore`" + +SetPath "$exe" "$fdir" "$gui_path_in_exe" && \ +SetPath "$exe" "$fdir" "$core_path_in_exe" && \ +SetPath "$gui_lib" "$fdir" "$core_path_in_gui" + diff --git a/bin/make-setup.sh_ b/bin/make-setup.sh_ new file mode 100644 index 0000000..f017931 --- /dev/null +++ b/bin/make-setup.sh_ @@ -0,0 +1,101 @@ +#!/bin/sh +# +# Copyright (C) 2001-2008 Graeme Walker +# +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . +# === +# +# make-setup.sh +# +# Builds a "setup" self-extracting archive -- or a payload file for +# one -- derived from running "make install" into a temporary directory. +# +# usage: make-setup.sh [-d] +# +# Normally run by "make setup" in the "src/gui". +# +# The packed files are those that appear under "/usr", which +# matches the default installation directory presented in the +# gui (see Dir::os_install()). +# +# There is only one level of packing, so the gui executable +# should be statically linked or repacked with its shared +# libraries if targeting other machines. +# + +# parse the command line +debug="0" ; if test "$1" = "-d" ; then shift ; debug="1" ; fi +setup="$1" +stub="$2" +pack="$3" +icon="$4" + +# define temporary directories and cleanup code +tmp="/tmp/`basename $0 .sh`.$$.tmp" +install="$tmp/install" +list="$tmp/list" +trap Cleanup 0 +trap Fail 1 2 3 13 15 +Cleanup() +{ + if test "$debug" -eq 0 + then + rm -rf "$tmp" + fi +} +Fail() +{ + Cleanup + exit 1 +} + +# check the command-line +if test "$setup" = "" -o ! -f "$stub" -o ! -x "$pack" +then + echo usage: `basename $0` ' ' >&2 + exit 2 +fi + +# run "make install" +echo `basename $0`: running make install into $install +mkdir -p $install +( cd ../.. && make install HAVE_DOXYGEN=no DESTDIR=$install ) > /dev/null 2>&1 + +# add in some extras +if test -d "$install/usr/lib/emailrelay/" +then + cp "$icon" $install/usr/lib/emailrelay/ +else + cp "$icon" $install/Applications/E-MailRelay/ +fi + +# build a file list +Filter() +{ + fgrep -v /doxygen/ | fgrep -v /emailrelay-gui +} +Edit() +{ + sed 's: \./: :' +} +echo `basename $0`: building a file list +find $install -type f | Filter | grep -n . | sed 's/:/1 /' > $list +( cd $install && find . -type f ) | Filter | grep -n . | sed 's/:/2 /' | Edit >> $list +sort -n $list | sed 's/^[0-9][0-9]* //' > $list.tmp && mv $list.tmp $list + +# create the packed file +echo `basename $0`: packing +PATH=".:$PATH" +"$pack" -q -f "$list" "$setup" "$stub" + diff --git a/bin/mu2docbook.sh_ b/bin/mu2docbook.sh_ index b71dc5d..becb588 100644 --- a/bin/mu2docbook.sh_ +++ b/bin/mu2docbook.sh_ @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (C) 2001-2007 Graeme Walker +# Copyright (C) 2001-2008 Graeme Walker # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by diff --git a/bin/mu2html.sh_ b/bin/mu2html.sh_ index c59560e..42d9746 100644 --- a/bin/mu2html.sh_ +++ b/bin/mu2html.sh_ @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (C) 2001-2007 Graeme Walker +# Copyright (C) 2001-2008 Graeme Walker # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -58,7 +58,7 @@ stylesheet="${2}" if test "${stylesheet}" != "" -a \! -f "${stylesheet}" then - echo `basename $0`: warning: missing stylesheet: ${stylesheet} >&2 + : # echo `basename $0`: warning: missing stylesheet: ${stylesheet} >&2 fi Main() diff --git a/bin/startup-mac.plist b/bin/startup-mac.plist new file mode 100644 index 0000000..09adb32 --- /dev/null +++ b/bin/startup-mac.plist @@ -0,0 +1,12 @@ +{ + Description = "E-MailRelay server"; + Provides = ("E-MailRelay"); + Requires = ("Network"); + Uses = ("Network"); + OrderPreference = "Late"; + Messages = + { + start = "Starting E-MailRelay"; + stop = "Stopping E-MailRelay"; + }; +} diff --git a/bin/txt2html.sh_ b/bin/txt2html.sh_ index 6cfa4ef..04f9f37 100644 --- a/bin/txt2html.sh_ +++ b/bin/txt2html.sh_ @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (C) 2001-2007 Graeme Walker +# Copyright (C) 2001-2008 Graeme Walker # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -78,7 +78,7 @@ fi if test "${stylesheet}" != "" -a \! -f "${stylesheet}" then - echo `basename $0`: warning: missing stylesheet: "${stylesheet}" >&2 + : # echo `basename $0`: warning: missing stylesheet: "${stylesheet}" >&2 fi if test "${graphics_dir}" = "" @@ -89,5 +89,5 @@ fi txt2mu="`dirname $0`/txt2mu.sh" mu2html="`dirname $0`/mu2html.sh" expand="`dirname $0`/expand.sh" -cat ${file} | ${expand} -a "${awk}" ${t} | ${txt2mu} -a "${awk}" ${t} | ${mu2html} -a "${awk}" ${x} "${title}" "${stylesheet}" | ${expand} -a "${awk}" +cat "${file}" | "${expand}" -a "${awk}" "${t}" | "${txt2mu}" -a "${awk}" "${t}" | "${mu2html}" -a "${awk}" ${x} "${title}" "${stylesheet}" | "${expand}" -a "${awk}" diff --git a/bin/txt2mu.sh_ b/bin/txt2mu.sh_ index 0db939f..79851e1 100644 --- a/bin/txt2mu.sh_ +++ b/bin/txt2mu.sh_ @@ -1,6 +1,6 @@ #!/bin/sh # -# Copyright (C) 2001-2007 Graeme Walker +# Copyright (C) 2001-2008 Graeme Walker # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -324,7 +324,7 @@ Cat() # == -Cat ${file} | \ +Cat "${file}" | \ Main "${text_mode}" | \ Compress | \ Number "item" | \ diff --git a/bootstrap b/bootstrap new file mode 100644 index 0000000..5e28f06 --- /dev/null +++ b/bootstrap @@ -0,0 +1,10 @@ +#!/bin/sh +# +# bootstrap +# +# Autogenerates stuff. +# +aclocal +autoconf +autoheader +automake -a -Woverride -Wportability diff --git a/config.h.in b/config.h.in index cc80e8f..f1d176d 100644 --- a/config.h.in +++ b/config.h.in @@ -1,5 +1,11 @@ /* config.h.in. Generated from configure.ac by autoheader. */ +/* Define for a mac build */ +#undef G_MAC + +/* Define to disable the G_LOG macro */ +#undef G_NO_LOG + /* Define to 1 if requires */ #undef HAVE_BUGGY_CTIME @@ -16,9 +22,6 @@ /* Define to 1 if gmtime_r in time.h */ #undef HAVE_GMTIME_R -/* Define to 1 to enable gui code */ -#undef HAVE_GUI - /* Define to 1 if you have the header file. */ #undef HAVE_INTTYPES_H @@ -34,9 +37,6 @@ /* Define to 1 if you have the header file, and it defines `DIR'. */ #undef HAVE_NDIR_H -/* Define to 1 to enable tls/ssh code using openssl */ -#undef HAVE_OPENSSL - /* Define to 1 if setgroups is available */ #undef HAVE_SETGROUPS @@ -81,9 +81,6 @@ /* Define to 1 if you have the header file. */ #undef HAVE_ZLIB_H -/* Name of package */ -#undef PACKAGE - /* Define to the address where bug reports for this package should be sent. */ #undef PACKAGE_BUGREPORT @@ -105,8 +102,29 @@ /* Define to 1 if you can safely include both and . */ #undef TIME_WITH_SYS_TIME -/* Version number of package */ -#undef VERSION +/* Define to use IPv6 */ +#undef USE_IPV6 + +/* Define to eliminate unused admin interface code as a size optimisation */ +#undef USE_NO_ADMIN + +/* Define to eliminate unused authentication code as a size optimisation */ +#undef USE_NO_AUTH + +/* Define to eliminate unused exec-ing code as a size optimisation */ +#undef USE_NO_EXEC + +/* Define to eliminate unused pop code as a size optimisation */ +#undef USE_NO_POP + +/* Define to eliminate proxying code as a size optimisation */ +#undef USE_NO_PROXY + +/* Define to eliminate unused config code as a size optimisation */ +#undef USE_SMALL_CONFIG + +/* Define to have exception types as functions as a size optimisation */ +#undef USE_SMALL_EXCEPTIONS /* Define to enable extra debug messages at compile-time */ #undef _DEBUG diff --git a/configure b/configure index 3f0807a..ad654ba 100755 --- a/configure +++ b/configure @@ -1,6 +1,6 @@ #! /bin/sh # Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.61. +# Generated by GNU Autoconf 2.61 for E-MailRelay 1.8. # # Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001, # 2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc. @@ -570,11 +570,11 @@ MAKEFLAGS= SHELL=${CONFIG_SHELL-/bin/sh} # Identity of this package. -PACKAGE_NAME= -PACKAGE_TARNAME= -PACKAGE_VERSION= -PACKAGE_STRING= -PACKAGE_BUGREPORT= +PACKAGE_NAME='E-MailRelay' +PACKAGE_TARNAME='emailrelay' +PACKAGE_VERSION='1.8' +PACKAGE_STRING='E-MailRelay 1.8' +PACKAGE_BUGREPORT='' ac_unique_file="src/gsmtp/gsmtp.h" # Factoring default headers for most tests. @@ -708,14 +708,39 @@ COMPILER_VERSION CPP EGREP PKG_CONFIG -IP QT_CFLAGS QT_LIBS MOC +IPV6_TRUE +IPV6_FALSE GUI_TRUE GUI_FALSE +POP_TRUE +POP_FALSE +EXEC_TRUE +EXEC_FALSE +ADMIN_TRUE +ADMIN_FALSE +AUTH_TRUE +AUTH_FALSE +DNS_TRUE +DNS_FALSE +IDENTITY_TRUE +IDENTITY_FALSE +SMALL_CONFIG_TRUE +SMALL_CONFIG_FALSE +SMALL_FRAGMENTS_TRUE +SMALL_FRAGMENTS_FALSE +FRAGMENTS_LIST +PROXY_TRUE +PROXY_FALSE +MAC_TRUE +MAC_FALSE SSL_LIBS -SSL +OPENSSL_TRUE +OPENSSL_FALSE +GLOB_TRUE +GLOB_FALSE STATIC_START STATIC_END e_docdir @@ -781,7 +806,7 @@ sharedstatedir='${prefix}/com' localstatedir='${prefix}/var' includedir='${prefix}/include' oldincludedir='/usr/include' -docdir='${datarootdir}/doc/${PACKAGE}' +docdir='${datarootdir}/doc/${PACKAGE_TARNAME}' infodir='${datarootdir}/info' htmldir='${docdir}' dvidir='${docdir}' @@ -1245,7 +1270,7 @@ if test "$ac_init_help" = "long"; then # Omit some internal or obsolete options to make the list less imposing. # This message is too long to be a string in the A/UX 3.1 sh. cat <<_ACEOF -\`configure' configures this package to adapt to many kinds of systems. +\`configure' configures E-MailRelay 1.8 to adapt to many kinds of systems. Usage: $0 [OPTION]... [VAR=VALUE]... @@ -1293,7 +1318,7 @@ Fine tuning of the installation directories: --infodir=DIR info documentation [DATAROOTDIR/info] --localedir=DIR locale-dependent data [DATAROOTDIR/locale] --mandir=DIR man documentation [DATAROOTDIR/man] - --docdir=DIR documentation root [DATAROOTDIR/doc/PACKAGE] + --docdir=DIR documentation root [DATAROOTDIR/doc/emailrelay] --htmldir=DIR html documentation [DOCDIR] --dvidir=DIR dvi documentation [DOCDIR] --pdfdir=DIR pdf documentation [DOCDIR] @@ -1310,7 +1335,9 @@ _ACEOF fi if test -n "$ac_init_help"; then - + case $ac_init_help in + short | recursive ) echo "Configuration of E-MailRelay 1.8:";; + esac cat <<\_ACEOF Optional Features: @@ -1321,26 +1348,44 @@ Optional Features: --disable-dependency-tracking speeds up one-time build --enable-dependency-tracking do not reject slow dependency extractors --enable-debug enable extra debug messages at compile-time (default - disabled) - --enable-ipv6 enable ipv6 (default disabled) + no) + --enable-ipv6 enable ipv6 (default no) --enable-gui enable configuration gui (requires Qt4) (default auto) + --enable-verbose enable verbose logging (default yes) + --enable-pop enable pop3 protocol (default yes) + --enable-exec enable running of external programs (disable-exec + requires disable-gui) (default yes) + --enable-admin enable admin interface (default yes) + --enable-auth enable authentication (disable-auth requires + disable-pop) (default yes) + --enable-dns enable dns lookup (default yes) + --enable-identity enable process userid switching (default yes) + --enable-small-config enable simplified confuration code for smaller + binaries (rtfm) (default no) + --enable-small-fragments + enable fragmented object files for smaller binaries + (default no) + --enable-small-exceptions + optimise exception classes for smaller binaries + (default no) + --enable-proxy enable proxying (default yes) + --enable-mac enable building for a mac os x target (default auto) --enable-static-linking prefer static linking for some libraries (default no) --enable-fhs force FHS-compliant directories, ignoring --prefix - etc (default disabled) + etc (default no) Optional Packages: --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) - --with-workshop use Sun WorkShop 'CC -xar' as the 'ar' tool (default - disabled) --with-doxygen generate source code documentation with doxygen (default auto) --with-man2html convert man pages to html using man2html (default auto) --with-openssl use openssl for smtp client tls extension (default auto) + --with-glob use glob() for reading directories (default auto) Some influential environment variables: CC C compiler command @@ -1420,7 +1465,7 @@ fi test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF -configure +E-MailRelay configure 1.8 generated by GNU Autoconf 2.61 Copyright (C) 1992, 1993, 1994, 1995, 1996, 1998, 1999, 2000, 2001, @@ -1434,7 +1479,7 @@ cat >config.log <<_ACEOF This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. -It was created by $as_me, which was +It was created by E-MailRelay $as_me 1.8, which was generated by GNU Autoconf 2.61. Invocation command line was $ $0 $@ @@ -1767,6 +1812,14 @@ fi + + + + + + + + @@ -1779,6 +1832,7 @@ ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $ ac_compiler_gnu=$ac_cv_c_compiler_gnu + am__api_version='1.10' ac_aux_dir= @@ -2115,19 +2169,10 @@ fi # Define the identity of the package. - PACKAGE=emailrelay - VERSION=1.7 + PACKAGE='emailrelay' + VERSION='1.8' -cat >>confdefs.h <<_ACEOF -#define PACKAGE "$PACKAGE" -_ACEOF - - -cat >>confdefs.h <<_ACEOF -#define VERSION "$VERSION" -_ACEOF - # Some tools Automake needs. ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"} @@ -4347,12 +4392,11 @@ fi - COMPILER_VERSION=`$CXX --version 2>/dev/null | sed q | sed 's/[^0-9 .]*//g;s/\./ /g;s/^ *//;s/ /./;s/ .*//;s/^/gcc/' | sed 's/gcc2.96/gcc2.95/'` - if test -z "${COMPILER_VERSION}" - then - COMPILER_VERSION=`$CXX -V 2>&1 | sed q | grep WorkShop | sed 's/[^0-9]*//;s/[ \.].*//;s/^/sunpro/'` - fi + COMPILER_VERSION_GCC=`$CXX --version 2>/dev/null | sed q | grep GCC | sed 's/[a-zA-Z][a-zA-Z]*[0-9]*//g' | sed 's/[^0-9 .]*//g;s/\./ /g;s/^ *//;s/ /./;s/ .*//;s/^/gcc/' | sed 's/gcc2.96/gcc2.95/'` + COMPILER_VERSION_SUNPRO=`$CXX -V 2>&1 | sed q | grep WorkShop | sed 's/[^0-9]*//;s/[ \.].*//;s/^/sunpro/'` + COMPILER_VERSION_ICC=`$CXX --version 2>&1 | sed q | grep ICC | sed 's/[^0-9]*//;s/[ \.].*//;s/^/icc/'` + COMPILER_VERSION="${COMPILER_VERSION_GCC}${COMPILER_VERSION_SUNPRO}${COMPILER_VERSION_ICC}" @@ -6528,6 +6572,259 @@ _ACEOF +if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then + if test -n "$ac_tool_prefix"; then + # Extract the first word of "${ac_tool_prefix}pkg-config", so it can be a program name with args. +set dummy ${ac_tool_prefix}pkg-config; ac_word=$2 +{ echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } +if test "${ac_cv_path_PKG_CONFIG+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + case $PKG_CONFIG in + [\\/]* | ?:[\\/]*) + ac_cv_path_PKG_CONFIG="$PKG_CONFIG" # Let the user override the test with a path. + ;; + *) + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_path_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + + ;; +esac +fi +PKG_CONFIG=$ac_cv_path_PKG_CONFIG +if test -n "$PKG_CONFIG"; then + { echo "$as_me:$LINENO: result: $PKG_CONFIG" >&5 +echo "${ECHO_T}$PKG_CONFIG" >&6; } +else + { echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6; } +fi + + +fi +if test -z "$ac_cv_path_PKG_CONFIG"; then + ac_pt_PKG_CONFIG=$PKG_CONFIG + # Extract the first word of "pkg-config", so it can be a program name with args. +set dummy pkg-config; ac_word=$2 +{ echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } +if test "${ac_cv_path_ac_pt_PKG_CONFIG+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + case $ac_pt_PKG_CONFIG in + [\\/]* | ?:[\\/]*) + ac_cv_path_ac_pt_PKG_CONFIG="$ac_pt_PKG_CONFIG" # Let the user override the test with a path. + ;; + *) + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_path_ac_pt_PKG_CONFIG="$as_dir/$ac_word$ac_exec_ext" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + + ;; +esac +fi +ac_pt_PKG_CONFIG=$ac_cv_path_ac_pt_PKG_CONFIG +if test -n "$ac_pt_PKG_CONFIG"; then + { echo "$as_me:$LINENO: result: $ac_pt_PKG_CONFIG" >&5 +echo "${ECHO_T}$ac_pt_PKG_CONFIG" >&6; } +else + { echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6; } +fi + + if test "x$ac_pt_PKG_CONFIG" = x; then + PKG_CONFIG="" + else + case $cross_compiling:$ac_tool_warned in +yes:) +{ echo "$as_me:$LINENO: WARNING: In the future, Autoconf will not detect cross-tools +whose name does not start with the host triplet. If you think this +configuration is useful to you, please write to autoconf@gnu.org." >&5 +echo "$as_me: WARNING: In the future, Autoconf will not detect cross-tools +whose name does not start with the host triplet. If you think this +configuration is useful to you, please write to autoconf@gnu.org." >&2;} +ac_tool_warned=yes ;; +esac + PKG_CONFIG=$ac_pt_PKG_CONFIG + fi +else + PKG_CONFIG="$ac_cv_path_PKG_CONFIG" +fi + +fi +if test -n "$PKG_CONFIG"; then + _pkg_min_version=0.9.0 + { echo "$as_me:$LINENO: checking pkg-config is at least version $_pkg_min_version" >&5 +echo $ECHO_N "checking pkg-config is at least version $_pkg_min_version... $ECHO_C" >&6; } + if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then + { echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6; } + else + { echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6; } + PKG_CONFIG="" + fi + +fi + + +pkg_failed=no +{ echo "$as_me:$LINENO: checking for QT" >&5 +echo $ECHO_N "checking for QT... $ECHO_C" >&6; } + +if test -n "$PKG_CONFIG"; then + if test -n "$QT_CFLAGS"; then + pkg_cv_QT_CFLAGS="$QT_CFLAGS" + else + if test -n "$PKG_CONFIG" && \ + { (echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"QtGui >= 4.0.1\"") >&5 + ($PKG_CONFIG --exists --print-errors "QtGui >= 4.0.1") 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + pkg_cv_QT_CFLAGS=`$PKG_CONFIG --cflags "QtGui >= 4.0.1" 2>/dev/null` +else + pkg_failed=yes +fi + fi +else + pkg_failed=untried +fi +if test -n "$PKG_CONFIG"; then + if test -n "$QT_LIBS"; then + pkg_cv_QT_LIBS="$QT_LIBS" + else + if test -n "$PKG_CONFIG" && \ + { (echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"QtGui >= 4.0.1\"") >&5 + ($PKG_CONFIG --exists --print-errors "QtGui >= 4.0.1") 2>&5 + ac_status=$? + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); }; then + pkg_cv_QT_LIBS=`$PKG_CONFIG --libs "QtGui >= 4.0.1" 2>/dev/null` +else + pkg_failed=yes +fi + fi +else + pkg_failed=untried +fi + + + +if test $pkg_failed = yes; then + +if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then + _pkg_short_errors_supported=yes +else + _pkg_short_errors_supported=no +fi + if test $_pkg_short_errors_supported = yes; then + QT_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "QtGui >= 4.0.1"` + else + QT_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "QtGui >= 4.0.1"` + fi + # Put the nasty error message in config.log where it belongs + echo "$QT_PKG_ERRORS" >&5 + + { echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6; } + { echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6; } +elif test $pkg_failed = untried; then + { echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6; } +else + QT_CFLAGS=$pkg_cv_QT_CFLAGS + QT_LIBS=$pkg_cv_QT_LIBS + { echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6; } + qt4=yes +fi + + MOC="${e_qtmoc}" + # Extract the first word of "moc", so it can be a program name with args. +set dummy moc; ac_word=$2 +{ echo "$as_me:$LINENO: checking for $ac_word" >&5 +echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } +if test "${ac_cv_path_MOC+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + case $MOC in + [\\/]* | ?:[\\/]*) + ac_cv_path_MOC="$MOC" # Let the user override the test with a path. + ;; + *) + as_save_IFS=$IFS; IFS=$PATH_SEPARATOR +for as_dir in $PATH +do + IFS=$as_save_IFS + test -z "$as_dir" && as_dir=. + for ac_exec_ext in '' $ac_executable_extensions; do + if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then + ac_cv_path_MOC="$as_dir/$ac_word$ac_exec_ext" + echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 + break 2 + fi +done +done +IFS=$as_save_IFS + + ;; +esac +fi +MOC=$ac_cv_path_MOC +if test -n "$MOC"; then + { echo "$as_me:$LINENO: result: $MOC" >&5 +echo "${ECHO_T}$MOC" >&6; } +else + { echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6; } +fi + + + + if test "$MOC" != "" + then + { echo "$as_me:$LINENO: checking moc is for qt 4" >&5 +echo $ECHO_N "checking moc is for qt 4... $ECHO_C" >&6; } + if test x$GREP = x ; then GREP=grep ; fi + if test -x "$MOC" -a "`$MOC -v 2>&1 | $GREP 'Qt 4'`" != "" ; then + { echo "$as_me:$LINENO: result: yes" >&5 +echo "${ECHO_T}yes" >&6; } + aclocal_moc="$MOC" + else + { echo "$as_me:$LINENO: result: no" >&5 +echo "${ECHO_T}no" >&6; } + aclocal_moc="" + fi + fi + + + if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then if test -n "$ac_tool_prefix"; then @@ -6654,14 +6951,16 @@ if test "${enable_debug+set}" = set; then fi -if test "$enable_debug" = "yes" -then + if test "$enable_debug" = "no" -o -z "$enable_debug" + then + : + else cat >>confdefs.h <<\_ACEOF #define _DEBUG 1 _ACEOF -fi + fi # Check whether --enable-ipv6 was given. @@ -6670,18 +6969,30 @@ if test "${enable_ipv6+set}" = set; then fi -if test "$enable_ipv6" = "yes" -then - if test "$aclocal_ipv6" != "yes" + if test "$enable_ipv6" = "yes" then - { echo "$as_me:$LINENO: WARNING: ignoring --enable-ipv6" >&5 + if test "$aclocal_ipv6" != "yes" + then + { echo "$as_me:$LINENO: WARNING: ignoring --enable-ipv6" >&5 echo "$as_me: WARNING: ignoring --enable-ipv6" >&2;} - IP="ipv4" + aclocal_use_ipv6="no" + else + +cat >>confdefs.h <<\_ACEOF +#define USE_IPV6 1 +_ACEOF + + aclocal_use_ipv6="yes" + fi else - IP="ipv6" + aclocal_use_ipv6="no" fi + if test x$aclocal_use_ipv6 = xyes; then + IPV6_TRUE= + IPV6_FALSE='#' else - IP="ipv4" + IPV6_TRUE='#' + IPV6_FALSE= fi @@ -6692,164 +7003,26 @@ if test "${enable_gui+set}" = set; then fi -qt4="no" -qt4moc="no" -if test "$enable_gui" = "no" -then - -cat >>confdefs.h <<\_ACEOF -#define HAVE_GUI 0 -_ACEOF - -else - -pkg_failed=no -{ echo "$as_me:$LINENO: checking for QT" >&5 -echo $ECHO_N "checking for QT... $ECHO_C" >&6; } - -if test -n "$PKG_CONFIG"; then - if test -n "$QT_CFLAGS"; then - pkg_cv_QT_CFLAGS="$QT_CFLAGS" - else - if test -n "$PKG_CONFIG" && \ - { (echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"QtGui >= 4.0.1\"") >&5 - ($PKG_CONFIG --exists --print-errors "QtGui >= 4.0.1") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - pkg_cv_QT_CFLAGS=`$PKG_CONFIG --cflags "QtGui >= 4.0.1" 2>/dev/null` -else - pkg_failed=yes -fi - fi -else - pkg_failed=untried -fi -if test -n "$PKG_CONFIG"; then - if test -n "$QT_LIBS"; then - pkg_cv_QT_LIBS="$QT_LIBS" - else - if test -n "$PKG_CONFIG" && \ - { (echo "$as_me:$LINENO: \$PKG_CONFIG --exists --print-errors \"QtGui >= 4.0.1\"") >&5 - ($PKG_CONFIG --exists --print-errors "QtGui >= 4.0.1") 2>&5 - ac_status=$? - echo "$as_me:$LINENO: \$? = $ac_status" >&5 - (exit $ac_status); }; then - pkg_cv_QT_LIBS=`$PKG_CONFIG --libs "QtGui >= 4.0.1" 2>/dev/null` -else - pkg_failed=yes -fi - fi -else - pkg_failed=untried -fi - - - -if test $pkg_failed = yes; then - -if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then - _pkg_short_errors_supported=yes -else - _pkg_short_errors_supported=no -fi - if test $_pkg_short_errors_supported = yes; then - QT_PKG_ERRORS=`$PKG_CONFIG --short-errors --errors-to-stdout --print-errors "QtGui >= 4.0.1"` - else - QT_PKG_ERRORS=`$PKG_CONFIG --errors-to-stdout --print-errors "QtGui >= 4.0.1"` - fi - # Put the nasty error message in config.log where it belongs - echo "$QT_PKG_ERRORS" >&5 - - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -elif test $pkg_failed = untried; then - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -else - QT_CFLAGS=$pkg_cv_QT_CFLAGS - QT_LIBS=$pkg_cv_QT_LIBS - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } - qt4=yes -fi - if test "$qt4" = "yes" + if test "$enable_gui" = "no" then - MOC="${e_qtmoc}" - # Extract the first word of "moc", so it can be a program name with args. -set dummy moc; ac_word=$2 -{ echo "$as_me:$LINENO: checking for $ac_word" >&5 -echo $ECHO_N "checking for $ac_word... $ECHO_C" >&6; } -if test "${ac_cv_path_MOC+set}" = set; then - echo $ECHO_N "(cached) $ECHO_C" >&6 -else - case $MOC in - [\\/]* | ?:[\\/]*) - ac_cv_path_MOC="$MOC" # Let the user override the test with a path. - ;; - *) - as_save_IFS=$IFS; IFS=$PATH_SEPARATOR -for as_dir in $PATH -do - IFS=$as_save_IFS - test -z "$as_dir" && as_dir=. - for ac_exec_ext in '' $ac_executable_extensions; do - if { test -f "$as_dir/$ac_word$ac_exec_ext" && $as_test_x "$as_dir/$ac_word$ac_exec_ext"; }; then - ac_cv_path_MOC="$as_dir/$ac_word$ac_exec_ext" - echo "$as_me:$LINENO: found $as_dir/$ac_word$ac_exec_ext" >&5 - break 2 - fi -done -done -IFS=$as_save_IFS - - ;; -esac -fi -MOC=$ac_cv_path_MOC -if test -n "$MOC"; then - { echo "$as_me:$LINENO: result: $MOC" >&5 -echo "${ECHO_T}$MOC" >&6; } -else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } -fi - - - { echo "$as_me:$LINENO: checking moc is for qt 4" >&5 -echo $ECHO_N "checking moc is for qt 4... $ECHO_C" >&6; } - if test x$GREP = x ; then GREP=grep ; fi - if test -x "$MOC" -a "`$MOC -v 2>&1 | $GREP 'Qt 4'`" != "" ; then - { echo "$as_me:$LINENO: result: yes" >&5 -echo "${ECHO_T}yes" >&6; } - qt4moc="yes" - else - { echo "$as_me:$LINENO: result: no" >&5 -echo "${ECHO_T}no" >&6; } - fi + MOC="" else - QT_LIBS="" - + if test "$enable_gui" = "yes" -a "$aclocal_moc" = "" + then + { echo "$as_me:$LINENO: WARNING: ignoring --enable-gui, set e_qtmoc to a Qt4 moc program to override" >&5 +echo "$as_me: WARNING: ignoring --enable-gui, set e_qtmoc to a Qt4 moc program to override" >&2;} + fi + MOC="$aclocal_moc" fi -fi -if test "$qt4moc" = "yes" -then -cat >>confdefs.h <<\_ACEOF -#define HAVE_GUI 1 -_ACEOF + if test "`uname`" = "Darwin" -a "$QT_LIBS" = "" + then + QT_LIBS="-framework QtGui -framework QtCore" + fi -else -cat >>confdefs.h <<\_ACEOF -#define HAVE_GUI 0 -_ACEOF -fi - - if test x$enable_gui != xno -a x$qt4moc = xyes ; then + if test x$MOC != x ; then GUI_TRUE= GUI_FALSE='#' else @@ -6858,22 +7031,295 @@ else fi + if test x$enable_exec = xno -a x$MOC != x + then + { { echo "$as_me:$LINENO: error: using --disable-exec requires --disable-gui" >&5 +echo "$as_me: error: using --disable-exec requires --disable-gui" >&2;} + { (exit 1); exit 1; }; } + fi -# Check whether --with-workshop was given. -if test "${with_workshop+set}" = set; then - withval=$with_workshop; +# Check whether --enable-verbose was given. +if test "${enable_verbose+set}" = set; then + enableval=$enable_verbose; fi -if test "$with_workshop" = "yes" -then - chmod +x lib/sunpro5/xar - AR="`pwd`/lib/sunpro5/xar --cxx \"$CXX\"" + if test x$enable_verbose != xno + then + : + else +cat >>confdefs.h <<\_ACEOF +#define G_NO_LOG 1 +_ACEOF + + fi + + +# Check whether --enable-pop was given. +if test "${enable_pop+set}" = set; then + enableval=$enable_pop; fi + if test x$enable_pop != xno + then + : + else + +cat >>confdefs.h <<\_ACEOF +#define USE_NO_POP 1 +_ACEOF + + fi + if test x$enable_pop != xno; then + POP_TRUE= + POP_FALSE='#' +else + POP_TRUE='#' + POP_FALSE= +fi + + + +# Check whether --enable-exec was given. +if test "${enable_exec+set}" = set; then + enableval=$enable_exec; +fi + + + if test x$enable_exec != xno + then + : + else + +cat >>confdefs.h <<\_ACEOF +#define USE_NO_EXEC 1 +_ACEOF + + fi + if test x$enable_exec != xno; then + EXEC_TRUE= + EXEC_FALSE='#' +else + EXEC_TRUE='#' + EXEC_FALSE= +fi + + + +# Check whether --enable-exec was given. +if test "${enable_exec+set}" = set; then + enableval=$enable_exec; +fi + + + if test x$enable_admin != xno + then + : + else + +cat >>confdefs.h <<\_ACEOF +#define USE_NO_ADMIN 1 +_ACEOF + + fi + if test x$enable_admin != xno; then + ADMIN_TRUE= + ADMIN_FALSE='#' +else + ADMIN_TRUE='#' + ADMIN_FALSE= +fi + + + +# Check whether --enable-exec was given. +if test "${enable_exec+set}" = set; then + enableval=$enable_exec; +fi + + + if test x$enable_auth != xno + then + : + else + +cat >>confdefs.h <<\_ACEOF +#define USE_NO_AUTH 1 +_ACEOF + + fi + if test x$enable_auth != xno; then + AUTH_TRUE= + AUTH_FALSE='#' +else + AUTH_TRUE='#' + AUTH_FALSE= +fi + + if test x$enable_auth = xno -a x$enable_pop != xno + then + { { echo "$as_me:$LINENO: error: using --disable-auth requires --disable-pop" >&5 +echo "$as_me: error: using --disable-auth requires --disable-pop" >&2;} + { (exit 1); exit 1; }; } + fi + + +# Check whether --enable-exec was given. +if test "${enable_exec+set}" = set; then + enableval=$enable_exec; +fi + + + if test x$enable_dns != xno; then + DNS_TRUE= + DNS_FALSE='#' +else + DNS_TRUE='#' + DNS_FALSE= +fi + + + +# Check whether --enable-exec was given. +if test "${enable_exec+set}" = set; then + enableval=$enable_exec; +fi + + + if test x$enable_identity != xno; then + IDENTITY_TRUE= + IDENTITY_FALSE='#' +else + IDENTITY_TRUE='#' + IDENTITY_FALSE= +fi + + + +# Check whether --enable-exec was given. +if test "${enable_exec+set}" = set; then + enableval=$enable_exec; +fi + + + if test x$enable_small_config = xyes + then + +cat >>confdefs.h <<\_ACEOF +#define USE_SMALL_CONFIG 1 +_ACEOF + + else + : + fi + if test x$enable_small_config = xyes; then + SMALL_CONFIG_TRUE= + SMALL_CONFIG_FALSE='#' +else + SMALL_CONFIG_TRUE='#' + SMALL_CONFIG_FALSE= +fi + + + +# Check whether --enable-exec was given. +if test "${enable_exec+set}" = set; then + enableval=$enable_exec; +fi + + + if test x$enable_small_fragments = xyes; then + SMALL_FRAGMENTS_TRUE= + SMALL_FRAGMENTS_FALSE='#' +else + SMALL_FRAGMENTS_TRUE='#' + SMALL_FRAGMENTS_FALSE= +fi + + if test x$enable_small_fragments = xyes + then + { echo "$as_me:$LINENO: creating source file fragments" >&5 +echo "$as_me: creating source file fragments" >&6;} + FRAGMENTS_LIST="`perl $srcdir/bin/fragment.pl_ -r $srcdir/src $srcdir/src/fragments`" + for fragment in $FRAGMENTS_LIST "" ; do if test "$fragment" != "" ; then + { echo "$as_me:$LINENO: creating source file fragment for $fragment" >&5 +echo "$as_me: creating source file fragment for $fragment" >&6;} + fi ; done + fi + + + +# Check whether --enable-small_exceptions was given. +if test "${enable_small_exceptions+set}" = set; then + enableval=$enable_small_exceptions; +fi + + + if test x$enable_small_exceptions = xyes + then + +cat >>confdefs.h <<\_ACEOF +#define USE_SMALL_EXCEPTIONS 1 +_ACEOF + + else + : + fi + + +# Check whether --enable-proxy was given. +if test "${enable_proxy+set}" = set; then + enableval=$enable_proxy; +fi + + + if test x$enable_proxy != xno + then + : + else + +cat >>confdefs.h <<\_ACEOF +#define USE_NO_PROXY 1 +_ACEOF + + fi + if test x$enable_proxy != xno; then + PROXY_TRUE= + PROXY_FALSE='#' +else + PROXY_TRUE='#' + PROXY_FALSE= +fi + + + +# Check whether --enable-mac was given. +if test "${enable_mac+set}" = set; then + enableval=$enable_mac; +fi + + + if test x$enable_mac = xyes -o "`uname`" = "Darwin" + then + +cat >>confdefs.h <<\_ACEOF +#define G_MAC 1 +_ACEOF + + fi + if test x$enable_mac = xyes -o "`uname`" = "Darwin"; then + MAC_TRUE= + MAC_FALSE='#' +else + MAC_TRUE='#' + MAC_FALSE= +fi + + + # Check whether --with-doxygen was given. if test "${with_doxygen+set}" = set; then @@ -6881,17 +7327,16 @@ if test "${with_doxygen+set}" = set; then fi -if test "$with_doxygen" != "" -then - if test "$with_doxygen" = "yes" -a "$HAVE_DOXYGEN" != "yes" + if test "$with_doxygen" != "" then - { echo "$as_me:$LINENO: WARNING: ignoring --with-doxygen" >&5 -echo "$as_me: WARNING: ignoring --with-doxygen" >&2;} - else + if test "$with_doxygen" = "yes" -a "$HAVE_DOXYGEN" != "yes" + then + { echo "$as_me:$LINENO: WARNING: forcing use of doxygen even though not found" >&5 +echo "$as_me: WARNING: forcing use of doxygen even though not found" >&2;} + fi HAVE_DOXYGEN="$with_doxygen" - fi -fi + @@ -6901,17 +7346,16 @@ if test "${with_man2html+set}" = set; then fi -if test "$with_man2html" != "" -then - if test "$with_man2html" = "yes" -a "$HAVE_MAN2HTML" != "yes" + if test "$with_man2html" != "" then - { echo "$as_me:$LINENO: WARNING: ignoring --with-man2html" >&5 -echo "$as_me: WARNING: ignoring --with-man2html" >&2;} - else + if test "$with_man2html" = "yes" -a "$HAVE_MAN2HTML" != "yes" + then + { echo "$as_me:$LINENO: WARNING: forcing use of man2html even though not found" >&5 +echo "$as_me: WARNING: forcing use of man2html even though not found" >&2;} + fi HAVE_MAN2HTML="$with_man2html" - fi -fi + @@ -6975,37 +7419,117 @@ fi echo "${ECHO_T}$aclocal_openssl" >&6; } if test "$aclocal_openssl" = "yes" then - -cat >>confdefs.h <<\_ACEOF -#define HAVE_OPENSSL 1 -_ACEOF - SSL_LIBS="-lssl -lcrypto" - SSL="openssl" + aclocal_ssl="openssl" else if test "$with_openssl" = "yes" then { echo "$as_me:$LINENO: WARNING: ignoring --with-openssl, check config.log and try setting CFLAGS" >&5 echo "$as_me: WARNING: ignoring --with-openssl, check config.log and try setting CFLAGS" >&2;} fi - -cat >>confdefs.h <<\_ACEOF -#define HAVE_OPENSSL 0 -_ACEOF - SSL_LIBS="" - SSL="none" + aclocal_ssl="none" fi else - -cat >>confdefs.h <<\_ACEOF -#define HAVE_OPENSSL 0 -_ACEOF - SSL_LIBS="" - SSL="none" + aclocal_ssl="none" fi + if test x$aclocal_ssl = xopenssl; then + OPENSSL_TRUE= + OPENSSL_FALSE='#' +else + OPENSSL_TRUE='#' + OPENSSL_FALSE= +fi + + + + +# Check whether --with-glob was given. +if test "${with_glob+set}" = set; then + withval=$with_glob; +fi + +if test "$with_glob" != "no" +then +{ echo "$as_me:$LINENO: checking for glob" >&5 +echo $ECHO_N "checking for glob... $ECHO_C" >&6; } +if test "${aclocal_have_glob+set}" = set; then + echo $ECHO_N "(cached) $ECHO_C" >&6 +else + + cat >conftest.$ac_ext <<_ACEOF +/* confdefs.h. */ +_ACEOF +cat confdefs.h >>conftest.$ac_ext +cat >>conftest.$ac_ext <<_ACEOF +/* end confdefs.h. */ +#include +int +main () +{ +glob_t * p = 0 ; globfree(p) ; return 1; + ; + return 0; +} +_ACEOF +rm -f conftest.$ac_objext +if { (ac_try="$ac_compile" +case "(($ac_try" in + *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; + *) ac_try_echo=$ac_try;; +esac +eval "echo \"\$as_me:$LINENO: $ac_try_echo\"") >&5 + (eval "$ac_compile") 2>conftest.er1 + ac_status=$? + grep -v '^ *+' conftest.er1 >conftest.err + rm -f conftest.er1 + cat conftest.err >&5 + echo "$as_me:$LINENO: \$? = $ac_status" >&5 + (exit $ac_status); } && { + test -z "$ac_cxx_werror_flag" || + test ! -s conftest.err + } && test -s conftest.$ac_objext; then + aclocal_have_glob=yes +else + echo "$as_me: failed program was:" >&5 +sed 's/^/| /' conftest.$ac_ext >&5 + + aclocal_have_glob=no +fi + +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext + +fi +{ echo "$as_me:$LINENO: result: $aclocal_have_glob" >&5 +echo "${ECHO_T}$aclocal_have_glob" >&6; } + if test "$aclocal_have_glob" = "yes" + then + aclocal_use_glob="yes" + else + if test "$with_glob" = "yes" + then + { echo "$as_me:$LINENO: WARNING: ignoring --with-glob" >&5 +echo "$as_me: WARNING: ignoring --with-glob" >&2;} + fi + aclocal_use_glob="no" + fi +else + if test "$aclocal_have_glob" = "yes" + then + { echo "$as_me:$LINENO: WARNING: not using available glob()" >&5 +echo "$as_me: WARNING: not using available glob()" >&2;} + fi + aclocal_use_glob="no" +fi + if test x$aclocal_use_glob = xyes; then + GLOB_TRUE= + GLOB_FALSE='#' +else + GLOB_TRUE='#' + GLOB_FALSE= +fi @@ -7015,14 +7539,14 @@ if test "${enable_static_linking+set}" = set; then fi -if test "$enable_static_linking" = "yes" -then - STATIC_START="-Xlinker -Bstatic" - STATIC_END="-Xlinker -Bdynamic -ldl" -else - STATIC_START="" - STATIC_END="" -fi + if test "$enable_static_linking" = "yes" + then + STATIC_START="-Xlinker -Bstatic" + STATIC_END="-Xlinker -Bdynamic -ldl" + else + STATIC_START="" + STATIC_END="" + fi @@ -7033,56 +7557,96 @@ if test "${enable_fhs+set}" = set; then fi -if test "$e_docdir" = "" ; then e_docdir="$docdir" ; fi -if test "$e_docdir" = "" ; then e_docdir="$datadir/$PACKAGE/doc" ; fi + # the following are used in the makefiles: + # * sbindir + # * e_libexecdir + # * e_examplesdir + # * e_sysconfdir + # * mandir + # * e_docdir + # * e_spooldir + # * e_initdir + + if test "$enable_fhs" = "yes" + then + prefix='/usr' + exec_prefix='/usr' + sbindir="/usr/sbin" + libexecdir="/usr/lib" + localstatedir="/var" + mandir="/usr/share/man" + datadir="/usr/share" + sysconfdir="/etc" + fi + if test "$e_libexecdir" = "" + then + if test "$enable_fhs" = "yes" + then + e_libexecdir="$libexecdir/$PACKAGE" + else + e_libexecdir="$libexecdir/$PACKAGE" + fi + fi + if test "$e_examplesdir" = "" + then + if test "$enable_fhs" = "yes" + then + e_examplesdir="$libexecdir/$PACKAGE/examples" + else + e_examplesdir="$libexecdir/$PACKAGE/examples" + fi + fi + if test "$e_sysconfdir" = "" + then + if test "$enable_fhs" = "yes" + then + e_sysconfdir="$sysconfdir" + else + e_sysconfdir="$sysconfdir" + fi + fi + if test "$e_docdir" = "" + then + if test "$enable_fhs" = "yes" + then + e_docdir="$datadir/doc/$PACKAGE" + else + e_docdir="$docdir" + if test "$e_docdir" = "" + then + e_docdir="$datadir/$PACKAGE/doc" + fi + fi + fi + if test "$e_spooldir" = "" + then + if test "$enable_fhs" = "yes" + then + e_spooldir="$localstatedir/spool/$PACKAGE" + else + e_spooldir="$localstatedir/spool/$PACKAGE" + fi + fi + if test "$e_initdir" = "" + then + if test "$enable_fhs" = "yes" + then + e_initdir="/etc/init.d" + else + e_initdir="$libexecdir/$PACKAGE/init" + fi + fi + + -if test "$e_initdir" = "" ; then e_initdir="$libexecdir/$PACKAGE/init" ; fi -if test "$e_spooldir" = "" ; then e_spooldir="$localstatedir/spool/$PACKAGE" ; fi -if test "$e_examplesdir" = "" ; then e_examplesdir="$libexecdir/$PACKAGE/examples" ; fi -if test "$e_libexecdir" = "" ; then e_libexecdir="$libexecdir/$PACKAGE" ; fi -if test "$e_sysconfdir" = "" ; then e_sysconfdir="$sysconfdir" ; fi if test "$e_qtmoc" = "" ; then e_qtmoc="moc" ; fi -if test "$enable_fhs" = "yes" -then - - # tweaks for fhs compliance... - # - prefix='/usr' - exec_prefix='/usr' - # - sbindir='/usr/sbin' - libexecdir='/usr/lib' - localstatedir='/var' - mandir='/usr/share/man' - datadir='/usr/share' - sysconfdir='/etc' - # - # not used by emailrelay - #bindir= - #sharedstatedir= - #libdir= - #includedir= - #oldincludedir= - #infodir= - # - # emailrelay-specific - e_libexecdir="$libexecdir/$PACKAGE" - e_docdir="$datadir/doc/$PACKAGE" - e_initdir="/etc/init.d" - e_spooldir="$localstatedir/spool/$PACKAGE" - e_examplesdir="$libexecdir/$PACKAGE/examples" - e_sysconfdir="$sysconfdir" - -fi - - -ac_config_files="$ac_config_files Makefile src/Makefile src/glib/Makefile src/gssl/Makefile src/gnet/Makefile src/gsmtp/Makefile src/gpop/Makefile src/main/Makefile src/win32/Makefile src/gui/Makefile lib/Makefile lib/gcc2.95/Makefile lib/msvc6.0/Makefile lib/sunpro5/Makefile bin/Makefile doc/Makefile etc/Makefile test/Makefile" +ac_config_files="$ac_config_files Makefile src/Makefile src/glib/Makefile src/gssl/Makefile src/gnet/Makefile src/gsmtp/Makefile src/gpop/Makefile src/main/Makefile src/win32/Makefile src/gui/Makefile lib/Makefile lib/gcc2.95/Makefile lib/msvc6.0/Makefile bin/Makefile doc/Makefile etc/Makefile test/Makefile extra/Makefile extra/mips/Makefile src/fragments/Makefile" cat >confcache <<\_ACEOF # This file is a shell script that caches the results of configure @@ -7208,6 +7772,13 @@ echo "$as_me: error: conditional \"am__fastdepCXX\" was never defined. Usually this means the macro was only invoked conditionally." >&2;} { (exit 1); exit 1; }; } fi +if test -z "${IPV6_TRUE}" && test -z "${IPV6_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"IPV6\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"IPV6\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi if test -z "${GUI_TRUE}" && test -z "${GUI_FALSE}"; then { { echo "$as_me:$LINENO: error: conditional \"GUI\" was never defined. Usually this means the macro was only invoked conditionally." >&5 @@ -7215,6 +7786,90 @@ echo "$as_me: error: conditional \"GUI\" was never defined. Usually this means the macro was only invoked conditionally." >&2;} { (exit 1); exit 1; }; } fi +if test -z "${POP_TRUE}" && test -z "${POP_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"POP\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"POP\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${EXEC_TRUE}" && test -z "${EXEC_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"EXEC\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"EXEC\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${ADMIN_TRUE}" && test -z "${ADMIN_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"ADMIN\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"ADMIN\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${AUTH_TRUE}" && test -z "${AUTH_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"AUTH\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"AUTH\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${DNS_TRUE}" && test -z "${DNS_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"DNS\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"DNS\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${IDENTITY_TRUE}" && test -z "${IDENTITY_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"IDENTITY\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"IDENTITY\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${SMALL_CONFIG_TRUE}" && test -z "${SMALL_CONFIG_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"SMALL_CONFIG\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"SMALL_CONFIG\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${SMALL_FRAGMENTS_TRUE}" && test -z "${SMALL_FRAGMENTS_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"SMALL_FRAGMENTS\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"SMALL_FRAGMENTS\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${PROXY_TRUE}" && test -z "${PROXY_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"PROXY\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"PROXY\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${MAC_TRUE}" && test -z "${MAC_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"MAC\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"MAC\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${OPENSSL_TRUE}" && test -z "${OPENSSL_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"OPENSSL\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"OPENSSL\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi +if test -z "${GLOB_TRUE}" && test -z "${GLOB_FALSE}"; then + { { echo "$as_me:$LINENO: error: conditional \"GLOB\" was never defined. +Usually this means the macro was only invoked conditionally." >&5 +echo "$as_me: error: conditional \"GLOB\" was never defined. +Usually this means the macro was only invoked conditionally." >&2;} + { (exit 1); exit 1; }; } +fi : ${CONFIG_STATUS=./config.status} ac_clean_files_save=$ac_clean_files @@ -7515,7 +8170,7 @@ exec 6>&1 # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" -This file was extended by $as_me, which was +This file was extended by E-MailRelay $as_me 1.8, which was generated by GNU Autoconf 2.61. Invocation command line was CONFIG_FILES = $CONFIG_FILES @@ -7568,7 +8223,7 @@ Report bugs to ." _ACEOF cat >>$CONFIG_STATUS <<_ACEOF ac_cs_version="\\ -config.status +E-MailRelay config.status 1.8 configured by $0, generated by GNU Autoconf 2.61, with options \\"`echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`\\" @@ -7697,11 +8352,13 @@ do "lib/Makefile") CONFIG_FILES="$CONFIG_FILES lib/Makefile" ;; "lib/gcc2.95/Makefile") CONFIG_FILES="$CONFIG_FILES lib/gcc2.95/Makefile" ;; "lib/msvc6.0/Makefile") CONFIG_FILES="$CONFIG_FILES lib/msvc6.0/Makefile" ;; - "lib/sunpro5/Makefile") CONFIG_FILES="$CONFIG_FILES lib/sunpro5/Makefile" ;; "bin/Makefile") CONFIG_FILES="$CONFIG_FILES bin/Makefile" ;; "doc/Makefile") CONFIG_FILES="$CONFIG_FILES doc/Makefile" ;; "etc/Makefile") CONFIG_FILES="$CONFIG_FILES etc/Makefile" ;; "test/Makefile") CONFIG_FILES="$CONFIG_FILES test/Makefile" ;; + "extra/Makefile") CONFIG_FILES="$CONFIG_FILES extra/Makefile" ;; + "extra/mips/Makefile") CONFIG_FILES="$CONFIG_FILES extra/mips/Makefile" ;; + "src/fragments/Makefile") CONFIG_FILES="$CONFIG_FILES src/fragments/Makefile" ;; *) { { echo "$as_me:$LINENO: error: invalid argument: $ac_config_target" >&5 echo "$as_me: error: invalid argument: $ac_config_target" >&2;} @@ -7859,8 +8516,8 @@ COMPILER_VERSION!$COMPILER_VERSION$ac_delim CPP!$CPP$ac_delim EGREP!$EGREP$ac_delim PKG_CONFIG!$PKG_CONFIG$ac_delim -IP!$IP$ac_delim QT_CFLAGS!$QT_CFLAGS$ac_delim +QT_LIBS!$QT_LIBS$ac_delim _ACEOF if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 97; then @@ -7902,12 +8559,37 @@ _ACEOF ac_delim='%!_!# ' for ac_last_try in false false false false false :; do cat >conf$$subs.sed <<_ACEOF -QT_LIBS!$QT_LIBS$ac_delim MOC!$MOC$ac_delim +IPV6_TRUE!$IPV6_TRUE$ac_delim +IPV6_FALSE!$IPV6_FALSE$ac_delim GUI_TRUE!$GUI_TRUE$ac_delim GUI_FALSE!$GUI_FALSE$ac_delim +POP_TRUE!$POP_TRUE$ac_delim +POP_FALSE!$POP_FALSE$ac_delim +EXEC_TRUE!$EXEC_TRUE$ac_delim +EXEC_FALSE!$EXEC_FALSE$ac_delim +ADMIN_TRUE!$ADMIN_TRUE$ac_delim +ADMIN_FALSE!$ADMIN_FALSE$ac_delim +AUTH_TRUE!$AUTH_TRUE$ac_delim +AUTH_FALSE!$AUTH_FALSE$ac_delim +DNS_TRUE!$DNS_TRUE$ac_delim +DNS_FALSE!$DNS_FALSE$ac_delim +IDENTITY_TRUE!$IDENTITY_TRUE$ac_delim +IDENTITY_FALSE!$IDENTITY_FALSE$ac_delim +SMALL_CONFIG_TRUE!$SMALL_CONFIG_TRUE$ac_delim +SMALL_CONFIG_FALSE!$SMALL_CONFIG_FALSE$ac_delim +SMALL_FRAGMENTS_TRUE!$SMALL_FRAGMENTS_TRUE$ac_delim +SMALL_FRAGMENTS_FALSE!$SMALL_FRAGMENTS_FALSE$ac_delim +FRAGMENTS_LIST!$FRAGMENTS_LIST$ac_delim +PROXY_TRUE!$PROXY_TRUE$ac_delim +PROXY_FALSE!$PROXY_FALSE$ac_delim +MAC_TRUE!$MAC_TRUE$ac_delim +MAC_FALSE!$MAC_FALSE$ac_delim SSL_LIBS!$SSL_LIBS$ac_delim -SSL!$SSL$ac_delim +OPENSSL_TRUE!$OPENSSL_TRUE$ac_delim +OPENSSL_FALSE!$OPENSSL_FALSE$ac_delim +GLOB_TRUE!$GLOB_TRUE$ac_delim +GLOB_FALSE!$GLOB_FALSE$ac_delim STATIC_START!$STATIC_START$ac_delim STATIC_END!$STATIC_END$ac_delim e_docdir!$e_docdir$ac_delim @@ -7921,7 +8603,7 @@ LIBOBJS!$LIBOBJS$ac_delim LTLIBOBJS!$LTLIBOBJS$ac_delim _ACEOF - if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 17; then + if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 42; then break elif $ac_last_try; then { { echo "$as_me:$LINENO: error: could not make $CONFIG_STATUS" >&5 @@ -8322,21 +9004,22 @@ echo "$as_me: $ac_file is unchanged" >&6;} fi rm -f "$tmp/out12" # Compute $ac_file's index in $config_headers. +_am_arg=$ac_file _am_stamp_count=1 for _am_header in $config_headers :; do case $_am_header in - $ac_file | $ac_file:* ) + $_am_arg | $_am_arg:* ) break ;; * ) _am_stamp_count=`expr $_am_stamp_count + 1` ;; esac done -echo "timestamp for $ac_file" >`$as_dirname -- $ac_file || -$as_expr X$ac_file : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ - X$ac_file : 'X\(//\)[^/]' \| \ - X$ac_file : 'X\(//\)$' \| \ - X$ac_file : 'X\(/\)' \| . 2>/dev/null || -echo X$ac_file | +echo "timestamp for $_am_arg" >`$as_dirname -- "$_am_arg" || +$as_expr X"$_am_arg" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ + X"$_am_arg" : 'X\(//\)[^/]' \| \ + X"$_am_arg" : 'X\(//\)$' \| \ + X"$_am_arg" : 'X\(/\)' \| . 2>/dev/null || +echo X"$_am_arg" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q @@ -8373,7 +9056,7 @@ echo "$as_me: executing $ac_file commands" >&6;} # each Makefile.in and add a new line on top of each file to say so. # Grep'ing the whole file is not good either: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. - if sed 10q "$mf" | grep '^#.*generated by automake' > /dev/null 2>&1; then + if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then dirpart=`$as_dirname -- "$mf" || $as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$mf" : 'X\(//\)[^/]' \| \ diff --git a/configure.ac b/configure.ac index 4a0f626..5407a42 100644 --- a/configure.ac +++ b/configure.ac @@ -1,4 +1,4 @@ -dnl Copyright (C) 2001-2007 Graeme Walker +dnl Copyright (C) 2001-2008 Graeme Walker dnl dnl This program is free software: you can redistribute it and/or modify dnl it under the terms of the GNU General Public License as published by @@ -17,8 +17,9 @@ dnl dnl Process this file with autoconf to produce a configure script. dnl -AC_INIT(src/gsmtp/gsmtp.h) -AM_INIT_AUTOMAKE(emailrelay,1.7) +AC_INIT([E-MailRelay],[1.8],,[emailrelay]) +AC_CONFIG_SRCDIR(src/gsmtp/gsmtp.h) +AM_INIT_AUTOMAKE([no-define]) AM_CONFIG_HEADER(config.h) AM_MAINTAINER_MODE @@ -65,6 +66,7 @@ ACLOCAL_CHECK_BUGGY_CTIME ACLOCAL_CHECK_GMTIME_R ACLOCAL_CHECK_LOCALTIME_R ACLOCAL_CHECK_SETGROUPS +ACLOCAL_CHECK_QT4 dnl === dnl initialise aclocal/pkg.m4... @@ -74,13 +76,13 @@ PKG_PROG_PKG_CONFIG(0.9.0) dnl === dnl "--enable-debug" dnl -AC_ARG_ENABLE(debug,AC_HELP_STRING([--enable-debug],[enable extra debug messages at compile-time (default disabled)])) +AC_ARG_ENABLE(debug,AC_HELP_STRING([--enable-debug],[enable extra debug messages at compile-time (default no)])) ENABLE_DEBUG dnl === dnl "--enable-ipv6" dnl -AC_ARG_ENABLE(ipv6,AC_HELP_STRING([--enable-ipv6],[enable ipv6 (default disabled)])) +AC_ARG_ENABLE(ipv6,AC_HELP_STRING([--enable-ipv6],[enable ipv6 (default no)])) ENABLE_IPV6 dnl === @@ -90,10 +92,76 @@ AC_ARG_ENABLE(gui,AC_HELP_STRING([--enable-gui],[enable configuration gui (requi ENABLE_GUI dnl === -dnl "--with-workshop" +dnl "--enable-verbose" dnl -AC_ARG_WITH(workshop,AC_HELP_STRING([--with-workshop],[use Sun WorkShop 'CC -xar' as the 'ar' tool (default disabled)])) -WITH_WORKSHOP +AC_ARG_ENABLE(verbose,AC_HELP_STRING([--enable-verbose],[enable verbose logging (default yes)])) +ENABLE_VERBOSE + +dnl === +dnl "--enable-pop" +dnl +AC_ARG_ENABLE(pop,AC_HELP_STRING([--enable-pop],[enable pop3 protocol (default yes)])) +ENABLE_POP + +dnl === +dnl "--enable-exec" +dnl +AC_ARG_ENABLE(exec,AC_HELP_STRING([--enable-exec],[enable running of external programs (disable-exec requires disable-gui) (default yes)])) +ENABLE_EXEC + +dnl === +dnl "--enable-admin" +dnl +AC_ARG_ENABLE(exec,AC_HELP_STRING([--enable-admin],[enable admin interface (default yes)])) +ENABLE_ADMIN + +dnl === +dnl "--enable-auth" +dnl +AC_ARG_ENABLE(exec,AC_HELP_STRING([--enable-auth],[enable authentication (disable-auth requires disable-pop) (default yes)])) +ENABLE_AUTH + +dnl === +dnl "--enable-dns" +dnl +AC_ARG_ENABLE(exec,AC_HELP_STRING([--enable-dns],[enable dns lookup (default yes)])) +ENABLE_DNS + +dnl === +dnl "--enable-identity" +dnl +AC_ARG_ENABLE(exec,AC_HELP_STRING([--enable-identity],[enable process userid switching (default yes)])) +ENABLE_IDENTITY + +dnl === +dnl "--enable-small-config" +dnl +AC_ARG_ENABLE(exec,AC_HELP_STRING([--enable-small-config],[enable simplified confuration code for smaller binaries (rtfm) (default no)])) +ENABLE_SMALL_CONFIG + +dnl === +dnl "--enable-small-fragments" +dnl +AC_ARG_ENABLE(exec,AC_HELP_STRING([--enable-small-fragments],[enable fragmented object files for smaller binaries (default no)])) +ENABLE_SMALL_FRAGMENTS + +dnl === +dnl "--enable-small-exceptions" +dnl +AC_ARG_ENABLE(small_exceptions,AC_HELP_STRING([--enable-small-exceptions],[optimise exception classes for smaller binaries (default no)])) +ENABLE_SMALL_EXCEPTIONS + +dnl === +dnl "--enable-proxy" +dnl +AC_ARG_ENABLE(proxy,AC_HELP_STRING([--enable-proxy],[enable proxying (default yes)])) +ENABLE_PROXY + +dnl === +dnl "--enable-mac" +dnl +AC_ARG_ENABLE(mac,AC_HELP_STRING([--enable-mac],[enable building for a mac os x target (default auto)])) +ENABLE_MAC dnl === dnl "--with-doxygen" @@ -113,6 +181,12 @@ dnl AC_ARG_WITH(openssl,AC_HELP_STRING([--with-openssl],[use openssl for smtp client tls extension (default auto)])) WITH_OPENSSL +dnl === +dnl "--with-glob" +dnl +AC_ARG_WITH(glob,AC_HELP_STRING([--with-glob],[use glob() for reading directories (default auto)])) +WITH_GLOB + dnl === dnl "--enable-static-linking" dnl @@ -122,30 +196,22 @@ ENABLE_STATIC_LINKING dnl === dnl directory tweaking and "--enable-fhs" ... dnl -dnl define e_ prefixed variables with a gnu feel and then -dnl use the enable_fhs macro tweak them for fhs +dnl define e_ prefixed directory variables dnl dnl not AC_PREFIX_DEFAULT([/usr]) -AC_ARG_ENABLE(fhs,AC_HELP_STRING([--enable-fhs],[force FHS-compliant directories, ignoring --prefix etc (default disabled)])) +AC_ARG_ENABLE(fhs,AC_HELP_STRING([--enable-fhs],[force FHS-compliant directories, ignoring --prefix etc (default no)])) +SET_DIRECTORIES AC_SUBST(e_docdir) -if test "$e_docdir" = "" ; then e_docdir="$docdir" ; fi -if test "$e_docdir" = "" ; then e_docdir="$datadir/$PACKAGE/doc" ; fi AC_SUBST(e_initdir) -if test "$e_initdir" = "" ; then e_initdir="$libexecdir/$PACKAGE/init" ; fi AC_SUBST(e_spooldir) -if test "$e_spooldir" = "" ; then e_spooldir="$localstatedir/spool/$PACKAGE" ; fi AC_SUBST(e_examplesdir) -if test "$e_examplesdir" = "" ; then e_examplesdir="$libexecdir/$PACKAGE/examples" ; fi AC_SUBST(e_libexecdir) -if test "$e_libexecdir" = "" ; then e_libexecdir="$libexecdir/$PACKAGE" ; fi AC_SUBST(e_sysconfdir) -if test "$e_sysconfdir" = "" ; then e_sysconfdir="$sysconfdir" ; fi AC_SUBST(e_qtmoc) if test "$e_qtmoc" = "" ; then e_qtmoc="moc" ; fi -ENABLE_FHS dnl === dnl generate files... dnl -AC_OUTPUT(Makefile src/Makefile src/glib/Makefile src/gssl/Makefile src/gnet/Makefile src/gsmtp/Makefile src/gpop/Makefile src/main/Makefile src/win32/Makefile src/gui/Makefile lib/Makefile lib/gcc2.95/Makefile lib/msvc6.0/Makefile lib/sunpro5/Makefile bin/Makefile doc/Makefile etc/Makefile test/Makefile) +AC_OUTPUT(Makefile src/Makefile src/glib/Makefile src/gssl/Makefile src/gnet/Makefile src/gsmtp/Makefile src/gpop/Makefile src/main/Makefile src/win32/Makefile src/gui/Makefile lib/Makefile lib/gcc2.95/Makefile lib/msvc6.0/Makefile bin/Makefile doc/Makefile etc/Makefile test/Makefile extra/Makefile extra/mips/Makefile src/fragments/Makefile) diff --git a/depcomp b/depcomp index ca5ea4e..e5f9736 100755 --- a/depcomp +++ b/depcomp @@ -1,9 +1,9 @@ #! /bin/sh # depcomp - compile a program generating dependencies as side-effects -scriptversion=2006-10-15.18 +scriptversion=2007-03-29.01 -# Copyright (C) 1999, 2000, 2003, 2004, 2005, 2006 Free Software +# Copyright (C) 1999, 2000, 2003, 2004, 2005, 2006, 2007 Free Software # Foundation, Inc. # This program is free software; you can redistribute it and/or modify @@ -215,34 +215,39 @@ aix) # current directory. Also, the AIX compiler puts `$object:' at the # start of each line; $object doesn't have directory information. # Version 6 uses the directory in both cases. - stripped=`echo "$object" | sed 's/\(.*\)\..*$/\1/'` - tmpdepfile="$stripped.u" + dir=`echo "$object" | sed -e 's|/[^/]*$|/|'` + test "x$dir" = "x$object" && dir= + base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'` if test "$libtool" = yes; then + tmpdepfile1=$dir$base.u + tmpdepfile2=$base.u + tmpdepfile3=$dir.libs/$base.u "$@" -Wc,-M else + tmpdepfile1=$dir$base.u + tmpdepfile2=$dir$base.u + tmpdepfile3=$dir$base.u "$@" -M fi stat=$? - if test -f "$tmpdepfile"; then : - else - stripped=`echo "$stripped" | sed 's,^.*/,,'` - tmpdepfile="$stripped.u" - fi - if test $stat -eq 0; then : else - rm -f "$tmpdepfile" + rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" exit $stat fi + for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" + do + test -f "$tmpdepfile" && break + done if test -f "$tmpdepfile"; then - outname="$stripped.o" # Each line is of the form `foo.o: dependent.h'. # Do two passes, one to just change these to # `$object: dependent.h' and one to simply `dependent.h:'. - sed -e "s,^$outname:,$object :," < "$tmpdepfile" > "$depfile" - sed -e "s,^$outname: \(.*\)$,\1:," < "$tmpdepfile" >> "$depfile" + sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile" + # That's a tab and a space in the []. + sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile" else # The sourcefile does not contain any dependencies, so just # store a dummy comment line, to avoid errors with the Makefile diff --git a/doc/Makefile.am b/doc/Makefile.am index c129ea0..60617eb 100644 --- a/doc/Makefile.am +++ b/doc/Makefile.am @@ -1,5 +1,5 @@ # -## Copyright (C) 2001-2007 Graeme Walker +## Copyright (C) 2001-2008 Graeme Walker ## ## This program is free software: you can redistribute it and/or modify ## it under the terms of the GNU General Public License as published by @@ -41,13 +41,13 @@ converter_mu2docbook=$(top_builddir)/bin/mu2docbook.sh run_doxygen=$(top_builddir)/bin/doxygen.sh .txt.html: - $(converter_html) -a "$(AWK)" $(top_srcdir)/doc/$*.txt $(stylesheet) > $*.html + $(converter_html) -a "$(AWK)" "$(top_srcdir)/doc/$*.txt" "$(stylesheet)" > "$*.html" .txt.mu: - $(converter_txt2mu) -a "$(AWK)" $(top_srcdir)/doc/$*.txt > $*.mu + $(converter_txt2mu) -a "$(AWK)" "$(top_srcdir)/doc/$*.txt" > "$*.mu" .mu.db: - $(converter_mu2docbook) -a "$(AWK)" -x < $(top_builddir)/doc/$*.mu > $*.db + $(converter_mu2docbook) -a "$(AWK)" -x < "$(top_builddir)/doc/$*.mu" > "$*.db" head.db: $(converter_mu2docbook) $(converter_mu2docbook) -a "$(AWK)" --head "E-MailRelay" > head.db.tmp && mv -f head.db.tmp head.db @@ -65,39 +65,39 @@ emailrelay.docbook: head.db tail.db userguide.db reference.db developer.db $(run_doxygen) "$(HAVE_DOXYGEN)" "$(top_srcdir)" "$(top_builddir)" && touch .dox emailrelay-man.html: emailrelay.1 - if test "$(HAVE_MAN2HTML)" = "yes" ; then man2html -r -L. emailrelay.1 < /dev/null > emailrelay-man.html.tmp && mv emailrelay-man.html.tmp emailrelay-man.html ; grep -v '^Content-type:' < emailrelay-man.html > emailrelay-man.html.tmp && mv emailrelay-man.html.tmp emailrelay-man.html ; fi + if test "$(HAVE_MAN2HTML)" = "yes" ; then man2html -r -L. emailrelay.1 < /dev/null > emailrelay-man.html.tmp && mv emailrelay-man.html.tmp emailrelay-man.html ; grep -v '^Content-type:' < emailrelay-man.html | grep -v '^Time:' > emailrelay-man.html.tmp ; mv emailrelay-man.html.tmp emailrelay-man.html ; fi developer.html reference.html userguide.html: $(converter_html) developer.mu reference.mu userguide.mu: $(converter_txt2mu) readme.html: $(top_srcdir)/README $(converter_html) - $(converter_html) -a "$(AWK)" $(top_srcdir)/README $(stylesheet) > readme.html + $(converter_html) -a "$(AWK)" "$(top_srcdir)/README" "$(stylesheet)" > readme.html changelog.html: $(top_srcdir)/ChangeLog $(converter_html) - $(converter_html) -a "$(AWK)" $(top_srcdir)/ChangeLog $(stylesheet) > changelog.html + $(converter_html) -a "$(AWK)" "$(top_srcdir)/ChangeLog" "$(stylesheet)" > changelog.html emailrelay.1.gz : emailrelay.1 - if test -n "$(GZIP)" ; then $(GZIP) -c $(top_srcdir)/doc/emailrelay.1 > emailrelay.1.gz ; fi + if test -n "$(GZIP)" ; then $(GZIP) -c "$(top_srcdir)/doc/emailrelay.1" > emailrelay.1.gz ; fi emailrelay-passwd.1.gz : emailrelay-passwd.1 - if test -n "$(GZIP)" ; then $(GZIP) -c $(top_srcdir)/doc/emailrelay-passwd.1 > emailrelay-passwd.1.gz ; fi + if test -n "$(GZIP)" ; then $(GZIP) -c "$(top_srcdir)/doc/emailrelay-passwd.1" > emailrelay-passwd.1.gz ; fi emailrelay-submit.1.gz : emailrelay-submit.1 - if test -n "$(GZIP)" ; then $(GZIP) -c $(top_srcdir)/doc/emailrelay-submit.1 > emailrelay-submit.1.gz ; fi + if test -n "$(GZIP)" ; then $(GZIP) -c "$(top_srcdir)/doc/emailrelay-submit.1" > emailrelay-submit.1.gz ; fi emailrelay-filter-copy.1.gz : emailrelay-filter-copy.1 - if test -n "$(GZIP)" ; then $(GZIP) -c $(top_srcdir)/doc/emailrelay-filter-copy.1 > emailrelay-filter-copy.1.gz ; fi + if test -n "$(GZIP)" ; then $(GZIP) -c "$(top_srcdir)/doc/emailrelay-filter-copy.1" > emailrelay-filter-copy.1.gz ; fi emailrelay-poke.1.gz: emailrelay-poke.1 - if test -n "$(GZIP)" ; then $(GZIP) -c $(top_srcdir)/doc/emailrelay-poke.1 > emailrelay-poke.1.gz ; fi + if test -n "$(GZIP)" ; then $(GZIP) -c "$(top_srcdir)/doc/emailrelay-poke.1" > emailrelay-poke.1.gz ; fi install-data-local: install-e_docDATA - $(mkinstalldirs) $(DESTDIR)$(e_docdir)/doxygen - if test "$(HAVE_DOXYGEN)" = "yes" ; then for file in doxygen/* ; do $(INSTALL) $$file $(DESTDIR)$(e_docdir)/$$file ; done ; fi + $(mkinstalldirs) "$(DESTDIR)$(e_docdir)/doxygen" + if test "$(HAVE_DOXYGEN)" = "yes" ; then for file in doxygen/* ; do $(INSTALL) "$$file" "$(DESTDIR)$(e_docdir)/$$file" ; done ; fi uninstall-local: - -rm -f $(DESTDIR)$(e_docdir)/doxygen/* 2>/dev/null - -rmdir $(DESTDIR)$(e_docdir)/doxygen 2>/dev/null - -rmdir $(DESTDIR)$(e_docdir) 2>/dev/null + -find "$(DESTDIR)$(e_docdir)/doxygen" -type f | xargs rm -f + -rmdir "$(DESTDIR)$(e_docdir)/doxygen" 2>/dev/null + -rmdir "$(DESTDIR)$(e_docdir)" 2>/dev/null diff --git a/doc/Makefile.in b/doc/Makefile.in index b483c11..7c64cbd 100644 --- a/doc/Makefile.in +++ b/doc/Makefile.in @@ -1,8 +1,8 @@ -# Makefile.in generated by automake 1.10 from Makefile.am. +# Makefile.in generated by automake 1.10.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004, 2005, 2006 Free Software Foundation, Inc. +# 2003, 2004, 2005, 2006, 2007, 2008 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. @@ -84,6 +84,7 @@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ +FRAGMENTS_LIST = @FRAGMENTS_LIST@ GREP = @GREP@ GZIP = @GZIP@ HAVE_DOXYGEN = @HAVE_DOXYGEN@ @@ -93,7 +94,6 @@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -IP = @IP@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ @@ -117,7 +117,6 @@ QT_LIBS = @QT_LIBS@ RANLIB = @RANLIB@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ -SSL = @SSL@ SSL_LIBS = @SSL_LIBS@ STATIC_END = @STATIC_END@ STATIC_START = @STATIC_START@ @@ -426,13 +425,13 @@ uninstall-man: uninstall-man1 .txt.html: - $(converter_html) -a "$(AWK)" $(top_srcdir)/doc/$*.txt $(stylesheet) > $*.html + $(converter_html) -a "$(AWK)" "$(top_srcdir)/doc/$*.txt" "$(stylesheet)" > "$*.html" .txt.mu: - $(converter_txt2mu) -a "$(AWK)" $(top_srcdir)/doc/$*.txt > $*.mu + $(converter_txt2mu) -a "$(AWK)" "$(top_srcdir)/doc/$*.txt" > "$*.mu" .mu.db: - $(converter_mu2docbook) -a "$(AWK)" -x < $(top_builddir)/doc/$*.mu > $*.db + $(converter_mu2docbook) -a "$(AWK)" -x < "$(top_builddir)/doc/$*.mu" > "$*.db" head.db: $(converter_mu2docbook) $(converter_mu2docbook) -a "$(AWK)" --head "E-MailRelay" > head.db.tmp && mv -f head.db.tmp head.db @@ -450,41 +449,41 @@ emailrelay.docbook: head.db tail.db userguide.db reference.db developer.db $(run_doxygen) "$(HAVE_DOXYGEN)" "$(top_srcdir)" "$(top_builddir)" && touch .dox emailrelay-man.html: emailrelay.1 - if test "$(HAVE_MAN2HTML)" = "yes" ; then man2html -r -L. emailrelay.1 < /dev/null > emailrelay-man.html.tmp && mv emailrelay-man.html.tmp emailrelay-man.html ; grep -v '^Content-type:' < emailrelay-man.html > emailrelay-man.html.tmp && mv emailrelay-man.html.tmp emailrelay-man.html ; fi + if test "$(HAVE_MAN2HTML)" = "yes" ; then man2html -r -L. emailrelay.1 < /dev/null > emailrelay-man.html.tmp && mv emailrelay-man.html.tmp emailrelay-man.html ; grep -v '^Content-type:' < emailrelay-man.html | grep -v '^Time:' > emailrelay-man.html.tmp ; mv emailrelay-man.html.tmp emailrelay-man.html ; fi developer.html reference.html userguide.html: $(converter_html) developer.mu reference.mu userguide.mu: $(converter_txt2mu) readme.html: $(top_srcdir)/README $(converter_html) - $(converter_html) -a "$(AWK)" $(top_srcdir)/README $(stylesheet) > readme.html + $(converter_html) -a "$(AWK)" "$(top_srcdir)/README" "$(stylesheet)" > readme.html changelog.html: $(top_srcdir)/ChangeLog $(converter_html) - $(converter_html) -a "$(AWK)" $(top_srcdir)/ChangeLog $(stylesheet) > changelog.html + $(converter_html) -a "$(AWK)" "$(top_srcdir)/ChangeLog" "$(stylesheet)" > changelog.html emailrelay.1.gz : emailrelay.1 - if test -n "$(GZIP)" ; then $(GZIP) -c $(top_srcdir)/doc/emailrelay.1 > emailrelay.1.gz ; fi + if test -n "$(GZIP)" ; then $(GZIP) -c "$(top_srcdir)/doc/emailrelay.1" > emailrelay.1.gz ; fi emailrelay-passwd.1.gz : emailrelay-passwd.1 - if test -n "$(GZIP)" ; then $(GZIP) -c $(top_srcdir)/doc/emailrelay-passwd.1 > emailrelay-passwd.1.gz ; fi + if test -n "$(GZIP)" ; then $(GZIP) -c "$(top_srcdir)/doc/emailrelay-passwd.1" > emailrelay-passwd.1.gz ; fi emailrelay-submit.1.gz : emailrelay-submit.1 - if test -n "$(GZIP)" ; then $(GZIP) -c $(top_srcdir)/doc/emailrelay-submit.1 > emailrelay-submit.1.gz ; fi + if test -n "$(GZIP)" ; then $(GZIP) -c "$(top_srcdir)/doc/emailrelay-submit.1" > emailrelay-submit.1.gz ; fi emailrelay-filter-copy.1.gz : emailrelay-filter-copy.1 - if test -n "$(GZIP)" ; then $(GZIP) -c $(top_srcdir)/doc/emailrelay-filter-copy.1 > emailrelay-filter-copy.1.gz ; fi + if test -n "$(GZIP)" ; then $(GZIP) -c "$(top_srcdir)/doc/emailrelay-filter-copy.1" > emailrelay-filter-copy.1.gz ; fi emailrelay-poke.1.gz: emailrelay-poke.1 - if test -n "$(GZIP)" ; then $(GZIP) -c $(top_srcdir)/doc/emailrelay-poke.1 > emailrelay-poke.1.gz ; fi + if test -n "$(GZIP)" ; then $(GZIP) -c "$(top_srcdir)/doc/emailrelay-poke.1" > emailrelay-poke.1.gz ; fi install-data-local: install-e_docDATA - $(mkinstalldirs) $(DESTDIR)$(e_docdir)/doxygen - if test "$(HAVE_DOXYGEN)" = "yes" ; then for file in doxygen/* ; do $(INSTALL) $$file $(DESTDIR)$(e_docdir)/$$file ; done ; fi + $(mkinstalldirs) "$(DESTDIR)$(e_docdir)/doxygen" + if test "$(HAVE_DOXYGEN)" = "yes" ; then for file in doxygen/* ; do $(INSTALL) "$$file" "$(DESTDIR)$(e_docdir)/$$file" ; done ; fi uninstall-local: - -rm -f $(DESTDIR)$(e_docdir)/doxygen/* 2>/dev/null - -rmdir $(DESTDIR)$(e_docdir)/doxygen 2>/dev/null - -rmdir $(DESTDIR)$(e_docdir) 2>/dev/null + -find "$(DESTDIR)$(e_docdir)/doxygen" -type f | xargs rm -f + -rmdir "$(DESTDIR)$(e_docdir)/doxygen" 2>/dev/null + -rmdir "$(DESTDIR)$(e_docdir)" 2>/dev/null # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: diff --git a/doc/developer.txt b/doc/developer.txt index 58f84ba..18b5e61 100644 --- a/doc/developer.txt +++ b/doc/developer.txt @@ -16,6 +16,9 @@ means that the "gnet" library has to be able to create GUI windows in order to process network events. The extra GUI and event classes are put into a separate library in the "src/win32" directory, using the namespace "GGui". +There is also a separate configuration GUI program which uses the "glib" library +together with TrollTech's Qt. + Event model ----------- The E-MailRelay server uses non-blocking socket i/o, with a select() event loop. @@ -105,9 +108,12 @@ runs the wrapper starts the actual E-MailRelay server by looking for a batch file called "emailrelay-start.bat" in the same directory as service wrapper executable. It reads the contents of this batch file in order to construct the E-MailRelay command-line, adding "--no-daemon" and "--hidden" switches if they -are not there already. The service name and display name can be put onto the -wrapper's "--install" command-line, and it is the service name that is used to -derive the name of the "start" batch file. +are not there already. + +The service name and display name can be added to the wrapper's "--install" +command-line, and it is the service name that is used to derive the name of the +"start" batch file. This allows more than one server to be run as services, +using different server command-line switches on each one. Diagrams -------- @@ -122,6 +128,63 @@ State transition diagrams: Sequence diagrams: * *Proxy mode forwarding* [sequence-3.png] +Configuration GUI +----------------- +The optional configuration GUI program "emailrelay-gui" uses TrollTech Qt v4 +for its user interface components. The GUI can run as a stand-alone +configuration helper or as part of a self-extracting installation program called +"emailrelay-setup". + +The packing scheme used to assemble a self-extracting archive is a simple +concatenation of the "stub" executable followed by a table of contents for the +payload files, followed by the payload files themselves (possibly compressed by +"zlib"), and ending with an twelve-byte ascii representation of the offset of +the table of contents. + +On Windows there are two levels of packing: the "setup" program has a stub +executable written in "C" that prints an "extracting..." message to the standard +output, with a payload comprising another packed executable and a small number of +"C++" runtime library files. The inner packed executable has the emailrelay GUI +program as its stub and all the other installable files, including the main +emailrelay executable, as its payload. + +When the GUI runs it checks whether it has a payload of packed files. If it +has then it runs as an installer; if it does not then it runs as a configuration +helper. Refer to the comments in "src/gui/guimain.cpp" for more details. + +The code works exactly the same on Windows, Mac OS X and unix-like operating +systems. However, on unix-like operating systems "make install", possibly run +via some package manager, is the preferred way to install files so the "setup" +program is never normally built or distributed. On Mac OS X the default packing +scheme works well enough, but there is also provision for having a separate +payload file within the Mac bundle rather than appending the payload to the stub +executable. + +The user interface is structured as a "wizard" having a dialog box with the +forward and back buttons at the bottom and a single Qt layout object for the +main area. A stack of Qt widgets representing the various pages of the wizard +are installed into the main layout object in turn as the user navigates from +one page to the next. + +Once the wizard is completed it asks each page to dump its state as a set of +key-value pairs into a stringstream (see "src/gui/pages.cpp"). These key-value +pairs are processed by an installer class into a list of action objects (in the +"Command" design pattern) and then the action objects are run in turn. In order +to display the progress of the installation each action object is run within a +timer callback so that the Qt framework get a chance to update the GUI between +each one. + +During development the user interface pages and the installer can be tested +separately since the interface between them is a simple text stream containing +key-value pairs. + +Source control +-------------- +The source code is stored in the SourceForge "svn" repository. A working +copy can be checked out as follows: + + $ svn co https://emailrelay.svn.sourceforge.net/svnroot/emailrelay + Directory structure ------------------- @@ -156,7 +219,7 @@ Directory structure # src/gui - Installation and configuration GUI program using Qt 4. + Installation and configuration GUI program using Qt v4. # lib @@ -166,15 +229,24 @@ Directory structure Test scripts and utilities. +Source file names +----------------- +Generally the source file names are follow the name of the principal class, +(often including the namespace) but all in lowercase. Any underscores in the +name indicate a choice of implementation, so class "G::Foo" might have two +implementations in the files "gfoo_main.cpp" and "gfoo_alternate.cpp". +The choice is normally made by the makefile. + Portability ----------- The E-MailRelay code is written in ISO C++, although avoiding less-widely -supported language features like "mutable", templated methods and "export". +supported language features such as "mutable", templated methods and "export". The header files "gdef.h" in "src/glib", and "gnet.h" in "src/gnet" are intended to be used to fix up compiler portability issues such as missing standard types, non-standard system headers etc. Conditional compilation directives ("#if" -etc.) are largely confined to these headers in order to improve readability. +etc.) are confined to these headers as far as possible in order to improve +readability. Deficiencies in the standard headers files provided by older compilers are fixed up by files in the "lib" directory tree. For example, the msvc6.0 compiler @@ -184,8 +256,8 @@ declarations in the "lib/msvc6.0" headers. These work-rounds are kept out of the "src" tree because they are not necessary for more modern compilers. Windows/unix portability is generally addressed by providing a common class -declaration with two implementations. Where necessary a "pimple" pattern is used -to hide the system-specific parts of the declaration. +declaration with two implementations. Where necessary a "pimple" (or "Bridge") +pattern is used to hide the system-specific parts of the declaration. A good example is the "G::Directory" class used for iterating through files in a directory. The header file "src/glib/gdirectory.h" is common to both systems, @@ -199,14 +271,34 @@ these cases there are three source files per header. For example, "gsocket.cpp", Compile-time features --------------------- -Compile-time features can normally be selected with switches passed to the -"configure" script. These include the following: +Compile-time features can be selected with switches passed to the "configure" +script. These include the following: * Debug-level logging ("--enable-debug") * IPv6 (Linux only) ("--enable-ipv6") * Configuration GUI ("--enable-gui") -Use "./configure --help" to see a complete list. +The "--enable-fhs" switch alters the compiled-in default directories to conform +to the Linux File Hierarchy Standard (FHS). This is recommended for most modern +Linux distributions. + +Some functionality can be disabled at compile-time in order to reduce the size +of the executable, typically when building for embedded systems: + +* Disable POP3 protocol, "--disable-pop" +* Disable authentication, "--disable-auth" (requires "--disable-pop") +* Disable administration interface, "--disable-admin" +* Disable execution of external programs, "--disable-exec" + +The "--enable-small-config" switch can be used to change the command-line +parsing code to use a configuration file instead, resulting in a smaller +executable. This also removes a lot of the configuration checking code, so it is +not recommended unless size is critical. (The format of the configuration file +is similar to the command-line using the long-form switches without the +double-dash and using '=' to separate the switch from the switch value.) + +Use "./configure --help" to see a complete list of options and refer to +"acinclude.m4" for more detailed comments. Patterns -------- @@ -240,6 +332,10 @@ Gang-of-four Design Patterns (ISBN 0-201-63361-2): - GSmtp::ProtocolMessage ++ Command + + - Installer + Lakos' Large Scale C++ Software Design patterns (ISBN 0-201-63362-0): + Insulation; fully insulating concrete class (Meyer's Effective C++ Item 34, pimple pattern) @@ -285,6 +381,10 @@ Other patterns: - G::Slot0 ++ Dependency injection + + - GSmtp::Server::newProtocolMessage() + Idioms ------ The "<<=" operator defined in "src/glib/gmemory.h" is used idiomatically @@ -292,4 +392,4 @@ to reassign a std::auto_ptr<> since reset() is not always available. -Copyright (C) 2001-2007 Graeme Walker . All rights reserved. +Copyright (C) 2001-2008 Graeme Walker . All rights reserved. diff --git a/doc/doxygen_missing.html b/doc/doxygen_missing.html index 7a40b5c..e6280d6 100644 --- a/doc/doxygen_missing.html +++ b/doc/doxygen_missing.html @@ -11,4 +11,4 @@ - + diff --git a/doc/emailrelay-filter-copy.1 b/doc/emailrelay-filter-copy.1 index ee28814..20106d9 100644 --- a/doc/emailrelay-filter-copy.1 +++ b/doc/emailrelay-filter-copy.1 @@ -1,4 +1,4 @@ -.\" Copyright (C) 2001-2007 Graeme Walker +.\" Copyright (C) 2001-2008 Graeme Walker .\" .\" This program is free software: you can redistribute it and/or modify .\" it under the terms of the GNU General Public License as published by diff --git a/doc/emailrelay-man.html b/doc/emailrelay-man.html index 10b7350..a30109a 100644 --- a/doc/emailrelay-man.html +++ b/doc/emailrelay-man.html @@ -224,6 +224,10 @@ Enables authentication of remote clients, using the given secrets file.
Enables tls/ssl layer for smtp server using the given openssl certificate file (if openssl built in). +
-M, --size <bytes> + +
+Limits the size of submitted messages.
-s, --spool-dir <dir>
@@ -380,7 +384,6 @@ Graeme Walker, mailto:graem This document was created by man2html, using the manual pages.
-Time: 00:56:15 GMT, September 19, 2007 - + diff --git a/doc/emailrelay-passwd.1 b/doc/emailrelay-passwd.1 index 501ff62..2917d33 100644 --- a/doc/emailrelay-passwd.1 +++ b/doc/emailrelay-passwd.1 @@ -1,4 +1,4 @@ -.\" Copyright (C) 2001-2007 Graeme Walker +.\" Copyright (C) 2001-2008 Graeme Walker .\" .\" This program is free software: you can redistribute it and/or modify .\" it under the terms of the GNU General Public License as published by diff --git a/doc/emailrelay-poke.1 b/doc/emailrelay-poke.1 index 584a31c..d1d5928 100644 --- a/doc/emailrelay-poke.1 +++ b/doc/emailrelay-poke.1 @@ -1,4 +1,4 @@ -.\" Copyright (C) 2001-2007 Graeme Walker +.\" Copyright (C) 2001-2008 Graeme Walker .\" .\" This program is free software: you can redistribute it and/or modify .\" it under the terms of the GNU General Public License as published by diff --git a/doc/emailrelay-submit.1 b/doc/emailrelay-submit.1 index 96c2974..c3af1c2 100644 --- a/doc/emailrelay-submit.1 +++ b/doc/emailrelay-submit.1 @@ -1,4 +1,4 @@ -.\" Copyright (C) 2001-2007 Graeme Walker +.\" Copyright (C) 2001-2008 Graeme Walker .\" .\" This program is free software: you can redistribute it and/or modify .\" it under the terms of the GNU General Public License as published by diff --git a/doc/emailrelay.1 b/doc/emailrelay.1 index baad3c6..47b872d 100644 --- a/doc/emailrelay.1 +++ b/doc/emailrelay.1 @@ -1,4 +1,4 @@ -.\" Copyright (C) 2001-2007 Graeme Walker +.\" Copyright (C) 2001-2008 Graeme Walker .\" .\" This program is free software: you can redistribute it and/or modify .\" it under the terms of the GNU General Public License as published by @@ -169,6 +169,9 @@ Enables authentication of remote clients, using the given secrets file. .B \-K, --server-tls \fI\fR Enables tls/ssl layer for smtp server using the given openssl certificate file (if openssl built in). .TP +.B \-M, --size \fI\fR +Limits the size of submitted messages. +.TP .B \-s, --spool-dir \fI\fR Specifies the spool directory (default is \fI/var/spool/emailrelay\fR). .TP diff --git a/doc/index.html b/doc/index.html index 5586a60..9fa3f7e 100644 --- a/doc/index.html +++ b/doc/index.html @@ -21,4 +21,4 @@ - + diff --git a/doc/reference.txt b/doc/reference.txt index e2f5fbb..8602dcb 100644 --- a/doc/reference.txt +++ b/doc/reference.txt @@ -125,6 +125,9 @@ where is: # --server-tls (-K) Enables tls/ssl layer for smtp server using the given openssl certificate file (if openssl built in). +# --size (-M) + Limits the size of submitted messages. + # --spool-dir (-s) Specifies the spool directory (default is "/var/spool/emailrelay"). @@ -535,6 +538,15 @@ switch) but the remote server does not support the AUTH extension, or does not support the LOGIN or CRAM-MD5 mechanism, then E-MailRelay will log an error and not forward any messages. +If E-MailRelay successfully authenticates with the remote server then the +client's authentication name (if any) is passed as a parameter to the MAIL +command when the message is forwarded. Some SMTP servers are reported to reject +the message if the name on the MAIL command does not match the name used to +authenticate with them. However, the name passed as a parameter to the MAIL +command is stored in the message's envelope file, so a "--filter" script can be +used to change this to match whatever the remote server expects. An example +script is provided in the distribution. + Note that some ISPs require separate POP/IMAP authentication before SMTP access from a particular IP address is allowed. This type of POP-before-SMTP authentication can be done outside the E-MailRelay system by POP/IMAP utilities @@ -742,8 +754,7 @@ To force FHS compliance you can use the "--enable-fhs" switch when running * /var/spool/emailrelay/emailrelay.*.envelope For finer control of the directory structure the following can be specified on -the "configure" command-line (but note that the "--enable-fhs" will override -them): +the "configure" command-line: * --mandir= * --sbindir= * e_libexecdir= @@ -780,4 +791,4 @@ the ".pc" file by setting "LDFLAGS": -Copyright (C) 2001-2007 Graeme Walker . All rights reserved. +Copyright (C) 2001-2008 Graeme Walker . All rights reserved. diff --git a/doc/userguide.txt b/doc/userguide.txt index bb1a6f1..e7f40bc 100644 --- a/doc/userguide.txt +++ b/doc/userguide.txt @@ -21,8 +21,8 @@ waits for incoming mail and stores anything it receives in a spool directory. As a forwarding agent E-MailRelay pulls messages out of the spool directory and passes them on to a remote server -- perhaps your ISP mail server. -E-MailRelay can also run as a POP3 server so that e-mail front-end programs -can read the spooled messages. +E-MailRelay can also run as a POP3 server so that e-mail client programs can +read the spooled messages. What it's not ------------- @@ -219,8 +219,8 @@ authentication. In this scheme you are required to conduct an authenticated POP or IMAP dialogue before you try to use SMTP. The POP/IMAP dialogue is done separately from the SMTP connection, but bear in mind that there might be a time limit so that your SMTP connection has to be made soon after the POP/IMAP -authentication. You should be able to use an e-mail front-end program, or -something like "fetchmail" to do the POP/IMAP authentication. +authentication. You should be able to use an e-mail client program, or something +like "fetchmail" to do the POP/IMAP authentication. If you can send mail messages sucessfully using telnet, then you should look at the E-MailRelay "--verbose" log output and compare what you do interactively @@ -241,9 +241,9 @@ use a firewall in this scenario. Another option is to require all clients to authenticate by using the "--server-auth" switch. If you then need local clients, such as your own e-mail -front-end, to connect without authentication then you must put those trusted IP -addresses in the secrets file with an authentication mechanism of "NONE". Refer -to the reference guide for more information. +client program, to connect without authentication then you must put those +trusted IP addresses in the secrets file with an authentication mechanism of +"NONE". Refer to the reference guide for more information. Taking it one stage further, you may want to allow connections from the Internet without authentication but only allow them to send mail to local users. In other @@ -257,9 +257,9 @@ details. Running as a POP server ----------------------- -E-MailRelay can run as a POP server so that e-mail front-end programs can -retrieve messages from the spool directory directly (although it is not a good -idea to run E-MailRelay as a POP server if also forwarding messages by SMTP). +E-MailRelay can run as a POP server so that e-mail client programs can retrieve +messages from the spool directory directly (although it is not a good idea to +run E-MailRelay as a POP server if also forwarding messages by SMTP). To allow POP access to spooled messages use a command-line something like this: @@ -274,7 +274,7 @@ like this: If you need to serve up messages to more than one POP client consider using the "--pop-by-name" option with a "--filter" script that moves messages into the -appropriate subdirectory. The "emailrelay-filter-copy" program is designed +appropriate sub-directory. The "emailrelay-filter-copy" program is designed to be used in this way: when a message is received over SMTP it copies it into all available sub-directories for collection by multiple POP clients. @@ -325,7 +325,25 @@ they have not been retried too many times already. If you are using E-MailRelay to forward outgoing e-mails then you can also get failed e-mails to bounce back to your in-tray by running the "emailrelay-notify.sh" script periodically as "root", although this does require -"procmail" to be available to act as a delivery agent. +"procmail" to act as a delivery agent. + +Polling and timeouts +-------------------- +In normal proxy mode, using "--immediate" or "--as-proxy", the E-MailRelay +server will try forward each message as soon as it is received and only then +will it acknowledge receipt of the message back to the submitting client. This +has the advantage that any problems with the forwarding process can be reported +back to the submitting client; any failures should be reported your e-mail +client program and the failed messages should stay in its "outbox". + +However, some e-mail client programs are not always prepared to wait long enough +for the message to be forwarded and this can result in problems with timeouts. A +good fix for this is to use the "--poll" mechanism as a replacement for +"--immediate"/"--as-proxy". In this way the submitting e-mail client program +does not have to wait for the E-MailRelay server to forward each message and so +it should not time out. If you have timeout problems try replacing "--immediate" +with "--poll 0" so that forwarding is done as soon as the client has finished +submitting messages. Usage patterns -------------- @@ -341,21 +359,12 @@ at any time, as long as the envelope file is not locked (ie. with a special filename extension). Your "--filter" program can edit messages in any way you want, and it can even remove the current message from the spool directory. -Another useful technique is to run E-MailRelay as an SMTP server but use the -"--poll" switch so that the server process will also do periodic forwarding. -With a short "--poll" period this behaves rather like a proxy, but the -submitting client program does not have to wait for the message to be delivered -to the remote server. To avoid the overhead of polling the spool directory -continuously you can use get the "--filter" program to force the "--poll" timer -to expire as each new message is received by using a special exit value of 103. - When using E-MailRelay as a POP server the "--pop-by-name" feature can be used to serve up different spooled messages according to the username that the client authenticated with: each user's messages are taken from their own sub-directory -of the main spool directory. This means that you can decide how to move or copy -the messages into those sub-directories. If messages are coming in over SMTP -then you could install an SMTP "--filter" script to move each new message into -the relevant sub-directory based on the message addressing. +of the main spool directory. If messages are coming in over SMTP then you could +install an SMTP "--filter" script to move each new message into the relevant +sub-directory based on the message addressing. For more ideas check out the "--client-filter" and "--poll" switches, and don't overlook the administration and control interface ("--admin") which you can use @@ -428,7 +437,7 @@ The secrets file should contain one line of text something like this: login client myname@gmail.com mypassword -Refer to this file using "--client-auth" on the E-MailRelay command-line and +Reference this file using "--client-auth" on the E-MailRelay command-line and also add in the "--client-tls" switch: emailrelay --as-proxy smtp.gmail.com:587 --client-tls --client-auth /etc/emailrelay.auth ... @@ -436,4 +445,4 @@ also add in the "--client-tls" switch: -Copyright (C) 2001-2007 Graeme Walker . All rights reserved. +Copyright (C) 2001-2008 Graeme Walker . All rights reserved. diff --git a/doc/windows.txt b/doc/windows.txt index 30f2f66..51ea90e 100644 --- a/doc/windows.txt +++ b/doc/windows.txt @@ -9,8 +9,8 @@ setup program is in a writeable directory with plenty of space on the disk because when you run it it will extract an installation GUI program plus dependent DLLs in into the same directory. -The installation GUI program will take you through the installation options and -then install the run-time files into your chosen directory. +The installation GUI will take you through the installation options and then +install the run-time files into your chosen directory. Manual installation ------------------- @@ -36,29 +36,36 @@ at boot-time you must first create a one-line batch file called the full E-MailRelay server command-line. Then run "emailrelay-service --install" to install the service. -When the E-MailRelay server is run in this way it has the "--no-daemon" and -"--hidden" switches added so that there is no user interface. (The "--no-daemon" -switch on Windows changes the interface from using the system-tray to using a -normal window, and the "--hidden" switch suppresses the window and any message -boxes.) +When the E-MailRelay server is run in this way the "--no-daemon" and "--hidden" +switches are added automatically to whatever is in the "emailrelay-start" batch +file, so that there is no user interface. (The "--no-daemon" switch on Windows +changes the interface from using the system-tray to using a normal window, and +the "--hidden" switch suppresses the window and any message boxes.) Note that the batch file and the main E-MailRelay executable must be in the same -directory and that the batch file is only read at install time; if you need to -change the command-line switches for the service you must edit the service -properties. +directory. + +If you need to run multiple E-MailRelay services then pass a unique service name +on the "emailrelay-server --install " command-line. This name is used to +derive the name of the "-start.bat" batch file that contains the +E-MailRelay server's command-line switches so you will need to create this too. Diagnostics ----------- E-MailRelay normally writes errors and warnings into the system event log, which you can view by running "eventvwr.exe". You can increase the verbosity by adding -the "--verbose" switch to the E-MailRelay command-line. +the "--verbose" switch to the E-MailRelay command-line, typically by editing the +"emailrelay-start.bat" batch script. -The E-MailRelay server also logs to the standard error stream but the +The E-MailRelay server also logs to the standard error stream, however the "--as-server" and "--as-proxy" switches implicitly incorporate "--close-stderr" so with these switches the standard error logging will stop soon after startup. -To get continuous logging you should replace "--as-server" with "--log" and -"--as-proxy" with "--immediate --forward-to". Then you will be able to redirect -the standard error stream to a log file. + +To get continuous logging to a log file you should replace "--as-server" with +"--log" and "--as-proxy" with "--immediate --forward-to" and then use "2>" to +redirect the standard error stream, eg: + + "c:\program files\emailrelay\emailrelay.exe" --log -v -L ... > c:\temp.out 2>&1 Building from source -------------------- @@ -72,4 +79,4 @@ MinGW please follow the guidelines in "mingw-common.mak" which is also in the -Copyright (C) 2001-2007 Graeme Walker . All rights reserved. +Copyright (C) 2001-2008 Graeme Walker . All rights reserved. diff --git a/emailrelay-gui.xcodeproj/project.pbxproj b/emailrelay-gui.xcodeproj/project.pbxproj new file mode 100644 index 0000000..f3a365f --- /dev/null +++ b/emailrelay-gui.xcodeproj/project.pbxproj @@ -0,0 +1,613 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 44; + objects = { + +/* Begin PBXAggregateTarget section */ + EE99190B0D9193D100FB06D5 /* all-targets */ = { + isa = PBXAggregateTarget; + buildConfigurationList = EE9919150D91940100FB06D5 /* Build configuration list for PBXAggregateTarget "all-targets" */; + buildPhases = ( + ); + dependencies = ( + EE99190F0D9193DC00FB06D5 /* PBXTargetDependency */, + EE9919110D9193DC00FB06D5 /* PBXTargetDependency */, + EE9919130D9193DC00FB06D5 /* PBXTargetDependency */, + ); + name = "all-targets"; + productName = "all-targets"; + }; +/* End PBXAggregateTarget section */ + +/* Begin PBXBuildFile section */ + EE486FEF0D3E3EA900AB4CC6 /* dir.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE486FCA0D3E3EA900AB4CC6 /* dir.cpp */; }; + EE486FF20D3E3EA900AB4CC6 /* gdialog.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE486FD00D3E3EA900AB4CC6 /* gdialog.cpp */; }; + EE486FF40D3E3EA900AB4CC6 /* gpage.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE486FD40D3E3EA900AB4CC6 /* gpage.cpp */; }; + EE486FF50D3E3EA900AB4CC6 /* guimain.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE486FD60D3E3EA900AB4CC6 /* guimain.cpp */; }; + EE486FF60D3E3EA900AB4CC6 /* gunpack.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE486FD70D3E3EA900AB4CC6 /* gunpack.cpp */; }; + EE486FF70D3E3EA900AB4CC6 /* installer.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE486FDA0D3E3EA900AB4CC6 /* installer.cpp */; }; + EE486FF80D3E3EA900AB4CC6 /* legal.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE486FDC0D3E3EA900AB4CC6 /* legal.cpp */; }; + EE486FFC0D3E3EA900AB4CC6 /* pages.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE486FE50D3E3EA900AB4CC6 /* pages.cpp */; }; + EE4870560D3E529100AB4CC6 /* moc_gdialog.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE4870530D3E529100AB4CC6 /* moc_gdialog.cpp */; }; + EE4870570D3E529100AB4CC6 /* moc_gpage.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE4870540D3E529100AB4CC6 /* moc_gpage.cpp */; }; + EE4870580D3E529100AB4CC6 /* moc_pages.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE4870550D3E529100AB4CC6 /* moc_pages.cpp */; }; + EEC342C10D50E0BD00DD9918 /* boot_mac.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EEC342BF0D50E0BD00DD9918 /* boot_mac.cpp */; }; + EEC342C20D50E0BD00DD9918 /* dir_mac.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EEC342C00D50E0BD00DD9918 /* dir_mac.cpp */; }; + EEC342C60D50E0D800DD9918 /* glink_mac.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EEC342C30D50E0D800DD9918 /* glink_mac.cpp */; }; + EEC342C80D50E0D800DD9918 /* state.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EEC342C50D50E0D800DD9918 /* state.cpp */; }; + EEC342E80D50F68600DD9918 /* guistart.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EEC342C40D50E0D800DD9918 /* guistart.cpp */; }; + EEC342FA0D50F72800DD9918 /* unpackmain.c in Sources */ = {isa = PBXBuildFile; fileRef = EEC342F90D50F72800DD9918 /* unpackmain.c */; }; + EEC342FC0D50F73900DD9918 /* unpack.c in Sources */ = {isa = PBXBuildFile; fileRef = EE486FEC0D3E3EA900AB4CC6 /* unpack.c */; }; +/* End PBXBuildFile section */ + +/* Begin PBXContainerItemProxy section */ + EE99190E0D9193DC00FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = 8DD76F620486A84900D96B5E; + remoteInfo = "emailrelay-gui"; + }; + EE9919100D9193DC00FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EEC342DE0D50F62E00DD9918; + remoteInfo = "emailrelay-start"; + }; + EE9919120D9193DC00FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EEC342EC0D50F6B600DD9918; + remoteInfo = "emailrelay-unpack"; + }; +/* End PBXContainerItemProxy section */ + +/* Begin PBXCopyFilesBuildPhase section */ + 8DD76F690486A84900D96B5E /* CopyFiles */ = { + isa = PBXCopyFilesBuildPhase; + buildActionMask = 8; + dstPath = /usr/share/man/man1/; + dstSubfolderSpec = 0; + files = ( + ); + runOnlyForDeploymentPostprocessing = 1; + }; +/* End PBXCopyFilesBuildPhase section */ + +/* Begin PBXFileReference section */ + 8DD76F6C0486A84900D96B5E /* emailrelay-gui */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = "emailrelay-gui"; sourceTree = BUILT_PRODUCTS_DIR; }; + EE486FC90D3E3EA900AB4CC6 /* boot.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = boot.h; sourceTree = ""; }; + EE486FCA0D3E3EA900AB4CC6 /* dir.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = dir.cpp; sourceTree = ""; }; + EE486FCB0D3E3EA900AB4CC6 /* dir.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = dir.h; sourceTree = ""; }; + EE486FCC0D3E3EA900AB4CC6 /* dir_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = dir_unix.cpp; sourceTree = ""; }; + EE486FCD0D3E3EA900AB4CC6 /* dir_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = dir_win32.cpp; sourceTree = ""; }; + EE486FCF0D3E3EA900AB4CC6 /* gcominit.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gcominit.h; sourceTree = ""; }; + EE486FD00D3E3EA900AB4CC6 /* gdialog.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdialog.cpp; sourceTree = ""; }; + EE486FD10D3E3EA900AB4CC6 /* gdialog.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gdialog.h; sourceTree = ""; }; + EE486FD30D3E3EA900AB4CC6 /* glink.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = glink.h; sourceTree = ""; }; + EE486FD40D3E3EA900AB4CC6 /* gpage.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpage.cpp; sourceTree = ""; }; + EE486FD50D3E3EA900AB4CC6 /* gpage.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gpage.h; sourceTree = ""; }; + EE486FD60D3E3EA900AB4CC6 /* guimain.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = guimain.cpp; sourceTree = ""; }; + EE486FD70D3E3EA900AB4CC6 /* gunpack.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gunpack.cpp; sourceTree = ""; }; + EE486FD80D3E3EA900AB4CC6 /* gunpack.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gunpack.h; sourceTree = ""; }; + EE486FDA0D3E3EA900AB4CC6 /* installer.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = installer.cpp; sourceTree = ""; }; + EE486FDB0D3E3EA900AB4CC6 /* installer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = installer.h; sourceTree = ""; }; + EE486FDC0D3E3EA900AB4CC6 /* legal.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = legal.cpp; sourceTree = ""; }; + EE486FDD0D3E3EA900AB4CC6 /* legal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = legal.h; sourceTree = ""; }; + EE486FE00D3E3EA900AB4CC6 /* Makefile.am */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.am; sourceTree = ""; }; + EE486FE10D3E3EA900AB4CC6 /* Makefile.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.in; sourceTree = ""; }; + EE486FE20D3E3EA900AB4CC6 /* mingw.mak */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = mingw.mak; sourceTree = ""; }; + EE486FE30D3E3EA900AB4CC6 /* mock */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = mock; sourceTree = ""; }; + EE486FE40D3E3EA900AB4CC6 /* pack.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pack.cpp; sourceTree = ""; }; + EE486FE50D3E3EA900AB4CC6 /* pages.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pages.cpp; sourceTree = ""; }; + EE486FE60D3E3EA900AB4CC6 /* pages.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pages.h; sourceTree = ""; }; + EE486FE70D3E3EA900AB4CC6 /* qt.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = qt.h; sourceTree = ""; }; + EE486FE80D3E3EA900AB4CC6 /* run.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = run.c; sourceTree = ""; }; + EE486FE90D3E3EA900AB4CC6 /* service_install.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = service_install.cpp; sourceTree = ""; }; + EE486FEA0D3E3EA900AB4CC6 /* service_install.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = service_install.h; sourceTree = ""; }; + EE486FEB0D3E3EA900AB4CC6 /* service_wrapper.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = service_wrapper.cpp; sourceTree = ""; }; + EE486FEC0D3E3EA900AB4CC6 /* unpack.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = unpack.c; sourceTree = ""; }; + EE486FED0D3E3EA900AB4CC6 /* unpack.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = unpack.h; sourceTree = ""; }; + EE4870530D3E529100AB4CC6 /* moc_gdialog.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = moc_gdialog.cpp; path = src/gui/moc_gdialog.cpp; sourceTree = ""; }; + EE4870540D3E529100AB4CC6 /* moc_gpage.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = moc_gpage.cpp; path = src/gui/moc_gpage.cpp; sourceTree = ""; }; + EE4870550D3E529100AB4CC6 /* moc_pages.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = moc_pages.cpp; path = src/gui/moc_pages.cpp; sourceTree = ""; }; + EEC342BF0D50E0BD00DD9918 /* boot_mac.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = boot_mac.cpp; sourceTree = ""; }; + EEC342C00D50E0BD00DD9918 /* dir_mac.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = dir_mac.cpp; sourceTree = ""; }; + EEC342C30D50E0D800DD9918 /* glink_mac.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = glink_mac.cpp; sourceTree = ""; }; + EEC342C40D50E0D800DD9918 /* guistart.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = guistart.cpp; sourceTree = ""; }; + EEC342C50D50E0D800DD9918 /* state.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = state.cpp; sourceTree = ""; }; + EEC342CB0D50E1D500DD9918 /* state.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = state.h; sourceTree = ""; }; + EEC342DF0D50F62E00DD9918 /* emailrelay-start-gui */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = "emailrelay-start-gui"; sourceTree = BUILT_PRODUCTS_DIR; }; + EEC342ED0D50F6B600DD9918 /* emailrelay-unpack */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = "emailrelay-unpack"; sourceTree = BUILT_PRODUCTS_DIR; }; + EEC342F90D50F72800DD9918 /* unpackmain.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = unpackmain.c; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 8DD76F660486A84900D96B5E /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EEC342DD0D50F62E00DD9918 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EEC342EB0D50F6B600DD9918 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 08FB7794FE84155DC02AAC07 /* emailrelay-gui */ = { + isa = PBXGroup; + children = ( + EE4870510D3E517800AB4CC6 /* moc */, + EE486FC70D3E3EA900AB4CC6 /* gui */, + 1AB674ADFE9D54B511CA2CBB /* Products */, + ); + name = "emailrelay-gui"; + sourceTree = ""; + }; + 1AB674ADFE9D54B511CA2CBB /* Products */ = { + isa = PBXGroup; + children = ( + 8DD76F6C0486A84900D96B5E /* emailrelay-gui */, + EEC342DF0D50F62E00DD9918 /* emailrelay-start-gui */, + EEC342ED0D50F6B600DD9918 /* emailrelay-unpack */, + ); + name = Products; + sourceTree = ""; + }; + EE486FC70D3E3EA900AB4CC6 /* gui */ = { + isa = PBXGroup; + children = ( + EEC342F90D50F72800DD9918 /* unpackmain.c */, + EEC342CB0D50E1D500DD9918 /* state.h */, + EEC342C30D50E0D800DD9918 /* glink_mac.cpp */, + EEC342C40D50E0D800DD9918 /* guistart.cpp */, + EEC342C50D50E0D800DD9918 /* state.cpp */, + EEC342BF0D50E0BD00DD9918 /* boot_mac.cpp */, + EEC342C00D50E0BD00DD9918 /* dir_mac.cpp */, + EE486FC90D3E3EA900AB4CC6 /* boot.h */, + EE486FCA0D3E3EA900AB4CC6 /* dir.cpp */, + EE486FCB0D3E3EA900AB4CC6 /* dir.h */, + EE486FCC0D3E3EA900AB4CC6 /* dir_unix.cpp */, + EE486FCD0D3E3EA900AB4CC6 /* dir_win32.cpp */, + EE486FCF0D3E3EA900AB4CC6 /* gcominit.h */, + EE486FD00D3E3EA900AB4CC6 /* gdialog.cpp */, + EE486FD10D3E3EA900AB4CC6 /* gdialog.h */, + EE486FD30D3E3EA900AB4CC6 /* glink.h */, + EE486FD40D3E3EA900AB4CC6 /* gpage.cpp */, + EE486FD50D3E3EA900AB4CC6 /* gpage.h */, + EE486FD60D3E3EA900AB4CC6 /* guimain.cpp */, + EE486FD70D3E3EA900AB4CC6 /* gunpack.cpp */, + EE486FD80D3E3EA900AB4CC6 /* gunpack.h */, + EE486FDA0D3E3EA900AB4CC6 /* installer.cpp */, + EE486FDB0D3E3EA900AB4CC6 /* installer.h */, + EE486FDC0D3E3EA900AB4CC6 /* legal.cpp */, + EE486FDD0D3E3EA900AB4CC6 /* legal.h */, + EE486FE00D3E3EA900AB4CC6 /* Makefile.am */, + EE486FE10D3E3EA900AB4CC6 /* Makefile.in */, + EE486FE20D3E3EA900AB4CC6 /* mingw.mak */, + EE486FE30D3E3EA900AB4CC6 /* mock */, + EE486FE40D3E3EA900AB4CC6 /* pack.cpp */, + EE486FE50D3E3EA900AB4CC6 /* pages.cpp */, + EE486FE60D3E3EA900AB4CC6 /* pages.h */, + EE486FE70D3E3EA900AB4CC6 /* qt.h */, + EE486FE80D3E3EA900AB4CC6 /* run.c */, + EE486FE90D3E3EA900AB4CC6 /* service_install.cpp */, + EE486FEA0D3E3EA900AB4CC6 /* service_install.h */, + EE486FEB0D3E3EA900AB4CC6 /* service_wrapper.cpp */, + EE486FEC0D3E3EA900AB4CC6 /* unpack.c */, + EE486FED0D3E3EA900AB4CC6 /* unpack.h */, + ); + name = gui; + path = src/gui; + sourceTree = ""; + }; + EE4870510D3E517800AB4CC6 /* moc */ = { + isa = PBXGroup; + children = ( + EE4870530D3E529100AB4CC6 /* moc_gdialog.cpp */, + EE4870540D3E529100AB4CC6 /* moc_gpage.cpp */, + EE4870550D3E529100AB4CC6 /* moc_pages.cpp */, + ); + name = moc; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXNativeTarget section */ + 8DD76F620486A84900D96B5E /* emailrelay-gui */ = { + isa = PBXNativeTarget; + buildConfigurationList = 1DEB923108733DC60010E9CD /* Build configuration list for PBXNativeTarget "emailrelay-gui" */; + buildPhases = ( + EE4870490D3E4B8200AB4CC6 /* ShellScript */, + 8DD76F640486A84900D96B5E /* Sources */, + 8DD76F660486A84900D96B5E /* Frameworks */, + 8DD76F690486A84900D96B5E /* CopyFiles */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = "emailrelay-gui"; + productInstallPath = "$(HOME)/bin"; + productName = "emailrelay-gui"; + productReference = 8DD76F6C0486A84900D96B5E /* emailrelay-gui */; + productType = "com.apple.product-type.tool"; + }; + EEC342DE0D50F62E00DD9918 /* emailrelay-start-gui */ = { + isa = PBXNativeTarget; + buildConfigurationList = EEC342E30D50F64F00DD9918 /* Build configuration list for PBXNativeTarget "emailrelay-start-gui" */; + buildPhases = ( + EEC342DC0D50F62E00DD9918 /* Sources */, + EEC342DD0D50F62E00DD9918 /* Frameworks */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = "emailrelay-start-gui"; + productName = "emailrelay-start"; + productReference = EEC342DF0D50F62E00DD9918 /* emailrelay-start-gui */; + productType = "com.apple.product-type.tool"; + }; + EEC342EC0D50F6B600DD9918 /* emailrelay-unpack */ = { + isa = PBXNativeTarget; + buildConfigurationList = EEC342F60D50F6D600DD9918 /* Build configuration list for PBXNativeTarget "emailrelay-unpack" */; + buildPhases = ( + EEC342EA0D50F6B600DD9918 /* Sources */, + EEC342EB0D50F6B600DD9918 /* Frameworks */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = "emailrelay-unpack"; + productName = "emailrelay-unpack"; + productReference = EEC342ED0D50F6B600DD9918 /* emailrelay-unpack */; + productType = "com.apple.product-type.tool"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 08FB7793FE84155DC02AAC07 /* Project object */ = { + isa = PBXProject; + buildConfigurationList = 1DEB923508733DC60010E9CD /* Build configuration list for PBXProject "emailrelay-gui" */; + compatibilityVersion = "Xcode 3.0"; + hasScannedForEncodings = 1; + mainGroup = 08FB7794FE84155DC02AAC07 /* emailrelay-gui */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 8DD76F620486A84900D96B5E /* emailrelay-gui */, + EEC342DE0D50F62E00DD9918 /* emailrelay-start-gui */, + EEC342EC0D50F6B600DD9918 /* emailrelay-unpack */, + EE99190B0D9193D100FB06D5 /* all-targets */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXShellScriptBuildPhase section */ + EE4870490D3E4B8200AB4CC6 /* ShellScript */ = { + isa = PBXShellScriptBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + inputPaths = ( + "$(SRCROOT)/src/gui/gpage.h", + "$(SRCROOT)/src/gui/gdialog.h", + "$(SRCROOT)/src/gui/pages.h", + ); + outputPaths = ( + "$(SRCROOT)/src/gui/moc_gpage.cpp", + "$(SRCROOT)/src/gui/moc_gdialog.cpp", + "$(SRCROOT)/src/gui/moc_pages.cpp", + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "\ni=0\nwhile test $i -lt $SCRIPT_INPUT_FILE_COUNT\ndo\n\tinput=\"`eval echo '$'SCRIPT_INPUT_FILE_$i`\"\n\toutput=\"`eval echo '$'SCRIPT_OUTPUT_FILE_$i`\"\n\techo moc -o$output $input\n\tmoc -o$output $input\n\ti=`expr $i + 1`\ndone"; + showEnvVarsInLog = 0; + }; +/* End PBXShellScriptBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 8DD76F640486A84900D96B5E /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EE486FEF0D3E3EA900AB4CC6 /* dir.cpp in Sources */, + EE486FF20D3E3EA900AB4CC6 /* gdialog.cpp in Sources */, + EE486FF40D3E3EA900AB4CC6 /* gpage.cpp in Sources */, + EE486FF50D3E3EA900AB4CC6 /* guimain.cpp in Sources */, + EE486FF60D3E3EA900AB4CC6 /* gunpack.cpp in Sources */, + EE486FF70D3E3EA900AB4CC6 /* installer.cpp in Sources */, + EE486FF80D3E3EA900AB4CC6 /* legal.cpp in Sources */, + EE486FFC0D3E3EA900AB4CC6 /* pages.cpp in Sources */, + EE4870560D3E529100AB4CC6 /* moc_gdialog.cpp in Sources */, + EE4870570D3E529100AB4CC6 /* moc_gpage.cpp in Sources */, + EE4870580D3E529100AB4CC6 /* moc_pages.cpp in Sources */, + EEC342C10D50E0BD00DD9918 /* boot_mac.cpp in Sources */, + EEC342C20D50E0BD00DD9918 /* dir_mac.cpp in Sources */, + EEC342C60D50E0D800DD9918 /* glink_mac.cpp in Sources */, + EEC342C80D50E0D800DD9918 /* state.cpp in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EEC342DC0D50F62E00DD9918 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EEC342E80D50F68600DD9918 /* guistart.cpp in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EEC342EA0D50F6B600DD9918 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EEC342FA0D50F72800DD9918 /* unpackmain.c in Sources */, + EEC342FC0D50F73900DD9918 /* unpack.c in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXTargetDependency section */ + EE99190F0D9193DC00FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = 8DD76F620486A84900D96B5E /* emailrelay-gui */; + targetProxy = EE99190E0D9193DC00FB06D5 /* PBXContainerItemProxy */; + }; + EE9919110D9193DC00FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EEC342DE0D50F62E00DD9918 /* emailrelay-start-gui */; + targetProxy = EE9919100D9193DC00FB06D5 /* PBXContainerItemProxy */; + }; + EE9919130D9193DC00FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EEC342EC0D50F6B600DD9918 /* emailrelay-unpack */; + targetProxy = EE9919120D9193DC00FB06D5 /* PBXContainerItemProxy */; + }; +/* End PBXTargetDependency section */ + +/* Begin XCBuildConfiguration section */ + 1DEB923208733DC60010E9CD /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "_GLIBCXX_DEBUG=1", + "_GLIBCXX_DEBUG_PEDANTIC=1", + "G_UNIX=1", + "_DEBUG=1", + ); + INSTALL_PATH = /usr/local/bin; + PRODUCT_NAME = "emailrelay-gui"; + ZERO_LINK = YES; + }; + name = Debug; + }; + 1DEB923308733DC60010E9CD /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + GCC_INLINES_ARE_PRIVATE_EXTERN = NO; + GCC_MODEL_TUNING = G5; + GCC_SYMBOLS_PRIVATE_EXTERN = NO; + INSTALL_PATH = /usr/local/bin; + PRODUCT_NAME = "emailrelay-gui"; + }; + name = Release; + }; + 1DEB923608733DC60010E9CD /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + GCC_PREPROCESSOR_DEFINITIONS = ( + "_DEBUG=1", + "G_UNIX=1", + ); + GCC_WARN_ABOUT_RETURN_TYPE = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + HEADER_SEARCH_PATHS = ( + src/main, + src/glib, + ); + OTHER_CFLAGS = ""; + OTHER_LDFLAGS = ( + "-lglib", + "-framework", + QtGui, + "-framework", + Carbon, + "-framework", + QtCore, + "-lz", + ); + PREBINDING = NO; + SDKROOT = "$(DEVELOPER_SDK_DIR)/MacOSX10.5.sdk"; + }; + name = Debug; + }; + 1DEB923708733DC60010E9CD /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ADDITIONAL_SDKS = ""; + ARCHS = ( + i386, + ppc, + ); + GCC_ENABLE_OBJC_EXCEPTIONS = NO; + GCC_FAST_OBJC_DISPATCH = NO; + GCC_PREPROCESSOR_DEFINITIONS = "G_UNIX=1"; + GCC_WARN_ABOUT_RETURN_TYPE = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + HEADER_SEARCH_PATHS = ( + src/main, + src/glib, + ); + OTHER_LDFLAGS = ( + "-lglib", + "-framework", + QtGui, + "-framework", + Carbon, + "-framework", + QtCore, + "-lz", + ); + PREBINDING = NO; + SDKROOT = "$(DEVELOPER_SDK_DIR)/MacOSX10.5.sdk"; + }; + name = Release; + }; + EE99190C0D9193D200FB06D5 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_OPTIMIZATION_LEVEL = 0; + PRODUCT_NAME = "all-targets"; + }; + name = Debug; + }; + EE99190D0D9193D200FB06D5 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = YES; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + GCC_ENABLE_FIX_AND_CONTINUE = NO; + PRODUCT_NAME = "all-targets"; + ZERO_LINK = NO; + }; + name = Release; + }; + EEC342E10D50F63100DD9918 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + INSTALL_PATH = /usr/local/bin; + PREBINDING = NO; + PRODUCT_NAME = "emailrelay-start-gui"; + ZERO_LINK = YES; + }; + name = Debug; + }; + EEC342E20D50F63100DD9918 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = YES; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + GCC_ENABLE_FIX_AND_CONTINUE = NO; + GCC_MODEL_TUNING = G5; + INSTALL_PATH = /usr/local/bin; + PREBINDING = NO; + PRODUCT_NAME = "emailrelay-start-gui"; + ZERO_LINK = NO; + }; + name = Release; + }; + EEC342EF0D50F6B800DD9918 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + INSTALL_PATH = /usr/local/bin; + PREBINDING = NO; + PRODUCT_NAME = "emailrelay-unpack"; + ZERO_LINK = YES; + }; + name = Debug; + }; + EEC342F00D50F6B800DD9918 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = YES; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + GCC_ENABLE_FIX_AND_CONTINUE = NO; + GCC_MODEL_TUNING = G5; + INSTALL_PATH = /usr/local/bin; + PREBINDING = NO; + PRODUCT_NAME = "emailrelay-unpack"; + ZERO_LINK = NO; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 1DEB923108733DC60010E9CD /* Build configuration list for PBXNativeTarget "emailrelay-gui" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 1DEB923208733DC60010E9CD /* Debug */, + 1DEB923308733DC60010E9CD /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 1DEB923508733DC60010E9CD /* Build configuration list for PBXProject "emailrelay-gui" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 1DEB923608733DC60010E9CD /* Debug */, + 1DEB923708733DC60010E9CD /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EE9919150D91940100FB06D5 /* Build configuration list for PBXAggregateTarget "all-targets" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EE99190C0D9193D200FB06D5 /* Debug */, + EE99190D0D9193D200FB06D5 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EEC342E30D50F64F00DD9918 /* Build configuration list for PBXNativeTarget "emailrelay-start-gui" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EEC342E10D50F63100DD9918 /* Debug */, + EEC342E20D50F63100DD9918 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EEC342F60D50F6D600DD9918 /* Build configuration list for PBXNativeTarget "emailrelay-unpack" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EEC342EF0D50F6B800DD9918 /* Debug */, + EEC342F00D50F6B800DD9918 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = 08FB7793FE84155DC02AAC07 /* Project object */; +} diff --git a/emailrelay.spec b/emailrelay.spec index b7e803c..5e65d20 100644 --- a/emailrelay.spec +++ b/emailrelay.spec @@ -1,11 +1,11 @@ Summary: Simple e-mail message transfer agent and proxy using SMTP Name: emailrelay -Version: 1.7 +Version: 1.8 Release: 1 License: GPL3 Group: System Environment/Daemons URL: http://emailrelay.sourceforge.net/ -Source: http://sourceforge.net/sourceforge/emailrelay/emailrelay-1.7-src.tar.gz +Source: http://sourceforge.net/sourceforge/emailrelay/emailrelay-1.8-src.tar.gz BuildRoot: /tmp/emailrelay-install %description @@ -86,6 +86,7 @@ test "$RPM_BUILD_ROOT" = "/" || rm -rf "$RPM_BUILD_ROOT" /usr/lib/emailrelay/examples/emailrelay-resubmit.sh /usr/lib/emailrelay/examples/emailrelay-notify.sh /usr/lib/emailrelay/examples/emailrelay-submit.sh +/usr/lib/emailrelay/examples/emailrelay-multicast.sh /usr/lib/emailrelay/emailrelay-poke /usr/lib/emailrelay/emailrelay-filter-copy /usr/sbin/emailrelay-submit diff --git a/emailrelay.xcodeproj/project.pbxproj b/emailrelay.xcodeproj/project.pbxproj new file mode 100644 index 0000000..21d5cd2 --- /dev/null +++ b/emailrelay.xcodeproj/project.pbxproj @@ -0,0 +1,2546 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 44; + objects = { + +/* Begin PBXAggregateTarget section */ + EE9918CC0D91760400FB06D5 /* all-targets */ = { + isa = PBXAggregateTarget; + buildConfigurationList = EE9918CF0D91762300FB06D5 /* Build configuration list for PBXAggregateTarget "all-targets" */; + buildPhases = ( + ); + dependencies = ( + EE9918D10D91762800FB06D5 /* PBXTargetDependency */, + EE9918DD0D91762800FB06D5 /* PBXTargetDependency */, + EE9918DF0D91762800FB06D5 /* PBXTargetDependency */, + EE9918E10D91762800FB06D5 /* PBXTargetDependency */, + EE9918E30D91762800FB06D5 /* PBXTargetDependency */, + EE9918E50D91762800FB06D5 /* PBXTargetDependency */, + ); + name = "all-targets"; + productName = "all-targets"; + }; +/* End PBXAggregateTarget section */ + +/* Begin PBXBuildFile section */ + EE303C5D0D326C9700D840F2 /* empty.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AD50D326C9600D840F2 /* empty.cpp */; }; + EE303D000D326C9700D840F2 /* admin_enabled.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C050D326C9600D840F2 /* admin_enabled.cpp */; }; + EE303D010D326C9700D840F2 /* commandline_full.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C070D326C9600D840F2 /* commandline_full.cpp */; }; + EE303D030D326C9700D840F2 /* configuration.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C0A0D326C9600D840F2 /* configuration.cpp */; }; + EE303D060D326C9700D840F2 /* legal.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C190D326C9600D840F2 /* legal.cpp */; }; + EE303D070D326C9700D840F2 /* main.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C1B0D326C9600D840F2 /* main.cpp */; }; + EE303D0A0D326C9700D840F2 /* news.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C210D326C9700D840F2 /* news.cpp */; }; + EE303D0B0D326C9700D840F2 /* output.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C230D326C9700D840F2 /* output.cpp */; }; + EE303D0E0D326C9700D840F2 /* run.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C2A0D326C9700D840F2 /* run.cpp */; }; + EE303D380D3271A200D840F2 /* gtest.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B2C0D326C9600D840F2 /* gtest.cpp */; }; + EE303D3A0D3271AF00D840F2 /* glogoutput_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B100D326C9600D840F2 /* glogoutput_unix.cpp */; }; + EE303D3B0D3271B000D840F2 /* gexception.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AF50D326C9600D840F2 /* gexception.cpp */; }; + EE303D3C0D3271B100D840F2 /* gtime.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B2E0D326C9600D840F2 /* gtime.cpp */; }; + EE303D3E0D3271B400D840F2 /* gslot.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B260D326C9600D840F2 /* gslot.cpp */; }; + EE303D400D3271B600D840F2 /* ghostname_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B050D326C9600D840F2 /* ghostname_unix.cpp */; }; + EE303D410D3271B700D840F2 /* gfile_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AFD0D326C9600D840F2 /* gfile_unix.cpp */; }; + EE303D420D3271B900D840F2 /* gprocess_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B1F0D326C9600D840F2 /* gprocess_unix.cpp */; }; + EE303D430D3271BA00D840F2 /* gmd5_native.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B130D326C9600D840F2 /* gmd5_native.cpp */; }; + EE303D440D3271BB00D840F2 /* ggetopt.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B020D326C9600D840F2 /* ggetopt.cpp */; }; + EE303D470D3271C500D840F2 /* gnewprocess_unix_exec_enabled.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B170D326C9600D840F2 /* gnewprocess_unix_exec_enabled.cpp */; }; + EE303D4A0D3271C800D840F2 /* glog.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B0C0D326C9600D840F2 /* glog.cpp */; }; + EE303D4C0D3271CA00D840F2 /* md5.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B340D326C9600D840F2 /* md5.cpp */; }; + EE303D4E0D3271D000D840F2 /* gcleanup_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303ADF0D326C9600D840F2 /* gcleanup_unix.cpp */; }; + EE303D4F0D3271D100D840F2 /* gdirectory_unix_glob.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AF20D326C9600D840F2 /* gdirectory_unix_glob.cpp */; }; + EE303D500D3271D200D840F2 /* gdatetime_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AEB0D326C9600D840F2 /* gdatetime_unix.cpp */; }; + EE303D510D3271D300D840F2 /* gdirectory_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AF10D326C9600D840F2 /* gdirectory_unix.cpp */; }; + EE303D520D3271D300D840F2 /* gdate.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AE70D326C9600D840F2 /* gdate.cpp */; }; + EE303D530D3271D400D840F2 /* gexecutable.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AF70D326C9600D840F2 /* gexecutable.cpp */; }; + EE303D540D3271D600D840F2 /* gstr.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B290D326C9600D840F2 /* gstr.cpp */; }; + EE303D550D3271D600D840F2 /* gfs_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B000D326C9600D840F2 /* gfs_unix.cpp */; }; + EE303D570D3271D800D840F2 /* gexecutable_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AF90D326C9600D840F2 /* gexecutable_unix.cpp */; }; + EE303D580D3271D900D840F2 /* gdatetime.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AE90D326C9600D840F2 /* gdatetime.cpp */; }; + EE303D590D3271DC00D840F2 /* groot.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B210D326C9600D840F2 /* groot.cpp */; }; + EE303D5A0D3271DD00D840F2 /* gpath.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B1A0D326C9600D840F2 /* gpath.cpp */; }; + EE303D5B0D3271DD00D840F2 /* gidentity_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B090D326C9600D840F2 /* gidentity_unix.cpp */; }; + EE303D5D0D3271DF00D840F2 /* gdirectory.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AEF0D326C9600D840F2 /* gdirectory.cpp */; }; + EE303D5F0D3271E100D840F2 /* garg_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303ADB0D326C9600D840F2 /* garg_unix.cpp */; }; + EE303D600D3271EB00D840F2 /* gxtext.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B300D326C9600D840F2 /* gxtext.cpp */; }; + EE303D640D3271EF00D840F2 /* garg.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AD90D326C9600D840F2 /* garg.cpp */; }; + EE303D660D3271F200D840F2 /* gfile.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AFB0D326C9600D840F2 /* gfile.cpp */; }; + EE303D670D3271F300D840F2 /* glogoutput.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B0E0D326C9600D840F2 /* glogoutput.cpp */; }; + EE303D680D3271F300D840F2 /* gpidfile.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B1C0D326C9600D840F2 /* gpidfile.cpp */; }; + EE303D6A0D3271F500D840F2 /* gdaemon_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AE50D326C9600D840F2 /* gdaemon_unix.cpp */; }; + EE303D6B0D3271F600D840F2 /* gcounter.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AE20D326C9600D840F2 /* gcounter.cpp */; }; + EE303DEB0D32997B00D840F2 /* gbufferedserverpeer.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B3C0D326C9600D840F2 /* gbufferedserverpeer.cpp */; }; + EE303DEC0D32997C00D840F2 /* gconnection.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B410D326C9600D840F2 /* gconnection.cpp */; }; + EE303DED0D32997F00D840F2 /* gaddress_ipv4.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B3A0D326C9600D840F2 /* gaddress_ipv4.cpp */; }; + EE303DEE0D32998000D840F2 /* gresolver.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B5D0D326C9600D840F2 /* gresolver.cpp */; }; + EE303DEF0D32998500D840F2 /* gsocket.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B6D0D326C9600D840F2 /* gsocket.cpp */; }; + EE303DF00D32998700D840F2 /* geventloop.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B490D326C9600D840F2 /* geventloop.cpp */; }; + EE303DF10D32998A00D840F2 /* gtimer.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B730D326C9600D840F2 /* gtimer.cpp */; }; + EE303DF20D32998C00D840F2 /* gsocket_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B6F0D326C9600D840F2 /* gsocket_unix.cpp */; }; + EE303DF30D32998E00D840F2 /* gsimpleclient.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B690D326C9600D840F2 /* gsimpleclient.cpp */; }; + EE303DF40D32998F00D840F2 /* gclient.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B3E0D326C9600D840F2 /* gclient.cpp */; }; + EE303DF50D32999100D840F2 /* gheapclient.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B4D0D326C9600D840F2 /* gheapclient.cpp */; }; + EE303DF60D32999600D840F2 /* geventhandler.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B470D326C9600D840F2 /* geventhandler.cpp */; }; + EE303DF70D32999800D840F2 /* gmultiserver.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B580D326C9600D840F2 /* gmultiserver.cpp */; }; + EE303DF80D32999900D840F2 /* gserver.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B670D326C9600D840F2 /* gserver.cpp */; }; + EE303DF90D32999C00D840F2 /* glocal_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B540D326C9600D840F2 /* glocal_unix.cpp */; }; + EE303DFA0D3299A000D840F2 /* gtimerlist.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B750D326C9600D840F2 /* gtimerlist.cpp */; }; + EE303DFB0D3299A300D840F2 /* gsimpleclient_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B6B0D326C9600D840F2 /* gsimpleclient_unix.cpp */; }; + EE303DFC0D3299A500D840F2 /* glinebuffer.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B4F0D326C9600D840F2 /* glinebuffer.cpp */; }; + EE303DFD0D3299A600D840F2 /* glocal.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B510D326C9600D840F2 /* glocal.cpp */; }; + EE303DFE0D3299A800D840F2 /* gresolver_ipv4.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B610D326C9600D840F2 /* gresolver_ipv4.cpp */; }; + EE303DFF0D3299AA00D840F2 /* gresolverinfo.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B650D326C9600D840F2 /* gresolverinfo.cpp */; }; + EE303E000D3299AE00D840F2 /* gmonitor.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B560D326C9600D840F2 /* gmonitor.cpp */; }; + EE303E010D3299B100D840F2 /* gsocketprotocol.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B710D326C9600D840F2 /* gsocketprotocol.cpp */; }; + EE303E020D3299B300D840F2 /* geventloop_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B4B0D326C9600D840F2 /* geventloop_unix.cpp */; }; + EE303E040D3299BB00D840F2 /* gdescriptor_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B440D326C9600D840F2 /* gdescriptor_unix.cpp */; }; + EE303E050D3299BD00D840F2 /* gresolver_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B630D326C9600D840F2 /* gresolver_unix.cpp */; }; + EE303E150D329BC100D840F2 /* gpopserverprotocol.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B850D326C9600D840F2 /* gpopserverprotocol.cpp */; }; + EE303E160D329BC300D840F2 /* gpopstore.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B870D326C9600D840F2 /* gpopstore.cpp */; }; + EE303E170D329BC400D840F2 /* gpopserver.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B830D326C9600D840F2 /* gpopserver.cpp */; }; + EE303E180D329BC500D840F2 /* gpopauth.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B7D0D326C9600D840F2 /* gpopauth.cpp */; }; + EE303E190D329BC700D840F2 /* gpopsecrets_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B810D326C9600D840F2 /* gpopsecrets_unix.cpp */; }; + EE303E1A0D329BC800D840F2 /* gpopsecrets.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B7F0D326C9600D840F2 /* gpopsecrets.cpp */; }; + EE303E260D329C1200D840F2 /* gstoredmessage.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BCC0D326C9600D840F2 /* gstoredmessage.cpp */; }; + EE303E270D329C1400D840F2 /* gexecutableverifier.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B950D326C9600D840F2 /* gexecutableverifier.cpp */; }; + EE303E280D329C1500D840F2 /* gsecrets_full.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BBD0D326C9600D840F2 /* gsecrets_full.cpp */; }; + EE303E290D329C1700D840F2 /* ginternalverifier.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B9B0D326C9600D840F2 /* ginternalverifier.cpp */; }; + EE303E2A0D329C1800D840F2 /* grequestclient.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BB60D326C9600D840F2 /* grequestclient.cpp */; }; + EE303E2B0D329C1A00D840F2 /* gadminserver.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B8D0D326C9600D840F2 /* gadminserver.cpp */; }; + EE303E2C0D329C1C00D840F2 /* gprocessor.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BAB0D326C9600D840F2 /* gprocessor.cpp */; }; + EE303E2D0D329C1E00D840F2 /* gprocessorfactory_exec_enabled.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BAF0D326C9600D840F2 /* gprocessorfactory_exec_enabled.cpp */; }; + EE303E2E0D329C1F00D840F2 /* gclientprotocol.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B910D326C9600D840F2 /* gclientprotocol.cpp */; }; + EE303E2F0D329C2200D840F2 /* gmessagestore.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B9D0D326C9600D840F2 /* gmessagestore.cpp */; }; + EE303E300D329C2400D840F2 /* gfilestore.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B990D326C9600D840F2 /* gfilestore.cpp */; }; + EE303E310D329C2500D840F2 /* gsasl_native.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BBA0D326C9600D840F2 /* gsasl_native.cpp */; }; + EE303E320D329C2600D840F2 /* gmessagestore_unix.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B9F0D326C9600D840F2 /* gmessagestore_unix.cpp */; }; + EE303E330D329C2800D840F2 /* gverifierstatus.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BD30D326C9600D840F2 /* gverifierstatus.cpp */; }; + EE303E340D329C2A00D840F2 /* gspamprocessor.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BC80D326C9600D840F2 /* gspamprocessor.cpp */; }; + EE303E350D329C2C00D840F2 /* gnullprocessor.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BA90D326C9600D840F2 /* gnullprocessor.cpp */; }; + EE303E360D329C3000D840F2 /* gbase64.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B8F0D326C9600D840F2 /* gbase64.cpp */; }; + EE303E370D329C3200D840F2 /* gverifierfactory_exec_enabled.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BD20D326C9600D840F2 /* gverifierfactory_exec_enabled.cpp */; }; + EE303E380D329C3400D840F2 /* gnetworkverifier.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BA30D326C9600D840F2 /* gnetworkverifier.cpp */; }; + EE303E390D329C3700D840F2 /* gstoredfile.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BCA0D326C9600D840F2 /* gstoredfile.cpp */; }; + EE303E3A0D329C3800D840F2 /* gprotocolmessage.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BB00D326C9600D840F2 /* gprotocolmessage.cpp */; }; + EE303E3B0D329C3A00D840F2 /* gverifier.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BCE0D326C9600D840F2 /* gverifier.cpp */; }; + EE303E3C0D329C3B00D840F2 /* gnewfile.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BA50D326C9600D840F2 /* gnewfile.cpp */; }; + EE303E3D0D329C3C00D840F2 /* gprotocolmessagestore.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BB40D326C9600D840F2 /* gprotocolmessagestore.cpp */; }; + EE303E3E0D329C3D00D840F2 /* gsmtpclient.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BC20D326C9600D840F2 /* gsmtpclient.cpp */; }; + EE303E3F0D329C3F00D840F2 /* gexecutableprocessor.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B930D326C9600D840F2 /* gexecutableprocessor.cpp */; }; + EE303E400D329C4000D840F2 /* gnewmessage.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BA70D326C9600D840F2 /* gnewmessage.cpp */; }; + EE303E410D329C4200D840F2 /* gprotocolmessageforward.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BB20D326C9600D840F2 /* gprotocolmessageforward.cpp */; }; + EE303E420D329C4400D840F2 /* gspamclient.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BC60D326C9600D840F2 /* gspamclient.cpp */; }; + EE303E430D329C4900D840F2 /* gfactoryparser.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303B970D326C9600D840F2 /* gfactoryparser.cpp */; }; + EE303E440D329C4B00D840F2 /* gnetworkprocessor.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BA10D326C9600D840F2 /* gnetworkprocessor.cpp */; }; + EE303E450D329C4E00D840F2 /* gsmtpserver.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BC40D326C9600D840F2 /* gsmtpserver.cpp */; }; + EE303E460D329C5000D840F2 /* gserverprotocol.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BBF0D326C9600D840F2 /* gserverprotocol.cpp */; }; + EE9918310D91664E00FB06D5 /* empty.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AD50D326C9600D840F2 /* empty.cpp */; }; + EE9918420D91670200FB06D5 /* filter_copy.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C130D326C9600D840F2 /* filter_copy.cpp */; }; + EE9918440D91673900FB06D5 /* filter.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C100D326C9600D840F2 /* filter.cpp */; }; + EE9918460D91675100FB06D5 /* legal.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C190D326C9600D840F2 /* legal.cpp */; }; + EE99184F0D91693000FB06D5 /* empty.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AD50D326C9600D840F2 /* empty.cpp */; }; + EE99185F0D91695000FB06D5 /* empty.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AD50D326C9600D840F2 /* empty.cpp */; }; + EE99186F0D91697900FB06D5 /* empty.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AD50D326C9600D840F2 /* empty.cpp */; }; + EE99187F0D91698A00FB06D5 /* empty.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303AD50D326C9600D840F2 /* empty.cpp */; }; + EE99188D0D9169FE00FB06D5 /* start.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE99188B0D9169F700FB06D5 /* start.cpp */; }; + EE99188F0D916A3600FB06D5 /* passwd.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C250D326C9700D840F2 /* passwd.cpp */; }; + EE9918900D916A4E00FB06D5 /* poke.c in Sources */ = {isa = PBXBuildFile; fileRef = EE303C270D326C9700D840F2 /* poke.c */; }; + EE9918920D916A7400FB06D5 /* submit.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C320D326C9700D840F2 /* submit.cpp */; }; + EE9918940D916A8600FB06D5 /* legal.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C190D326C9600D840F2 /* legal.cpp */; }; + EE9918A50D916B1A00FB06D5 /* legal.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303C190D326C9600D840F2 /* legal.cpp */; }; + EE9919380D91A4F500FB06D5 /* gssl_openssl.cpp in Sources */ = {isa = PBXBuildFile; fileRef = EE303BDB0D326C9600D840F2 /* gssl_openssl.cpp */; }; +/* End PBXBuildFile section */ + +/* Begin PBXContainerItemProxy section */ + EE303D800D32779300D840F2 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE303D330D32714D00D840F2; + remoteInfo = glib; + }; + EE303E5C0D32A86200D840F2 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE303DE60D3298F600D840F2; + remoteInfo = gnet; + }; + EE303E5E0D32A86200D840F2 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE303E110D329BAA00D840F2; + remoteInfo = gpop; + }; + EE303E600D32A86200D840F2 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE303E220D329BFF00D840F2; + remoteInfo = gsmtp; + }; + EE303E620D32A86200D840F2 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE303E4E0D329D8F00D840F2; + remoteInfo = gssl; + }; + EE9918270D91664E00FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE303D330D32714D00D840F2; + remoteInfo = glib; + }; + EE99185D0D91695000FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE303D330D32714D00D840F2; + remoteInfo = glib; + }; + EE99187D0D91698A00FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE303D330D32714D00D840F2; + remoteInfo = glib; + }; + EE9918950D916AA200FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE303DE60D3298F600D840F2; + remoteInfo = gnet; + }; + EE9918B10D91707300FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE303E220D329BFF00D840F2; + remoteInfo = gsmtp; + }; + EE9918B30D91707900FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE303E4E0D329D8F00D840F2; + remoteInfo = gssl; + }; + EE9918D00D91762800FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = 8DD76F620486A84900D96B5E; + remoteInfo = emailrelay; + }; + EE9918DC0D91762800FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE9918250D91664E00FB06D5; + remoteInfo = "emailrelay-filter-copy"; + }; + EE9918DE0D91762800FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE99184B0D91693000FB06D5; + remoteInfo = "emailrelay-start"; + }; + EE9918E00D91762800FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE99185B0D91695000FB06D5; + remoteInfo = "emailrelay-passwd"; + }; + EE9918E20D91762800FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE99186B0D91697900FB06D5; + remoteInfo = "emailrelay-poke"; + }; + EE9918E40D91762800FB06D5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 08FB7793FE84155DC02AAC07 /* Project object */; + proxyType = 1; + remoteGlobalIDString = EE99187B0D91698A00FB06D5; + remoteInfo = "emailrelay-submit"; + }; +/* End PBXContainerItemProxy section */ + +/* Begin PBXCopyFilesBuildPhase section */ + 8DD76F690486A84900D96B5E /* CopyFiles */ = { + isa = PBXCopyFilesBuildPhase; + buildActionMask = 8; + dstPath = /usr/share/man/man1/; + dstSubfolderSpec = 0; + files = ( + ); + runOnlyForDeploymentPostprocessing = 1; + }; + EE99183B0D91664E00FB06D5 /* CopyFiles */ = { + isa = PBXCopyFilesBuildPhase; + buildActionMask = 8; + dstPath = /usr/share/man/man1/; + dstSubfolderSpec = 0; + files = ( + ); + runOnlyForDeploymentPostprocessing = 1; + }; + EE9918540D91693000FB06D5 /* CopyFiles */ = { + isa = PBXCopyFilesBuildPhase; + buildActionMask = 8; + dstPath = /usr/share/man/man1/; + dstSubfolderSpec = 0; + files = ( + ); + runOnlyForDeploymentPostprocessing = 1; + }; + EE9918640D91695000FB06D5 /* CopyFiles */ = { + isa = PBXCopyFilesBuildPhase; + buildActionMask = 8; + dstPath = /usr/share/man/man1/; + dstSubfolderSpec = 0; + files = ( + ); + runOnlyForDeploymentPostprocessing = 1; + }; + EE9918740D91697900FB06D5 /* CopyFiles */ = { + isa = PBXCopyFilesBuildPhase; + buildActionMask = 8; + dstPath = /usr/share/man/man1/; + dstSubfolderSpec = 0; + files = ( + ); + runOnlyForDeploymentPostprocessing = 1; + }; + EE9918840D91698A00FB06D5 /* CopyFiles */ = { + isa = PBXCopyFilesBuildPhase; + buildActionMask = 8; + dstPath = /usr/share/man/man1/; + dstSubfolderSpec = 0; + files = ( + ); + runOnlyForDeploymentPostprocessing = 1; + }; +/* End PBXCopyFilesBuildPhase section */ + +/* Begin PBXFileReference section */ + 8DD76F6C0486A84900D96B5E /* emailrelay */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = emailrelay; sourceTree = BUILT_PRODUCTS_DIR; }; + EE303AD30D326C9600D840F2 /* emailrelay.dsw */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = emailrelay.dsw; sourceTree = ""; }; + EE303AD50D326C9600D840F2 /* empty.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = empty.cpp; sourceTree = ""; }; + EE303AD60D326C9600D840F2 /* Makefile.am */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.am; sourceTree = ""; }; + EE303AD70D326C9600D840F2 /* Makefile.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.in; sourceTree = ""; }; + EE303AD90D326C9600D840F2 /* garg.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = garg.cpp; sourceTree = ""; }; + EE303ADA0D326C9600D840F2 /* garg.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = garg.h; sourceTree = ""; }; + EE303ADB0D326C9600D840F2 /* garg_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = garg_unix.cpp; sourceTree = ""; }; + EE303ADC0D326C9600D840F2 /* garg_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = garg_win32.cpp; sourceTree = ""; }; + EE303ADD0D326C9600D840F2 /* gassert.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gassert.h; sourceTree = ""; }; + EE303ADE0D326C9600D840F2 /* gcleanup.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gcleanup.h; sourceTree = ""; }; + EE303ADF0D326C9600D840F2 /* gcleanup_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gcleanup_unix.cpp; sourceTree = ""; }; + EE303AE00D326C9600D840F2 /* gcleanup_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gcleanup_win32.cpp; sourceTree = ""; }; + EE303AE10D326C9600D840F2 /* gconvert.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gconvert.h; sourceTree = ""; }; + EE303AE20D326C9600D840F2 /* gcounter.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gcounter.cpp; sourceTree = ""; }; + EE303AE30D326C9600D840F2 /* gcounter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gcounter.h; sourceTree = ""; }; + EE303AE40D326C9600D840F2 /* gdaemon.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gdaemon.h; sourceTree = ""; }; + EE303AE50D326C9600D840F2 /* gdaemon_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdaemon_unix.cpp; sourceTree = ""; }; + EE303AE60D326C9600D840F2 /* gdaemon_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdaemon_win32.cpp; sourceTree = ""; }; + EE303AE70D326C9600D840F2 /* gdate.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdate.cpp; sourceTree = ""; }; + EE303AE80D326C9600D840F2 /* gdate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gdate.h; sourceTree = ""; }; + EE303AE90D326C9600D840F2 /* gdatetime.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdatetime.cpp; sourceTree = ""; }; + EE303AEA0D326C9600D840F2 /* gdatetime.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gdatetime.h; sourceTree = ""; }; + EE303AEB0D326C9600D840F2 /* gdatetime_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdatetime_unix.cpp; sourceTree = ""; }; + EE303AEC0D326C9600D840F2 /* gdatetime_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdatetime_win32.cpp; sourceTree = ""; }; + EE303AED0D326C9600D840F2 /* gdebug.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gdebug.h; sourceTree = ""; }; + EE303AEE0D326C9600D840F2 /* gdef.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gdef.h; sourceTree = ""; }; + EE303AEF0D326C9600D840F2 /* gdirectory.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdirectory.cpp; sourceTree = ""; }; + EE303AF00D326C9600D840F2 /* gdirectory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gdirectory.h; sourceTree = ""; }; + EE303AF10D326C9600D840F2 /* gdirectory_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdirectory_unix.cpp; sourceTree = ""; }; + EE303AF20D326C9600D840F2 /* gdirectory_unix_glob.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdirectory_unix_glob.cpp; sourceTree = ""; }; + EE303AF30D326C9600D840F2 /* gdirectory_unix_noglob.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdirectory_unix_noglob.cpp; sourceTree = ""; }; + EE303AF40D326C9600D840F2 /* gdirectory_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdirectory_win32.cpp; sourceTree = ""; }; + EE303AF50D326C9600D840F2 /* gexception.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gexception.cpp; sourceTree = ""; }; + EE303AF60D326C9600D840F2 /* gexception.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gexception.h; sourceTree = ""; }; + EE303AF70D326C9600D840F2 /* gexecutable.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gexecutable.cpp; sourceTree = ""; }; + EE303AF80D326C9600D840F2 /* gexecutable.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gexecutable.h; sourceTree = ""; }; + EE303AF90D326C9600D840F2 /* gexecutable_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gexecutable_unix.cpp; sourceTree = ""; }; + EE303AFA0D326C9600D840F2 /* gexecutable_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gexecutable_win32.cpp; sourceTree = ""; }; + EE303AFB0D326C9600D840F2 /* gfile.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gfile.cpp; sourceTree = ""; }; + EE303AFC0D326C9600D840F2 /* gfile.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gfile.h; sourceTree = ""; }; + EE303AFD0D326C9600D840F2 /* gfile_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gfile_unix.cpp; sourceTree = ""; }; + EE303AFE0D326C9600D840F2 /* gfile_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gfile_win32.cpp; sourceTree = ""; }; + EE303AFF0D326C9600D840F2 /* gfs.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gfs.h; sourceTree = ""; }; + EE303B000D326C9600D840F2 /* gfs_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gfs_unix.cpp; sourceTree = ""; }; + EE303B010D326C9600D840F2 /* gfs_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gfs_win32.cpp; sourceTree = ""; }; + EE303B020D326C9600D840F2 /* ggetopt.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ggetopt.cpp; sourceTree = ""; }; + EE303B030D326C9600D840F2 /* ggetopt.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ggetopt.h; sourceTree = ""; }; + EE303B040D326C9600D840F2 /* ghostname.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ghostname.h; sourceTree = ""; }; + EE303B050D326C9600D840F2 /* ghostname_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ghostname_unix.cpp; sourceTree = ""; }; + EE303B060D326C9600D840F2 /* ghostname_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ghostname_win32.cpp; sourceTree = ""; }; + EE303B070D326C9600D840F2 /* gidentity.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gidentity.h; sourceTree = ""; }; + EE303B080D326C9600D840F2 /* gidentity_disabled.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gidentity_disabled.cpp; sourceTree = ""; }; + EE303B090D326C9600D840F2 /* gidentity_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gidentity_unix.cpp; sourceTree = ""; }; + EE303B0A0D326C9600D840F2 /* gidentity_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gidentity_win32.cpp; sourceTree = ""; }; + EE303B0B0D326C9600D840F2 /* glimits.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = glimits.h; sourceTree = ""; }; + EE303B0C0D326C9600D840F2 /* glog.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = glog.cpp; sourceTree = ""; }; + EE303B0D0D326C9600D840F2 /* glog.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = glog.h; sourceTree = ""; }; + EE303B0E0D326C9600D840F2 /* glogoutput.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = glogoutput.cpp; sourceTree = ""; }; + EE303B0F0D326C9600D840F2 /* glogoutput.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = glogoutput.h; sourceTree = ""; }; + EE303B100D326C9600D840F2 /* glogoutput_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = glogoutput_unix.cpp; sourceTree = ""; }; + EE303B110D326C9600D840F2 /* glogoutput_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = glogoutput_win32.cpp; sourceTree = ""; }; + EE303B120D326C9600D840F2 /* gmd5.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gmd5.h; sourceTree = ""; }; + EE303B130D326C9600D840F2 /* gmd5_native.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gmd5_native.cpp; sourceTree = ""; }; + EE303B140D326C9600D840F2 /* gmemory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gmemory.h; sourceTree = ""; }; + EE303B150D326C9600D840F2 /* gnewprocess.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gnewprocess.h; sourceTree = ""; }; + EE303B160D326C9600D840F2 /* gnewprocess_unix_exec_disabled.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gnewprocess_unix_exec_disabled.cpp; sourceTree = ""; }; + EE303B170D326C9600D840F2 /* gnewprocess_unix_exec_enabled.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gnewprocess_unix_exec_enabled.cpp; sourceTree = ""; }; + EE303B180D326C9600D840F2 /* gnewprocess_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gnewprocess_win32.cpp; sourceTree = ""; }; + EE303B190D326C9600D840F2 /* gnoncopyable.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gnoncopyable.h; sourceTree = ""; }; + EE303B1A0D326C9600D840F2 /* gpath.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpath.cpp; sourceTree = ""; }; + EE303B1B0D326C9600D840F2 /* gpath.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gpath.h; sourceTree = ""; }; + EE303B1C0D326C9600D840F2 /* gpidfile.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpidfile.cpp; sourceTree = ""; }; + EE303B1D0D326C9600D840F2 /* gpidfile.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gpidfile.h; sourceTree = ""; }; + EE303B1E0D326C9600D840F2 /* gprocess.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gprocess.h; sourceTree = ""; }; + EE303B1F0D326C9600D840F2 /* gprocess_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gprocess_unix.cpp; sourceTree = ""; }; + EE303B200D326C9600D840F2 /* gprocess_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gprocess_win32.cpp; sourceTree = ""; }; + EE303B210D326C9600D840F2 /* groot.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = groot.cpp; sourceTree = ""; }; + EE303B220D326C9600D840F2 /* groot.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = groot.h; sourceTree = ""; }; + EE303B230D326C9600D840F2 /* gsetter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gsetter.h; sourceTree = ""; }; + EE303B240D326C9600D840F2 /* gsignalsafe.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gsignalsafe.h; sourceTree = ""; }; + EE303B250D326C9600D840F2 /* gsleep.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gsleep.h; sourceTree = ""; }; + EE303B260D326C9600D840F2 /* gslot.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gslot.cpp; sourceTree = ""; }; + EE303B270D326C9600D840F2 /* gslot.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gslot.h; sourceTree = ""; }; + EE303B280D326C9600D840F2 /* gstatemachine.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gstatemachine.h; sourceTree = ""; }; + EE303B290D326C9600D840F2 /* gstr.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gstr.cpp; sourceTree = ""; }; + EE303B2A0D326C9600D840F2 /* gstr.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gstr.h; sourceTree = ""; }; + EE303B2B0D326C9600D840F2 /* gstrings.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gstrings.h; sourceTree = ""; }; + EE303B2C0D326C9600D840F2 /* gtest.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gtest.cpp; sourceTree = ""; }; + EE303B2D0D326C9600D840F2 /* gtest.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gtest.h; sourceTree = ""; }; + EE303B2E0D326C9600D840F2 /* gtime.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gtime.cpp; sourceTree = ""; }; + EE303B2F0D326C9600D840F2 /* gtime.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gtime.h; sourceTree = ""; }; + EE303B300D326C9600D840F2 /* gxtext.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gxtext.cpp; sourceTree = ""; }; + EE303B310D326C9600D840F2 /* gxtext.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gxtext.h; sourceTree = ""; }; + EE303B320D326C9600D840F2 /* Makefile.am */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.am; sourceTree = ""; }; + EE303B330D326C9600D840F2 /* Makefile.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.in; sourceTree = ""; }; + EE303B340D326C9600D840F2 /* md5.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = md5.cpp; sourceTree = ""; }; + EE303B350D326C9600D840F2 /* md5.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = md5.h; sourceTree = ""; }; + EE303B360D326C9600D840F2 /* mingw.mak */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = mingw.mak; sourceTree = ""; }; + EE303B380D326C9600D840F2 /* gaddress.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gaddress.h; sourceTree = ""; }; + EE303B390D326C9600D840F2 /* gaddress_ip.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gaddress_ip.cpp; sourceTree = ""; }; + EE303B3A0D326C9600D840F2 /* gaddress_ipv4.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gaddress_ipv4.cpp; sourceTree = ""; }; + EE303B3B0D326C9600D840F2 /* gaddress_ipv6.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gaddress_ipv6.cpp; sourceTree = ""; }; + EE303B3C0D326C9600D840F2 /* gbufferedserverpeer.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gbufferedserverpeer.cpp; sourceTree = ""; }; + EE303B3D0D326C9600D840F2 /* gbufferedserverpeer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gbufferedserverpeer.h; sourceTree = ""; }; + EE303B3E0D326C9600D840F2 /* gclient.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gclient.cpp; sourceTree = ""; }; + EE303B3F0D326C9600D840F2 /* gclient.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gclient.h; sourceTree = ""; }; + EE303B400D326C9600D840F2 /* gclientptr.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gclientptr.h; sourceTree = ""; }; + EE303B410D326C9600D840F2 /* gconnection.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gconnection.cpp; sourceTree = ""; }; + EE303B420D326C9600D840F2 /* gconnection.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gconnection.h; sourceTree = ""; }; + EE303B430D326C9600D840F2 /* gdescriptor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gdescriptor.h; sourceTree = ""; }; + EE303B440D326C9600D840F2 /* gdescriptor_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdescriptor_unix.cpp; sourceTree = ""; }; + EE303B450D326C9600D840F2 /* gdescriptor_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdescriptor_win32.cpp; sourceTree = ""; }; + EE303B460D326C9600D840F2 /* gevent.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gevent.h; sourceTree = ""; }; + EE303B470D326C9600D840F2 /* geventhandler.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = geventhandler.cpp; sourceTree = ""; }; + EE303B480D326C9600D840F2 /* geventhandler.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = geventhandler.h; sourceTree = ""; }; + EE303B490D326C9600D840F2 /* geventloop.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = geventloop.cpp; sourceTree = ""; }; + EE303B4A0D326C9600D840F2 /* geventloop.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = geventloop.h; sourceTree = ""; }; + EE303B4B0D326C9600D840F2 /* geventloop_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = geventloop_unix.cpp; sourceTree = ""; }; + EE303B4C0D326C9600D840F2 /* geventloop_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = geventloop_win32.cpp; sourceTree = ""; }; + EE303B4D0D326C9600D840F2 /* gheapclient.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gheapclient.cpp; sourceTree = ""; }; + EE303B4E0D326C9600D840F2 /* gheapclient.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gheapclient.h; sourceTree = ""; }; + EE303B4F0D326C9600D840F2 /* glinebuffer.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = glinebuffer.cpp; sourceTree = ""; }; + EE303B500D326C9600D840F2 /* glinebuffer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = glinebuffer.h; sourceTree = ""; }; + EE303B510D326C9600D840F2 /* glocal.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = glocal.cpp; sourceTree = ""; }; + EE303B520D326C9600D840F2 /* glocal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = glocal.h; sourceTree = ""; }; + EE303B530D326C9600D840F2 /* glocal_dns_disabled.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = glocal_dns_disabled.cpp; sourceTree = ""; }; + EE303B540D326C9600D840F2 /* glocal_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = glocal_unix.cpp; sourceTree = ""; }; + EE303B550D326C9600D840F2 /* glocal_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = glocal_win32.cpp; sourceTree = ""; }; + EE303B560D326C9600D840F2 /* gmonitor.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gmonitor.cpp; sourceTree = ""; }; + EE303B570D326C9600D840F2 /* gmonitor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gmonitor.h; sourceTree = ""; }; + EE303B580D326C9600D840F2 /* gmultiserver.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gmultiserver.cpp; sourceTree = ""; }; + EE303B590D326C9600D840F2 /* gmultiserver.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gmultiserver.h; sourceTree = ""; }; + EE303B5A0D326C9600D840F2 /* gnet.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gnet.h; sourceTree = ""; }; + EE303B5B0D326C9600D840F2 /* grequest.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = grequest.cpp; sourceTree = ""; }; + EE303B5C0D326C9600D840F2 /* grequest.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = grequest.h; sourceTree = ""; }; + EE303B5D0D326C9600D840F2 /* gresolver.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gresolver.cpp; sourceTree = ""; }; + EE303B5E0D326C9600D840F2 /* gresolver.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gresolver.h; sourceTree = ""; }; + EE303B5F0D326C9600D840F2 /* gresolver_dns_disabled.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gresolver_dns_disabled.cpp; sourceTree = ""; }; + EE303B600D326C9600D840F2 /* gresolver_ip.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gresolver_ip.cpp; sourceTree = ""; }; + EE303B610D326C9600D840F2 /* gresolver_ipv4.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gresolver_ipv4.cpp; sourceTree = ""; }; + EE303B620D326C9600D840F2 /* gresolver_ipv6.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gresolver_ipv6.cpp; sourceTree = ""; }; + EE303B630D326C9600D840F2 /* gresolver_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gresolver_unix.cpp; sourceTree = ""; }; + EE303B640D326C9600D840F2 /* gresolver_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gresolver_win32.cpp; sourceTree = ""; }; + EE303B650D326C9600D840F2 /* gresolverinfo.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gresolverinfo.cpp; sourceTree = ""; }; + EE303B660D326C9600D840F2 /* gresolverinfo.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gresolverinfo.h; sourceTree = ""; }; + EE303B670D326C9600D840F2 /* gserver.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gserver.cpp; sourceTree = ""; }; + EE303B680D326C9600D840F2 /* gserver.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gserver.h; sourceTree = ""; }; + EE303B690D326C9600D840F2 /* gsimpleclient.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsimpleclient.cpp; sourceTree = ""; }; + EE303B6A0D326C9600D840F2 /* gsimpleclient.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gsimpleclient.h; sourceTree = ""; }; + EE303B6B0D326C9600D840F2 /* gsimpleclient_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsimpleclient_unix.cpp; sourceTree = ""; }; + EE303B6C0D326C9600D840F2 /* gsimpleclient_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsimpleclient_win32.cpp; sourceTree = ""; }; + EE303B6D0D326C9600D840F2 /* gsocket.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsocket.cpp; sourceTree = ""; }; + EE303B6E0D326C9600D840F2 /* gsocket.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gsocket.h; sourceTree = ""; }; + EE303B6F0D326C9600D840F2 /* gsocket_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsocket_unix.cpp; sourceTree = ""; }; + EE303B700D326C9600D840F2 /* gsocket_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsocket_win32.cpp; sourceTree = ""; }; + EE303B710D326C9600D840F2 /* gsocketprotocol.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsocketprotocol.cpp; sourceTree = ""; }; + EE303B720D326C9600D840F2 /* gsocketprotocol.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gsocketprotocol.h; sourceTree = ""; }; + EE303B730D326C9600D840F2 /* gtimer.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gtimer.cpp; sourceTree = ""; }; + EE303B740D326C9600D840F2 /* gtimer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gtimer.h; sourceTree = ""; }; + EE303B750D326C9600D840F2 /* gtimerlist.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gtimerlist.cpp; sourceTree = ""; }; + EE303B760D326C9600D840F2 /* gtimerlist.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gtimerlist.h; sourceTree = ""; }; + EE303B770D326C9600D840F2 /* Makefile.am */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.am; sourceTree = ""; }; + EE303B780D326C9600D840F2 /* Makefile.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.in; sourceTree = ""; }; + EE303B790D326C9600D840F2 /* mingw.mak */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = mingw.mak; sourceTree = ""; }; + EE303B7B0D326C9600D840F2 /* gpop.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gpop.h; sourceTree = ""; }; + EE303B7C0D326C9600D840F2 /* gpop_disabled.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpop_disabled.cpp; sourceTree = ""; }; + EE303B7D0D326C9600D840F2 /* gpopauth.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpopauth.cpp; sourceTree = ""; }; + EE303B7E0D326C9600D840F2 /* gpopauth.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gpopauth.h; sourceTree = ""; }; + EE303B7F0D326C9600D840F2 /* gpopsecrets.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpopsecrets.cpp; sourceTree = ""; }; + EE303B800D326C9600D840F2 /* gpopsecrets.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gpopsecrets.h; sourceTree = ""; }; + EE303B810D326C9600D840F2 /* gpopsecrets_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpopsecrets_unix.cpp; sourceTree = ""; }; + EE303B820D326C9600D840F2 /* gpopsecrets_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpopsecrets_win32.cpp; sourceTree = ""; }; + EE303B830D326C9600D840F2 /* gpopserver.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpopserver.cpp; sourceTree = ""; }; + EE303B840D326C9600D840F2 /* gpopserver.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gpopserver.h; sourceTree = ""; }; + EE303B850D326C9600D840F2 /* gpopserverprotocol.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpopserverprotocol.cpp; sourceTree = ""; }; + EE303B860D326C9600D840F2 /* gpopserverprotocol.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gpopserverprotocol.h; sourceTree = ""; }; + EE303B870D326C9600D840F2 /* gpopstore.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpopstore.cpp; sourceTree = ""; }; + EE303B880D326C9600D840F2 /* gpopstore.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gpopstore.h; sourceTree = ""; }; + EE303B890D326C9600D840F2 /* Makefile.am */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.am; sourceTree = ""; }; + EE303B8A0D326C9600D840F2 /* Makefile.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.in; sourceTree = ""; }; + EE303B8B0D326C9600D840F2 /* mingw.mak */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = mingw.mak; sourceTree = ""; }; + EE303B8D0D326C9600D840F2 /* gadminserver.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gadminserver.cpp; sourceTree = ""; }; + EE303B8E0D326C9600D840F2 /* gadminserver.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gadminserver.h; sourceTree = ""; }; + EE303B8F0D326C9600D840F2 /* gbase64.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gbase64.cpp; sourceTree = ""; }; + EE303B900D326C9600D840F2 /* gbase64.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gbase64.h; sourceTree = ""; }; + EE303B910D326C9600D840F2 /* gclientprotocol.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gclientprotocol.cpp; sourceTree = ""; }; + EE303B920D326C9600D840F2 /* gclientprotocol.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gclientprotocol.h; sourceTree = ""; }; + EE303B930D326C9600D840F2 /* gexecutableprocessor.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gexecutableprocessor.cpp; sourceTree = ""; }; + EE303B940D326C9600D840F2 /* gexecutableprocessor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gexecutableprocessor.h; sourceTree = ""; }; + EE303B950D326C9600D840F2 /* gexecutableverifier.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gexecutableverifier.cpp; sourceTree = ""; }; + EE303B960D326C9600D840F2 /* gexecutableverifier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gexecutableverifier.h; sourceTree = ""; }; + EE303B970D326C9600D840F2 /* gfactoryparser.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gfactoryparser.cpp; sourceTree = ""; }; + EE303B980D326C9600D840F2 /* gfactoryparser.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gfactoryparser.h; sourceTree = ""; }; + EE303B990D326C9600D840F2 /* gfilestore.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gfilestore.cpp; sourceTree = ""; }; + EE303B9A0D326C9600D840F2 /* gfilestore.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gfilestore.h; sourceTree = ""; }; + EE303B9B0D326C9600D840F2 /* ginternalverifier.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ginternalverifier.cpp; sourceTree = ""; }; + EE303B9C0D326C9600D840F2 /* ginternalverifier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ginternalverifier.h; sourceTree = ""; }; + EE303B9D0D326C9600D840F2 /* gmessagestore.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gmessagestore.cpp; sourceTree = ""; }; + EE303B9E0D326C9600D840F2 /* gmessagestore.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gmessagestore.h; sourceTree = ""; }; + EE303B9F0D326C9600D840F2 /* gmessagestore_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gmessagestore_unix.cpp; sourceTree = ""; }; + EE303BA00D326C9600D840F2 /* gmessagestore_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gmessagestore_win32.cpp; sourceTree = ""; }; + EE303BA10D326C9600D840F2 /* gnetworkprocessor.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gnetworkprocessor.cpp; sourceTree = ""; }; + EE303BA20D326C9600D840F2 /* gnetworkprocessor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gnetworkprocessor.h; sourceTree = ""; }; + EE303BA30D326C9600D840F2 /* gnetworkverifier.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gnetworkverifier.cpp; sourceTree = ""; }; + EE303BA40D326C9600D840F2 /* gnetworkverifier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gnetworkverifier.h; sourceTree = ""; }; + EE303BA50D326C9600D840F2 /* gnewfile.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gnewfile.cpp; sourceTree = ""; }; + EE303BA60D326C9600D840F2 /* gnewfile.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gnewfile.h; sourceTree = ""; }; + EE303BA70D326C9600D840F2 /* gnewmessage.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gnewmessage.cpp; sourceTree = ""; }; + EE303BA80D326C9600D840F2 /* gnewmessage.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gnewmessage.h; sourceTree = ""; }; + EE303BA90D326C9600D840F2 /* gnullprocessor.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gnullprocessor.cpp; sourceTree = ""; }; + EE303BAA0D326C9600D840F2 /* gnullprocessor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gnullprocessor.h; sourceTree = ""; }; + EE303BAB0D326C9600D840F2 /* gprocessor.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gprocessor.cpp; sourceTree = ""; }; + EE303BAC0D326C9600D840F2 /* gprocessor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gprocessor.h; sourceTree = ""; }; + EE303BAD0D326C9600D840F2 /* gprocessorfactory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gprocessorfactory.h; sourceTree = ""; }; + EE303BAE0D326C9600D840F2 /* gprocessorfactory_exec_disabled.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gprocessorfactory_exec_disabled.cpp; sourceTree = ""; }; + EE303BAF0D326C9600D840F2 /* gprocessorfactory_exec_enabled.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gprocessorfactory_exec_enabled.cpp; sourceTree = ""; }; + EE303BB00D326C9600D840F2 /* gprotocolmessage.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gprotocolmessage.cpp; sourceTree = ""; }; + EE303BB10D326C9600D840F2 /* gprotocolmessage.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gprotocolmessage.h; sourceTree = ""; }; + EE303BB20D326C9600D840F2 /* gprotocolmessageforward.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gprotocolmessageforward.cpp; sourceTree = ""; }; + EE303BB30D326C9600D840F2 /* gprotocolmessageforward.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gprotocolmessageforward.h; sourceTree = ""; }; + EE303BB40D326C9600D840F2 /* gprotocolmessagestore.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gprotocolmessagestore.cpp; sourceTree = ""; }; + EE303BB50D326C9600D840F2 /* gprotocolmessagestore.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gprotocolmessagestore.h; sourceTree = ""; }; + EE303BB60D326C9600D840F2 /* grequestclient.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = grequestclient.cpp; sourceTree = ""; }; + EE303BB70D326C9600D840F2 /* grequestclient.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = grequestclient.h; sourceTree = ""; }; + EE303BB80D326C9600D840F2 /* gsasl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gsasl.h; sourceTree = ""; }; + EE303BB90D326C9600D840F2 /* gsasl_gnu.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsasl_gnu.cpp; sourceTree = ""; }; + EE303BBA0D326C9600D840F2 /* gsasl_native.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsasl_native.cpp; sourceTree = ""; }; + EE303BBB0D326C9600D840F2 /* gsasl_none.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsasl_none.cpp; sourceTree = ""; }; + EE303BBC0D326C9600D840F2 /* gsecrets.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gsecrets.h; sourceTree = ""; }; + EE303BBD0D326C9600D840F2 /* gsecrets_full.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsecrets_full.cpp; sourceTree = ""; }; + EE303BBE0D326C9600D840F2 /* gsecrets_none.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsecrets_none.cpp; sourceTree = ""; }; + EE303BBF0D326C9600D840F2 /* gserverprotocol.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gserverprotocol.cpp; sourceTree = ""; }; + EE303BC00D326C9600D840F2 /* gserverprotocol.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gserverprotocol.h; sourceTree = ""; }; + EE303BC10D326C9600D840F2 /* gsmtp.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gsmtp.h; sourceTree = ""; }; + EE303BC20D326C9600D840F2 /* gsmtpclient.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsmtpclient.cpp; sourceTree = ""; }; + EE303BC30D326C9600D840F2 /* gsmtpclient.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gsmtpclient.h; sourceTree = ""; }; + EE303BC40D326C9600D840F2 /* gsmtpserver.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gsmtpserver.cpp; sourceTree = ""; }; + EE303BC50D326C9600D840F2 /* gsmtpserver.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gsmtpserver.h; sourceTree = ""; }; + EE303BC60D326C9600D840F2 /* gspamclient.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gspamclient.cpp; sourceTree = ""; }; + EE303BC70D326C9600D840F2 /* gspamclient.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gspamclient.h; sourceTree = ""; }; + EE303BC80D326C9600D840F2 /* gspamprocessor.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gspamprocessor.cpp; sourceTree = ""; }; + EE303BC90D326C9600D840F2 /* gspamprocessor.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gspamprocessor.h; sourceTree = ""; }; + EE303BCA0D326C9600D840F2 /* gstoredfile.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gstoredfile.cpp; sourceTree = ""; }; + EE303BCB0D326C9600D840F2 /* gstoredfile.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gstoredfile.h; sourceTree = ""; }; + EE303BCC0D326C9600D840F2 /* gstoredmessage.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gstoredmessage.cpp; sourceTree = ""; }; + EE303BCD0D326C9600D840F2 /* gstoredmessage.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gstoredmessage.h; sourceTree = ""; }; + EE303BCE0D326C9600D840F2 /* gverifier.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gverifier.cpp; sourceTree = ""; }; + EE303BCF0D326C9600D840F2 /* gverifier.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gverifier.h; sourceTree = ""; }; + EE303BD00D326C9600D840F2 /* gverifierfactory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gverifierfactory.h; sourceTree = ""; }; + EE303BD10D326C9600D840F2 /* gverifierfactory_exec_disabled.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gverifierfactory_exec_disabled.cpp; sourceTree = ""; }; + EE303BD20D326C9600D840F2 /* gverifierfactory_exec_enabled.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gverifierfactory_exec_enabled.cpp; sourceTree = ""; }; + EE303BD30D326C9600D840F2 /* gverifierstatus.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gverifierstatus.cpp; sourceTree = ""; }; + EE303BD40D326C9600D840F2 /* gverifierstatus.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gverifierstatus.h; sourceTree = ""; }; + EE303BD50D326C9600D840F2 /* Makefile.am */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.am; sourceTree = ""; }; + EE303BD60D326C9600D840F2 /* Makefile.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.in; sourceTree = ""; }; + EE303BD70D326C9600D840F2 /* mingw.mak */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = mingw.mak; sourceTree = ""; }; + EE303BD90D326C9600D840F2 /* gssl.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gssl.h; sourceTree = ""; }; + EE303BDA0D326C9600D840F2 /* gssl_none.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gssl_none.cpp; sourceTree = ""; }; + EE303BDB0D326C9600D840F2 /* gssl_openssl.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gssl_openssl.cpp; sourceTree = ""; }; + EE303BDC0D326C9600D840F2 /* Makefile.am */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.am; sourceTree = ""; }; + EE303BDD0D326C9600D840F2 /* Makefile.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.in; sourceTree = ""; }; + EE303BDE0D326C9600D840F2 /* mingw.mak */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = mingw.mak; sourceTree = ""; }; + EE303BE00D326C9600D840F2 /* boot.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = boot.cpp; sourceTree = ""; }; + EE303BE10D326C9600D840F2 /* boot.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = boot.h; sourceTree = ""; }; + EE303BE20D326C9600D840F2 /* dir.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = dir.cpp; sourceTree = ""; }; + EE303BE30D326C9600D840F2 /* dir.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = dir.h; sourceTree = ""; }; + EE303BE40D326C9600D840F2 /* dir_unix.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = dir_unix.cpp; sourceTree = ""; }; + EE303BE50D326C9600D840F2 /* dir_win32.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = dir_win32.cpp; sourceTree = ""; }; + EE303BE60D326C9600D840F2 /* emailrelay-icon.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "emailrelay-icon.png"; sourceTree = ""; }; + EE303BE70D326C9600D840F2 /* gcominit.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gcominit.h; sourceTree = ""; }; + EE303BE80D326C9600D840F2 /* gdialog.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdialog.cpp; sourceTree = ""; }; + EE303BE90D326C9600D840F2 /* gdialog.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gdialog.h; sourceTree = ""; }; + EE303BEA0D326C9600D840F2 /* glink.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = glink.cpp; sourceTree = ""; }; + EE303BEB0D326C9600D840F2 /* glink.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = glink.h; sourceTree = ""; }; + EE303BEC0D326C9600D840F2 /* gpage.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpage.cpp; sourceTree = ""; }; + EE303BED0D326C9600D840F2 /* gpage.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gpage.h; sourceTree = ""; }; + EE303BEE0D326C9600D840F2 /* guimain.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = guimain.cpp; sourceTree = ""; }; + EE303BEF0D326C9600D840F2 /* gunpack.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gunpack.cpp; sourceTree = ""; }; + EE303BF00D326C9600D840F2 /* gunpack.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gunpack.h; sourceTree = ""; }; + EE303BF10D326C9600D840F2 /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; + EE303BF20D326C9600D840F2 /* installer.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = installer.cpp; sourceTree = ""; }; + EE303BF30D326C9600D840F2 /* installer.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = installer.h; sourceTree = ""; }; + EE303BF40D326C9600D840F2 /* legal.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = legal.cpp; sourceTree = ""; }; + EE303BF50D326C9600D840F2 /* legal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = legal.h; sourceTree = ""; }; + EE303BF60D326C9600D840F2 /* mac.mak */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = mac.mak; sourceTree = ""; }; + EE303BF70D326C9600D840F2 /* Makefile.am */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.am; sourceTree = ""; }; + EE303BF80D326C9600D840F2 /* Makefile.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.in; sourceTree = ""; }; + EE303BF90D326C9600D840F2 /* mingw.mak */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = mingw.mak; sourceTree = ""; }; + EE303BFA0D326C9600D840F2 /* mock */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = mock; sourceTree = ""; }; + EE303BFB0D326C9600D840F2 /* pack.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pack.cpp; sourceTree = ""; }; + EE303BFC0D326C9600D840F2 /* pages.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = pages.cpp; sourceTree = ""; }; + EE303BFD0D326C9600D840F2 /* pages.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = pages.h; sourceTree = ""; }; + EE303BFE0D326C9600D840F2 /* qt.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = qt.h; sourceTree = ""; }; + EE303BFF0D326C9600D840F2 /* run.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = run.c; sourceTree = ""; }; + EE303C000D326C9600D840F2 /* unpack.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = unpack.c; sourceTree = ""; }; + EE303C010D326C9600D840F2 /* unpack.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = unpack.h; sourceTree = ""; }; + EE303C030D326C9600D840F2 /* admin.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = admin.h; sourceTree = ""; }; + EE303C040D326C9600D840F2 /* admin_disabled.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = admin_disabled.cpp; sourceTree = ""; }; + EE303C050D326C9600D840F2 /* admin_enabled.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = admin_enabled.cpp; sourceTree = ""; }; + EE303C060D326C9600D840F2 /* commandline.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = commandline.h; sourceTree = ""; }; + EE303C070D326C9600D840F2 /* commandline_full.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = commandline_full.cpp; sourceTree = ""; }; + EE303C080D326C9600D840F2 /* commandline_simple.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = commandline_simple.cpp; sourceTree = ""; }; + EE303C090D326C9600D840F2 /* common.dsp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = common.dsp; sourceTree = ""; }; + EE303C0A0D326C9600D840F2 /* configuration.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = configuration.cpp; sourceTree = ""; }; + EE303C0B0D326C9600D840F2 /* configuration.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = configuration.h; sourceTree = ""; }; + EE303C0C0D326C9600D840F2 /* doxygen.cfg */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = doxygen.cfg; sourceTree = ""; }; + EE303C0D0D326C9600D840F2 /* doxygen.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = doxygen.h; sourceTree = ""; }; + EE303C0E0D326C9600D840F2 /* emailrelay.dsp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = emailrelay.dsp; sourceTree = ""; }; + EE303C0F0D326C9600D840F2 /* emailrelay.rc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = emailrelay.rc; sourceTree = ""; }; + EE303C100D326C9600D840F2 /* filter.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = filter.cpp; sourceTree = ""; }; + EE303C110D326C9600D840F2 /* filter.dsp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = filter.dsp; sourceTree = ""; }; + EE303C120D326C9600D840F2 /* filter.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = filter.h; sourceTree = ""; }; + EE303C130D326C9600D840F2 /* filter_copy.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = filter_copy.cpp; sourceTree = ""; }; + EE303C140D326C9600D840F2 /* icon-32.ico */ = {isa = PBXFileReference; lastKnownFileType = image.ico; path = "icon-32.ico"; sourceTree = ""; }; + EE303C150D326C9600D840F2 /* icon2.ico */ = {isa = PBXFileReference; lastKnownFileType = image.ico; path = icon2.ico; sourceTree = ""; }; + EE303C160D326C9600D840F2 /* icon3.ico */ = {isa = PBXFileReference; lastKnownFileType = image.ico; path = icon3.ico; sourceTree = ""; }; + EE303C170D326C9600D840F2 /* icon4.ico */ = {isa = PBXFileReference; lastKnownFileType = image.ico; path = icon4.ico; sourceTree = ""; }; + EE303C180D326C9600D840F2 /* icon5.ico */ = {isa = PBXFileReference; lastKnownFileType = image.ico; path = icon5.ico; sourceTree = ""; }; + EE303C190D326C9600D840F2 /* legal.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = legal.cpp; sourceTree = ""; }; + EE303C1A0D326C9600D840F2 /* legal.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = legal.h; sourceTree = ""; }; + EE303C1B0D326C9600D840F2 /* main.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = main.cpp; sourceTree = ""; }; + EE303C1C0D326C9600D840F2 /* Makefile.am */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.am; sourceTree = ""; }; + EE303C1D0D326C9600D840F2 /* Makefile.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.in; sourceTree = ""; }; + EE303C1E0D326C9600D840F2 /* messages.mc */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = messages.mc; sourceTree = ""; }; + EE303C1F0D326C9600D840F2 /* mingw.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = mingw.c; sourceTree = ""; }; + EE303C200D326C9600D840F2 /* mingw.mak */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = mingw.mak; sourceTree = ""; }; + EE303C210D326C9700D840F2 /* news.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = news.cpp; sourceTree = ""; }; + EE303C220D326C9700D840F2 /* news.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = news.h; sourceTree = ""; }; + EE303C230D326C9700D840F2 /* output.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = output.cpp; sourceTree = ""; }; + EE303C240D326C9700D840F2 /* output.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = output.h; sourceTree = ""; }; + EE303C250D326C9700D840F2 /* passwd.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = passwd.cpp; sourceTree = ""; }; + EE303C260D326C9700D840F2 /* passwd.dsp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = passwd.dsp; sourceTree = ""; }; + EE303C270D326C9700D840F2 /* poke.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = poke.c; sourceTree = ""; }; + EE303C280D326C9700D840F2 /* poke.dsp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = poke.dsp; sourceTree = ""; }; + EE303C290D326C9700D840F2 /* resource.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = resource.h; sourceTree = ""; }; + EE303C2A0D326C9700D840F2 /* run.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = run.cpp; sourceTree = ""; }; + EE303C2B0D326C9700D840F2 /* run.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = run.h; sourceTree = ""; }; + EE303C2C0D326C9700D840F2 /* service.dsp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = service.dsp; sourceTree = ""; }; + EE303C2D0D326C9700D840F2 /* service_install.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = service_install.cpp; sourceTree = ""; }; + EE303C2E0D326C9700D840F2 /* service_install.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = service_install.h; sourceTree = ""; }; + EE303C2F0D326C9700D840F2 /* service_remove.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = service_remove.cpp; sourceTree = ""; }; + EE303C300D326C9700D840F2 /* service_remove.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = service_remove.h; sourceTree = ""; }; + EE303C310D326C9700D840F2 /* service_wrapper.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = service_wrapper.cpp; sourceTree = ""; }; + EE303C320D326C9700D840F2 /* submit.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = submit.cpp; sourceTree = ""; }; + EE303C330D326C9700D840F2 /* submit.dsp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = submit.dsp; sourceTree = ""; }; + EE303C340D326C9700D840F2 /* winapp.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = winapp.cpp; sourceTree = ""; }; + EE303C350D326C9700D840F2 /* winapp.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = winapp.h; sourceTree = ""; }; + EE303C360D326C9700D840F2 /* winform.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = winform.cpp; sourceTree = ""; }; + EE303C370D326C9700D840F2 /* winform.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = winform.h; sourceTree = ""; }; + EE303C380D326C9700D840F2 /* winmain.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = winmain.cpp; sourceTree = ""; }; + EE303C390D326C9700D840F2 /* winmenu.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = winmenu.cpp; sourceTree = ""; }; + EE303C3A0D326C9700D840F2 /* winmenu.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = winmenu.h; sourceTree = ""; }; + EE303C3B0D326C9700D840F2 /* Makefile.am */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.am; sourceTree = ""; }; + EE303C3C0D326C9700D840F2 /* Makefile.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.in; sourceTree = ""; }; + EE303C3D0D326C9700D840F2 /* mingw-common.mak */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = "mingw-common.mak"; sourceTree = ""; }; + EE303C3E0D326C9700D840F2 /* mingw.mak */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = mingw.mak; sourceTree = ""; }; + EE303C400D326C9700D840F2 /* gappbase.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gappbase.cpp; sourceTree = ""; }; + EE303C410D326C9700D840F2 /* gappbase.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gappbase.h; sourceTree = ""; }; + EE303C420D326C9700D840F2 /* gappinst.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gappinst.cpp; sourceTree = ""; }; + EE303C430D326C9700D840F2 /* gappinst.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gappinst.h; sourceTree = ""; }; + EE303C440D326C9700D840F2 /* gcontrol.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gcontrol.cpp; sourceTree = ""; }; + EE303C450D326C9700D840F2 /* gcontrol.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gcontrol.h; sourceTree = ""; }; + EE303C460D326C9700D840F2 /* gcracker.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gcracker.cpp; sourceTree = ""; }; + EE303C470D326C9700D840F2 /* gcracker.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gcracker.h; sourceTree = ""; }; + EE303C480D326C9700D840F2 /* gdc.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdc.cpp; sourceTree = ""; }; + EE303C490D326C9700D840F2 /* gdc.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gdc.h; sourceTree = ""; }; + EE303C4A0D326C9700D840F2 /* gdialog.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gdialog.cpp; sourceTree = ""; }; + EE303C4B0D326C9700D840F2 /* gdialog.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gdialog.h; sourceTree = ""; }; + EE303C4C0D326C9700D840F2 /* gpump.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpump.cpp; sourceTree = ""; }; + EE303C4D0D326C9700D840F2 /* gpump.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gpump.h; sourceTree = ""; }; + EE303C4E0D326C9700D840F2 /* gpump_dialog.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gpump_dialog.cpp; sourceTree = ""; }; + EE303C4F0D326C9700D840F2 /* gscmap.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gscmap.cpp; sourceTree = ""; }; + EE303C500D326C9700D840F2 /* gscmap.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gscmap.h; sourceTree = ""; }; + EE303C510D326C9700D840F2 /* gsize.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gsize.h; sourceTree = ""; }; + EE303C520D326C9700D840F2 /* gtray.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gtray.cpp; sourceTree = ""; }; + EE303C530D326C9700D840F2 /* gtray.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gtray.h; sourceTree = ""; }; + EE303C540D326C9700D840F2 /* gwinbase.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gwinbase.cpp; sourceTree = ""; }; + EE303C550D326C9700D840F2 /* gwinbase.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gwinbase.h; sourceTree = ""; }; + EE303C560D326C9700D840F2 /* gwindow.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gwindow.cpp; sourceTree = ""; }; + EE303C570D326C9700D840F2 /* gwindow.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gwindow.h; sourceTree = ""; }; + EE303C580D326C9700D840F2 /* gwinhid.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = gwinhid.cpp; sourceTree = ""; }; + EE303C590D326C9700D840F2 /* gwinhid.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = gwinhid.h; sourceTree = ""; }; + EE303C5A0D326C9700D840F2 /* Makefile.am */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.am; sourceTree = ""; }; + EE303C5B0D326C9700D840F2 /* Makefile.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.in; sourceTree = ""; }; + EE303C5C0D326C9700D840F2 /* mingw.mak */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.make; path = mingw.mak; sourceTree = ""; }; + EE303D340D32714D00D840F2 /* libglib.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = libglib.a; sourceTree = BUILT_PRODUCTS_DIR; }; + EE303DE70D3298F600D840F2 /* libgnet.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = libgnet.a; sourceTree = BUILT_PRODUCTS_DIR; }; + EE303E120D329BAA00D840F2 /* libgpop.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = libgpop.a; sourceTree = BUILT_PRODUCTS_DIR; }; + EE303E230D329BFF00D840F2 /* libgsmtp.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = libgsmtp.a; sourceTree = BUILT_PRODUCTS_DIR; }; + EE303E4F0D329D8F00D840F2 /* libgssl.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = libgssl.a; sourceTree = BUILT_PRODUCTS_DIR; }; + EE303EA90D366E5500D840F2 /* auth.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = auth.png; sourceTree = ""; }; + EE303EAA0D366E5500D840F2 /* developer.txt */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = developer.txt; sourceTree = ""; }; + EE303EAB0D366E5500D840F2 /* doxygen_header.html */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.html; path = doxygen_header.html; sourceTree = ""; }; + EE303EAC0D366E5500D840F2 /* doxygen_missing.html */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.html; path = doxygen_missing.html; sourceTree = ""; }; + EE303EAD0D366E5500D840F2 /* emailrelay-filter-copy.1 */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.man; path = "emailrelay-filter-copy.1"; sourceTree = ""; }; + EE303EAE0D366E5500D840F2 /* emailrelay-man.html */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.html; path = "emailrelay-man.html"; sourceTree = ""; }; + EE303EAF0D366E5500D840F2 /* emailrelay-passwd.1 */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.man; path = "emailrelay-passwd.1"; sourceTree = ""; }; + EE303EB00D366E5500D840F2 /* emailrelay-poke.1 */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.man; path = "emailrelay-poke.1"; sourceTree = ""; }; + EE303EB10D366E5500D840F2 /* emailrelay-submit.1 */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.man; path = "emailrelay-submit.1"; sourceTree = ""; }; + EE303EB20D366E5500D840F2 /* emailrelay.1 */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.man; path = emailrelay.1; sourceTree = ""; }; + EE303EB30D366E5500D840F2 /* emailrelay.css */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.css; path = emailrelay.css; sourceTree = ""; }; + EE303EB40D366E5500D840F2 /* gnet-classes.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "gnet-classes.png"; sourceTree = ""; }; + EE303EB50D366E5500D840F2 /* gnet-client.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "gnet-client.png"; sourceTree = ""; }; + EE303EB60D366E5500D840F2 /* gsmtp-classes.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "gsmtp-classes.png"; sourceTree = ""; }; + EE303EB70D366E5500D840F2 /* gsmtp-serverprotocol.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "gsmtp-serverprotocol.png"; sourceTree = ""; }; + EE303EB80D366E5500D840F2 /* index.html */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.html; path = index.html; sourceTree = ""; }; + EE303EB90D366E5500D840F2 /* Makefile.am */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.am; sourceTree = ""; }; + EE303EBA0D366E5500D840F2 /* Makefile.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = Makefile.in; sourceTree = ""; }; + EE303EBB0D366E5500D840F2 /* reference.txt */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = reference.txt; sourceTree = ""; }; + EE303EBC0D366E5500D840F2 /* sequence-3.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "sequence-3.png"; sourceTree = ""; }; + EE303EBD0D366E5500D840F2 /* userguide.txt */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = userguide.txt; sourceTree = ""; }; + EE303EBE0D366E5500D840F2 /* windows.txt */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; path = windows.txt; sourceTree = ""; }; + EE99183F0D91664E00FB06D5 /* emailrelay-filter-copy */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = "emailrelay-filter-copy"; sourceTree = BUILT_PRODUCTS_DIR; }; + EE9918410D91664F00FB06D5 /* Info copy.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = "Info copy.plist"; sourceTree = ""; }; + EE9918580D91693000FB06D5 /* emailrelay-start */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = "emailrelay-start"; sourceTree = BUILT_PRODUCTS_DIR; }; + EE99185A0D91693000FB06D5 /* Info copy 2.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = "Info copy 2.plist"; sourceTree = ""; }; + EE9918680D91695000FB06D5 /* emailrelay-passwd */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = "emailrelay-passwd"; sourceTree = BUILT_PRODUCTS_DIR; }; + EE99186A0D91695000FB06D5 /* Info copy 3.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = "Info copy 3.plist"; sourceTree = ""; }; + EE9918780D91697900FB06D5 /* emailrelay-poke */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = "emailrelay-poke"; sourceTree = BUILT_PRODUCTS_DIR; }; + EE99187A0D91697900FB06D5 /* Info copy 4.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = "Info copy 4.plist"; sourceTree = ""; }; + EE9918880D91698A00FB06D5 /* emailrelay-submit */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = "emailrelay-submit"; sourceTree = BUILT_PRODUCTS_DIR; }; + EE99188A0D91698A00FB06D5 /* Info copy 5.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = "Info copy 5.plist"; sourceTree = ""; }; + EE99188B0D9169F700FB06D5 /* start.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = start.cpp; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 8DD76F660486A84900D96B5E /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303D320D32714D00D840F2 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303DE50D3298F600D840F2 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303E100D329BAA00D840F2 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303E210D329BFF00D840F2 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303E4D0D329D8F00D840F2 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE99183A0D91664E00FB06D5 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE9918530D91693000FB06D5 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE9918630D91695000FB06D5 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE9918730D91697900FB06D5 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE9918830D91698A00FB06D5 /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 08FB7794FE84155DC02AAC07 /* emailrelay */ = { + isa = PBXGroup; + children = ( + EE303EA80D366E5500D840F2 /* doc */, + EE303AD20D326C9600D840F2 /* src */, + 08FB7795FE84155DC02AAC07 /* Source */, + C6859E8C029090F304C91782 /* Documentation */, + 1AB674ADFE9D54B511CA2CBB /* Products */, + EE9918410D91664F00FB06D5 /* Info copy.plist */, + EE99185A0D91693000FB06D5 /* Info copy 2.plist */, + EE99186A0D91695000FB06D5 /* Info copy 3.plist */, + EE99187A0D91697900FB06D5 /* Info copy 4.plist */, + EE99188A0D91698A00FB06D5 /* Info copy 5.plist */, + ); + name = emailrelay; + sourceTree = ""; + }; + 08FB7795FE84155DC02AAC07 /* Source */ = { + isa = PBXGroup; + children = ( + ); + name = Source; + sourceTree = ""; + }; + 1AB674ADFE9D54B511CA2CBB /* Products */ = { + isa = PBXGroup; + children = ( + 8DD76F6C0486A84900D96B5E /* emailrelay */, + EE303D340D32714D00D840F2 /* libglib.a */, + EE303DE70D3298F600D840F2 /* libgnet.a */, + EE303E120D329BAA00D840F2 /* libgpop.a */, + EE303E230D329BFF00D840F2 /* libgsmtp.a */, + EE303E4F0D329D8F00D840F2 /* libgssl.a */, + EE99183F0D91664E00FB06D5 /* emailrelay-filter-copy */, + EE9918580D91693000FB06D5 /* emailrelay-start */, + EE9918680D91695000FB06D5 /* emailrelay-passwd */, + EE9918780D91697900FB06D5 /* emailrelay-poke */, + EE9918880D91698A00FB06D5 /* emailrelay-submit */, + ); + name = Products; + sourceTree = ""; + }; + C6859E8C029090F304C91782 /* Documentation */ = { + isa = PBXGroup; + children = ( + ); + name = Documentation; + sourceTree = ""; + }; + EE303AD20D326C9600D840F2 /* src */ = { + isa = PBXGroup; + children = ( + EE303AD30D326C9600D840F2 /* emailrelay.dsw */, + EE303AD40D326C9600D840F2 /* fragments */, + EE303AD80D326C9600D840F2 /* glib */, + EE303B370D326C9600D840F2 /* gnet */, + EE303B7A0D326C9600D840F2 /* gpop */, + EE303B8C0D326C9600D840F2 /* gsmtp */, + EE303BD80D326C9600D840F2 /* gssl */, + EE303BDF0D326C9600D840F2 /* gui */, + EE303C020D326C9600D840F2 /* main */, + EE303C3B0D326C9700D840F2 /* Makefile.am */, + EE303C3C0D326C9700D840F2 /* Makefile.in */, + EE303C3D0D326C9700D840F2 /* mingw-common.mak */, + EE303C3E0D326C9700D840F2 /* mingw.mak */, + EE303C3F0D326C9700D840F2 /* win32 */, + ); + path = src; + sourceTree = ""; + }; + EE303AD40D326C9600D840F2 /* fragments */ = { + isa = PBXGroup; + children = ( + EE303AD50D326C9600D840F2 /* empty.cpp */, + EE303AD60D326C9600D840F2 /* Makefile.am */, + EE303AD70D326C9600D840F2 /* Makefile.in */, + ); + path = fragments; + sourceTree = ""; + }; + EE303AD80D326C9600D840F2 /* glib */ = { + isa = PBXGroup; + children = ( + EE303AD90D326C9600D840F2 /* garg.cpp */, + EE303ADA0D326C9600D840F2 /* garg.h */, + EE303ADB0D326C9600D840F2 /* garg_unix.cpp */, + EE303ADC0D326C9600D840F2 /* garg_win32.cpp */, + EE303ADD0D326C9600D840F2 /* gassert.h */, + EE303ADE0D326C9600D840F2 /* gcleanup.h */, + EE303ADF0D326C9600D840F2 /* gcleanup_unix.cpp */, + EE303AE00D326C9600D840F2 /* gcleanup_win32.cpp */, + EE303AE10D326C9600D840F2 /* gconvert.h */, + EE303AE20D326C9600D840F2 /* gcounter.cpp */, + EE303AE30D326C9600D840F2 /* gcounter.h */, + EE303AE40D326C9600D840F2 /* gdaemon.h */, + EE303AE50D326C9600D840F2 /* gdaemon_unix.cpp */, + EE303AE60D326C9600D840F2 /* gdaemon_win32.cpp */, + EE303AE70D326C9600D840F2 /* gdate.cpp */, + EE303AE80D326C9600D840F2 /* gdate.h */, + EE303AE90D326C9600D840F2 /* gdatetime.cpp */, + EE303AEA0D326C9600D840F2 /* gdatetime.h */, + EE303AEB0D326C9600D840F2 /* gdatetime_unix.cpp */, + EE303AEC0D326C9600D840F2 /* gdatetime_win32.cpp */, + EE303AED0D326C9600D840F2 /* gdebug.h */, + EE303AEE0D326C9600D840F2 /* gdef.h */, + EE303AEF0D326C9600D840F2 /* gdirectory.cpp */, + EE303AF00D326C9600D840F2 /* gdirectory.h */, + EE303AF10D326C9600D840F2 /* gdirectory_unix.cpp */, + EE303AF20D326C9600D840F2 /* gdirectory_unix_glob.cpp */, + EE303AF30D326C9600D840F2 /* gdirectory_unix_noglob.cpp */, + EE303AF40D326C9600D840F2 /* gdirectory_win32.cpp */, + EE303AF50D326C9600D840F2 /* gexception.cpp */, + EE303AF60D326C9600D840F2 /* gexception.h */, + EE303AF70D326C9600D840F2 /* gexecutable.cpp */, + EE303AF80D326C9600D840F2 /* gexecutable.h */, + EE303AF90D326C9600D840F2 /* gexecutable_unix.cpp */, + EE303AFA0D326C9600D840F2 /* gexecutable_win32.cpp */, + EE303AFB0D326C9600D840F2 /* gfile.cpp */, + EE303AFC0D326C9600D840F2 /* gfile.h */, + EE303AFD0D326C9600D840F2 /* gfile_unix.cpp */, + EE303AFE0D326C9600D840F2 /* gfile_win32.cpp */, + EE303AFF0D326C9600D840F2 /* gfs.h */, + EE303B000D326C9600D840F2 /* gfs_unix.cpp */, + EE303B010D326C9600D840F2 /* gfs_win32.cpp */, + EE303B020D326C9600D840F2 /* ggetopt.cpp */, + EE303B030D326C9600D840F2 /* ggetopt.h */, + EE303B040D326C9600D840F2 /* ghostname.h */, + EE303B050D326C9600D840F2 /* ghostname_unix.cpp */, + EE303B060D326C9600D840F2 /* ghostname_win32.cpp */, + EE303B070D326C9600D840F2 /* gidentity.h */, + EE303B080D326C9600D840F2 /* gidentity_disabled.cpp */, + EE303B090D326C9600D840F2 /* gidentity_unix.cpp */, + EE303B0A0D326C9600D840F2 /* gidentity_win32.cpp */, + EE303B0B0D326C9600D840F2 /* glimits.h */, + EE303B0C0D326C9600D840F2 /* glog.cpp */, + EE303B0D0D326C9600D840F2 /* glog.h */, + EE303B0E0D326C9600D840F2 /* glogoutput.cpp */, + EE303B0F0D326C9600D840F2 /* glogoutput.h */, + EE303B100D326C9600D840F2 /* glogoutput_unix.cpp */, + EE303B110D326C9600D840F2 /* glogoutput_win32.cpp */, + EE303B120D326C9600D840F2 /* gmd5.h */, + EE303B130D326C9600D840F2 /* gmd5_native.cpp */, + EE303B140D326C9600D840F2 /* gmemory.h */, + EE303B150D326C9600D840F2 /* gnewprocess.h */, + EE303B160D326C9600D840F2 /* gnewprocess_unix_exec_disabled.cpp */, + EE303B170D326C9600D840F2 /* gnewprocess_unix_exec_enabled.cpp */, + EE303B180D326C9600D840F2 /* gnewprocess_win32.cpp */, + EE303B190D326C9600D840F2 /* gnoncopyable.h */, + EE303B1A0D326C9600D840F2 /* gpath.cpp */, + EE303B1B0D326C9600D840F2 /* gpath.h */, + EE303B1C0D326C9600D840F2 /* gpidfile.cpp */, + EE303B1D0D326C9600D840F2 /* gpidfile.h */, + EE303B1E0D326C9600D840F2 /* gprocess.h */, + EE303B1F0D326C9600D840F2 /* gprocess_unix.cpp */, + EE303B200D326C9600D840F2 /* gprocess_win32.cpp */, + EE303B210D326C9600D840F2 /* groot.cpp */, + EE303B220D326C9600D840F2 /* groot.h */, + EE303B230D326C9600D840F2 /* gsetter.h */, + EE303B240D326C9600D840F2 /* gsignalsafe.h */, + EE303B250D326C9600D840F2 /* gsleep.h */, + EE303B260D326C9600D840F2 /* gslot.cpp */, + EE303B270D326C9600D840F2 /* gslot.h */, + EE303B280D326C9600D840F2 /* gstatemachine.h */, + EE303B290D326C9600D840F2 /* gstr.cpp */, + EE303B2A0D326C9600D840F2 /* gstr.h */, + EE303B2B0D326C9600D840F2 /* gstrings.h */, + EE303B2C0D326C9600D840F2 /* gtest.cpp */, + EE303B2D0D326C9600D840F2 /* gtest.h */, + EE303B2E0D326C9600D840F2 /* gtime.cpp */, + EE303B2F0D326C9600D840F2 /* gtime.h */, + EE303B300D326C9600D840F2 /* gxtext.cpp */, + EE303B310D326C9600D840F2 /* gxtext.h */, + EE303B320D326C9600D840F2 /* Makefile.am */, + EE303B330D326C9600D840F2 /* Makefile.in */, + EE303B340D326C9600D840F2 /* md5.cpp */, + EE303B350D326C9600D840F2 /* md5.h */, + EE303B360D326C9600D840F2 /* mingw.mak */, + ); + path = glib; + sourceTree = ""; + }; + EE303B370D326C9600D840F2 /* gnet */ = { + isa = PBXGroup; + children = ( + EE303B380D326C9600D840F2 /* gaddress.h */, + EE303B390D326C9600D840F2 /* gaddress_ip.cpp */, + EE303B3A0D326C9600D840F2 /* gaddress_ipv4.cpp */, + EE303B3B0D326C9600D840F2 /* gaddress_ipv6.cpp */, + EE303B3C0D326C9600D840F2 /* gbufferedserverpeer.cpp */, + EE303B3D0D326C9600D840F2 /* gbufferedserverpeer.h */, + EE303B3E0D326C9600D840F2 /* gclient.cpp */, + EE303B3F0D326C9600D840F2 /* gclient.h */, + EE303B400D326C9600D840F2 /* gclientptr.h */, + EE303B410D326C9600D840F2 /* gconnection.cpp */, + EE303B420D326C9600D840F2 /* gconnection.h */, + EE303B430D326C9600D840F2 /* gdescriptor.h */, + EE303B440D326C9600D840F2 /* gdescriptor_unix.cpp */, + EE303B450D326C9600D840F2 /* gdescriptor_win32.cpp */, + EE303B460D326C9600D840F2 /* gevent.h */, + EE303B470D326C9600D840F2 /* geventhandler.cpp */, + EE303B480D326C9600D840F2 /* geventhandler.h */, + EE303B490D326C9600D840F2 /* geventloop.cpp */, + EE303B4A0D326C9600D840F2 /* geventloop.h */, + EE303B4B0D326C9600D840F2 /* geventloop_unix.cpp */, + EE303B4C0D326C9600D840F2 /* geventloop_win32.cpp */, + EE303B4D0D326C9600D840F2 /* gheapclient.cpp */, + EE303B4E0D326C9600D840F2 /* gheapclient.h */, + EE303B4F0D326C9600D840F2 /* glinebuffer.cpp */, + EE303B500D326C9600D840F2 /* glinebuffer.h */, + EE303B510D326C9600D840F2 /* glocal.cpp */, + EE303B520D326C9600D840F2 /* glocal.h */, + EE303B530D326C9600D840F2 /* glocal_dns_disabled.cpp */, + EE303B540D326C9600D840F2 /* glocal_unix.cpp */, + EE303B550D326C9600D840F2 /* glocal_win32.cpp */, + EE303B560D326C9600D840F2 /* gmonitor.cpp */, + EE303B570D326C9600D840F2 /* gmonitor.h */, + EE303B580D326C9600D840F2 /* gmultiserver.cpp */, + EE303B590D326C9600D840F2 /* gmultiserver.h */, + EE303B5A0D326C9600D840F2 /* gnet.h */, + EE303B5B0D326C9600D840F2 /* grequest.cpp */, + EE303B5C0D326C9600D840F2 /* grequest.h */, + EE303B5D0D326C9600D840F2 /* gresolver.cpp */, + EE303B5E0D326C9600D840F2 /* gresolver.h */, + EE303B5F0D326C9600D840F2 /* gresolver_dns_disabled.cpp */, + EE303B600D326C9600D840F2 /* gresolver_ip.cpp */, + EE303B610D326C9600D840F2 /* gresolver_ipv4.cpp */, + EE303B620D326C9600D840F2 /* gresolver_ipv6.cpp */, + EE303B630D326C9600D840F2 /* gresolver_unix.cpp */, + EE303B640D326C9600D840F2 /* gresolver_win32.cpp */, + EE303B650D326C9600D840F2 /* gresolverinfo.cpp */, + EE303B660D326C9600D840F2 /* gresolverinfo.h */, + EE303B670D326C9600D840F2 /* gserver.cpp */, + EE303B680D326C9600D840F2 /* gserver.h */, + EE303B690D326C9600D840F2 /* gsimpleclient.cpp */, + EE303B6A0D326C9600D840F2 /* gsimpleclient.h */, + EE303B6B0D326C9600D840F2 /* gsimpleclient_unix.cpp */, + EE303B6C0D326C9600D840F2 /* gsimpleclient_win32.cpp */, + EE303B6D0D326C9600D840F2 /* gsocket.cpp */, + EE303B6E0D326C9600D840F2 /* gsocket.h */, + EE303B6F0D326C9600D840F2 /* gsocket_unix.cpp */, + EE303B700D326C9600D840F2 /* gsocket_win32.cpp */, + EE303B710D326C9600D840F2 /* gsocketprotocol.cpp */, + EE303B720D326C9600D840F2 /* gsocketprotocol.h */, + EE303B730D326C9600D840F2 /* gtimer.cpp */, + EE303B740D326C9600D840F2 /* gtimer.h */, + EE303B750D326C9600D840F2 /* gtimerlist.cpp */, + EE303B760D326C9600D840F2 /* gtimerlist.h */, + EE303B770D326C9600D840F2 /* Makefile.am */, + EE303B780D326C9600D840F2 /* Makefile.in */, + EE303B790D326C9600D840F2 /* mingw.mak */, + ); + path = gnet; + sourceTree = ""; + }; + EE303B7A0D326C9600D840F2 /* gpop */ = { + isa = PBXGroup; + children = ( + EE303B7B0D326C9600D840F2 /* gpop.h */, + EE303B7C0D326C9600D840F2 /* gpop_disabled.cpp */, + EE303B7D0D326C9600D840F2 /* gpopauth.cpp */, + EE303B7E0D326C9600D840F2 /* gpopauth.h */, + EE303B7F0D326C9600D840F2 /* gpopsecrets.cpp */, + EE303B800D326C9600D840F2 /* gpopsecrets.h */, + EE303B810D326C9600D840F2 /* gpopsecrets_unix.cpp */, + EE303B820D326C9600D840F2 /* gpopsecrets_win32.cpp */, + EE303B830D326C9600D840F2 /* gpopserver.cpp */, + EE303B840D326C9600D840F2 /* gpopserver.h */, + EE303B850D326C9600D840F2 /* gpopserverprotocol.cpp */, + EE303B860D326C9600D840F2 /* gpopserverprotocol.h */, + EE303B870D326C9600D840F2 /* gpopstore.cpp */, + EE303B880D326C9600D840F2 /* gpopstore.h */, + EE303B890D326C9600D840F2 /* Makefile.am */, + EE303B8A0D326C9600D840F2 /* Makefile.in */, + EE303B8B0D326C9600D840F2 /* mingw.mak */, + ); + path = gpop; + sourceTree = ""; + }; + EE303B8C0D326C9600D840F2 /* gsmtp */ = { + isa = PBXGroup; + children = ( + EE303B8D0D326C9600D840F2 /* gadminserver.cpp */, + EE303B8E0D326C9600D840F2 /* gadminserver.h */, + EE303B8F0D326C9600D840F2 /* gbase64.cpp */, + EE303B900D326C9600D840F2 /* gbase64.h */, + EE303B910D326C9600D840F2 /* gclientprotocol.cpp */, + EE303B920D326C9600D840F2 /* gclientprotocol.h */, + EE303B930D326C9600D840F2 /* gexecutableprocessor.cpp */, + EE303B940D326C9600D840F2 /* gexecutableprocessor.h */, + EE303B950D326C9600D840F2 /* gexecutableverifier.cpp */, + EE303B960D326C9600D840F2 /* gexecutableverifier.h */, + EE303B970D326C9600D840F2 /* gfactoryparser.cpp */, + EE303B980D326C9600D840F2 /* gfactoryparser.h */, + EE303B990D326C9600D840F2 /* gfilestore.cpp */, + EE303B9A0D326C9600D840F2 /* gfilestore.h */, + EE303B9B0D326C9600D840F2 /* ginternalverifier.cpp */, + EE303B9C0D326C9600D840F2 /* ginternalverifier.h */, + EE303B9D0D326C9600D840F2 /* gmessagestore.cpp */, + EE303B9E0D326C9600D840F2 /* gmessagestore.h */, + EE303B9F0D326C9600D840F2 /* gmessagestore_unix.cpp */, + EE303BA00D326C9600D840F2 /* gmessagestore_win32.cpp */, + EE303BA10D326C9600D840F2 /* gnetworkprocessor.cpp */, + EE303BA20D326C9600D840F2 /* gnetworkprocessor.h */, + EE303BA30D326C9600D840F2 /* gnetworkverifier.cpp */, + EE303BA40D326C9600D840F2 /* gnetworkverifier.h */, + EE303BA50D326C9600D840F2 /* gnewfile.cpp */, + EE303BA60D326C9600D840F2 /* gnewfile.h */, + EE303BA70D326C9600D840F2 /* gnewmessage.cpp */, + EE303BA80D326C9600D840F2 /* gnewmessage.h */, + EE303BA90D326C9600D840F2 /* gnullprocessor.cpp */, + EE303BAA0D326C9600D840F2 /* gnullprocessor.h */, + EE303BAB0D326C9600D840F2 /* gprocessor.cpp */, + EE303BAC0D326C9600D840F2 /* gprocessor.h */, + EE303BAD0D326C9600D840F2 /* gprocessorfactory.h */, + EE303BAE0D326C9600D840F2 /* gprocessorfactory_exec_disabled.cpp */, + EE303BAF0D326C9600D840F2 /* gprocessorfactory_exec_enabled.cpp */, + EE303BB00D326C9600D840F2 /* gprotocolmessage.cpp */, + EE303BB10D326C9600D840F2 /* gprotocolmessage.h */, + EE303BB20D326C9600D840F2 /* gprotocolmessageforward.cpp */, + EE303BB30D326C9600D840F2 /* gprotocolmessageforward.h */, + EE303BB40D326C9600D840F2 /* gprotocolmessagestore.cpp */, + EE303BB50D326C9600D840F2 /* gprotocolmessagestore.h */, + EE303BB60D326C9600D840F2 /* grequestclient.cpp */, + EE303BB70D326C9600D840F2 /* grequestclient.h */, + EE303BB80D326C9600D840F2 /* gsasl.h */, + EE303BB90D326C9600D840F2 /* gsasl_gnu.cpp */, + EE303BBA0D326C9600D840F2 /* gsasl_native.cpp */, + EE303BBB0D326C9600D840F2 /* gsasl_none.cpp */, + EE303BBC0D326C9600D840F2 /* gsecrets.h */, + EE303BBD0D326C9600D840F2 /* gsecrets_full.cpp */, + EE303BBE0D326C9600D840F2 /* gsecrets_none.cpp */, + EE303BBF0D326C9600D840F2 /* gserverprotocol.cpp */, + EE303BC00D326C9600D840F2 /* gserverprotocol.h */, + EE303BC10D326C9600D840F2 /* gsmtp.h */, + EE303BC20D326C9600D840F2 /* gsmtpclient.cpp */, + EE303BC30D326C9600D840F2 /* gsmtpclient.h */, + EE303BC40D326C9600D840F2 /* gsmtpserver.cpp */, + EE303BC50D326C9600D840F2 /* gsmtpserver.h */, + EE303BC60D326C9600D840F2 /* gspamclient.cpp */, + EE303BC70D326C9600D840F2 /* gspamclient.h */, + EE303BC80D326C9600D840F2 /* gspamprocessor.cpp */, + EE303BC90D326C9600D840F2 /* gspamprocessor.h */, + EE303BCA0D326C9600D840F2 /* gstoredfile.cpp */, + EE303BCB0D326C9600D840F2 /* gstoredfile.h */, + EE303BCC0D326C9600D840F2 /* gstoredmessage.cpp */, + EE303BCD0D326C9600D840F2 /* gstoredmessage.h */, + EE303BCE0D326C9600D840F2 /* gverifier.cpp */, + EE303BCF0D326C9600D840F2 /* gverifier.h */, + EE303BD00D326C9600D840F2 /* gverifierfactory.h */, + EE303BD10D326C9600D840F2 /* gverifierfactory_exec_disabled.cpp */, + EE303BD20D326C9600D840F2 /* gverifierfactory_exec_enabled.cpp */, + EE303BD30D326C9600D840F2 /* gverifierstatus.cpp */, + EE303BD40D326C9600D840F2 /* gverifierstatus.h */, + EE303BD50D326C9600D840F2 /* Makefile.am */, + EE303BD60D326C9600D840F2 /* Makefile.in */, + EE303BD70D326C9600D840F2 /* mingw.mak */, + ); + path = gsmtp; + sourceTree = ""; + }; + EE303BD80D326C9600D840F2 /* gssl */ = { + isa = PBXGroup; + children = ( + EE303BD90D326C9600D840F2 /* gssl.h */, + EE303BDA0D326C9600D840F2 /* gssl_none.cpp */, + EE303BDB0D326C9600D840F2 /* gssl_openssl.cpp */, + EE303BDC0D326C9600D840F2 /* Makefile.am */, + EE303BDD0D326C9600D840F2 /* Makefile.in */, + EE303BDE0D326C9600D840F2 /* mingw.mak */, + ); + path = gssl; + sourceTree = ""; + }; + EE303BDF0D326C9600D840F2 /* gui */ = { + isa = PBXGroup; + children = ( + EE303BE00D326C9600D840F2 /* boot.cpp */, + EE303BE10D326C9600D840F2 /* boot.h */, + EE303BE20D326C9600D840F2 /* dir.cpp */, + EE303BE30D326C9600D840F2 /* dir.h */, + EE303BE40D326C9600D840F2 /* dir_unix.cpp */, + EE303BE50D326C9600D840F2 /* dir_win32.cpp */, + EE303BE60D326C9600D840F2 /* emailrelay-icon.png */, + EE303BE70D326C9600D840F2 /* gcominit.h */, + EE303BE80D326C9600D840F2 /* gdialog.cpp */, + EE303BE90D326C9600D840F2 /* gdialog.h */, + EE303BEA0D326C9600D840F2 /* glink.cpp */, + EE303BEB0D326C9600D840F2 /* glink.h */, + EE303BEC0D326C9600D840F2 /* gpage.cpp */, + EE303BED0D326C9600D840F2 /* gpage.h */, + EE303BEE0D326C9600D840F2 /* guimain.cpp */, + EE303BEF0D326C9600D840F2 /* gunpack.cpp */, + EE303BF00D326C9600D840F2 /* gunpack.h */, + EE303BF10D326C9600D840F2 /* Info.plist */, + EE303BF20D326C9600D840F2 /* installer.cpp */, + EE303BF30D326C9600D840F2 /* installer.h */, + EE303BF40D326C9600D840F2 /* legal.cpp */, + EE303BF50D326C9600D840F2 /* legal.h */, + EE303BF60D326C9600D840F2 /* mac.mak */, + EE303BF70D326C9600D840F2 /* Makefile.am */, + EE303BF80D326C9600D840F2 /* Makefile.in */, + EE303BF90D326C9600D840F2 /* mingw.mak */, + EE303BFA0D326C9600D840F2 /* mock */, + EE303BFB0D326C9600D840F2 /* pack.cpp */, + EE303BFC0D326C9600D840F2 /* pages.cpp */, + EE303BFD0D326C9600D840F2 /* pages.h */, + EE303BFE0D326C9600D840F2 /* qt.h */, + EE303BFF0D326C9600D840F2 /* run.c */, + EE303C000D326C9600D840F2 /* unpack.c */, + EE303C010D326C9600D840F2 /* unpack.h */, + ); + path = gui; + sourceTree = ""; + }; + EE303C020D326C9600D840F2 /* main */ = { + isa = PBXGroup; + children = ( + EE99188B0D9169F700FB06D5 /* start.cpp */, + EE303C030D326C9600D840F2 /* admin.h */, + EE303C040D326C9600D840F2 /* admin_disabled.cpp */, + EE303C050D326C9600D840F2 /* admin_enabled.cpp */, + EE303C060D326C9600D840F2 /* commandline.h */, + EE303C070D326C9600D840F2 /* commandline_full.cpp */, + EE303C080D326C9600D840F2 /* commandline_simple.cpp */, + EE303C090D326C9600D840F2 /* common.dsp */, + EE303C0A0D326C9600D840F2 /* configuration.cpp */, + EE303C0B0D326C9600D840F2 /* configuration.h */, + EE303C0C0D326C9600D840F2 /* doxygen.cfg */, + EE303C0D0D326C9600D840F2 /* doxygen.h */, + EE303C0E0D326C9600D840F2 /* emailrelay.dsp */, + EE303C0F0D326C9600D840F2 /* emailrelay.rc */, + EE303C100D326C9600D840F2 /* filter.cpp */, + EE303C110D326C9600D840F2 /* filter.dsp */, + EE303C120D326C9600D840F2 /* filter.h */, + EE303C130D326C9600D840F2 /* filter_copy.cpp */, + EE303C140D326C9600D840F2 /* icon-32.ico */, + EE303C150D326C9600D840F2 /* icon2.ico */, + EE303C160D326C9600D840F2 /* icon3.ico */, + EE303C170D326C9600D840F2 /* icon4.ico */, + EE303C180D326C9600D840F2 /* icon5.ico */, + EE303C190D326C9600D840F2 /* legal.cpp */, + EE303C1A0D326C9600D840F2 /* legal.h */, + EE303C1B0D326C9600D840F2 /* main.cpp */, + EE303C1C0D326C9600D840F2 /* Makefile.am */, + EE303C1D0D326C9600D840F2 /* Makefile.in */, + EE303C1E0D326C9600D840F2 /* messages.mc */, + EE303C1F0D326C9600D840F2 /* mingw.c */, + EE303C200D326C9600D840F2 /* mingw.mak */, + EE303C210D326C9700D840F2 /* news.cpp */, + EE303C220D326C9700D840F2 /* news.h */, + EE303C230D326C9700D840F2 /* output.cpp */, + EE303C240D326C9700D840F2 /* output.h */, + EE303C250D326C9700D840F2 /* passwd.cpp */, + EE303C260D326C9700D840F2 /* passwd.dsp */, + EE303C270D326C9700D840F2 /* poke.c */, + EE303C280D326C9700D840F2 /* poke.dsp */, + EE303C290D326C9700D840F2 /* resource.h */, + EE303C2A0D326C9700D840F2 /* run.cpp */, + EE303C2B0D326C9700D840F2 /* run.h */, + EE303C2C0D326C9700D840F2 /* service.dsp */, + EE303C2D0D326C9700D840F2 /* service_install.cpp */, + EE303C2E0D326C9700D840F2 /* service_install.h */, + EE303C2F0D326C9700D840F2 /* service_remove.cpp */, + EE303C300D326C9700D840F2 /* service_remove.h */, + EE303C310D326C9700D840F2 /* service_wrapper.cpp */, + EE303C320D326C9700D840F2 /* submit.cpp */, + EE303C330D326C9700D840F2 /* submit.dsp */, + EE303C340D326C9700D840F2 /* winapp.cpp */, + EE303C350D326C9700D840F2 /* winapp.h */, + EE303C360D326C9700D840F2 /* winform.cpp */, + EE303C370D326C9700D840F2 /* winform.h */, + EE303C380D326C9700D840F2 /* winmain.cpp */, + EE303C390D326C9700D840F2 /* winmenu.cpp */, + EE303C3A0D326C9700D840F2 /* winmenu.h */, + ); + path = main; + sourceTree = ""; + }; + EE303C3F0D326C9700D840F2 /* win32 */ = { + isa = PBXGroup; + children = ( + EE303C400D326C9700D840F2 /* gappbase.cpp */, + EE303C410D326C9700D840F2 /* gappbase.h */, + EE303C420D326C9700D840F2 /* gappinst.cpp */, + EE303C430D326C9700D840F2 /* gappinst.h */, + EE303C440D326C9700D840F2 /* gcontrol.cpp */, + EE303C450D326C9700D840F2 /* gcontrol.h */, + EE303C460D326C9700D840F2 /* gcracker.cpp */, + EE303C470D326C9700D840F2 /* gcracker.h */, + EE303C480D326C9700D840F2 /* gdc.cpp */, + EE303C490D326C9700D840F2 /* gdc.h */, + EE303C4A0D326C9700D840F2 /* gdialog.cpp */, + EE303C4B0D326C9700D840F2 /* gdialog.h */, + EE303C4C0D326C9700D840F2 /* gpump.cpp */, + EE303C4D0D326C9700D840F2 /* gpump.h */, + EE303C4E0D326C9700D840F2 /* gpump_dialog.cpp */, + EE303C4F0D326C9700D840F2 /* gscmap.cpp */, + EE303C500D326C9700D840F2 /* gscmap.h */, + EE303C510D326C9700D840F2 /* gsize.h */, + EE303C520D326C9700D840F2 /* gtray.cpp */, + EE303C530D326C9700D840F2 /* gtray.h */, + EE303C540D326C9700D840F2 /* gwinbase.cpp */, + EE303C550D326C9700D840F2 /* gwinbase.h */, + EE303C560D326C9700D840F2 /* gwindow.cpp */, + EE303C570D326C9700D840F2 /* gwindow.h */, + EE303C580D326C9700D840F2 /* gwinhid.cpp */, + EE303C590D326C9700D840F2 /* gwinhid.h */, + EE303C5A0D326C9700D840F2 /* Makefile.am */, + EE303C5B0D326C9700D840F2 /* Makefile.in */, + EE303C5C0D326C9700D840F2 /* mingw.mak */, + ); + path = win32; + sourceTree = ""; + }; + EE303EA80D366E5500D840F2 /* doc */ = { + isa = PBXGroup; + children = ( + EE303EA90D366E5500D840F2 /* auth.png */, + EE303EAA0D366E5500D840F2 /* developer.txt */, + EE303EAB0D366E5500D840F2 /* doxygen_header.html */, + EE303EAC0D366E5500D840F2 /* doxygen_missing.html */, + EE303EAD0D366E5500D840F2 /* emailrelay-filter-copy.1 */, + EE303EAE0D366E5500D840F2 /* emailrelay-man.html */, + EE303EAF0D366E5500D840F2 /* emailrelay-passwd.1 */, + EE303EB00D366E5500D840F2 /* emailrelay-poke.1 */, + EE303EB10D366E5500D840F2 /* emailrelay-submit.1 */, + EE303EB20D366E5500D840F2 /* emailrelay.1 */, + EE303EB30D366E5500D840F2 /* emailrelay.css */, + EE303EB40D366E5500D840F2 /* gnet-classes.png */, + EE303EB50D366E5500D840F2 /* gnet-client.png */, + EE303EB60D366E5500D840F2 /* gsmtp-classes.png */, + EE303EB70D366E5500D840F2 /* gsmtp-serverprotocol.png */, + EE303EB80D366E5500D840F2 /* index.html */, + EE303EB90D366E5500D840F2 /* Makefile.am */, + EE303EBA0D366E5500D840F2 /* Makefile.in */, + EE303EBB0D366E5500D840F2 /* reference.txt */, + EE303EBC0D366E5500D840F2 /* sequence-3.png */, + EE303EBD0D366E5500D840F2 /* userguide.txt */, + EE303EBE0D366E5500D840F2 /* windows.txt */, + ); + path = doc; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXHeadersBuildPhase section */ + EE303D300D32714D00D840F2 /* Headers */ = { + isa = PBXHeadersBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303DE30D3298F600D840F2 /* Headers */ = { + isa = PBXHeadersBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303E0E0D329BAA00D840F2 /* Headers */ = { + isa = PBXHeadersBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303E1F0D329BFF00D840F2 /* Headers */ = { + isa = PBXHeadersBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303E4B0D329D8F00D840F2 /* Headers */ = { + isa = PBXHeadersBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXHeadersBuildPhase section */ + +/* Begin PBXNativeTarget section */ + 8DD76F620486A84900D96B5E /* emailrelay */ = { + isa = PBXNativeTarget; + buildConfigurationList = 1DEB923108733DC60010E9CD /* Build configuration list for PBXNativeTarget "emailrelay" */; + buildPhases = ( + 8DD76F640486A84900D96B5E /* Sources */, + 8DD76F660486A84900D96B5E /* Frameworks */, + 8DD76F690486A84900D96B5E /* CopyFiles */, + ); + buildRules = ( + ); + dependencies = ( + EE303D810D32779300D840F2 /* PBXTargetDependency */, + EE303E5D0D32A86200D840F2 /* PBXTargetDependency */, + EE303E5F0D32A86200D840F2 /* PBXTargetDependency */, + EE303E610D32A86200D840F2 /* PBXTargetDependency */, + EE303E630D32A86200D840F2 /* PBXTargetDependency */, + ); + name = emailrelay; + productInstallPath = "$(HOME)/bin"; + productName = emailrelay; + productReference = 8DD76F6C0486A84900D96B5E /* emailrelay */; + productType = "com.apple.product-type.tool"; + }; + EE303D330D32714D00D840F2 /* glib */ = { + isa = PBXNativeTarget; + buildConfigurationList = EE303D370D32716C00D840F2 /* Build configuration list for PBXNativeTarget "glib" */; + buildPhases = ( + EE303D300D32714D00D840F2 /* Headers */, + EE303D310D32714D00D840F2 /* Sources */, + EE303D320D32714D00D840F2 /* Frameworks */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = glib; + productName = glib; + productReference = EE303D340D32714D00D840F2 /* libglib.a */; + productType = "com.apple.product-type.library.static"; + }; + EE303DE60D3298F600D840F2 /* gnet */ = { + isa = PBXNativeTarget; + buildConfigurationList = EE303DEA0D32994100D840F2 /* Build configuration list for PBXNativeTarget "gnet" */; + buildPhases = ( + EE303DE30D3298F600D840F2 /* Headers */, + EE303DE40D3298F600D840F2 /* Sources */, + EE303DE50D3298F600D840F2 /* Frameworks */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = gnet; + productName = gnet; + productReference = EE303DE70D3298F600D840F2 /* libgnet.a */; + productType = "com.apple.product-type.library.static"; + }; + EE303E110D329BAA00D840F2 /* gpop */ = { + isa = PBXNativeTarget; + buildConfigurationList = EE303E1C0D329BE600D840F2 /* Build configuration list for PBXNativeTarget "gpop" */; + buildPhases = ( + EE303E0E0D329BAA00D840F2 /* Headers */, + EE303E0F0D329BAA00D840F2 /* Sources */, + EE303E100D329BAA00D840F2 /* Frameworks */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = gpop; + productName = gpop; + productReference = EE303E120D329BAA00D840F2 /* libgpop.a */; + productType = "com.apple.product-type.library.static"; + }; + EE303E220D329BFF00D840F2 /* gsmtp */ = { + isa = PBXNativeTarget; + buildConfigurationList = EE303E480D329C6E00D840F2 /* Build configuration list for PBXNativeTarget "gsmtp" */; + buildPhases = ( + EE303E1F0D329BFF00D840F2 /* Headers */, + EE303E200D329BFF00D840F2 /* Sources */, + EE303E210D329BFF00D840F2 /* Frameworks */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = gsmtp; + productName = gsmtp; + productReference = EE303E230D329BFF00D840F2 /* libgsmtp.a */; + productType = "com.apple.product-type.library.static"; + }; + EE303E4E0D329D8F00D840F2 /* gssl */ = { + isa = PBXNativeTarget; + buildConfigurationList = EE303E540D329DF200D840F2 /* Build configuration list for PBXNativeTarget "gssl" */; + buildPhases = ( + EE303E4B0D329D8F00D840F2 /* Headers */, + EE303E4C0D329D8F00D840F2 /* Sources */, + EE303E4D0D329D8F00D840F2 /* Frameworks */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = gssl; + productName = gssl; + productReference = EE303E4F0D329D8F00D840F2 /* libgssl.a */; + productType = "com.apple.product-type.library.static"; + }; + EE9918250D91664E00FB06D5 /* emailrelay-filter-copy */ = { + isa = PBXNativeTarget; + buildConfigurationList = EE99183C0D91664E00FB06D5 /* Build configuration list for PBXNativeTarget "emailrelay-filter-copy" */; + buildPhases = ( + EE9918300D91664E00FB06D5 /* Sources */, + EE99183A0D91664E00FB06D5 /* Frameworks */, + EE99183B0D91664E00FB06D5 /* CopyFiles */, + ); + buildRules = ( + ); + dependencies = ( + EE9918260D91664E00FB06D5 /* PBXTargetDependency */, + ); + name = "emailrelay-filter-copy"; + productInstallPath = "$(HOME)/bin"; + productName = emailrelay; + productReference = EE99183F0D91664E00FB06D5 /* emailrelay-filter-copy */; + productType = "com.apple.product-type.tool"; + }; + EE99184B0D91693000FB06D5 /* emailrelay-start */ = { + isa = PBXNativeTarget; + buildConfigurationList = EE9918550D91693000FB06D5 /* Build configuration list for PBXNativeTarget "emailrelay-start" */; + buildPhases = ( + EE99184E0D91693000FB06D5 /* Sources */, + EE9918530D91693000FB06D5 /* Frameworks */, + EE9918540D91693000FB06D5 /* CopyFiles */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = "emailrelay-start"; + productInstallPath = "$(HOME)/bin"; + productName = emailrelay; + productReference = EE9918580D91693000FB06D5 /* emailrelay-start */; + productType = "com.apple.product-type.tool"; + }; + EE99185B0D91695000FB06D5 /* emailrelay-passwd */ = { + isa = PBXNativeTarget; + buildConfigurationList = EE9918650D91695000FB06D5 /* Build configuration list for PBXNativeTarget "emailrelay-passwd" */; + buildPhases = ( + EE99185E0D91695000FB06D5 /* Sources */, + EE9918630D91695000FB06D5 /* Frameworks */, + EE9918640D91695000FB06D5 /* CopyFiles */, + ); + buildRules = ( + ); + dependencies = ( + EE99185C0D91695000FB06D5 /* PBXTargetDependency */, + ); + name = "emailrelay-passwd"; + productInstallPath = "$(HOME)/bin"; + productName = emailrelay; + productReference = EE9918680D91695000FB06D5 /* emailrelay-passwd */; + productType = "com.apple.product-type.tool"; + }; + EE99186B0D91697900FB06D5 /* emailrelay-poke */ = { + isa = PBXNativeTarget; + buildConfigurationList = EE9918750D91697900FB06D5 /* Build configuration list for PBXNativeTarget "emailrelay-poke" */; + buildPhases = ( + EE99186E0D91697900FB06D5 /* Sources */, + EE9918730D91697900FB06D5 /* Frameworks */, + EE9918740D91697900FB06D5 /* CopyFiles */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = "emailrelay-poke"; + productInstallPath = "$(HOME)/bin"; + productName = emailrelay; + productReference = EE9918780D91697900FB06D5 /* emailrelay-poke */; + productType = "com.apple.product-type.tool"; + }; + EE99187B0D91698A00FB06D5 /* emailrelay-submit */ = { + isa = PBXNativeTarget; + buildConfigurationList = EE9918850D91698A00FB06D5 /* Build configuration list for PBXNativeTarget "emailrelay-submit" */; + buildPhases = ( + EE99187E0D91698A00FB06D5 /* Sources */, + EE9918830D91698A00FB06D5 /* Frameworks */, + EE9918840D91698A00FB06D5 /* CopyFiles */, + ); + buildRules = ( + ); + dependencies = ( + EE99187C0D91698A00FB06D5 /* PBXTargetDependency */, + EE9918B40D91707900FB06D5 /* PBXTargetDependency */, + EE9918960D916AA200FB06D5 /* PBXTargetDependency */, + EE9918B20D91707300FB06D5 /* PBXTargetDependency */, + ); + name = "emailrelay-submit"; + productInstallPath = "$(HOME)/bin"; + productName = emailrelay; + productReference = EE9918880D91698A00FB06D5 /* emailrelay-submit */; + productType = "com.apple.product-type.tool"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 08FB7793FE84155DC02AAC07 /* Project object */ = { + isa = PBXProject; + buildConfigurationList = 1DEB923508733DC60010E9CD /* Build configuration list for PBXProject "emailrelay" */; + compatibilityVersion = "Xcode 3.0"; + hasScannedForEncodings = 1; + mainGroup = 08FB7794FE84155DC02AAC07 /* emailrelay */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 8DD76F620486A84900D96B5E /* emailrelay */, + EE303D330D32714D00D840F2 /* glib */, + EE303DE60D3298F600D840F2 /* gnet */, + EE303E110D329BAA00D840F2 /* gpop */, + EE303E220D329BFF00D840F2 /* gsmtp */, + EE303E4E0D329D8F00D840F2 /* gssl */, + EE9918250D91664E00FB06D5 /* emailrelay-filter-copy */, + EE99184B0D91693000FB06D5 /* emailrelay-start */, + EE99185B0D91695000FB06D5 /* emailrelay-passwd */, + EE99186B0D91697900FB06D5 /* emailrelay-poke */, + EE99187B0D91698A00FB06D5 /* emailrelay-submit */, + EE9918CC0D91760400FB06D5 /* all-targets */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXSourcesBuildPhase section */ + 8DD76F640486A84900D96B5E /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EE303C5D0D326C9700D840F2 /* empty.cpp in Sources */, + EE303D000D326C9700D840F2 /* admin_enabled.cpp in Sources */, + EE303D010D326C9700D840F2 /* commandline_full.cpp in Sources */, + EE303D030D326C9700D840F2 /* configuration.cpp in Sources */, + EE303D060D326C9700D840F2 /* legal.cpp in Sources */, + EE303D070D326C9700D840F2 /* main.cpp in Sources */, + EE303D0A0D326C9700D840F2 /* news.cpp in Sources */, + EE303D0B0D326C9700D840F2 /* output.cpp in Sources */, + EE303D0E0D326C9700D840F2 /* run.cpp in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303D310D32714D00D840F2 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EE303D380D3271A200D840F2 /* gtest.cpp in Sources */, + EE303D3A0D3271AF00D840F2 /* glogoutput_unix.cpp in Sources */, + EE303D3B0D3271B000D840F2 /* gexception.cpp in Sources */, + EE303D3C0D3271B100D840F2 /* gtime.cpp in Sources */, + EE303D3E0D3271B400D840F2 /* gslot.cpp in Sources */, + EE303D400D3271B600D840F2 /* ghostname_unix.cpp in Sources */, + EE303D410D3271B700D840F2 /* gfile_unix.cpp in Sources */, + EE303D420D3271B900D840F2 /* gprocess_unix.cpp in Sources */, + EE303D430D3271BA00D840F2 /* gmd5_native.cpp in Sources */, + EE303D440D3271BB00D840F2 /* ggetopt.cpp in Sources */, + EE303D470D3271C500D840F2 /* gnewprocess_unix_exec_enabled.cpp in Sources */, + EE303D4A0D3271C800D840F2 /* glog.cpp in Sources */, + EE303D4C0D3271CA00D840F2 /* md5.cpp in Sources */, + EE303D4E0D3271D000D840F2 /* gcleanup_unix.cpp in Sources */, + EE303D4F0D3271D100D840F2 /* gdirectory_unix_glob.cpp in Sources */, + EE303D500D3271D200D840F2 /* gdatetime_unix.cpp in Sources */, + EE303D510D3271D300D840F2 /* gdirectory_unix.cpp in Sources */, + EE303D520D3271D300D840F2 /* gdate.cpp in Sources */, + EE303D530D3271D400D840F2 /* gexecutable.cpp in Sources */, + EE303D540D3271D600D840F2 /* gstr.cpp in Sources */, + EE303D550D3271D600D840F2 /* gfs_unix.cpp in Sources */, + EE303D570D3271D800D840F2 /* gexecutable_unix.cpp in Sources */, + EE303D580D3271D900D840F2 /* gdatetime.cpp in Sources */, + EE303D590D3271DC00D840F2 /* groot.cpp in Sources */, + EE303D5A0D3271DD00D840F2 /* gpath.cpp in Sources */, + EE303D5B0D3271DD00D840F2 /* gidentity_unix.cpp in Sources */, + EE303D5D0D3271DF00D840F2 /* gdirectory.cpp in Sources */, + EE303D5F0D3271E100D840F2 /* garg_unix.cpp in Sources */, + EE303D600D3271EB00D840F2 /* gxtext.cpp in Sources */, + EE303D640D3271EF00D840F2 /* garg.cpp in Sources */, + EE303D660D3271F200D840F2 /* gfile.cpp in Sources */, + EE303D670D3271F300D840F2 /* glogoutput.cpp in Sources */, + EE303D680D3271F300D840F2 /* gpidfile.cpp in Sources */, + EE303D6A0D3271F500D840F2 /* gdaemon_unix.cpp in Sources */, + EE303D6B0D3271F600D840F2 /* gcounter.cpp in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303DE40D3298F600D840F2 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EE303DEB0D32997B00D840F2 /* gbufferedserverpeer.cpp in Sources */, + EE303DEC0D32997C00D840F2 /* gconnection.cpp in Sources */, + EE303DED0D32997F00D840F2 /* gaddress_ipv4.cpp in Sources */, + EE303DEE0D32998000D840F2 /* gresolver.cpp in Sources */, + EE303DEF0D32998500D840F2 /* gsocket.cpp in Sources */, + EE303DF00D32998700D840F2 /* geventloop.cpp in Sources */, + EE303DF10D32998A00D840F2 /* gtimer.cpp in Sources */, + EE303DF20D32998C00D840F2 /* gsocket_unix.cpp in Sources */, + EE303DF30D32998E00D840F2 /* gsimpleclient.cpp in Sources */, + EE303DF40D32998F00D840F2 /* gclient.cpp in Sources */, + EE303DF50D32999100D840F2 /* gheapclient.cpp in Sources */, + EE303DF60D32999600D840F2 /* geventhandler.cpp in Sources */, + EE303DF70D32999800D840F2 /* gmultiserver.cpp in Sources */, + EE303DF80D32999900D840F2 /* gserver.cpp in Sources */, + EE303DF90D32999C00D840F2 /* glocal_unix.cpp in Sources */, + EE303DFA0D3299A000D840F2 /* gtimerlist.cpp in Sources */, + EE303DFB0D3299A300D840F2 /* gsimpleclient_unix.cpp in Sources */, + EE303DFC0D3299A500D840F2 /* glinebuffer.cpp in Sources */, + EE303DFD0D3299A600D840F2 /* glocal.cpp in Sources */, + EE303DFE0D3299A800D840F2 /* gresolver_ipv4.cpp in Sources */, + EE303DFF0D3299AA00D840F2 /* gresolverinfo.cpp in Sources */, + EE303E000D3299AE00D840F2 /* gmonitor.cpp in Sources */, + EE303E010D3299B100D840F2 /* gsocketprotocol.cpp in Sources */, + EE303E020D3299B300D840F2 /* geventloop_unix.cpp in Sources */, + EE303E040D3299BB00D840F2 /* gdescriptor_unix.cpp in Sources */, + EE303E050D3299BD00D840F2 /* gresolver_unix.cpp in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303E0F0D329BAA00D840F2 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EE303E150D329BC100D840F2 /* gpopserverprotocol.cpp in Sources */, + EE303E160D329BC300D840F2 /* gpopstore.cpp in Sources */, + EE303E170D329BC400D840F2 /* gpopserver.cpp in Sources */, + EE303E180D329BC500D840F2 /* gpopauth.cpp in Sources */, + EE303E190D329BC700D840F2 /* gpopsecrets_unix.cpp in Sources */, + EE303E1A0D329BC800D840F2 /* gpopsecrets.cpp in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303E200D329BFF00D840F2 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EE303E260D329C1200D840F2 /* gstoredmessage.cpp in Sources */, + EE303E270D329C1400D840F2 /* gexecutableverifier.cpp in Sources */, + EE303E280D329C1500D840F2 /* gsecrets_full.cpp in Sources */, + EE303E290D329C1700D840F2 /* ginternalverifier.cpp in Sources */, + EE303E2A0D329C1800D840F2 /* grequestclient.cpp in Sources */, + EE303E2B0D329C1A00D840F2 /* gadminserver.cpp in Sources */, + EE303E2C0D329C1C00D840F2 /* gprocessor.cpp in Sources */, + EE303E2D0D329C1E00D840F2 /* gprocessorfactory_exec_enabled.cpp in Sources */, + EE303E2E0D329C1F00D840F2 /* gclientprotocol.cpp in Sources */, + EE303E2F0D329C2200D840F2 /* gmessagestore.cpp in Sources */, + EE303E300D329C2400D840F2 /* gfilestore.cpp in Sources */, + EE303E310D329C2500D840F2 /* gsasl_native.cpp in Sources */, + EE303E320D329C2600D840F2 /* gmessagestore_unix.cpp in Sources */, + EE303E330D329C2800D840F2 /* gverifierstatus.cpp in Sources */, + EE303E340D329C2A00D840F2 /* gspamprocessor.cpp in Sources */, + EE303E350D329C2C00D840F2 /* gnullprocessor.cpp in Sources */, + EE303E360D329C3000D840F2 /* gbase64.cpp in Sources */, + EE303E370D329C3200D840F2 /* gverifierfactory_exec_enabled.cpp in Sources */, + EE303E380D329C3400D840F2 /* gnetworkverifier.cpp in Sources */, + EE303E390D329C3700D840F2 /* gstoredfile.cpp in Sources */, + EE303E3A0D329C3800D840F2 /* gprotocolmessage.cpp in Sources */, + EE303E3B0D329C3A00D840F2 /* gverifier.cpp in Sources */, + EE303E3C0D329C3B00D840F2 /* gnewfile.cpp in Sources */, + EE303E3D0D329C3C00D840F2 /* gprotocolmessagestore.cpp in Sources */, + EE303E3E0D329C3D00D840F2 /* gsmtpclient.cpp in Sources */, + EE303E3F0D329C3F00D840F2 /* gexecutableprocessor.cpp in Sources */, + EE303E400D329C4000D840F2 /* gnewmessage.cpp in Sources */, + EE303E410D329C4200D840F2 /* gprotocolmessageforward.cpp in Sources */, + EE303E420D329C4400D840F2 /* gspamclient.cpp in Sources */, + EE303E430D329C4900D840F2 /* gfactoryparser.cpp in Sources */, + EE303E440D329C4B00D840F2 /* gnetworkprocessor.cpp in Sources */, + EE303E450D329C4E00D840F2 /* gsmtpserver.cpp in Sources */, + EE303E460D329C5000D840F2 /* gserverprotocol.cpp in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE303E4C0D329D8F00D840F2 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EE9919380D91A4F500FB06D5 /* gssl_openssl.cpp in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE9918300D91664E00FB06D5 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EE9918310D91664E00FB06D5 /* empty.cpp in Sources */, + EE9918420D91670200FB06D5 /* filter_copy.cpp in Sources */, + EE9918440D91673900FB06D5 /* filter.cpp in Sources */, + EE9918460D91675100FB06D5 /* legal.cpp in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE99184E0D91693000FB06D5 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EE99184F0D91693000FB06D5 /* empty.cpp in Sources */, + EE99188D0D9169FE00FB06D5 /* start.cpp in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE99185E0D91695000FB06D5 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EE99185F0D91695000FB06D5 /* empty.cpp in Sources */, + EE99188F0D916A3600FB06D5 /* passwd.cpp in Sources */, + EE9918A50D916B1A00FB06D5 /* legal.cpp in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE99186E0D91697900FB06D5 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EE99186F0D91697900FB06D5 /* empty.cpp in Sources */, + EE9918900D916A4E00FB06D5 /* poke.c in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + EE99187E0D91698A00FB06D5 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + EE99187F0D91698A00FB06D5 /* empty.cpp in Sources */, + EE9918920D916A7400FB06D5 /* submit.cpp in Sources */, + EE9918940D916A8600FB06D5 /* legal.cpp in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXTargetDependency section */ + EE303D810D32779300D840F2 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE303D330D32714D00D840F2 /* glib */; + targetProxy = EE303D800D32779300D840F2 /* PBXContainerItemProxy */; + }; + EE303E5D0D32A86200D840F2 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE303DE60D3298F600D840F2 /* gnet */; + targetProxy = EE303E5C0D32A86200D840F2 /* PBXContainerItemProxy */; + }; + EE303E5F0D32A86200D840F2 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE303E110D329BAA00D840F2 /* gpop */; + targetProxy = EE303E5E0D32A86200D840F2 /* PBXContainerItemProxy */; + }; + EE303E610D32A86200D840F2 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE303E220D329BFF00D840F2 /* gsmtp */; + targetProxy = EE303E600D32A86200D840F2 /* PBXContainerItemProxy */; + }; + EE303E630D32A86200D840F2 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE303E4E0D329D8F00D840F2 /* gssl */; + targetProxy = EE303E620D32A86200D840F2 /* PBXContainerItemProxy */; + }; + EE9918260D91664E00FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE303D330D32714D00D840F2 /* glib */; + targetProxy = EE9918270D91664E00FB06D5 /* PBXContainerItemProxy */; + }; + EE99185C0D91695000FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE303D330D32714D00D840F2 /* glib */; + targetProxy = EE99185D0D91695000FB06D5 /* PBXContainerItemProxy */; + }; + EE99187C0D91698A00FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE303D330D32714D00D840F2 /* glib */; + targetProxy = EE99187D0D91698A00FB06D5 /* PBXContainerItemProxy */; + }; + EE9918960D916AA200FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE303DE60D3298F600D840F2 /* gnet */; + targetProxy = EE9918950D916AA200FB06D5 /* PBXContainerItemProxy */; + }; + EE9918B20D91707300FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE303E220D329BFF00D840F2 /* gsmtp */; + targetProxy = EE9918B10D91707300FB06D5 /* PBXContainerItemProxy */; + }; + EE9918B40D91707900FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE303E4E0D329D8F00D840F2 /* gssl */; + targetProxy = EE9918B30D91707900FB06D5 /* PBXContainerItemProxy */; + }; + EE9918D10D91762800FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = 8DD76F620486A84900D96B5E /* emailrelay */; + targetProxy = EE9918D00D91762800FB06D5 /* PBXContainerItemProxy */; + }; + EE9918DD0D91762800FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE9918250D91664E00FB06D5 /* emailrelay-filter-copy */; + targetProxy = EE9918DC0D91762800FB06D5 /* PBXContainerItemProxy */; + }; + EE9918DF0D91762800FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE99184B0D91693000FB06D5 /* emailrelay-start */; + targetProxy = EE9918DE0D91762800FB06D5 /* PBXContainerItemProxy */; + }; + EE9918E10D91762800FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE99185B0D91695000FB06D5 /* emailrelay-passwd */; + targetProxy = EE9918E00D91762800FB06D5 /* PBXContainerItemProxy */; + }; + EE9918E30D91762800FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE99186B0D91697900FB06D5 /* emailrelay-poke */; + targetProxy = EE9918E20D91762800FB06D5 /* PBXContainerItemProxy */; + }; + EE9918E50D91762800FB06D5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = EE99187B0D91698A00FB06D5 /* emailrelay-submit */; + targetProxy = EE9918E40D91762800FB06D5 /* PBXContainerItemProxy */; + }; +/* End PBXTargetDependency section */ + +/* Begin XCBuildConfiguration section */ + 1DEB923208733DC60010E9CD /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "_GLIBCXX_DEBUG=1", + "_GLIBCXX_DEBUG_PEDANTIC=1", + "G_SYSCONFDIR=\\\"/Applications/E-MailRelay\\\"", + "G_SPOOLDIR=\\\"/Library/Mail/Spool\\\"", + "G_UNIX=1", + "_DEBUG=1", + ); + INSTALL_PATH = /usr/local/bin; + OTHER_LDFLAGS = ( + "-lgsmtp", + "-lgpop", + "-lgnet", + "-lgssl", + "-lglib", + "-lssl", + "-lcrypto", + ); + PRODUCT_NAME = emailrelay; + ZERO_LINK = YES; + }; + name = Debug; + }; + 1DEB923308733DC60010E9CD /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + EXECUTABLE_EXTENSION = .app; + GCC_INLINES_ARE_PRIVATE_EXTERN = NO; + GCC_MODEL_TUNING = G5; + INFOPLIST_FILE = Info.plist; + INSTALL_PATH = /usr/local/bin; + MACH_O_TYPE = mh_execute; + OTHER_LDFLAGS = ( + "-lgsmtp", + "-lgpop", + "-lgnet", + "-lgssl", + "-lglib", + "-lssl", + "-lcrypto", + ); + PRODUCT_NAME = emailrelay; + }; + name = Release; + }; + 1DEB923608733DC60010E9CD /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + GCC_INLINES_ARE_PRIVATE_EXTERN = NO; + GCC_PREPROCESSOR_DEFINITIONS = ( + "_DEBUG=1", + "G_UNIX=1", + "G_SYSCONFDIR=\\\"/Applications/E-MailRelay\\\"", + "G_SPOOLDIR=\\\"/Library/Mail/Spool\\\"", + "_GLIBCXX_DEBUG=1", + "_GLIBCXX_DEBUG_PEDANTIC=1", + ); + GCC_SYMBOLS_PRIVATE_EXTERN = NO; + GCC_WARN_ABOUT_RETURN_TYPE = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + OTHER_LDFLAGS = ""; + PREBINDING = NO; + SDKROOT = "$(DEVELOPER_SDK_DIR)/MacOSX10.5.sdk"; + }; + name = Debug; + }; + 1DEB923708733DC60010E9CD /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ARCHS = ( + i386, + ppc, + ppc64, + x86_64, + ); + GCC_PRECOMPILE_PREFIX_HEADER = YES; + GCC_PREFIX_HEADER = src/glib/gdef.h; + GCC_PREPROCESSOR_DEFINITIONS = ( + "G_UNIX=1", + "G_SYSCONFDIR=\\\"/Applications/E-MailRelay\\\"", + "G_SPOOLDIR=\\\"/Library/Mail/Spool\\\"", + ); + GCC_SYMBOLS_PRIVATE_EXTERN = NO; + GCC_WARN_ABOUT_RETURN_TYPE = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + OTHER_LDFLAGS = ""; + PREBINDING = NO; + PRECOMPS_INCLUDE_HEADERS_FROM_BUILT_PRODUCTS_DIR = YES; + SDKROOT = "$(DEVELOPER_SDK_DIR)/MacOSX10.5.sdk"; + }; + name = Release; + }; + EE303D350D32714E00D840F2 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + INSTALL_PATH = /usr/local/lib; + PREBINDING = NO; + PRODUCT_NAME = glib; + ZERO_LINK = YES; + }; + name = Debug; + }; + EE303D360D32714E00D840F2 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = YES; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + GCC_ENABLE_FIX_AND_CONTINUE = NO; + GCC_MODEL_TUNING = G5; + INSTALL_PATH = /usr/local/lib; + PREBINDING = NO; + PRODUCT_NAME = glib; + ZERO_LINK = NO; + }; + name = Release; + }; + EE303DE80D3298F700D840F2 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + INSTALL_PATH = /usr/local/lib; + PREBINDING = NO; + PRODUCT_NAME = gnet; + ZERO_LINK = YES; + }; + name = Debug; + }; + EE303DE90D3298F700D840F2 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = YES; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + GCC_ENABLE_FIX_AND_CONTINUE = NO; + GCC_MODEL_TUNING = G5; + INSTALL_PATH = /usr/local/lib; + PREBINDING = NO; + PRODUCT_NAME = gnet; + ZERO_LINK = NO; + }; + name = Release; + }; + EE303E130D329BAB00D840F2 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + INSTALL_PATH = /usr/local/lib; + PREBINDING = NO; + PRODUCT_NAME = gpop; + ZERO_LINK = YES; + }; + name = Debug; + }; + EE303E140D329BAB00D840F2 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = YES; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + GCC_ENABLE_FIX_AND_CONTINUE = NO; + GCC_MODEL_TUNING = G5; + INSTALL_PATH = /usr/local/lib; + PREBINDING = NO; + PRODUCT_NAME = gpop; + ZERO_LINK = NO; + }; + name = Release; + }; + EE303E240D329C0000D840F2 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + INSTALL_PATH = /usr/local/lib; + PREBINDING = NO; + PRODUCT_NAME = gsmtp; + ZERO_LINK = YES; + }; + name = Debug; + }; + EE303E250D329C0000D840F2 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = YES; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + GCC_ENABLE_FIX_AND_CONTINUE = NO; + GCC_MODEL_TUNING = G5; + INSTALL_PATH = /usr/local/lib; + PREBINDING = NO; + PRODUCT_NAME = gsmtp; + ZERO_LINK = NO; + }; + name = Release; + }; + EE303E500D329D9000D840F2 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + INSTALL_PATH = /usr/local/lib; + PREBINDING = NO; + PRODUCT_NAME = gssl; + ZERO_LINK = YES; + }; + name = Debug; + }; + EE303E510D329D9000D840F2 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = YES; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + GCC_ENABLE_FIX_AND_CONTINUE = NO; + GCC_MODEL_TUNING = G5; + INSTALL_PATH = /usr/local/lib; + PREBINDING = NO; + PRODUCT_NAME = gssl; + ZERO_LINK = NO; + }; + name = Release; + }; + EE99183D0D91664E00FB06D5 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "_GLIBCXX_DEBUG=1", + "_GLIBCXX_DEBUG_PEDANTIC=1", + "G_SYSCONFDIR=\\\"/Applications/E-MailRelay\\\"", + "G_SPOOLDIR=\\\"/Library/Mail/Spool\\\"", + "G_UNIX=1", + "_DEBUG=1", + ); + INFOPLIST_FILE = "/Users/graeme/build.xcode/emailrelay-1.8/Info copy.plist"; + INSTALL_PATH = /usr/local/bin; + OTHER_LDFLAGS = "-lglib"; + PRODUCT_NAME = "emailrelay-filter-copy"; + ZERO_LINK = YES; + }; + name = Debug; + }; + EE99183E0D91664E00FB06D5 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + EXECUTABLE_EXTENSION = .app; + GCC_INLINES_ARE_PRIVATE_EXTERN = NO; + GCC_MODEL_TUNING = G5; + INFOPLIST_FILE = "/Users/graeme/build.xcode/emailrelay-1.8/Info copy.plist"; + INSTALL_PATH = /usr/local/bin; + MACH_O_TYPE = mh_execute; + OTHER_LDFLAGS = "-lglib"; + PRODUCT_NAME = "emailrelay-filter-copy"; + }; + name = Release; + }; + EE9918560D91693000FB06D5 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "_GLIBCXX_DEBUG=1", + "_GLIBCXX_DEBUG_PEDANTIC=1", + "G_SYSCONFDIR=\\\"/Applications/E-MailRelay\\\"", + "G_SPOOLDIR=\\\"/Library/Mail/Spool\\\"", + "G_UNIX=1", + "_DEBUG=1", + ); + INFOPLIST_FILE = "/Users/graeme/build.xcode/emailrelay-1.8/Info copy 2.plist"; + INSTALL_PATH = /usr/local/bin; + OTHER_LDFLAGS = ""; + PRODUCT_NAME = "emailrelay-start"; + ZERO_LINK = YES; + }; + name = Debug; + }; + EE9918570D91693000FB06D5 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + EXECUTABLE_EXTENSION = .app; + GCC_INLINES_ARE_PRIVATE_EXTERN = NO; + GCC_MODEL_TUNING = G5; + INFOPLIST_FILE = "/Users/graeme/build.xcode/emailrelay-1.8/Info copy 2.plist"; + INSTALL_PATH = /usr/local/bin; + MACH_O_TYPE = mh_execute; + OTHER_LDFLAGS = ""; + PRODUCT_NAME = "emailrelay-start"; + }; + name = Release; + }; + EE9918660D91695000FB06D5 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "_GLIBCXX_DEBUG=1", + "_GLIBCXX_DEBUG_PEDANTIC=1", + "G_SYSCONFDIR=\\\"/Applications/E-MailRelay\\\"", + "G_SPOOLDIR=\\\"/Library/Mail/Spool\\\"", + "G_UNIX=1", + "_DEBUG=1", + ); + INFOPLIST_FILE = "/Users/graeme/build.xcode/emailrelay-1.8/Info copy 3.plist"; + INSTALL_PATH = /usr/local/bin; + OTHER_LDFLAGS = "-lglib"; + PRODUCT_NAME = "emailrelay-passwd"; + ZERO_LINK = YES; + }; + name = Debug; + }; + EE9918670D91695000FB06D5 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + EXECUTABLE_EXTENSION = .app; + GCC_INLINES_ARE_PRIVATE_EXTERN = NO; + GCC_MODEL_TUNING = G5; + INFOPLIST_FILE = "/Users/graeme/build.xcode/emailrelay-1.8/Info copy 3.plist"; + INSTALL_PATH = /usr/local/bin; + MACH_O_TYPE = mh_execute; + OTHER_LDFLAGS = "-lglib"; + PRODUCT_NAME = "emailrelay-passwd"; + }; + name = Release; + }; + EE9918760D91697900FB06D5 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "_GLIBCXX_DEBUG=1", + "_GLIBCXX_DEBUG_PEDANTIC=1", + "G_SYSCONFDIR=\\\"/Applications/E-MailRelay\\\"", + "G_SPOOLDIR=\\\"/Library/Mail/Spool\\\"", + "G_UNIX=1", + "_DEBUG=1", + ); + INFOPLIST_FILE = "/Users/graeme/build.xcode/emailrelay-1.8/Info copy 4.plist"; + INSTALL_PATH = /usr/local/bin; + OTHER_LDFLAGS = ""; + PRODUCT_NAME = "emailrelay-poke"; + ZERO_LINK = YES; + }; + name = Debug; + }; + EE9918770D91697900FB06D5 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + EXECUTABLE_EXTENSION = .app; + GCC_INLINES_ARE_PRIVATE_EXTERN = NO; + GCC_MODEL_TUNING = G5; + INFOPLIST_FILE = "/Users/graeme/build.xcode/emailrelay-1.8/Info copy 4.plist"; + INSTALL_PATH = /usr/local/bin; + MACH_O_TYPE = mh_execute; + OTHER_LDFLAGS = ""; + PRODUCT_NAME = "emailrelay-poke"; + }; + name = Release; + }; + EE9918860D91698A00FB06D5 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_ENABLE_FIX_AND_CONTINUE = YES; + GCC_MODEL_TUNING = G5; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "_GLIBCXX_DEBUG=1", + "_GLIBCXX_DEBUG_PEDANTIC=1", + "G_SYSCONFDIR=\\\"/Applications/E-MailRelay\\\"", + "G_SPOOLDIR=\\\"/Library/Mail/Spool\\\"", + "G_UNIX=1", + "_DEBUG=1", + ); + INFOPLIST_FILE = "/Users/graeme/build.xcode/emailrelay-1.8/Info copy 5.plist"; + INSTALL_PATH = /usr/local/bin; + OTHER_LDFLAGS = ( + "-lgsmtp", + "-lgnet", + "-lgssl", + "-lglib", + ); + PRODUCT_NAME = "emailrelay-submit"; + ZERO_LINK = YES; + }; + name = Debug; + }; + EE9918870D91698A00FB06D5 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + EXECUTABLE_EXTENSION = .app; + GCC_INLINES_ARE_PRIVATE_EXTERN = NO; + GCC_MODEL_TUNING = G5; + INFOPLIST_FILE = "/Users/graeme/build.xcode/emailrelay-1.8/Info copy 5.plist"; + INSTALL_PATH = /usr/local/bin; + MACH_O_TYPE = mh_execute; + OTHER_LDFLAGS = ( + "-lgsmtp", + "-lgnet", + "-lgssl", + "-lglib", + ); + PRODUCT_NAME = "emailrelay-submit"; + }; + name = Release; + }; + EE9918CD0D91760500FB06D5 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = NO; + GCC_DYNAMIC_NO_PIC = NO; + GCC_OPTIMIZATION_LEVEL = 0; + PRODUCT_NAME = "all-targets"; + }; + name = Debug; + }; + EE9918CE0D91760500FB06D5 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + COPY_PHASE_STRIP = YES; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + GCC_ENABLE_FIX_AND_CONTINUE = NO; + PRODUCT_NAME = "all-targets"; + ZERO_LINK = NO; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 1DEB923108733DC60010E9CD /* Build configuration list for PBXNativeTarget "emailrelay" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 1DEB923208733DC60010E9CD /* Debug */, + 1DEB923308733DC60010E9CD /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 1DEB923508733DC60010E9CD /* Build configuration list for PBXProject "emailrelay" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 1DEB923608733DC60010E9CD /* Debug */, + 1DEB923708733DC60010E9CD /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EE303D370D32716C00D840F2 /* Build configuration list for PBXNativeTarget "glib" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EE303D350D32714E00D840F2 /* Debug */, + EE303D360D32714E00D840F2 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EE303DEA0D32994100D840F2 /* Build configuration list for PBXNativeTarget "gnet" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EE303DE80D3298F700D840F2 /* Debug */, + EE303DE90D3298F700D840F2 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EE303E1C0D329BE600D840F2 /* Build configuration list for PBXNativeTarget "gpop" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EE303E130D329BAB00D840F2 /* Debug */, + EE303E140D329BAB00D840F2 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EE303E480D329C6E00D840F2 /* Build configuration list for PBXNativeTarget "gsmtp" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EE303E240D329C0000D840F2 /* Debug */, + EE303E250D329C0000D840F2 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EE303E540D329DF200D840F2 /* Build configuration list for PBXNativeTarget "gssl" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EE303E500D329D9000D840F2 /* Debug */, + EE303E510D329D9000D840F2 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EE99183C0D91664E00FB06D5 /* Build configuration list for PBXNativeTarget "emailrelay-filter-copy" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EE99183D0D91664E00FB06D5 /* Debug */, + EE99183E0D91664E00FB06D5 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EE9918550D91693000FB06D5 /* Build configuration list for PBXNativeTarget "emailrelay-start" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EE9918560D91693000FB06D5 /* Debug */, + EE9918570D91693000FB06D5 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EE9918650D91695000FB06D5 /* Build configuration list for PBXNativeTarget "emailrelay-passwd" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EE9918660D91695000FB06D5 /* Debug */, + EE9918670D91695000FB06D5 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EE9918750D91697900FB06D5 /* Build configuration list for PBXNativeTarget "emailrelay-poke" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EE9918760D91697900FB06D5 /* Debug */, + EE9918770D91697900FB06D5 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EE9918850D91698A00FB06D5 /* Build configuration list for PBXNativeTarget "emailrelay-submit" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EE9918860D91698A00FB06D5 /* Debug */, + EE9918870D91698A00FB06D5 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + EE9918CF0D91762300FB06D5 /* Build configuration list for PBXAggregateTarget "all-targets" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + EE9918CD0D91760500FB06D5 /* Debug */, + EE9918CE0D91760500FB06D5 /* Release */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = 08FB7793FE84155DC02AAC07 /* Project object */; +} diff --git a/etc/Makefile.am b/etc/Makefile.am index 63ab67f..ae1c541 100644 --- a/etc/Makefile.am +++ b/etc/Makefile.am @@ -1,5 +1,5 @@ # -## Copyright (C) 2001-2007 Graeme Walker +## Copyright (C) 2001-2008 Graeme Walker ## ## This program is free software: you can redistribute it and/or modify ## it under the terms of the GNU General Public License as published by @@ -14,7 +14,11 @@ ## You should have received a copy of the GNU General Public License ## along with this program. If not, see . # + EXTRA_DIST = emailrelay.conf.template + e_sysconf_DATA = emailrelay.conf.template + install-data-hook: - if test -f "$(DESTDIR)$(e_sysconfdir)/emailrelay.conf" ; then : ; else cp "$(DESTDIR)$(e_sysconfdir)/emailrelay.conf.template" "$(DESTDIR)$(e_sysconfdir)/emailrelay.conf" ; fi + if test -f "$(DESTDIR)$(e_sysconfdir)/emailrelay.conf" ; then : ; else cat "$(DESTDIR)$(e_sysconfdir)/emailrelay.conf.template" | sed "s:^#spool-dir /var/spool/emailrelay:spool-dir $(DESTDIR)$(e_spooldir):g" | sed 's:"/var/spool/emailrelay":"'"$(e_spooldir)"'":g' | sed "s:/etc:$(e_sysconfdir):g" | sed "s:/usr/local/bin:$(e_libexecdir):g" > "$(DESTDIR)$(e_sysconfdir)/emailrelay.conf" ; fi + diff --git a/etc/Makefile.in b/etc/Makefile.in index aa21a12..ef48f33 100644 --- a/etc/Makefile.in +++ b/etc/Makefile.in @@ -1,8 +1,8 @@ -# Makefile.in generated by automake 1.10 from Makefile.am. +# Makefile.in generated by automake 1.10.1 from Makefile.am. # @configure_input@ # Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002, -# 2003, 2004, 2005, 2006 Free Software Foundation, Inc. +# 2003, 2004, 2005, 2006, 2007, 2008 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. @@ -14,6 +14,9 @@ @SET_MAKE@ +# +# + VPATH = @srcdir@ pkgdatadir = $(datadir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ @@ -76,6 +79,7 @@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ EXEEXT = @EXEEXT@ +FRAGMENTS_LIST = @FRAGMENTS_LIST@ GREP = @GREP@ GZIP = @GZIP@ HAVE_DOXYGEN = @HAVE_DOXYGEN@ @@ -85,7 +89,6 @@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ -IP = @IP@ LDFLAGS = @LDFLAGS@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ @@ -109,7 +112,6 @@ QT_LIBS = @QT_LIBS@ RANLIB = @RANLIB@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ -SSL = @SSL@ SSL_LIBS = @SSL_LIBS@ STATIC_END = @STATIC_END@ STATIC_START = @STATIC_START@ @@ -164,9 +166,6 @@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ - -# -# EXTRA_DIST = emailrelay.conf.template e_sysconf_DATA = emailrelay.conf.template all: all-am @@ -352,8 +351,9 @@ uninstall-am: uninstall-e_sysconfDATA mostlyclean mostlyclean-generic pdf pdf-am ps ps-am uninstall \ uninstall-am uninstall-e_sysconfDATA + install-data-hook: - if test -f "$(DESTDIR)$(e_sysconfdir)/emailrelay.conf" ; then : ; else cp "$(DESTDIR)$(e_sysconfdir)/emailrelay.conf.template" "$(DESTDIR)$(e_sysconfdir)/emailrelay.conf" ; fi + if test -f "$(DESTDIR)$(e_sysconfdir)/emailrelay.conf" ; then : ; else cat "$(DESTDIR)$(e_sysconfdir)/emailrelay.conf.template" | sed "s:^#spool-dir /var/spool/emailrelay:spool-dir $(DESTDIR)$(e_spooldir):g" | sed 's:"/var/spool/emailrelay":"'"$(e_spooldir)"'":g' | sed "s:/etc:$(e_sysconfdir):g" | sed "s:/usr/local/bin:$(e_libexecdir):g" > "$(DESTDIR)$(e_sysconfdir)/emailrelay.conf" ; fi # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: diff --git a/etc/emailrelay.conf.template b/etc/emailrelay.conf.template index 14211ca..3756b66 100644 --- a/etc/emailrelay.conf.template +++ b/etc/emailrelay.conf.template @@ -32,8 +32,8 @@ # Format: interface # Description: Specifies an interface to listen on. The default is to listen # on all interfaces (INADDR_ANY). Using a specific interface can make it harder -# for clients on other sub-networks to connect, so improving security. Up to -# three interface addresses can be specified using comma separators. +# for clients on other sub-networks to connect, so improving security. Multiple +# interface addresses can be specified using comma separators. # #interface 192.168.0.10 @@ -67,6 +67,12 @@ # #client-auth /etc/emailrelay.auth +# Name: client-tls +# Format: client-tls +# Description: Enables the tls/ssl layer when acting as an smtp client. +# +#client-tls + # Name: connection-timeout # Format: connection-timeout