[CMAKE]
[reactos.git] / msc.cmake
index 3ca388f..6669204 100644 (file)
--- a/msc.cmake
+++ b/msc.cmake
@@ -14,6 +14,8 @@ else()
 add_definitions(/GS- /Zl /Zi)\r
 add_definitions(-Dinline=__inline -D__STDC__=1)\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
@@ -48,12 +50,6 @@ macro(set_image_base MODULE IMAGE_BASE)
     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
-endmacro()\r
-\r
 macro(set_module_type MODULE TYPE)\r
     add_dependencies(${MODULE} psdk buildno_header)\r
     if(${TYPE} MATCHES nativecui)\r
@@ -65,15 +61,24 @@ 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
+        set_entrypoint(${MODULE} __DllMainCRTStartup)\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
     add_definitions(-DUNICODE -D_UNICODE)\r
 endmacro()\r
 \r
-endif()\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
 \r
@@ -81,14 +86,35 @@ macro(set_rc_compiler)
 # 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(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
-        list(APPEND OBJECTS ${OBJECT})\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_target(\r
+        lib${_name}\r
+        COMMAND LINK /LIB /MACHINE:X86 /DEF:${CMAKE_CURRENT_BINARY_DIR}/${_file}.def /OUT:${CMAKE_BINARY_DIR}/importlibs/lib${_name}.lib\r
+        DEPENDS ${_def_file}\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
-    add_custom_target(${TARGET} ALL DEPENDS ${OBJECTS})\r
 endmacro()\r
+\r
+file(MAKE_DIRECTORY ${CMAKE_BINARY_DIR}/importlibs)\r
+\r
+#pseh workaround\r
+set(PSEH_LIB "")\r
+\r
+endif()\r
+\r