react-native-nitro-fetch 0.1.7 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (154) hide show
  1. package/android/src/main/java/com/margelo/nitro/nitrofetch/AutoPrefetcher.kt +3 -1
  2. package/android/src/main/java/com/margelo/nitro/nitrofetch/CronetExtensions.kt +31 -0
  3. package/android/src/main/java/com/margelo/nitro/nitrofetch/NitroCronet.kt +89 -0
  4. package/android/src/main/java/com/margelo/nitro/nitrofetch/NitroFetchClient.kt +115 -28
  5. package/android/src/main/java/com/margelo/nitro/nitrofetch/NitroUrlRequest.kt +35 -0
  6. package/android/src/main/java/com/margelo/nitro/nitrofetch/NitroUrlRequestBuilder.kt +181 -0
  7. package/ios/HybridNitroCronet.swift +31 -0
  8. package/ios/HybridUrlRequest.swift +41 -0
  9. package/ios/HybridUrlRequestBuilder.swift +255 -0
  10. package/ios/NitroAutoPrefetcher.swift +3 -1
  11. package/ios/NitroFetchClient.swift +87 -5
  12. package/ios/URLSessionExtensions.swift +36 -0
  13. package/lib/module/NitroCronet.nitro.js +4 -0
  14. package/lib/module/NitroCronet.nitro.js.map +1 -0
  15. package/lib/module/NitroInstances.js +1 -0
  16. package/lib/module/NitroInstances.js.map +1 -1
  17. package/lib/module/fetch.js +179 -9
  18. package/lib/module/fetch.js.map +1 -1
  19. package/lib/typescript/src/NitroCronet.nitro.d.ts +53 -0
  20. package/lib/typescript/src/NitroCronet.nitro.d.ts.map +1 -0
  21. package/lib/typescript/src/NitroFetch.nitro.d.ts +10 -0
  22. package/lib/typescript/src/NitroFetch.nitro.d.ts.map +1 -1
  23. package/lib/typescript/src/NitroInstances.d.ts +3 -1
  24. package/lib/typescript/src/NitroInstances.d.ts.map +1 -1
  25. package/lib/typescript/src/fetch.d.ts +5 -2
  26. package/lib/typescript/src/fetch.d.ts.map +1 -1
  27. package/lib/typescript/src/index.d.ts +1 -1
  28. package/lib/typescript/src/index.d.ts.map +1 -1
  29. package/nitro.json +34 -6
  30. package/nitrogen/generated/android/c++/JFunc_void_UrlResponseInfo.hpp +82 -0
  31. package/nitrogen/generated/android/c++/JFunc_void_UrlResponseInfo_std__shared_ptr_ArrayBuffer__double.hpp +84 -0
  32. package/nitrogen/generated/android/c++/JFunc_void_UrlResponseInfo_std__string.hpp +82 -0
  33. package/nitrogen/generated/android/c++/JFunc_void_std__optional_UrlResponseInfo_.hpp +83 -0
  34. package/nitrogen/generated/android/c++/JFunc_void_std__optional_UrlResponseInfo__RequestException.hpp +85 -0
  35. package/nitrogen/generated/android/c++/JHttpHeader.hpp +61 -0
  36. package/nitrogen/generated/android/c++/JHybridNativeStorageSpec.cpp +23 -16
  37. package/nitrogen/generated/android/c++/JHybridNativeStorageSpec.hpp +20 -21
  38. package/nitrogen/generated/android/c++/JHybridNitroCronetSpec.cpp +57 -0
  39. package/nitrogen/generated/android/c++/JHybridNitroCronetSpec.hpp +63 -0
  40. package/nitrogen/generated/android/c++/JHybridNitroFetchClientSpec.cpp +32 -16
  41. package/nitrogen/generated/android/c++/JHybridNitroFetchClientSpec.hpp +21 -21
  42. package/nitrogen/generated/android/c++/JHybridNitroFetchSpec.cpp +22 -15
  43. package/nitrogen/generated/android/c++/JHybridNitroFetchSpec.hpp +20 -21
  44. package/nitrogen/generated/android/c++/JHybridUrlRequestBuilderSpec.cpp +123 -0
  45. package/nitrogen/generated/android/c++/JHybridUrlRequestBuilderSpec.hpp +73 -0
  46. package/nitrogen/generated/android/c++/JHybridUrlRequestSpec.cpp +69 -0
  47. package/nitrogen/generated/android/c++/JHybridUrlRequestSpec.hpp +67 -0
  48. package/nitrogen/generated/android/c++/JNitroFormDataPart.hpp +74 -0
  49. package/nitrogen/generated/android/c++/JNitroHeader.hpp +7 -3
  50. package/nitrogen/generated/android/c++/JNitroRequest.hpp +39 -6
  51. package/nitrogen/generated/android/c++/JNitroRequestMethod.hpp +9 -10
  52. package/nitrogen/generated/android/c++/JNitroResponse.hpp +9 -4
  53. package/nitrogen/generated/android/c++/JRequestException.hpp +57 -0
  54. package/nitrogen/generated/android/c++/JUrlResponseInfo.hpp +146 -0
  55. package/nitrogen/generated/android/c++/JVariant_ArrayBuffer_String.cpp +26 -0
  56. package/nitrogen/generated/android/c++/JVariant_ArrayBuffer_String.hpp +70 -0
  57. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/Func_void_UrlResponseInfo.kt +80 -0
  58. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/Func_void_UrlResponseInfo_std__shared_ptr_ArrayBuffer__double.kt +80 -0
  59. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/Func_void_UrlResponseInfo_std__string.kt +80 -0
  60. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/Func_void_std__optional_UrlResponseInfo_.kt +80 -0
  61. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/Func_void_std__optional_UrlResponseInfo__RequestException.kt +80 -0
  62. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/HttpHeader.kt +41 -0
  63. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/HybridNativeStorageSpec.kt +18 -16
  64. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/HybridNitroCronetSpec.kt +54 -0
  65. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/HybridNitroFetchClientSpec.kt +23 -16
  66. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/HybridNitroFetchSpec.kt +18 -16
  67. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/HybridUrlRequestBuilderSpec.kt +125 -0
  68. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/HybridUrlRequestSpec.kt +70 -0
  69. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/NitroFormDataPart.kt +50 -0
  70. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/NitroHeader.kt +19 -10
  71. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/NitroRequest.kt +40 -25
  72. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/NitroRequestMethod.kt +3 -1
  73. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/NitroResponse.kt +39 -30
  74. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/RequestException.kt +38 -0
  75. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/UrlResponseInfo.kt +65 -0
  76. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/Variant_ArrayBuffer_String.kt +53 -0
  77. package/nitrogen/generated/android/kotlin/com/margelo/nitro/nitrofetch/nitrofetchOnLoad.kt +1 -1
  78. package/nitrogen/generated/android/nitrofetch+autolinking.cmake +8 -1
  79. package/nitrogen/generated/android/nitrofetch+autolinking.gradle +1 -1
  80. package/nitrogen/generated/android/nitrofetchOnLoad.cpp +85 -33
  81. package/nitrogen/generated/android/nitrofetchOnLoad.hpp +14 -5
  82. package/nitrogen/generated/ios/NitroFetch+autolinking.rb +2 -2
  83. package/nitrogen/generated/ios/NitroFetch-Swift-Cxx-Bridge.cpp +102 -10
  84. package/nitrogen/generated/ios/NitroFetch-Swift-Cxx-Bridge.hpp +359 -24
  85. package/nitrogen/generated/ios/NitroFetch-Swift-Cxx-Umbrella.hpp +32 -1
  86. package/nitrogen/generated/ios/NitroFetchAutolinking.mm +9 -1
  87. package/nitrogen/generated/ios/NitroFetchAutolinking.swift +29 -22
  88. package/nitrogen/generated/ios/c++/HybridNativeStorageSpecSwift.cpp +1 -1
  89. package/nitrogen/generated/ios/c++/HybridNativeStorageSpecSwift.hpp +10 -1
  90. package/nitrogen/generated/ios/c++/HybridNitroCronetSpecSwift.cpp +11 -0
  91. package/nitrogen/generated/ios/c++/HybridNitroCronetSpecSwift.hpp +85 -0
  92. package/nitrogen/generated/ios/c++/HybridNitroFetchClientSpecSwift.cpp +1 -1
  93. package/nitrogen/generated/ios/c++/HybridNitroFetchClientSpecSwift.hpp +22 -4
  94. package/nitrogen/generated/ios/c++/HybridNitroFetchSpecSwift.cpp +1 -1
  95. package/nitrogen/generated/ios/c++/HybridNitroFetchSpecSwift.hpp +10 -1
  96. package/nitrogen/generated/ios/c++/HybridUrlRequestBuilderSpecSwift.cpp +11 -0
  97. package/nitrogen/generated/ios/c++/HybridUrlRequestBuilderSpecSwift.hpp +163 -0
  98. package/nitrogen/generated/ios/c++/HybridUrlRequestSpecSwift.cpp +11 -0
  99. package/nitrogen/generated/ios/c++/HybridUrlRequestSpecSwift.hpp +106 -0
  100. package/nitrogen/generated/ios/swift/Func_void.swift +1 -2
  101. package/nitrogen/generated/ios/swift/Func_void_NitroResponse.swift +1 -2
  102. package/nitrogen/generated/ios/swift/Func_void_UrlResponseInfo.swift +46 -0
  103. package/nitrogen/generated/ios/swift/Func_void_UrlResponseInfo_std__shared_ptr_ArrayBuffer__double.swift +46 -0
  104. package/nitrogen/generated/ios/swift/Func_void_UrlResponseInfo_std__string.swift +46 -0
  105. package/nitrogen/generated/ios/swift/Func_void_std__exception_ptr.swift +1 -2
  106. package/nitrogen/generated/ios/swift/Func_void_std__optional_UrlResponseInfo_.swift +46 -0
  107. package/nitrogen/generated/ios/swift/Func_void_std__optional_UrlResponseInfo__RequestException.swift +46 -0
  108. package/nitrogen/generated/ios/swift/HttpHeader.swift +34 -0
  109. package/nitrogen/generated/ios/swift/HybridNativeStorageSpec.swift +10 -4
  110. package/nitrogen/generated/ios/swift/HybridNativeStorageSpec_cxx.swift +18 -3
  111. package/nitrogen/generated/ios/swift/HybridNitroCronetSpec.swift +55 -0
  112. package/nitrogen/generated/ios/swift/HybridNitroCronetSpec_cxx.swift +141 -0
  113. package/nitrogen/generated/ios/swift/HybridNitroFetchClientSpec.swift +11 -4
  114. package/nitrogen/generated/ios/swift/HybridNitroFetchClientSpec_cxx.swift +29 -3
  115. package/nitrogen/generated/ios/swift/HybridNitroFetchSpec.swift +10 -4
  116. package/nitrogen/generated/ios/swift/HybridNitroFetchSpec_cxx.swift +18 -3
  117. package/nitrogen/generated/ios/swift/HybridUrlRequestBuilderSpec.swift +65 -0
  118. package/nitrogen/generated/ios/swift/HybridUrlRequestBuilderSpec_cxx.swift +305 -0
  119. package/nitrogen/generated/ios/swift/HybridUrlRequestSpec.swift +59 -0
  120. package/nitrogen/generated/ios/swift/HybridUrlRequestSpec_cxx.swift +182 -0
  121. package/nitrogen/generated/ios/swift/NitroFormDataPart.swift +101 -0
  122. package/nitrogen/generated/ios/swift/NitroHeader.swift +5 -17
  123. package/nitrogen/generated/ios/swift/NitroRequest.swift +111 -121
  124. package/nitrogen/generated/ios/swift/NitroRequestMethod.swift +1 -1
  125. package/nitrogen/generated/ios/swift/NitroResponse.swift +40 -97
  126. package/nitrogen/generated/ios/swift/RequestException.swift +29 -0
  127. package/nitrogen/generated/ios/swift/UrlResponseInfo.swift +118 -0
  128. package/nitrogen/generated/ios/swift/Variant_ArrayBuffer_String.swift +18 -0
  129. package/nitrogen/generated/shared/c++/HttpHeader.hpp +87 -0
  130. package/nitrogen/generated/shared/c++/HybridNativeStorageSpec.cpp +1 -1
  131. package/nitrogen/generated/shared/c++/HybridNativeStorageSpec.hpp +1 -1
  132. package/nitrogen/generated/shared/c++/HybridNitroCronetSpec.cpp +21 -0
  133. package/nitrogen/generated/shared/c++/HybridNitroCronetSpec.hpp +65 -0
  134. package/nitrogen/generated/shared/c++/HybridNitroFetchClientSpec.cpp +2 -1
  135. package/nitrogen/generated/shared/c++/HybridNitroFetchClientSpec.hpp +3 -1
  136. package/nitrogen/generated/shared/c++/HybridNitroFetchSpec.cpp +1 -1
  137. package/nitrogen/generated/shared/c++/HybridNitroFetchSpec.hpp +1 -1
  138. package/nitrogen/generated/shared/c++/HybridUrlRequestBuilderSpec.cpp +31 -0
  139. package/nitrogen/generated/shared/c++/HybridUrlRequestBuilderSpec.hpp +85 -0
  140. package/nitrogen/generated/shared/c++/HybridUrlRequestSpec.cpp +25 -0
  141. package/nitrogen/generated/shared/c++/HybridUrlRequestSpec.hpp +66 -0
  142. package/nitrogen/generated/shared/c++/NitroFormDataPart.hpp +100 -0
  143. package/nitrogen/generated/shared/c++/NitroHeader.hpp +24 -8
  144. package/nitrogen/generated/shared/c++/NitroRequest.hpp +51 -24
  145. package/nitrogen/generated/shared/c++/NitroRequestMethod.hpp +1 -1
  146. package/nitrogen/generated/shared/c++/NitroResponse.hpp +42 -26
  147. package/nitrogen/generated/shared/c++/RequestException.hpp +83 -0
  148. package/nitrogen/generated/shared/c++/UrlResponseInfo.hpp +123 -0
  149. package/package.json +13 -10
  150. package/src/NitroCronet.nitro.ts +72 -0
  151. package/src/NitroFetch.nitro.ts +28 -6
  152. package/src/NitroInstances.ts +4 -0
  153. package/src/fetch.ts +214 -13
  154. package/src/index.tsx +1 -1
