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>
66 lines
2.0 KiB
CMake
66 lines
2.0 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/examples/stringop/lib:stringop_params_proto
|
|
sapi_protobuf_generate_cpp(
|
|
_sapi_stringop_params_pb_cc _sapi_stringop_params_pb_h
|
|
stringop_params.proto
|
|
)
|
|
# Object library to avoid having to use -Wl,--whole-archive. This simulates
|
|
# Bazel's alwayslink=1.
|
|
add_library(sapi_stringop_params_proto OBJECT
|
|
${_sapi_stringop_params_pb_cc}
|
|
${_sapi_stringop_params_pb_h}
|
|
)
|
|
add_library(sapi::stringop_params_proto ALIAS sapi_stringop_params_proto)
|
|
target_include_directories(sapi_stringop_params_proto PUBLIC
|
|
${Protobuf_INCLUDE_DIRS}
|
|
)
|
|
|
|
# sandboxed_api/examples/stringop/lib:stringop
|
|
add_library(sapi_stringop STATIC
|
|
stringop.cc
|
|
)
|
|
add_library(sapi::stringop ALIAS sapi_stringop)
|
|
add_dependencies(sapi_stringop
|
|
sapi::stringop_params_proto
|
|
)
|
|
target_link_libraries(sapi_stringop
|
|
PRIVATE $<TARGET_OBJECTS:sapi_stringop_params_proto>
|
|
sapi::base
|
|
sapi::lenval_core
|
|
PUBLIC protobuf::libprotobuf
|
|
)
|
|
|
|
# sandboxed_api/examples/stringop/lib:stringop-sapi
|
|
add_sapi_library(stringop-sapi
|
|
SOURCES sandbox.h
|
|
FUNCTIONS duplicate_string
|
|
reverse_string
|
|
pb_duplicate_string
|
|
pb_reverse_string
|
|
nop
|
|
violate
|
|
get_raw_c_string
|
|
INPUTS stringop.cc
|
|
LIBRARY sapi_stringop
|
|
LIBRARY_NAME Stringop
|
|
NAMESPACE ""
|
|
)
|
|
add_library(sapi::stringop_sapi ALIAS stringop-sapi)
|
|
target_link_libraries(stringop-sapi PRIVATE
|
|
$<TARGET_OBJECTS:sapi_stringop_params_proto>
|
|
sapi::base
|
|
)
|