[PSDK]
[reactos.git] / msc.cmake
index e365319..413da1c 100644 (file)
--- a/msc.cmake
+++ b/msc.cmake
@@ -23,6 +23,18 @@ link_directories("${REACTOS_BINARY_DIR}/importlibs" ${REACTOS_BINARY_DIR}/lib/3r
 \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_pch _target_name _header_filename _src_list)\r
+    get_filename_component(FILE ${_header_filename} NAME)\r
+    set(_gch_filename "${_target_name}_${FILE}.gch")\r
+    list(APPEND ${_src_list} ${_gch_filename})\r
+    _PCH_GET_COMPILE_FLAGS(${_target_name} _args ${_header_filename})\r
+    file(REMOVE ${_gch_filename})\r
+    add_custom_command(\r
+        OUTPUT ${_gch_filename}\r
+        COMMAND ${CMAKE_C_COMPILER} ${CMAKE_C_COMPILER_ARG1} ${_args}\r
+        DEPENDS ${_header_filename})\r
+ENDMACRO(add_pch _target_name _header_filename _src_list)\r
+\r
 macro(add_linkerflag MODULE _flag)\r
     set(NEW_LINKER_FLAGS ${_flag})\r
     get_target_property(LINKER_FLAGS ${MODULE} LINK_FLAGS)\r
@@ -34,7 +46,7 @@ endmacro()
 \r
 macro(set_entrypoint MODULE ENTRYPOINT)\r
     if(${ENTRYPOINT} STREQUAL "0")\r
-        add_linkerflag(${MODULE} "/ENTRY:0")\r
+        add_linkerflag(${MODULE} "/NOENTRY")\r
     else()\r
         add_linkerflag(${MODULE} "/ENTRY:${ENTRYPOINT}")\r
     endif()\r
@@ -52,17 +64,27 @@ macro(set_module_type MODULE TYPE)
     add_dependencies(${MODULE} psdk buildno_header)\r
     if(${TYPE} MATCHES nativecui)\r
         set_subsystem(${MODULE} native)\r
-        add_importlibs(${MODULE} ntdll)\r
+        set_entrypoint(${MODULE} NtProcessStartup@4)\r
     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
+        if(IS_UNICODE)\r
+            target_link_libraries(${MODULE} mingw_wmain)\r
+        else()\r
+            target_link_libraries(${MODULE} mingw_main)\r
+        endif()\r
+               target_link_libraries(${MODULE} mingw_common)\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
+        if(IS_UNICODE)\r
+            target_link_libraries(${MODULE} mingw_wmain)\r
+        else()\r
+            target_link_libraries(${MODULE} mingw_main)\r
+        endif()\r
+               target_link_libraries(${MODULE} mingw_common)\r
     endif ()\r
     if(${TYPE} MATCHES win32dll)\r
         # Need this only because mingw library is broken\r
@@ -73,14 +95,29 @@ macro(set_module_type MODULE TYPE)
                        message(STATUS "${MODULE} has no base address")\r
                endif()\r
                target_link_libraries(${MODULE} mingw_common mingw_dllmain)\r
-               add_importlibs(${MODULE} msvcrt kernel32)\r
         add_linkerflag(${MODULE} "/DLL")\r
     endif()\r
+    if(${TYPE} MATCHES win32ocx)\r
+        set_entrypoint(${MODULE} DllMain@12)\r
+        set_target_properties(${MODULE} PROPERTIES SUFFIX ".ocx")\r
+    endif()\r
+    if(${TYPE} MATCHES cpl)\r
+        set_entrypoint(${MODULE} DllMain@12)\r
+        set_target_properties(${MODULE} PROPERTIES SUFFIX ".cpl")\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
-    add_definitions(-DUNICODE -D_UNICODE)\r
+   add_definitions(-DUNICODE -D_UNICODE)\r
+   set(IS_UNICODE 1)\r
 endmacro()\r
 \r
 set(CMAKE_C_FLAGS_DEBUG_INIT "/D_DEBUG /MDd /Zi  /Ob0 /Od")\r
@@ -148,18 +185,15 @@ macro(add_importlibs MODULE)
     endforeach()\r
 endmacro()\r
 \r
-MACRO(spec2def _dllname _spec_file)\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
+        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
-    add_custom_target(\r
-        ${_dllname}.def\r
-        DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/${_file}.def)\r
-ENDMACRO(spec2def _dllname _spec_file)\r
+endmacro()\r
 \r
 # Optional 3rd parameter: dllname\r
 macro(set_export_spec _module _spec_file)\r
@@ -170,8 +204,6 @@ macro(set_export_spec _module _spec_file)
         set(_dllname ${_file}.dll)\r
     endif()\r
     spec2def(${_dllname} ${_spec_file})\r
-    add_linkerflag(${_module} "/DEF:${CMAKE_CURRENT_BINARY_DIR}/${_file}.def")\r
-    add_dependencies(${_module} ${_dllname}.def)\r
 endmacro()\r
 \r
 file(MAKE_DIRECTORY ${CMAKE_BINARY_DIR}/importlibs)\r