[EVENTLOG]
[reactos.git] / msc.cmake
index deb1622..3ca388f 100644 (file)
--- a/msc.cmake
+++ b/msc.cmake
@@ -1,6 +1,6 @@
 \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
@@ -14,8 +14,15 @@ else()
 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
+\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
@@ -32,28 +39,56 @@ macro(set_subsystem MODULE SUBSYSTEM)
     set_target_properties(${MODULE} PROPERTIES LINK_FLAGS ${NEW_LINKER_FLAGS})\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
+endmacro()\r
+\r
 macro(add_importlibs MODULE)\r
-  FOREACH(LIB ${ARGN})\r
-    target_link_libraries(${MODULE} ${LIB}.LIB)\r
-  ENDFOREACH()\r
+    foreach(LIB ${ARGN})\r
+        target_link_libraries(${MODULE} ${LIB}.LIB)\r
+    endforeach()\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} windows)\r
-    set_entrypoint(${MODULE} mainCRTStartup)\r
-  endif ()\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
+    endif ()\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
+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(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
+    endforeach()\r
+    add_custom_target(${TARGET} ALL DEPENDS ${OBJECTS})\r
+endmacro()\r