@@ -2,10 +2,9 @@
2
2
  /// HybridNitroFetchSpec.swift
3
3
  /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
4
  /// https://github.com/mrousavy/nitro
5
- /// Copyright © 2026 Marc Rousavy @ Margelo
5
+ /// Copyright © Marc Rousavy @ Margelo
6
6
  ///
7
7
 
8
- import Foundation
9
8
  import NitroModules
10
9
 
11
10
  /// See ``HybridNitroFetchSpec``
@@ -17,20 +16,27 @@ public protocol HybridNitroFetchSpec_protocol: HybridObject {
17
16
  func createClient() throws -> (any HybridNitroFetchClientSpec)
18
17
  }
19
18
 
19
+ public extension HybridNitroFetchSpec_protocol {
20
+ /// Default implementation of ``HybridObject.toString``
21
+ func toString() -> String {
22
+ return "[HybridObject NitroFetch]"
23
+ }
24
+ }
25
+
20
26
  /// See ``HybridNitroFetchSpec``
21
27
  open class HybridNitroFetchSpec_base {
22
28
  private weak var cxxWrapper: HybridNitroFetchSpec_cxx? = nil
23
29
  public init() { }
24
30
  public func getCxxWrapper() -> HybridNitroFetchSpec_cxx {
25
31
  #if DEBUG
26
- guard self is HybridNitroFetchSpec else {
32
+ guard self is any HybridNitroFetchSpec else {
27
33
  fatalError("`self` is not a `HybridNitroFetchSpec`! Did you accidentally inherit from `HybridNitroFetchSpec_base` instead of `HybridNitroFetchSpec`?")
28
34
  }
29
35
  #endif
30
36
  if let cxxWrapper = self.cxxWrapper {
31
37
  return cxxWrapper
32
38
  } else {
33
- let cxxWrapper = HybridNitroFetchSpec_cxx(self as! HybridNitroFetchSpec)
39
+ let cxxWrapper = HybridNitroFetchSpec_cxx(self as! any HybridNitroFetchSpec)
34
40
  self.cxxWrapper = cxxWrapper
35
41
  return cxxWrapper
36
42
  }
@@ -2,10 +2,9 @@
2
2
  /// HybridNitroFetchSpec_cxx.swift
3
3
  /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
4
  /// https://github.com/mrousavy/nitro
5
- /// Copyright © 2026 Marc Rousavy @ Margelo
5
+ /// Copyright © Marc Rousavy @ Margelo
6
6
  ///
7
7
 
8
- import Foundation
9
8
  import NitroModules
10
9
 
11
10
  /**
@@ -76,7 +75,7 @@ open class HybridNitroFetchSpec_cxx {
76
75
  */
77
76
  public func getCxxPart() -> bridge.std__shared_ptr_HybridNitroFetchSpec_ {
78
77
  let cachedCxxPart = self.__cxxPart.lock()
79
- if cachedCxxPart.__convertToBool() {
78
+ if Bool(fromCxx: cachedCxxPart) {
80
79
  return cachedCxxPart
81
80
  } else {
82
81
  let newCxxPart = bridge.create_std__shared_ptr_HybridNitroFetchSpec_(self.toUnsafe())
@@ -96,6 +95,14 @@ open class HybridNitroFetchSpec_cxx {
96
95
  return MemoryHelper.getSizeOf(self.__implementation) + self.__implementation.memorySize
97
96
  }
98
97
 
98
+ /**
99
+ * Compares this object with the given [other] object for reference equality.
100
+ */
101
+ @inline(__always)
102
+ public func equals(other: HybridNitroFetchSpec_cxx) -> Bool {
103
+ return self.__implementation === other.__implementation
104
+ }
105
+
99
106
  /**
100
107
  * Call dispose() on the Swift class.
101
108
  * This _may_ be called manually from JS.
@@ -105,6 +112,14 @@ open class HybridNitroFetchSpec_cxx {
105
112
  self.__implementation.dispose()
106
113
  }
107
114
 
115
+ /**
116
+ * Call toString() on the Swift class.
117
+ */
118
+ @inline(__always)
119
+ public func toString() -> String {
120
+ return self.__implementation.toString()
121
+ }
122
+
108
123
  // Properties
109
124
 
110
125
 
@@ -0,0 +1,65 @@
1
+ ///
2
+ /// HybridUrlRequestBuilderSpec.swift
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ import NitroModules
9
+
10
+ /// See ``HybridUrlRequestBuilderSpec``
11
+ public protocol HybridUrlRequestBuilderSpec_protocol: HybridObject {
12
+ // Properties
13
+
14
+
15
+ // Methods
16
+ func setHttpMethod(httpMethod: String) throws -> Void
17
+ func addHeader(name: String, value: String) throws -> Void
18
+ func setUploadBody(body: Variant_ArrayBuffer_String) throws -> Void
19
+ func disableCache() throws -> Void
20
+ func onSucceeded(callback: @escaping (_ info: UrlResponseInfo) -> Void) throws -> Void
21
+ func onFailed(callback: @escaping (_ info: UrlResponseInfo?, _ error: RequestException) -> Void) throws -> Void
22
+ func onCanceled(callback: @escaping (_ info: UrlResponseInfo?) -> Void) throws -> Void
23
+ func onRedirectReceived(callback: @escaping (_ info: UrlResponseInfo, _ newLocationUrl: String) -> Void) throws -> Void
24
+ func onResponseStarted(callback: @escaping (_ info: UrlResponseInfo) -> Void) throws -> Void
25
+ func onReadCompleted(callback: @escaping (_ info: UrlResponseInfo, _ byteBuffer: ArrayBuffer, _ bytesRead: Double) -> Void) throws -> Void
26
+ func build() throws -> (any HybridUrlRequestSpec)
27
+ }
28
+
29
+ public extension HybridUrlRequestBuilderSpec_protocol {
30
+ /// Default implementation of ``HybridObject.toString``
31
+ func toString() -> String {
32
+ return "[HybridObject UrlRequestBuilder]"
33
+ }
34
+ }
35
+
36
+ /// See ``HybridUrlRequestBuilderSpec``
37
+ open class HybridUrlRequestBuilderSpec_base {
38
+ private weak var cxxWrapper: HybridUrlRequestBuilderSpec_cxx? = nil
39
+ public init() { }
40
+ public func getCxxWrapper() -> HybridUrlRequestBuilderSpec_cxx {
41
+ #if DEBUG
42
+ guard self is any HybridUrlRequestBuilderSpec else {
43
+ fatalError("`self` is not a `HybridUrlRequestBuilderSpec`! Did you accidentally inherit from `HybridUrlRequestBuilderSpec_base` instead of `HybridUrlRequestBuilderSpec`?")
44
+ }
45
+ #endif
46
+ if let cxxWrapper = self.cxxWrapper {
47
+ return cxxWrapper
48
+ } else {
49
+ let cxxWrapper = HybridUrlRequestBuilderSpec_cxx(self as! any HybridUrlRequestBuilderSpec)
50
+ self.cxxWrapper = cxxWrapper
51
+ return cxxWrapper
52
+ }
53
+ }
54
+ }
55
+
56
+ /**
57
+ * A Swift base-protocol representing the UrlRequestBuilder HybridObject.
58
+ * Implement this protocol to create Swift-based instances of UrlRequestBuilder.
59
+ * ```swift
60
+ * class HybridUrlRequestBuilder : HybridUrlRequestBuilderSpec {
61
+ * // ...
62
+ * }
63
+ * ```
64
+ */
65
+ public typealias HybridUrlRequestBuilderSpec = HybridUrlRequestBuilderSpec_protocol & HybridUrlRequestBuilderSpec_base
@@ -0,0 +1,305 @@
1
+ ///
2
+ /// HybridUrlRequestBuilderSpec_cxx.swift
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ import NitroModules
9
+
10
+ /**
11
+ * A class implementation that bridges HybridUrlRequestBuilderSpec over to C++.
12
+ * In C++, we cannot use Swift protocols - so we need to wrap it in a class to make it strongly defined.
13
+ *
14
+ * Also, some Swift types need to be bridged with special handling:
15
+ * - Enums need to be wrapped in Structs, otherwise they cannot be accessed bi-directionally (Swift bug: https://github.com/swiftlang/swift/issues/75330)
16
+ * - Other HybridObjects need to be wrapped/unwrapped from the Swift TCxx wrapper
17
+ * - Throwing methods need to be wrapped with a Result<T, Error> type, as exceptions cannot be propagated to C++
18
+ */
19
+ open class HybridUrlRequestBuilderSpec_cxx {
20
+ /**
21
+ * The Swift <> C++ bridge's namespace (`margelo::nitro::nitrofetch::bridge::swift`)
22
+ * from `NitroFetch-Swift-Cxx-Bridge.hpp`.
23
+ * This contains specialized C++ templates, and C++ helper functions that can be accessed from Swift.
24
+ */
25
+ public typealias bridge = margelo.nitro.nitrofetch.bridge.swift
26
+
27
+ /**
28
+ * Holds an instance of the `HybridUrlRequestBuilderSpec` Swift protocol.
29
+ */
30
+ private var __implementation: any HybridUrlRequestBuilderSpec
31
+
32
+ /**
33
+ * Holds a weak pointer to the C++ class that wraps the Swift class.
34
+ */
35
+ private var __cxxPart: bridge.std__weak_ptr_HybridUrlRequestBuilderSpec_
36
+
37
+ /**
38
+ * Create a new `HybridUrlRequestBuilderSpec_cxx` that wraps the given `HybridUrlRequestBuilderSpec`.
39
+ * All properties and methods bridge to C++ types.
40
+ */
41
+ public init(_ implementation: any HybridUrlRequestBuilderSpec) {
42
+ self.__implementation = implementation
43
+ self.__cxxPart = .init()
44
+ /* no base class */
45
+ }
46
+
47
+ /**
48
+ * Get the actual `HybridUrlRequestBuilderSpec` instance this class wraps.
49
+ */
50
+ @inline(__always)
51
+ public func getHybridUrlRequestBuilderSpec() -> any HybridUrlRequestBuilderSpec {
52
+ return __implementation
53
+ }
54
+
55
+ /**
56
+ * Casts this instance to a retained unsafe raw pointer.
57
+ * This acquires one additional strong reference on the object!
58
+ */
59
+ public func toUnsafe() -> UnsafeMutableRawPointer {
60
+ return Unmanaged.passRetained(self).toOpaque()
61
+ }
62
+
63
+ /**
64
+ * Casts an unsafe pointer to a `HybridUrlRequestBuilderSpec_cxx`.
65
+ * The pointer has to be a retained opaque `Unmanaged<HybridUrlRequestBuilderSpec_cxx>`.
66
+ * This removes one strong reference from the object!
67
+ */
68
+ public class func fromUnsafe(_ pointer: UnsafeMutableRawPointer) -> HybridUrlRequestBuilderSpec_cxx {
69
+ return Unmanaged<HybridUrlRequestBuilderSpec_cxx>.fromOpaque(pointer).takeRetainedValue()
70
+ }
71
+
72
+ /**
73
+ * Gets (or creates) the C++ part of this Hybrid Object.
74
+ * The C++ part is a `std::shared_ptr<HybridUrlRequestBuilderSpec>`.
75
+ */
76
+ public func getCxxPart() -> bridge.std__shared_ptr_HybridUrlRequestBuilderSpec_ {
77
+ let cachedCxxPart = self.__cxxPart.lock()
78
+ if Bool(fromCxx: cachedCxxPart) {
79
+ return cachedCxxPart
80
+ } else {
81
+ let newCxxPart = bridge.create_std__shared_ptr_HybridUrlRequestBuilderSpec_(self.toUnsafe())
82
+ __cxxPart = bridge.weakify_std__shared_ptr_HybridUrlRequestBuilderSpec_(newCxxPart)
83
+ return newCxxPart
84
+ }
85
+ }
86
+
87
+
88
+
89
+ /**
90
+ * Get the memory size of the Swift class (plus size of any other allocations)
91
+ * so the JS VM can properly track it and garbage-collect the JS object if needed.
92
+ */
93
+ @inline(__always)
94
+ public var memorySize: Int {
95
+ return MemoryHelper.getSizeOf(self.__implementation) + self.__implementation.memorySize
96
+ }
97
+
98
+ /**
99
+ * Compares this object with the given [other] object for reference equality.
100
+ */
101
+ @inline(__always)
102
+ public func equals(other: HybridUrlRequestBuilderSpec_cxx) -> Bool {
103
+ return self.__implementation === other.__implementation
104
+ }
105
+
106
+ /**
107
+ * Call dispose() on the Swift class.
108
+ * This _may_ be called manually from JS.
109
+ */
110
+ @inline(__always)
111
+ public func dispose() {
112
+ self.__implementation.dispose()
113
+ }
114
+
115
+ /**
116
+ * Call toString() on the Swift class.
117
+ */
118
+ @inline(__always)
119
+ public func toString() -> String {
120
+ return self.__implementation.toString()
121
+ }
122
+
123
+ // Properties
124
+
125
+
126
+ // Methods
127
+ @inline(__always)
128
+ public final func setHttpMethod(httpMethod: std.string) -> bridge.Result_void_ {
129
+ do {
130
+ try self.__implementation.setHttpMethod(httpMethod: String(httpMethod))
131
+ return bridge.create_Result_void_()
132
+ } catch (let __error) {
133
+ let __exceptionPtr = __error.toCpp()
134
+ return bridge.create_Result_void_(__exceptionPtr)
135
+ }
136
+ }
137
+
138
+ @inline(__always)
139
+ public final func addHeader(name: std.string, value: std.string) -> bridge.Result_void_ {
140
+ do {
141
+ try self.__implementation.addHeader(name: String(name), value: String(value))
142
+ return bridge.create_Result_void_()
143
+ } catch (let __error) {
144
+ let __exceptionPtr = __error.toCpp()
145
+ return bridge.create_Result_void_(__exceptionPtr)
146
+ }
147
+ }
148
+
149
+ @inline(__always)
150
+ public final func setUploadBody(body: bridge.std__variant_std__shared_ptr_ArrayBuffer___std__string_) -> bridge.Result_void_ {
151
+ do {
152
+ try self.__implementation.setUploadBody(body: { () -> Variant_ArrayBuffer_String in
153
+ let __variant = body
154
+ switch __variant.index() {
155
+ case 0:
156
+ let __actual = __variant.get_0()
157
+ return .first(ArrayBuffer(__actual))
158
+ case 1:
159
+ let __actual = __variant.get_1()
160
+ return .second(String(__actual))
161
+ default:
162
+ fatalError("Variant can never have index \(__variant.index())!")
163
+ }
164
+ }())
165
+ return bridge.create_Result_void_()
166
+ } catch (let __error) {
167
+ let __exceptionPtr = __error.toCpp()
168
+ return bridge.create_Result_void_(__exceptionPtr)
169
+ }
170
+ }
171
+
172
+ @inline(__always)
173
+ public final func disableCache() -> bridge.Result_void_ {
174
+ do {
175
+ try self.__implementation.disableCache()
176
+ return bridge.create_Result_void_()
177
+ } catch (let __error) {
178
+ let __exceptionPtr = __error.toCpp()
179
+ return bridge.create_Result_void_(__exceptionPtr)
180
+ }
181
+ }
182
+
183
+ @inline(__always)
184
+ public final func onSucceeded(callback: bridge.Func_void_UrlResponseInfo) -> bridge.Result_void_ {
185
+ do {
186
+ try self.__implementation.onSucceeded(callback: { () -> (UrlResponseInfo) -> Void in
187
+ let __wrappedFunction = bridge.wrap_Func_void_UrlResponseInfo(callback)
188
+ return { (__info: UrlResponseInfo) -> Void in
189
+ __wrappedFunction.call(__info)
190
+ }
191
+ }())
192
+ return bridge.create_Result_void_()
193
+ } catch (let __error) {
194
+ let __exceptionPtr = __error.toCpp()
195
+ return bridge.create_Result_void_(__exceptionPtr)
196
+ }
197
+ }
198
+
199
+ @inline(__always)
200
+ public final func onFailed(callback: bridge.Func_void_std__optional_UrlResponseInfo__RequestException) -> bridge.Result_void_ {
201
+ do {
202
+ try self.__implementation.onFailed(callback: { () -> (UrlResponseInfo?, RequestException) -> Void in
203
+ let __wrappedFunction = bridge.wrap_Func_void_std__optional_UrlResponseInfo__RequestException(callback)
204
+ return { (__info: UrlResponseInfo?, __error: RequestException) -> Void in
205
+ __wrappedFunction.call({ () -> bridge.std__optional_UrlResponseInfo_ in
206
+ if let __unwrappedValue = __info {
207
+ return bridge.create_std__optional_UrlResponseInfo_(__unwrappedValue)
208
+ } else {
209
+ return .init()
210
+ }
211
+ }(), __error)
212
+ }
213
+ }())
214
+ return bridge.create_Result_void_()
215
+ } catch (let __error) {
216
+ let __exceptionPtr = __error.toCpp()
217
+ return bridge.create_Result_void_(__exceptionPtr)
218
+ }
219
+ }
220
+
221
+ @inline(__always)
222
+ public final func onCanceled(callback: bridge.Func_void_std__optional_UrlResponseInfo_) -> bridge.Result_void_ {
223
+ do {
224
+ try self.__implementation.onCanceled(callback: { () -> (UrlResponseInfo?) -> Void in
225
+ let __wrappedFunction = bridge.wrap_Func_void_std__optional_UrlResponseInfo_(callback)
226
+ return { (__info: UrlResponseInfo?) -> Void in
227
+ __wrappedFunction.call({ () -> bridge.std__optional_UrlResponseInfo_ in
228
+ if let __unwrappedValue = __info {
229
+ return bridge.create_std__optional_UrlResponseInfo_(__unwrappedValue)
230
+ } else {
231
+ return .init()
232
+ }
233
+ }())
234
+ }
235
+ }())
236
+ return bridge.create_Result_void_()
237
+ } catch (let __error) {
238
+ let __exceptionPtr = __error.toCpp()
239
+ return bridge.create_Result_void_(__exceptionPtr)
240
+ }
241
+ }
242
+
243
+ @inline(__always)
244
+ public final func onRedirectReceived(callback: bridge.Func_void_UrlResponseInfo_std__string) -> bridge.Result_void_ {
245
+ do {
246
+ try self.__implementation.onRedirectReceived(callback: { () -> (UrlResponseInfo, String) -> Void in
247
+ let __wrappedFunction = bridge.wrap_Func_void_UrlResponseInfo_std__string(callback)
248
+ return { (__info: UrlResponseInfo, __newLocationUrl: String) -> Void in
249
+ __wrappedFunction.call(__info, std.string(__newLocationUrl))
250
+ }
251
+ }())
252
+ return bridge.create_Result_void_()
253
+ } catch (let __error) {
254
+ let __exceptionPtr = __error.toCpp()
255
+ return bridge.create_Result_void_(__exceptionPtr)
256
+ }
257
+ }
258
+
259
+ @inline(__always)
260
+ public final func onResponseStarted(callback: bridge.Func_void_UrlResponseInfo) -> bridge.Result_void_ {
261
+ do {
262
+ try self.__implementation.onResponseStarted(callback: { () -> (UrlResponseInfo) -> Void in
263
+ let __wrappedFunction = bridge.wrap_Func_void_UrlResponseInfo(callback)
264
+ return { (__info: UrlResponseInfo) -> Void in
265
+ __wrappedFunction.call(__info)
266
+ }
267
+ }())
268
+ return bridge.create_Result_void_()
269
+ } catch (let __error) {
270
+ let __exceptionPtr = __error.toCpp()
271
+ return bridge.create_Result_void_(__exceptionPtr)
272
+ }
273
+ }
274
+
275
+ @inline(__always)
276
+ public final func onReadCompleted(callback: bridge.Func_void_UrlResponseInfo_std__shared_ptr_ArrayBuffer__double) -> bridge.Result_void_ {
277
+ do {
278
+ try self.__implementation.onReadCompleted(callback: { () -> (UrlResponseInfo, ArrayBuffer, Double) -> Void in
279
+ let __wrappedFunction = bridge.wrap_Func_void_UrlResponseInfo_std__shared_ptr_ArrayBuffer__double(callback)
280
+ return { (__info: UrlResponseInfo, __byteBuffer: ArrayBuffer, __bytesRead: Double) -> Void in
281
+ __wrappedFunction.call(__info, __byteBuffer, __bytesRead)
282
+ }
283
+ }())
284
+ return bridge.create_Result_void_()
285
+ } catch (let __error) {
286
+ let __exceptionPtr = __error.toCpp()
287
+ return bridge.create_Result_void_(__exceptionPtr)
288
+ }
289
+ }
290
+
291
+ @inline(__always)
292
+ public final func build() -> bridge.Result_std__shared_ptr_HybridUrlRequestSpec__ {
293
+ do {
294
+ let __result = try self.__implementation.build()
295
+ let __resultCpp = { () -> bridge.std__shared_ptr_HybridUrlRequestSpec_ in
296
+ let __cxxWrapped = __result.getCxxWrapper()
297
+ return __cxxWrapped.getCxxPart()
298
+ }()
299
+ return bridge.create_Result_std__shared_ptr_HybridUrlRequestSpec__(__resultCpp)
300
+ } catch (let __error) {
301
+ let __exceptionPtr = __error.toCpp()
302
+ return bridge.create_Result_std__shared_ptr_HybridUrlRequestSpec__(__exceptionPtr)
303
+ }
304
+ }
305
+ }
@@ -0,0 +1,59 @@
1
+ ///
2
+ /// HybridUrlRequestSpec.swift
3
+ /// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
4
+ /// https://github.com/mrousavy/nitro
5
+ /// Copyright © Marc Rousavy @ Margelo
6
+ ///
7
+
8
+ import NitroModules
9
+
10
+ /// See ``HybridUrlRequestSpec``
11
+ public protocol HybridUrlRequestSpec_protocol: HybridObject {
12
+ // Properties
13
+
14
+
15
+ // Methods
16
+ func start() throws -> Void
17
+ func followRedirect() throws -> Void
18
+ func read() throws -> Void
19
+ func cancel() throws -> Void
20
+ func isDone() throws -> Bool
21
+ }
22
+
23
+ public extension HybridUrlRequestSpec_protocol {
24
+ /// Default implementation of ``HybridObject.toString``
25
+ func toString() -> String {
26
+ return "[HybridObject UrlRequest]"
27
+ }
28
+ }
29
+
30
+ /// See ``HybridUrlRequestSpec``
31
+ open class HybridUrlRequestSpec_base {
32
+ private weak var cxxWrapper: HybridUrlRequestSpec_cxx? = nil
33
+ public init() { }
34
+ public func getCxxWrapper() -> HybridUrlRequestSpec_cxx {
35
+ #if DEBUG
36
+ guard self is any HybridUrlRequestSpec else {
37
+ fatalError("`self` is not a `HybridUrlRequestSpec`! Did you accidentally inherit from `HybridUrlRequestSpec_base` instead of `HybridUrlRequestSpec`?")
38
+ }
39
+ #endif
40
+ if let cxxWrapper = self.cxxWrapper {
41
+ return cxxWrapper
42
+ } else {
43
+ let cxxWrapper = HybridUrlRequestSpec_cxx(self as! any HybridUrlRequestSpec)
44
+ self.cxxWrapper = cxxWrapper
45
+ return cxxWrapper
46
+ }
47
+ }
48
+ }
49
+
50
+ /**
51
+ * A Swift base-protocol representing the UrlRequest HybridObject.
52
+ * Implement this protocol to create Swift-based instances of UrlRequest.
53
+ * ```swift
54
+ * class HybridUrlRequest : HybridUrlRequestSpec {
55
+ * // ...
56
+ * }
57
+ * ```
58
+ */
59
+ public typealias HybridUrlRequestSpec = HybridUrlRequestSpec_protocol & HybridUrlRequestSpec_base