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
endmacro()\r
\r
else()\r
\r
endif()\r
\r
-macro(add_minicd_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
- file(APPEND ${REACTOS_BINARY_DIR}/boot/ros_minicd_target.txt "${_targetname}\t${_dir}\t${_nameoncd}\n")\r
-endmacro()\r
-\r
-macro(add_minicd FILENAME _dir _nameoncd)\r
- file(APPEND ${REACTOS_BINARY_DIR}/boot/ros_minicd.txt "${FILENAME}\t${_dir}\t${_nameoncd}\n")\r
-endmacro()\r
-\r
macro(set_cpp)\r
include_directories(BEFORE ${REACTOS_SOURCE_DIR}/include/c++/stlport)\r
set(IS_CPP 1)\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
- file(APPEND ${REACTOS_BINARY_DIR}/boot/ros_livecd_target.txt "${_targetname}\t${_dir}\t${_nameoncd}\n")\r
-endmacro()\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()\r
-\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
-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()\r
-\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()\r
-\r
macro(add_dependency_node _node)\r
if(GENERATE_DEPENDENCY_GRAPH)\r
get_target_property(_type ${_node} TYPE)\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
+ 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