1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101
|
//===--- NaiveRangeReplaceableCollectionConformance.swift -----------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2023 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
//
//===----------------------------------------------------------------------===//
import TestsUtils
var contiguous:[UInt8] = []
public let benchmarks = [
BenchmarkInfo(name: "NaiveRRC.append.largeContiguous",
runFunction: runAppendLargeContiguous,
tags: [.validation, .api],
setUpFunction: { contiguous = [UInt8](repeating: 7, count: 1_000) }),
BenchmarkInfo(name: "NaiveRRC.append.smallContiguousRepeated",
runFunction: runAppendSmallContiguousRepeatedly,
tags: [.validation, .api],
setUpFunction: { contiguous = [UInt8](repeating: 7, count: 1) }),
BenchmarkInfo(name: "NaiveRRC.init.largeContiguous",
runFunction: runInitLargeContiguous,
tags: [.validation, .api],
setUpFunction: { contiguous = [UInt8](repeating: 7, count: 1_000) })
]
struct NaiveRRC : RangeReplaceableCollection {
var storage:[UInt8] = []
init() {}
func index(after i: Int) -> Int {
i + 1
}
func index(before i: Int) -> Int {
i - 1
}
var startIndex: Int {
0
}
var endIndex: Int {
count
}
var count: Int {
storage.count
}
subscript(position: Int) -> UInt8 {
get {
storage[position]
}
set(newValue) {
storage[position] = newValue
}
}
mutating func replaceSubrange(_ subrange: Range<Int>, with newElements: some Collection<UInt8>) {
storage.replaceSubrange(subrange, with: newElements)
}
mutating func reserveCapacity(_ n: Int) {
storage.reserveCapacity(n)
}
}
@inline(never)
public func runAppendLargeContiguous(N: Int) {
for _ in 1...N {
var rrc = NaiveRRC()
rrc.append(contentsOf: contiguous)
blackHole(rrc)
}
}
@inline(never)
public func runAppendSmallContiguousRepeatedly(N: Int) {
for _ in 1...N {
var rrc = NaiveRRC()
for _ in 1...5_000 {
rrc.append(contentsOf: contiguous)
}
blackHole(rrc)
}
}
@inline(never)
public func runInitLargeContiguous(N: Int) {
for _ in 1...N {
blackHole(NaiveRRC(contiguous))
}
}
|