[EVENTLOG]
[reactos.git] / msc.cmake
index 42754e4..3ca388f 100644 (file)
--- a/msc.cmake
+++ b/msc.cmake
@@ -14,11 +14,14 @@ 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
     if(${ENTRYPOINT} STREQUAL "0")\r
-    set(NEW_LINKER_FLAGS "/ENTRY:0")\r
+        set(NEW_LINKER_FLAGS "/ENTRY:0")\r
     else()\r
-    set(NEW_LINKER_FLAGS "/ENTRY:${ENTRYPOINT}")\r
+        set(NEW_LINKER_FLAGS "/ENTRY:${ENTRYPOINT}")\r
     endif()\r
     get_target_property(LINKER_FLAGS ${MODULE} LINK_FLAGS)\r
     if(LINKER_FLAGS)\r
@@ -36,6 +39,15 @@ 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
@@ -43,6 +55,7 @@ macro(add_importlibs MODULE)
 endmacro()\r
 \r
 macro(set_module_type MODULE TYPE)\r
+    add_dependencies(${MODULE} psdk buildno_header)\r
     if(${TYPE} MATCHES nativecui)\r
         set_subsystem(${MODULE} native)\r
         add_importlibs(${MODULE} ntdll)\r
@@ -78,4 +91,4 @@ macro(ADD_TYPELIB TARGET)
         list(APPEND OBJECTS ${OBJECT})\r
     endforeach()\r
     add_custom_target(${TARGET} ALL DEPENDS ${OBJECTS})\r
-endmacro()
\ No newline at end of file
+endmacro()\r