## Process this file with automake to produce Makefile.in # $Id$ SUBDIRS = misc maths frontend spicelib include DIST_SUBDIRS = misc maths frontend spicelib include xspice ciderlib if XSPICE_WANTED SUBDIRS += xspice endif if CIDER_WANTED SUBDIRS += ciderlib endif if !TCL_MODULE bin_PROGRAMS = ngspice ngnutmeg if !WINDOWS bin_PROGRAMS += ngsconvert ngproc2mod ngmultidec ngmakeidx helpdatadir = $(pkgdatadir)/helpdir helpdata_DATA = ngspice.txt ngspice.idx if !NO_HELP bin_PROGRAMS += nghelp endif !NO_HELP endif !WINDOWS endif !TCL_MODULE EXTRA_DIST = ngspice.txt setplot spectrum \ devload devaxis ciderinit winmain.c winmain.h unsupported \ tclspice.c tclspice.map pkgIndex.tcl.in tclspinit.in main.c initdatadir = $(pkgdatadir)/scripts initdata_DATA = spinit setplot spectrum if CIDER_WANTED initdata_DATA += devload devaxis ciderinit endif DYNAMIC_DEVICELIBS = \ spicelib/devices/asrc/libasrc.la \ spicelib/devices/bjt/libbjt.la \ spicelib/devices/bsim1/libbsim1.la \ spicelib/devices/bsim2/libbsim2.la \ spicelib/devices/bsim3/libbsim3.la \ spicelib/devices/bsim3v0/libbsim3v0.la \ spicelib/devices/bsim3v1/libbsim3v1.la \ spicelib/devices/bsim3v32/libbsim3v32.la \ spicelib/devices/bsim4/libbsim4.la \ spicelib/devices/bsim4v2/libbsim4v2.la \ spicelib/devices/bsim4v3/libbsim4v3.la \ spicelib/devices/bsim4v4/libbsim4v4.la \ spicelib/devices/bsim4v5/libbsim4v5.la \ spicelib/devices/cap/libcap.la \ spicelib/devices/bsim3soi/libbsim4soi.la \ spicelib/devices/bsim3soi_pd/libbsim3soipd.la \ spicelib/devices/bsim3soi_fd/libbsim3soifd.la \ spicelib/devices/bsim3soi_dd/libbsim3soidd.la \ spicelib/devices/cccs/libcccs.la \ spicelib/devices/ccvs/libccvs.la \ spicelib/devices/cpl/libcpl.la \ spicelib/devices/csw/libcsw.la \ spicelib/devices/dio/libdio.la \ spicelib/devices/ind/libind.la \ spicelib/devices/isrc/libisrc.la \ spicelib/devices/hfet1/libhfet.la \ spicelib/devices/hfet2/libhfet2.la \ spicelib/devices/hisim2/libhisim2.la \ spicelib/devices/hisimhv/libhisimhv.la \ spicelib/devices/jfet/libjfet.la \ spicelib/devices/jfet2/libjfet2.la \ spicelib/devices/ltra/libltra.la \ spicelib/devices/mes/libmes.la \ spicelib/devices/mesa/libmesa.la \ spicelib/devices/mos1/libmos1.la \ spicelib/devices/mos2/libmos2.la \ spicelib/devices/mos3/libmos3.la \ spicelib/devices/mos6/libmos6.la \ spicelib/devices/mos9/libmos9.la \ spicelib/devices/res/libres.la \ spicelib/devices/soi3/libsoi3.la \ spicelib/devices/sw/libsw.la \ spicelib/devices/txl/libtxl.la \ spicelib/devices/tra/libtra.la \ spicelib/devices/urc/liburc.la \ spicelib/devices/vbic/libvbic.la \ spicelib/devices/vccs/libvccs.la \ spicelib/devices/vcvs/libvcvs.la \ spicelib/devices/vsrc/libvsrc.la \ @VLADEV@ ## Build ngspice first: ngspice_SOURCES = \ main.c \ conf.c \ conf.h \ ngspice.c ngspice_CPPFLAGS = $(AM_CPPFLAGS) -DSIMULATOR if WINDOWS ngspice_SOURCES += winmain.c endif ngspice_LDADD = \ frontend/libfte.la if WINDOWS ngspice_LDADD += \ frontend/wdisp/libwindisp.la endif ngspice_LDADD += \ frontend/plotting/libplotting.la ngspice_LDADD += \ spicelib/devices/dev.lo \ $(DYNAMIC_DEVICELIBS) if NDEV_WANTED ngspice_LDADD += spicelib/devices/ndev/libndev.la endif if NUMDEV_WANTED ngspice_LDADD += \ spicelib/devices/nbjt/libnbjt.la \ spicelib/devices/nbjt2/libnbjt2.la \ spicelib/devices/numd/libnumd.la \ spicelib/devices/numd2/libnumd2.la \ spicelib/devices/numos/libnumos.la endif ngspice_LDADD += \ spicelib/analysis/libckt.la \ spicelib/devices/libdev.la if XSPICE_WANTED ngspice_LDADD += \ xspice/cm/libcmxsp.la \ xspice/mif/libmifxsp.la \ xspice/evt/libevtxsp.la \ xspice/enh/libenhxsp.la \ xspice/ipc/libipcxsp.la \ xspice/idn/libidnxsp.la \ @XSPICEDLLIBS@ endif ngspice_LDADD += \ frontend/parser/libparser.la \ frontend/numparam/libnumparam.la \ frontend/trannoise/libtrannoise.la \ spicelib/parser/libinp.la if CIDER_WANTED ngspice_LDADD += \ ciderlib/twod/libcidertwod.la \ ciderlib/oned/libcideroned.la \ ciderlib/input/libciderinput.la \ ciderlib/support/libcidersuprt.la endif ngspice_LDADD += \ maths/deriv/libderiv.la \ maths/cmaths/libcmaths.la \ maths/misc/libmathmisc.la \ maths/fft/libmathfft.la \ maths/poly/libpoly.la \ maths/ni/libni.la \ maths/sparse/libsparse.la \ misc/libmisc.la if !WINDOWS if !NO_X ngspice_LDADD += frontend/help/libhlp.la endif endif ## nutmeg: ngnutmeg_SOURCES = \ main.c \ conf.c \ conf.h \ ngnutmeg.c ngnutmeg_CPPFLAGS = $(AM_CPPFLAGS) if WINDOWS ngnutmeg_SOURCES += winmain.c endif ngnutmeg_LDADD = \ frontend/libfte.la if WINDOWS ngnutmeg_LDADD += \ frontend/wdisp/libwindisp.la endif ngnutmeg_LDADD += \ frontend/plotting/libplotting.la \ frontend/parser/libparser.la \ frontend/numparam/libnumparam.la \ frontend/trannoise/libtrannoise.la \ maths/cmaths/libcmaths.la \ maths/misc/libmathmisc.la \ maths/fft/libmathfft.la \ maths/poly/libpoly.la \ misc/libmisc.la \ spicelib/parser/libinp.la ## These programs are not required on Windows if !WINDOWS if !NO_X ngnutmeg_LDADD += \ frontend/help/libhlp.la endif !NO_X ## help: nghelp_SOURCES = conf.c nghelp.c if !NO_HELP # We keep the libraries to a minimum here and link against terminal.o # rather than the full front-end library libfte.a to avoid link errors that # that would otherwise occur (thanks to Andreas Unger for this fix). nghelp_LDADD = \ frontend/terminal.lo \ misc/libmisc.la if !NO_X nghelp_LDADD += \ frontend/help/libhlp.la endif !NO_X endif !NO_HELP ## sconvert: ngsconvert_SOURCES = ngsconvert.c ngsconvert_LDADD = \ frontend/libfte.la \ frontend/parser/libparser.la \ maths/misc/libmathmisc.la \ misc/libmisc.la ## proc2mod: ngproc2mod_SOURCES = ngproc2mod.c ngproc2mod_LDADD = \ frontend/parser/libparser.la \ spicelib/parser/libinp.la \ misc/libmisc.la ## multidec: ngmultidec_SOURCES = ngmultidec.c ngmultidec_LDADD = \ maths/sparse/libsparse.la \ misc/libmisc.la ## ngmakeidx: ngmakeidx_SOURCES = makeidx.c ## create index for online help: ngspice.idx: ngmakeidx$(EXEEXT) ./ngmakeidx$(EXEEXT) $(srcdir)/ngspice.txt endif !WINDOWS ## General Includes and libraries: AM_CPPFLAGS = -I$(top_srcdir)/src/include -I$(top_srcdir)/src/spicelib/devices @X_CFLAGS@ LIBS = @LIBS@ @X_LIBS@ @X_PRE_LIBS@ @X_EXTRA_LIBS@ if WINDOWS LIBS += -lpsapi endif MAINTAINERCLEANFILES = Makefile.in ngspice.idx ## Tcl: if TCL_MODULE lib_LTLIBRARIES = libspice.la install: install-libLTLIBRARIES install-tcl-recursive install-tclspice install-data-am EXTRA_DIST += tclspice.c initdata_DATA += tclspinit if TCLWIN LIBS += -lpsapi -ltcl84 -lBLT24 endif libspice_la_SOURCES = \ main.c \ conf.c \ conf.h \ ngspice.c \ tclspice.c libspice_la_CPPFLAGS = $(AM_CPPFLAGS) -DSIMULATOR \ -DTCLSPICE_version="\"$(TCLSPICE_VERSION)\"" libspice_la_LIBADD = \ @X_LIBS@ \ frontend/libfte.la if WINDOWS libspice_la_LIBADD += \ frontend/wdisp/libwindisp.la endif libspice_la_LIBADD += \ frontend/plotting/libplotting.la if XSPICE_WANTED libspice_la_LIBADD += \ xspice/cm/libcmxsp.la \ xspice/mif/libmifxsp.la endif libspice_la_LIBADD += \ $(DYNAMIC_DEVICELIBS) if NDEV_WANTED libspice_la_LIBADD += \ spicelib/devices/ndev/libndev.la endif if NUMDEV_WANTED libspice_la_LIBADD += \ spicelib/devices/nbjt/libnbjt.la \ spicelib/devices/nbjt2/libnbjt2.la \ spicelib/devices/numd/libnumd.la \ spicelib/devices/numd2/libnumd2.la \ spicelib/devices/numos/libnumos.la endif libspice_la_LIBADD += \ spicelib/analysis/libckt.la \ spicelib/devices/libdev.la if XSPICE_WANTED libspice_la_LIBADD += \ xspice/evt/libevtxsp.la \ xspice/enh/libenhxsp.la \ xspice/ipc/libipcxsp.la \ xspice/idn/libidnxsp.la \ @XSPICEDLLIBS@ endif libspice_la_LIBADD += \ frontend/parser/libparser.la \ frontend/numparam/libnumparam.la \ frontend/trannoise/libtrannoise.la \ spicelib/parser/libinp.la if CIDER_WANTED libspice_la_LIBADD += \ ciderlib/twod/libcidertwod.la \ ciderlib/oned/libcideroned.la \ ciderlib/input/libciderinput.la \ ciderlib/support/libcidersuprt.la endif libspice_la_LIBADD += \ maths/deriv/libderiv.la \ maths/cmaths/libcmaths.la \ maths/misc/libmathmisc.la \ maths/fft/libmathfft.la \ maths/poly/libpoly.la \ maths/ni/libni.la \ maths/sparse/libsparse.la \ misc/libmisc.la \ $(LIBS) libspice_la_CFLAGS = $(AM_CFLAGS) libspice_la_LDFLAGS = -shared -Wl,--version-script=tclspice.map if TCLWIN libspice_la_LDFLAGS += -no-undefined libspice_la_LDFLAGS += --def spice.def @TCL_LIB_SPEC@ endif if TCLCYG libspice_la_LDFLAGS += -no-undefined libspice_la_LDFLAGS += --def spice.def @TCL_LIB_SPEC@ endif CLEANFILES = pkgIndex.tcl libspice.so TCL_PKG_PATH = @TCL_PACKAGE_PATH@ TCLSPICE_VERSION = @VERSION@ TCL_FILES = libspice.la pkgIndex.tcl pkgIndex.tcl: pkgIndex.tcl.in rm -f $@ sed -e 's;%LIB_DIR%;$(DESTDIR)$(libdir);g' $< | \ sed -e 's;%VERSION%;$(TCLSPICE_VERSION);g' > $@ all: $(TCL_FILES) install-tcl-recursive: list='$(SUBDIRS)'; for subdir in $$list; do \ echo "Making $$target in $$subdir"; \ (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) install) \ || case "$$amf" in *=*) exit 1;; *k*) fail=yes;; *) exit 1;; esac; \ done; install-tclspice: $(mkinstalldirs) $(DESTDIR)$(libdir)/spice $(INSTALL_DATA) pkgIndex.tcl $(DESTDIR)$(libdir)/spice endif TCL_MODULE EXTRA_DIST += spice.def