[CMAKE]
[reactos.git] / CMakeMacros.cmake
index 880555a..b2a7c68 100644 (file)
@@ -1,4 +1,4 @@
-
+\r
 MACRO(_PCH_GET_COMPILE_FLAGS _target_name _out_compile_flags _header_filename)\r
 \r
     # Add the precompiled header to the build\r
@@ -41,17 +41,6 @@ MACRO(add_pch _target_name _header_filename _src_list)
 \r
 ENDMACRO(add_pch _target_name _header_filename _src_list)\r
 \r
-MACRO(spec2def _target_name _spec_file _def_file)\r
-\r
-    add_custom_command(\r
-        OUTPUT ${_def_file}\r
-        COMMAND native-winebuild -o ${_def_file} --def -E ${_spec_file} --filename ${_target_name}.dll\r
-        DEPENDS native-winebuild)\r
-    set_source_files_properties(${_def_file} PROPERTIES GENERATED TRUE)\r
-    add_custom_target(${_target_name}_def ALL DEPENDS ${_def_file})\r
-\r
-ENDMACRO(spec2def _target_name _spec_file _def_file)\r
-\r
 if (NOT MSVC)\r
 MACRO(CreateBootSectorTarget _target_name _asm_file _object_file)\r
 \r
@@ -72,7 +61,7 @@ MACRO(CreateBootSectorTarget _target_name _asm_file _object_file)
     add_custom_command(\r
         OUTPUT ${_object_file}\r
         COMMAND nasm -o ${_object_file} ${result_incs} ${result_defs} -f bin ${_asm_file}\r
-        DEPENDS native-winebuild)\r
+        DEPENDS ${_asm_file})\r
     set_source_files_properties(${_object_file} PROPERTIES GENERATED TRUE)\r
     add_custom_target(${_target_name} ALL DEPENDS ${_object_file})\r
     add_minicd(${_object_file} loader ${OBJECT_NAME})\r
@@ -117,70 +106,89 @@ MACRO(ADD_INTERFACE_DEFINITIONS TARGET)
 ENDMACRO()\r
 \r
 MACRO(add_minicd_target _targetname _dir) # optional parameter: _nameoncd\r
-    get_target_property(FILENAME ${_targetname} LOCATION)\r
-\r
     if("${ARGN}" STREQUAL "")\r
+        get_target_property(FILENAME ${_targetname} LOCATION)\r
        get_filename_component(_nameoncd ${FILENAME} NAME)\r
     else()\r
        set(_nameoncd ${ARGN})\r
     endif()\r
-\r
-    add_custom_command(\r
-        OUTPUT ${BOOTCD_DIR}/${_dir}/${_nameoncd}        \r
-        COMMAND ${CMAKE_COMMAND} -E copy ${FILENAME} ${BOOTCD_DIR}/${_dir}/${_nameoncd})\r
-\r
-    add_custom_target(${_targetname}_minicd DEPENDS ${BOOTCD_DIR}/${_dir}/${_nameoncd})\r
-\r
-    add_dependencies(${_targetname}_minicd ${_targetname})\r
-    add_dependencies(minicd ${_targetname}_minicd)\r
-ENDMACRO(add_minicd_target _targetname _dir _nameoncd)\r
+    \r
+    file(APPEND ${REACTOS_BINARY_DIR}/boot/ros_minicd_target.txt "${_targetname}\t${_dir}\t${_nameoncd}\n")\r
+ENDMACRO(add_minicd_target)\r
 \r
 MACRO(add_minicd FILENAME _dir _nameoncd)\r
-    add_custom_command(\r
-        OUTPUT ${BOOTCD_DIR}/${_dir}/${_nameoncd}\r
-        DEPENDS ${FILENAME}\r
-        COMMAND ${CMAKE_COMMAND} -E copy ${FILENAME} ${BOOTCD_DIR}/${_dir}/${_nameoncd})\r
-        \r
-    add_custom_target(${_nameoncd}_minicd DEPENDS ${BOOTCD_DIR}/${_dir}/${_nameoncd})\r
-    \r
-    add_dependencies(minicd ${_nameoncd}_minicd)\r
+    file(APPEND ${REACTOS_BINARY_DIR}/boot/ros_minicd.txt "${FILENAME}\t${_dir}\t${_nameoncd}\n")\r
 ENDMACRO(add_minicd)\r
