version 0.3.33
[fms.git] / CMakeLists.txt
index 9c0e66a..88af084 100644 (file)
@@ -1,22 +1,42 @@
+CMAKE_MINIMUM_REQUIRED(VERSION 2.4)\r
+IF(COMMAND CMAKE_POLICY)\r
+       CMAKE_POLICY(SET CMP0003 OLD)\r
+ENDIF(COMMAND CMAKE_POLICY)\r
+\r
 PROJECT(fms)\r
 \r
-SET(FMS_SRC \r
+OPTION(USE_BUNDLED_SQLITE "Use the bundled SQLite3 library." ON)\r
+IF(APPLE)\r
+       SET(USE_BUNDLED_SQLITE ON)\r
+ENDIF(APPLE)\r
+OPTION(DO_CHARSET_CONVERSION "Do charset conversion on sent messages to UTF-8.  This requires libiconv." ON)\r
+OPTION(I_HAVE_READ_THE_README "I have fully read and understood the readme.txt." OFF)\r
+OPTION(ALTERNATE_CAPTCHA "Use alternate captcha.  This requires the FreeImage library." OFF)\r
+OPTION(QUERY_LOG "Log all database queries made by FMS." OFF)\r
+OPTION(FROST_SUPPORT "Compile with support for downloading Frost messages." ON)\r
+\r
+SET(FMS_SRC\r
 src/base64.cpp\r
+src/bitmapvalidator.cpp\r
 src/board.cpp\r
 src/boardlist.cpp\r
-src/commandthread.cpp\r
-src/datetime.cpp\r
+src/dbconversions.cpp\r
+src/dbmaintenancethread.cpp\r
+src/dbsetup.cpp\r
+src/fmsapp.cpp\r
 src/global.cpp\r
 src/hex.cpp\r
-src/logfile.cpp\r
+src/ipaddressacl.cpp\r
+src/localidentity.cpp\r
 src/main.cpp\r
 src/message.cpp\r
 src/messagelist.cpp\r
+src/messagethread.cpp\r
 src/option.cpp\r
+src/optionssetup.cpp\r
 src/socketdefines.cpp\r
 src/stringfunctions.cpp\r
-src/threadcontroller.cpp\r
-src/uuidgenerator.cpp\r
+src/threadbuilder.cpp\r
 src/db/sqlite3db.cpp\r
 src/db/sqlite3recordset.cpp\r
 src/db/sqlite3statement.cpp\r
@@ -24,6 +44,9 @@ src/freenet/boardlistinserter.cpp
 src/freenet/boardlistrequester.cpp\r
 src/freenet/boardlistxml.cpp\r
 src/freenet/fcpv2.cpp\r
+src/freenet/fileinserter.cpp\r
+src/freenet/fmsversionrequester.cpp\r
+src/freenet/fmsversionxml.cpp\r
 src/freenet/freenetmasterthread.cpp\r
 src/freenet/freenetssk.cpp\r
 src/freenet/identityinserter.cpp\r
@@ -32,6 +55,7 @@ src/freenet/identityintroductionrequester.cpp
 src/freenet/identityintroductionxml.cpp\r
 src/freenet/identityrequester.cpp\r
 src/freenet/identityxml.cpp\r
+src/freenet/inactivemessagelistrequester.cpp\r
 src/freenet/introductionpuzzleinserter.cpp\r
 src/freenet/introductionpuzzlerequester.cpp\r
 src/freenet/introductionpuzzlexml.cpp\r
@@ -41,31 +65,45 @@ src/freenet/messagelistrequester.cpp
 src/freenet/messagelistxml.cpp\r
 src/freenet/messagerequester.cpp\r
 src/freenet/messagexml.cpp\r
-src/freenet/periodicdbmaintenance.cpp\r
+src/freenet/siteinserter.cpp\r
 src/freenet/trustlistinserter.cpp\r
 src/freenet/trustlistrequester.cpp\r
 src/freenet/trustlistxml.cpp\r
 src/freenet/unkeyedidcreator.cpp\r
+src/freenet/unknownidentityrequester.cpp\r
 src/freenet/captcha/simplecaptcha.cpp\r
 src/freenet/captcha/easybmp/EasyBMP.cpp\r
 src/freenet/captcha/easybmp/EasyBMP_Font.cpp\r
 src/freenet/captcha/easybmp/EasyBMP_Geometry.cpp\r
+src/http/fmshttprequesthandlerfactory.cpp\r
 src/http/httpthread.cpp\r
 src/http/identityexportxml.cpp\r
 src/http/ipagehandler.cpp\r
+src/http/multipartparser.cpp\r
 src/http/pages/addpeerpage.cpp\r
 src/http/pages/announceidentitypage.cpp\r
 src/http/pages/boardspage.cpp\r
+src/http/pages/confirmpage.cpp\r
 src/http/pages/controlboardpage.cpp\r
 src/http/pages/createidentitypage.cpp\r
 src/http/pages/execquerypage.cpp\r
+src/http/pages/forumcreatepostpage.cpp\r
+src/http/pages/forummainpage.cpp\r
+src/http/pages/forumthreadspage.cpp\r
+src/http/pages/forumviewthreadpage.cpp\r
 src/http/pages/homepage.cpp\r
+src/http/pages/insertedfilespage.cpp\r
 src/http/pages/localidentitiespage.cpp\r
 src/http/pages/optionspage.cpp\r
 src/http/pages/peerdetailspage.cpp\r
 src/http/pages/peermaintenancepage.cpp\r
 src/http/pages/peertrustpage.cpp\r
+src/http/pages/recentlyaddedpage.cpp\r
 src/http/pages/showcaptchapage.cpp\r
+src/http/pages/showimagepage.cpp\r
+src/http/pages/showpendingmessagepage.cpp\r
+src/http/pages/versioninfopage.cpp\r
+src/nntp/extensiontrust.cpp\r
 src/nntp/nntpconnection.cpp\r
 src/nntp/nntplistener.cpp\r
 src/nntp/uwildmat.cpp\r
@@ -73,29 +111,58 @@ src/nntp/mime/Mime.cpp
 src/nntp/mime/MimeChar.cpp\r
 src/nntp/mime/MimeCode.cpp\r
 src/nntp/mime/MimeType.cpp\r
-src/pthreadwrapper/guard.cpp\r
-src/pthreadwrapper/mutex.cpp\r
-src/pthreadwrapper/runnable.cpp\r
-src/pthreadwrapper/thread.cpp\r
-src/pthreadwrapper/threadedexecutor.cpp\r
-src/xyssl/sha1.c\r
+src/threadwrapper/threadedexector.cpp\r
+src/unicode/ConvertUTF.c\r
+src/unicode/unicodeformatter.cpp\r
+src/unicode/utfconversion.cpp\r
 )\r
 \r
-IF(WIN32)\r
-       SET(FMS_PLATFORM_SRC src/fmsservice.cpp)\r
-ELSE(WIN32)\r
-       SET(FMS_PLATFORM_SRC src/fmsdaemon.cpp)\r
-ENDIF(WIN32)\r
+SET(FMS_PLATFORM_SRC )\r
+\r
+IF(DO_CHARSET_CONVERSION)\r
+       SET(FMS_SRC ${FMS_SRC} src/charsetconverter.cpp)\r
+ENDIF(DO_CHARSET_CONVERSION)\r
+\r
+IF(ALTERNATE_CAPTCHA)\r
+       SET(FMS_SRC ${FMS_SRC} \r
+       src/freenet/captcha/alternatecaptcha1.cpp\r
+       src/freenet/captcha/alternatecaptcha2.cpp\r
+       src/freenet/captcha/alternatecaptchafonts.cpp\r
+       src/freenet/captcha/freeimage/bitmap.cpp\r
+       src/freenet/captcha/freeimage/font.cpp)\r
+ELSE(ALTERNATE_CAPTCHA)\r
+       MESSAGE(STATUS "You are using the old captcha generator.  Add a -D ALTERNATE_CAPTCHA=ON to the command line to use the alternate captcha generator.")\r
+ENDIF(ALTERNATE_CAPTCHA)\r
 \r
-ADD_DEFINITIONS(-DTIXML_USE_STL)\r
+IF(FROST_SUPPORT)\r
+# TODO - add source files for frost support\r
+       SET(FMS_SRC ${FMS_SRC}\r
+       src/freenet/frostidentity.cpp\r
+       src/freenet/frostmessagerequester.cpp\r
+       src/freenet/frostmessagexml.cpp)\r
+ENDIF(FROST_SUPPORT)\r
 \r
-# was for ZThreads\r
-#IF(CMAKE_COMPILER_IS_GNUCXX)\r
-#      #ADD_DEFINITIONS(-fpermissive)\r
-#      SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fpermissive")\r
-#ENDIF(CMAKE_COMPILER_IS_GNUCXX)\r
+# Get a relative list of include files.\r
+FILE(GLOB_RECURSE FMS_INC RELATIVE ${CMAKE_CURRENT_SOURCE_DIR} include/*.h)\r
 \r
-ADD_EXECUTABLE(fms ${FMS_SRC} ${FMS_PLATFORM_SRC})\r
+# Create source groups for all sources and includes, in their original directory structure.\r
+FOREACH(SRC ${FMS_SRC} ${FMS_INC})\r
+       STRING(REGEX REPLACE ${CMAKE_CURRENT_SOURCE_DIR} "Files" REL_DIR "${SRC}")\r
+       STRING(REGEX REPLACE "[\\\\/][^\\\\/]*$" "" REL_DIR "${REL_DIR}")\r
+       STRING(REGEX REPLACE "^[\\\\/]" "" REL_DIR "${REL_DIR}")\r
+       IF(REL_DIR)\r
+               STRING(REPLACE "/" "\\" REL_DIR "${REL_DIR}")\r
+               SOURCE_GROUP(${REL_DIR} FILES ${SRC})\r
+       ELSE(REL_DIR)\r
+               SOURCE_GROUP(Files FILES ${SRC})\r
+       ENDIF(REL_DIR)\r
+ENDFOREACH(SRC)\r
+\r
+IF(NOT I_HAVE_READ_THE_README)\r
+       MESSAGE(FATAL_ERROR "You must fully read the readme.txt before continuing.")\r
+ENDIF(NOT I_HAVE_READ_THE_README)\r
+\r
+ADD_EXECUTABLE(fms ${FMS_SRC} ${FMS_PLATFORM_SRC} ${FMS_INC})\r
 \r
 # link dl - For SQLite3 and shttpd - not for FreeBSD\r
 IF(CMAKE_COMPILER_IS_GNUCC)\r
@@ -112,9 +179,10 @@ IF(CMAKE_SYSTEM_NAME STREQUAL "FreeBSD")
        ENDIF(CMAKE_COMPILER_IS_GNUCXX)\r
 ENDIF(CMAKE_SYSTEM_NAME STREQUAL "FreeBSD")\r
 \r
-# link ws2_32 for Windows\r
+# link ws2_32 and iphlpapi for Windows\r
 IF(WIN32)\r
        TARGET_LINK_LIBRARIES(fms ws2_32)\r
+       TARGET_LINK_LIBRARIES(fms iphlpapi)\r
 ENDIF(WIN32)\r
 \r
 # add -lxnet and -lsocket on solaris\r
@@ -123,47 +191,129 @@ IF(CMAKE_SYSTEM_NAME STREQUAL "SunOS")
        TARGET_LINK_LIBRARIES(fms socket)\r
 ENDIF(CMAKE_SYSTEM_NAME STREQUAL "SunOS")\r
 \r
-FIND_LIBRARY(SQLITE3_LIBRARY NAMES sqlite3 sqlite3_s)\r
-FIND_LIBRARY(TINYXML_LIBRARY NAMES tinyxml tinyxml_s)\r
+IF(NOT USE_BUNDLED_SQLITE)\r
+       FIND_LIBRARY(SQLITE3_LIBRARY NAMES sqlite3 sqlite3_s)\r
+ENDIF(NOT USE_BUNDLED_SQLITE)\r
+\r
+FIND_LIBRARY(POCO_FOUNDATION_LIBRARY NAMES PocoFoundation PocoFoundationmt)\r
+FIND_LIBRARY(POCO_NET_LIBRARY NAMES PocoNet PocoNetmt)\r
+FIND_LIBRARY(POCO_UTIL_LIBRARY NAMES PocoUtil PocoUtilmt)\r
+FIND_LIBRARY(POCO_XML_LIBRARY NAMES PocoXML PocoXMLmt)\r
 FIND_LIBRARY(PTHREADS_LIBRARY NAMES pthread pthreads pthreadvc2)\r
-FIND_LIBRARY(SHTTPD_LIBRARY NAMES shttpd)\r
+FIND_LIBRARY(ICONV_LIBRARY NAMES iconv iconv_s libiconv libiconv_s)\r
+IF(ALTERNATE_CAPTCHA)\r
+       FIND_FILE(FREEIMAGE_LIBRARY NAMES libfreeimage.a PATHS /usr/lib/)\r
+       IF(NOT FREEIMAGE_LIBRARY)\r
+               FIND_LIBRARY(FREEIMAGE_LIBRARY NAMES FreeImage libFreeImage libfreeimage freeimage)\r
+       ENDIF(NOT FREEIMAGE_LIBRARY)\r
+ENDIF(ALTERNATE_CAPTCHA)\r
+\r
+IF(POCO_FOUNDATION_LIBRARY)\r
+       # We don't need to explicitly link under MSVC, POCO uses #pragmas to specify linked libraries.\r
+       IF(NOT MSVC)\r
+               TARGET_LINK_LIBRARIES(fms ${POCO_FOUNDATION_LIBRARY})\r
+       ENDIF(NOT MSVC)\r
+       ADD_DEFINITIONS(-DPOCO_HAVE_IPv6)\r
+       IF(WIN32)\r
+               ADD_DEFINITIONS(-DPOCO_STATIC)\r
+       ENDIF(WIN32)\r
+       IF(POCO_UTIL_LIBRARY)\r
+               IF(NOT MSVC)\r
+                       TARGET_LINK_LIBRARIES(fms ${POCO_UTIL_LIBRARY})\r
+               ENDIF(NOT MSVC)\r
+       ELSE(POCO_UTIL_LIBRARY)\r
+               MESSAGE(FATAL_ERROR "Could not find system Poco Util library.  You must set the location manually.")\r
+       ENDIF(POCO_UTIL_LIBRARY)\r
+       IF(POCO_NET_LIBRARY)\r
+               IF(NOT MSVC)\r
+                       TARGET_LINK_LIBRARIES(fms ${POCO_NET_LIBRARY})\r
+               ENDIF(NOT MSVC)\r
+       ELSE(POCO_NET_LIBRARY)\r
+               MESSAGE(FATAL_ERROR "Could not find system Poco Net library.  You must set the location manually.")\r
+       ENDIF(POCO_NET_LIBRARY)\r
+       IF(POCO_XML_LIBRARY)\r
+               IF(NOT MSVC)\r
+                       TARGET_LINK_LIBRARIES(fms ${POCO_XML_LIBRARY})\r
+               ENDIF(NOT MSVC)\r
+       ELSE(POCO_XML_LIBRARY)\r
+               MESSAGE(FATAL_ERROR "Could not find system Poco XML library.  You must set the location manually.")\r
+       ENDIF(POCO_XML_LIBRARY)\r
+ELSE(POCO_FOUNDATION_LIBRARY)\r
+       MESSAGE(FATAL_ERROR "Could not find system Poco Foundation library.  You must set the location manually.")\r
+ENDIF(POCO_FOUNDATION_LIBRARY)\r
+\r
+IF(NOT WIN32)\r
+       IF(PTHREADS_LIBRARY)\r
+               TARGET_LINK_LIBRARIES(fms ${PTHREADS_LIBRARY})\r
+       ELSE(PTHREADS_LIBRARY)\r
+               MESSAGE(FATAL_ERROR "Could not find system pthread library.  You must set the location manually.")\r
+       ENDIF(PTHREADS_LIBRARY)\r
+ENDIF(NOT WIN32)\r
 \r
 IF(SQLITE3_LIBRARY)\r
+       MESSAGE(STATUS "Linking against system SQLite3 library.")\r
        TARGET_LINK_LIBRARIES(fms ${SQLITE3_LIBRARY})\r
 ELSE(SQLITE3_LIBRARY)\r
-       MESSAGE(STATUS "Could not find system SQLite library.  Will compile from included source.")\r
+       IF(NOT USE_BUNDLED_SQLITE)\r
+               MESSAGE(STATUS "Could not find system SQLite3 library.  Will compile from included source.")\r
+       ENDIF(NOT USE_BUNDLED_SQLITE)\r
        ADD_LIBRARY(sqlite3 libs/sqlite3/sqlite3.c)\r
        TARGET_LINK_LIBRARIES(fms sqlite3)\r
        INCLUDE_DIRECTORIES(libs/sqlite3)\r
 ENDIF(SQLITE3_LIBRARY)\r
 \r
-IF(TINYXML_LIBRARY)\r
-       TARGET_LINK_LIBRARIES(fms ${TINYXML_LIBRARY})\r
-ELSE(TINYXML_LIBRARY)\r
-       MESSAGE(STATUS "Could not find system TinyXML library.  Will compile from included source.")\r
-       ADD_LIBRARY(tinyxml libs/tinyxml/tinystr.cpp libs/tinyxml/tinyxml.cpp libs/tinyxml/tinyxmlerror.cpp libs/tinyxml/tinyxmlparser.cpp)\r
-       TARGET_LINK_LIBRARIES(fms tinyxml)\r
-       INCLUDE_DIRECTORIES(libs/tinyxml)\r
-ENDIF(TINYXML_LIBRARY)\r
-\r
-IF(PTHREADS_LIBRARY)\r
-       TARGET_LINK_LIBRARIES(fms ${PTHREADS_LIBRARY})\r
-ELSE(PTHREADS_LIBRARY)\r
-       MESSAGE(FATAL ERROR "Could not find pthreads library.  You must set the location manually.")\r
-ENDIF(PTHREADS_LIBRARY)\r
-\r
-IF(SHTTPD_LIBRARY)\r
-       TARGET_LINK_LIBRARIES(fms ${SHTTPD_LIBRARY})\r
-ELSE(SHTTPD_LIBRARY)\r
-       MESSAGE(STATUS "Could not find shttpd library.  Will compile from included source.")\r
-       ADD_DEFINITIONS(-DEMBEDDED)\r
-       INCLUDE_DIRECTORIES(libs/shttpd/include)\r
-       IF(WIN32)\r
-               ADD_DEFINITIONS(-DNO_GUI)\r
-               SET(SHTTPD_PLATFORM_SRC libs/shttpd/compat_win32.c)\r
-       ELSE(WIN32)\r
-               SET(SHTTPD_PLATFORM_SRC libs/shttpd/compat_unix.c)\r
-       ENDIF(WIN32)\r
-       ADD_LIBRARY(shttpd ${SHTTPD_PLATFORM_SRC} libs/shttpd/auth.c libs/shttpd/cgi.c libs/shttpd/config.c libs/shttpd/io_cgi.c libs/shttpd/io_dir.c libs/shttpd/io_emb.c libs/shttpd/io_file.c libs/shttpd/io_socket.c libs/shttpd/io_ssi.c libs/shttpd/io_ssl.c libs/shttpd/log.c libs/shttpd/md5.c libs/shttpd/mime_type.c libs/shttpd/shttpd.c libs/shttpd/string.c)\r
-       TARGET_LINK_LIBRARIES(fms shttpd)\r
-ENDIF(SHTTPD_LIBRARY)\r
+IF(DO_CHARSET_CONVERSION)\r
+       ADD_DEFINITIONS(-DDO_CHARSET_CONVERSION)\r
+       IF(ICONV_LIBRARY)\r
+               TARGET_LINK_LIBRARIES(fms ${ICONV_LIBRARY})\r
+       ELSE(ICONV_LIBRARY)\r
+               IF(WIN32)\r
+                       MESSAGE(FATAL_ERROR "Could not find iconv library.  You must set the location manually, or turn off charset conversion.")\r
+               ENDIF(WIN32)\r
+       ENDIF(ICONV_LIBRARY)\r
+ENDIF(DO_CHARSET_CONVERSION)\r
+\r
+IF(ALTERNATE_CAPTCHA)\r
+       IF(FREEIMAGE_LIBRARY)\r
+               TARGET_LINK_LIBRARIES(fms ${FREEIMAGE_LIBRARY})\r
+               ADD_DEFINITIONS("-DALTERNATE_CAPTCHA")\r
+       ELSE(FREEIMAGE_LIBRARY)\r
+               MESSAGE(FATAL_ERROR "Could not find the FreeImage library.  Set the location manually, or turn off the alternate captchas.")\r
+       ENDIF(FREEIMAGE_LIBRARY)\r
+ENDIF(ALTERNATE_CAPTCHA)\r
+\r
+IF(FROST_SUPPORT)\r
+       FIND_LIBRARY(TOMCRYPT_LIBRARY NAMES tomcrypt libtomcrypt)\r
+       FIND_LIBRARY(TOMMATH_LIBRARY NAMES tommath libtommath)\r
+       \r
+       IF(TOMMATH_LIBRARY)\r
+               TARGET_LINK_LIBRARIES(fms ${TOMMATH_LIBRARY})\r
+       ELSE(TOMMATH_LIBRARY)\r
+               #ADD_LIBRARY(tommath ${LIBTOMMATH_SRC})\r
+               ADD_SUBDIRECTORY(libs/libtommath)\r
+               TARGET_LINK_LIBRARIES(fms tommath)\r
+               INCLUDE_DIRECTORIES(libs/libtommath)\r
+       ENDIF(TOMMATH_LIBRARY)\r
+       \r
+       IF(TOMCRYPT_LIBRARY)\r
+               TARGET_LINK_LIBRARIES(fms ${TOMCRYPT_LIBRARY})\r
+       ELSE(TOMCRYPT_LIBRARY)\r
+               #ADD_DEFINITIONS(-DLTC_NO_ASM)\r
+               #ADD_LIBRARY(tomcrypt ${LIBTOMCRYPT_SRC})\r
+               ADD_SUBDIRECTORY(libs/libtomcrypt)\r
+               TARGET_LINK_LIBRARIES(fms tomcrypt)\r
+               INCLUDE_DIRECTORIES(libs/libtomcrypt/headers)\r
+       ENDIF(TOMCRYPT_LIBRARY)\r
+       \r
+       ADD_DEFINITIONS(-DFROST_SUPPORT)\r
+       \r
+ENDIF(FROST_SUPPORT)\r
+\r
+# FreeBSD won't find Poco include files without this\r
+IF(CMAKE_SYSTEM_NAME STREQUAL "FreeBSD")\r
+       INCLUDE_DIRECTORIES(AFTER /usr/local/include)\r
+ENDIF(CMAKE_SYSTEM_NAME STREQUAL "FreeBSD")\r
+\r
+IF(QUERY_LOG)\r
+       ADD_DEFINITIONS(-DQUERY_LOG)\r
+ENDIF(QUERY_LOG)\r