This is a template for Nitro Modules.
Clone this repo, and change all $$*$$ names according to your nitro.json file.
Contribute a change to this template to update it for newer React Native versions.
android/: All yourandroid-specific implementations.build.gradle: The gradle build file. This contains four important pieces:- Standard react-native library boilerplate code
- Configures Kotlin (
apply plugin: 'org.jetbrains.kotlin.android') - Adds all Nitrogen files (
apply from: '.../NitroMath+autolinking.gradle') - Triggers the native C++ build (via CMake/
externalNativeBuild)
CMakeLists.txt: The CMake build file to build C++ code. This contains four important pieces:- Creates a library called
NitroMath(same as innitro.json) - Adds all Nitrogen files (
include(.../NitroMath+autolinking.cmake)) - Adds all custom C++ files (only
HybridTestObjectCpp.cpp) - Adds a
cpp-adapter.cppfile, which autolinks all C++ HybridObjects (onlyHybridTestObjectCpp)
- Creates a library called
src/main/java/com/margelo/nitro/math/: All Kotlin implementations.NitroMathPackage.java: The react-native package. You need this because the react-native CLI only adds libraries if they have a*Package.javafile. In here, you can autolink all Kotlin HybridObjects.
cpp/: All your cross-platform implementations. (onlyHybridTestObjectCpp.cpp)ios/: All your iOS-specific implementations.nitrogen/: All files generated by nitrogen. You should commit this folder to git.src/: The TypeScript codebase. This defines all HybridObjects and loads them at runtime.specs/: All HybridObject types. Nitrogen will run on all*.nitro.tsfiles.
nitro.json: The configuration file for nitrogen. This will define all native namespaces, as well as the library name.NitroMath.podspec: The iOS podspec build file to build the iOS code. This contains three important pieces:- Specifies the Pod's name. This must be identical to the name specified in
nitro.json. - Adds all of your
.swiftor.cppfiles (implementations). - Adds all Nitrogen files (
add_nitrogen_files(s))
- Specifies the Pod's name. This must be identical to the name specified in
package.json: The npm package.json file.react-native-nitro-modulesshould be apeerDependency.