Create multiple Cxx TurboModules in same package #283
-
| Hi! I have a npm package with multiple cross-platform C++ modules, but on android, the second one fails to link. My structure: 
 react-native.config.js: module.exports = {
    dependency: {
        platforms: {
            android: {
                cxxModuleCMakeListsModuleName: 'A',
                cxxModuleCMakeListsPath: 'CMakeLists.txt',
                cxxModuleHeaderName: 'NativeATurboModule',
            },
        },
    },
};I think as NativeATurboModule is defined as cxxModuleHeaderName, that's the reason only the A module is linked? When I check the the autolinking.cpp, I can find this line: std::shared_ptr<TurboModule> autolinking_cxxModuleProvider(const std::string moduleName, const std::shared_ptr<CallInvoker>& jsInvoker) {
if (moduleName == NativeATurboModule::kModuleName) {
return std::make_shared<NativeATurboModule>(jsInvoker);
}
  return nullptr;
}But in the locally generated codegen folder of the package, I can also find this one (inside the RNModuleNameSpec-generated.cpp): std::shared_ptr<TurboModule> RNMultiTrackPlayerSpec_ModuleProvider(const std::string &moduleName, const JavaTurboModule::InitParams ¶ms) {
  if (moduleName == "A") {
    return std::make_shared<NativeASpecJSI>(params);
  }
  if (moduleName == "B") {
    return std::make_shared<NativeBSpecJSI>(params);
  }
  return nullptr;
}Does anyone know how to add multiple C++ TurboModules in an npm package? I think I can merge all the definitions, but this would result in a really large and kinda messy module... | 
Beta Was this translation helpful? Give feedback.
Replies: 4 comments 9 replies
-
| 
 This is sadly not supported at the moment. As we need to generate a lot of C++ code for this to work, the initial implementation of Autolinking for pure C++ TM, was done under the assumption that there would be one module per NPM package. You should create a separate package for  The  | 
Beta Was this translation helpful? Give feedback.
-
| hey, @cortinico Writing native modules with C++ is only available from React Native version 0.76? | 
Beta Was this translation helpful? Give feedback.
-
| https://github.com/nocanstillbb/mutipleTurboModulesInApp @mensonones I want to know how to create multiple turbo.so / turbo.framework. C++ compilation is slow, but it can be compiled incrementally. If there is only one build target, linking will take a lot of time. It is best to split it into multiple @mensonones | 
Beta Was this translation helpful? Give feedback.
-
| I have a problem with this workaround, I created a  #include <DefaultComponentsRegistry.h>
#include <DefaultTurboModuleManagerDelegate.h>
// #include <autolinking.h> // cannot be found
#include "modules/NativeFileSystemModule.h"
#include "modules/NativeStorageModule.h"
#include "modules/NativeTransferifyModule.h"
#include "modules/NativeUtilityModule.h"
#include <fbjni/fbjni.h>
#include <react/renderer/componentregistry/ComponentDescriptorProviderRegistry.h>
#include <rncore.h>
...
namespace facebook::react
{
...
std::shared_ptr<TurboModule> cxxModuleProvider(const std::string &                  name,
                                               const std::shared_ptr<CallInvoker> & jsInvoker)
{
  if (name == NativeFileSystemModule::kModuleName)
  {
    return std::make_shared<NativeFileSystemModule>(jsInvoker);
  }
  else if (name == NativeStorageModule::kModuleName)
  {
    return std::make_shared<NativeStorageModule>(jsInvoker);
  }
  else if (name == NativeTransferifyModule::kModuleName)
  {
    return std::make_shared<NativeTransferifyModule>(jsInvoker);
  }
  else if (name == NativeUtilityModule::kModuleName)
  {
    return std::make_shared<NativeUtilityModule>(jsInvoker);
  }
  else
  {
    // And we fallback to the CXX module providers autolinked
    // return autolinking_cxxModuleProvider(name, jsInvoker);
  }
  return nullptr;
}
...
}  // namespace facebook::react
...I have a  Any help is much appreciated, thanks! Edit: will turbo modules ever support multiple modules in the same package? | 
Beta Was this translation helpful? Give feedback.
This is sadly not supported at the moment. As we need to generate a lot of C++ code for this to work, the initial implementation of Autolinking for pure C++ TM, was done under the assumption that there would be one module per NPM package.
You should create a separate package for
NativeAandNativeBas they will generate separate module provider and need to be both autolinked.The
react-native.config.jsfile also allows for a single module and not an array of them.