Strip Xcode versions like "9.0gm" for the version flag.
Turns out, those exist.
RELNOTES: None.
PiperOrigin-RevId: 172768102
diff --git a/tools/osx/xcode_version_flag.bzl b/tools/osx/xcode_version_flag.bzl
index 5503749..58efa96 100644
--- a/tools/osx/xcode_version_flag.bzl
+++ b/tools/osx/xcode_version_flag.bzl
@@ -14,48 +14,74 @@
"""Rules that allows select() to differentiate between Apple OS versions."""
+def _strip_version(version):
+ """Strip trailing characters from version names.
+
+ Some OS versions look like "9.0gm", which is not useful for select()
+ statements. Thus, we strip the trailing "gm" part.
+
+ Args:
+ version: the version string
+
+ Returns:
+ The version with trailing letters stripped.
+ """
+ result = ""
+ for ch in str(version):
+ if not ch.isdigit() and ch != ".":
+ break
+
+ result += ch
+
+ return result
+
+
def _xcode_version_flag_impl(ctx):
"""A rule that allows select() to differentiate between Xcode versions."""
xcode_config = ctx.attr._xcode_config[apple_common.XcodeVersionConfig]
-
return struct(providers = [
- config_common.FeatureFlagInfo(value = str(xcode_config.xcode_version()))])
+ config_common.FeatureFlagInfo(value = _strip_version(
+ xcode_config.xcode_version()))])
def _ios_sdk_version_flag_impl(ctx):
"""A rule that allows select() to select based on the iOS SDK version."""
xcode_config = ctx.attr._xcode_config[apple_common.XcodeVersionConfig]
- return struct(providers = [config_common.FeatureFlagInfo(value = str(
- xcode_config.sdk_version_for_platform(
- apple_common.platform.ios_device)))])
+ return struct(providers = [
+ config_common.FeatureFlagInfo(value = _strip_version(
+ xcode_config.sdk_version_for_platform(
+ apple_common.platform.ios_device)))])
def _tvos_sdk_version_flag_impl(ctx):
"""A rule that allows select() to select based on the tvOS SDK version."""
xcode_config = ctx.attr._xcode_config[apple_common.XcodeVersionConfig]
- return struct(providers = [config_common.FeatureFlagInfo(value = str(
- xcode_config.sdk_version_for_platform(
- apple_common.platform.tvos_device)))])
+ return struct(providers = [
+ config_common.FeatureFlagInfo(value = _strip_version(
+ xcode_config.sdk_version_for_platform(
+ apple_common.platform.tvos_device)))])
def _watchos_sdk_version_flag_impl(ctx):
"""A rule that allows select() to select based on the watchOS SDK version."""
xcode_config = ctx.attr._xcode_config[apple_common.XcodeVersionConfig]
- return struct(providers = [config_common.FeatureFlagInfo(value = str(
- xcode_config.sdk_version_for_platform(
- apple_common.platform.watchos_device)))])
+ return struct(providers = [
+ config_common.FeatureFlagInfo(value = _strip_version(
+ xcode_config.sdk_version_for_platform(
+ apple_common.platform.watchos_device)))])
def _macos_sdk_version_flag_impl(ctx):
"""A rule that allows select() to select based on the macOS SDK version."""
xcode_config = ctx.attr._xcode_config[apple_common.XcodeVersionConfig]
- return struct(providers = [config_common.FeatureFlagInfo(value = str(
- xcode_config.sdk_version_for_platform(
- apple_common.platform.macos_device)))])
+ return struct(providers = [
+ config_common.FeatureFlagInfo(value = _strip_version(
+ xcode_config.sdk_version_for_platform(
+ apple_common.platform.macos_device)))])
xcode_version_flag = rule(