-
-macro(set_cpp)
-  include_directories(BEFORE ${REACTOS_SOURCE_DIR}/lib/3rdparty/stlport/stlport)
-  set(IS_CPP 1)
-endmacro()
+\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_livecd_target _targetname _dir )# optional parameter : _nameoncd\r
+    if("${ARGN}" STREQUAL "")\r
+        get_target_property(FILENAME ${_targetname} LOCATION)\r
+       get_filename_component(_nameoncd ${FILENAME} NAME)\r
+    else()\r
+       set(_nameoncd ${ARGN})\r
+    endif()\r
     \r
-    get_target_property(FILENAME ${_targetname} LOCATION)\r
+    file(APPEND ${REACTOS_BINARY_DIR}/boot/ros_livecd_target.txt "${_targetname}\t${_dir}\t${_nameoncd}\n")\r
+ENDMACRO(add_livecd_target)\r
 \r
+MACRO(add_livecd FILENAME _dir)# optional parameter : _nameoncd\r
     if("${ARGN}" STREQUAL "")\r
        get_filename_component(_nameoncd ${FILENAME} NAME)\r
     else()\r
        set(_nameoncd ${ARGN})\r
     endif()\r
+    file(APPEND ${REACTOS_BINARY_DIR}/boot/ros_livecd.txt "${FILENAME}\t${_dir}\t${_nameoncd}\n")\r
+ENDMACRO(add_livecd)\r
 \r
-    add_custom_command(\r
-        OUTPUT ${LIVECD_DIR}/${_dir}/${_nameoncd}        \r
-        COMMAND ${CMAKE_COMMAND} -E copy ${FILENAME} ${LIVECD_DIR}/${_dir}/${_nameoncd})\r
-        \r
-    add_custom_target(${_targetname}_livecd DEPENDS ${LIVECD_DIR}/${_dir}/${_nameoncd})\r
+macro(cab_to_dir _dir_num _var_name)\r
+#   1 = system32\r
+#   2 = system32\drivers\r
+#   3 = Fonts\r
+#   4 =\r
+#   5 = system32\drivers\etc\r
+#   6 = inf\r
+#   7 = bin\r
+#   8 = media\r
+    if(${_dir_num} STREQUAL "1")\r
+        set(${_var_name} "reactos/system32")\r
+    elseif(${_dir_num} STREQUAL "2")\r
+        set(${_var_name} "reactos/system32/drivers")\r
+    elseif(${_dir_num} STREQUAL "3")\r
+        set(${_var_name} "reactos/fonts")\r
+    elseif(${_dir_num} STREQUAL "4")\r
+        set(${_var_name} "reactos")\r
+    elseif(${_dir_num} STREQUAL "5")\r
+        set(${_var_name} "reactos/system32/drivers/etc")\r
+    elseif(${_dir_num} STREQUAL "6")\r
+        set(${_var_name} "reactos/inf")\r
+    elseif(${_dir_num} STREQUAL "7")\r
+        set(${_var_name} "reactos/bin")\r
+    elseif(${_dir_num} STREQUAL "8")\r
+        set(${_var_name} "reactos/system32/drivers")\r
+    else()\r
+        message(FATAL_ERROR "Wrong directory ${_dir_num}")\r
+    endif()\r
+endmacro()\r
 \r
-    add_dependencies(${_targetname}_livecd ${_targetname})\r
-    add_dependencies(livecd ${_targetname}_livecd)\r
-ENDMACRO(add_livecd_target _targetname _dir _nameoncd)\r
+MACRO(add_cab_target _targetname _num )\r
+    file(APPEND ${REACTOS_BINARY_DIR}/boot/ros_cab_target.txt "${_targetname}\t${_num}\n")\r
+    cab_to_dir(${_num} _dir)\r
+    add_livecd_target(${_targetname} ${_dir})\r
+ENDMACRO(add_cab_target)\r
 \r
