react-native-nitro-net 0.1.5
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.
- package/README.md +133 -0
- package/android/CMakeLists.txt +29 -0
- package/android/OnLoad.cpp +6 -0
- package/android/build.gradle +72 -0
- package/android/gradle.properties +6 -0
- package/android/libs/arm64-v8a/librust_c_net.so +0 -0
- package/android/libs/armeabi-v7a/librust_c_net.so +0 -0
- package/android/libs/x86/librust_c_net.so +0 -0
- package/android/libs/x86_64/librust_c_net.so +0 -0
- package/android/src/main/AndroidManifest.xml +3 -0
- package/android/src/main/java/com/margelo/nitro/net/NitroNetPackage.java +32 -0
- package/cpp/HybridNetDriver.cpp +5 -0
- package/cpp/HybridNetDriver.hpp +42 -0
- package/cpp/HybridNetServerDriver.cpp +5 -0
- package/cpp/HybridNetServerDriver.hpp +114 -0
- package/cpp/HybridNetSocketDriver.cpp +6 -0
- package/cpp/HybridNetSocketDriver.hpp +132 -0
- package/cpp/NetBindings.hpp +68 -0
- package/cpp/NetManager.hpp +160 -0
- package/ios/Frameworks/RustCNet.xcframework/Info.plist +44 -0
- package/ios/Frameworks/RustCNet.xcframework/ios-arm64/RustCNet.framework/Info.plist +20 -0
- package/ios/Frameworks/RustCNet.xcframework/ios-arm64/RustCNet.framework/RustCNet +0 -0
- package/ios/Frameworks/RustCNet.xcframework/ios-arm64_x86_64-simulator/RustCNet.framework/Info.plist +20 -0
- package/ios/Frameworks/RustCNet.xcframework/ios-arm64_x86_64-simulator/RustCNet.framework/RustCNet +0 -0
- package/lib/Driver.d.ts +2 -0
- package/lib/Driver.js +5 -0
- package/lib/Net.nitro.d.ts +85 -0
- package/lib/Net.nitro.js +21 -0
- package/lib/index.d.ts +162 -0
- package/lib/index.js +781 -0
- package/nitrogen/generated/.gitattributes +1 -0
- package/nitrogen/generated/android/RustCNet+autolinking.cmake +86 -0
- package/nitrogen/generated/android/RustCNet+autolinking.gradle +27 -0
- package/nitrogen/generated/android/RustCNetOnLoad.cpp +51 -0
- package/nitrogen/generated/android/RustCNetOnLoad.hpp +25 -0
- package/nitrogen/generated/android/c++/JFunc_void_double_std__shared_ptr_ArrayBuffer_.hpp +77 -0
- package/nitrogen/generated/android/c++/JHybridNetDriverSpec.cpp +74 -0
- package/nitrogen/generated/android/c++/JHybridNetDriverSpec.hpp +67 -0
- package/nitrogen/generated/android/c++/JHybridNetServerDriverSpec.cpp +99 -0
- package/nitrogen/generated/android/c++/JHybridNetServerDriverSpec.hpp +72 -0
- package/nitrogen/generated/android/c++/JHybridNetSocketDriverSpec.cpp +127 -0
- package/nitrogen/generated/android/c++/JHybridNetSocketDriverSpec.hpp +79 -0
- package/nitrogen/generated/android/c++/JNetConfig.hpp +57 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/Func_void_double_std__shared_ptr_ArrayBuffer_.kt +80 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/HybridNetDriverSpec.kt +65 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/HybridNetServerDriverSpec.kt +92 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/HybridNetSocketDriverSpec.kt +122 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/NetConfig.kt +38 -0
- package/nitrogen/generated/android/kotlin/com/margelo/nitro/net/RustCNetOnLoad.kt +35 -0
- package/nitrogen/generated/ios/RustCNet+autolinking.rb +60 -0
- package/nitrogen/generated/ios/RustCNet-Swift-Cxx-Bridge.cpp +75 -0
- package/nitrogen/generated/ios/RustCNet-Swift-Cxx-Bridge.hpp +186 -0
- package/nitrogen/generated/ios/RustCNet-Swift-Cxx-Umbrella.hpp +60 -0
- package/nitrogen/generated/ios/RustCNetAutolinking.mm +35 -0
- package/nitrogen/generated/ios/RustCNetAutolinking.swift +12 -0
- package/nitrogen/generated/ios/c++/HybridNetDriverSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridNetDriverSpecSwift.hpp +100 -0
- package/nitrogen/generated/ios/c++/HybridNetServerDriverSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridNetServerDriverSpecSwift.hpp +117 -0
- package/nitrogen/generated/ios/c++/HybridNetSocketDriverSpecSwift.cpp +11 -0
- package/nitrogen/generated/ios/c++/HybridNetSocketDriverSpecSwift.hpp +163 -0
- package/nitrogen/generated/ios/swift/Func_void_double_std__shared_ptr_ArrayBuffer_.swift +47 -0
- package/nitrogen/generated/ios/swift/HybridNetDriverSpec.swift +58 -0
- package/nitrogen/generated/ios/swift/HybridNetDriverSpec_cxx.swift +167 -0
- package/nitrogen/generated/ios/swift/HybridNetServerDriverSpec.swift +61 -0
- package/nitrogen/generated/ios/swift/HybridNetServerDriverSpec_cxx.swift +217 -0
- package/nitrogen/generated/ios/swift/HybridNetSocketDriverSpec.swift +69 -0
- package/nitrogen/generated/ios/swift/HybridNetSocketDriverSpec_cxx.swift +288 -0
- package/nitrogen/generated/ios/swift/NetConfig.swift +36 -0
- package/nitrogen/generated/shared/c++/HybridNetDriverSpec.cpp +23 -0
- package/nitrogen/generated/shared/c++/HybridNetDriverSpec.hpp +74 -0
- package/nitrogen/generated/shared/c++/HybridNetServerDriverSpec.cpp +29 -0
- package/nitrogen/generated/shared/c++/HybridNetServerDriverSpec.hpp +72 -0
- package/nitrogen/generated/shared/c++/HybridNetSocketDriverSpec.cpp +36 -0
- package/nitrogen/generated/shared/c++/HybridNetSocketDriverSpec.hpp +78 -0
- package/nitrogen/generated/shared/c++/HybridNitroBufferSpec.cpp +32 -0
- package/nitrogen/generated/shared/c++/HybridNitroBufferSpec.hpp +74 -0
- package/nitrogen/generated/shared/c++/NetConfig.hpp +83 -0
- package/package.json +59 -0
- package/react-native-nitro-net.podspec +47 -0
- package/src/Driver.ts +4 -0
- package/src/Net.nitro.ts +85 -0
- package/src/index.ts +870 -0
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
#
|
|
2
|
+
# RustCNet+autolinking.rb
|
|
3
|
+
# This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
# https://github.com/mrousavy/nitro
|
|
5
|
+
# Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
#
|
|
7
|
+
|
|
8
|
+
# This is a Ruby script that adds all files generated by Nitrogen
|
|
9
|
+
# to the given podspec.
|
|
10
|
+
#
|
|
11
|
+
# To use it, add this to your .podspec:
|
|
12
|
+
# ```ruby
|
|
13
|
+
# Pod::Spec.new do |spec|
|
|
14
|
+
# # ...
|
|
15
|
+
#
|
|
16
|
+
# # Add all files generated by Nitrogen
|
|
17
|
+
# load 'nitrogen/generated/ios/RustCNet+autolinking.rb'
|
|
18
|
+
# add_nitrogen_files(spec)
|
|
19
|
+
# end
|
|
20
|
+
# ```
|
|
21
|
+
|
|
22
|
+
def add_nitrogen_files(spec)
|
|
23
|
+
Pod::UI.puts "[NitroModules] 🔥 RustCNet is boosted by nitro!"
|
|
24
|
+
|
|
25
|
+
spec.dependency "NitroModules"
|
|
26
|
+
|
|
27
|
+
current_source_files = Array(spec.attributes_hash['source_files'])
|
|
28
|
+
spec.source_files = current_source_files + [
|
|
29
|
+
# Generated cross-platform specs
|
|
30
|
+
"nitrogen/generated/shared/**/*.{h,hpp,c,cpp,swift}",
|
|
31
|
+
# Generated bridges for the cross-platform specs
|
|
32
|
+
"nitrogen/generated/ios/**/*.{h,hpp,c,cpp,mm,swift}",
|
|
33
|
+
]
|
|
34
|
+
|
|
35
|
+
current_public_header_files = Array(spec.attributes_hash['public_header_files'])
|
|
36
|
+
spec.public_header_files = current_public_header_files + [
|
|
37
|
+
# Generated specs
|
|
38
|
+
"nitrogen/generated/shared/**/*.{h,hpp}",
|
|
39
|
+
# Swift to C++ bridging helpers
|
|
40
|
+
"nitrogen/generated/ios/RustCNet-Swift-Cxx-Bridge.hpp"
|
|
41
|
+
]
|
|
42
|
+
|
|
43
|
+
current_private_header_files = Array(spec.attributes_hash['private_header_files'])
|
|
44
|
+
spec.private_header_files = current_private_header_files + [
|
|
45
|
+
# iOS specific specs
|
|
46
|
+
"nitrogen/generated/ios/c++/**/*.{h,hpp}",
|
|
47
|
+
# Views are framework-specific and should be private
|
|
48
|
+
"nitrogen/generated/shared/**/views/**/*"
|
|
49
|
+
]
|
|
50
|
+
|
|
51
|
+
current_pod_target_xcconfig = spec.attributes_hash['pod_target_xcconfig'] || {}
|
|
52
|
+
spec.pod_target_xcconfig = current_pod_target_xcconfig.merge({
|
|
53
|
+
# Use C++ 20
|
|
54
|
+
"CLANG_CXX_LANGUAGE_STANDARD" => "c++20",
|
|
55
|
+
# Enables C++ <-> Swift interop (by default it's only ObjC)
|
|
56
|
+
"SWIFT_OBJC_INTEROP_MODE" => "objcxx",
|
|
57
|
+
# Enables stricter modular headers
|
|
58
|
+
"DEFINES_MODULE" => "YES",
|
|
59
|
+
})
|
|
60
|
+
end
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// RustCNet-Swift-Cxx-Bridge.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include "RustCNet-Swift-Cxx-Bridge.hpp"
|
|
9
|
+
|
|
10
|
+
// Include C++ implementation defined types
|
|
11
|
+
#include "HybridNetDriverSpecSwift.hpp"
|
|
12
|
+
#include "HybridNetServerDriverSpecSwift.hpp"
|
|
13
|
+
#include "HybridNetSocketDriverSpecSwift.hpp"
|
|
14
|
+
#include "RustCNet-Swift-Cxx-Umbrella.hpp"
|
|
15
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
16
|
+
|
|
17
|
+
namespace margelo::nitro::net::bridge::swift {
|
|
18
|
+
|
|
19
|
+
// pragma MARK: std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)>
|
|
20
|
+
Func_void_double_std__shared_ptr_ArrayBuffer_ create_Func_void_double_std__shared_ptr_ArrayBuffer_(void* NON_NULL swiftClosureWrapper) noexcept {
|
|
21
|
+
auto swiftClosure = RustCNet::Func_void_double_std__shared_ptr_ArrayBuffer_::fromUnsafe(swiftClosureWrapper);
|
|
22
|
+
return [swiftClosure = std::move(swiftClosure)](double event, const std::shared_ptr<ArrayBuffer>& data) mutable -> void {
|
|
23
|
+
swiftClosure.call(event, ArrayBufferHolder(data));
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
// pragma MARK: std::shared_ptr<HybridNetSocketDriverSpec>
|
|
28
|
+
std::shared_ptr<HybridNetSocketDriverSpec> create_std__shared_ptr_HybridNetSocketDriverSpec_(void* NON_NULL swiftUnsafePointer) noexcept {
|
|
29
|
+
RustCNet::HybridNetSocketDriverSpec_cxx swiftPart = RustCNet::HybridNetSocketDriverSpec_cxx::fromUnsafe(swiftUnsafePointer);
|
|
30
|
+
return std::make_shared<margelo::nitro::net::HybridNetSocketDriverSpecSwift>(swiftPart);
|
|
31
|
+
}
|
|
32
|
+
void* NON_NULL get_std__shared_ptr_HybridNetSocketDriverSpec_(std__shared_ptr_HybridNetSocketDriverSpec_ cppType) {
|
|
33
|
+
std::shared_ptr<margelo::nitro::net::HybridNetSocketDriverSpecSwift> swiftWrapper = std::dynamic_pointer_cast<margelo::nitro::net::HybridNetSocketDriverSpecSwift>(cppType);
|
|
34
|
+
#ifdef NITRO_DEBUG
|
|
35
|
+
if (swiftWrapper == nullptr) [[unlikely]] {
|
|
36
|
+
throw std::runtime_error("Class \"HybridNetSocketDriverSpec\" is not implemented in Swift!");
|
|
37
|
+
}
|
|
38
|
+
#endif
|
|
39
|
+
RustCNet::HybridNetSocketDriverSpec_cxx& swiftPart = swiftWrapper->getSwiftPart();
|
|
40
|
+
return swiftPart.toUnsafe();
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
// pragma MARK: std::shared_ptr<HybridNetServerDriverSpec>
|
|
44
|
+
std::shared_ptr<HybridNetServerDriverSpec> create_std__shared_ptr_HybridNetServerDriverSpec_(void* NON_NULL swiftUnsafePointer) noexcept {
|
|
45
|
+
RustCNet::HybridNetServerDriverSpec_cxx swiftPart = RustCNet::HybridNetServerDriverSpec_cxx::fromUnsafe(swiftUnsafePointer);
|
|
46
|
+
return std::make_shared<margelo::nitro::net::HybridNetServerDriverSpecSwift>(swiftPart);
|
|
47
|
+
}
|
|
48
|
+
void* NON_NULL get_std__shared_ptr_HybridNetServerDriverSpec_(std__shared_ptr_HybridNetServerDriverSpec_ cppType) {
|
|
49
|
+
std::shared_ptr<margelo::nitro::net::HybridNetServerDriverSpecSwift> swiftWrapper = std::dynamic_pointer_cast<margelo::nitro::net::HybridNetServerDriverSpecSwift>(cppType);
|
|
50
|
+
#ifdef NITRO_DEBUG
|
|
51
|
+
if (swiftWrapper == nullptr) [[unlikely]] {
|
|
52
|
+
throw std::runtime_error("Class \"HybridNetServerDriverSpec\" is not implemented in Swift!");
|
|
53
|
+
}
|
|
54
|
+
#endif
|
|
55
|
+
RustCNet::HybridNetServerDriverSpec_cxx& swiftPart = swiftWrapper->getSwiftPart();
|
|
56
|
+
return swiftPart.toUnsafe();
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
// pragma MARK: std::shared_ptr<HybridNetDriverSpec>
|
|
60
|
+
std::shared_ptr<HybridNetDriverSpec> create_std__shared_ptr_HybridNetDriverSpec_(void* NON_NULL swiftUnsafePointer) noexcept {
|
|
61
|
+
RustCNet::HybridNetDriverSpec_cxx swiftPart = RustCNet::HybridNetDriverSpec_cxx::fromUnsafe(swiftUnsafePointer);
|
|
62
|
+
return std::make_shared<margelo::nitro::net::HybridNetDriverSpecSwift>(swiftPart);
|
|
63
|
+
}
|
|
64
|
+
void* NON_NULL get_std__shared_ptr_HybridNetDriverSpec_(std__shared_ptr_HybridNetDriverSpec_ cppType) {
|
|
65
|
+
std::shared_ptr<margelo::nitro::net::HybridNetDriverSpecSwift> swiftWrapper = std::dynamic_pointer_cast<margelo::nitro::net::HybridNetDriverSpecSwift>(cppType);
|
|
66
|
+
#ifdef NITRO_DEBUG
|
|
67
|
+
if (swiftWrapper == nullptr) [[unlikely]] {
|
|
68
|
+
throw std::runtime_error("Class \"HybridNetDriverSpec\" is not implemented in Swift!");
|
|
69
|
+
}
|
|
70
|
+
#endif
|
|
71
|
+
RustCNet::HybridNetDriverSpec_cxx& swiftPart = swiftWrapper->getSwiftPart();
|
|
72
|
+
return swiftPart.toUnsafe();
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
} // namespace margelo::nitro::net::bridge::swift
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// RustCNet-Swift-Cxx-Bridge.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
// Forward declarations of C++ defined types
|
|
11
|
+
// Forward declaration of `ArrayBufferHolder` to properly resolve imports.
|
|
12
|
+
namespace NitroModules { class ArrayBufferHolder; }
|
|
13
|
+
// Forward declaration of `HybridNetDriverSpec` to properly resolve imports.
|
|
14
|
+
namespace margelo::nitro::net { class HybridNetDriverSpec; }
|
|
15
|
+
// Forward declaration of `HybridNetServerDriverSpec` to properly resolve imports.
|
|
16
|
+
namespace margelo::nitro::net { class HybridNetServerDriverSpec; }
|
|
17
|
+
// Forward declaration of `HybridNetSocketDriverSpec` to properly resolve imports.
|
|
18
|
+
namespace margelo::nitro::net { class HybridNetSocketDriverSpec; }
|
|
19
|
+
|
|
20
|
+
// Forward declarations of Swift defined types
|
|
21
|
+
// Forward declaration of `HybridNetDriverSpec_cxx` to properly resolve imports.
|
|
22
|
+
namespace RustCNet { class HybridNetDriverSpec_cxx; }
|
|
23
|
+
// Forward declaration of `HybridNetServerDriverSpec_cxx` to properly resolve imports.
|
|
24
|
+
namespace RustCNet { class HybridNetServerDriverSpec_cxx; }
|
|
25
|
+
// Forward declaration of `HybridNetSocketDriverSpec_cxx` to properly resolve imports.
|
|
26
|
+
namespace RustCNet { class HybridNetSocketDriverSpec_cxx; }
|
|
27
|
+
|
|
28
|
+
// Include C++ defined types
|
|
29
|
+
#include "HybridNetDriverSpec.hpp"
|
|
30
|
+
#include "HybridNetServerDriverSpec.hpp"
|
|
31
|
+
#include "HybridNetSocketDriverSpec.hpp"
|
|
32
|
+
#include <NitroModules/ArrayBuffer.hpp>
|
|
33
|
+
#include <NitroModules/ArrayBufferHolder.hpp>
|
|
34
|
+
#include <NitroModules/Result.hpp>
|
|
35
|
+
#include <exception>
|
|
36
|
+
#include <functional>
|
|
37
|
+
#include <memory>
|
|
38
|
+
#include <optional>
|
|
39
|
+
#include <string>
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Contains specialized versions of C++ templated types so they can be accessed from Swift,
|
|
43
|
+
* as well as helper functions to interact with those C++ types from Swift.
|
|
44
|
+
*/
|
|
45
|
+
namespace margelo::nitro::net::bridge::swift {
|
|
46
|
+
|
|
47
|
+
// pragma MARK: std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)>
|
|
48
|
+
/**
|
|
49
|
+
* Specialized version of `std::function<void(double, const std::shared_ptr<ArrayBuffer>&)>`.
|
|
50
|
+
*/
|
|
51
|
+
using Func_void_double_std__shared_ptr_ArrayBuffer_ = std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)>;
|
|
52
|
+
/**
|
|
53
|
+
* Wrapper class for a `std::function<void(double / * event * /, const std::shared_ptr<ArrayBuffer>& / * data * /)>`, this can be used from Swift.
|
|
54
|
+
*/
|
|
55
|
+
class Func_void_double_std__shared_ptr_ArrayBuffer__Wrapper final {
|
|
56
|
+
public:
|
|
57
|
+
explicit Func_void_double_std__shared_ptr_ArrayBuffer__Wrapper(std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)>&& func): _function(std::make_unique<std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)>>(std::move(func))) {}
|
|
58
|
+
inline void call(double event, ArrayBufferHolder data) const noexcept {
|
|
59
|
+
_function->operator()(event, data.getArrayBuffer());
|
|
60
|
+
}
|
|
61
|
+
private:
|
|
62
|
+
std::unique_ptr<std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)>> _function;
|
|
63
|
+
} SWIFT_NONCOPYABLE;
|
|
64
|
+
Func_void_double_std__shared_ptr_ArrayBuffer_ create_Func_void_double_std__shared_ptr_ArrayBuffer_(void* NON_NULL swiftClosureWrapper) noexcept;
|
|
65
|
+
inline Func_void_double_std__shared_ptr_ArrayBuffer__Wrapper wrap_Func_void_double_std__shared_ptr_ArrayBuffer_(Func_void_double_std__shared_ptr_ArrayBuffer_ value) noexcept {
|
|
66
|
+
return Func_void_double_std__shared_ptr_ArrayBuffer__Wrapper(std::move(value));
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
// pragma MARK: std::shared_ptr<HybridNetSocketDriverSpec>
|
|
70
|
+
/**
|
|
71
|
+
* Specialized version of `std::shared_ptr<HybridNetSocketDriverSpec>`.
|
|
72
|
+
*/
|
|
73
|
+
using std__shared_ptr_HybridNetSocketDriverSpec_ = std::shared_ptr<HybridNetSocketDriverSpec>;
|
|
74
|
+
std::shared_ptr<HybridNetSocketDriverSpec> create_std__shared_ptr_HybridNetSocketDriverSpec_(void* NON_NULL swiftUnsafePointer) noexcept;
|
|
75
|
+
void* NON_NULL get_std__shared_ptr_HybridNetSocketDriverSpec_(std__shared_ptr_HybridNetSocketDriverSpec_ cppType);
|
|
76
|
+
|
|
77
|
+
// pragma MARK: std::weak_ptr<HybridNetSocketDriverSpec>
|
|
78
|
+
using std__weak_ptr_HybridNetSocketDriverSpec_ = std::weak_ptr<HybridNetSocketDriverSpec>;
|
|
79
|
+
inline std__weak_ptr_HybridNetSocketDriverSpec_ weakify_std__shared_ptr_HybridNetSocketDriverSpec_(const std::shared_ptr<HybridNetSocketDriverSpec>& strong) noexcept { return strong; }
|
|
80
|
+
|
|
81
|
+
// pragma MARK: Result<void>
|
|
82
|
+
using Result_void_ = Result<void>;
|
|
83
|
+
inline Result_void_ create_Result_void_() noexcept {
|
|
84
|
+
return Result<void>::withValue();
|
|
85
|
+
}
|
|
86
|
+
inline Result_void_ create_Result_void_(const std::exception_ptr& error) noexcept {
|
|
87
|
+
return Result<void>::withError(error);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
// pragma MARK: Result<std::string>
|
|
91
|
+
using Result_std__string_ = Result<std::string>;
|
|
92
|
+
inline Result_std__string_ create_Result_std__string_(const std::string& value) noexcept {
|
|
93
|
+
return Result<std::string>::withValue(value);
|
|
94
|
+
}
|
|
95
|
+
inline Result_std__string_ create_Result_std__string_(const std::exception_ptr& error) noexcept {
|
|
96
|
+
return Result<std::string>::withError(error);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
// pragma MARK: std::optional<double>
|
|
100
|
+
/**
|
|
101
|
+
* Specialized version of `std::optional<double>`.
|
|
102
|
+
*/
|
|
103
|
+
using std__optional_double_ = std::optional<double>;
|
|
104
|
+
inline std::optional<double> create_std__optional_double_(const double& value) noexcept {
|
|
105
|
+
return std::optional<double>(value);
|
|
106
|
+
}
|
|
107
|
+
inline bool has_value_std__optional_double_(const std::optional<double>& optional) noexcept {
|
|
108
|
+
return optional.has_value();
|
|
109
|
+
}
|
|
110
|
+
inline double get_std__optional_double_(const std::optional<double>& optional) noexcept {
|
|
111
|
+
return *optional;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
// pragma MARK: std::optional<bool>
|
|
115
|
+
/**
|
|
116
|
+
* Specialized version of `std::optional<bool>`.
|
|
117
|
+
*/
|
|
118
|
+
using std__optional_bool_ = std::optional<bool>;
|
|
119
|
+
inline std::optional<bool> create_std__optional_bool_(const bool& value) noexcept {
|
|
120
|
+
return std::optional<bool>(value);
|
|
121
|
+
}
|
|
122
|
+
inline bool has_value_std__optional_bool_(const std::optional<bool>& optional) noexcept {
|
|
123
|
+
return optional.has_value();
|
|
124
|
+
}
|
|
125
|
+
inline bool get_std__optional_bool_(const std::optional<bool>& optional) noexcept {
|
|
126
|
+
return *optional;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
// pragma MARK: std::shared_ptr<HybridNetServerDriverSpec>
|
|
130
|
+
/**
|
|
131
|
+
* Specialized version of `std::shared_ptr<HybridNetServerDriverSpec>`.
|
|
132
|
+
*/
|
|
133
|
+
using std__shared_ptr_HybridNetServerDriverSpec_ = std::shared_ptr<HybridNetServerDriverSpec>;
|
|
134
|
+
std::shared_ptr<HybridNetServerDriverSpec> create_std__shared_ptr_HybridNetServerDriverSpec_(void* NON_NULL swiftUnsafePointer) noexcept;
|
|
135
|
+
void* NON_NULL get_std__shared_ptr_HybridNetServerDriverSpec_(std__shared_ptr_HybridNetServerDriverSpec_ cppType);
|
|
136
|
+
|
|
137
|
+
// pragma MARK: std::weak_ptr<HybridNetServerDriverSpec>
|
|
138
|
+
using std__weak_ptr_HybridNetServerDriverSpec_ = std::weak_ptr<HybridNetServerDriverSpec>;
|
|
139
|
+
inline std__weak_ptr_HybridNetServerDriverSpec_ weakify_std__shared_ptr_HybridNetServerDriverSpec_(const std::shared_ptr<HybridNetServerDriverSpec>& strong) noexcept { return strong; }
|
|
140
|
+
|
|
141
|
+
// pragma MARK: std::optional<std::string>
|
|
142
|
+
/**
|
|
143
|
+
* Specialized version of `std::optional<std::string>`.
|
|
144
|
+
*/
|
|
145
|
+
using std__optional_std__string_ = std::optional<std::string>;
|
|
146
|
+
inline std::optional<std::string> create_std__optional_std__string_(const std::string& value) noexcept {
|
|
147
|
+
return std::optional<std::string>(value);
|
|
148
|
+
}
|
|
149
|
+
inline bool has_value_std__optional_std__string_(const std::optional<std::string>& optional) noexcept {
|
|
150
|
+
return optional.has_value();
|
|
151
|
+
}
|
|
152
|
+
inline std::string get_std__optional_std__string_(const std::optional<std::string>& optional) noexcept {
|
|
153
|
+
return *optional;
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
// pragma MARK: std::shared_ptr<HybridNetDriverSpec>
|
|
157
|
+
/**
|
|
158
|
+
* Specialized version of `std::shared_ptr<HybridNetDriverSpec>`.
|
|
159
|
+
*/
|
|
160
|
+
using std__shared_ptr_HybridNetDriverSpec_ = std::shared_ptr<HybridNetDriverSpec>;
|
|
161
|
+
std::shared_ptr<HybridNetDriverSpec> create_std__shared_ptr_HybridNetDriverSpec_(void* NON_NULL swiftUnsafePointer) noexcept;
|
|
162
|
+
void* NON_NULL get_std__shared_ptr_HybridNetDriverSpec_(std__shared_ptr_HybridNetDriverSpec_ cppType);
|
|
163
|
+
|
|
164
|
+
// pragma MARK: std::weak_ptr<HybridNetDriverSpec>
|
|
165
|
+
using std__weak_ptr_HybridNetDriverSpec_ = std::weak_ptr<HybridNetDriverSpec>;
|
|
166
|
+
inline std__weak_ptr_HybridNetDriverSpec_ weakify_std__shared_ptr_HybridNetDriverSpec_(const std::shared_ptr<HybridNetDriverSpec>& strong) noexcept { return strong; }
|
|
167
|
+
|
|
168
|
+
// pragma MARK: Result<std::shared_ptr<HybridNetSocketDriverSpec>>
|
|
169
|
+
using Result_std__shared_ptr_HybridNetSocketDriverSpec__ = Result<std::shared_ptr<HybridNetSocketDriverSpec>>;
|
|
170
|
+
inline Result_std__shared_ptr_HybridNetSocketDriverSpec__ create_Result_std__shared_ptr_HybridNetSocketDriverSpec__(const std::shared_ptr<HybridNetSocketDriverSpec>& value) noexcept {
|
|
171
|
+
return Result<std::shared_ptr<HybridNetSocketDriverSpec>>::withValue(value);
|
|
172
|
+
}
|
|
173
|
+
inline Result_std__shared_ptr_HybridNetSocketDriverSpec__ create_Result_std__shared_ptr_HybridNetSocketDriverSpec__(const std::exception_ptr& error) noexcept {
|
|
174
|
+
return Result<std::shared_ptr<HybridNetSocketDriverSpec>>::withError(error);
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
// pragma MARK: Result<std::shared_ptr<HybridNetServerDriverSpec>>
|
|
178
|
+
using Result_std__shared_ptr_HybridNetServerDriverSpec__ = Result<std::shared_ptr<HybridNetServerDriverSpec>>;
|
|
179
|
+
inline Result_std__shared_ptr_HybridNetServerDriverSpec__ create_Result_std__shared_ptr_HybridNetServerDriverSpec__(const std::shared_ptr<HybridNetServerDriverSpec>& value) noexcept {
|
|
180
|
+
return Result<std::shared_ptr<HybridNetServerDriverSpec>>::withValue(value);
|
|
181
|
+
}
|
|
182
|
+
inline Result_std__shared_ptr_HybridNetServerDriverSpec__ create_Result_std__shared_ptr_HybridNetServerDriverSpec__(const std::exception_ptr& error) noexcept {
|
|
183
|
+
return Result<std::shared_ptr<HybridNetServerDriverSpec>>::withError(error);
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
} // namespace margelo::nitro::net::bridge::swift
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// RustCNet-Swift-Cxx-Umbrella.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
// Forward declarations of C++ defined types
|
|
11
|
+
// Forward declaration of `HybridNetDriverSpec` to properly resolve imports.
|
|
12
|
+
namespace margelo::nitro::net { class HybridNetDriverSpec; }
|
|
13
|
+
// Forward declaration of `HybridNetServerDriverSpec` to properly resolve imports.
|
|
14
|
+
namespace margelo::nitro::net { class HybridNetServerDriverSpec; }
|
|
15
|
+
// Forward declaration of `HybridNetSocketDriverSpec` to properly resolve imports.
|
|
16
|
+
namespace margelo::nitro::net { class HybridNetSocketDriverSpec; }
|
|
17
|
+
// Forward declaration of `NetConfig` to properly resolve imports.
|
|
18
|
+
namespace margelo::nitro::net { struct NetConfig; }
|
|
19
|
+
|
|
20
|
+
// Include C++ defined types
|
|
21
|
+
#include "HybridNetDriverSpec.hpp"
|
|
22
|
+
#include "HybridNetServerDriverSpec.hpp"
|
|
23
|
+
#include "HybridNetSocketDriverSpec.hpp"
|
|
24
|
+
#include "NetConfig.hpp"
|
|
25
|
+
#include <NitroModules/ArrayBuffer.hpp>
|
|
26
|
+
#include <NitroModules/Result.hpp>
|
|
27
|
+
#include <exception>
|
|
28
|
+
#include <functional>
|
|
29
|
+
#include <memory>
|
|
30
|
+
#include <optional>
|
|
31
|
+
#include <string>
|
|
32
|
+
|
|
33
|
+
// C++ helpers for Swift
|
|
34
|
+
#include "RustCNet-Swift-Cxx-Bridge.hpp"
|
|
35
|
+
|
|
36
|
+
// Common C++ types used in Swift
|
|
37
|
+
#include <NitroModules/ArrayBufferHolder.hpp>
|
|
38
|
+
#include <NitroModules/AnyMapUtils.hpp>
|
|
39
|
+
#include <NitroModules/RuntimeError.hpp>
|
|
40
|
+
#include <NitroModules/DateToChronoDate.hpp>
|
|
41
|
+
|
|
42
|
+
// Forward declarations of Swift defined types
|
|
43
|
+
// Forward declaration of `HybridNetDriverSpec_cxx` to properly resolve imports.
|
|
44
|
+
namespace RustCNet { class HybridNetDriverSpec_cxx; }
|
|
45
|
+
// Forward declaration of `HybridNetServerDriverSpec_cxx` to properly resolve imports.
|
|
46
|
+
namespace RustCNet { class HybridNetServerDriverSpec_cxx; }
|
|
47
|
+
// Forward declaration of `HybridNetSocketDriverSpec_cxx` to properly resolve imports.
|
|
48
|
+
namespace RustCNet { class HybridNetSocketDriverSpec_cxx; }
|
|
49
|
+
|
|
50
|
+
// Include Swift defined types
|
|
51
|
+
#if __has_include("RustCNet-Swift.h")
|
|
52
|
+
// This header is generated by Xcode/Swift on every app build.
|
|
53
|
+
// If it cannot be found, make sure the Swift module's name (= podspec name) is actually "RustCNet".
|
|
54
|
+
#include "RustCNet-Swift.h"
|
|
55
|
+
// Same as above, but used when building with frameworks (`use_frameworks`)
|
|
56
|
+
#elif __has_include(<RustCNet/RustCNet-Swift.h>)
|
|
57
|
+
#include <RustCNet/RustCNet-Swift.h>
|
|
58
|
+
#else
|
|
59
|
+
#error RustCNet's autogenerated Swift header cannot be found! Make sure the Swift module's name (= podspec name) is actually "RustCNet", and try building the app first.
|
|
60
|
+
#endif
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// RustCNetAutolinking.mm
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#import <Foundation/Foundation.h>
|
|
9
|
+
#import <NitroModules/HybridObjectRegistry.hpp>
|
|
10
|
+
|
|
11
|
+
#import <type_traits>
|
|
12
|
+
|
|
13
|
+
#include "HybridNetDriver.hpp"
|
|
14
|
+
|
|
15
|
+
@interface RustCNetAutolinking : NSObject
|
|
16
|
+
@end
|
|
17
|
+
|
|
18
|
+
@implementation RustCNetAutolinking
|
|
19
|
+
|
|
20
|
+
+ (void) load {
|
|
21
|
+
using namespace margelo::nitro;
|
|
22
|
+
using namespace margelo::nitro::net;
|
|
23
|
+
|
|
24
|
+
HybridObjectRegistry::registerHybridObjectConstructor(
|
|
25
|
+
"NetDriver",
|
|
26
|
+
[]() -> std::shared_ptr<HybridObject> {
|
|
27
|
+
static_assert(std::is_default_constructible_v<HybridNetDriver>,
|
|
28
|
+
"The HybridObject \"HybridNetDriver\" is not default-constructible! "
|
|
29
|
+
"Create a public constructor that takes zero arguments to be able to autolink this HybridObject.");
|
|
30
|
+
return std::make_shared<HybridNetDriver>();
|
|
31
|
+
}
|
|
32
|
+
);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
@end
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// RustCNetAutolinking.swift
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
public final class RustCNetAutolinking {
|
|
9
|
+
public typealias bridge = margelo.nitro.net.bridge.swift
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNetDriverSpecSwift.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include "HybridNetDriverSpecSwift.hpp"
|
|
9
|
+
|
|
10
|
+
namespace margelo::nitro::net {
|
|
11
|
+
} // namespace margelo::nitro::net
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNetDriverSpecSwift.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#include "HybridNetDriverSpec.hpp"
|
|
11
|
+
|
|
12
|
+
// Forward declaration of `HybridNetDriverSpec_cxx` to properly resolve imports.
|
|
13
|
+
namespace RustCNet { class HybridNetDriverSpec_cxx; }
|
|
14
|
+
|
|
15
|
+
// Forward declaration of `HybridNetSocketDriverSpec` to properly resolve imports.
|
|
16
|
+
namespace margelo::nitro::net { class HybridNetSocketDriverSpec; }
|
|
17
|
+
// Forward declaration of `HybridNetServerDriverSpec` to properly resolve imports.
|
|
18
|
+
namespace margelo::nitro::net { class HybridNetServerDriverSpec; }
|
|
19
|
+
// Forward declaration of `NetConfig` to properly resolve imports.
|
|
20
|
+
namespace margelo::nitro::net { struct NetConfig; }
|
|
21
|
+
|
|
22
|
+
#include <memory>
|
|
23
|
+
#include "HybridNetSocketDriverSpec.hpp"
|
|
24
|
+
#include <string>
|
|
25
|
+
#include <optional>
|
|
26
|
+
#include "HybridNetServerDriverSpec.hpp"
|
|
27
|
+
#include "NetConfig.hpp"
|
|
28
|
+
|
|
29
|
+
#include "RustCNet-Swift-Cxx-Umbrella.hpp"
|
|
30
|
+
|
|
31
|
+
namespace margelo::nitro::net {
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* The C++ part of HybridNetDriverSpec_cxx.swift.
|
|
35
|
+
*
|
|
36
|
+
* HybridNetDriverSpecSwift (C++) accesses HybridNetDriverSpec_cxx (Swift), and might
|
|
37
|
+
* contain some additional bridging code for C++ <> Swift interop.
|
|
38
|
+
*
|
|
39
|
+
* Since this obviously introduces an overhead, I hope at some point in
|
|
40
|
+
* the future, HybridNetDriverSpec_cxx can directly inherit from the C++ class HybridNetDriverSpec
|
|
41
|
+
* to simplify the whole structure and memory management.
|
|
42
|
+
*/
|
|
43
|
+
class HybridNetDriverSpecSwift: public virtual HybridNetDriverSpec {
|
|
44
|
+
public:
|
|
45
|
+
// Constructor from a Swift instance
|
|
46
|
+
explicit HybridNetDriverSpecSwift(const RustCNet::HybridNetDriverSpec_cxx& swiftPart):
|
|
47
|
+
HybridObject(HybridNetDriverSpec::TAG),
|
|
48
|
+
_swiftPart(swiftPart) { }
|
|
49
|
+
|
|
50
|
+
public:
|
|
51
|
+
// Get the Swift part
|
|
52
|
+
inline RustCNet::HybridNetDriverSpec_cxx& getSwiftPart() noexcept {
|
|
53
|
+
return _swiftPart;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
public:
|
|
57
|
+
inline size_t getExternalMemorySize() noexcept override {
|
|
58
|
+
return _swiftPart.getMemorySize();
|
|
59
|
+
}
|
|
60
|
+
void dispose() noexcept override {
|
|
61
|
+
_swiftPart.dispose();
|
|
62
|
+
}
|
|
63
|
+
std::string toString() override {
|
|
64
|
+
return _swiftPart.toString();
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
public:
|
|
68
|
+
// Properties
|
|
69
|
+
|
|
70
|
+
|
|
71
|
+
public:
|
|
72
|
+
// Methods
|
|
73
|
+
inline std::shared_ptr<HybridNetSocketDriverSpec> createSocket(const std::optional<std::string>& id) override {
|
|
74
|
+
auto __result = _swiftPart.createSocket(id);
|
|
75
|
+
if (__result.hasError()) [[unlikely]] {
|
|
76
|
+
std::rethrow_exception(__result.error());
|
|
77
|
+
}
|
|
78
|
+
auto __value = std::move(__result.value());
|
|
79
|
+
return __value;
|
|
80
|
+
}
|
|
81
|
+
inline std::shared_ptr<HybridNetServerDriverSpec> createServer() override {
|
|
82
|
+
auto __result = _swiftPart.createServer();
|
|
83
|
+
if (__result.hasError()) [[unlikely]] {
|
|
84
|
+
std::rethrow_exception(__result.error());
|
|
85
|
+
}
|
|
86
|
+
auto __value = std::move(__result.value());
|
|
87
|
+
return __value;
|
|
88
|
+
}
|
|
89
|
+
inline void initWithConfig(const NetConfig& config) override {
|
|
90
|
+
auto __result = _swiftPart.initWithConfig(std::forward<decltype(config)>(config));
|
|
91
|
+
if (__result.hasError()) [[unlikely]] {
|
|
92
|
+
std::rethrow_exception(__result.error());
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
private:
|
|
97
|
+
RustCNet::HybridNetDriverSpec_cxx _swiftPart;
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
} // namespace margelo::nitro::net
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNetServerDriverSpecSwift.cpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#include "HybridNetServerDriverSpecSwift.hpp"
|
|
9
|
+
|
|
10
|
+
namespace margelo::nitro::net {
|
|
11
|
+
} // namespace margelo::nitro::net
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNetServerDriverSpecSwift.hpp
|
|
3
|
+
/// This file was generated by nitrogen. DO NOT MODIFY THIS FILE.
|
|
4
|
+
/// https://github.com/mrousavy/nitro
|
|
5
|
+
/// Copyright © 2025 Marc Rousavy @ Margelo
|
|
6
|
+
///
|
|
7
|
+
|
|
8
|
+
#pragma once
|
|
9
|
+
|
|
10
|
+
#include "HybridNetServerDriverSpec.hpp"
|
|
11
|
+
|
|
12
|
+
// Forward declaration of `HybridNetServerDriverSpec_cxx` to properly resolve imports.
|
|
13
|
+
namespace RustCNet { class HybridNetServerDriverSpec_cxx; }
|
|
14
|
+
|
|
15
|
+
// Forward declaration of `ArrayBufferHolder` to properly resolve imports.
|
|
16
|
+
namespace NitroModules { class ArrayBufferHolder; }
|
|
17
|
+
|
|
18
|
+
#include <NitroModules/ArrayBuffer.hpp>
|
|
19
|
+
#include <functional>
|
|
20
|
+
#include <NitroModules/ArrayBufferHolder.hpp>
|
|
21
|
+
#include <optional>
|
|
22
|
+
#include <string>
|
|
23
|
+
|
|
24
|
+
#include "RustCNet-Swift-Cxx-Umbrella.hpp"
|
|
25
|
+
|
|
26
|
+
namespace margelo::nitro::net {
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* The C++ part of HybridNetServerDriverSpec_cxx.swift.
|
|
30
|
+
*
|
|
31
|
+
* HybridNetServerDriverSpecSwift (C++) accesses HybridNetServerDriverSpec_cxx (Swift), and might
|
|
32
|
+
* contain some additional bridging code for C++ <> Swift interop.
|
|
33
|
+
*
|
|
34
|
+
* Since this obviously introduces an overhead, I hope at some point in
|
|
35
|
+
* the future, HybridNetServerDriverSpec_cxx can directly inherit from the C++ class HybridNetServerDriverSpec
|
|
36
|
+
* to simplify the whole structure and memory management.
|
|
37
|
+
*/
|
|
38
|
+
class HybridNetServerDriverSpecSwift: public virtual HybridNetServerDriverSpec {
|
|
39
|
+
public:
|
|
40
|
+
// Constructor from a Swift instance
|
|
41
|
+
explicit HybridNetServerDriverSpecSwift(const RustCNet::HybridNetServerDriverSpec_cxx& swiftPart):
|
|
42
|
+
HybridObject(HybridNetServerDriverSpec::TAG),
|
|
43
|
+
_swiftPart(swiftPart) { }
|
|
44
|
+
|
|
45
|
+
public:
|
|
46
|
+
// Get the Swift part
|
|
47
|
+
inline RustCNet::HybridNetServerDriverSpec_cxx& getSwiftPart() noexcept {
|
|
48
|
+
return _swiftPart;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
public:
|
|
52
|
+
inline size_t getExternalMemorySize() noexcept override {
|
|
53
|
+
return _swiftPart.getMemorySize();
|
|
54
|
+
}
|
|
55
|
+
void dispose() noexcept override {
|
|
56
|
+
_swiftPart.dispose();
|
|
57
|
+
}
|
|
58
|
+
std::string toString() override {
|
|
59
|
+
return _swiftPart.toString();
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
public:
|
|
63
|
+
// Properties
|
|
64
|
+
inline std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)> getOnEvent() noexcept override {
|
|
65
|
+
auto __result = _swiftPart.getOnEvent();
|
|
66
|
+
return __result;
|
|
67
|
+
}
|
|
68
|
+
inline void setOnEvent(const std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)>& onEvent) noexcept override {
|
|
69
|
+
_swiftPart.setOnEvent(onEvent);
|
|
70
|
+
}
|
|
71
|
+
inline double getMaxConnections() noexcept override {
|
|
72
|
+
return _swiftPart.getMaxConnections();
|
|
73
|
+
}
|
|
74
|
+
inline void setMaxConnections(double maxConnections) noexcept override {
|
|
75
|
+
_swiftPart.setMaxConnections(std::forward<decltype(maxConnections)>(maxConnections));
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
public:
|
|
79
|
+
// Methods
|
|
80
|
+
inline void listen(double port, std::optional<double> backlog, std::optional<bool> ipv6Only, std::optional<bool> reusePort) override {
|
|
81
|
+
auto __result = _swiftPart.listen(std::forward<decltype(port)>(port), backlog, ipv6Only, reusePort);
|
|
82
|
+
if (__result.hasError()) [[unlikely]] {
|
|
83
|
+
std::rethrow_exception(__result.error());
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
inline void listenUnix(const std::string& path, std::optional<double> backlog) override {
|
|
87
|
+
auto __result = _swiftPart.listenUnix(path, backlog);
|
|
88
|
+
if (__result.hasError()) [[unlikely]] {
|
|
89
|
+
std::rethrow_exception(__result.error());
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
inline void listenHandle(double fd, std::optional<double> backlog) override {
|
|
93
|
+
auto __result = _swiftPart.listenHandle(std::forward<decltype(fd)>(fd), backlog);
|
|
94
|
+
if (__result.hasError()) [[unlikely]] {
|
|
95
|
+
std::rethrow_exception(__result.error());
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
inline std::string getLocalAddress() override {
|
|
99
|
+
auto __result = _swiftPart.getLocalAddress();
|
|
100
|
+
if (__result.hasError()) [[unlikely]] {
|
|
101
|
+
std::rethrow_exception(__result.error());
|
|
102
|
+
}
|
|
103
|
+
auto __value = std::move(__result.value());
|
|
104
|
+
return __value;
|
|
105
|
+
}
|
|
106
|
+
inline void close() override {
|
|
107
|
+
auto __result = _swiftPart.close();
|
|
108
|
+
if (__result.hasError()) [[unlikely]] {
|
|
109
|
+
std::rethrow_exception(__result.error());
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
private:
|
|
114
|
+
RustCNet::HybridNetServerDriverSpec_cxx _swiftPart;
|
|
115
|
+
};
|
|
116
|
+
|
|
117
|
+
} // namespace margelo::nitro::net
|