diff options
Diffstat (limited to '')
-rw-r--r-- | Makefile.am | 1147 |
1 files changed, 1147 insertions, 0 deletions
diff --git a/Makefile.am b/Makefile.am new file mode 100644 index 0000000..5348ce3 --- /dev/null +++ b/Makefile.am @@ -0,0 +1,1147 @@ +## Process this file with automake to produce Makefile.in +# +# $Id: Makefile.am 5502 2023-07-16 15:03:24Z chrfranke $ +# + +@SET_MAKE@ + +ACLOCAL_AMFLAGS = -I m4 + +# BUILD_INFO can be provided by package maintainers (see INSTALL file) +BUILD_INFO= "(local build)" + +AM_CPPFLAGS = \ + -DBUILD_INFO='$(BUILD_INFO)' \ + -DSMARTMONTOOLS_SYSCONFDIR='"$(sysconfdir)"' \ + -DSMARTMONTOOLS_SMARTDSCRIPTDIR='"$(smartdscriptdir)"' + +if ENABLE_DRIVEDB +AM_CPPFLAGS += -DSMARTMONTOOLS_DRIVEDBDIR='"$(drivedbdir)"' +endif +if ENABLE_SAVESTATES +AM_CPPFLAGS += -DSMARTMONTOOLS_SAVESTATES='"$(savestates)"' +endif +if ENABLE_ATTRIBUTELOG +AM_CPPFLAGS += -DSMARTMONTOOLS_ATTRIBUTELOG='"$(attributelog)"' +endif + +if OS_WIN32_MINGW +AM_CPPFLAGS += -I$(srcdir)/os_win32 +endif +if NEED_GETOPT_LONG +AM_CPPFLAGS += -I$(srcdir)/getopt -D_GETOPT_STANDALONE +endif +if NEED_REGEX +AM_CPPFLAGS += -I$(srcdir)/regex -D_REGEX_STANDALONE +endif + +sbin_PROGRAMS = \ + smartctl \ + smartd + +if ENABLE_UPDATE_SMART_DRIVEDB +if OS_WIN32_MINGW +else +sbin_SCRIPTS = update-smart-drivedb +endif +endif + + +smartctl_SOURCES = \ + smartctl.cpp \ + smartctl.h \ + atacmdnames.cpp \ + atacmdnames.h \ + atacmds.cpp \ + atacmds.h \ + ataidentify.cpp \ + ataidentify.h \ + ataprint.cpp \ + ataprint.h \ + dev_ata_cmd_set.cpp \ + dev_ata_cmd_set.h \ + dev_intelliprop.cpp \ + dev_interface.cpp \ + dev_interface.h \ + dev_jmb39x_raid.cpp \ + dev_tunnelled.h \ + drivedb.h \ + farmcmds.cpp \ + farmcmds.h \ + farmprint.cpp \ + farmprint.h \ + json.cpp \ + json.h \ + knowndrives.cpp \ + knowndrives.h \ + nvmecmds.cpp \ + nvmecmds.h \ + nvmeprint.cpp \ + nvmeprint.h \ + scsicmds.cpp \ + scsicmds.h \ + scsiata.cpp \ + scsinvme.cpp \ + scsiprint.cpp \ + scsiprint.h \ + static_assert.h \ + utility.cpp \ + utility.h \ + sg_unaligned.h + +smartctl_LDADD = $(os_deps) $(os_libs) +smartctl_DEPENDENCIES = $(os_deps) + +EXTRA_smartctl_SOURCES = \ + os_darwin.cpp \ + os_darwin.h \ + os_linux.cpp \ + os_linux.h \ + os_freebsd.cpp \ + os_freebsd.h \ + os_netbsd.cpp \ + os_netbsd.h \ + os_openbsd.cpp \ + os_openbsd.h \ + os_os2.cpp \ + os_os2.h \ + os_qnxnto.cpp \ + os_qnxnto.h \ + os_solaris.cpp \ + os_win32.cpp \ + os_generic.cpp \ + os_generic.h \ + aacraid.h \ + cciss.cpp \ + cciss.h \ + cissio_freebsd.h \ + dev_areca.cpp \ + dev_areca.h \ + dev_legacy.cpp \ + linux_nvme_ioctl.h \ + megaraid.h \ + sssraid.h + +if OS_WIN32_MINGW + +smartctl_SOURCES += \ + os_win32/popen_win32.cpp \ + os_win32/popen.h + +smartctl_LDADD += smartctl_res.o +smartctl_DEPENDENCIES += smartctl_res.o + +endif + + +smartd_SOURCES = \ + smartd.cpp \ + atacmdnames.cpp \ + atacmdnames.h \ + atacmds.cpp \ + atacmds.h \ + dev_ata_cmd_set.cpp \ + dev_ata_cmd_set.h \ + dev_intelliprop.cpp \ + dev_interface.cpp \ + dev_interface.h \ + dev_jmb39x_raid.cpp \ + dev_tunnelled.h \ + drivedb.h \ + knowndrives.cpp \ + knowndrives.h \ + nvmecmds.cpp \ + nvmecmds.h \ + scsicmds.cpp \ + scsicmds.h \ + scsiata.cpp \ + scsinvme.cpp \ + static_assert.h \ + utility.cpp \ + utility.h \ + sg_unaligned.h + +smartd_LDADD = $(os_deps) $(os_libs) $(CAPNG_LDADD) $(SYSTEMD_LDADD) +smartd_DEPENDENCIES = $(os_deps) + +EXTRA_smartd_SOURCES = \ + os_darwin.cpp \ + os_darwin.h \ + os_linux.cpp \ + os_linux.h \ + os_freebsd.cpp \ + os_freebsd.h \ + os_netbsd.cpp \ + os_netbsd.h \ + os_openbsd.cpp \ + os_openbsd.h \ + os_os2.cpp \ + os_os2.h \ + os_qnxnto.cpp \ + os_qnxnto.h \ + os_solaris.cpp \ + os_win32.cpp \ + os_generic.cpp \ + os_generic.h \ + aacraid.h \ + cciss.cpp \ + cciss.h \ + cissio_freebsd.h \ + dev_areca.cpp \ + dev_areca.h \ + dev_legacy.cpp \ + linux_nvme_ioctl.h \ + freebsd_nvme_ioctl.h \ + netbsd_nvme_ioctl.h \ + megaraid.h \ + sssraid.h + +if OS_POSIX + +smartd_SOURCES += \ + popen_as_ugid.cpp \ + popen_as_ugid.h + +endif + +if OS_WIN32_MINGW + +smartd_SOURCES += \ + os_win32/daemon_win32.cpp \ + os_win32/daemon_win32.h \ + os_win32/popen_win32.cpp \ + os_win32/popen.h \ + os_win32/syslog_win32.cpp \ + os_win32/syslog.h + +smartd_LDADD += smartd_res.o +smartd_DEPENDENCIES += smartd_res.o + +endif + +if NEED_GETOPT_LONG + +smartctl_SOURCES += \ + getopt/getopt.c \ + getopt/getopt.h \ + getopt/getopt1.c \ + getopt/getopt_int.h \ + getopt/bits/getopt_core.h \ + getopt/bits/getopt_ext.h + +smartd_SOURCES += \ + getopt/getopt.c \ + getopt/getopt.h \ + getopt/getopt1.c \ + getopt/getopt_int.h \ + getopt/bits/getopt_core.h \ + getopt/bits/getopt_ext.h + +endif + +if NEED_REGEX + +smartctl_SOURCES += \ + regex/regex.c \ + regex/regex.h \ + regex/regex_internal.h + +smartd_SOURCES += \ + regex/regex.c \ + regex/regex.h \ + regex/regex_internal.h + +# Included by regex.c: +EXTRA_smartctl_SOURCES += \ + regex/regcomp.c \ + regex/regexec.c \ + regex/regex_internal.c + +EXTRA_smartd_SOURCES += \ + regex/regcomp.c \ + regex/regexec.c \ + regex/regex_internal.c + +endif + +if OS_WIN32 + +smartctl_SOURCES += \ + csmisas.h \ + os_win32/wmiquery.cpp \ + os_win32/wmiquery.h + +smartd_SOURCES += \ + csmisas.h \ + os_win32/wmiquery.cpp \ + os_win32/wmiquery.h + +smartctl_LDADD += -lole32 -loleaut32 +smartd_LDADD += -lole32 -loleaut32 + +# Some versions of the MinGW-w64 import lib for kernel32.dll include some symbols +# duplicated from advapi32.dll. Older versions of windows provide these symbols +# only in advapi32.dll. Ensure that the advapi32 lib is linked first. +smartctl_LDADD += -ladvapi32 +smartd_LDADD += -ladvapi32 + +endif + +if OS_SOLARIS +# This block is required because Solaris uses manual page section 1m +# for administrative command (linux/freebsd use section 8) and Solaris +# uses manual page section 4 for file formats (linux/freebsd use +# section 5). Automake can deal cleanly with man page sections 1-8 +# and n, but NOT with sections of the form 1m. +extra_MANS = smartd.conf.4 \ + smartctl.1m \ + smartd.1m +if ENABLE_UPDATE_SMART_DRIVEDB +extra_MANS += update-smart-drivedb.1m +endif + +all-local: $(extra_MANS) +install-man: $(extra_MANS) + @$(NORMAL_INSTALL) + $(MKDIR_P) '$(DESTDIR)$(mandir)/man4' + $(MKDIR_P) '$(DESTDIR)$(mandir)/man1m' + for i in $(extra_MANS); do \ + if test -f $(srcdir)/$$i; then file=$(srcdir)/$$i; \ + else file=$$i; fi; \ + ext=`echo $$i | sed -e 's/^.*\\.//'`; \ + inst=`echo $$i | sed -e 's/\\.[0-9a-z]*$$//'`; \ + inst=`echo $$inst | sed -e 's/^.*\///'`; \ + inst=`echo $$inst | sed '$(transform)'`.$$ext; \ + echo " $(INSTALL_DATA) '$$file' '$(DESTDIR)$(mandir)/man$$ext/$$inst'"; \ + $(INSTALL_DATA) "$$file" "$(DESTDIR)$(mandir)/man$$ext/$$inst"; \ + done +uninstall-man: + @$(NORMAL_UNINSTALL) + for i in $(extra_MANS); do \ + if test -f $(srcdir)/$$i; then file=$(srcdir)/$$i; \ + else file=$$i; fi; \ + ext=`echo $$i | sed -e 's/^.*\\.//'`; \ + inst=`echo $$i | sed -e 's/\\.[0-9a-z]*$$//'`; \ + inst=`echo $$inst | sed -e 's/^.*\///'`; \ + inst=`echo $$inst | sed '$(transform)'`.$$ext; \ + echo " rm -f '$(DESTDIR)$(mandir)/man$$ext/$$inst'"; \ + rm -f "$(DESTDIR)$(mandir)/man$$ext/$$inst"; \ + done +else +# For systems that adopts traditional manner + +man_MANS = smartd.conf.5 \ + smartctl.8 \ + smartd.8 + +if ENABLE_UPDATE_SMART_DRIVEDB +man_MANS += update-smart-drivedb.8 +endif + +endif + +docsdir=$(docdir) +docs_DATA = \ + AUTHORS \ + ChangeLog \ + ChangeLog-6.0-7.0 \ + COPYING \ + INSTALL \ + NEWS \ + README \ + TODO \ + smartd.conf + +examplesdir=$(exampledir) +examples_DATA = \ + examplescripts/README +examples_SCRIPTS = \ + examplescripts/Example1 \ + examplescripts/Example2 \ + examplescripts/Example3 \ + examplescripts/Example4 \ + examplescripts/Example5 \ + examplescripts/Example6 \ + examplescripts/Example7 \ + examplescripts/Example8 + +sysconf_DATA = smartd.conf + +# If modified smartd.conf exists install smartd.conf.sample instead +install-sysconfDATA: $(sysconf_DATA) + $(MKDIR_P) '$(DESTDIR)$(sysconfdir)' + @s="$(srcdir)/smartd.conf"; \ + f="$(DESTDIR)$(sysconfdir)/smartd.conf$(smartd_suffix)"; \ + if test -z "$(smartd_suffix)" && test -f "$$f"; then \ + if cmp "$$s" "$$f" >/dev/null 2>/dev/null; then :; else \ + echo "************************************************************"; \ + echo "*** $$f preserved"; \ + echo "*** installing smartd.conf.sample instead"; \ + echo "************************************************************"; \ + f="$$f".sample; \ + fi; \ + fi; \ + echo " $(INSTALL_DATA) '$$s' '$$f'"; \ + $(INSTALL_DATA) "$$s" "$$f" + +# If smartd.conf.sample exists preserve smartd.conf +uninstall-sysconfDATA: + @f="$(DESTDIR)$(sysconfdir)/smartd.conf$(smartd_suffix)"; \ + if test -z "$(smartd_suffix)" && test -f "$$f".sample; then \ + echo "************************************************************"; \ + echo "*** $$f preserved"; \ + echo "*** removing smartd.conf.sample instead"; \ + echo "************************************************************"; \ + f="$$f".sample; \ + fi; \ + echo " rm -f '$$f'"; \ + rm -f "$$f" + +smartdscript_SCRIPTS = smartd_warning.sh + +EXTRA_DIST = \ + .editorconfig \ + autogen.sh \ + ChangeLog-5.0-6.0 \ + cppcheck.sh \ + smartd.initd.in \ + smartd.cygwin.initd.in \ + smartd.freebsd.initd.in \ + smartd.8.in \ + smartctl.8.in \ + smartd.conf.5.in \ + smartd.conf \ + smartd.service.in \ + smartd_warning.sh.in \ + update-smart-drivedb.in \ + update-smart-drivedb.8.in \ + m4/pkg.m4 \ + os_darwin/com.smartmontools.smartd.plist.in \ + os_darwin/pkg/PackageInfo.in \ + os_darwin/pkg/Distribution.in \ + os_darwin/pkg/installer/README.html \ + os_darwin/pkg/root/usr/local/sbin/smart-pkg-uninstall \ + os_win32/default.manifest \ + os_win32/installer.nsi \ + os_win32/runcmd.c \ + os_win32/smartd_mailer.ps1 \ + os_win32/smartd_mailer.conf.sample.ps1 \ + os_win32/smartd_warning.cmd \ + os_win32/syslogevt.mc \ + os_win32/update-smart-drivedb.ps1.in \ + os_win32/versioninfo.rc.in \ + os_win32/wtssendmsg.c \ + $(docs_DATA) \ + $(examples_DATA) \ + $(examples_SCRIPTS) + +CLEANFILES = \ + smartd.8 \ + smartd.1m \ + smartd.8.html \ + smartd.8.html.tmp \ + smartd.8.pdf \ + smartd.8.txt \ + smartctl.8 \ + smartctl.1m \ + smartctl.8.html \ + smartctl.8.html.tmp \ + smartctl.8.pdf \ + smartctl.8.txt \ + smartd.conf.5 \ + smartd.conf.4 \ + smartd.conf.5.html \ + smartd.conf.5.html.tmp \ + smartd.conf.5.pdf \ + smartd.conf.5.txt \ + smartd.initd \ + smartd.cygwin.initd \ + smartd.freebsd.initd \ + smartd.service \ + smartd_warning.sh \ + svnversion.h \ + update-smart-drivedb \ + update-smart-drivedb.8 \ + update-smart-drivedb.1m \ + update-smart-drivedb.8.html \ + update-smart-drivedb.8.html.tmp \ + update-smart-drivedb.8.pdf \ + update-smart-drivedb.8.txt \ + SMART + +# 'make maintainer-clean' also removes files generated by './autogen.sh' +MAINTAINERCLEANFILES = \ + $(srcdir)/Makefile.in \ + $(srcdir)/aclocal.m4 \ + $(srcdir)/compile \ + $(srcdir)/configure \ + $(srcdir)/config.guess \ + $(srcdir)/config.h.in \ + $(srcdir)/config.h.in~ \ + $(srcdir)/config.sub \ + $(srcdir)/depcomp \ + $(srcdir)/install-sh \ + $(srcdir)/missing \ + $(srcdir)/m4/pkg.m4 + +smartctl.o utility.o: svnversion.h + +if IS_SVN_BUILD +# Get version info from SVN +svnversion.h: ChangeLog Makefile $(svn_deps) + @echo ' svn info | $$(VERSION_FROM_SVN_INFO) > $@' + @echo '/* svnversion.h. Generated by Makefile from svn info. */' > $@ + @(cd $(srcdir) \ + && svnversion 2>/dev/null | sed -n 's,^\([0-9][:0-9A-Z]*\).*$$,REV "\1",p' \ + && TZ= LC_ALL=C svn info 2>/dev/null \ + | sed -n 'h;s,^.* Date: *\([^ ]*\) .*$$,DATE "\1",p;g;s,^.* Date: *[^ ]* *\([^ ]*\) .*$$,TIME "\1",p') \ + | sed 's,^,#define SMARTMONTOOLS_SVN_,' >> $@ +else + +# SVN not available, guess version info from Id strings +svnversion.h: ChangeLog Makefile NEWS + @echo ' cat ChangeLog NEWS $$(SOURCES) | $$(VERSION_FROM_SVN_IDS) > $@' + @echo '/* svnversion.h. Generated by Makefile from Id strings. */' > $@ + @(cd $(srcdir) && cat ChangeLog NEWS Makefile.am configure.ac smart*.in *.cpp *.h) \ + | sed -n 's,^.*\$$[I][d]: [^ ]* \([0-9][0-9]* [0-9][-0-9]* [0-9][:0-9]*\)[^:0-9][^$$]*\$$.*$$,\1,p' \ + | sort -n -r \ + | sed -n 'h;s,^\([^ ]*\) .*$$,REV "\1",p;g;s,^[^ ]* \([^ ]*\) .*$$,DATE "\1",p;g;s,^[^ ]* [^ ]* \([^ ]*\)$$,TIME "\1",p;q' \ + | sed 's,^,#define SMARTMONTOOLS_SVN_,' >> $@ +endif + + +if ENABLE_DRIVEDB +drivedbinst_DATA = drivedb.h +endif + +update-smart-drivedb: update-smart-drivedb.in config.status + $(SHELL) ./config.status --file=$@ + chmod +x $@ + +smartd_warning.sh: smartd_warning.sh.in config.status + $(SHELL) ./config.status --file=$@ + chmod +x $@ + +if INSTALL_INITSCRIPT +if OS_DARWIN +initd_DATA = com.smartmontools.smartd.plist + +initd_DATA_install = install-initdDATA-darwin +initd_DATA_uninstall = uninstall-initdDATA-darwin + +com.smartmontools.smartd.plist : os_darwin/com.smartmontools.smartd.plist.in + sed "s|/usr/sbin/|$(sbindir)/|" $< > $@ + +install-initdDATA-darwin: $(initd_DATA) + $(MKDIR_P) '$(DESTDIR)$(initddir)' + $(INSTALL_DATA) $(top_builddir)/$(initd_DATA) $(DESTDIR)$(initddir)/$(initd_DATA) + +uninstall-initdDATA-darwin: + rm -f $(DESTDIR)$(initddir)/$(initd_DATA) + +else + +initd_DATA = $(initdfile) + +$(initdfile): $(srcdir)/$(initdfile).in Makefile + sed 's|/usr/local/sbin/|$(sbindir)/|g' $(srcdir)/$(initdfile).in > $@ + +initd_install_name = smartd$(smartd_suffix) + +initd_DATA_install = install-initdDATA-generic +initd_DATA_uninstall = uninstall-initdDATA-generic + +install-initdDATA-generic: $(initd_DATA) + $(MKDIR_P) '$(DESTDIR)$(initddir)' + $(INSTALL_SCRIPT) '$(top_builddir)/$(initdfile)' '$(DESTDIR)$(initddir)/smartd$(smartd_suffix)' + +uninstall-initdDATA-generic: + rm -f '$(DESTDIR)$(initddir)/$(initd_install_name)' +endif +else + +initd_DATA_install = install-initdDATA-null +initd_DATA_uninstall = uninstall-initdDATA-null + +install-initdDATA-null: +uninstall-initdDATA-null: +endif + +install-initdDATA : $(initd_DATA_install) + +uninstall-initdDATA: $(initd_DATA_uninstall) + +if INSTALL_SYSTEMDUNIT +systemdsystemunit_DATA = smartd.service +endif + +smartd.service: smartd.service.in Makefile + @echo ' $$(SMARTD_SERVICE_FILTER) < $(srcdir)/smartd.service.in > $@' + @{ \ + sed 's|/usr/local/sbin/smartd|$(sbindir)/smartd|' | \ + if test -n '$(SYSTEMD_LDADD)'; then \ + cat; \ + else \ + sed '/^Type=notify/d'; \ + fi | \ + if test -n '$(systemdenvfile)'; then \ + sed 's|/usr/local/etc/sysconfig/smartmontools|$(systemdenvfile)|'; \ + else \ + sed -e '/^EnvironmentFile=/d' -e 's| *\$$smartd[_a-z]* *||g'; \ + fi; } < $(srcdir)/smartd.service.in > $@ + + +# Create empty directories if configured. +# Default install rules no longer create empty directories since automake 1.11. +installdirs-local: + @for d in '$(smartdplugindir)' '$(drivedbdir)' '$(savestatesdir)' '$(attributelogdir)'; do \ + test -n "$$d" || continue; \ + echo " $(MKDIR_P) '$(DESTDIR)$$d'"; \ + $(MKDIR_P) "$(DESTDIR)$$d" || exit 1; \ + done + +install-data-local: installdirs-local + +# +# Build man pages +# +MAN_FILTER = { \ + sed -e 's|CURRENT_SVN_VERSION|$(releaseversion)|g' \ + -e "s|CURRENT_SVN_DATE|`sed -n 's,^.*DATE[^"]*"\([^"]*\)".*$$,\1,p' svnversion.h`|g" \ + -e "s|CURRENT_SVN_REV|`sed -n 's,^.*REV[^"]*"\([^"]*\)".*$$,r\1,p' svnversion.h`|g" \ + -e 's|/usr/local/share/man/|$(mandir)/|g' \ + -e 's|/usr/local/sbin/|$(sbindir)/|g' \ + -e 's|/usr/local/share/doc/smartmontools/examplescripts/|!exampledir!|g' \ + -e 's|/usr/local/share/doc/smartmontools/|$(docsdir)/|g' \ + -e 's|!exampledir!|$(exampledir)/|g' \ + -e 's|/usr/local/etc/smartd\.conf|$(sysconfdir)/smartd.conf|g' \ + -e 's|/usr/local/etc/smart_drivedb\.h|$(sysconfdir)/smart_drivedb.h|g' \ + -e 's|/usr/local/etc/smartd_warning\.sh|$(smartdscriptdir)/smartd_warning.sh|g' \ + -e 's|\\fBmail\\fP|\\fB$(os_mailer)\\fP|g' \ + -e 's|\\'\''mail\\'\''|\\'\''$(os_mailer)\\'\''|g' \ + -e 's|/usr/bin/mail|/usr/bin/$(os_mailer)|g' \ + -e 's|RELEASE_6_0_DRIVEDB|$(DRIVEDB_BRANCH)|g' | \ + if test -n '$(drivedbdir)'; then \ + sed -e 's|/usr/local/share/smartmontools/drivedb\.h|$(drivedbinstdir)/drivedb.h|g' \ + -e 's|/usr/local/var/lib/smartmontools/drivedb\.h|$(drivedbdir)/drivedb.h|g' ; \ + else \ + sed '/^\.\\" %IF ENABLE_DRIVEDB/,/^\.\\" %ENDIF ENABLE_DRIVEDB/ s,^,.\\"\# ,' ; \ + fi | \ + if test '$(drivedbinstdir)' != '$(drivedbdir)'; then \ + cat; \ + else \ + sed '/^\.\\" %IF ENABLE_DB_INSTALL/,/^\.\\" %ENDIF ENABLE_DB_INSTALL/ s,^,.\\"\# ,' ; \ + fi | \ + if test '$(with_update_smart_drivedb)' = 'yes'; then \ + cat; \ + else \ + sed '/^\.\\" %IF ENABLE_UPDATE_SMART_DRIVEDB/,/^\.\\" %ENDIF ENABLE_UPDATE_SMART_DRIVEDB/ s,^,.\\"\# ,' ; \ + fi | \ + if test -n '$(initddir)'; then \ + sed 's|/usr/local/etc/rc\.d/init\.d/|$(initddir)/|g' ; \ + else \ + sed '/^\.\\" %IF ENABLE_INITSCRIPT/,/^\.\\" %ENDIF ENABLE_INITSCRIPT/ s,^,.\\"\# ,' ; \ + fi | \ + if test -n '$(savestates)'; then \ + sed 's|/usr/local/var/lib/smartmontools/smartd\.|$(savestates)|g' ; \ + else \ + sed '/^\.\\" %IF ENABLE_SAVESTATES/,/^\.\\" %ENDIF ENABLE_SAVESTATES/ s,^,.\\"\# ,' ; \ + fi | \ + if test -n '$(attributelog)'; then \ + sed 's|/usr/local/var/lib/smartmontools/attrlog\.|$(attributelog)|g' ; \ + else \ + sed '/^\.\\" %IF ENABLE_ATTRIBUTELOG/,/^\.\\" %ENDIF ENABLE_ATTRIBUTELOG/ s,^,.\\"\# ,' ; \ + fi | \ + if test -n '$(smartdplugindir)'; then \ + sed 's|/usr/local/etc/smartd_warning\.d|$(smartdplugindir)|g' ; \ + else \ + sed '/^\.\\" %IF ENABLE_SMARTDPLUGINDIR/,/^\.\\" %ENDIF ENABLE_SMARTDPLUGINDIR/ s,^,.\\"\# ,' ; \ + fi | \ + if test -n '$(CAPNG_LDADD)'; then \ + cat; \ + else \ + sed '/^\.\\" %IF ENABLE_CAPABILITIES/,/^\.\\" %ENDIF ENABLE_CAPABILITIES/ s,^,.\\"\# ,' ; \ + fi | \ + if test -n '$(SYSTEMD_LDADD)'; then \ + cat; \ + else \ + sed '/^\.\\" %IF ENABLE_SYSTEMD_NOTIFY/,/^\.\\" %ENDIF ENABLE_SYSTEMD_NOTIFY/ s,^,.\\"\# ,' ; \ + fi | \ + if test '$(with_nvme_devicescan)' = 'yes'; then \ + cat; \ + else \ + sed '/^\.\\" %IF ENABLE_NVME_DEVICESCAN/,/^\.\\" %ENDIF ENABLE_NVME_DEVICESCAN/ s,^,.\\"\# ,' ; \ + fi | \ + if test -n '$(os_man_filter)'; then \ + sed -e 's,OS_MAN_FILTER,$(os_man_filter),g' \ + -e '/^\.\\" %IF NOT OS .*$(os_man_filter)/,/^.\\" %ENDIF NOT OS .*$(os_man_filter)/ s,^,.\\"\# ,' \ + -e '/^\.\\" %IF OS .*$(os_man_filter)/,/^\.\\" %ENDIF OS .*$(os_man_filter)/ s,^,!!,' \ + -e '/^\.\\" %IF OS ./,/^\.\\" %ENDIF OS ./ s,^,.\\"\# ,' \ + -e '/^!*\.\\" %IF NOT OS ./,/^!*\.\\" %ENDIF NOT OS ./ s,^,!!,' \ + -e 's,^!!!*\.\\"! \(.*\)$$,\1 \\"\#,' \ + -e 's,^!!!*,,' ; \ + else \ + cat; \ + fi; } + +# Implicit rule 'smart%: smart%.in ...' does not work with BSD make +smartctl.8: smartctl.8.in Makefile svnversion.h + @echo ' $$(MAN_FILTER) < $(srcdir)/smartctl.8.in > $@' + @$(MAN_FILTER) < $(srcdir)/smartctl.8.in > $@ + +smartd.8: smartd.8.in Makefile svnversion.h + @echo ' $$(MAN_FILTER) < $(srcdir)/smartd.8.in > $@' + @$(MAN_FILTER) < $(srcdir)/smartd.8.in > $@ + +smartd.conf.5: smartd.conf.5.in Makefile svnversion.h + @echo ' $$(MAN_FILTER) < $(srcdir)/smartd.conf.5.in > $@' + @$(MAN_FILTER) < $(srcdir)/smartd.conf.5.in > $@ + +update-smart-drivedb.8: update-smart-drivedb.8.in Makefile svnversion.h + @echo ' $$(MAN_FILTER) < $(srcdir)/update-smart-drivedb.8.in > $@' + @$(MAN_FILTER) < $(srcdir)/update-smart-drivedb.8.in > $@ + +# Build Solaris specific man pages +SOLARIS_MAN_FILTER = \ + sed -e '/^\.TH/s, \([58]\) , !!\1!! ,' \ + -e '/^\.BR/s, (\([578]\)), (!!\1!!),' \ + -e 's,\\fP(\([578]\)),\\fP(!!\1!!),g' \ + -e 's,!!5!!,4,g' -e 's,!!7!!,5,g' -e 's,!!8!!,1m,g' \ + -e 's,/var/log/messages,/var/adm/messages,g' + +smartctl.1m: smartctl.8 + @echo ' $$(SOLARIS_MAN_FILTER) < smartctl.8 > $@' + @$(SOLARIS_MAN_FILTER) < smartctl.8 > $@ + +smartd.1m: smartd.8 + @echo ' $$(SOLARIS_MAN_FILTER) < smartd.8 > $@' + @$(SOLARIS_MAN_FILTER) < smartd.8 > $@ + +smartd.conf.4: smartd.conf.5 + @echo ' $$(SOLARIS_MAN_FILTER) < smartd.conf.5 > $@' + @$(SOLARIS_MAN_FILTER) < smartd.conf.5 > $@ + +update-smart-drivedb.1m: update-smart-drivedb.8 + @echo ' $$(SOLARIS_MAN_FILTER) < update-smart-drivedb.8 > $@' + @$(SOLARIS_MAN_FILTER) < update-smart-drivedb.8 > $@ + + +# Convert man pages into .html, .pdf and .txt +# TODO: configure +MAN2HTML = man2html +#MAN2HTML = groff -man -Thtml +MAN2PDF = man -Tpdf -l +#MAN2PDF = groff -man -Tpdf +MAN2TXT = groff -man -Tascii -P'-bcou' + +# Remove HTTP header and fix links in man2html output +FIXHTML = sed -e '1s,^Content-type.*,,' \ + -e 's,<A HREF="[^"]*/man2html?\([1-8]\)+\(smart[cd][.a-z]*\)">,<A HREF="\2.\1.html">,g' \ + -e 's,<A HREF="[^"]*/man2html">,<A HREF=".">,g' \ + -e 's,<A HREF="[^"]*/man2html?[^"]*">\([^<]*\)</A>,\1,g' \ + -e 's,<A HREF="mailto:[^s][^m][^a][^"]*">\([^<]*\)</A>,\1,g' + +htmlman: smartctl.8.html smartd.8.html smartd.conf.5.html update-smart-drivedb.8.html + +pdfman: smartctl.8.pdf smartd.8.pdf smartd.conf.5.pdf update-smart-drivedb.8.pdf + +txtman: smartctl.8.txt smartd.8.txt smartd.conf.5.txt update-smart-drivedb.8.txt + +%.5.html: %.5 + $(MAN2HTML) $< > $@.tmp + @echo ' $$(FIXHTML) < $@.tmp > $@' + @$(FIXHTML) < $@.tmp > $@ + +%.8.html: %.8 + $(MAN2HTML) $< > $@.tmp + @echo ' $$(FIXHTML) < $@.tmp > $@' + @$(FIXHTML) < $@.tmp > $@ + +%.5.pdf: %.5 + $(MAN2PDF) $< > $@ + +%.8.pdf: %.8 + $(MAN2PDF) $< > $@ + +%.5.txt: %.5 + $(MAN2TXT) $< > $@ + +%.8.txt: %.8 + $(MAN2TXT) $< > $@ + + +# Check drive database syntax +check: + @if ./smartctl -P showall >/dev/null && \ + ./smartctl -B $(srcdir)/drivedb.h -P showall >/dev/null; then \ + echo "$(srcdir)/drivedb.h: OK"; \ + else \ + echo "$(srcdir)/drivedb.h: Syntax check failed"; exit 1; \ + fi + +# Create cppcheck report +cppcheck: cppcheck.txt + +CPPCHECKFLAGS= +cppcheck.txt: $(smartctl_SOURCES) $(EXTRA_smartctl_SOURCES) \ + $(smartd_SOURCES) $(EXTRA_smartd_SOURCES) + $(srcdir)/cppcheck.sh $(CPPCHECKFLAGS) > $@ + + +if OS_WIN32_MINGW +# Windows resources + +smartctl_res.o: smartctl_res.rc $(os_win32_manifest) + $(WINDRES) $< $@ + +smartd_res.o: smartd_res.rc syslogevt.rc $(os_win32_manifest) + $(WINDRES) $< $@ + +runcmda_res.o: runcmda_res.rc defadmin.manifest + $(WINDRES) $< $@ + +runcmdu_res.o: runcmdu_res.rc $(os_win32_manifest) + $(WINDRES) $< $@ + +wtssendmsg_res.o: wtssendmsg_res.rc $(os_win32_manifest) + $(WINDRES) $< $@ + +# Convert version for VERSIONINFO resource: 6.6 r4519 -> 6.6.0.4519, +# set description, name, version and year +WIN_RC_FILTER = { \ + ver=`echo '$(PACKAGE_VERSION).0' | sed -n 's,^\([0-9]*\.[0-9]*\.[0-9]*\).*$$,\1,p'` && \ + rev=`sed -n 's,^.*REV[^"]*"\([0-9]*\).*$$,\1,p' svnversion.h` && \ + txtver="$${ver:-0.0.0}.$${rev:-0}" && binver=`echo "$$txtver" | sed 's|\.|,|g'` && \ + yy=`sed -n 's,^.*DATE[^"]*"20\([0-9][0-9]\).*$$,\1,p' svnversion.h` && yy="$${yy:-XX}" && \ + sed -e "s|@DESC@|$$d|" -e "s|@NAME@|$$n|" -e "s|@BINARY_VERSION@|$$binver|g" \ + -e "s|@TEXT_VERSION@|$$txtver|g" -e "s|@YY@|$$yy|g"; } + +WIN_MAKE_RES = \ + echo "n=$$n d=\"$$d"'"; $$(WIN_RC_FILTER) < $< > $@'; \ + $(WIN_RC_FILTER) < $< > $@ + +WIN_APP_MANIFEST = \ + if test -n '$(os_win32_manifest)'; then \ + echo "echo '1 24 \"$(srcdir)/$(os_win32_manifest)\"' >> $@"; \ + echo '1 24 "$(srcdir)/$(os_win32_manifest)"' >> $@; \ + fi + +smartctl_res.rc: os_win32/versioninfo.rc.in Makefile svnversion.h + @n=smartctl d="Control and Monitor Utility for SMART Disks"; $(WIN_MAKE_RES) + @$(WIN_APP_MANIFEST) + +smartd_res.rc: os_win32/versioninfo.rc.in Makefile svnversion.h + @n=smartd d="SMART Disk Monitoring Daemon"; $(WIN_MAKE_RES) + echo '#include "./syslogevt.rc"' >> $@ + @$(WIN_APP_MANIFEST) + +runcmdu_res.rc: os_win32/versioninfo.rc.in Makefile svnversion.h + @n=runcmdu d="Run console command"; $(WIN_MAKE_RES) + @$(WIN_APP_MANIFEST) + +runcmda_res.rc: os_win32/versioninfo.rc.in Makefile svnversion.h + @n=runcmda d="Run console command as admin"; $(WIN_MAKE_RES) + echo '1 24 "./defadmin.manifest"' >> $@ + +wtssendmsg_res.rc: os_win32/versioninfo.rc.in Makefile svnversion.h + @n=wtssendmsg d="Send console messages"; $(WIN_MAKE_RES) + @$(WIN_APP_MANIFEST) + +syslogevt.rc: os_win32/syslogevt.mc + @if test -n '$(WINDMC)'; then \ + echo '$(WINDMC) -b $<'; \ + $(WINDMC) -b $<; \ + else \ + echo "echo '// MESSAGETABLE not available' > $@"; \ + echo '// MESSAGETABLE not available' > $@; \ + fi + +defadmin.manifest: os_win32/default.manifest + sed 's,"asInvoker","requireAdministrator",' $< > $@ + +# Definitions for Windows distribution + +if OS_WIN64 +win_bits = 64 +else +win_bits = 32 +endif + +distdir_win32 = $(PACKAGE)-$(VERSION).win$(win_bits) +distzip_win32 = $(PACKAGE)-$(VERSION).win$(win_bits).zip +distinst_win32 = $(PACKAGE)-$(VERSION).win$(win_bits)-setup.exe + +exedir_win32 = $(distdir_win32)/bin +docdir_win32 = $(distdir_win32)/doc + +EXEFILES_WIN32 = \ + $(exedir_win32)/smartctl.exe \ + $(exedir_win32)/smartctl-nc.exe \ + $(exedir_win32)/smartd.exe \ + $(exedir_win32)/smartd_mailer.ps1 \ + $(exedir_win32)/smartd_mailer.conf.sample.ps1 \ + $(exedir_win32)/smartd_warning.cmd \ + $(exedir_win32)/runcmda.exe \ + $(exedir_win32)/runcmdu.exe \ + $(exedir_win32)/wtssendmsg.exe + +if ENABLE_DRIVEDB +EXEFILES_WIN32 += \ + $(exedir_win32)/update-smart-drivedb.ps1 +endif + +FILES_WIN32 = \ + $(EXEFILES_WIN32) \ + $(docdir_win32)/AUTHORS.txt \ + $(docdir_win32)/ChangeLog.txt \ + $(docdir_win32)/ChangeLog-6.0-7.0.txt \ + $(docdir_win32)/COPYING.txt \ + $(docdir_win32)/INSTALL.txt \ + $(docdir_win32)/NEWS.txt \ + $(docdir_win32)/README.txt \ + $(docdir_win32)/TODO.txt \ + $(docdir_win32)/checksums$(win_bits).txt \ + $(docdir_win32)/smartd.conf \ + $(docdir_win32)/smartctl.8.html \ + $(docdir_win32)/smartctl.8.pdf \ + $(docdir_win32)/smartd.8.html \ + $(docdir_win32)/smartd.8.pdf \ + $(docdir_win32)/smartd.conf.5.html \ + $(docdir_win32)/smartd.conf.5.pdf + +if ENABLE_DRIVEDB +FILES_WIN32 += \ + $(exedir_win32)/drivedb.h +endif + +CLEANFILES += \ + $(FILES_WIN32) \ + defadmin.manifest \ + distdir.mkdir \ + runcmda.exe runcmda_res.rc \ + runcmdu.exe runcmdu_res.rc \ + smartctl-nc.exe smartctl-nc.exe.tmp \ + smartctl_res.rc smartd_res.rc \ + syslogevt.h \ + syslogevt.rc syslogevt_*.bin \ + update-smart-drivedb.ps1 \ + wtssendmsg.exe wtssendmsg_res.rc + +# Note: Only use without options to be compatible with all variants +UNIX2DOS = unix2dos + +# Build Windows distribution + +dist-win32: $(distzip_win32) + +install-win32: $(distinst_win32) + ./$(distinst_win32) + +installer-win32: $(distinst_win32) + +distdir-win32: distdir.mkdir $(FILES_WIN32) + +$(distzip_win32): distdir.mkdir $(FILES_WIN32) + @rm -fv $(distzip_win32) + cd $(distdir_win32) && zip -9 ../$(distzip_win32) bin/* doc/* + md5sum $@ > $@.md5 + sha1sum $@ > $@.sha1 + sha256sum $@ > $@.sha256 + +# Build NSIS installer +# Note: Only option character '-' is also compatible with Linux version of makensis +$(distinst_win32): os_win32/installer.nsi smartctl_res.rc distdir.mkdir $(FILES_WIN32) + @test -n '$(MAKENSIS)' || ! echo 'makensis: command not found (https://nsis.sourceforge.io)' + test -z '$(builddir_win64)' || ( cd $(builddir_win64) && make distdir-win32 ) + @date=`sed -n 's,^.*DATE[^"]*"\([^"]*\)".*$$,\1,p' svnversion.h` && \ + rev=`sed -n 's,^.*REV[^"]*"\([^"]*\)".*$$,r\1,p' svnversion.h` && \ + version=`sed -n 's|^ *VALUE "FileVersion", "\([0-9.]*\)".*$$|\1|p' smartctl_res.rc` && \ + yy=`echo "$$date" | sed -n 's,^20\([0-9][0-9]\).*$$,\1,p'`; yy="$${yy:-XX}" && \ + verstr="$(PACKAGE_VERSION) $$date $$rev "$(BUILD_INFO) && \ + d64= && if [ -n '$(builddir_win64)' ]; then d64='-DINPDIR64=$(builddir_win64)/$(PACKAGE)-$(VERSION).win64'; fi && \ + echo "'$(MAKENSIS)' -V2 -NOCD -DINPDIR=$(distdir_win32) $$d64 -DOUTFILE=$@ -DVERSION=$$version -DYY=$$yy -DVERSTR='$$verstr' $<" && \ + '$(MAKENSIS)' -V2 -NOCD -DINPDIR=$(distdir_win32) $$d64 -DOUTFILE=$@ -DVERSION=$$version -DYY=$$yy -DVERSTR="$$verstr" $< + md5sum $@ > $@.md5 + sha1sum $@ > $@.sha1 + sha256sum $@ > $@.sha256 + +cleandist-win32: + rm -rf $(distdir_win32) distdir.mkdir + +distdir.mkdir: + @test -d $(exedir_win32) || mkdir -pv $(exedir_win32) + @test -d $(docdir_win32) || mkdir -pv $(docdir_win32) + touch $@ + +$(exedir_win32)/%.exe: %.exe + cp -p $< $@ + if test -n '$(STRIP)'; then $(STRIP) -s $@; else strip -s $@; fi + touch -r $< $@ + +$(exedir_win32)/%.h: $(srcdir)/%.h + $(UNIX2DOS) < $< > $@ + touch -r $< $@ + +$(exedir_win32)/%.cmd: $(srcdir)/os_win32/%.cmd + $(UNIX2DOS) < $< > $@ + touch -r $< $@ + +$(exedir_win32)/%.ps1: $(srcdir)/os_win32/%.ps1 + $(UNIX2DOS) < $< > $@ + touch -r $< $@ + +$(exedir_win32)/%.ps1: %.ps1 + $(UNIX2DOS) < $< > $@ + touch -r $< $@ + +$(docdir_win32)/%.html: %.html + $(UNIX2DOS) < $< > $@ + touch -r $< $@ + +$(docdir_win32)/%.pdf: %.pdf + cp -p $< $@ + +$(docdir_win32)/%.txt: $(srcdir)/% + $(UNIX2DOS) < $< > $@ + touch -r $< $@ + +$(docdir_win32)/%.conf: $(srcdir)/%.conf + $(UNIX2DOS) < $< > $@ + touch -r $< $@ + +$(docdir_win32)/checksums$(win_bits).txt: $(EXEFILES_WIN32) + (cd $(exedir_win32) && for algo in md5 sha1 sha256; do $${algo}sum *.exe *.cmd *.ps1; done) \ + | $(UNIX2DOS) > $@ + +# Build non-console version of smartctl for GSmartControl. +# The script below changes the word at offset 220 (Subsystem) from 3 +# (Console) to 2 (GUI) in a copy of smartctl.exe. +# This will be changed when a tool (like 'editbin') is available in +# the Cygwin distribution +smartctl-nc.exe: smartctl.exe + @rm -f $@ + cp -p smartctl.exe $@.tmp + @if test `od -A n -j 220 -N 2 -d $@.tmp` -eq 3; then :; \ + else echo "invalid EXE header"; exit 1; fi + @echo "editbin /subsystem:windows $@.tmp" + @echo -ne '\002' | dd bs=1 seek=220 count=1 conv=notrunc of=$@.tmp 2>/dev/null + @if test `od -A n -j 220 -N 2 -d $@.tmp` -eq 2; then :; \ + else echo "EXE patch failed"; exit 1; fi + mv -f $@.tmp $@ + +# Build runcmd?.exe and wtssendmsg.exe +runcmd.o: os_win32/runcmd.c + $(CC) -c -Os $< + +runcmdu.exe: runcmd.o runcmdu_res.o + $(CC) -o $@ $^ + +runcmda.exe: runcmd.o runcmda_res.o + $(CC) -o $@ $^ + +wtssendmsg.exe: os_win32/wtssendmsg.c wtssendmsg_res.o + $(CC) -Os -o $@ $^ -lwtsapi32 + +# Build drivedb.h update script +update-smart-drivedb.ps1: os_win32/update-smart-drivedb.ps1.in config.status + $(SHELL) ./config.status --file=$@:$< + +# MSVC Version to change in make command line +vc = 17 +vcver = $(vc) + +.PHONY: check-vc-version clean-vc config-vc distclean-vc maintainer-clean-vc + +check-vc-version: + @case '$(vcver)' in \ + 16|17) test -d '$(srcdir)/os_win32/vc$(vcver)' || \ + { echo '$(srcdir)/os_win32/vc$(vcver): Not found (not included in src tarball)' >&2; exit 1; } ;; \ + *) echo 'Usage: $(MAKE) vc=16|17 config-vc clean-vc distclean-vc maintainer-clean-vc'; exit 1 ;; \ + esac + +# Build os_win32/vcNN/{config.h,smart*.rc,svnversion.h} for MSVCNN from MinGW files + +CONFIG_VC_FILES = \ + $(srcdir)/os_win32/vc$(vcver)/config.h \ + $(srcdir)/os_win32/vc$(vcver)/smartctl_res.rc \ + $(srcdir)/os_win32/vc$(vcver)/smartd_res.rc \ + $(srcdir)/os_win32/vc$(vcver)/svnversion.h + +config-vc: check-vc-version $(CONFIG_VC_FILES) + +$(srcdir)/os_win32/vc$(vcver)/config.h: config.h Makefile + sed -e '1i/* os_win32/vc$(vcver)/config.h. Generated from config.h by Makefile. */' \ + -e 's,^#define HAVE_\(ATTR_PACKED\|CLOCK_GETTIME\|GETTIMEOFDAY\|__INT128\|LONG_DOUBLE_WIDER\|STRINGS_H\|UNISTD_H\) 1.*$$,/* #undef HAVE_\1 */ /* VC$(vcver) */,' \ + -e 's,^\(#define SMARTMONTOOLS_BUILD_HOST "[^-]*\)[^"]*,\1-pc-w32vc$(vcver),' $< > $@ + +$(srcdir)/os_win32/vc$(vcver)/svnversion.h: svnversion.h + cp $< $@ + +$(srcdir)/os_win32/vc$(vcver)/smartctl_res.rc: smartctl_res.rc + sed '/^1 24 /d' $< > $@ + +$(srcdir)/os_win32/vc$(vcver)/smartd_res.rc: smartd_res.rc + sed '/^1 24 /d' $< > $@ + +clean-vc: check-vc-version + rm -f $(srcdir)/os_win32/vc$(vcver)/.vs/smartmontools/v$(vcver)/Browse.VC.opendb + rm -f $(srcdir)/os_win32/vc$(vcver)/.vs/smartmontools/v$(vcver)/*.VC.db* + rm -rf $(srcdir)/os_win32/vc$(vcver)/.vs/smartmontools/v$(vcver)/ipch + rm -f $(srcdir)/os_win32/vc$(vcver)/syslogevt.h + rm -rf $(srcdir)/os_win32/vc$(vcver)/Debug + rm -rf $(srcdir)/os_win32/vc$(vcver)/Debug-static + rm -rf $(srcdir)/os_win32/vc$(vcver)/Release + rm -rf $(srcdir)/os_win32/vc$(vcver)/Release-static + rm -rf $(srcdir)/os_win32/vc$(vcver)/x64 + +distclean-vc: clean-vc + rm -f $(CONFIG_VC_FILES) + +maintainer-clean-vc: distclean-vc + rm -f $(srcdir)/os_win32/vc$(vcver)/*.vcxproj.user + rm -rf $(srcdir)/os_win32/vc$(vcver)/.vs + +endif + + +if OS_DARWIN +# Definitions for OSX distribution +distdir_darwin = $(PACKAGE)-$(VERSION).darwin +dmg_darwin = $(PACKAGE)-$(VERSION).dmg +pkg_darwin = $(PACKAGE)-$(VERSION).pkg + +# build darwin installer +$(pkg_darwin): + ${MAKE} install DESTDIR=$(distdir_darwin)/root + @cp $(srcdir)/os_darwin/pkg/root/usr/local/sbin/smart-pkg-uninstall $(distdir_darwin)/root$(sbindir) + @mkdir -p $(distdir_darwin)/pkg + @( cd $(distdir_darwin)/root && find . | cpio -o --format odc --owner 0:80 | gzip -c ) > $(distdir_darwin)/pkg/Payload + PAYLOAD_FILES=`find $(distdir_darwin)/root | wc -l` &&\ + PAYLOAD_SIZEKB=`du -BK -s $(distdir_darwin)/root|${AWK} '{print $$1}'|tr -d 'K'` &&\ + sed -e "s|@version@|$(VERSION)|" -e "s|@files@|$${PAYLOAD_FILES}|" \ + -e "s|@size@|$${PAYLOAD_SIZEKB}|" $(srcdir)/os_darwin/pkg/PackageInfo.in \ + > $(distdir_darwin)/pkg/PackageInfo &&\ + sed -e "s|@version@|$(VERSION)|" -e "s|@files@|$${PAYLOAD_FILES}|" -e "s|@size@|$${PAYLOAD_SIZEKB}|" \ + -e "s|@pkgname@|$(pkg_darwin)|" \ + $(srcdir)/os_darwin/pkg/Distribution.in > $(distdir_darwin)/pkg/Distribution + @mkdir -p $(distdir_darwin)/pkg/Resources/English.lproj + @cp $(srcdir)/COPYING $(distdir_darwin)/pkg/Resources/English.lproj/license.txt + @mkbom -u 0 -g 80 $(distdir_darwin)/root $(distdir_darwin)/pkg/Bom + @mkdir -p $(distdir_darwin)/dmg + @( cd $(distdir_darwin)/pkg && xar --compression none -cf "../dmg/$(pkg_darwin)" * ) + +# build darwon dmg image +$(dmg_darwin): + @cp $(srcdir)/os_darwin/pkg/installer/README.html $(distdir_darwin)/dmg + @mkisofs -V 'smartmontools' -no-pad -r -apple -o $(distdir_darwin)/smartmontools-$(VERSION).iso \ + -hfs-bless "$(distdir_darwin)/dmg/" "$(distdir_darwin)/dmg/" + @dmg dmg $(distdir_darwin)/smartmontools-$(VERSION).iso $(dmg_darwin) + md5sum $@ > $@.md5 + sha1sum $@ > $@.sha1 + sha256sum $@ > $@.sha256 + +install-darwin: install-darwin-cleanup $(pkg_darwin) $(dmg_darwin) + +install-darwin-cleanup: + @rm -rf $(distdir_darwin) +endif |