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 @@
|
|
|
1
|
+
** linguist-generated=true
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
#
|
|
2
|
+
# RustCNet+autolinking.cmake
|
|
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 CMake file that adds all files generated by Nitrogen
|
|
9
|
+
# to the current CMake project.
|
|
10
|
+
#
|
|
11
|
+
# To use it, add this to your CMakeLists.txt:
|
|
12
|
+
# ```cmake
|
|
13
|
+
# include(${CMAKE_SOURCE_DIR}/../nitrogen/generated/android/RustCNet+autolinking.cmake)
|
|
14
|
+
# ```
|
|
15
|
+
|
|
16
|
+
# Define a flag to check if we are building properly
|
|
17
|
+
add_definitions(-DBUILDING_RUSTCNET_WITH_GENERATED_CMAKE_PROJECT)
|
|
18
|
+
|
|
19
|
+
# Enable Raw Props parsing in react-native (for Nitro Views)
|
|
20
|
+
add_definitions(-DRN_SERIALIZABLE_STATE)
|
|
21
|
+
|
|
22
|
+
# Add all headers that were generated by Nitrogen
|
|
23
|
+
include_directories(
|
|
24
|
+
"../nitrogen/generated/shared/c++"
|
|
25
|
+
"../nitrogen/generated/android/c++"
|
|
26
|
+
"../nitrogen/generated/android/"
|
|
27
|
+
)
|
|
28
|
+
|
|
29
|
+
# Add all .cpp sources that were generated by Nitrogen
|
|
30
|
+
target_sources(
|
|
31
|
+
# CMake project name (Android C++ library name)
|
|
32
|
+
RustCNet PRIVATE
|
|
33
|
+
# Autolinking Setup
|
|
34
|
+
../nitrogen/generated/android/RustCNetOnLoad.cpp
|
|
35
|
+
# Shared Nitrogen C++ sources
|
|
36
|
+
../nitrogen/generated/shared/c++/HybridNetSocketDriverSpec.cpp
|
|
37
|
+
../nitrogen/generated/shared/c++/HybridNetServerDriverSpec.cpp
|
|
38
|
+
../nitrogen/generated/shared/c++/HybridNetDriverSpec.cpp
|
|
39
|
+
../nitrogen/generated/shared/c++/HybridNitroBufferSpec.cpp
|
|
40
|
+
# Android-specific Nitrogen C++ sources
|
|
41
|
+
../nitrogen/generated/android/c++/JHybridNetSocketDriverSpec.cpp
|
|
42
|
+
../nitrogen/generated/android/c++/JHybridNetServerDriverSpec.cpp
|
|
43
|
+
../nitrogen/generated/android/c++/JHybridNetDriverSpec.cpp
|
|
44
|
+
)
|
|
45
|
+
|
|
46
|
+
# From node_modules/react-native/ReactAndroid/cmake-utils/folly-flags.cmake
|
|
47
|
+
# Used in node_modules/react-native/ReactAndroid/cmake-utils/ReactNative-application.cmake
|
|
48
|
+
target_compile_definitions(
|
|
49
|
+
RustCNet PRIVATE
|
|
50
|
+
-DFOLLY_NO_CONFIG=1
|
|
51
|
+
-DFOLLY_HAVE_CLOCK_GETTIME=1
|
|
52
|
+
-DFOLLY_USE_LIBCPP=1
|
|
53
|
+
-DFOLLY_CFG_NO_COROUTINES=1
|
|
54
|
+
-DFOLLY_MOBILE=1
|
|
55
|
+
-DFOLLY_HAVE_RECVMMSG=1
|
|
56
|
+
-DFOLLY_HAVE_PTHREAD=1
|
|
57
|
+
# Once we target android-23 above, we can comment
|
|
58
|
+
# the following line. NDK uses GNU style stderror_r() after API 23.
|
|
59
|
+
-DFOLLY_HAVE_XSI_STRERROR_R=1
|
|
60
|
+
)
|
|
61
|
+
|
|
62
|
+
# Add all libraries required by the generated specs
|
|
63
|
+
find_package(fbjni REQUIRED) # <-- Used for communication between Java <-> C++
|
|
64
|
+
find_package(ReactAndroid REQUIRED) # <-- Used to set up React Native bindings (e.g. CallInvoker/TurboModule)
|
|
65
|
+
find_package(react-native-nitro-modules REQUIRED) # <-- Used to create all HybridObjects and use the Nitro core library
|
|
66
|
+
|
|
67
|
+
# Link all libraries together
|
|
68
|
+
target_link_libraries(
|
|
69
|
+
RustCNet
|
|
70
|
+
fbjni::fbjni # <-- Facebook C++ JNI helpers
|
|
71
|
+
ReactAndroid::jsi # <-- RN: JSI
|
|
72
|
+
react-native-nitro-modules::NitroModules # <-- NitroModules Core :)
|
|
73
|
+
)
|
|
74
|
+
|
|
75
|
+
# Link react-native (different prefab between RN 0.75 and RN 0.76)
|
|
76
|
+
if(ReactAndroid_VERSION_MINOR GREATER_EQUAL 76)
|
|
77
|
+
target_link_libraries(
|
|
78
|
+
RustCNet
|
|
79
|
+
ReactAndroid::reactnative # <-- RN: Native Modules umbrella prefab
|
|
80
|
+
)
|
|
81
|
+
else()
|
|
82
|
+
target_link_libraries(
|
|
83
|
+
RustCNet
|
|
84
|
+
ReactAndroid::react_nativemodule_core # <-- RN: TurboModules Core
|
|
85
|
+
)
|
|
86
|
+
endif()
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// RustCNet+autolinking.gradle
|
|
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 Gradle file that adds all files generated by Nitrogen
|
|
9
|
+
/// to the current Gradle project.
|
|
10
|
+
///
|
|
11
|
+
/// To use it, add this to your build.gradle:
|
|
12
|
+
/// ```gradle
|
|
13
|
+
/// apply from: '../nitrogen/generated/android/RustCNet+autolinking.gradle'
|
|
14
|
+
/// ```
|
|
15
|
+
|
|
16
|
+
logger.warn("[NitroModules] 🔥 RustCNet is boosted by nitro!")
|
|
17
|
+
|
|
18
|
+
android {
|
|
19
|
+
sourceSets {
|
|
20
|
+
main {
|
|
21
|
+
java.srcDirs += [
|
|
22
|
+
// Nitrogen files
|
|
23
|
+
"${project.projectDir}/../nitrogen/generated/android/kotlin"
|
|
24
|
+
]
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// RustCNetOnLoad.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
|
+
#ifndef BUILDING_RUSTCNET_WITH_GENERATED_CMAKE_PROJECT
|
|
9
|
+
#error RustCNetOnLoad.cpp is not being built with the autogenerated CMakeLists.txt project. Is a different CMakeLists.txt building this?
|
|
10
|
+
#endif
|
|
11
|
+
|
|
12
|
+
#include "RustCNetOnLoad.hpp"
|
|
13
|
+
|
|
14
|
+
#include <jni.h>
|
|
15
|
+
#include <fbjni/fbjni.h>
|
|
16
|
+
#include <NitroModules/HybridObjectRegistry.hpp>
|
|
17
|
+
|
|
18
|
+
#include "JHybridNetSocketDriverSpec.hpp"
|
|
19
|
+
#include "JFunc_void_double_std__shared_ptr_ArrayBuffer_.hpp"
|
|
20
|
+
#include "JHybridNetServerDriverSpec.hpp"
|
|
21
|
+
#include "JHybridNetDriverSpec.hpp"
|
|
22
|
+
#include "HybridNetDriver.hpp"
|
|
23
|
+
|
|
24
|
+
namespace margelo::nitro::net {
|
|
25
|
+
|
|
26
|
+
int initialize(JavaVM* vm) {
|
|
27
|
+
using namespace margelo::nitro;
|
|
28
|
+
using namespace margelo::nitro::net;
|
|
29
|
+
using namespace facebook;
|
|
30
|
+
|
|
31
|
+
return facebook::jni::initialize(vm, [] {
|
|
32
|
+
// Register native JNI methods
|
|
33
|
+
margelo::nitro::net::JHybridNetSocketDriverSpec::registerNatives();
|
|
34
|
+
margelo::nitro::net::JFunc_void_double_std__shared_ptr_ArrayBuffer__cxx::registerNatives();
|
|
35
|
+
margelo::nitro::net::JHybridNetServerDriverSpec::registerNatives();
|
|
36
|
+
margelo::nitro::net::JHybridNetDriverSpec::registerNatives();
|
|
37
|
+
|
|
38
|
+
// Register Nitro Hybrid Objects
|
|
39
|
+
HybridObjectRegistry::registerHybridObjectConstructor(
|
|
40
|
+
"NetDriver",
|
|
41
|
+
[]() -> std::shared_ptr<HybridObject> {
|
|
42
|
+
static_assert(std::is_default_constructible_v<HybridNetDriver>,
|
|
43
|
+
"The HybridObject \"HybridNetDriver\" is not default-constructible! "
|
|
44
|
+
"Create a public constructor that takes zero arguments to be able to autolink this HybridObject.");
|
|
45
|
+
return std::make_shared<HybridNetDriver>();
|
|
46
|
+
}
|
|
47
|
+
);
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
} // namespace margelo::nitro::net
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// RustCNetOnLoad.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
|
+
#include <jni.h>
|
|
9
|
+
#include <NitroModules/NitroDefines.hpp>
|
|
10
|
+
|
|
11
|
+
namespace margelo::nitro::net {
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Initializes the native (C++) part of RustCNet, and autolinks all Hybrid Objects.
|
|
15
|
+
* Call this in your `JNI_OnLoad` function (probably inside `cpp-adapter.cpp`).
|
|
16
|
+
* Example:
|
|
17
|
+
* ```cpp (cpp-adapter.cpp)
|
|
18
|
+
* JNIEXPORT jint JNICALL JNI_OnLoad(JavaVM* vm, void*) {
|
|
19
|
+
* return margelo::nitro::net::initialize(vm);
|
|
20
|
+
* }
|
|
21
|
+
* ```
|
|
22
|
+
*/
|
|
23
|
+
int initialize(JavaVM* vm);
|
|
24
|
+
|
|
25
|
+
} // namespace margelo::nitro::net
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// JFunc_void_double_std__shared_ptr_ArrayBuffer_.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 <fbjni/fbjni.h>
|
|
11
|
+
#include <functional>
|
|
12
|
+
|
|
13
|
+
#include <NitroModules/ArrayBuffer.hpp>
|
|
14
|
+
#include <functional>
|
|
15
|
+
#include <NitroModules/JNICallable.hpp>
|
|
16
|
+
#include <NitroModules/JArrayBuffer.hpp>
|
|
17
|
+
|
|
18
|
+
namespace margelo::nitro::net {
|
|
19
|
+
|
|
20
|
+
using namespace facebook;
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Represents the Java/Kotlin callback `(event: Double, data: ArrayBuffer) -> Unit`.
|
|
24
|
+
* This can be passed around between C++ and Java/Kotlin.
|
|
25
|
+
*/
|
|
26
|
+
struct JFunc_void_double_std__shared_ptr_ArrayBuffer_: public jni::JavaClass<JFunc_void_double_std__shared_ptr_ArrayBuffer_> {
|
|
27
|
+
public:
|
|
28
|
+
static auto constexpr kJavaDescriptor = "Lcom/margelo/nitro/net/Func_void_double_std__shared_ptr_ArrayBuffer_;";
|
|
29
|
+
|
|
30
|
+
public:
|
|
31
|
+
/**
|
|
32
|
+
* Invokes the function this `JFunc_void_double_std__shared_ptr_ArrayBuffer_` instance holds through JNI.
|
|
33
|
+
*/
|
|
34
|
+
void invoke(double event, const std::shared_ptr<ArrayBuffer>& data) const {
|
|
35
|
+
static const auto method = javaClassStatic()->getMethod<void(double /* event */, jni::alias_ref<JArrayBuffer::javaobject> /* data */)>("invoke");
|
|
36
|
+
method(self(), event, JArrayBuffer::wrap(data));
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* An implementation of Func_void_double_std__shared_ptr_ArrayBuffer_ that is backed by a C++ implementation (using `std::function<...>`)
|
|
42
|
+
*/
|
|
43
|
+
class JFunc_void_double_std__shared_ptr_ArrayBuffer__cxx final: public jni::HybridClass<JFunc_void_double_std__shared_ptr_ArrayBuffer__cxx, JFunc_void_double_std__shared_ptr_ArrayBuffer_> {
|
|
44
|
+
public:
|
|
45
|
+
static jni::local_ref<JFunc_void_double_std__shared_ptr_ArrayBuffer_::javaobject> fromCpp(const std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)>& func) {
|
|
46
|
+
return JFunc_void_double_std__shared_ptr_ArrayBuffer__cxx::newObjectCxxArgs(func);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
public:
|
|
50
|
+
/**
|
|
51
|
+
* Invokes the C++ `std::function<...>` this `JFunc_void_double_std__shared_ptr_ArrayBuffer__cxx` instance holds.
|
|
52
|
+
*/
|
|
53
|
+
void invoke_cxx(double event, jni::alias_ref<JArrayBuffer::javaobject> data) {
|
|
54
|
+
_func(event, data->cthis()->getArrayBuffer());
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
public:
|
|
58
|
+
[[nodiscard]]
|
|
59
|
+
inline const std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)>& getFunction() const {
|
|
60
|
+
return _func;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
public:
|
|
64
|
+
static auto constexpr kJavaDescriptor = "Lcom/margelo/nitro/net/Func_void_double_std__shared_ptr_ArrayBuffer__cxx;";
|
|
65
|
+
static void registerNatives() {
|
|
66
|
+
registerHybrid({makeNativeMethod("invoke_cxx", JFunc_void_double_std__shared_ptr_ArrayBuffer__cxx::invoke_cxx)});
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
private:
|
|
70
|
+
explicit JFunc_void_double_std__shared_ptr_ArrayBuffer__cxx(const std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)>& func): _func(func) { }
|
|
71
|
+
|
|
72
|
+
private:
|
|
73
|
+
friend HybridBase;
|
|
74
|
+
std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)> _func;
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
} // namespace margelo::nitro::net
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// JHybridNetDriverSpec.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 "JHybridNetDriverSpec.hpp"
|
|
9
|
+
|
|
10
|
+
// Forward declaration of `HybridNetSocketDriverSpec` to properly resolve imports.
|
|
11
|
+
namespace margelo::nitro::net { class HybridNetSocketDriverSpec; }
|
|
12
|
+
// Forward declaration of `HybridNetServerDriverSpec` to properly resolve imports.
|
|
13
|
+
namespace margelo::nitro::net { class HybridNetServerDriverSpec; }
|
|
14
|
+
// Forward declaration of `NetConfig` to properly resolve imports.
|
|
15
|
+
namespace margelo::nitro::net { struct NetConfig; }
|
|
16
|
+
|
|
17
|
+
#include <memory>
|
|
18
|
+
#include "HybridNetSocketDriverSpec.hpp"
|
|
19
|
+
#include "JHybridNetSocketDriverSpec.hpp"
|
|
20
|
+
#include "HybridNetServerDriverSpec.hpp"
|
|
21
|
+
#include "JHybridNetServerDriverSpec.hpp"
|
|
22
|
+
#include <string>
|
|
23
|
+
#include <optional>
|
|
24
|
+
#include "NetConfig.hpp"
|
|
25
|
+
#include "JNetConfig.hpp"
|
|
26
|
+
|
|
27
|
+
namespace margelo::nitro::net {
|
|
28
|
+
|
|
29
|
+
jni::local_ref<JHybridNetDriverSpec::jhybriddata> JHybridNetDriverSpec::initHybrid(jni::alias_ref<jhybridobject> jThis) {
|
|
30
|
+
return makeCxxInstance(jThis);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
void JHybridNetDriverSpec::registerNatives() {
|
|
34
|
+
registerHybrid({
|
|
35
|
+
makeNativeMethod("initHybrid", JHybridNetDriverSpec::initHybrid),
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
size_t JHybridNetDriverSpec::getExternalMemorySize() noexcept {
|
|
40
|
+
static const auto method = javaClassStatic()->getMethod<jlong()>("getMemorySize");
|
|
41
|
+
return method(_javaPart);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
void JHybridNetDriverSpec::dispose() noexcept {
|
|
45
|
+
static const auto method = javaClassStatic()->getMethod<void()>("dispose");
|
|
46
|
+
method(_javaPart);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
std::string JHybridNetDriverSpec::toString() {
|
|
50
|
+
static const auto method = javaClassStatic()->getMethod<jni::JString()>("toString");
|
|
51
|
+
auto javaString = method(_javaPart);
|
|
52
|
+
return javaString->toStdString();
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
// Properties
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
// Methods
|
|
59
|
+
std::shared_ptr<HybridNetSocketDriverSpec> JHybridNetDriverSpec::createSocket(const std::optional<std::string>& id) {
|
|
60
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<JHybridNetSocketDriverSpec::javaobject>(jni::alias_ref<jni::JString> /* id */)>("createSocket");
|
|
61
|
+
auto __result = method(_javaPart, id.has_value() ? jni::make_jstring(id.value()) : nullptr);
|
|
62
|
+
return __result->cthis()->shared_cast<JHybridNetSocketDriverSpec>();
|
|
63
|
+
}
|
|
64
|
+
std::shared_ptr<HybridNetServerDriverSpec> JHybridNetDriverSpec::createServer() {
|
|
65
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<JHybridNetServerDriverSpec::javaobject>()>("createServer");
|
|
66
|
+
auto __result = method(_javaPart);
|
|
67
|
+
return __result->cthis()->shared_cast<JHybridNetServerDriverSpec>();
|
|
68
|
+
}
|
|
69
|
+
void JHybridNetDriverSpec::initWithConfig(const NetConfig& config) {
|
|
70
|
+
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<JNetConfig> /* config */)>("initWithConfig");
|
|
71
|
+
method(_javaPart, JNetConfig::fromCpp(config));
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
} // namespace margelo::nitro::net
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNetDriverSpec.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 <NitroModules/JHybridObject.hpp>
|
|
11
|
+
#include <fbjni/fbjni.h>
|
|
12
|
+
#include "HybridNetDriverSpec.hpp"
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
namespace margelo::nitro::net {
|
|
18
|
+
|
|
19
|
+
using namespace facebook;
|
|
20
|
+
|
|
21
|
+
class JHybridNetDriverSpec: public jni::HybridClass<JHybridNetDriverSpec, JHybridObject>,
|
|
22
|
+
public virtual HybridNetDriverSpec {
|
|
23
|
+
public:
|
|
24
|
+
static auto constexpr kJavaDescriptor = "Lcom/margelo/nitro/net/HybridNetDriverSpec;";
|
|
25
|
+
static jni::local_ref<jhybriddata> initHybrid(jni::alias_ref<jhybridobject> jThis);
|
|
26
|
+
static void registerNatives();
|
|
27
|
+
|
|
28
|
+
protected:
|
|
29
|
+
// C++ constructor (called from Java via `initHybrid()`)
|
|
30
|
+
explicit JHybridNetDriverSpec(jni::alias_ref<jhybridobject> jThis) :
|
|
31
|
+
HybridObject(HybridNetDriverSpec::TAG),
|
|
32
|
+
HybridBase(jThis),
|
|
33
|
+
_javaPart(jni::make_global(jThis)) {}
|
|
34
|
+
|
|
35
|
+
public:
|
|
36
|
+
~JHybridNetDriverSpec() override {
|
|
37
|
+
// Hermes GC can destroy JS objects on a non-JNI Thread.
|
|
38
|
+
jni::ThreadScope::WithClassLoader([&] { _javaPart.reset(); });
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
public:
|
|
42
|
+
size_t getExternalMemorySize() noexcept override;
|
|
43
|
+
void dispose() noexcept override;
|
|
44
|
+
std::string toString() override;
|
|
45
|
+
|
|
46
|
+
public:
|
|
47
|
+
inline const jni::global_ref<JHybridNetDriverSpec::javaobject>& getJavaPart() const noexcept {
|
|
48
|
+
return _javaPart;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
public:
|
|
52
|
+
// Properties
|
|
53
|
+
|
|
54
|
+
|
|
55
|
+
public:
|
|
56
|
+
// Methods
|
|
57
|
+
std::shared_ptr<HybridNetSocketDriverSpec> createSocket(const std::optional<std::string>& id) override;
|
|
58
|
+
std::shared_ptr<HybridNetServerDriverSpec> createServer() override;
|
|
59
|
+
void initWithConfig(const NetConfig& config) override;
|
|
60
|
+
|
|
61
|
+
private:
|
|
62
|
+
friend HybridBase;
|
|
63
|
+
using HybridBase::HybridBase;
|
|
64
|
+
jni::global_ref<JHybridNetDriverSpec::javaobject> _javaPart;
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
} // namespace margelo::nitro::net
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// JHybridNetServerDriverSpec.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 "JHybridNetServerDriverSpec.hpp"
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
#include <NitroModules/ArrayBuffer.hpp>
|
|
13
|
+
#include <functional>
|
|
14
|
+
#include "JFunc_void_double_std__shared_ptr_ArrayBuffer_.hpp"
|
|
15
|
+
#include <NitroModules/JNICallable.hpp>
|
|
16
|
+
#include <NitroModules/JArrayBuffer.hpp>
|
|
17
|
+
#include <string>
|
|
18
|
+
#include <optional>
|
|
19
|
+
|
|
20
|
+
namespace margelo::nitro::net {
|
|
21
|
+
|
|
22
|
+
jni::local_ref<JHybridNetServerDriverSpec::jhybriddata> JHybridNetServerDriverSpec::initHybrid(jni::alias_ref<jhybridobject> jThis) {
|
|
23
|
+
return makeCxxInstance(jThis);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
void JHybridNetServerDriverSpec::registerNatives() {
|
|
27
|
+
registerHybrid({
|
|
28
|
+
makeNativeMethod("initHybrid", JHybridNetServerDriverSpec::initHybrid),
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
size_t JHybridNetServerDriverSpec::getExternalMemorySize() noexcept {
|
|
33
|
+
static const auto method = javaClassStatic()->getMethod<jlong()>("getMemorySize");
|
|
34
|
+
return method(_javaPart);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
void JHybridNetServerDriverSpec::dispose() noexcept {
|
|
38
|
+
static const auto method = javaClassStatic()->getMethod<void()>("dispose");
|
|
39
|
+
method(_javaPart);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
std::string JHybridNetServerDriverSpec::toString() {
|
|
43
|
+
static const auto method = javaClassStatic()->getMethod<jni::JString()>("toString");
|
|
44
|
+
auto javaString = method(_javaPart);
|
|
45
|
+
return javaString->toStdString();
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// Properties
|
|
49
|
+
std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)> JHybridNetServerDriverSpec::getOnEvent() {
|
|
50
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<JFunc_void_double_std__shared_ptr_ArrayBuffer_::javaobject>()>("getOnEvent_cxx");
|
|
51
|
+
auto __result = method(_javaPart);
|
|
52
|
+
return [&]() -> std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)> {
|
|
53
|
+
if (__result->isInstanceOf(JFunc_void_double_std__shared_ptr_ArrayBuffer__cxx::javaClassStatic())) [[likely]] {
|
|
54
|
+
auto downcast = jni::static_ref_cast<JFunc_void_double_std__shared_ptr_ArrayBuffer__cxx::javaobject>(__result);
|
|
55
|
+
return downcast->cthis()->getFunction();
|
|
56
|
+
} else {
|
|
57
|
+
auto __resultRef = jni::make_global(__result);
|
|
58
|
+
return JNICallable<JFunc_void_double_std__shared_ptr_ArrayBuffer_, void(double, std::shared_ptr<ArrayBuffer>)>(std::move(__resultRef));
|
|
59
|
+
}
|
|
60
|
+
}();
|
|
61
|
+
}
|
|
62
|
+
void JHybridNetServerDriverSpec::setOnEvent(const std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)>& onEvent) {
|
|
63
|
+
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<JFunc_void_double_std__shared_ptr_ArrayBuffer_::javaobject> /* onEvent */)>("setOnEvent_cxx");
|
|
64
|
+
method(_javaPart, JFunc_void_double_std__shared_ptr_ArrayBuffer__cxx::fromCpp(onEvent));
|
|
65
|
+
}
|
|
66
|
+
double JHybridNetServerDriverSpec::getMaxConnections() {
|
|
67
|
+
static const auto method = javaClassStatic()->getMethod<double()>("getMaxConnections");
|
|
68
|
+
auto __result = method(_javaPart);
|
|
69
|
+
return __result;
|
|
70
|
+
}
|
|
71
|
+
void JHybridNetServerDriverSpec::setMaxConnections(double maxConnections) {
|
|
72
|
+
static const auto method = javaClassStatic()->getMethod<void(double /* maxConnections */)>("setMaxConnections");
|
|
73
|
+
method(_javaPart, maxConnections);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
// Methods
|
|
77
|
+
void JHybridNetServerDriverSpec::listen(double port, std::optional<double> backlog, std::optional<bool> ipv6Only, std::optional<bool> reusePort) {
|
|
78
|
+
static const auto method = javaClassStatic()->getMethod<void(double /* port */, jni::alias_ref<jni::JDouble> /* backlog */, jni::alias_ref<jni::JBoolean> /* ipv6Only */, jni::alias_ref<jni::JBoolean> /* reusePort */)>("listen");
|
|
79
|
+
method(_javaPart, port, backlog.has_value() ? jni::JDouble::valueOf(backlog.value()) : nullptr, ipv6Only.has_value() ? jni::JBoolean::valueOf(ipv6Only.value()) : nullptr, reusePort.has_value() ? jni::JBoolean::valueOf(reusePort.value()) : nullptr);
|
|
80
|
+
}
|
|
81
|
+
void JHybridNetServerDriverSpec::listenUnix(const std::string& path, std::optional<double> backlog) {
|
|
82
|
+
static const auto method = javaClassStatic()->getMethod<void(jni::alias_ref<jni::JString> /* path */, jni::alias_ref<jni::JDouble> /* backlog */)>("listenUnix");
|
|
83
|
+
method(_javaPart, jni::make_jstring(path), backlog.has_value() ? jni::JDouble::valueOf(backlog.value()) : nullptr);
|
|
84
|
+
}
|
|
85
|
+
void JHybridNetServerDriverSpec::listenHandle(double fd, std::optional<double> backlog) {
|
|
86
|
+
static const auto method = javaClassStatic()->getMethod<void(double /* fd */, jni::alias_ref<jni::JDouble> /* backlog */)>("listenHandle");
|
|
87
|
+
method(_javaPart, fd, backlog.has_value() ? jni::JDouble::valueOf(backlog.value()) : nullptr);
|
|
88
|
+
}
|
|
89
|
+
std::string JHybridNetServerDriverSpec::getLocalAddress() {
|
|
90
|
+
static const auto method = javaClassStatic()->getMethod<jni::local_ref<jni::JString>()>("getLocalAddress");
|
|
91
|
+
auto __result = method(_javaPart);
|
|
92
|
+
return __result->toStdString();
|
|
93
|
+
}
|
|
94
|
+
void JHybridNetServerDriverSpec::close() {
|
|
95
|
+
static const auto method = javaClassStatic()->getMethod<void()>("close");
|
|
96
|
+
method(_javaPart);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
} // namespace margelo::nitro::net
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
///
|
|
2
|
+
/// HybridNetServerDriverSpec.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 <NitroModules/JHybridObject.hpp>
|
|
11
|
+
#include <fbjni/fbjni.h>
|
|
12
|
+
#include "HybridNetServerDriverSpec.hpp"
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
namespace margelo::nitro::net {
|
|
18
|
+
|
|
19
|
+
using namespace facebook;
|
|
20
|
+
|
|
21
|
+
class JHybridNetServerDriverSpec: public jni::HybridClass<JHybridNetServerDriverSpec, JHybridObject>,
|
|
22
|
+
public virtual HybridNetServerDriverSpec {
|
|
23
|
+
public:
|
|
24
|
+
static auto constexpr kJavaDescriptor = "Lcom/margelo/nitro/net/HybridNetServerDriverSpec;";
|
|
25
|
+
static jni::local_ref<jhybriddata> initHybrid(jni::alias_ref<jhybridobject> jThis);
|
|
26
|
+
static void registerNatives();
|
|
27
|
+
|
|
28
|
+
protected:
|
|
29
|
+
// C++ constructor (called from Java via `initHybrid()`)
|
|
30
|
+
explicit JHybridNetServerDriverSpec(jni::alias_ref<jhybridobject> jThis) :
|
|
31
|
+
HybridObject(HybridNetServerDriverSpec::TAG),
|
|
32
|
+
HybridBase(jThis),
|
|
33
|
+
_javaPart(jni::make_global(jThis)) {}
|
|
34
|
+
|
|
35
|
+
public:
|
|
36
|
+
~JHybridNetServerDriverSpec() override {
|
|
37
|
+
// Hermes GC can destroy JS objects on a non-JNI Thread.
|
|
38
|
+
jni::ThreadScope::WithClassLoader([&] { _javaPart.reset(); });
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
public:
|
|
42
|
+
size_t getExternalMemorySize() noexcept override;
|
|
43
|
+
void dispose() noexcept override;
|
|
44
|
+
std::string toString() override;
|
|
45
|
+
|
|
46
|
+
public:
|
|
47
|
+
inline const jni::global_ref<JHybridNetServerDriverSpec::javaobject>& getJavaPart() const noexcept {
|
|
48
|
+
return _javaPart;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
public:
|
|
52
|
+
// Properties
|
|
53
|
+
std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)> getOnEvent() override;
|
|
54
|
+
void setOnEvent(const std::function<void(double /* event */, const std::shared_ptr<ArrayBuffer>& /* data */)>& onEvent) override;
|
|
55
|
+
double getMaxConnections() override;
|
|
56
|
+
void setMaxConnections(double maxConnections) override;
|
|
57
|
+
|
|
58
|
+
public:
|
|
59
|
+
// Methods
|
|
60
|
+
void listen(double port, std::optional<double> backlog, std::optional<bool> ipv6Only, std::optional<bool> reusePort) override;
|
|
61
|
+
void listenUnix(const std::string& path, std::optional<double> backlog) override;
|
|
62
|
+
void listenHandle(double fd, std::optional<double> backlog) override;
|
|
63
|
+
std::string getLocalAddress() override;
|
|
64
|
+
void close() override;
|
|
65
|
+
|
|
66
|
+
private:
|
|
67
|
+
friend HybridBase;
|
|
68
|
+
using HybridBase::HybridBase;
|
|
69
|
+
jni::global_ref<JHybridNetServerDriverSpec::javaobject> _javaPart;
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
} // namespace margelo::nitro::net
|