\r
if(CMAKE_SYSTEM_PROCESSOR MATCHES "x86")\r
- add_definitions(-D__i386__)\r
+ add_definitions(-D__i386__)\r
endif()\r
\r
add_definitions(-Dinline=__inline)\r
if(NOT CMAKE_CROSSCOMPILING)\r
\r
\r
-\r
else()\r
\r
add_definitions(/GS- /Zl /Zi)\r
add_definitions(-Dinline=__inline -D__STDC__=1)\r
\r
+IF(${_MACHINE_ARCH_FLAG} MATCHES X86)\r
+ SET (CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} /SAFESEH:NO")\r
+ SET (CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} /SAFESEH:NO")\r
+ SET (CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} /SAFESEH:NO")\r
+ENDIF()\r
+\r
+link_directories("${REACTOS_BINARY_DIR}/importlibs" ${REACTOS_BINARY_DIR}/lib/3rdparty/mingw)\r
+\r
+set(CMAKE_RC_CREATE_SHARED_LIBRARY "<CMAKE_C_COMPILER> <CMAKE_SHARED_LIBRARY_C_FLAGS> <LINK_FLAGS> <CMAKE_SHARED_LIBRARY_CREATE_C_FLAGS> -o <TARGET> <OBJECTS> <LINK_LIBRARIES>")\r
+\r
+\r
macro(set_entrypoint MODULE ENTRYPOINT)\r
- set(NEW_LINKER_FLAGS "/ENTRY:${ENTRYPOINT}")\r
+ if(${ENTRYPOINT} STREQUAL "0")\r
+ set(NEW_LINKER_FLAGS "/ENTRY:0")\r
+ else()\r
+ set(NEW_LINKER_FLAGS "/ENTRY:${ENTRYPOINT}")\r
+ endif()\r
get_target_property(LINKER_FLAGS ${MODULE} LINK_FLAGS)\r
if(LINKER_FLAGS)\r
set(NEW_LINKER_FLAGS "${LINKER_FLAGS} ${NEW_LINKER_FLAGS}")\r
set_target_properties(${MODULE} PROPERTIES LINK_FLAGS ${NEW_LINKER_FLAGS})\r
endmacro()\r
\r
-macro(add_importlibs MODULE)\r
- FOREACH(LIB ${ARGN})\r
- target_link_libraries(${MODULE} ${LIB}.LIB)\r
- ENDFOREACH()\r
+macro(set_image_base MODULE IMAGE_BASE)\r
+ set(NEW_LINKER_FLAGS "/BASE:${IMAGE_BASE}")\r
+ get_target_property(LINKER_FLAGS ${MODULE} LINK_FLAGS)\r
+ if(LINKER_FLAGS)\r
+ set(NEW_LINKER_FLAGS "${LINKER_FLAGS} ${NEW_LINKER_FLAGS}")\r
+ endif()\r
+ set_target_properties(${MODULE} PROPERTIES LINK_FLAGS ${NEW_LINKER_FLAGS})\r
endmacro()\r
\r
macro(set_module_type MODULE TYPE)\r
- if(${TYPE} MATCHES nativecui)\r
- set_subsystem(${MODULE} native)\r
- add_importlibs(${MODULE} ntdll)\r
- endif()\r
- if (${TYPE} MATCHES win32gui)\r
- set_subsystem(${MODULE} windows)\r
- endif ()\r
- if (${TYPE} MATCHES win32cui)\r
- set_subsystem(${MODULE} console)\r
- endif ()\r
-endmacro()\r
+ add_dependencies(${MODULE} psdk buildno_header)\r
+ if(${TYPE} MATCHES nativecui)\r
+ set_subsystem(${MODULE} native)\r
+ add_importlibs(${MODULE} ntdll)\r
+ endif()\r
+ if (${TYPE} MATCHES win32gui)\r
+ set_subsystem(${MODULE} windows)\r
+ endif ()\r
+ if (${TYPE} MATCHES win32cui)\r
+ set_subsystem(${MODULE} console)\r
+ set_entrypoint(${MODULE} mainCRTStartup)\r
+ endif ()\r
+ if(${TYPE} MATCHES win32dll)\r
+ # Need this only because mingw library is broken\r
+ set_entrypoint(${MODULE} DllMainCRTStartup@12)\r
+ if(DEFINED baseaddress_${MODULE})\r
+ set_image_base(${MODULE} ${baseaddress_${MODULE}})\r
+ else()\r
+ message(STATUS "${MODULE} has no base address")\r
+ endif()\r
+ target_link_libraries(${MODULE} mingw_common mingw_dllmain)\r
+ endif()\r
\r
-macro(set_unicode MODULE STATE)\r
- if(${STATE} MATCHES yes)\r
- add_definitions(-DUNICODE -D_UNICODE)\r
- endif()\r
endmacro()\r
\r
-endif()\r
+macro(set_unicode)\r
+ add_definitions(-DUNICODE -D_UNICODE)\r
+endmacro()\r
\r
set(CMAKE_C_FLAGS_DEBUG_INIT "/D_DEBUG /MDd /Zi /Ob0 /Od")\r
-SET(CMAKE_CXX_FLAGS_DEBUG_INIT "/D_DEBUG /MDd /Zi /Ob0 /Od")\r
+set(CMAKE_CXX_FLAGS_DEBUG_INIT "/D_DEBUG /MDd /Zi /Ob0 /Od")\r
\r
macro(set_rc_compiler)\r
# dummy, this workaround is only needed in mingw due to lack of RC support in cmake\r
endmacro()\r
\r
-#typelib support\r
-macro(ADD_TYPELIB TARGET)\r
- FOREACH(SOURCE ${ARGN})\r
- GET_FILENAME_COMPONENT(FILE ${SOURCE} NAME_WE)\r
- SET(OBJECT ${CMAKE_CURRENT_BINARY_DIR}/${FILE}.tlb)\r
- ADD_CUSTOM_COMMAND(\r
- OUTPUT ${OBJECT}\r
- COMMAND midl /I ${REACTOS_SOURCE_DIR}/include/dxsdk /I . /I ${REACTOS_SOURCE_DIR}/include /I ${REACTOS_SOURCE_DIR}/include/psdk /win32 /tlb ${OBJECT} ${CMAKE_CURRENT_SOURCE_DIR}/${SOURCE}\r
+#idl files support\r
+set(IDL_COMPILER midl)\r
+set(IDL_FLAGS /win32)\r
+set(IDL_HEADER_ARG /h) #.h\r
+set(IDL_TYPELIB_ARG /tlb) #.tlb\r
+set(IDL_SERVER_ARG /sstub) #.c for stub server library\r
+set(IDL_CLIENT_ARG /cstub) #.c for stub client library\r
+\r
+\r
+macro(add_importlib_target _def_file)\r
+ get_filename_component(_name ${_def_file} NAME_WE)\r
+ add_custom_command(\r
+ OUTPUT {CMAKE_BINARY_DIR}/importlibs/lib${_name}.lib\r
+ COMMAND LINK /LIB /MACHINE:X86 /DEF:${_def_file} /OUT:${CMAKE_BINARY_DIR}/importlibs/lib${_name}.lib\r
+ DEPENDS ${_def_file}\r
)\r
- LIST(APPEND OBJECTS ${OBJECT})\r
- ENDFOREACH()\r
- ADD_CUSTOM_TARGET(${TARGET} ALL DEPENDS ${OBJECTS})\r
-ENDMACRO()
\ No newline at end of file
+ add_custom_target(\r
+ lib${_name}\r
+ DEPENDS {CMAKE_BINARY_DIR}/importlibs/lib${_name}.lib\r
+ )\r
+endmacro()\r
+\r
+macro(add_importlibs MODULE)\r
+ foreach(LIB ${ARGN})\r
+ target_link_libraries(${MODULE} ${CMAKE_BINARY_DIR}/importlibs/lib${LIB}.lib)\r
+ add_dependencies(${MODULE} lib${LIB})\r
+ endforeach()\r
+endmacro()\r
+\r
+file(MAKE_DIRECTORY ${CMAKE_BINARY_DIR}/importlibs)\r
+\r
+#pseh workaround\r
+set(PSEH_LIB "")\r
+\r
+endif()\r