[CMAKE]
[reactos.git] / msc.cmake
index fe0d7b6..a256263 100644 (file)
--- a/msc.cmake
+++ b/msc.cmake
@@ -8,21 +8,23 @@ 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
-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
+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
-macro(set_entrypoint MODULE 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
+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
+macro(add_linkerflag MODULE _flag)\r
+    set(NEW_LINKER_FLAGS ${_flag})\r
     get_target_property(LINKER_FLAGS ${MODULE} LINK_FLAGS)\r
     if(LINKER_FLAGS)\r
         set(NEW_LINKER_FLAGS "${LINKER_FLAGS} ${NEW_LINKER_FLAGS}")\r
@@ -30,22 +32,20 @@ macro(set_entrypoint MODULE ENTRYPOINT)
     set_target_properties(${MODULE} PROPERTIES LINK_FLAGS ${NEW_LINKER_FLAGS})\r
 endmacro()\r
 \r
-macro(set_subsystem MODULE SUBSYSTEM)\r
-    set(NEW_LINKER_FLAGS "/subsystem:${SUBSYSTEM}")\r
-    get_target_property(LINKER_FLAGS ${MODULE} LINK_FLAGS)\r
-    if(LINKER_FLAGS)\r
-        set(NEW_LINKER_FLAGS "${LINKER_FLAGS} ${NEW_LINKER_FLAGS}")\r
+macro(set_entrypoint MODULE ENTRYPOINT)\r
+    if(${ENTRYPOINT} STREQUAL "0")\r
+        add_linkerflag(${MODULE} "/ENTRY:0")\r
+    else()\r
+        add_linkerflag(${MODULE} "/ENTRY:${ENTRYPOINT}")\r
     endif()\r
-    set_target_properties(${MODULE} PROPERTIES LINK_FLAGS ${NEW_LINKER_FLAGS})\r
+endmacro()\r
+\r
+macro(set_subsystem MODULE SUBSYSTEM)\r
+    add_linkerflag(${MODULE} "/subsystem:${SUBSYSTEM}")\r
 endmacro()\r
 \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
+    add_linkerflag(${MODULE} "/BASE:${IMAGE_BASE}")\r
 endmacro()\r
 \r
 macro(set_module_type MODULE TYPE)\r
@@ -56,10 +56,33 @@ macro(set_module_type MODULE TYPE)
     endif()\r
     if (${TYPE} MATCHES win32gui)\r
         set_subsystem(${MODULE} windows)\r
+        set_entrypoint(${MODULE} WinMainCRTStartup)\r
+               target_link_libraries(${MODULE} mingw_common mingw_wmain)\r
     endif ()\r
     if (${TYPE} MATCHES win32cui)\r
         set_subsystem(${MODULE} console)\r
+        set_entrypoint(${MODULE} mainCRTStartup)\r
+               target_link_libraries(${MODULE} mingw_common mingw_wmain)\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
+        add_linkerflag(${MODULE} "/DLL")\r
+    endif()\r
+       if(${TYPE} MATCHES kernelmodedriver)\r
+           set_target_properties(${MODULE} PROPERTIES SUFFIX ".sys")\r
+           set_entrypoint(${MODULE} DriverEntry@8)\r
+               set_subsystem(${MODULE} native)\r
+        set_image_base(${MODULE} 0x00010000)\r
+               add_dependencies(${MODULE} bugcodes)\r
+       endif()\r
+\r
 endmacro()\r
 \r
 macro(set_unicode)\r
@@ -75,20 +98,51 @@ endmacro()
 \r
 #idl files support\r
 set(IDL_COMPILER midl)\r
-set(IDL_FLAGS /win32)\r
+set(IDL_FLAGS /win32 /Dstrict_context_handle=)\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
+# Thanks MS for creating a stupid linker\r
+macro(add_importlib_target _spec_file)\r
+    get_filename_component(_name ${_spec_file} NAME_WE)\r
+\r
+    # Generate the asm stub file\r
+    add_custom_command(\r
+        OUTPUT ${CMAKE_BINARY_DIR}/importlibs/lib${_name}_stubs.asm\r
+        COMMAND native-spec2def -s ${CMAKE_CURRENT_SOURCE_DIR}/${_spec_file} ${CMAKE_BINARY_DIR}/importlibs/lib${_name}_stubs.asm\r
+        DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${_spec_file})\r
+\r
+    # Generate a the export def file\r
+    add_custom_command(\r
+        OUTPUT ${CMAKE_BINARY_DIR}/importlibs/lib${_name}_exp.def\r
+        COMMAND native-spec2def -n -r ${CMAKE_CURRENT_SOURCE_DIR}/${_spec_file} ${CMAKE_BINARY_DIR}/importlibs/lib${_name}_exp.def\r
+        DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${_spec_file})\r
+\r
+    # Assemble the file\r
+    add_custom_command(\r
+        OUTPUT ${CMAKE_BINARY_DIR}/importlibs/lib${_name}_stubs.obj\r
+        COMMAND ${CMAKE_ASM_COMPILER} /NOLOGO /Fo${CMAKE_BINARY_DIR}/importlibs/lib${_name}_stubs.obj /c /Ta ${CMAKE_BINARY_DIR}/importlibs/lib${_name}_stubs.asm\r
+        DEPENDS "${CMAKE_BINARY_DIR}/importlibs/lib${_name}_stubs.asm"\r
+    )\r
+\r
+    # Add neccessary importlibs for redirections\r
+    set(_libraries "")\r
+    foreach(_lib ${ARGN})\r
+        list(APPEND _libraries "${CMAKE_BINARY_DIR}/importlibs/${_lib}.lib")\r
+    endforeach()\r
 \r
-macro(add_importlib_target _name)\r
+    # Build the importlib\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
+        COMMAND LINK /LIB /NOLOGO /MACHINE:X86 /DEF:${CMAKE_BINARY_DIR}/importlibs/lib${_name}_exp.def /OUT:${CMAKE_BINARY_DIR}/importlibs/lib${_name}.lib ${CMAKE_BINARY_DIR}/importlibs/lib${_name}_stubs.obj ${_libraries}\r
+        DEPENDS ${CMAKE_BINARY_DIR}/importlibs/lib${_name}_stubs.obj ${CMAKE_BINARY_DIR}/importlibs/lib${_name}_exp.def ${_libraries}\r
     )\r
