mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
This reverts commit f835a115e283dd03001f397ae1538b3745ad779a. ExistentialCollection tests failed in the release+asserts build. Swift SVN r27939
146 lines
3.8 KiB
Swift
146 lines
3.8 KiB
Swift
//===--- BridgeNonVerbatim.swift - Array bridging implementation test -----===//
|
|
//
|
|
// This source file is part of the Swift.org open source project
|
|
//
|
|
// Copyright (c) 2014 - 2015 Apple Inc. and the Swift project authors
|
|
// Licensed under Apache License v2.0 with Runtime Library Exception
|
|
//
|
|
// See http://swift.org/LICENSE.txt for license information
|
|
// See http://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// When a ContiguousArray<T> is bridged to Objective-C, and T isn't
|
|
// "bridged verbatim," Cocoa operations like objectAtIndex may have
|
|
// to conjure up an object to return, and this object is expected to
|
|
// outlive the array.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
// RUN: %target-run-stdlib-swift %s | FileCheck %s
|
|
//
|
|
// XFAIL: interpret
|
|
// REQUIRES: objc_interop
|
|
|
|
import Swift
|
|
import SwiftShims
|
|
import ObjectiveC
|
|
|
|
//===--- class Tracked ----------------------------------------------------===//
|
|
// Instead of testing with Int elements, we use this wrapper class
|
|
// that can help us track allocations and find issues with object
|
|
// lifetime inside Array implementations.
|
|
var trackedCount = 0
|
|
var nextTrackedSerialNumber = 0
|
|
|
|
final class Tracked : ForwardIndexType, CustomStringConvertible {
|
|
required init(_ value: Int) {
|
|
++trackedCount
|
|
serialNumber = ++nextTrackedSerialNumber
|
|
self.value = value
|
|
}
|
|
|
|
deinit {
|
|
assert(serialNumber > 0, "double destruction!")
|
|
--trackedCount
|
|
serialNumber = -serialNumber
|
|
}
|
|
|
|
var description: String {
|
|
assert(serialNumber > 0, "dead Tracked!")
|
|
return value.description
|
|
}
|
|
|
|
func successor() -> Self {
|
|
return self.dynamicType(self.value.successor())
|
|
}
|
|
|
|
var value: Int
|
|
var serialNumber: Int
|
|
}
|
|
|
|
func == (x: Tracked, y: Tracked) -> Bool {
|
|
return x.value == y.value
|
|
}
|
|
|
|
struct X : _ObjectiveCBridgeable {
|
|
static func _isBridgedToObjectiveC() -> Bool {
|
|
return true
|
|
}
|
|
|
|
init(_ value: Int) {
|
|
self.value = value
|
|
}
|
|
|
|
static func _getObjectiveCType() -> Any.Type {
|
|
return Tracked.self
|
|
}
|
|
|
|
func _bridgeToObjectiveC() -> Tracked {
|
|
return Tracked(value)
|
|
}
|
|
|
|
static func _forceBridgeFromObjectiveC(
|
|
x: Tracked,
|
|
inout result: X?
|
|
) {
|
|
result = X(x.value)
|
|
}
|
|
|
|
static func _conditionallyBridgeFromObjectiveC(
|
|
x: Tracked,
|
|
inout result: X?
|
|
) -> Bool {
|
|
result = X(x.value)
|
|
return true
|
|
}
|
|
|
|
var value: Int
|
|
}
|
|
|
|
// CHECK: testing...
|
|
println("testing...")
|
|
|
|
func testScope() {
|
|
let a = [X(1), X(2), X(3)]
|
|
let nsx = a._buffer._asCocoaArray()
|
|
|
|
// construction of these tracked objects is lazy
|
|
// CHECK-NEXT: trackedCount = 0 .
|
|
println("trackedCount = \(trackedCount) .")
|
|
|
|
// We can get a single element out
|
|
// CHECK-NEXT: nsx[0]: 1 .
|
|
var one = nsx.objectAtIndex(0) as! Tracked
|
|
println("nsx[0]: \(one.value) .")
|
|
|
|
// We can get the element again, but it may not have the same identity
|
|
// CHECK-NEXT: object identity matches?
|
|
var anotherOne = nsx.objectAtIndex(0) as! Tracked
|
|
println("object identity matches? \(one === anotherOne)")
|
|
|
|
// Because the elements come back at +0, we really don't want to
|
|
// treat them as objects, or we'll get double deletion
|
|
var objects: [Word] = [0, 0]
|
|
|
|
objects.withUnsafeMutableBufferPointer {
|
|
// FIXME: Can't elide signature and use $0 here <rdar://problem/17770732>
|
|
(inout buf: UnsafeMutableBufferPointer<Word>)->() in
|
|
nsx.getObjects(
|
|
UnsafeMutablePointer<AnyObject>(buf.baseAddress),
|
|
range: _SwiftNSRange(location: 1, length: 2))
|
|
}
|
|
|
|
// CHECK-NEXT: getObjects yields them at +0: true
|
|
var x = objects[0]
|
|
println("getObjects yields them at +0: "
|
|
+ "\(_swift_isUniquelyReferenced_native(UnsafePointer(bitPattern:x)))")
|
|
}
|
|
|
|
autoreleasepool() {
|
|
testScope()
|
|
}
|
|
|
|
// CHECK-NEXT: leaks = 0 .
|
|
println("leaks = \(trackedCount) .")
|
|
|