onnxruntime
29 строк · 1.7 Кб
1# Copyright (c) Microsoft Corporation. All rights reserved.
2# Licensed under the MIT License.
3
4# Configures sources on a target to use a precompiled header. This function takes a target and
5# header name as input. The function will generate a .cpp file that includes the header and is used
6# to generate the precompiled header; this source file is added to the target's sources.
7function(target_precompiled_header target_name header_name)
8if (MSVC AND CMAKE_VS_PLATFORM_TOOLSET)
9# The input precompiled header source (i.e. the '.h' file used for the precompiled header).
10set(pch_header_path ${header_name})
11get_filename_component(header_base_name ${header_name} NAME_WE)
12
13# Generate the source file that builds the precompiled header. The generated file will have
14# the same base name as the input header name, but has the .cpp extension.
15set(pch_source_path ${CMAKE_CURRENT_BINARY_DIR}/${target_name}_${header_base_name}.cpp)
16set(pch_source_content "// THIS FILE IS GENERATED BY CMAKE\n#include \"${pch_header_path}\"")
17file(WRITE ${pch_source_path} ${pch_source_content})
18set_source_files_properties(${pch_source_path} PROPERTIES COMPILE_FLAGS "/Yc${pch_header_path}")
19
20# The target's C++ sources use the precompiled header (/Yu). Source-level properties will
21# take precedence over target-level properties, so this will not change the generated source
22# file's property to create the precompiled header (/Yc).
23target_compile_options(${target_name} PRIVATE $<$<COMPILE_LANGUAGE:CXX>:/Yu${header_name}>)
24
25# Append generated precompiled source to target's sources.
26target_sources(${target_name} PRIVATE ${pch_source_path})
27
28endif()
29endfunction()
30