mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
Fixes a general category (pun intended) of scalar-alignment bugs surrounding exchanging non-scalar-aligned indices between views and for slicing. SE-0180 unifies the Index type of String and all its views and allows non-scalar-aligned indices to be used across views. In order to guarantee behavior, we often have to check and perform scalar alignment. To speed up these checks, we allocate a bit denoting known-to-be-aligned, so that the alignment check can skip the load. The below shows what views need to check for alignment before they can operate, and whether the indices they produce are aligned. ┌───────────────╥────────────────────┬──────────────────────────┐ │ View ║ Requires Alignment │ Produces Aligned Indices │ ╞═══════════════╬════════════════════╪══════════════════════════╡ │ Native UTF8 ║ no │ no │ ├───────────────╫────────────────────┼──────────────────────────┤ │ Native UTF16 ║ yes │ no │ ╞═══════════════╬════════════════════╪══════════════════════════╡ │ Foreign UTF8 ║ yes │ no │ ├───────────────╫────────────────────┼──────────────────────────┤ │ Foreign UTF16 ║ no │ no │ ╞═══════════════╬════════════════════╪══════════════════════════╡ │ UnicodeScalar ║ yes │ yes │ ├───────────────╫────────────────────┼──────────────────────────┤ │ Character ║ yes │ yes │ └───────────────╨────────────────────┴──────────────────────────┘ The "requires alignment" applies to any operation taking a String.Index that's not defined entirely in terms of other operations taking a String.Index. These include: * index(after:) * index(before:) * subscript * distance(from:to:) (since `to` is compared against directly) * UTF16View._nativeGetOffset(for:)
82 lines
2.5 KiB
Swift
82 lines
2.5 KiB
Swift
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This source file is part of the Swift.org open source project
|
|
//
|
|
// Copyright (c) 2014 - 2019 Apple Inc. and the Swift project authors
|
|
// Licensed under Apache License v2.0 with Runtime Library Exception
|
|
//
|
|
// See https://swift.org/LICENSE.txt for license information
|
|
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// This file contains non-API (or underscored) declarations that are needed to
|
|
// be kept around for ABI compatibility
|
|
|
|
extension Unicode.UTF16 {
|
|
@available(*, unavailable, renamed: "Unicode.UTF16.isASCII")
|
|
@inlinable
|
|
public static func _isASCII(_ x: CodeUnit) -> Bool {
|
|
return Unicode.UTF16.isASCII(x)
|
|
}
|
|
}
|
|
|
|
@available(*, unavailable, renamed: "Unicode.UTF8.isASCII")
|
|
@inlinable
|
|
internal func _isASCII(_ x: UInt8) -> Bool {
|
|
return Unicode.UTF8.isASCII(x)
|
|
}
|
|
|
|
@available(*, unavailable, renamed: "Unicode.UTF8.isContinuation")
|
|
@inlinable
|
|
internal func _isContinuation(_ x: UInt8) -> Bool {
|
|
return UTF8.isContinuation(x)
|
|
}
|
|
|
|
extension Substring {
|
|
@available(*, unavailable, renamed: "Substring.base")
|
|
@inlinable
|
|
internal var _wholeString: String { return base }
|
|
}
|
|
|
|
extension String {
|
|
@available(*, unavailable, renamed: "String.withUTF8")
|
|
@inlinable
|
|
internal func _withUTF8<R>(
|
|
_ body: (UnsafeBufferPointer<UInt8>) throws -> R
|
|
) rethrows -> R {
|
|
var copy = self
|
|
return try copy.withUTF8(body)
|
|
}
|
|
}
|
|
|
|
extension Substring {
|
|
@available(*, unavailable, renamed: "Substring.withUTF8")
|
|
@inlinable
|
|
internal func _withUTF8<R>(
|
|
_ body: (UnsafeBufferPointer<UInt8>) throws -> R
|
|
) rethrows -> R {
|
|
var copy = self
|
|
return try copy.withUTF8(body)
|
|
}
|
|
}
|
|
|
|
// This function is no longer used but must be kept for ABI compatibility
|
|
// because references to it may have been inlined.
|
|
@usableFromInline
|
|
internal func _branchHint(_ actual: Bool, expected: Bool) -> Bool {
|
|
// The LLVM intrinsic underlying int_expect_Int1 now requires an immediate
|
|
// argument for the expected value so we cannot call it here. This should
|
|
// never be called in cases where performance matters, so just return the
|
|
// value without any branch hint.
|
|
return actual
|
|
}
|
|
|
|
extension String {
|
|
@usableFromInline // Never actually used in inlinable code...
|
|
internal func _nativeCopyUTF16CodeUnits(
|
|
into buffer: UnsafeMutableBufferPointer<UInt16>,
|
|
range: Range<String.Index>
|
|
) { fatalError() }
|
|
}
|