MinKey+Codable.swift 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /*
  2. * Copyright 2025 Google LLC
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #if SWIFT_PACKAGE
  17. @_exported import FirebaseFirestoreInternalWrapper
  18. #else
  19. @_exported import FirebaseFirestoreInternal
  20. #endif // SWIFT_PACKAGE
  21. /**
  22. * A protocol describing the encodable properties of a MinKey.
  23. *
  24. * Note: this protocol exists as a workaround for the Swift compiler: if the MinKey class
  25. * was extended directly to conform to Codable, the methods implementing the protocol would be need
  26. * to be marked required but that can't be done in an extension. Declaring the extension on the
  27. * protocol sidesteps this issue.
  28. */
  29. private protocol CodableMinKey: Codable {
  30. init()
  31. }
  32. /** The keys in a MinKey. */
  33. private enum MinKeyKeys: String, CodingKey {
  34. // We'll use a simple CodingKeys enum with a single case
  35. // to represent the presence of the singleton.
  36. case isFirestoreMinKey
  37. }
  38. /**
  39. * An extension of MinKey that implements the behavior of the Codable protocol.
  40. *
  41. * Note: this is implemented manually here because the Swift compiler can't synthesize these methods
  42. * when declaring an extension to conform to Codable.
  43. */
  44. extension CodableMinKey {
  45. public init(from decoder: Decoder) throws {
  46. // The presence of the `isFirestoreMinKey` is enough to know that we
  47. // should return the singleton.
  48. let container = try decoder.container(keyedBy: MinKeyKeys.self)
  49. _ = try container.decodeIfPresent(Bool.self, forKey: .isFirestoreMinKey)
  50. self.init()
  51. }
  52. public func encode(to encoder: Encoder) throws {
  53. var container = encoder.container(keyedBy: MinKeyKeys.self)
  54. // Encode a value of `true` to indicate the presence of MinKey
  55. try container.encode(true, forKey: .isFirestoreMinKey)
  56. }
  57. }
  58. /** Extends RegexValue to conform to Codable. */
  59. extension FirebaseFirestore.MinKey: FirebaseFirestore.CodableMinKey {}