Skip to content

Commit

Permalink
fixup! Initial C++ engine and Typescript web package
Browse files Browse the repository at this point in the history
  • Loading branch information
juztamau5 committed Mar 12, 2024
1 parent bd8685c commit facad36
Show file tree
Hide file tree
Showing 12 changed files with 78 additions and 58 deletions.
24 changes: 12 additions & 12 deletions .github/workflows/nodejs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,18 @@ jobs:
src/frontend/public/wasm
key: cache-wasm-${{ matrix.os }}-${{ matrix.node-version }}-${{ hashFiles('src/engine/**', 'tools/build-wasm.sh', 'tools/download-emscripten.sh') }}

- name: Install emsdk
if: steps.cache-emsdk.outputs.cache-hit != 'true'
run: |
./download-emscripten.sh
working-directory: tools

- name: Build wasm libraries
if: steps.cache-wasm.outputs.cache-hit != 'true'
run: |
./build-wasm.sh
working-directory: tools

- name: Setup Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v4
with:
Expand Down Expand Up @@ -94,15 +106,3 @@ jobs:
if: steps.cache-vite.outputs.cache-hit != 'true'
run: |
pnpm build
- name: Install emsdk
if: steps.cache-emsdk.outputs.cache-hit != 'true'
run: |
./download-emscripten.sh
working-directory: tools

- name: Build wasm libraries
if: steps.cache-wasm.outputs.cache-hit != 'true'
run: |
./build-wasm.sh
working-directory: tools
2 changes: 2 additions & 0 deletions src/engine/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ if (${CMAKE_SYSTEM_NAME} MATCHES "Emscripten")
-s USE_WEBGL2=1 \
-s WASM=1 \
--bind \
--embind-emit-tsd retro_engine.d.ts \
--source-map-base https://retro.ai/ \
"
)
Expand All @@ -68,6 +69,7 @@ endif ()

INSTALL(
FILES
"${CMAKE_BINARY_DIR}/retro_engine.d.ts"
"${CMAKE_BINARY_DIR}/retro_engine.js"
"${CMAKE_BINARY_DIR}/retro_engine.wasm"
"${CMAKE_BINARY_DIR}/retro_engine.wasm.map"
Expand Down
2 changes: 1 addition & 1 deletion src/engine/core/retro_engine.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@

namespace
{
constexpr const char* CANVAS_ID = "retroengine";
constexpr const char* CANVAS_ID = "retroEngine";
}

RetroEngine::RetroEngine() : m_webGLContext(0)
Expand Down
3 changes: 2 additions & 1 deletion src/frontend/.eslintignore
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,6 @@
/node_modules
/pnpm-lock.yaml

# Generated WASM libraries
# Generated WASM files
/public/wasm
/src/wasm
3 changes: 2 additions & 1 deletion src/frontend/.gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,6 @@
/node_modules
/yarn-*.log*

# Generated WASM libraries
# Generated WASM files
/public/wasm
/src/wasm
3 changes: 2 additions & 1 deletion src/frontend/.prettierignore
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,6 @@
/node_modules
/pnpm-lock.yaml

# Generated WASM libraries
# Generated WASM files
/public/wasm
/src/wasm
8 changes: 0 additions & 8 deletions src/frontend/retro_engine.d.ts

This file was deleted.

51 changes: 38 additions & 13 deletions src/frontend/src/components/HomePage.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
/// <reference types="../types/retro_engine" />
/*
* Copyright (C) 2023-2024 retro.ai
* This file is part of retro3 - https://github.com/retroai/retro3
Expand All @@ -10,7 +9,18 @@
import "./HomePage.css";

import React, { useEffect, useRef } from "react";
import loadWasmModule, { WasmModule } from "retro_engine";

import RetroEngineModule, {
MainModule,
RetroEngine,
} from "../wasm/retro_engine.js";

// Allow the TypeScript compiler to recognize the module parameters
declare module "../wasm/retro_engine.js" {
export default function RetroEngineModule(moduleArg?: {
locateFile?: (path: string) => string;
}): Promise<MainModule>;
}

const HomePage: React.FC = () => {
// Reference to the canvas element
Expand All @@ -32,28 +42,43 @@ const HomePage: React.FC = () => {
// Ensure canvas size adjusts on window resize
window.addEventListener("resize", updateCanvasSize);

const initWasm: () => Promise<void> = async () => {
try {
// Dynamically import the wasm module
const wasmModule: WasmModule = await loadWasmModule();
let engineInstance: RetroEngine | null = null;

async function initializeAndUseRetroEngine(): Promise<void> {
// Provide the locateFile function when initializing your WASM module
const moduleOverrides = {
locateFile: (file: string) => `/wasm/${file}`,
};

// Await the promise to resolve to the module instance
const wasmModule: MainModule = await RetroEngineModule(moduleOverrides);

// TODO: Move to app logic
wasmModule.initialize();
} catch (error: unknown) {
console.error("Failed to load WASM module:", error);
// Instantiate RetroEngine
engineInstance = new wasmModule.RetroEngine();

// Initialize RetroEngine
const initialized: boolean = engineInstance.initialize();
if (initialized) {
console.log("RetroEngine initialized successfully");
} else {
console.error("Failed to initialize RetroEngine");
}
};
}

initWasm();
// Call the function to initialize and use the RetroEngine
initializeAndUseRetroEngine().catch(console.error);

return (): void => {
// Cleanup on component unmount
window.removeEventListener("resize", updateCanvasSize);

// Deinitialize engine if it has been initialized
engineInstance?.deinitialize();
};
}, []);

// Render the canvas element
return <canvas ref={canvasRef} id="retroengine" />;
return <canvas ref={canvasRef} id="retroEngine" />;
};

export default HomePage;
8 changes: 0 additions & 8 deletions src/frontend/src/types/retro_engine.d.ts

This file was deleted.

4 changes: 2 additions & 2 deletions src/frontend/tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,10 @@
"outDir": "./dist",
"resolveJsonModule": true,
"rootDir": "./src",
"skipLibCheck": true,
"skipLibCheck": false,
"strict": true,
"target": "ES2022",
"types": ["node", "vite/client"]
},
"include": ["src"]
"include": ["src/**/*"]
}
5 changes: 0 additions & 5 deletions src/frontend/vite.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,4 @@ export default defineConfig({
react(),
// Other plugins
],
resolve: {
alias: {
retro_engine: "./public/wasm/retro_engine.js",
},
},
});
23 changes: 17 additions & 6 deletions tools/build-wasm.sh
Original file line number Diff line number Diff line change
Expand Up @@ -39,12 +39,20 @@ BUILD_DIRECTORY="${TOOL_DIRECTORY}/build"
# Directory of the Emscripten SDK
EMSDK_DIRECTORY="${TOOL_DIRECTORY}/emsdk"

