mirror of
https://github.com/jellyfin/Swiftfin.git
synced 2024-11-27 00:00:37 +00:00
f5bd1b8fcd
* Rename ExperimentalSettingsView.swift to PlaybackQualitySettingsView.swift Fix Merge * Rename MaximumBitrateSettingsView.swift to PlaybackQualitySettingsView.swift fix merge * Re-implement on Main. Should now have all the Main changed. Added a new change to use the Device Profile as a Transcoding Profile. * Part 1 -> Making VideoPlayerType into a struct (I Hope) correctly * Part 1.1 -> Making VideoPlayerType into a struct (I Hope) correctly * Remove unneeded Files * Missing file + CustomDeviceProfileSelection -> CustomDeviceProfileAction Rename * Change + to Appending * Attempt to add StorageValues+User. Not sure if this is correct? * Move the Array unwrapping to funcitons. Not required but this should help prevent accidently doing this wrong. Add subtitles back into the custom profiles since that somehow got dropped. Added a PlaybackCompatibility enum. This might need to work for more than just video * Complete rewrite to allow multiple profiles, compatibility mode, and directplay. * Hardward -> Hardware * Update CustomDeviceProfileSettingsView.swift Double Licensing * It was actually really easy to implement iOS... Trash cans still look weird and small. * Swipe to Delete instead of the edit button * wip * wip * Linting * tvOS Implementation * wip * wip * cleanup * Create Package.resolved --------- Co-authored-by: Joseph Kribs <joseph@kribs.net> Co-authored-by: Ethan Pippin <ethanpippin2343@gmail.com>
58 lines
1.4 KiB
Swift
58 lines
1.4 KiB
Swift
//
|
|
// Swiftfin is subject to the terms of the Mozilla Public
|
|
// License, v2.0. If a copy of the MPL was not distributed with this
|
|
// file, you can obtain one at https://mozilla.org/MPL/2.0/.
|
|
//
|
|
// Copyright (c) 2024 Jellyfin & Jellyfin Contributors
|
|
//
|
|
|
|
import Foundation
|
|
|
|
extension Array {
|
|
|
|
func appending(_ element: Element) -> [Element] {
|
|
self + [element]
|
|
}
|
|
|
|
func appending(_ element: Element, if condition: Bool) -> [Element] {
|
|
if condition {
|
|
return self + [element]
|
|
} else {
|
|
return self
|
|
}
|
|
}
|
|
|
|
func appending(_ contents: [Element]) -> [Element] {
|
|
self + contents
|
|
}
|
|
|
|
func count(where predicate: (Element) throws -> Bool) rethrows -> Int {
|
|
try filter(predicate).count
|
|
}
|
|
|
|
func prepending(_ element: Element) -> [Element] {
|
|
[element] + self
|
|
}
|
|
|
|
func prepending(_ element: Element, if condition: Bool) -> [Element] {
|
|
if condition {
|
|
return [element] + self
|
|
} else {
|
|
return self
|
|
}
|
|
}
|
|
|
|
// There are instances where `removeFirst()` is called on an empty
|
|
// collection even with a count check and causes a crash
|
|
@discardableResult
|
|
mutating func removeFirstSafe() -> Element? {
|
|
guard count > 0 else { return nil }
|
|
return removeFirst()
|
|
}
|
|
}
|
|
|
|
// extension Array where Element: RawRepresentable<String> {
|
|
//
|
|
// var asCommaString: String {}
|
|
// }
|