X-Git-Url: https://git.proxmox.com/?a=blobdiff_plain;f=Makefile.am;h=d1055560fd12e2e576f19ba6e7899e4fad4034ed;hb=66527000f17fda58af091b6b9b363eeb90f26552;hp=185e83fd832a7000a950f934cf86a73ac597feca;hpb=ba59cff116181eae6e00eae958bc573eb5e97dfb;p=mirror_smartmontools-debian.git diff --git a/Makefile.am b/Makefile.am index 185e83f..d105556 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1,41 +1,71 @@ ## Process this file with automake to produce Makefile.in # -# $Id: Makefile.am,v 1.80 2006/10/21 18:34:31 chrfranke Exp $ +# $Id: Makefile.am 3545 2012-05-25 21:19:03Z chrfranke $ # @SET_MAKE@ +ACLOCAL_AM_FLAGS = -I m4 + # Make sure .cpp takes precedence to avoid compiling old .c file SUFFIXES = .cpp .c .s .o +# BUILD_INFO can be provided by package maintainers (see INSTALL file) +BUILD_INFO= "(local build)" -AM_CPPFLAGS = -DSMARTMONTOOLS_SYSCONFDIR=\"$(sysconfdir)\" +AM_CPPFLAGS = -DBUILD_INFO='$(BUILD_INFO)' -DSMARTMONTOOLS_SYSCONFDIR='"$(sysconfdir)"' +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 -DHAVE_GETOPT_LONG -D__GNU_LIBRARY__ +endif +if NEED_REGEX +AM_CPPFLAGS += -I$(srcdir)/regex +endif sbin_PROGRAMS = smartd \ smartctl +if ENABLE_DRIVEDB +if OS_WIN32_MINGW +else +sbin_SCRIPTS = update-smart-drivedb +endif +endif + + smartd_SOURCES = smartd.cpp \ - smartd.h \ atacmdnames.cpp \ atacmdnames.h \ atacmds.cpp \ atacmds.h \ - ataprint.cpp \ - ataprint.h \ - extern.h \ + dev_ata_cmd_set.cpp \ + dev_ata_cmd_set.h \ + dev_interface.cpp \ + dev_interface.h \ + dev_tunnelled.h \ + drivedb.h \ int64.h \ knowndrives.cpp \ knowndrives.h \ scsicmds.cpp \ scsicmds.h \ scsiata.cpp \ - scsiata.h \ - scsiprint.cpp \ - scsiprint.h \ utility.cpp \ utility.h -smartd_LDADD = @os_deps@ @os_libs@ +smartd_LDADD = @os_deps@ @os_libs@ @CAPNG_LDADD@ smartd_DEPENDENCIES = @os_deps@ EXTRA_smartd_SOURCES = os_darwin.cpp \ @@ -48,32 +78,30 @@ EXTRA_smartd_SOURCES = os_darwin.cpp \ os_netbsd.h \ os_openbsd.cpp \ os_openbsd.h \ + os_qnxnto.cpp \ + os_qnxnto.h \ os_solaris.cpp \ os_solaris.h \ os_solaris_ata.s \ os_win32.cpp \ os_generic.cpp \ - os_generic.h + os_generic.h \ + cciss.cpp \ + cciss.h \ + cissio_freebsd.h \ + dev_legacy.cpp \ + megaraid.h if OS_WIN32_MINGW -smartd_SOURCES += \ - posix/regex.h \ - posix/regex.c \ - os_win32/daemon_win32.h \ - os_win32/daemon_win32.cpp \ - os_win32/hostname_win32.h \ - os_win32/hostname_win32.cpp \ - os_win32/syslog.h \ - os_win32/syslog_win32.cpp - -# Included by regex.c: -EXTRA_smartd_SOURCES += \ - posix/regcomp.c \ - posix/regexec.c \ - posix/regex_internal.c \ - posix/regex_internal.h +smartd_SOURCES += \ + os_win32/daemon_win32.cpp \ + os_win32/daemon_win32.h \ + os_win32/hostname_win32.cpp \ + os_win32/hostname_win32.h \ + os_win32/syslog_win32.cpp \ + os_win32/syslog.h endif @@ -85,19 +113,24 @@ smartctl_SOURCES= smartctl.cpp \ atacmds.h \ ataprint.cpp \ ataprint.h \ - extern.h \ + dev_ata_cmd_set.cpp \ + dev_ata_cmd_set.h \ + dev_interface.cpp \ + dev_interface.h \ + dev_tunnelled.h \ + drivedb.h \ int64.h \ knowndrives.cpp \ knowndrives.h \ scsicmds.cpp \ scsicmds.h \ scsiata.cpp \ - scsiata.h \ scsiprint.cpp \ scsiprint.h \ utility.cpp \ utility.h + smartctl_LDADD = @os_deps@ @os_libs@ smartctl_DEPENDENCIES = @os_deps@ @@ -109,25 +142,72 @@ EXTRA_smartctl_SOURCES = os_linux.cpp \ os_netbsd.h \ os_openbsd.cpp \ os_openbsd.h \ + os_qnxnto.cpp \ + os_qnxnto.h \ os_solaris.cpp \ os_solaris.h \ os_win32.cpp \ os_generic.cpp \ - os_generic.h + os_generic.h \ + cciss.cpp \ + cciss.h \ + cissio_freebsd.h \ + dev_legacy.cpp \ + megaraid.h -if OS_WIN32_MINGW +if NEED_GETOPT_LONG + +smartctl_SOURCES += \ + getopt/getopt.c \ + getopt/getopt.h \ + getopt/getopt1.c + +smartd_SOURCES += \ + getopt/getopt.c \ + getopt/getopt.h \ + getopt/getopt1.c + +endif -smartctl_SOURCES += \ - posix/regex.h \ - posix/regex.c \ - os_win32/syslog.h +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 += \ - posix/regcomp.c \ - posix/regexec.c \ - posix/regex_internal.c \ - posix/regex_internal.h +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 endif @@ -200,57 +280,152 @@ docs_DATA = AUTHORS \ WARNINGS \ smartd.conf -sysconf_DATA = smartd.conf$(smartd_suffix) - -if SMARTD_SUFFIX -smartd.conf$(smartd_suffix): smartd.conf - cp ${srcdir}/smartd.conf smartd.conf$(smartd_suffix) -endif - -EXTRA_DIST = smartmontools.spec \ - smartd.initd.in \ - smartd.8.in \ - smartctl.8.in \ - smartd.conf.5.in \ - smartd.conf \ - autogen.sh \ - os_darwin/SMART.in \ - os_darwin/StartupParameters.plist \ - os_darwin/English_Localizable.strings \ - os_win32/installer.nsi \ - $(docs_DATA) - -CLEANFILES = smartd.conf.5 \ - smartd.conf.4 \ - smartd.8 \ - smartd.1m \ - smartd.8.html \ - smartd.8.txt \ - smartctl.8 \ - smartctl.1m \ - smartctl.8.html \ - smartctl.8.txt \ - smartd.conf.5.html \ - smartd.conf.5.txt \ - smartd.initd \ - SMART - -if SMARTD_SUFFIX -CLEANFILES += smartd.conf$(smartd_suffix) -endif - - -smartd.conf.5.in: smartd.8.in - sed '1,/STARTINCLUDE/ D;/ENDINCLUDE/,$$D' < $(srcdir)/smartd.8.in > $(top_builddir)/tmp.directives - sed '/STARTINCLUDE/,$$D' < $(srcdir)/smartd.conf.5.in > $(top_builddir)/tmp.head - sed '1,/ENDINCLUDE/D' < $(srcdir)/smartd.conf.5.in > $(top_builddir)/tmp.tail - cat $(top_builddir)/tmp.head > $(srcdir)/smartd.conf.5.in - echo '.\" STARTINCLUDE' >> $(srcdir)/smartd.conf.5.in - cat $(top_builddir)/tmp.directives >> $(srcdir)/smartd.conf.5.in - echo '.\" ENDINCLUDE' >> $(srcdir)/smartd.conf.5.in - cat $(top_builddir)/tmp.tail >> $(srcdir)/smartd.conf.5.in - rm -f $(top_builddir)/tmp.head $(top_builddir)/tmp.tail $(top_builddir)/tmp.directives +examplesdir=$(exampledir) +examples_DATA = \ + examplescripts/README +examples_SCRIPTS = \ + examplescripts/Example1 \ + examplescripts/Example2 \ + examplescripts/Example3 \ + examplescripts/Example4 + +sysconf_DATA = smartd.conf + +# If modified smartd.conf exists install smartd.conf.sample instead +install-sysconfDATA: $(sysconf_DATA) + $(mkinstalldirs) $(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" + +EXTRA_DIST = \ + autogen.sh \ + smartd.initd.in \ + smartd.freebsd.initd.in \ + smartd.8.in \ + smartctl.8.in \ + smartd.conf.5.in \ + smartd.conf \ + smartd.service.in \ + update-smart-drivedb.in \ + m4/pkg.m4 \ + os_darwin/SMART.in \ + os_darwin/StartupParameters.plist \ + os_darwin/English_Localizable.strings \ + os_win32/installer.nsi \ + os_win32/runcmd.c \ + os_win32/runcmda.exe.manifest \ + os_win32/runcmdu.exe.manifest \ + os_win32/syslogevt.c \ + os_win32/syslogevt.mc \ + os_win32/update-smart-drivedb.nsi \ + os_win32/wbemcli_small.h \ + $(docs_DATA) \ + $(examples_DATA) \ + $(examples_SCRIPTS) + +CLEANFILES = \ + smartd.conf.5 \ + smartd.conf.4 \ + smartd.8 \ + smartd.1m \ + smartd.8.html \ + smartd.8.txt \ + smartctl.8 \ + smartctl.1m \ + smartctl.8.html \ + smartctl.8.txt \ + smartd.conf.5.html \ + smartd.conf.5.txt \ + smartd.initd \ + smartd.freebsd.initd \ + smartd.service \ + svnversion.h \ + update-smart-drivedb \ + SMART + +# 'make maintainer-clean' also removes files generated by './autogen.sh' +MAINTAINERCLEANFILES = \ + $(srcdir)/Makefile.in \ + $(srcdir)/aclocal.m4 \ + $(srcdir)/configure \ + $(srcdir)/config.guess \ + $(srcdir)/config.h.in \ + $(srcdir)/config.h.in~ \ + $(srcdir)/config.sub \ + $(srcdir)/depcomp \ + $(srcdir)/install-sh \ + $(srcdir)/missing \ + $(srcdir)/mkinstalldirs \ + $(srcdir)/m4/pkg.m4 + +utility.o: svnversion.h + +if IS_SVN_BUILD +# Get version info from SVN +svnversion.h: CHANGELOG Makefile $(svn_deps) + echo '/* svnversion.h. Generated by Makefile from svn info. */' > $@ + (cd $(srcdir) \ + && svnversion 2>/dev/null | sed -n 's,^\([0-9].*\),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 + echo '/* svnversion.h. Generated by Makefile from Id strings. */' > $@ + (cd $(srcdir) && cat CHANGELOG Makefile.am configure.in smart*.in *.cpp *.h *.s) \ + | 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 +drivedb_DATA = drivedb.h +endif + +if ENABLE_SAVESTATES +# Create $(savestatesdir) only +savestates_DATA = +endif +if ENABLE_ATTRIBUTELOG +# Create $(attributelogdir) only +attributelog_DATA = +endif + +update-smart-drivedb: update-smart-drivedb.in config.status + $(SHELL) ./config.status --file=$@ + chmod +x $@ + + +if INSTALL_INITSCRIPT if OS_DARWIN initd_DATA = SMART \ os_darwin/StartupParameters.plist \ @@ -259,6 +434,7 @@ initd_DATA = SMART \ initd_install_name = SMART initd_DATA_install = install-initdDATA-darwin +initd_DATA_uninstall = uninstall-initdDATA-darwin SMART : os_darwin/SMART.in sed "s|/usr/sbin/|$(sbindir)/|" $< > $@ @@ -276,56 +452,113 @@ install-initdDATA-darwin: $(initd_DATA) $(INSTALL_DATA) $(srcdir)/os_darwin/$${i}_Localizable.strings \ $$RDIR/Localizable.strings ; \ done - @echo -e "\n\n####################################################################\n#" - @echo -e "# PLEASE READ THIS BOX!\n#" - @echo -e "# To manually start the smartd daemon, run:\n# ${initddir}/SMART/SMART start\n#" - @echo -e "# To automatically start smartd on bootup, add the line:\n# SMARTd=-YES-\n# to /etc/hostconfig\n#" - @echo -e "# smartd can now use a configuration file ${sysconfdir}/smartd.conf. Do:\n# man smartd" - @echo -e "# to learn about it. A sample configuration file can be found in:\n# ${docdir}\n#" - @echo -e "####################################################################\n\n" + +uninstall-initdDATA-darwin: + rm -rf $(DESTDIR)$(initddir)/$(initd_install_name) else -initd_DATA = smartd.initd +initd_DATA = @initdfile@ -smartd.initd: $(srcdir)/smartd.initd.in Makefile - sed "s|/usr/local/sbin/|$(sbindir)/|g" $(srcdir)/smartd.initd.in > $@ +@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) $(mkinstalldirs) $(DESTDIR)$(initddir) - $(INSTALL_SCRIPT) $(top_builddir)/smartd.initd $(DESTDIR)$(initddir)/smartd$(smartd_suffix) - @echo -e "\n\n####################################################################\n#" - @echo -e "# PLEASE READ THIS BOX!\n#" - @echo -e "# To manually start the smartd daemon, run:\n# ${initddir}/smartd start\n#" - @echo -e "# To automatically start smartd on bootup, run:\n# /sbin/chkconfig --add smartd\n#" - @echo -e "# smartd can now use a configuration file ${sysconfdir}/smartd.conf. Do:\n# man smartd" - @echo -e "# to learn about it. A sample configuration file can be found in:\n# ${docdir}\n#" - @echo -e "####################################################################\n\n" + $(INSTALL_SCRIPT) $(top_builddir)/@initdfile@ $(DESTDIR)$(initddir)/smartd$(smartd_suffix) + +uninstall-initdDATA-generic: + rm -rf $(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: - rm -rf $(DESTDIR)$(initddir)/$(initd_install_name) +uninstall-initdDATA: $(initd_DATA_uninstall) -uninstall-docsDATA: - rm -rf $(DESTDIR)$(docsdir) +if INSTALL_SYSTEMDUNIT +systemdsystemunit_DATA = smartd.service +endif -smart%: $(srcdir)/smart%.in Makefile - sed "s|CURRENT_CVS_VERSION|$(releaseversion)|g" $< | \ - sed "s|CURRENT_CVS_DATE|$(smartmontools_release_date)|g" | \ - sed "s|CURRENT_CVS_TIME|$(smartmontools_release_time)|g" | \ - sed "s|/usr/local/share/man/|$(mandir)/|g" | \ - sed "s|/usr/local/sbin/|$(sbindir)/|g" | \ - sed "s|/usr/local/etc/rc\\.d/init.d/|$(initddir)/|g" | \ - sed "s|/usr/local/share/doc/smartmontools-5.1/|$(docsdir)/|g" | \ - sed "s|/usr/local/etc/smartd\\.conf|$(sysconfdir)/smartd.conf|g" > $@ +smartd.service: smartd.service.in Makefile + sed "s|/usr/local/sbin/smartd|$(sbindir)/smartd|g; \ + s|/usr/local/etc/sysconfig/smartmontools|$(sysconfdir)/sysconfig/smartmontools|g" \ + $(srcdir)/smartd.service.in > $@ +if ENABLE_CAPABILITIES +MAN_CAPABILITIES = cat +else +MAN_CAPABILITIES = sed '/^\.\\" %IF ENABLE_CAPABILITIES/,/^\.\\" %ENDIF ENABLE_CAPABILITIES/ s,^,.\\"\# ,' +endif + +if ENABLE_DRIVEDB +MAN_DRIVEDB = sed "s|/usr/local/share/smartmontools/drivedb\\.h|$(drivedbdir)/drivedb.h|g" +else +MAN_DRIVEDB = sed '/^\.\\" %IF ENABLE_DRIVEDB/,/^\.\\" %ENDIF ENABLE_DRIVEDB/ s,^,.\\"\# ,' +endif + +if ENABLE_SAVESTATES +MAN_SAVESTATES = sed "s|/usr/local/var/lib/smartmontools/smartd\\.|$(savestates)|g" +else +MAN_SAVESTATES = sed '/^\.\\" %IF ENABLE_SAVESTATES/,/^\.\\" %ENDIF ENABLE_SAVESTATES/ s,^,.\\"\# ,' +endif + +if ENABLE_ATTRIBUTELOG +MAN_ATTRIBUTELOG = sed "s|/usr/local/var/lib/smartmontools/attrlog\\.|$(attributelog)|g" +else +MAN_ATTRIBUTELOG = sed '/^\.\\" %IF ENABLE_ATTRIBUTELOG/,/^\.\\" %ENDIF ENABLE_ATTRIBUTELOG/ s,^,.\\"\# ,' +endif + +MAN_FILTER = \ + sed "s|CURRENT_SVN_VERSION|$(releaseversion)|g; \ + s|CURRENT_SVN_DATE|`sed -n 's,^.*DATE[^"]*"\([^"]*\)".*$$,\1,p' svnversion.h`|g; \ + s|CURRENT_SVN_REV|`sed -n 's,^.*REV[^"]*"\([^"]*\)".*$$,r\1,p' svnversion.h`|g; \ + s|/usr/local/share/man/|$(mandir)/|g; \ + s|/usr/local/sbin/|$(sbindir)/|g; \ + s|/usr/local/etc/rc\\.d/init.d/|$(initddir)/|g; \ + s|/usr/local/share/doc/smartmontools/examplescripts/|!exampledir!|g; \ + s|/usr/local/share/doc/smartmontools/|$(docsdir)/|g; \ + s|!exampledir!|$(exampledir)/|g; \ + s|/usr/local/etc/smartd\\.conf|$(sysconfdir)/smartd.conf|g; \ + s|/usr/local/etc/smart_drivedb\\.h|$(sysconfdir)/smart_drivedb\\.h|g" | \ + $(MAN_ATTRIBUTELOG) | \ + $(MAN_CAPABILITIES) | \ + $(MAN_DRIVEDB) | \ + $(MAN_SAVESTATES) | \ + 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 + cat $(srcdir)/smartctl.8.in | $(MAN_FILTER) > $@ + +smartd.8: smartd.8.in Makefile svnversion.h + cat $(srcdir)/smartd.8.in | $(MAN_FILTER) > $@ + +smartd.conf.5: smartd.conf.5.in Makefile svnversion.h + cat $(srcdir)/smartd.conf.5.in | $(MAN_FILTER) > $@ # Commands to convert man pages into .html and .txt # TODO: configure @@ -369,40 +602,89 @@ endif $(MAN2TXT) $< > $@ +# Check drive database syntax +check: + @if ./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 + if OS_WIN32_MINGW # Definitions for Windows distribution -distdir_win32 = $(PACKAGE)-$(VERSION).win32 -distzip_win32 = $(PACKAGE)-$(VERSION).win32.zip -distinst_win32= $(PACKAGE)-$(VERSION).win32-setup.exe +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 -FILES_WIN32 = $(exedir_win32)/smartctl.exe \ - $(exedir_win32)/smartd.exe \ - $(docdir_win32)/AUTHORS.txt \ - $(docdir_win32)/CHANGELOG.txt \ - $(docdir_win32)/COPYING.txt \ - $(docdir_win32)/INSTALL.txt \ - $(docdir_win32)/NEWS.txt \ - $(docdir_win32)/README.txt \ - $(docdir_win32)/TODO.txt \ - $(docdir_win32)/WARNINGS.txt \ - $(docdir_win32)/smartd.conf \ - $(docdir_win32)/smartctl.8.html \ - $(docdir_win32)/smartctl.8.txt \ - $(docdir_win32)/smartd.8.html \ - $(docdir_win32)/smartd.8.txt \ - $(docdir_win32)/smartd.conf.5.html \ - $(docdir_win32)/smartd.conf.5.txt - -CLEANFILES += $(FILES_WIN32) $(exedir_win32)/syslogevt.exe distdir.mkdir syslogevt.check - -# Textfile converter from cygutils -UNIX2DOS = unix2dos -D -DOS2UNIX = dos2unix -U +EXEFILES_WIN32 = \ + $(exedir_win32)/smartctl.exe \ + $(exedir_win32)/smartctl-nc.exe \ + $(exedir_win32)/smartd.exe \ + $(exedir_win32)/runcmda.exe \ + $(exedir_win32)/runcmdu.exe + +if OS_WIN32_WINDMC +EXEFILES_WIN32 += \ + $(exedir_win32)/syslogevt.exe +endif + +if ENABLE_DRIVEDB +if OS_WIN32_NSIS +EXEFILES_WIN32 += \ + $(exedir_win32)/update-smart-drivedb.exe +endif +endif + +FILES_WIN32 = \ + $(EXEFILES_WIN32) \ + $(docdir_win32)/AUTHORS.txt \ + $(docdir_win32)/CHANGELOG.txt \ + $(docdir_win32)/COPYING.txt \ + $(docdir_win32)/INSTALL.txt \ + $(docdir_win32)/NEWS.txt \ + $(docdir_win32)/README.txt \ + $(docdir_win32)/TODO.txt \ + $(docdir_win32)/WARNINGS.txt \ + $(docdir_win32)/checksums$(win_bits).txt \ + $(docdir_win32)/smartd.conf \ + $(docdir_win32)/smartctl.8.html \ + $(docdir_win32)/smartctl.8.txt \ + $(docdir_win32)/smartd.8.html \ + $(docdir_win32)/smartd.8.txt \ + $(docdir_win32)/smartd.conf.5.html \ + $(docdir_win32)/smartd.conf.5.txt \ + $(exedir_win32)/runcmda.exe.manifest \ + $(exedir_win32)/runcmdu.exe.manifest + +if ENABLE_DRIVEDB +FILES_WIN32 += \ + $(exedir_win32)/drivedb.h +endif + +CLEANFILES += \ + $(FILES_WIN32) \ + runcmdu.exe \ + smartctl-nc.exe smartctl-nc.exe.tmp \ + syslogevt.exe syslogevt.h syslogevt.o \ + syslogevt.res.o syslogevt.rc syslogevt_*.bin \ + update-smart-drivedb.exe \ + distdir.mkdir + +# Textfile converter from package cygutils or tofrodos +# Note: Only use without options to be compatible with both packages +UNIX2DOS = unix2dos +DOS2UNIX = dos2unix # Build Windows distribution @@ -413,44 +695,67 @@ install-win32: $(distinst_win32) installer-win32: $(distinst_win32) -distdir-win32: distdir.mkdir $(FILES_WIN32) syslogevt.check +distdir-win32: distdir.mkdir $(FILES_WIN32) -$(distzip_win32): distdir.mkdir $(FILES_WIN32) syslogevt.check +$(distzip_win32): distdir.mkdir $(FILES_WIN32) @rm -fv $(distzip_win32) - cd $(distdir_win32) && zip -9Dr ../$(distzip_win32) . - -# Build NSIS installer, try to locate makensis in default location first -$(distinst_win32): $(srcdir)/os_win32/installer.nsi distdir.mkdir $(FILES_WIN32) syslogevt.check - @makensis="$(MAKENSIS)"; if [ -z "$$makensis" ]; then \ - if [ ! -z "$$PROGRAMFILES" ] && "$$PROGRAMFILES/NSIS/makensis" /VERSION >/dev/null 2>&1; then \ - makensis="$$PROGRAMFILES/NSIS/makensis"; \ - elif makensis /VERSION >/dev/null 2>&1; then \ - makensis=makensis; \ - else \ - echo 'makensis: command not found. Please download and install NSIS' 1>&2; \ - echo 'from http://nsis.sourceforge.net/Download' 1>&2; exit 1; \ - fi; \ - fi; \ - echo "$$makensis /V2 /NOCD /DINPDIR=$(distdir_win32) /DOUTFILE=$(distinst_win32) $(srcdir)/os_win32/installer.nsi"; \ - "$$makensis" /V2 /NOCD /DINPDIR="$(distdir_win32)" /DOUTFILE="$(distinst_win32)" "$(srcdir)/os_win32/installer.nsi" + cd $(distdir_win32) && zip -9 ../$(distzip_win32) bin/* doc/* + md5sum $@ > $@.md5 + sha1sum $@ > $@.sha1 + sha256sum $@ > $@.sha256 + +if OS_WIN32_NSIS +# Build NSIS installer +# Note: Only option character '-' is also compatible with Linux version of makensis +$(distinst_win32): os_win32/installer.nsi distdir.mkdir $(FILES_WIN32) + 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`; \ + verstr="$(PACKAGE_VERSION) $$date $$rev "$(BUILD_INFO); \ + d64=; test -z '$(builddir_win64)' || d64='-DINPDIR64=$(builddir_win64)/$(PACKAGE)-$(VERSION).win64'; \ + echo "'$(MAKENSIS)' -V2 -NOCD -DINPDIR=$(distdir_win32) $$d64 -DOUTFILE=$@ -DVERSTR='$$verstr' $<"; \ + '$(MAKENSIS)' -V2 -NOCD -DINPDIR=$(distdir_win32) $$d64 -DOUTFILE=$@ -DVERSTR="$$verstr" $< + md5sum $@ > $@.md5 + sha1sum $@ > $@.sha1 + sha256sum $@ > $@.sha256 + +# Build drivedb.h update tool +update-smart-drivedb.exe: os_win32/update-smart-drivedb.nsi + "$(MAKENSIS)" -V2 -NOCD -DBRANCH=$(DRIVEDB_BRANCH) $< + +else +$(distinst_win32): + @echo "makensis: command not found. Please install NSIS from http://nsis.sourceforge.net/" 1>&2 + @exit 1 +endif cleandist-win32: - rm -rf $(distdir_win32) distdir.mkdir syslogevt.check + 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 $@ -syslogevt.check: - @if [ -f $(srcdir)/os_win32/syslogevt.exe ]; then \ - cp -pv $(srcdir)/os_win32/syslogevt.exe $(exedir_win32)/syslogevt.exe; \ - else echo "Warning: $(srcdir)/os_win32/syslogevt.exe missing."; fi - touch $@ - $(exedir_win32)/%.exe: %.exe cp -p $< $@ - strip -s $@ + if test -n '$(STRIP)'; then $(STRIP) -s $@; else strip -s $@; fi + touch -r $< $@ + +# strip would break NSIS integrity check +$(exedir_win32)/update-smart-drivedb.exe: update-smart-drivedb.exe + cp -p $< $@ + +# runcmd?.exe only differ by .exe.manifest files +$(exedir_win32)/runcmda.exe: $(exedir_win32)/runcmdu.exe + cp -p $< $@ + +$(exedir_win32)/%.h: $(srcdir)/%.h + $(UNIX2DOS) < $< > $@ + touch -r $< $@ + +$(exedir_win32)/%.exe.manifest: $(srcdir)/os_win32/%.exe.manifest + $(UNIX2DOS) < $< > $@ touch -r $< $@ $(docdir_win32)/%.html: %.html @@ -469,16 +774,56 @@ $(docdir_win32)/%.conf: $(srcdir)/%.conf $(UNIX2DOS) < $< > $@ touch -r $< $@ +$(docdir_win32)/checksums$(win_bits).txt: $(EXEFILES_WIN32) + (cd $(exedir_win32) && md5sum *.exe && sha1sum *.exe && sha256sum *.exe) \ + | $(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 +runcmdu.exe: os_win32/runcmd.c + $(CC) -Os -o $@ $< + +if OS_WIN32_WINDMC +# Build syslogevt.exe event message file tool + +syslogevt.exe: syslogevt.o syslogevt.res.o + $(LINK) $^ + +syslogevt.o: os_win32/syslogevt.c syslogevt.rc + $(CC) -c -I. -Os -o $@ $< + +syslogevt.res.o: syslogevt.rc + $(WINDRES) $< $@ + +syslogevt.rc: os_win32/syslogevt.mc + $(WINDMC) -b $< +endif -# Build config_vc6.h for MSVC 6 from MinGW config.h +# Build {config,svnversion}_vc10.h for MSVC10 from MinGW {config,svnversion}.h -config-vc6: $(srcdir)/os_win32/config_vc6.h +config-vc10: $(srcdir)/os_win32/config_vc10.h $(srcdir)/os_win32/svnversion_vc10.h -$(srcdir)/os_win32/config_vc6.h: config.h - sed '1i/* config_vc6.h. Generated by Makefile. */' $< | \ - sed 's,^#define HAVE_\(ATTR_PACKED\|INTTYPES_H\|STDINT_H\|STRINGS_H\|STRTOULL\|U*INT64_T\|UNISTD_H\) 1$$,/* #undef HAVE_\1 */,' | \ - sed 's,i.86-pc-mingw32,i686-pc-win32vc6,' > $@ +$(srcdir)/os_win32/config_vc10.h: config.h Makefile + sed -e '1i/* config_vc10.h. Generated from config.h by Makefile. */' \ + -e 's,^#define HAVE_\(ATTR_PACKED\|GETTIMEOFDAY\|INTTYPES_H\|[DK_]*NTDDDISK_H\|STRINGS_H\|STRTOULL\|UNISTD_H\|WORKING_SNPRINTF\) 1$$,/* #undef HAVE_\1 */,' \ + -e 's,^\(#define SMARTMONTOOLS_BUILD_HOST "[^-]*\)[^"]*,\1-pc-w32vc10,' $< > $@ -endif +$(srcdir)/os_win32/svnversion_vc10.h: svnversion.h + cp $< $@ -SUBDIRS= . examplescripts +endif