# file: Makefile G. Moody 6 July 1983
# Last revised: 23 February 2006 wfdblib 10.4.0
# 'make' description file for compiling the WFDB library
#
# _____________________________________________________________________________
# wfdb: a library for reading and writing annotated waveforms(time series data)
# Copyright (C) 1983-2006 George B. Moody
#
# This library is free software; you can redistribute it and/or modify it under
# the terms of the GNU Library General Public License as published by the Free
# Software Foundation; either version 2 of the License, or (at your option) any
# later version.
#
# This library 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 Library General Public License for
# more details.
#
# You should have received a copy of the GNU Library General Public License
# along with this library; if not, see .
#
# You may contact the author by e-mail (wfdb@physionet.org) or postal mail
# (MIT Room E25-505A, Cambridge, MA 02139 USA). For updates to this software,
# please visit PhysioNet (http://www.physionet.org/).
# _____________________________________________________________________________
#
# This file is used with the UNIX `make' command to install the WFDB library.
# Before using it for the first time, check that the site-specific variables
# below are appropriate for your system. To build and install the standard
# WFDB library, type `make' or `make lib' (from within this directory). To
# build and install the alternate WFDB library (not available on all systems),
# type `make slib'.
# _____________________________________________________________________________
# file: version.def G. Moody 24 May 2000
# Last revised: 25 January 2018
# Each release of the WFDB Software Package is identified by a three-part
# version number, defined below. Be sure to leave a single space before
# and after the "=" in each of the next three lines!
MAJOR = 10
MINOR = 6
RELEASE = 2
VERSION = 10.6.2
# RPMRELEASE can be incremented if changes are made between official
# releases. It should be reset to 1 whenever the VERSION is changed.
RPMRELEASE = 1
# VDEFS is the set of C compiler options needed to set version number variables
# while compiling the WFDB Software Package.
VDEFS = -DWFDB_MAJOR=$(MAJOR) -DWFDB_MINOR=$(MINOR) -DWFDB_RELEASE=$(RELEASE)
# WAVEVERSION is the WAVE version number.
WAVEVERSION = 6.12
# _____________________________________________________________________________
# Definitions generated by 'configure'
PACKAGE = wfdb-10.6.2
SRCDIR = "/tmp/wfdb-10.6.2"
LONGDATE = 8 March 2019
SHORTDATE = MARCH 2019
YEAR = 2019
ARCH = x86_64-Linux
BUILD_CC = $(CC)
# _____________________________________________________________________________
# file: linux-slib.def G. Moody 31 May 2000
# Last revised: 8 March 2017
# This section contains settings suitable for generating an ELF-format shared
# library under Linux.
# Choose a value for WFDBROOT to determine where the WFDB Software Package will
# be installed. One of the following is usually a reasonable choice.
# Installing in /usr generally requires root permissions, but will be easiest
# for future software development (no special -I or -L options will be needed
# to compile software with the WFDB library, since the *.h files and the
# library will be installed in the standard directories).
WFDBROOT = /usr/local
# Installing in /usr/local usually requires root permissions. On a multi-user
# system where it is desirable to keep the OS vendor's software separate from
# other software, this is a good choice. Another common choice in such cases
# is /opt .
# WFDBROOT = /usr/local
# To install without root permissions, a good choice is to set WFDBROOT to the
# name of your home directory, as in the example below (change as needed).
# WFDBROOT = /home/frodo
# LC and LL are used to determine C compiler and linker options needed to
# enable NETFILES (code that allows applications linked to the WFDB library to
# read input from HTTP and FTP servers, in addition to the standard filesystem
# support available without NETFILES). The WFDB library can use either
# libcurl (recommended) or libwww to provide NETFILES support. To use libcurl,
# set LC to `curl-config --cflags` (note the backquotes) and LL to
# `curl-config --libs`. Otherwise, to use libwww, set LC to
# `libwww-config --cflags` and LL to `libwww-config --libs`. If neither
# libcurl nor libwww is available, LC and LL should be empty (and NETFILES
# will be disabled).
LC = `curl-config --cflags`
LL = `curl-config --libs`
# BINDIR specifies the directory in which the applications will be installed;
# it should be a directory in the PATH of those who will use the applications.
BINDIR = $(WFDBROOT)/bin
# DBDIR specifies the name of a directory in which to install the contents
# of the `data' directory.
DBDIR = $(WFDBROOT)/database
# INCDIR specifies the name of a directory in which to install the WFDB
# library's #include <...> files.
INCDIR = $(WFDBROOT)/include
# LIBDIR specifies the name of a directory in which to install the WFDB
# library.
LIBDIR = $(WFDBROOT)/lib
# RPATHFLAGS is a set of C compiler options that cause the program to
# search for shared libraries in a non-standard location at run-time.
# These options are not needed or useful when using a static library.
RPATHFLAGS = -Wl,--enable-new-dtags,-rpath,$(LIBDIR)
# LDFLAGS is appended to the C compiler command line to specify loading the
# WFDB library.
LDFLAGS = -L$(DESTDIR)$(LIBDIR) -lwfdb $(RPATHFLAGS)
# CC is the name of your C compiler.
CC = gcc
# CCDEFS is the set of C compiler options needed to set preprocessor variables
# while compiling the WFDB Software Package. CCDEFS should always include
# VDEFS (the version definitions). Under Linux, add -fno-stack-protector
# when compiling the original (SWIG-based) WFDB Toolkit for Matlab.
CCDEFS = $(VDEFS)
# MFLAGS is the set of architecture-dependent (-m*) compiler options, which
# is usually empty. See the gcc manual for information about gcc's -m options.
MFLAGS =
# CFLAGS is the set of C compiler options used when compiling the shared
# library. CFLAGS should always include CCDEFS.
CFLAGS = -Wno-implicit -Wformat $(MFLAGS) -fpic -g -O $(CCDEFS) $(LC) -I$(DESTDIR)$(INCDIR)
# WFDBLIB_BASENAME is the name, without version numbers, of the alternate
# library. WFDBLIB_SONAME is the shared object name ("soname") of the
# alternate library; normally, this includes the base name and the major
# version number only. WFDBLIB is the complete name, including the minor
# version number. Symbolic links from WFDBLIB to WFDBLIB_BASENAME and
# WFDBLIB_SONAME will be created as the final step in building the alternate
# library.
WFDBLIB_BASENAME = libwfdb.so
WFDBLIB_SONAME = $(WFDBLIB_BASENAME).$(MAJOR)
WFDBLIB = $(WFDBLIB_SONAME).$(MINOR)
# For a shared library, the soname is significant for proper run-time binding.
# If you change function interfaces in the library, change its soname by
# incrementing the major version number; when you do this, set the minor
# version number to zero. If you change the library without changing the
# function interfaces, increment the minor version number; this allows existing
# binaries to use the new version without recompilation, since the soname is
# unchanged in this case.
# BUILDLIB is the command that creates the shared WFDB library once its
# components have been compiled separately; the list of *.o files that
# make up the library will be appended to BUILDLIB.
BUILDLIB = $(CC) $(MFLAGS) -shared -Wl,-soname,$(WFDBLIB_SONAME) \
-o $(WFDBLIB)
# BUILDLIB_LDFLAGS is a list of arguments appended to BUILDLIB following
# the list of *.o files.
BUILDLIB_LDFLAGS = $(LL)
# LDCONFIG is the name of the program needed to refresh the system's cached
# index of shared libraries.
LDCONFIG = /sbin/ldconfig
# PRINT is the name of the program used to produce listings (including any
# options for the desired formatting).
PRINT = lpr
# SETPERMISSIONS is the command needed to make the installed files accessible
# to those who will use them. The value given below makes them readable by
# everyone, and writeable by the owner only. (If you perform the installation
# as `root', `root' is the owner of the installed files.)
SETPERMISSIONS = chmod 644
# SETDPERMISSIONS is similarly used to make directories created during the
# installation accessible.
SETDPERMISSIONS = chmod 755
# SETLPERMISSIONS is the command needed to make the WFDB library usable by
# programs linked to it.
SETLPERMISSIONS = chmod 755
# `make' (with no target specified) will be equivalent to `make all'.
make-all: all
# `make lib-post-install' should be run after installing the WFDB library.
lib-post-install:
-(cd $(DESTDIR)$(LIBDIR); ln -sf $(WFDBLIB) $(WFDBLIB_SONAME))
-(cd $(DESTDIR)$(LIBDIR); ln -sf $(WFDBLIB_SONAME) $(WFDBLIB_BASENAME))
-([$EUID -eq 0 -a -x /usr/sbin/selinuxenabled ] && /usr/sbin/selinuxenabled && /sbin/restorecon $(DESTDIR)$(LIBDIR)/$(WFDBLIB))
-([$EUID -eq 0] && ($(LDCONFIG) 2>/dev/null || \
echo Warning: "$(LDCONFIG)" was unsuccessful))
lib-post-uninstall:
rm -f $(DESTDIR)$(LIBDIR)/$(WFDBLIB_BASENAME)
rm -f $(DESTDIR)$(LIBDIR)/$(WFDBLIB_SONAME)
-@$(LDCONFIG) || echo Warning: "$(LDCONFIG)" was unsuccessful
#______________________________________________________________________________
# file: Makefile.tpl G. Moody 24 May 2000
# Last revised: 9 May 2018
# This section of the Makefile should not need to be changed.
INCLUDES = $(DESTDIR)$(INCDIR)/wfdb/wfdb.h \
$(DESTDIR)$(INCDIR)/wfdb/wfdblib.h \
$(DESTDIR)$(INCDIR)/wfdb/ecgcodes.h \
$(DESTDIR)$(INCDIR)/wfdb/ecgmap.h
HFILES = wfdb.h ecgcodes.h ecgmap.h wfdblib.h
CFILES = wfdbinit.c annot.c signal.c calib.c wfdbio.c
OFILES = wfdbinit.o annot.o signal.o calib.o wfdbio.o
MFILES = Makefile Makefile.dos
# `make' or `make all': build the WFDB library
all:
$(MAKE) setup
$(MAKE) $(OFILES)
$(BUILDLIB) $(OFILES) $(BUILDLIB_LDFLAGS)
# `make install': install the WFDB library and headers
install:
$(MAKE) clean # force recompilation since config may have changed
$(MAKE) all
$(MAKE) $(INCLUDES) $(DESTDIR)$(LIBDIR)
cp $(WFDBLIB) $(DESTDIR)$(LIBDIR)
$(SETLPERMISSIONS) $(DESTDIR)$(LIBDIR)/$(WFDBLIB)
$(MAKE) lib-post-install 2>/dev/null
# 'make collect': retrieve the installed WFDB library and headers
collect:
../conf/collect.sh $(INCDIR)/wfdb wfdb.h ecgcodes.h ecgmap.h
../conf/collect.sh $(LIBDIR) $(WFDBLIB) $(WFDBLIB_DLLNAME)
uninstall:
../uninstall.sh $(DESTDIR)$(INCDIR)/wfdb $(HFILES)
../uninstall.sh $(DESTDIR)$(INCDIR)
../uninstall.sh $(DESTDIR)$(LIBDIR) $(WFDBLIB)
$(MAKE) lib-post-uninstall
../uninstall.sh $(DESTDIR)$(LIBDIR)
setup:
sed "s+DBDIR+$(DBDIR)+" wfdblib.h
# `make clean': remove binaries and backup files
clean:
rm -f $(OFILES) libwfdb.* *.dll *~
# `make TAGS': make an `emacs' TAGS file
TAGS: $(HFILES) $(CFILES)
@etags $(HFILES) $(CFILES)
# `make listing': print a listing of WFDB library sources
listing:
$(PRINT) README $(MFILES) $(HFILES) $(CFILES)
# Rule for creating installation directories
$(DESTDIR)$(INCDIR) $(DESTDIR)$(INCDIR)/wfdb $(DESTDIR)$(INCDIR)/ecg $(DESTDIR)$(LIBDIR):
mkdir -p $@; $(SETDPERMISSIONS) $@
# Rules for installing the include files
$(DESTDIR)$(INCDIR)/wfdb/wfdb.h: $(DESTDIR)$(INCDIR)/wfdb wfdb.h
cp -p wfdb.h $(DESTDIR)$(INCDIR)/wfdb
$(SETPERMISSIONS) $(DESTDIR)$(INCDIR)/wfdb/wfdb.h
$(DESTDIR)$(INCDIR)/wfdb/wfdblib.h: $(DESTDIR)$(INCDIR)/wfdb wfdblib.h
cp -p wfdblib.h $(DESTDIR)$(INCDIR)/wfdb
$(SETPERMISSIONS) $(DESTDIR)$(INCDIR)/wfdb/wfdblib.h
$(DESTDIR)$(INCDIR)/wfdb/ecgcodes.h: $(DESTDIR)$(INCDIR)/wfdb ecgcodes.h
cp -p ecgcodes.h $(DESTDIR)$(INCDIR)/wfdb
$(SETPERMISSIONS) $(DESTDIR)$(INCDIR)/wfdb/ecgcodes.h
$(DESTDIR)$(INCDIR)/wfdb/ecgmap.h: $(DESTDIR)$(INCDIR)/wfdb ecgmap.h
cp -p ecgmap.h $(DESTDIR)$(INCDIR)/wfdb
$(SETPERMISSIONS) $(DESTDIR)$(INCDIR)/wfdb/ecgmap.h
# Prerequisites for the library modules
wfdbinit.o: wfdb.h wfdblib.h wfdbinit.c
annot.o: wfdb.h ecgcodes.h ecgmap.h wfdblib.h annot.c
signal.o: wfdb.h wfdblib.h signal.c
calib.o: wfdb.h wfdblib.h calib.c
wfdbio.o: wfdb.h wfdblib.h wfdbio.c
lf='"$(LDFLAGS)"' ; \
lf=`echo "$$lf" | sed 's|$(DESTDIR)$(LIBDIR)|$(LIBDIR)|g'` ; \
$(CC) $(CFLAGS) -DVERSION='"$(VERSION)"' -DCFLAGS='"-I$(INCDIR)"' \
-DLDFLAGS="$$lf" $(BUILD_DATE_FLAGS) -c wfdbio.c