Skip to content

Run .NET and Node.js code in-process on Windows, MacOS, and Linux

License

Notifications You must be signed in to change notification settings

stefy/electron-edge-js

 
 

Repository files navigation

.NET and Node.js in-process on Electron

This is a fork of edge-js adapted to support Electron.

Compatible with

  • Electron 12.x - Node.js v14.16.0
  • Electron 13.x - Node.js v14.16.0
  • Electron 14.x - Node.js v14.17.0
  • Electron 15.x - Node.js v16.5.0
  • Electron 16.x - Node.js v16.9.1
  • Electron 17.x - Node.js v16.13.0
  • Electron 18.x - Node.js v16.13.2
  • Electron 19.x - Node.js v16.14.2
  • Electron 20.x - Node.js v16.15.0
  • Electron 21.x - Node.js v16.16.0
  • Electron 22.x - Node.js v16.17.1

Usage is the same as edge or edge-js, replace require('edge-js') with require('electron-edge-js'):

npm install electron-edge-js
-var edge = require('edge-js');
+var edge = require('electron-edge-js');

var helloWorld = edge.func(function () {/*
    async (input) => {
        return ".NET Welcomes " + input.ToString();
    }
*/});

Requirements (Windows)

You must install Microsoft Visual C++ Redistributable (x86)

Why use electron-edge-js?

Electron is built using specific version of Node.js. In order to use edge in Electron project you would need to recompile it using the same Node.js version and Electron headers.

electron-edge-js comes precompiled with correct Node.js versions and headers.

Quick start

Simple app that shows how to work with .NET Core using compiled C# libraries.
https://github.com/agracio/electron-edge-js-quick-start

MacOS

edge-js and electron-edge-js will fail to build on MacOS if Visual Studion for mac is installed. VS installs Mono runtimes that edge-js fails to access durring nmp install.

Packaging Electron application

Packaging example based on the app above.
https://github.com/zenb/electron-edge-js-quick-start

Related issues to use for troubleshooting:
agracio#39
agracio#74
agracio#21

Async execution

Underlying 'edge' component is written as synchronous C++ Node.js module and will cause Electron app to freeze when executing long running .NET code.
For workaround refer to this issue: agracio#97

Documentation

For full documentation please see see original edge-js repo.

Build

Build.bat supports only Electron major versions.

About

Run .NET and Node.js code in-process on Windows, MacOS, and Linux

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 85.6%
  • C# 10.1%
  • JavaScript 2.0%
  • Python 1.3%
  • C 0.6%
  • Batchfile 0.3%
  • VBScript 0.1%