]> git.proxmox.com Git - mirror_smartmontools-debian.git/blobdiff - Makefile.am
Imported Upstream version 5.38+svn2879
[mirror_smartmontools-debian.git] / Makefile.am
index dd3b1f73aac8874eb092b3520387a21acc8cb7f9..15dcdfa4d9bf79227d3564adbbc41e34f6930ae2 100644 (file)
@@ -1,6 +1,6 @@
 ## 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@
@@ -8,20 +8,33 @@
 # 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 \
@@ -29,9 +42,6 @@ smartd_SOURCES =  smartd.cpp      \
                   scsicmds.cpp    \
                   scsicmds.h      \
                   scsiata.cpp     \
-                  scsiata.h       \
-                  scsiprint.cpp   \
-                  scsiprint.h     \
                   utility.cpp     \
                   utility.h
 
@@ -55,7 +65,9 @@ EXTRA_smartd_SOURCES = os_darwin.cpp    \
                        os_generic.cpp   \
                        os_generic.h     \
                        cciss.cpp        \
-                       cciss.h
+                       cciss.h          \
+                       dev_legacy.cpp   \
+                       megaraid.h
 
 
 if OS_WIN32_MINGW
@@ -87,6 +99,11 @@ smartctl_SOURCES= smartctl.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 \
@@ -94,12 +111,12 @@ smartctl_SOURCES= smartctl.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@
 
@@ -117,7 +134,9 @@ EXTRA_smartctl_SOURCES = os_linux.cpp \
                        os_generic.cpp \
                        os_generic.h   \
                        cciss.cpp      \
-                       cciss.h
+                       cciss.h        \
+                       dev_legacy.cpp \
+                       megaraid.h
 
 if OS_WIN32_MINGW
 
@@ -211,8 +230,7 @@ smartd.conf$(smartd_suffix): smartd.conf
        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                      \
@@ -224,7 +242,8 @@ EXTRA_DIST = smartmontools.spec                    \
              os_win32/installer.nsi                \
              $(docs_DATA)
 
-CLEANFILES = smartd.conf.5      \
+CLEANFILES = drivedb.h          \
+             smartd.conf.5      \
              smartd.conf.4      \
              smartd.8           \
              smartd.1m          \
@@ -236,13 +255,70 @@ CLEANFILES = smartd.conf.5      \
              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
@@ -255,6 +331,7 @@ smartd.conf.5.in: smartd.8.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
 
+if INSTALL_INITSCRIPT
 if OS_DARWIN
 initd_DATA = SMART                            \
        os_darwin/StartupParameters.plist     \
@@ -263,6 +340,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)/|" $< > $@
@@ -288,6 +366,9 @@ install-initdDATA-darwin: $(initd_DATA)
        @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
@@ -298,6 +379,7 @@ smartd.initd: $(srcdir)/smartd.initd.in Makefile
 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)
@@ -310,26 +392,72 @@ install-initdDATA-generic: $(initd_DATA)
        @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
@@ -385,6 +513,7 @@ exedir_win32 = $(distdir_win32)/bin
 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 \
@@ -402,7 +531,9 @@ FILES_WIN32 = $(exedir_win32)/smartctl.exe \
               $(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
@@ -435,8 +566,11 @@ $(distinst_win32): $(srcdir)/os_win32/installer.nsi distdir.mkdir $(FILES_WIN32)
            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
@@ -473,15 +607,34 @@ $(docdir_win32)/%.conf: $(srcdir)/%.conf
        $(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