mirror of
https://github.com/GLEGram/GLEGram-iOS.git
synced 2026-04-23 19:36:26 +02:00
4647310322
Based on Swiftgram 12.5 (Telegram iOS 12.5). All GLEGram features ported and organized in GLEGram/ folder. Features: Ghost Mode, Saved Deleted Messages, Content Protection Bypass, Font Replacement, Fake Profile, Chat Export, Plugin System, and more. See CHANGELOG_12.5.md for full details.
80 lines
3.0 KiB
Swift
80 lines
3.0 KiB
Swift
import Foundation
|
|
|
|
public extension Array {
|
|
|
|
func parallelMap<T>(transform: (Element) -> T) -> [T] {
|
|
var result = ContiguousArray<T?>(repeating: nil, count: count)
|
|
return result.withUnsafeMutableBufferPointer { buffer in
|
|
DispatchQueue.concurrentPerform(iterations: buffer.count) { idx in
|
|
buffer[idx] = transform(self[idx])
|
|
}
|
|
return buffer.map { $0! }
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Holds a sorted array, created from specified sequence
|
|
/// This structure is needed for the cases, when some part of application requires array to be sorted, but don't trust any inputs :)
|
|
public struct SortedArray<T: Comparable> {
|
|
public let value: Array<T>
|
|
public init<S: Sequence>(_ value: S) where S.Element == T {
|
|
self.value = value.sorted()
|
|
}
|
|
}
|
|
|
|
public extension SortedArray {
|
|
/// Returns the first index in which an element of the collection satisfies the given predicate.
|
|
/// The collection assumed to be sorted. If collection is not have sorted values the result is undefined.
|
|
///
|
|
/// The idea is to get first index of a function for which the given predicate evaluates to true.
|
|
///
|
|
/// let values = [1,2,3,4,5]
|
|
/// let idx = values.firstIndexAssumingSorted(where: { $0 > 3 })
|
|
///
|
|
/// // false, false, false, true, true
|
|
/// // ^
|
|
/// // therefore idx == 3
|
|
///
|
|
/// - Parameter predicate: A closure that takes an element as its argument
|
|
/// and returns a Boolean value that indicates whether the passed element
|
|
/// represents a match.
|
|
///
|
|
/// - Returns: The index of the first element for which `predicate` returns
|
|
/// `true`. If no elements in the collection satisfy the given predicate,
|
|
/// returns `nil`.
|
|
///
|
|
/// - Complexity: O(log(*n*)), where *n* is the length of the collection.
|
|
@inlinable
|
|
func firstIndex(where predicate: (T) throws -> Bool) rethrows -> Int? {
|
|
// Predicate should divide a collection to two pairs of values
|
|
// "bad" values for which predicate returns `false``
|
|
// "good" values for which predicate return `true`
|
|
// false false false false false true true true
|
|
// ^
|
|
// The idea is to get _first_ index which for which the predicate returns `true`
|
|
let lastIndex = value.count
|
|
|
|
// The index that represents where bad values start
|
|
var badIndex = -1
|
|
|
|
// The index that represents where good values start
|
|
var goodIndex = lastIndex
|
|
var midIndex = (badIndex + goodIndex) / 2
|
|
|
|
while badIndex + 1 < goodIndex {
|
|
if try predicate(value[midIndex]) {
|
|
goodIndex = midIndex
|
|
} else {
|
|
badIndex = midIndex
|
|
}
|
|
midIndex = (badIndex + goodIndex) / 2
|
|
}
|
|
|
|
// We're out of bounds, no good items in array
|
|
if midIndex == lastIndex || goodIndex == lastIndex {
|
|
return nil
|
|
}
|
|
return goodIndex
|
|
}
|
|
}
|