-MACRO(add_livecd FILENAME _dir _nameoncd)\r
-    add_custom_command(\r
-        OUTPUT ${LIVECD_DIR}/${_dir}/${_nameoncd}\r
-        DEPENDS ${FILENAME}\r
-        COMMAND ${CMAKE_COMMAND} -E copy ${FILENAME} ${LIVECD_DIR}/${_dir}/${_nameoncd})\r
-        \r
-    add_custom_target(${_nameoncd}_livecd DEPENDS ${LIVECD_DIR}/${_dir}/${_nameoncd})\r
-    \r
-    add_dependencies(livecd ${_nameoncd}_livecd)\r
-ENDMACRO(add_livecd)\r
+MACRO(add_cab FILENAME _num)\r
+    file(APPEND ${REACTOS_BINARY_DIR}/boot/ros_cab.txt "${FILENAME}\t${_num}\n")\r
+    cab_to_dir(${_num} _dir)\r
+    add_livecd(${FILENAME} ${_dir})\r
+ENDMACRO(add_cab)    \r
 \r
 macro(custom_incdefs)\r
     if(NOT DEFINED result_incs) #rpc_defines\r
@@ -236,8 +244,8 @@ macro (MACRO_IDL_FILES)
         get_filename_component(FILE ${_in_FILE} NAME_WE)\r
         add_custom_command(\r
             OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_s.h ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_s.c\r
-            COMMAND native-widl ${result_incs} ${result_defs} -m32 --win32 -h -H ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_s.h -s -S ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_s.c ${CMAKE_CURRENT_SOURCE_DIR}/${FILE}.idl\r
-            DEPENDS native-widl)\r
+            COMMAND ${IDL_COMPILER} ${result_incs} ${result_defs} ${IDL_FLAGS} ${IDL_HEADER_ARG} ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_s.h ${IDL_SERVER_ARG} ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_s.c ${CMAKE_CURRENT_SOURCE_DIR}/${FILE}.idl\r
+            DEPENDS ${_in_file})\r
         set_source_files_properties(\r
             ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_s.h ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_s.c\r
             PROPERTIES GENERATED TRUE)\r
@@ -246,8 +254,8 @@ macro (MACRO_IDL_FILES)
     \r
         add_custom_command(\r
             OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_c.h ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_c.c\r
-            COMMAND native-widl ${result_incs} ${result_defs} -m32 --win32 -h -H ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_c.h -c -C ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_c.c ${CMAKE_CURRENT_SOURCE_DIR}/${FILE}.idl\r
-            DEPENDS native-widl)\r
+            COMMAND ${IDL_COMPILER} ${result_incs} ${result_defs} ${IDL_FLAGS} ${IDL_HEADER_ARG} ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_c.h ${IDL_CLIENT_ARG} ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_c.c ${CMAKE_CURRENT_SOURCE_DIR}/${FILE}.idl\r
+            DEPENDS ${_in_file})\r
         set_source_files_properties(\r
             ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_c.h ${CMAKE_CURRENT_BINARY_DIR}/${FILE}_c.c\r
             PROPERTIES GENERATED TRUE)\r
@@ -256,3 +264,16 @@ macro (MACRO_IDL_FILES)
     endforeach(_in_FILE ${ARGN})\r
 \r
 endmacro (MACRO_IDL_FILES)\r
+\r
+macro(ADD_TYPELIB TARGET)\r
+  custom_incdefs()\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 ${CMAKE_CURRENT_BINARY_DIR}/${FILE}.tlb\r
+                       COMMAND ${IDL_COMPILER} ${result_incs} ${IDL_FLAGS} ${IDL_TYPELIB_ARG} ${CMAKE_CURRENT_BINARY_DIR}/${FILE}.tlb ${CMAKE_CURRENT_SOURCE_DIR}/${SOURCE}\r
+                       DEPENDS ${SOURCE})\r
+    list(APPEND OBJECTS ${OBJECT})\r
+  endforeach()\r
+  add_custom_target(${TARGET} ALL DEPENDS ${OBJECTS})\r
+endmacro()\r