[CMAKE]
[reactos.git] / msc.cmake
index 91ba045..c555033 100644 (file)
--- a/msc.cmake
+++ b/msc.cmake
@@ -8,12 +8,19 @@ add_definitions(-Dinline=__inline)
 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
@@ -59,7 +66,19 @@ macro(set_module_type MODULE TYPE)
     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
 endmacro()\r
 \r
 macro(set_unicode)\r
@@ -82,14 +101,16 @@ set(IDL_SERVER_ARG /sstub) #.c for stub server library
 set(IDL_CLIENT_ARG /cstub) #.c for stub client library\r
 \r
 \r
-macro(add_importlib_target _name)\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:${CMAKE_CURRENT_BINARY_DIR}/${_name}.def /OUT:${CMAKE_BINARY_DIR}/importlibs/lib${_name}.lib\r
-        DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${_name}.def\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
-    add_custom_target(lib${_name}\r
-        DEPENDS ${CMAKE_BINARY_DIR}/importlibs/lib${_name}.lib\r
+    add_custom_target(\r
+        lib${_name}\r
+        DEPENDS {CMAKE_BINARY_DIR}/importlibs/lib${_name}.lib\r
     )\r
 endmacro()\r
 \r
@@ -102,5 +123,7 @@ endmacro()
 \r
 file(MAKE_DIRECTORY ${CMAKE_BINARY_DIR}/importlibs)\r
 \r
-endif()\r
+#pseh workaround\r
+set(PSEH_LIB "")\r
 \r
+endif()\r