Sync with trunk revision r58045 to bring the corrections on configure.cmd and on...
[reactos.git] / cmake / CMakeMacros.cmake
index ef64eeb..34aeebd 100644 (file)
-\r
-macro(set_cpp)\r
-    include_directories(BEFORE ${REACTOS_SOURCE_DIR}/include/c++/stlport)\r
-    set(IS_CPP 1)\r
-    add_definitions(\r
-        -DNATIVE_CPP_INCLUDE=${REACTOS_SOURCE_DIR}/include/c++\r
-        -DNATIVE_C_INCLUDE=${REACTOS_SOURCE_DIR}/include/crt)\r
-endmacro()\r
-\r
-macro(add_dependency_node _node)\r
-    if(GENERATE_DEPENDENCY_GRAPH)\r
-        get_target_property(_type ${_node} TYPE)\r
-        if(_type MATCHES SHARED_LIBRARY OR ${_node} MATCHES ntoskrnl)\r
-            file(APPEND ${REACTOS_BINARY_DIR}/dependencies.graphml "    <node id=\"${_node}\"/>\n")\r
-        endif()\r
-     endif()\r
-endmacro()\r
-\r
-macro(add_dependency_edge _source _target)\r
-    if(GENERATE_DEPENDENCY_GRAPH)\r
-        get_target_property(_type ${_source} TYPE)\r
-        if(_type MATCHES SHARED_LIBRARY)\r
-            file(APPEND ${REACTOS_BINARY_DIR}/dependencies.graphml "    <edge source=\"${_source}\" target=\"${_target}\"/>\n")\r
-        endif()\r
-    endif()\r
-endmacro()\r
-\r
-macro(add_dependency_header)\r
-    file(APPEND ${REACTOS_BINARY_DIR}/dependencies.graphml "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<graphml>\n  <graph id=\"ReactOS dependencies\" edgedefault=\"directed\">\n")\r
-endmacro()\r
-\r
-macro(add_dependency_footer)\r
-    add_dependency_node(ntdll)\r
-    file(APPEND ${REACTOS_BINARY_DIR}/dependencies.graphml "  </graph>\n</graphml>\n")\r
-endmacro()\r
-\r
-macro(add_message_headers)\r
-    foreach(_in_FILE ${ARGN})\r
-        get_filename_component(FILE ${_in_FILE} NAME_WE)\r
-        macro_mc(${FILE})\r
-        add_custom_command(\r
-            OUTPUT ${REACTOS_BINARY_DIR}/include/reactos/${FILE}.rc ${REACTOS_BINARY_DIR}/include/reactos/${FILE}.h\r
-            COMMAND ${COMMAND_MC}\r
-            DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${FILE}.mc)\r
-        set_source_files_properties(\r
-            ${REACTOS_BINARY_DIR}/include/reactos/${FILE}.h ${REACTOS_BINARY_DIR}/include/reactos/${FILE}.rc\r
-            PROPERTIES GENERATED TRUE)\r
-        add_custom_target(${FILE} ALL DEPENDS ${REACTOS_BINARY_DIR}/include/reactos/${FILE}.h ${REACTOS_BINARY_DIR}/include/reactos/${FILE}.rc)\r
-    endforeach()\r
-endmacro()\r
-\r
-macro(dir_to_num dir var)\r
-    if(${dir} STREQUAL reactos/system32)\r
-        set(${var} 1)\r
-    elseif(${dir} STREQUAL reactos/system32/drivers)\r
-        set(${var} 2)\r
-    elseif(${dir} STREQUAL reactos/Fonts)\r
-        set(${var} 3)\r
-    elseif(${dir} STREQUAL reactos)\r
-        set(${var} 4)\r
-    elseif(${dir} STREQUAL reactos/system32/drivers/etc)\r
-        set(${var} 5)\r
-    elseif(${dir} STREQUAL reactos/inf)\r
-        set(${var} 6)\r
-    elseif(${dir} STREQUAL reactos/bin)\r
-        set(${var} 7)\r
-    elseif(${dir} STREQUAL reactos/media)\r
-        set(${var} 8)\r
-    else()\r
-        message(ERROR "Wrong destination: ${dir}")\r
-    endif()\r
-endmacro()\r
-\r
-function(add_cd_file)\r
-    cmake_parse_arguments(_CD "NO_CAB" "DESTINATION;NAME_ON_CD;TARGET" "FILE;FOR" ${ARGN})\r
-    if(NOT (_CD_TARGET OR _CD_FILE))\r
-        message(FATAL_ERROR "You must provide a target or a file to install!")\r
-    endif()\r
-\r
-    if(NOT _CD_DESTINATION)\r
-        message(FATAL_ERROR "You must provide a destination")\r
-    elseif(${_CD_DESTINATION} STREQUAL root)\r
-        set(_CD_DESTINATION "")\r
-    endif()\r
-\r
-    if(NOT _CD_FOR)\r
-        message(FATAL_ERROR "You must provide a cd name (or "all" for all of them) to install the file on!")\r
-    endif()\r
-\r
-    #get file if we need to\r
-    if(NOT _CD_FILE)\r
-        get_target_property(_CD_FILE ${_CD_TARGET} LOCATION)\r
-    endif()\r
-\r
-    #do we add it to all CDs?\r
-    if(_CD_FOR STREQUAL all)\r
-        set(_CD_FOR "bootcd;livecd;regtest")\r
-    endif()\r
-\r
-    #do we add it to bootcd?\r
-    list(FIND _CD_FOR bootcd __cd)\r
-    if(NOT __cd EQUAL -1)\r
-        #whether or not we should put it in reactos.cab or directly on cd\r
-        if(_CD_NO_CAB)\r
-            #directly on cd\r
-            foreach(item ${_CD_FILE})\r
-                file(APPEND ${REACTOS_BINARY_DIR}/boot/bootcd.cmake "file(COPY \"${item}\" DESTINATION \"\${CD_DIR}/${_CD_DESTINATION}\")\n")\r
-            endforeach()\r
-            if(_CD_NAME_ON_CD)\r
-                get_filename_component(__file ${_CD_FILE} NAME)\r
-                #rename it in the cd tree\r
-                file(APPEND ${REACTOS_BINARY_DIR}/boot/bootcd.cmake "file(RENAME \${CD_DIR}/${_CD_DESTINATION}/${__file} \${CD_DIR}/${_CD_DESTINATION}/${_CD_NAME_ON_CD})\n")\r
-            endif()\r
-            if(_CD_TARGET)\r
-                #manage dependency\r
-                add_dependencies(bootcd ${_CD_TARGET})\r
-            endif()\r
-        else()\r
-            #add it in reactos.cab\r
-            dir_to_num(${_CD_DESTINATION} _num)\r
-            if(CMAKE_HOST_SYSTEM_NAME MATCHES Windows)\r
-                file(APPEND ${REACTOS_BINARY_DIR}/boot/bootdata/packages/reactos.dff.dyn "${_CD_FILE} ${_num}\n")\r
-            else()\r
-                file(APPEND ${REACTOS_BINARY_DIR}/boot/bootdata/packages/reactos.dff.dyn "\"${_CD_FILE}\" ${_num}\n")\r
-            endif()\r
-            if(_CD_TARGET)\r
-                #manage dependency\r
-                add_dependencies(reactos_cab ${_CD_TARGET})\r
-            endif()\r
-        endif()\r
-    endif() #end bootcd\r
-\r
-    #do we add it to livecd?\r
-    list(FIND _CD_FOR livecd __cd)\r
-    if(NOT __cd EQUAL -1)\r
-        #manage dependency\r
-        if(_CD_TARGET)\r
-            add_dependencies(livecd ${_CD_TARGET})\r
-        endif()\r
-        foreach(item ${_CD_FILE})\r
-            file(APPEND ${REACTOS_BINARY_DIR}/boot/livecd.cmake "file(COPY \"${item}\" DESTINATION \"\${CD_DIR}/${_CD_DESTINATION}\")\n")\r
-        endforeach()\r
-        if(_CD_NAME_ON_CD)\r
-            get_filename_component(__file ${_CD_FILE} NAME)\r
-            #rename it in the cd tree\r
-            file(APPEND ${REACTOS_BINARY_DIR}/boot/livecd.cmake "file(RENAME \${CD_DIR}/${_CD_DESTINATION}/${__file} \${CD_DIR}/${_CD_DESTINATION}/${_CD_NAME_ON_CD})\n")\r
-        endif()\r
-    endif() #end livecd\r
-\r
-    #do we add it to regtest?\r
-    list(FIND _CD_FOR regtest __cd)\r
-    if(NOT __cd EQUAL -1)\r
-        #whether or not we should put it in reactos.cab or directly on cd\r
-        if(_CD_NO_CAB)\r
-            #directly on cd\r
-            foreach(item ${_CD_FILE})\r
-                file(APPEND ${REACTOS_BINARY_DIR}/boot/bootcdregtest.cmake "file(COPY \"${item}\" DESTINATION \"\${CD_DIR}/${_CD_DESTINATION}\")\n")\r
-            endforeach()\r
-            if(_CD_NAME_ON_CD)\r
-                get_filename_component(__file ${_CD_FILE} NAME)\r
-                #rename it in the cd tree\r
-                file(APPEND ${REACTOS_BINARY_DIR}/boot/bootcdregtest.cmake "file(RENAME \${CD_DIR}/${_CD_DESTINATION}/${__file} \${CD_DIR}/${_CD_DESTINATION}/${_CD_NAME_ON_CD})\n")\r
-            endif()\r
-            if(_CD_TARGET)\r
-                #manage dependency\r
-                add_dependencies(bootcdregtest ${_CD_TARGET})\r
-            endif()\r
-        else()\r
-            #add it in reactos.cab\r
-            #dir_to_num(${_CD_DESTINATION} _num)\r
-            #file(APPEND ${REACTOS_BINARY_DIR}/boot/bootdata/packages/reactos.dff.dyn "${_CD_FILE} ${_num}\n")\r
-            #if(_CD_TARGET)\r
-            #    #manage dependency\r
-            #    add_dependencies(reactos_cab ${_CD_TARGET})\r
-            #endif()\r
-        endif()\r
-    endif() #end bootcd\r
-endfunction()\r
-\r
-# Create module_clean targets\r
-function(add_clean_target target)\r
-    if(CMAKE_GENERATOR MATCHES "Unix Makefiles" OR CMAKE_GENERATOR MATCHES "MinGW Makefiles")\r
-        set(CLEAN_COMMAND make clean)\r
-    elseif(CMAKE_GENERATOR MATCHES "NMake Makefiles")\r
-        set(CLEAN_COMMAND nmake clean)\r
-    endif()\r
-    add_custom_target(${target}_clean\r
-        COMMAND ${CLEAN_COMMAND}\r
-        WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}\r
-        COMMENT "Cleaning ${target}")\r
-endfunction()\r
-\r
-if(NOT MSVC_IDE)\r
-    function(add_library name)\r
-        _add_library(${name} ${ARGN})\r
-        add_clean_target(${name})\r
-    endfunction()\r
-\r
-    function(add_executable name)\r
-        _add_executable(${name} ${ARGN})\r
-        add_clean_target(${name})\r
-    endfunction()\r
-endif()\r
-\r
-if(CMAKE_HOST_SYSTEM_NAME MATCHES Windows)\r
-    macro(to_win_path _cmake_path _native_path)\r
-        string(REPLACE "/" "\\" ${_native_path} "${_cmake_path}")\r
-    endmacro()\r
-\r
-    macro(concatenate_files _file1 _file2 _output)\r
-        to_win_path("${_file1}" _real_file1)\r
-        to_win_path("${_file2}" _real_file2)\r
-        to_win_path("${_output}" _real_output)\r
-        add_custom_command(\r
-            OUTPUT ${_output}\r
-            COMMAND cmd.exe /C "copy /Y /B ${_real_file1} + ${_real_file2} ${_real_output} > nul"\r
-            DEPENDS ${_file1}\r
-            DEPENDS ${_file2})\r
-    endmacro()\r
-else()\r
-    macro(concatenate_files _file1 _file2 _output)\r
-        add_custom_command(\r
-            OUTPUT ${_output}\r
-            COMMAND cat ${_file1} ${_file2} > ${_output}\r
-            DEPENDS ${_file1}\r
-            DEPENDS ${_file2})\r
-    endmacro()\r
-endif()\r
-\r
-macro(add_importlibs MODULE)\r
-    add_dependency_node(${MODULE})\r
-    foreach(LIB ${ARGN})\r
-        if ("${LIB}" MATCHES "msvcrt")\r
-            add_definitions(-D_DLL -D__USE_CRTIMP)\r
-            target_link_libraries(${MODULE} msvcrtex)\r
-        endif()\r
-        target_link_libraries(${MODULE} ${CMAKE_BINARY_DIR}/importlibs/lib${LIB}${CMAKE_STATIC_LIBRARY_SUFFIX})\r
-        add_dependencies(${MODULE} lib${LIB})\r
-        add_dependency_edge(${MODULE} ${LIB})\r
-    endforeach()\r
-endmacro()\r
+
+macro(set_cpp)
+    set(IS_CPP 1)
+    if(MSVC)
+        include_directories(${REACTOS_SOURCE_DIR}/include/c++)
+    endif()
+endmacro()
+
+function(add_dependency_node _node)
+    if(GENERATE_DEPENDENCY_GRAPH)
+        get_target_property(_type ${_node} TYPE)
+        if(_type MATCHES SHARED_LIBRARY OR ${_node} MATCHES ntoskrnl)
+            file(APPEND ${REACTOS_BINARY_DIR}/dependencies.graphml "    <node id=\"${_node}\"/>\n")
+        endif()
+     endif()
+endfunction()
+
+function(add_dependency_edge _source _target)
+    if(GENERATE_DEPENDENCY_GRAPH)
+        get_target_property(_type ${_source} TYPE)
+        if(_type MATCHES SHARED_LIBRARY)
+            file(APPEND ${REACTOS_BINARY_DIR}/dependencies.graphml "    <edge source=\"${_source}\" target=\"${_target}\"/>\n")
+        endif()
+    endif()
+endfunction()
+
+function(add_dependency_header)
+    file(APPEND ${REACTOS_BINARY_DIR}/dependencies.graphml "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<graphml>\n  <graph id=\"ReactOS dependencies\" edgedefault=\"directed\">\n")
+endfunction()
+
+function(add_dependency_footer)
+    add_dependency_node(ntdll)
+    file(APPEND ${REACTOS_BINARY_DIR}/dependencies.graphml "  </graph>\n</graphml>\n")
+endfunction()
+
+function(add_message_headers _type)
+    if(${_type} STREQUAL UNICODE)
+        set(_flag "-U")
+    else()
+        set(_flag "-A")
+    endif()
+    foreach(_in_FILE ${ARGN})
+        get_filename_component(FILE ${_in_FILE} NAME_WE)
+        macro_mc(${_flag} ${FILE})
+        add_custom_command(
+            OUTPUT ${REACTOS_BINARY_DIR}/include/reactos/${FILE}.rc ${REACTOS_BINARY_DIR}/include/reactos/${FILE}.h
+            COMMAND ${COMMAND_MC} ${MC_FLAGS}
+            DEPENDS ${CMAKE_CURRENT_SOURCE_DIR}/${FILE}.mc)
+        set_source_files_properties(
+            ${REACTOS_BINARY_DIR}/include/reactos/${FILE}.h ${REACTOS_BINARY_DIR}/include/reactos/${FILE}.rc
+            PROPERTIES GENERATED TRUE)
+        add_custom_target(${FILE} ALL DEPENDS ${REACTOS_BINARY_DIR}/include/reactos/${FILE}.h ${REACTOS_BINARY_DIR}/include/reactos/${FILE}.rc)
+    endforeach()
+endfunction()
+
+function(add_link)
+       cmake_parse_arguments(_LINK "MINIMIZE" "NAME;PATH;CMD_LINE_ARGS;ICON;GUID" "" ${ARGN})
+    if(NOT _LINK_NAME OR NOT _LINK_PATH)
+        message(FATAL_ERROR "You must provide name and path")
+    endif()
+
+       if(_LINK_CMD_LINE_ARGS)
+               set(_LINK_CMD_LINE_ARGS -c ${_LINK_CMD_LINE_ARGS})
+       endif()
+
+       if(_LINK_ICON)
+               set(_LINK_ICON -i ${_LINK_ICON})
+       endif()
+
+       if(_LINK_GUID)
+               set(_LINK_GUID -g ${_LINK_GUID})
+       endif()
+
+       if(_LINK_MINIMIZE)
+               set(_LINK_MINIMIZE "-m")
+       endif()
+
+    add_custom_command(
+        OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${_LINK_NAME}.lnk
+        COMMAND native-mkshelllink -o ${CMAKE_CURRENT_BINARY_DIR}/${_LINK_NAME}.lnk ${_LINK_CMD_LINE_ARGS} ${_LINK_ICON} ${_LINK_GUID} ${_LINK_MINIMIZE} ${_LINK_PATH}
+        DEPENDS native-mkshelllink)
+    set_source_files_properties(${CMAKE_CURRENT_BINARY_DIR}/${_LINK_NAME}.lnk PROPERTIES GENERATED TRUE)
+endfunction()
+
+macro(dir_to_num dir var)
+    if(${dir} STREQUAL reactos/system32)
+        set(${var} 1)
+    elseif(${dir} STREQUAL reactos/system32/drivers)
+        set(${var} 2)
+    elseif(${dir} STREQUAL reactos/Fonts)
+        set(${var} 3)
+    elseif(${dir} STREQUAL reactos)
+        set(${var} 4)
+    elseif(${dir} STREQUAL reactos/system32/drivers/etc)
+        set(${var} 5)
+    elseif(${dir} STREQUAL reactos/inf)
+        set(${var} 6)
+    elseif(${dir} STREQUAL reactos/bin)
+        set(${var} 7)
+    elseif(${dir} STREQUAL reactos/bin/data)
+        set(${var} 8)
+    elseif(${dir} STREQUAL reactos/media)
+        set(${var} 9)
+    elseif(${dir} STREQUAL reactos/Microsoft.NET)
+        set(${var} 10)
+    elseif(${dir} STREQUAL reactos/Microsoft.NET/Framework)
+        set(${var} 11)
+    elseif(${dir} STREQUAL reactos/Microsoft.NET/Framework/v1.0.3705)
+        set(${var} 12)
+    elseif(${dir} STREQUAL reactos/Microsoft.NET/Framework/v1.1.4322)
+        set(${var} 13)
+    elseif(${dir} STREQUAL reactos/Microsoft.NET/Framework/v2.0.50727)
+        set(${var} 14)
+    else()
+        message(ERROR "Wrong destination: ${dir}")
+    endif()
+endmacro()
+
+function(add_cd_file)
+    cmake_parse_arguments(_CD "NO_CAB" "DESTINATION;NAME_ON_CD;TARGET" "FILE;FOR" ${ARGN})
+    if(NOT (_CD_TARGET OR _CD_FILE))
+        message(FATAL_ERROR "You must provide a target or a file to install!")
+    endif()
+
+    if(NOT _CD_DESTINATION)
+        message(FATAL_ERROR "You must provide a destination")
+    elseif(${_CD_DESTINATION} STREQUAL root)
+        set(_CD_DESTINATION "")
+    endif()
+
+    if(NOT _CD_FOR)
+        message(FATAL_ERROR "You must provide a cd name (or "all" for all of them) to install the file on!")
+    endif()
+
+    #get file if we need to
+    if(NOT _CD_FILE)
+        get_target_property(_CD_FILE ${_CD_TARGET} LOCATION)
+    endif()
+
+    #do we add it to all CDs?
+    if(_CD_FOR STREQUAL all)
+        set(_CD_FOR "bootcd;livecd;regtest")
+    endif()
+
+    #do we add it to bootcd?
+    list(FIND _CD_FOR bootcd __cd)
+    if(NOT __cd EQUAL -1)
+        #whether or not we should put it in reactos.cab or directly on cd
+        if(_CD_NO_CAB)
+            #directly on cd
+            foreach(item ${_CD_FILE})
+                file(APPEND ${REACTOS_BINARY_DIR}/boot/bootcd.cmake "file(COPY \"${item}\" DESTINATION \"\${CD_DIR}/${_CD_DESTINATION}\")\n")
+            endforeach()
+            if(_CD_NAME_ON_CD)
+                get_filename_component(__file ${_CD_FILE} NAME)
+                #rename it in the cd tree
+                file(APPEND ${REACTOS_BINARY_DIR}/boot/bootcd.cmake "file(RENAME \${CD_DIR}/${_CD_DESTINATION}/${__file} \${CD_DIR}/${_CD_DESTINATION}/${_CD_NAME_ON_CD})\n")
+            endif()
+            if(_CD_TARGET)
+                #manage dependency
+                add_dependencies(bootcd ${_CD_TARGET})
+            endif()
+        else()
+            #add it in reactos.cab
+            dir_to_num(${_CD_DESTINATION} _num)
+            file(RELATIVE_PATH __relative_file ${REACTOS_SOURCE_DIR} ${_CD_FILE})
+            file(APPEND ${REACTOS_BINARY_DIR}/boot/bootdata/packages/reactos.dff.dyn "\"${__relative_file}\" ${_num}\n")
+            unset(__relative_file)
+            if(_CD_TARGET)
+                #manage dependency
+                add_dependencies(reactos_cab ${_CD_TARGET})
+            endif()
+        endif()
+    endif() #end bootcd
+
+    #do we add it to livecd?
+    list(FIND _CD_FOR livecd __cd)
+    if(NOT __cd EQUAL -1)
+        #manage dependency
+        if(_CD_TARGET)
+            add_dependencies(livecd ${_CD_TARGET})
+        endif()
+        foreach(item ${_CD_FILE})
+            file(APPEND ${REACTOS_BINARY_DIR}/boot/livecd.cmake "file(COPY \"${item}\" DESTINATION \"\${CD_DIR}/${_CD_DESTINATION}\")\n")
+        endforeach()
+        if(_CD_NAME_ON_CD)
+            get_filename_component(__file ${_CD_FILE} NAME)
+            #rename it in the cd tree
+            file(APPEND ${REACTOS_BINARY_DIR}/boot/livecd.cmake "file(RENAME \${CD_DIR}/${_CD_DESTINATION}/${__file} \${CD_DIR}/${_CD_DESTINATION}/${_CD_NAME_ON_CD})\n")
+        endif()
+    endif() #end livecd
+
+    #do we add it to regtest?
+    list(FIND _CD_FOR regtest __cd)
+    if(NOT __cd EQUAL -1)
+        #whether or not we should put it in reactos.cab or directly on cd
+        if(_CD_NO_CAB)
+            #directly on cd
+            foreach(item ${_CD_FILE})
+                file(APPEND ${REACTOS_BINARY_DIR}/boot/bootcdregtest.cmake "file(COPY \"${item}\" DESTINATION \"\${CD_DIR}/${_CD_DESTINATION}\")\n")
+            endforeach()
+            if(_CD_NAME_ON_CD)
+                get_filename_component(__file ${_CD_FILE} NAME)
+                #rename it in the cd tree
+                file(APPEND ${REACTOS_BINARY_DIR}/boot/bootcdregtest.cmake "file(RENAME \${CD_DIR}/${_CD_DESTINATION}/${__file} \${CD_DIR}/${_CD_DESTINATION}/${_CD_NAME_ON_CD})\n")
+            endif()
+            if(_CD_TARGET)
+                #manage dependency
+                add_dependencies(bootcdregtest ${_CD_TARGET})
+            endif()
+        else()
+            #add it in reactos.cab
+            #dir_to_num(${_CD_DESTINATION} _num)
+            #file(APPEND ${REACTOS_BINARY_DIR}/boot/bootdata/packages/reactos.dff.dyn "${_CD_FILE} ${_num}\n")
+            #if(_CD_TARGET)
+            #    #manage dependency
+            #    add_dependencies(reactos_cab ${_CD_TARGET})
+            #endif()
+        endif()
+    endif() #end bootcd
+endfunction()
+
+# Create module_clean targets
+function(add_clean_target _target)
+    set(_clean_working_directory ${CMAKE_CURRENT_BINARY_DIR})
+    if(CMAKE_GENERATOR STREQUAL "Unix Makefiles" OR CMAKE_GENERATOR STREQUAL "MinGW Makefiles")
+        set(_clean_command make clean)
+    elseif(CMAKE_GENERATOR STREQUAL "NMake Makefiles")
+        set(_clean_command nmake /nologo clean)
+    elseif(CMAKE_GENERATOR STREQUAL "Ninja")
+        set(_clean_command ninja -t clean ${_target})
+        set(_clean_working_directory ${REACTOS_BINARY_DIR})
+    endif()
+    add_custom_target(${_target}_clean
+        COMMAND ${_clean_command}
+        WORKING_DIRECTORY ${_clean_working_directory}
+        COMMENT "Cleaning ${_target}")
+endfunction()
+
+if(NOT MSVC_IDE)
+    function(add_library name)
+        _add_library(${name} ${ARGN})
+        add_clean_target(${name})
+    endfunction()
+
+    function(add_executable name)
+        _add_executable(${name} ${ARGN})
+        add_clean_target(${name})
+    endfunction()
+endif()
+
+if(CMAKE_HOST_SYSTEM_NAME STREQUAL "Windows")
+    macro(to_win_path _cmake_path _native_path)
+        string(REPLACE "/" "\\" ${_native_path} "${_cmake_path}")
+    endmacro()
+
+    # yeah the parameter mess sucks, but thats what works...
+    function(concatenate_files _file1 _target2 _output)
+        get_target_property(_file2 ${_target2} LOCATION)
+        to_win_path("${_file1}" _real_file1)
+        to_win_path("${_file2}" _real_file2)
+        to_win_path("${_output}" _real_output)
+        add_custom_command(
+            OUTPUT ${_output}
+            COMMAND cmd.exe /C "copy /Y /B ${_real_file1} + ${_real_file2} ${_real_output} > nul"
+            DEPENDS ${_file1}
+            DEPENDS ${_target2})
+    endfunction()
+else()
+    macro(concatenate_files _file1 _target2 _output)
+        get_target_property(_file2 ${_target2} LOCATION)
+        add_custom_command(
+            OUTPUT ${_output}
+            COMMAND cat ${_file1} ${_file2} > ${_output}
+            DEPENDS ${_file1}
+            DEPENDS ${_target2})
+    endmacro()
+endif()
+
+function(add_importlibs _module)
+    add_dependency_node(${_module})
+    foreach(LIB ${ARGN})
+        if("${LIB}" MATCHES "msvcrt")
+            add_target_compile_definitions(${_module} _DLL __USE_CRTIMP)
+            target_link_libraries(${_module} msvcrtex)
+        endif()
+        target_link_libraries(${_module} lib${LIB})
+        add_dependencies(${_module} lib${LIB})
+        add_dependency_edge(${_module} ${LIB})
+    endforeach()
+endfunction()
+
+function(set_module_type MODULE TYPE)
+    cmake_parse_arguments(__module "UNICODE" "IMAGEBASE" "ENTRYPOINT" ${ARGN})
+
+    if(__module_UNPARSED_ARGUMENTS)
+        message(STATUS "set_module_type : unparsed arguments ${__module_UNPARSED_ARGUMENTS}, module : ${MODULE}")
+    endif()
+
+    # Set subsystem. Also take this as an occasion
+    # to error out if someone gave a non existing type
+    if((${TYPE} STREQUAL nativecui) OR (${TYPE} STREQUAL nativedll) OR (${TYPE} STREQUAL kernelmodedriver))
+        set(__subsystem native)
+    elseif(${TYPE} STREQUAL win32cui)
+        set(__subsystem console)
+    elseif(${TYPE} STREQUAL win32gui)
+        set(__subsystem windows)
+    elseif(NOT ((${TYPE} STREQUAL win32dll) OR (${TYPE} STREQUAL win32ocx)
+            OR (${TYPE} STREQUAL cpl) OR (${TYPE} STREQUAL module)))
+        message(FATAL_ERROR "Unknown type ${TYPE} for module ${MODULE}")
+    endif()
+
+    if(DEFINED __subsystem)
+        set_subsystem(${MODULE} ${__subsystem})
+    endif()
+
+    #set unicode definitions
+    if(__module_UNICODE)
+        add_target_compile_definitions(${MODULE} UNICODE _UNICODE)
+    endif()
+
+    # set entry point
+    if(__module_ENTRYPOINT OR (__module_ENTRYPOINT STREQUAL "0"))
+        list(GET __module_ENTRYPOINT 0 __entrypoint)
+        list(LENGTH __module_ENTRYPOINT __length)
+        if(${__length} EQUAL 2)
+            list(GET __module_ENTRYPOINT 1 __entrystack)
+        elseif(NOT ${__length} EQUAL 1)
+            message(FATAL_ERROR "Wrong arguments for ENTRYPOINT parameter of set_module_type : ${__module_ENTRYPOINT}")
+        endif()
+        unset(__length)
+    elseif(${TYPE} STREQUAL nativecui)
+        set(__entrypoint NtProcessStartup)
+        set(__entrystack 4)
+    elseif((${TYPE} STREQUAL win32gui) OR (${TYPE} STREQUAL win32cui))
+        if(__module_UNICODE)
+            set(__entrypoint wWinMainCRTStartup)
+        else()
+            set(__entrypoint WinMainCRTStartup)
+        endif()
+    elseif((${TYPE} STREQUAL win32dll) OR (${TYPE} STREQUAL win32ocx)
+            OR (${TYPE} STREQUAL cpl))
+        set(__entrypoint DllMainCRTStartup)
+        set(__entrystack 12)
+    elseif(${TYPE} STREQUAL kernelmodedriver)
+        set(__entrypoint DriverEntry)
+        set(__entrystack 8)
+    elseif(${TYPE} STREQUAL nativedll)
+        set(__entrypoint DllMain)
+        set(__entrystack 12)
+    elseif(${TYPE} STREQUAL module)
+        set(__entrypoint 0)
+    endif()
+
+    if(DEFINED __entrypoint)
+        if(DEFINED __entrystack)
+            set_entrypoint(${MODULE} ${__entrypoint} ${__entrystack})
+        else()
+            set_entrypoint(${MODULE} ${__entrypoint})
+        endif()
+    endif()
+
+    #set base address
+    if(__module_IMAGEBASE)
+        set_image_base(${MODULE} __module_IMAGEBASE)
+    elseif(${TYPE} STREQUAL win32dll)
+        if(DEFINED baseaddress_${MODULE})
+            set_image_base(${MODULE} ${baseaddress_${MODULE}})
+        else()
+            message(STATUS "${MODULE} has no base address")
+        endif()
+    elseif(${TYPE} STREQUAL kernelmodedriver)
+        set_image_base(${MODULE} 0x00010000)
+    endif()
+
+    # Now do some stuff which is specific to each type
+    if(${TYPE} STREQUAL kernelmodedriver)
+        add_dependencies(${MODULE} bugcodes)
+        set_target_properties(${MODULE} PROPERTIES SUFFIX ".sys")
+    endif()
+
+    if(${TYPE} STREQUAL win32ocx)
+        set_target_properties(${MODULE} PROPERTIES SUFFIX ".ocx")
+    endif()
+
+    if(${TYPE} STREQUAL cpl)
+        set_target_properties(${MODULE} PROPERTIES SUFFIX ".cpl")
+    endif()
+
+    # do compiler specific stuff
+    set_module_type_toolchain(${MODULE} ${TYPE})
+endfunction()
+
+function(preprocess_file __in __out)
+    set(__arg ${__in})
+    foreach(__def in ${ARGN})
+        list(APPEND __arg -D${__def})
+    endforeach()
+    if(MSVC)
+        add_custom_command(OUTPUT ${_out}
+            COMMAND ${CMAKE_C_COMPILER} /EP ${__arg}
+            DEPENDS ${__in})
+    else()
+        add_custom_command(OUTPUT ${_out}
+            COMMAND ${CMAKE_C_COMPILER} -E ${__arg}
+            DEPENDS ${__in})
+    endif()
+endfunction()
+
+function(get_includes OUTPUT_VAR)
+    get_directory_property(_includes INCLUDE_DIRECTORIES)
+    foreach(arg ${_includes})
+        list(APPEND __tmp_var -I${arg})
+    endforeach()
+    set(${OUTPUT_VAR} ${__tmp_var} PARENT_SCOPE)
+endfunction()
+
+function(get_defines OUTPUT_VAR)
+    get_directory_property(_defines COMPILE_DEFINITIONS)
+    foreach(arg ${_defines})
+        list(APPEND __tmp_var -D${arg})
+    endforeach()
+    set(${OUTPUT_VAR} ${__tmp_var} PARENT_SCOPE)
+endfunction()