Я хочу создать решение Visual Studio для кроссплатформенного проекта Linux из проекта CMake.
Межплатформенная рабочая нагрузка Visual Studio 2017 прекрасно работает, особенно когда речь идет об отладке. Я использую это, чтобы предназначаться для WSL.
Теперь у меня есть существующий проект Linux CMake, который я хочу разработать для Windows и Visual Studio и построить его на WSL. Я просто не вижу способа генерирования подходящего решения для Visual Studio. Кто-нибудь может просветить меня?
Уже были некоторые запросы для поддержки типа проекта «Linux» CMake, но я не думаю, что что-то еще реализовано (глядя на код, он не может генерировать необходимые настройки проекта).
В этих случаях вы можете работать только с include_external_msproject()
командные вызовы.
Это будет включать в себя существующий .vcproj
файл в ваше сгенерированное CMake решение, например:
include_external_msproject(
MyProject
${CMAKE_CURRENT_SOURCE_DIR}/MyProject/MyProject.vcproj
)
Итак, давайте сделаем шаблон существующего Linux .vcxproj
файл как это:
<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" ToolsVersion="@[email protected]" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup Label="ProjectConfigurations">
<ProjectConfiguration Include="Debug|x86">
<Configuration>Debug</Configuration>
<Platform>x86</Platform>
</ProjectConfiguration>
<ProjectConfiguration Include="Release|x86">
<Configuration>Release</Configuration>
<Platform>x86</Platform>
</ProjectConfiguration>
</ItemGroup>
<PropertyGroup Label="Globals">
<ProjectGuid>@_guid@</ProjectGuid>
<Keyword>Linux</Keyword>
<RootNamespace>@_target@</RootNamespace>
<MinimumVisualStudioVersion>@[email protected]</MinimumVisualStudioVersion>
<ApplicationType>Linux</ApplicationType>
<ApplicationTypeRevision>1.0</ApplicationTypeRevision>
<TargetLinuxPlatform>Generic</TargetLinuxPlatform>
<LinuxProjectType>{D51BCBC9-82E9-4017-911E-C93873C4EA2B}</LinuxProjectType>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x86'" Label="Configuration">
<UseDebugLibraries>true</UseDebugLibraries>
</PropertyGroup>
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x86'" Label="Configuration">
<UseDebugLibraries>false</UseDebugLibraries>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
<ImportGroup Label="ExtensionSettings" />
<ImportGroup Label="Shared" />
<ImportGroup Label="PropertySheets" />
<PropertyGroup Label="UserMacros" />
<ItemGroup>
<ClCompile Include="@_sources@" />
</ItemGroup>
<ItemGroup>
</ItemGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
<ImportGroup Label="ExtensionTargets" />
</Project>
И создать новый add_linux_executable()
команда, использующая это:
cmake_minimum_required(VERSION 2.8)
project(ConfigureVCXProjForLinux)
function(add_linux_executable _target)
if (CMAKE_GENERATOR MATCHES "Visual Studio ([0-9]*)")
foreach(_source IN LISTS ARGN)
get_filename_component(_source_abs "${_source}" ABSOLUTE)
file(TO_NATIVE_PATH "${_source_abs}" _source_native)
list(APPEND _sources "${_source_native}")
endforeach()
file(TO_NATIVE_PATH "${CMAKE_CURRENT_LIST_FILE}" _list_file_native)
list(APPEND _sources "${_list_file_native}")
string(
UUID _guid
NAMESPACE "2e4779e9-c831-47b0-b138-3745b2ed6ba9"NAME ${_target}
TYPE SHA1
UPPER
)
configure_file(
"LinuxTemplate.vcxproj.in""${CMAKE_CURRENT_BINARY_DIR}/${_target}.vcxproj"@ONLY
)
include_external_msproject(
${_target}
"${CMAKE_CURRENT_BINARY_DIR}/${_target}.vcxproj"TYPE "8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942"GUID "${_guid}")
endif()
endfunction()
file(WRITE "main.cpp" [=[
#include <iostream>
int main()
{
std::cout << "Hello Linux !" << std::endl;
}
]=])
add_linux_executable(${PROJECT_NAME} "main.cpp")
Обратите внимание на замену шаблона:
@CMAKE_MATCH_1@
для номера версии Visual Studio@_target@
для проекта RootNamespace@_sources@
для любого исходного файла вы указали « add_linux_executable () `в качестве аргумента@_guid@
уникальный GUID для проектаДля этого все равно потребуется один шаблон для любых выбранных вами параметров компиляции. Но использование шаблонов делает этот подход несколько более гибким.
Других решений пока нет …