-    add_custom_target(lib${_name}\r
+\r
+    # Add the importlib target\r
+    add_custom_target(\r
+        lib${_name}\r
         DEPENDS ${CMAKE_BINARY_DIR}/importlibs/lib${_name}.lib\r
     )\r
 endmacro()\r
@@ -96,10 +150,34 @@ endmacro()
 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
+macro(spec2def _dllname _spec_file)\r
+    get_filename_component(_file ${_spec_file} NAME_WE)\r
+    add_custom_command(\r
+        OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${_file}.def\r
+        COMMAND native-spec2def -n --dll ${_dllname} ${CMAKE_CURRENT_SOURCE_DIR}/${_spec_file} ${CMAKE_CURRENT_BINARY_DIR}/${_file}.def\r
+        DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${_spec_file})\r
+    set_source_files_properties(${CMAKE_CURRENT_BINARY_DIR}/${_file}.def\r
+        PROPERTIES GENERATED TRUE)\r
+endmacro()\r
+\r
+# Optional 3rd parameter: dllname\r
+macro(set_export_spec _module _spec_file)\r
+    get_filename_component(_file ${_spec_file} NAME_WE)\r
+    if (${ARGC} GREATER 2)\r
+        set(_dllname ${ARGV2})\r
+    else()\r
+        set(_dllname ${_file}.dll)\r
+    endif()\r
+    spec2def(${_dllname} ${_spec_file})\r
+endmacro()\r
+\r
 file(MAKE_DIRECTORY ${CMAKE_BINARY_DIR}/importlibs)\r
 \r
-endif()\r
+#pseh workaround\r
+set(PSEH_LIB "")\r
 \r
+endif()\r