From eefad4a723ce63a0ac02edec7c41d69fa10b14bb Mon Sep 17 00:00:00 2001 From: Katalin Rebhan Date: Tue, 25 Feb 2025 21:26:32 +0100 Subject: Add swift_interoperability_mode kwarg --- docs/markdown/snippets/swift_cxx_interoperability.md | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) (limited to 'docs/markdown/snippets') diff --git a/docs/markdown/snippets/swift_cxx_interoperability.md b/docs/markdown/snippets/swift_cxx_interoperability.md index f18e114..9e324f9 100644 --- a/docs/markdown/snippets/swift_cxx_interoperability.md +++ b/docs/markdown/snippets/swift_cxx_interoperability.md @@ -1,13 +1,23 @@ ## Swift/C++ interoperability is now supported It is now possible to create Swift executables that can link to C++ or -Objective-C++ libraries. Only specifying a bridging header for the Swift -target is required. +Objective-C++ libraries. To enable this feature, set the target kwarg +_swift\_interoperability\_mode_ to 'cpp'. + +To import C++ code, specify a bridging header in the Swift target's +sources, or use another way such as adding a directory containing a +Clang module map to its include path. + +Note: Enabling C++ interoperability in a library target is a breaking +change. Swift libraries that enable it need their consumers to enable +it as well, as per [the Swift documentation][1]. Swift 5.9 is required to use this feature. Xcode 15 is required if the Xcode backend is used. ```meson lib = static_library('mylib', 'mylib.cpp') -exe = executable('prog', 'main.swift', 'mylib.h', link_with: lib) +exe = executable('prog', 'main.swift', 'mylib.h', link_with: lib, swift_interoperability_mode: 'cpp') ``` + +[1]: https://www.swift.org/documentation/cxx-interop/project-build-setup/#vending-packages-that-enable-c-interoperability -- cgit v1.1