From b3691018a3c3a2c40f0904289c3a0a689c3e0df5 Mon Sep 17 00:00:00 2001 From: "N. Samardzic" Date: Thu, 7 Mar 2024 14:03:50 +0100 Subject: [PATCH] use high-level library loading --- src/NodeApi/Runtime/NodejsPlatform.cs | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) diff --git a/src/NodeApi/Runtime/NodejsPlatform.cs b/src/NodeApi/Runtime/NodejsPlatform.cs index 2c2e9d31..2b4d3fdc 100644 --- a/src/NodeApi/Runtime/NodejsPlatform.cs +++ b/src/NodeApi/Runtime/NodejsPlatform.cs @@ -2,6 +2,7 @@ // Licensed under the MIT License. using System; +using System.Reflection; using System.Runtime.InteropServices; namespace Microsoft.JavaScript.NodeApi.Runtime; @@ -25,25 +26,29 @@ public sealed class NodejsPlatform : IDisposable /// /// Initializes the Node.js platform. /// - /// Path to the `libnode` shared library, including extension. + /// Name of the `libnode` shared library. /// Optional application arguments. /// Optional platform options. /// A Node.js platform instance has already been /// loaded in the current process. public NodejsPlatform( - string libnodePath, + string libnode, string[]? args = null, string[]? execArgs = null) { - if (string.IsNullOrEmpty(libnodePath)) throw new ArgumentNullException(nameof(libnodePath)); - if (Current != null) { throw new InvalidOperationException( "Only one Node.js platform instance per process is allowed."); } - nint libnodeHandle = NativeLibrary.Load(libnodePath); + var entryAssembly = Assembly.GetEntryAssembly(); + + nint libnodeHandle = + entryAssembly == null + ? NativeLibrary.Load(libnode, entryAssembly, null) + : NativeLibrary.Load(libnode); + Runtime = new NodejsRuntime(libnodeHandle); Runtime.CreatePlatform(args, execArgs, (error) => Console.WriteLine(error), out _platform)