mirror of
https://github.com/reactos/reactos.git
synced 2024-07-31 00:28:56 +00:00
![Jérôme Gardou](/assets/img/avatar_default.png)
Instead of messing with global variables and the like, we introduce two target properties: - WITH_CXX_EXCEPTIONS: if you want to use C++ exceptions - WITH_CXX_RTTI: if you need RTTI in your module You can use the newly introduced set_target_cpp_properties function, with WITH_EXCEPTIONS and WITH_RTTI arguments We also introduce two libraries : - cpprt: for C++ runtime routines - cppstl: for the C++ standard template library NB: On GCC, this requires to create imported libraries with the related built-in libraries:libsupc++, limingwex, libstdc++ Finally, we manage the relevant flags with the ad-hoc generator expressions So, if you don't need exceptions, nor RTTI, nor use any runtime at all: you simply have nothing else to do than add your C++ file to your module
21 lines
538 B
CMake
21 lines
538 B
CMake
|
|
include_directories(BEFORE include)
|
|
add_compile_flags("-D__USE_W32_SOCKETS")
|
|
|
|
list(APPEND SOURCE
|
|
config.cpp
|
|
error.cpp
|
|
http.cpp
|
|
httpd.cpp
|
|
roshttpd.cpp
|
|
common/list.cpp
|
|
common/socket.cpp
|
|
common/thread.cpp)
|
|
|
|
add_executable(roshttpd ${SOURCE} common/roshttpd.rc)
|
|
target_link_libraries(roshttpd cppstl)
|
|
set_target_cpp_properties(roshttpd WITH_EXCEPTIONS)
|
|
set_module_type(roshttpd win32cui)
|
|
add_importlibs(roshttpd user32 ws2_32 msvcrt kernel32)
|
|
add_cd_file(TARGET roshttpd DESTINATION reactos/system32 FOR all)
|