# 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