Expo
To proceed with incorporating custom native code, you need to transition from Expo Go to a development build. This is necessary because Expo Go only supports libraries included in the Expo SDK or those without custom native code.
If your project does not currently include the 'ios' and 'android' directories, you can create them by executing the following command in your project directory:
npx expo prebuild
npx expo customize metro.config.js
This creates the android and ios directories for running your React code.
To integrate cpp.js into your project using React Native, you can utilize the @cpp.js/plugin-react-native, @cpp.js/plugin-react-native-ios-helper. Start by installing these package with the following command:
- npm
- Yarn
- pnpm
- bun
npm install @cpp.js/plugin-react-native @cpp.js/plugin-react-native-ios-helper
yarn add @cpp.js/plugin-react-native @cpp.js/plugin-react-native-ios-helper
pnpm add @cpp.js/plugin-react-native @cpp.js/plugin-react-native-ios-helper
bun add @cpp.js/plugin-react-native @cpp.js/plugin-react-native-ios-helper
To enable the plugin, modify the metro.config.js
file as shown below.
// Learn more https://docs.expo.io/guides/customizing-metro
const { getDefaultConfig } = require('expo/metro-config');
+const { mergeConfig } = require('metro-config');
+const CppjsMetroPlugin = require('@cpp.js/plugin-metro/metro-plugin.cjs');
/** @type {import('expo/metro-config').MetroConfig} */
const config = getDefaultConfig(__dirname);
+const newConfig = {
+ ...CppjsMetroPlugin(config),
+};
-module.exports = config;
+module.exports = mergeConfig(config, newConfig);
Cpp.js requires a configuration file to work. For a minimal setup, create a cppjs.config.mjs
file and add the following content.
export default {
paths: {
config: import.meta.url,
},
};
Move your C++ code to the src/native directory. For example;
#pragma once
#include <string>
class MySampleClass {
public:
static std::string sample() {
return "Hello World!";
}
};
Modify the React file to call the c++ function from your React page. For example;
+import { useState, useEffect } from 'react';
+import { initCppJs, MySampleClass } from '../../src/native/MySampleClass.h';
export default function HomeScreen() {
+ const [message, setMessage] = useState('compiling ...');
+ useEffect(() => {
+ initCppJs().then(() => {
+ setMessage(MySampleClass.sample());
+ });
+ }, []);
return (
<ThemedView style={styles.titleContainer}>
- <ThemedText type="title">Welcome!</ThemedText>
+ <ThemedText type="title">Response from c++ : {message}</ThemedText>
<HelloWave />
</ThemedView>
);
}
The project is now fully set up and ready to run.
Before proceeding, ensure that you have met all the prerequisites for setting up a working development environment.
Run on iOS
You can run the app on iOS using the following command:
- npm
- Yarn
- pnpm
- bun
npm run ios
yarn ios
pnpm run ios
bun run ios
Run on Android
You can run the app on Android using the following command:
- npm
- Yarn
- pnpm
- bun
npm run android
yarn android
pnpm run android
bun run android
Sample Source Code: You can access the sample source code from this link.