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.cpp
file, 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.java
file. 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.ts
files.
-
-
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
.swift
or.cpp
files (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-modules
should be apeerDependency
.