# Directory to place the generated libraries
INSTALL_DIRECTORY="${TOOL_DIRECTORY}/install"
# Directory to place the build output
OUTPUT_DIRECTORY="${TOOL_DIRECTORY}/install"

# Directory to install the generated WASM binary
WASM_DIRECTORY="${PROJECT_DIRECTORY}/src/frontend/public/wasm"

# Directory to install the generated JS loader
LOADER_DIRECTORY="${PROJECT_DIRECTORY}/src/frontend/src/wasm"

# Ensure directories exist
mkdir -p "${BUILD_DIRECTORY}"
mkdir -p "${INSTALL_DIRECTORY}"
mkdir -p "${OUTPUT_DIRECTORY}"
mkdir -p "${WASM_DIRECTORY}"
mkdir -p "${LOADER_DIRECTORY}"

################################################################################
# Setup environment
Expand All @@ -60,12 +68,15 @@ cd "${BUILD_DIRECTORY}"

emcmake cmake \
"${ENGINE_DIRECTORY}" \
-DCMAKE_INSTALL_PREFIX="${INSTALL_DIRECTORY}" \
-DCMAKE_INSTALL_PREFIX="${OUTPUT_DIRECTORY}" \
$(! command -v ccache &> /dev/null || echo "-DCMAKE_CXX_COMPILER_LAUNCHER=ccache")

cmake \
--build "${BUILD_DIRECTORY}" \
--target install

# Copy the generated libraries to the public directory
cp -rv "${INSTALL_DIRECTORY}/wasm" "${PROJECT_DIRECTORY}/src/frontend/public"
# Copy the generated WASM files to the public directory
cp -rv "${OUTPUT_DIRECTORY}/wasm"/*.wasm* "${WASM_DIRECTORY}"

# Copy the generated loader to the frontend directory
cp -v "${OUTPUT_DIRECTORY}/wasm"/*.[jt]s "${LOADER_DIRECTORY}"

0 comments on commit facad36

Please sign in to comment.