Index: /trunk/FACT++/CMakeLists.txt
===================================================================
--- /trunk/FACT++/CMakeLists.txt	(revision 18980)
+++ /trunk/FACT++/CMakeLists.txt	(revision 18980)
@@ -0,0 +1,709 @@
+# *********************************
+# ************ cmake **************
+# *********************************
+CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
+CMAKE_POLICY(SET CMP0043 NEW)
+CMAKE_POLICY(SET CMP0048 NEW)
+
+# Enable debug symbols by default
+# must be done before project() statement
+IF (NOT CMAKE_BUILD_TYPE)
+	SET(CMAKE_BUILD_TYPE Debug CACHE STRING "Choose the type of build (Debug or Release)" FORCE)
+ENDIF()
+# (you can also set it on the command line: -D CMAKE_BUILD_TYPE=Release)
+
+# Enable CLANG as default compilers, to change this use
+# cmake -DCMAKE_C_COMPILER=cc -DCMAKE_CXX_COMPILER=c++
+# Note that if compilers are switched on the fly,
+# the cache is deleted
+
+IF (NOT DEFINED CMAKE_C_COMPILER)
+	SET(CMAKE_C_COMPILER   "clang")#   CACHE STRING "Choose the compiler (c++, g++, clang++)" FORCE)
+ENDIF()
+
+IF (NOT DEFINED CMAKE_CXX_COMPILER)
+	SET(CMAKE_CXX_COMPILER "clang++")# CACHE STRING "Choose the compiler (c++, g++, clang++)" FORCE)
+ENDIF()
+
+#SET(CMAKE_VERBOSE_MAKEFILE ON)
+
+# To check for an include file you do this:
+#CHECK_INCLUDE_FILE("stdint.h"        HAVE_STDINT_H)
+# To check the size of a primitive type:
+#CHECK_TYPE_SIZE("int"   SIZEOF_INT)
+
+
+
+# *********************************
+# ************ Project ************
+# *********************************
+
+STRING(TIMESTAMP VERSION %y.%U.%w.%H UTC)
+
+MESSAGE(STATUS "FACT++ V${VERSION}")
+
+PROJECT(fact++ VERSION ${VERSION})
+
+INCLUDE(GNUInstallDirs)
+
+# ======== For config.h.in =========
+SET(PACKAGE_MAINTAINER "Thomas Bretz")
+SET(PACKAGE_BUGREPORT  "tbretz@physik.rwth-aachen.de")
+SET(PACKAGE_URL        "https://www.fact-project.org")
+
+
+
+# *********************************
+# ******** FAMOUS / IceACT ********
+# *********************************
+
+IF(EXISTS "${CMAKE_SOURCE_DIR}/famous")
+	MESSAGE(STATUS "Compilation of 'famous' enabled.")
+        SET(FOUND_FAMOUS ON)
+ENDIF()
+
+IF(EXISTS "${CMAKE_SOURCE_DIR}/iceact")
+	MESSAGE(STATUS "Compilation of 'iceact' enabled.")
+        SET(FOUND_ICEACT ON)
+ENDIF()
+
+
+
+# *********************************
+# ********* Requirements **********
+# *********************************
+
+# ========== executables ==========
+FIND_PROGRAM(HELP2MAN_EXECUTABLE help2man)
+FIND_PROGRAM(JSDOC_EXECUTABLE    jsdoc)
+FIND_PROGRAM(MAILX_EXECUTABLE    mailx)
+FIND_PROGRAM(CURL_EXECUTABLE     curl)
+FIND_PROGRAM(PS2DPF_EXECUTABLE   ps2pdf)
+FIND_PROGRAM(GROFF_EXECUTABLE    groff)
+
+# =========== pkg-config ============
+FIND_PACKAGE(PkgConfig)
+FIND_PACKAGE(PackageHandleStandardArgs)
+
+
+# =========== libraries =============
+
+SET(CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cmake" ${CMAKE_MODULE_PATH})
+
+FIND_PACKAGE(DBus)
+FIND_PACKAGE(Motif)
+FIND_PACKAGE(Nova     REQUIRED)
+FIND_PACKAGE(Readline REQUIRED)
+FIND_PACKAGE(GLUT)
+FIND_PACKAGE(Curses) # FIXME : Requires ncurses panel
+FIND_PACKAGE(ZLIB REQUIRED)
+FIND_PACKAGE(Threads REQUIRED)
+
+INCLUDE_DIRECTORIES("/usr/include/mysql")
+#LINK_DIRECTORIES(${Boost_LIBRARY_DIRS})
+
+
+# =============== BOOST ============
+#SET(Boost_ADDITIONAL_VERSIONS "1.78" "1.78.0" "1.79" "1.79.0")
+FIND_PACKAGE(Boost 1.58.0 REQUIRED
+        date_time
+        filesystem
+        program_options
+        regex
+        system
+        thread)
+INCLUDE_DIRECTORIES(${Boost_INCLUDE_DIRS})
+LINK_DIRECTORIES(${Boost_LIBRARY_DIRS})
+
+# =============== QT5 ==============
+#find_package(Qt5Widgets)
+#SET(CMAKE_AUTOMOC ON)
+#SET(CMAKE_AUTORCC ON)
+SET(CMAKE_INCLUDE_CURRENT_DIR)
+FIND_PACKAGE(Qt5 COMPONENTS Core Widgets Xml REQUIRED)
+#INCLUDE_DIRECTORIES(${Qt5_INCLUDE_DIR})
+
+# dbus-1 dbus-glib-1
+# doxygen
+# libm
+# readline
+# ncurses libpanel panel.h
+# motif
+# GL
+# GLU
+# cfitsio
+# ccfits
+# mysql devel
+# mysqlpp devel
+# boost system, asio, date_time, filesystem, program_options, regex, thread
+# v8
+# Qt4/5 Core QGL QWT
+
+
+# =========== Enable C++11 ===========
+
+SET(CMAKE_CXX_STANDARD 11)
+SET(CMAKE_C_FLAGS "-pedantic")
+
+SET(CMAKE_CXX_FLAGS
+	"${CMAKE_CXX_FLAGS} -Wall -Winit-self -Wpointer-arith \
+         -Wcast-align -Wformat=2 -Woverloaded-virtual \
+         -Wnon-virtual-dtor -Wshadow -fPIC") # -Wextra
+
+# FIXME: Move that to config.h.in
+# -D__MARS__
+SET(CMAKE_CXX_FLAGS
+	"${CMAKE_CXX_FLAGS} \
+         -D_REENTRANT -D__LINUX__ -DHAVE_ZLIB -DHAVE_V8 -DHAVE_SQL -DHAVE_NOVA \
+         -DMARSVER=\\\"${VERSION}\\\" \
+         -DPACKAGE_VERSION=\\\"${VERSION}\\\" \
+         -DREVISION=\\\"${REVISION}\\\" \
+         -DPACKAGE_STRING=\\\"FACT++\\\" \
+         -DPACKAGE_URL=\\\"${PACKAGE_URL}\\\" \
+         -DPACKAGE_BUGREPORT=\\\"${PACKAGE_BUGREPORT}\\\""
+         )
+
+# Flags required for Dim
+SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -DMIPSEL -DPROTOCOL=1 -Dunix -Dlinux")
+
+# --------- config.h -------------
+
+#CONFIGURE_FILE("${PROJECT_SOURCE_DIR}/config.h.in" "${PROJECT_BINARY_DIR}/config.h")
+#INCLUDE_DIRECTORIES("${PROJECT_BINARY_DIR}")
+
+SET(CMAKE_MODULE_PATH $ENV{ROOTSYS}/etc/cmake ${CMAKE_MODULE_PATH})
+
+# You need to tell CMake where to find the ROOT installation. This can be done in a number of ways:
+#   - ROOT built with classic configure/make use the provided $ROOTSYS/etc/cmake/FindROOT.cmake
+#   - ROOT built with CMake. Add in CMAKE_PREFIX_PATH the installation prefix for ROOT
+#LIST(APPEND CMAKE_PREFIX_PATH $ENV{ROOTSYS})
+
+#---Locate the ROOT package and defines a number of variables (e.g. ROOT_INCLUDE_DIRS)
+
+# -lGui -lCore -lCint -lRIO -lNet -lHist -lGraf -lGraf3d -lGpad -lTree
+# -lRint -lPostscript -lMatrix -lPhysics -lMathCore -lThread
+# -lASImage -lMinuit -lHistPainter -lThread
+
+FIND_PACKAGE(ROOT REQUIRED COMPONENTS Gui Minuit)
+INCLUDE_DIRECTORIES(${ROOT_INCLUDE_DIRS})
+
+
+#MESSAGE("INCL_DIRS: ${ROOT_INCLUDE_DIRS}")
+#MESSAGE("LIBS:      ${ROOT_LIBRARIES}")
+#MESSAGE("DEFS:      ${ROOT_DEFINITIONS}")
+#MESSAGE("CXXFLAGS:  ${ROOT_CXX_FLAGS}")
+#MESSAGE("CXFLAGS:   ${ROOT_CC_FLAGS}")
+#MESSAGE("FOUND:     ${ROOT_FOUND}")
+#MESSAGE("FILE:      ${ROOT_USE_FILE}")
+#MESSAGE("DIR:       ${CMAKE_CURRENT_SOURCE_DIR}")
+#ROOT_<library>_LIBRARY	PATH	Full path for each of the ROOT libraries listed in COMPONENTS
+#ROOT_<command>_CMD	PATH	Full path for each ROOT executable (rootcling, root, hadd, etc.)
+#ROOT_<option>_FOUND	BOOL	True for each enabled build option (e.g. cocoa, python, xrootd, etc.)
+
+# -------------------------------------------------------
+
+INCLUDE_DIRECTORIES(pal)
+INCLUDE_DIRECTORIES(erfa/src)
+INCLUDE_DIRECTORIES(dim/dim)
+INCLUDE_DIRECTORIES(externals)
+INCLUDE_DIRECTORIES(src)
+
+# ********************************************************
+# ********************** Libraries ***********************
+# ********************************************************
+
+# =================== libPointing.so ======================
+ADD_LIBRARY(Pointing SHARED
+	pal/pal.h
+	pal/palDtt.c 		pal/palDat.c 		pal/palMappa.c
+	pal/palPrenut.c		pal/palEvp.c 		pal/palAoppa.c
+	pal/palAoppat.c		pal/palRefco.c 		pal/palRefro.c
+	pal/pal1Atmt.c 		pal/palDrange.c		pal/palOne2One.c
+	pal/pal1Atms.c 		pal/palMapqkz.c 	pal/palAopqk.c
+	pal/palRefz.c 		pal/palAmpqk.c 		pal/palRdplan.c
+	pal/palDt.c 		pal/palPvobs.c 		pal/palNut.c
+	pal/palDmoon.c 		pal/palPlanet.c 	pal/palNutc.c
+	pal/palDeuler.c
+	erfa/src/gd2gc.c	erfa/src/p06e.c		erfa/src/c2s.c
+	erfa/src/eform.c	erfa/src/s2c.c		erfa/src/pas.c
+	erfa/src/pmat06.c	erfa/src/epv00.c	erfa/src/plan94.c
+	erfa/src/anpm.c		erfa/src/obl06.c	erfa/src/dat.c
+        erfa/src/af2a.c		erfa/src/rxr.c		erfa/src/gmst06.c
+	erfa/src/sepp.c		erfa/src/rz.c		erfa/src/zp.c
+	erfa/src/rxpv.c		erfa/src/pn.c		erfa/src/cr.c
+	erfa/src/seps.c		erfa/src/ry.c		erfa/src/pdp.c
+	erfa/src/pnm06a.c	erfa/src/hfk5z.c	erfa/src/epj2jd.c
+	erfa/src/pv2s.c		erfa/src/tf2a.c		erfa/src/pm.c
+	erfa/src/sxp.c		erfa/src/a2af.c		erfa/src/rxp.c
+	erfa/src/pxp.c		erfa/src/fk5hip.c	erfa/src/fw2m.c
+	erfa/src/rx.c		erfa/src/tf2d.c		erfa/src/cal2jd.c
+	erfa/src/cp.c		erfa/src/nut06a.c	erfa/src/rm2v.c
+	erfa/src/nut00a.c	erfa/src/ee06a.c	erfa/src/fk5hz.c
+	erfa/src/epb2jd.c	erfa/src/refco.c	erfa/src/a2tf.c
+	erfa/src/fapa03.c	erfa/src/gst06a.c	erfa/src/faf03.c
+	erfa/src/faur03.c	erfa/src/faju03.c	erfa/src/fal03.c
+	erfa/src/fasa03.c	erfa/src/fame03.c 	erfa/src/fave03.c
+	erfa/src/fama03.c 	erfa/src/faom03.c 	erfa/src/gst06.c
+	erfa/src/jd2cal.c	erfa/src/gd2gce.c	erfa/src/anp.c
+	erfa/src/fae03.c	erfa/src/ir.c		erfa/src/pfw06.c
+	erfa/src/bpn2xy.c	erfa/src/eors.c		erfa/src/s06.c
+	erfa/src/trxp.c		erfa/src/era00.c	erfa/src/epj.c
+	erfa/src/d2tf.c		erfa/src/epb.c		erfa/src/rv2m.c
+	erfa/src/pap.c		erfa/src/fad03.c	erfa/src/pmp.c
+	erfa/src/tr.c		erfa/src/falp03.c)
+
+# ======================= libDim.so ======================
+ADD_LIBRARY(Dim SHARED
+#	dim/dim/dic.h
+#	dim/dim/dim_common.h
+#	dim/dim/dim.h
+#	dim/dim/dim_tcpip.h
+#	dim/dim/dis.h
+	dim/src/dic.c
+	dim/src/dis.c
+	dim/src/dna.c
+	dim/src/sll.c
+	dim/src/dll.c
+	dim/src/hash.c
+	dim/src/swap.c
+	dim/src/copy_swap.c
+	dim/src/open_dns.c
+	dim/src/conn_handler.c
+	dim/src/tcpip.c
+	dim/src/dtq.c
+	dim/src/dim_thr.c
+	dim/src/utilities.c)
+
+# ================= libDimExtension.so ===================
+ADD_LIBRARY(DimExtension SHARED
+#        src/DimSetup.h
+	src/DimSetup.cc)
+
+# ===================== libDim++.so ======================
+ADD_LIBRARY(Dim++ SHARED
+#       dim/dim/dic.hxx
+#       dim/dim/dis.hxx
+#       dim/dim/dim_core.hxx
+#       dim/dim/dim.hxx
+#       dim/dim/dim_tcpip.h
+#       dim/dim/dllist.hxx
+#       dim/dim/sllist.hxx
+#       dim/dim/tokenstring.hxx
+#       src/Dim.h
+	dim/src/diccpp.cxx
+	dim/src/dimcpp.cxx
+	dim/src/discpp.cxx
+	dim/src/tokenstring.cxx)
+
+# ================= libStateMachine.so ===================
+ADD_LIBRARY(StateMachine SHARED
+	src/WindowLog.h       src/WindowLog.cc
+	src/Readline.h        src/Readline.cc
+	src/ReadlineColor.h   src/ReadlineColor.cc
+	src/ReadlineWindow.h  src/ReadlineWindow.cc
+	src/Console.h         src/Console.cc
+	src/Shell.h           src/Shell.cc
+	src/EventImp.h        src/EventImp.cc
+	src/Event.h           src/Event.cc
+	src/State.h           src/State.cc
+	src/Description.h     src/Description.cc
+	src/MessageImp.h      src/MessageImp.cc
+	src/Converter.h       src/Converter.cc
+	src/StateMachineImp.h src/StateMachineImp.cc
+	src/StateMachine.h    src/StateMachine.cc
+	src/EventDim.h
+	src/MessageDim.h         src/MessageDim.cc
+	src/StateMachineDim.h    src/StateMachineDim.cc
+	src/DimServerList.h      src/DimServerList.cc
+	src/DimServiceInfoList.h src/DimServiceInfoList.cc
+#	src/DimNetworkList.h     src/DimNetwork.cc
+	src/ServiceList.h        src/ServiceList.cc
+	src/DimErrorRedirecter.h
+	src/DimErrorRedirecter.cc
+	src/DimDescriptionService.h
+	src/DimDescriptionService.cc
+	src/Connection.h      src/Connection.cc
+	src/ConnectionUSB.h   src/ConnectionUSB.cc
+#	FACT.h ByteOrder.h
+	src/DimWriteStatistics.h src/DimWriteStatistics.cc)
+
+# ================= libConfiguration.so ==================
+ADD_LIBRARY(Configuration SHARED
+	src/Configuration.h src/Configuration.cc
+	src/FACT.h src/FACT.cc)
+
+# ===================== libTime.so =======================
+ADD_LIBRARY(Time SHARED
+	src/Time.h src/Time.cc)
+TARGET_LINK_LIBRARIES(Time)# ${NOVA_LIBRARY})
+
+# ===================== libTools.so ======================
+ADD_LIBRARY(Tools SHARED
+	src/tools.h src/tools.cc)
+
+
+
+# ********************************************************
+# ********************** Manuals *************************
+# ********************************************************
+
+FILE(MAKE_DIRECTORY ${PROJECT_BINARY_DIR}/man1)
+FILE(MAKE_DIRECTORY ${PROJECT_BINARY_DIR}/html)
+FILE(MAKE_DIRECTORY ${PROJECT_BINARY_DIR}/pdf)
+
+MACRO(MANPAGE program description)
+# https://samthursfield.wordpress.com/2015/11/21/cmake-dependencies-between-targets-and-files-and-custom-commands/
+        ADD_CUSTOM_COMMAND(
+        	OUTPUT
+                   man1/${program}.1
+                DEPENDS
+                   ${program}
+  		COMMAND
+                   ${HELP2MAN_EXECUTABLE}
+                   ${PROJECT_BINARY_DIR}/${program}
+  	  	   -n "${description}"
+  	  	   --no-info
+  	  	   --output=man1/${program}.1
+		COMMAND
+                   ${GROFF_EXECUTABLE}
+                   -mandoc man1/${program}.1
+                   -T html > html/${program}.html
+		COMMAND
+                   ${GROFF_EXECUTABLE}
+                   -mandoc man1/${program}.1
+                   -T pdf > pdf/${program}.pdf
+                COMMENT
+                   "Generating man-page ${program}.1"
+                VERBATIM)
+
+	ADD_CUSTOM_TARGET(${program}.man ALL DEPENDS man1/${program}.1)
+
+#	INSTALL(FILES ${PROJECT_BINARY_DIR}/${program}.1 DESTINATION "${PKG_MAN}")
+
+ENDMACRO()
+
+
+
+
+# ********************************************************
+# *********************** Helpers ************************
+# ********************************************************
+
+SET(HELP++LIBS Tools Configuration Time ${Boost_LIBRARIES} mysqlpp mysqlclient)
+
+# --------------------------------------------------------
+
+ADD_EXECUTABLE(fitsdump src/fitsdump.cc)
+TARGET_LINK_LIBRARIES(fitsdump ${HELP++LIBS} ZLIB::ZLIB)
+MANPAGE(fitsdump "")
+
+#ADD_EXECUTABLE(fitsloader src/fitsloader.cc)
+#TARGET_LINK_LIBRARIES(fitsloader ${HELP++LIBS})
+#MANPAGE(fitsloader "")
+
+#ADD_EXECUTABLE(fitscheck src/fitscheck.cc)
+#TARGET_LINK_LIBRARIES(fitscheck ${HELP++LIBS} ZLIB::ZLIB)
+#MANPAGE(fitscheck "")
+
+#ADD_EXECUTABLE(fitsCompressor src/fitsCompressor.cc)
+#TARGET_LINK_LIBRARIES(fitsCompressor ${HELP++LIBS} ZLIB::ZLIB)
+#MANPAGE(fitsCompressor "")
+
+#ADD_EXECUTABLE(fitsselect src/fitsselect.cc)
+#TARGET_LINK_LIBRARIES(fitsselect ${HELP++LIBS} ZLIB::ZLIB)
+#MANPAGE(fitsselect "")
+
+ADD_EXECUTABLE(getevent src/getevent.cc)
+TARGET_LINK_LIBRARIES(getevent ${HELP++LIBS} ZLIB::ZLIB)
+MANPAGE(getevent "")
+
+#ADD_EXECUTABLE(readfits src/readfits.cc)
+#TARGET_LINK_LIBRARIES(readfits ${HELP++LIBS} ZLIB::ZLIB)
+#MANPAGE(readfits "")
+
+ADD_EXECUTABLE(rootifysql src/rootifysql.cc)
+TARGET_LINK_LIBRARIES(rootifysql ${HELP++LIBS} ${ROOT_LIBRARIES})
+MANPAGE(rootifysql "")
+
+ADD_EXECUTABLE(root2sql src/root2sql.cc)
+TARGET_LINK_LIBRARIES(root2sql ${HELP++LIBS} ${ROOT_LIBRARIES})
+MANPAGE(root2sql "")
+
+#ADD_EXECUTABLE(calcsource src/calcsource.cc)
+#TARGET_LINK_LIBRARIES(calcsource  ${HELP++LIBS} ${ROOT_LIBRARIES} ${NOVA_LIBRARY} Pointing)
+
+ADD_EXECUTABLE(makeplots src/makeplots.cc)
+TARGET_LINK_LIBRARIES(makeplots  ${HELP++LIBS} ${ROOT_LIBRARIES} ${NOVA_LIBRARY})
+MANPAGE(makeplots "")
+
+ADD_EXECUTABLE(makedata src/makedata.cc)
+TARGET_LINK_LIBRARIES(makedata ${HELP++LIBS} ${NOVA_LIBRARY})
+MANPAGE(makedata "")
+
+ADD_EXECUTABLE(makeschedule src/makeschedule.cc)
+TARGET_LINK_LIBRARIES(makeschedule ${HELP++LIBS} ${NOVA_LIBRARY})
+MANPAGE(makeschedule "")
+
+ADD_EXECUTABLE(showlog src/showlog.cc src/WindowLog.cc)
+TARGET_LINK_LIBRARIES(showlog ${HELP++LIBS} ncurses)
+MANPAGE(showlog "")
+
+ADD_EXECUTABLE(zfits src/zfits.cc)
+TARGET_LINK_LIBRARIES(zfits ${HELP++LIBS} ZLIB::ZLIB)
+MANPAGE(zfits "")
+
+
+
+# ********************************************************
+# ********************* Operation ************************
+# ********************************************************
+
+SET(FACT++LIBS StateMachine Tools Configuration Time Dim++ Dim DimExtension
+        ${Boost_LIBRARIES} mysqlpp readline ncurses panel) # HAVE_SQL
+
+# --------------------------------------------------------
+
+ADD_EXECUTABLE(agilentctrl src/agilentctrl.cc)
+TARGET_LINK_LIBRARIES(agilentctrl ${FACT++LIBS})
+MANPAGE(agilentctrl "")
+
+ADD_EXECUTABLE(biasctrl src/biasctrl.cc)
+TARGET_LINK_LIBRARIES(biasctrl ${FACT++LIBS})
+MANPAGE(biasctrl "")
+
+ADD_EXECUTABLE(biastemp src/biastemp.cc)
+TARGET_LINK_LIBRARIES(biastemp ${FACT++LIBS})
+MANPAGE(biastemp "")
+
+ADD_EXECUTABLE(chatserv src/chatserv.cc)
+TARGET_LINK_LIBRARIES(chatserv ${FACT++LIBS}) # does not require libpanel
+MANPAGE(chatserv "")
+
+ADD_EXECUTABLE(chatclient src/chatclient.cc)
+TARGET_LINK_LIBRARIES(chatclient ${FACT++LIBS}) # does not require libpanel
+MANPAGE(chatclient "")
+
+#ADD_EXECUTABLE(cosyctrl src/cosyctrl.cc)# src/LocalControl.h
+#TARGET_LINK_LIBRARIES(cosyctrl
+#	StateMachine Tools Configuration Time Dim++ Dim DimExtension
+#        ${Boost_LIBRARIES} readline ncurses)
+
+ADD_EXECUTABLE(dimctrl src/dimctrl.cc
+	src/StateMachineDimControl.cc
+        src/RemoteControl.cc
+        src/InterpreterV8.cc
+        src/DimState.cc)
+TARGET_LINK_LIBRARIES(dimctrl ${FACT++LIBS} ${NOVA_LIBRARY} Pointing ZLIB::ZLIB v8)
+MANPAGE(dimctrl "")
+
+ADD_CUSTOM_TARGET(dimserver ALL
+	COMMAND ln -sf dimctrl dimserver
+        COMMENT "Creating symlink for dimserver"
+	DEPENDS dimctrl)
+
+ADD_EXECUTABLE(drivectrl src/drivectrl.cc)
+TARGET_LINK_LIBRARIES(drivectrl ${FACT++LIBS} ${NOVA_LIBRARY} Pointing)
+MANPAGE(drivectrl "")
+
+ADD_EXECUTABLE(evtserver src/evtserver.cc)
+TARGET_LINK_LIBRARIES(evtserver ${FACT++LIBS} ${NOVA_LIBRARY} ZLIB::ZLIB)
+MANPAGE(evtserver "")
+
+ADD_EXECUTABLE(feedback src/feedback.cc)
+TARGET_LINK_LIBRARIES(feedback ${FACT++LIBS})
+MANPAGE(feedback "")
+
+ADD_EXECUTABLE(fscctrl src/fscctrl.cc src/HeadersFTM.cc)
+TARGET_LINK_LIBRARIES(fscctrl ${FACT++LIBS})
+MANPAGE(fscctrl "")
+
+ADD_EXECUTABLE(ftmctrl src/ftmctrl.cc src/HeadersFTM.cc)
+TARGET_LINK_LIBRARIES(ftmctrl ${FACT++LIBS})
+MANPAGE(ftmctrl "")
+
+ADD_EXECUTABLE(gcn src/gcn.cc)
+TARGET_LINK_LIBRARIES(gcn ${FACT++LIBS} ${NOVA_LIBRARY})
+MANPAGE(gcn "")
+QT5_USE_MODULES(gcn Xml)
+
+ADD_EXECUTABLE(gpsctrl src/gpsctrl.cc)
+TARGET_LINK_LIBRARIES(gpsctrl ${FACT++LIBS})
+MANPAGE(gpsctrl "")
+
+ADD_EXECUTABLE(lidctrl src/lidctrl.cc)
+TARGET_LINK_LIBRARIES(lidctrl ${FACT++LIBS})
+QT5_USE_MODULES(lidctrl Xml)
+MANPAGE(lidctrl "")
+
+ADD_EXECUTABLE(magiclidar src/magiclidar.cc)
+TARGET_LINK_LIBRARIES(magiclidar ${FACT++LIBS})
+MANPAGE(magiclidar "")
+
+ADD_EXECUTABLE(magicweather src/magicweather.cc)
+TARGET_LINK_LIBRARIES(magicweather ${FACT++LIBS})
+MANPAGE(magicweather "")
+
+ADD_EXECUTABLE(mcp src/mcp.cc)
+TARGET_LINK_LIBRARIES(mcp ${FACT++LIBS})
+MANPAGE(mcp "")
+
+ADD_EXECUTABLE(pfminictrl src/pfminictrl.cc)
+TARGET_LINK_LIBRARIES(pfminictrl ${FACT++LIBS})
+MANPAGE(pfminictrl "")
+
+ADD_EXECUTABLE(pwrctrl src/pwrctrl.cc src/HeadersPower.cc)
+TARGET_LINK_LIBRARIES(pwrctrl ${FACT++LIBS})
+MANPAGE(pwrctrl "")
+QT5_USE_MODULES(pwrctrl Xml)
+
+ADD_EXECUTABLE(ratecontrol src/ratecontrol.cc)
+TARGET_LINK_LIBRARIES(ratecontrol ${FACT++LIBS})
+MANPAGE(ratecontrol "")
+
+ADD_EXECUTABLE(ratescan src/ratescan.cc)
+TARGET_LINK_LIBRARIES(ratescan ${FACT++LIBS})
+MANPAGE(ratescan "")
+
+#ADD_EXECUTABLE(scheduler src/scheduler.cc)
+#TARGET_LINK_LIBRARIES(scheduler ${FACT++LIBS})
+#MANPAGE(scheduler "")
+
+#ADD_EXECUTABLE(skypeclient src/skypeclient.cc)
+#TARGET_LINK_LIBRARIES(skypeclient ${FACT++LIBS})
+#MANPAGE(skypeclient "")
+
+ADD_EXECUTABLE(sqmctrl src/sqmctrl.cc)
+TARGET_LINK_LIBRARIES(sqmctrl ${FACT++LIBS})
+MANPAGE(sqmctrl "")
+
+ADD_EXECUTABLE(smartfact src/smartfact.cc)
+TARGET_LINK_LIBRARIES(smartfact ${FACT++LIBS} ${NOVA_LIBRARY}) # HAVE_NOVA
+MANPAGE(smartfact "")
+
+ADD_EXECUTABLE(temperature src/temperature.cc)
+TARGET_LINK_LIBRARIES(temperature ${FACT++LIBS})
+MANPAGE(temperature "")
+
+ADD_EXECUTABLE(timecheck src/timecheck.cc)
+TARGET_LINK_LIBRARIES(timecheck ${FACT++LIBS})
+MANPAGE(timecheck "")
+
+ADD_EXECUTABLE(tngweather src/tngweather.cc)
+TARGET_LINK_LIBRARIES(tngweather ${FACT++LIBS})
+MANPAGE(tngweather "")
+QT5_USE_MODULES(tngweather Xml)
+
+#ADD_EXECUTABLE(triggerschedule src/triggerschedule.cc)
+#TARGET_LINK_LIBRARIES(triggerschedule ${FACT++LIBS})
+#MANPAGE(triggerschedule "")
+
+# *****************************************************************
+
+#dclient5_SOURCES = src/dclient5.cc src/LocalControl.h
+#dclient5_LDADD   = libDim++.la libDim.la libStateMachine.la libTime.la libTools.la \
+#    libConfiguration.la
+
+#fadctrl_SOURCES = src/fadctrl.cc src/LocalControl.h src/HeadersFAD.cc \
+#	src/EventBuilder.cc     src/EventBuilder.h \
+#	src/DataProcessorImp.cc src/DataProcessorImp.h \
+#	src/DataCalib.cc        src/DataCalib.h \
+#	src/DataWriteRaw.cc     src/DataWriteRaw.h \
+#	src/DrsCalib.h
+#if HAS_FITS
+#fadctrl_SOURCES += src/FitsFile.h src/FitsFile.cc \
+#	src/DataWriteFits.cc    src/DataWriteFits.h \
+#	src/DataWriteFits2.cc   src/DataWriteFits2.h
+#endif
+##fadctrl_LDADD   = libDim++.la libDim.la  libDimExtension.la \
+#	libStateMachine.la libTools.la libTime.la \
+#    	libConfiguration.la
+
+#argv_SOURCES = src/argv.cc
+#argv_LDADD = libConfiguration.la
+
+#time_SOURCES = src/time.cc
+#time_LDADD = libTime.la
+
+#test_SOURCES = src/test.cc
+#test_LDADD = libStateMachine.la libTools.la libTime.la libDim++.la libDim.la libConfiguration.la
+
+#datalogger_SOURCES = src/datalogger.cc src/LocalControl.h src/DimState.cc src/DimState.h
+#if HAS_FITS
+#datalogger_SOURCES += src/FitsFile.h src/FitsFile.cc src/Fits.h src/Fits.cc
+#endif
+#datalogger_LDADD  = libDim++.la libDim.la libDimExtension.la \
+#	libStateMachine.la libTools.la libTime.la \
+#    	libConfiguration.la
+
+# -----
+
+#if HAS_GUI
+
+#fact_DIALOGS = \
+#	gui/design.ui
+
+#fact_RESOURCES = \
+#	gui/design.qrc
+
+#fact_QT_SOURCES = \
+#	gui/DockWindow.cc \
+#	gui/MainWindow.cc \
+#	gui/QCameraWidget.cc \
+#	gui/BasicGlCamera.cc
+
+#fact_SRCADD = $(fact_DIALOGS:.ui=.h) $(fact_RESOURCES:.qrc=.cc) $(fact_QT_SOURCES:.cc=.moc.cc)
+
+#endif
+
+# -----
+
+#if HAS_VIEWER
+
+#viewer_DIALOGS = \
+#	gui/RawEventsViewer/viewer.ui
+
+#viewer_QT_SOURCES = \
+#	gui/RawEventsViewer/RawEventsViewer.cc \
+#	gui/BasicGlCamera.cc \
+#	gui/QCameraWidget.cc \
+#	gui/Q3DCameraWidget.cc
+
+#viewer_SRCADD = $(viewer_DIALOGS:.ui=.h) $(viewer_RESOURCES:.qrc=.cc) $(viewer_QT_SOURCES:.cc=.moc.cc)
+
+#endif
+
+
+IF(FOUND_FAMOUS)
+	INCLUDE_DIRECTORIES(famous/ui)
+	INCLUDE_DIRECTORIES(famous/src)
+
+	ADD_EXECUTABLE(famousbias famous/src/biasctrl.cc)
+	TARGET_LINK_LIBRARIES(famousbias ${FACT++LIBS})
+	MANPAGE(famousbias "")
+
+#	ADD_EXECUTABLE(famouspsu famous/src/famouspsu.cc)
+#	TARGET_LINK_LIBRARIES(famouspsu ${FACT++LIBS})
+#	MANPAGE(famouspsu "")
+
+	ADD_EXECUTABLE(famousui famous/ui/famousui.cc)
+	TARGET_LINK_LIBRARIES(famousui ${FACT++LIBS})
+	MANPAGE(famousui "")
+
+	ADD_EXECUTABLE(ftuctrl famous/src/ftuctrl.cc)
+	TARGET_LINK_LIBRARIES(ftuctrl ${FACT++LIBS})
+	MANPAGE(ftuctrl "")
+
+	ADD_EXECUTABLE(miniftmctrl famous/src/miniftmctrl.cc)
+	TARGET_LINK_LIBRARIES(miniftmctrl ${FACT++LIBS})
+	MANPAGE(miniftmctrl "")
+
+#	ADD_EXECUTABLE(ratecontrol famous/src/ratecontrol.cc)
+#	TARGET_LINK_LIBRARIES(ratecontrol ${FACT++LIBS})
+#	MANPAGE(ratecontrol "")
+ENDIF()
+
+IF(FOUND_ICEACT)
+#	ADD_EXECUTABLE(psuctrl iceact/src/psuctrl.cc)
+#	TARGET_LINK_LIBRARIES(psuctrl ${FACT++LIBS})
+#	MANPAGE(psuctrl "")
+ENDIF()
