## Process this file with automake to produce Makefile.in
#
-# $Id: Makefile.am,v 1.81 2007/04/01 16:49:44 shattered Exp $
+# $Id: Makefile.am 2878 2009-08-26 20:03:06Z chrfranke $
#
@SET_MAKE@
# 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
sbin_PROGRAMS = smartd \
smartctl
smartd_SOURCES = smartd.cpp \
- smartd.h \
atacmdnames.cpp \
atacmdnames.h \
atacmds.cpp \
atacmds.h \
- ataprint.cpp \
- ataprint.h \
+ dev_ata_cmd_set.cpp \
+ dev_ata_cmd_set.h \
+ dev_interface.cpp \
+ dev_interface.h \
+ dev_tunnelled.h \
extern.h \
int64.h \
knowndrives.cpp \
scsicmds.cpp \
scsicmds.h \
scsiata.cpp \
- scsiata.h \
- scsiprint.cpp \
- scsiprint.h \
utility.cpp \
utility.h
os_generic.cpp \
os_generic.h \
cciss.cpp \
- cciss.h
+ cciss.h \
+ dev_legacy.cpp \
+ megaraid.h
if OS_WIN32_MINGW
atacmds.h \
ataprint.cpp \
ataprint.h \
+ dev_ata_cmd_set.cpp \
+ dev_ata_cmd_set.h \
+ dev_interface.cpp \
+ dev_interface.h \
+ dev_tunnelled.h \
extern.h \
int64.h \
knowndrives.cpp \
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@
os_generic.cpp \
os_generic.h \
cciss.cpp \
- cciss.h
+ cciss.h \
+ dev_legacy.cpp \
+ megaraid.h
if OS_WIN32_MINGW
cp ${srcdir}/smartd.conf smartd.conf$(smartd_suffix)
endif
-EXTRA_DIST = smartmontools.spec \
- smartd.initd.in \
+EXTRA_DIST = smartd.initd.in \
smartd.8.in \
smartctl.8.in \
smartd.conf.5.in \
os_win32/installer.nsi \
$(docs_DATA)
-CLEANFILES = smartd.conf.5 \
+CLEANFILES = drivedb.h \
+ smartd.conf.5 \
smartd.conf.4 \
smartd.8 \
smartd.1m \
smartctl.8.txt \
smartd.conf.5.html \
smartd.conf.5.txt \
- smartd.initd \
+ smartd.initd \
+ svnversion.h \
SMART
if SMARTD_SUFFIX
CLEANFILES += smartd.conf$(smartd_suffix)
endif
+# '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
+
+utility.o: svnversion.h
+
+if IS_SVN_BUILD
+# Get version info from SVN
+svnversion.h: CHANGELOG Makefile $(srcdir)/.svn/entries
+ 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
+
+
+# Drive Database
+drivedb.h: knowndrives.cpp Makefile
+ echo '/* drivedb.h. Generated from knowndrives.cpp by Makefile. */' > $@
+ sed '1,/^\/\/ BEGIN drivedb.h/d;/^\/\/ END drivedb.h/,$$d;s/^ //' $(srcdir)/knowndrives.cpp >> $@
+
+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
smartd.conf.5.in: smartd.8.in
sed '1,/STARTINCLUDE/ D;/ENDINCLUDE/,$$D' < $(srcdir)/smartd.8.in > $(top_builddir)/tmp.directives
cat $(top_builddir)/tmp.tail >> $(srcdir)/smartd.conf.5.in
rm -f $(top_builddir)/tmp.head $(top_builddir)/tmp.tail $(top_builddir)/tmp.directives
+if INSTALL_INITSCRIPT
if OS_DARWIN
initd_DATA = SMART \
os_darwin/StartupParameters.plist \
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)/|" $< > $@
@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_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)
@echo -e "# to learn about it. A sample configuration file can be found in:\n# ${docdir}\n#"
@echo -e "####################################################################\n\n"
+
+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 ENABLE_DRIVEDB
+MAN_DRIVEDB = sed "s|/usr/local/share/smartmontools/drivedb\\.h|$(drivedbdir)/drivedb.h|g"
+else
+MAN_DRIVEDB = sed '/BEGIN ENABLE_DRIVEDB/,/END ENABLE_DRIVEDB/d'
+endif
-smart%: $(srcdir)/smart%.in Makefile
+if ENABLE_SAVESTATES
+MAN_SAVESTATES = sed "s|/usr/local/var/lib/smartmontools/smartd\\.|$(savestates)|g"
+else
+MAN_SAVESTATES = sed '/BEGIN ENABLE_SAVESTATES/,/END ENABLE_SAVESTATES/d'
+endif
+
+if ENABLE_ATTRIBUTELOG
+MAN_ATTRIBUTELOG = sed "s|/usr/local/var/lib/smartmontools/attrlog\\.|$(attributelog)|g"
+else
+MAN_ATTRIBUTELOG = sed '/BEGIN ENABLE_ATTRIBUTELOG/,/END ENABLE_ATTRIBUTELOG/d'
+endif
+
+if OS_FREEBSD
+.for file in $(man_MANS)
+${file}: $(srcdir)/${file}.in Makefile svnversion.h
+ sed "s|CURRENT_CVS_VERSION|$(releaseversion)|g; \
+ s|CURRENT_CVS_DATE|`sed -n 's,^.*DATE[^"]*"\([^"]*\)".*$$,\1,p' svnversion.h`|g; \
+ s|CURRENT_CVS_TIME|`sed -n 's,^.*TIME[^"]*"\([^"]*\)".*$$,\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-5.1/|$(docsdir)/|g; \
+ s|/usr/local/etc/smartd\\.conf|$(sysconfdir)/smartd.conf|g; \
+ s|/usr/local/etc/smart_drivedb\\.h|$(sysconfdir)/smart_drivedb\\.h|g" ${.ALLSRC:M*.in} | \
+ $(MAN_DRIVEDB) | \
+ $(MAN_SAVESTATES) | \
+ $(MAN_ATTRIBUTELOG) > $@
+.endfor
+else
+smart%: $(srcdir)/smart%.in Makefile svnversion.h
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|CURRENT_CVS_DATE|`sed -n 's,^.*DATE[^"]*"\([^"]*\)".*$$,\1,p' svnversion.h`|g" | \
+ sed "s|CURRENT_CVS_TIME|`sed -n 's,^.*TIME[^"]*"\([^"]*\)".*$$,\1,p' svnversion.h`|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" > $@
-
+ sed "s|/usr/local/etc/smartd\\.conf|$(sysconfdir)/smartd.conf|g" | \
+ sed "s|/usr/local/etc/smart_drivedb\\.h|$(sysconfdir)/smart_drivedb\\.h|g" | \
+ $(MAN_DRIVEDB) | \
+ $(MAN_SAVESTATES) | \
+ $(MAN_ATTRIBUTELOG) > $@
+endif
# Commands to convert man pages into .html and .txt
# TODO: configure
docdir_win32 = $(distdir_win32)/doc
FILES_WIN32 = $(exedir_win32)/smartctl.exe \
+ $(exedir_win32)/smartctl-nc.exe \
$(exedir_win32)/smartd.exe \
$(docdir_win32)/AUTHORS.txt \
$(docdir_win32)/CHANGELOG.txt \
$(docdir_win32)/smartd.conf.5.html \
$(docdir_win32)/smartd.conf.5.txt
-CLEANFILES += $(FILES_WIN32) $(exedir_win32)/syslogevt.exe distdir.mkdir syslogevt.check
+CLEANFILES += $(FILES_WIN32) $(exedir_win32)/syslogevt.exe \
+ smartctl-nc.exe smartctl-nc.exe.tmp \
+ distdir.mkdir syslogevt.check
# Textfile converter from cygutils
UNIX2DOS = unix2dos -D
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"
+ 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); \
+ echo "$$makensis /V2 /NOCD /DINPDIR=$(distdir_win32) /DOUTFILE=$(distinst_win32) /DVERSTR='$$verstr' $(srcdir)/os_win32/installer.nsi"; \
+ "$$makensis" /V2 /NOCD /DINPDIR="$(distdir_win32)" /DOUTFILE="$(distinst_win32)" /DVERSTR="$$verstr" "$(srcdir)/os_win32/installer.nsi"
cleandist-win32:
rm -rf $(distdir_win32) distdir.mkdir syslogevt.check
$(UNIX2DOS) < $< > $@
touch -r $< $@
-
-# Build config_vc6.h for MSVC 6 from MinGW config.h
-
-config-vc6: $(srcdir)/os_win32/config_vc6.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,' > $@
+# 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 {config,svnversion}_vc8.h for MSVC8 from MinGW {config,svnversion}.h
+
+config-vc8: $(srcdir)/os_win32/config_vc8.h $(srcdir)/os_win32/svnversion_vc8.h
+
+$(srcdir)/os_win32/config_vc8.h: config.h
+ sed '1i/* config_vc8.h. Generated from config.h by Makefile. */' $< | \
+ sed 's,^#define HAVE_\(ATTR_PACKED\|INTTYPES_H\|STDINT_H\|STRINGS_H\|STRTOULL\|U*INT64_T\|UNISTD_H\|WORKING_SNPRINTF\) 1$$,/* #undef HAVE_\1 */,' | \
+ sed 's,i.86-pc-mingw32,i686-pc-win32vc8,' > $@
+
+$(srcdir)/os_win32/svnversion_vc8.h: svnversion.h
+ cp svnversion.h $@
endif