mirror of
https://github.com/google/sandboxed-api.git
synced 2024-03-22 13:11:30 +08:00
f44cca6c98
When embedding SAPI in an external CMake project, the version of `protobuf_generate_cpp` that we lifted from upstream protobuf produces the wrong generated file paths. For example, given this project structure: ``` /parent/ +-- myproject/ +-- myproject_build/ <- CMake build directory +-- sandboxed-api/ <- Checkout from GitHub ``` And a CMake file in `myproject/CMakeLists.txt` that embeds SAPI like this: ``` cmake_minimum_required(VERSION 3.12) project(SandboxedTest LANGUAGES CXX) set(CMAKE_CXX_STANDARD 17) set(CMAKE_CXX_STANDARD_REQUIRED ON) add_subdirectory( ${PROJECT_SOURCE_DIR}/../sandboxed-api ${PROJECT_BINARY_DIR}/sandboxed-api ) ``` Then `protobuf_generate_cpp` correctly invokes the protoc compiler to generate `/parent/myproject_build/sandboxed-api/sandboxed_api/proto_arg.proto.pb.cc'. However, the path of the generated source file that is passed to the C++ compiler will be `/parent/myproject_build/sandboxed-api/sandboxed_api/../../myproject_build/sandboxed-api/sandboxed_api/proto_arg.pb.cc`. Note the duplicated project build directory component in the canonicalized version: `/parent/myproject_build/myproject_build/sandboxed-api/sandboxed_api/proto_arg.pb.cc`. This change simple omits the computation of any relative file paths and simply uses `_pb_PROTOC_OUT_DIR` which defauls to `CMAKE_CURRENT_BINARY_DIR`, which should always contain the correct path. Signed-off-by: Christian Blichmann <mail@blichmann.eu>
55 lines
1.5 KiB
CMake
55 lines
1.5 KiB
CMake
# Copyright 2019 Google LLC
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
# sandboxed_api/sandbox2/unwind:ptrace_hook
|
|
add_library(sandbox2_ptrace_hook STATIC
|
|
ptrace_hook.cc
|
|
ptrace_hook.h
|
|
)
|
|
add_library(sandbox2::ptrace_hook ALIAS sandbox2_ptrace_hook)
|
|
target_link_libraries(sandbox2_ptrace_hook PRIVATE
|
|
sapi::base
|
|
)
|
|
|
|
# sandboxed_api/sandbox2/unwind:unwind
|
|
add_library(sandbox2_unwind STATIC
|
|
unwind.cc
|
|
unwind.h
|
|
)
|
|
add_library(sandbox2::unwind ALIAS sandbox2_unwind)
|
|
target_link_libraries(sandbox2_unwind PRIVATE
|
|
sandbox2::comms
|
|
sandbox2::maps_parser
|
|
sandbox2::minielf
|
|
sandbox2::strerror
|
|
sandbox2::unwind_proto
|
|
sapi::base
|
|
sapi::raw_logging
|
|
unwind::unwind_ptrace_wrapped
|
|
)
|
|
|
|
# sandboxed_api/sandbox2/unwind:unwind_proto
|
|
sapi_protobuf_generate_cpp(_sandbox2_unwind_pb_h _sandbox2_unwind_pb_cc
|
|
unwind.proto
|
|
)
|
|
add_library(sandbox2_unwind_proto STATIC
|
|
${_sandbox2_unwind_pb_cc}
|
|
${_sandbox2_unwind_pb_h}
|
|
)
|
|
add_library(sandbox2::unwind_proto ALIAS sandbox2_unwind_proto)
|
|
target_link_libraries(sandbox2_unwind_proto PRIVATE
|
|
protobuf::libprotobuf
|
|
sapi::base
|
|
)
|