|author||davg <firstname.lastname@example.org>||Wed Apr 01 12:49:25 2020 -0400|
|committer||David Goldman <email@example.com>||Fri Apr 17 10:06:27 2020 -0400|
Use the unique name when setting `PRODUCT_NAME` for `PBXNativeTarget`s While this is a requirement for the new build system, this fixes a long-standing known issue in Tulsi where running multiple tests with the same bundle name from a test_suite would not work properly. - Additionally try to shorten the unique native target names by searching for a common prefix (currently limited to targets but not test_suites themselves) PiperOrigin-RevId: 304204500
.bazelrcto see if the Xcode version used by Tulsi is installed locally. If it isn't, feel free to remove the
--xcode_versionflag or modify it as you wish, but note that Tulsi may not build correctly with different versions of Xcode.
build_and_run.sh. This will install Tulsi.app inside ~/Applications.
Tulsi-generated Xcode projects use Bazel to build, not Xcode via xcbuild. This means that many common components of an Xcode project are handled differently than you may be used to. Notable differences:
bazelinvocations, some of which may affect Bazel caching. In order to maximize cache re-use when building from the command line, try using the
user_build.pyscript which is located in the generated xcodeproj at
Tulsi projects contain a few settings which control various behaviors during project generation and builds.
buildflags, customizable per compilation mode (
buildstartup flags, also customizable per compilation mode
fastbuild) used during project generation.
dbg, swap to
optif you normally build Release builds in Xcode (i.e. profiling your app). Setting this improperly shouldn't break your project although it may potentially worsen generation and build performance.
No, swap to
Yesif your project contains Swift (even in its dependencies). Setting this improperly shouldn't break your project although it may potentially worsen generation and build performance.