-
Notifications
You must be signed in to change notification settings - Fork 58
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
21 changed files
with
1,264 additions
and
315 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
// Copyright (c) Microsoft Corporation. | ||
// Licensed under the MIT License. | ||
|
||
using System; | ||
using System.Threading; | ||
using Microsoft.JavaScript.NodeApi.Interop; | ||
|
||
namespace Microsoft.JavaScript.NodeApi; | ||
|
||
/// <summary> | ||
/// An exception that was caused by an attempt to access a JavaScript value without any | ||
/// <see cref="JSValueScope" /> established on the current thread, or from a thread associated | ||
/// with a different environment / root scope. | ||
/// </summary> | ||
/// <remarks> | ||
/// All JavaScript values are created within a scope that is bound to the thread that runs the | ||
/// JS environment. They can only be accessed from the same thread and only as long as the scope | ||
/// is still valid (not disposed). | ||
/// </remarks> | ||
/// <seealso cref="JSSynchronizationContext"/> | ||
public class JSInvalidScopeException : InvalidOperationException | ||
{ | ||
/// <summary> | ||
/// Creates a new instance of <see cref="JSInvalidScopeException" /> with a | ||
/// current scope and message. | ||
/// </summary> | ||
public JSInvalidScopeException( | ||
JSValueScope? currentScope, | ||
string? message = null) | ||
: this(currentScope, targetScope: null, message) | ||
{ | ||
} | ||
|
||
/// <summary> | ||
/// Creates a new instance of <see cref="JSInvalidScopeException" /> with current | ||
/// and target scopes and a message. | ||
/// </summary> | ||
public JSInvalidScopeException( | ||
JSValueScope? currentScope, | ||
JSValueScope? targetScope, | ||
string? message = null) | ||
: base(message ?? GetMessage(currentScope, targetScope)) | ||
{ | ||
CurrentScope = currentScope; | ||
TargetScope = targetScope; | ||
} | ||
|
||
/// <summary> | ||
/// Gets the scope associated with the current thread (<see cref="JSValueScope.Current" />) | ||
/// when the exception was thrown, or null if there was no scope for the thread. | ||
/// </summary> | ||
public JSValueScope? CurrentScope { get; internal set; } | ||
|
||
/// <summary> | ||
/// Gets the scope of the value (<see cref="JSValue.Scope" />) that was being accessed when | ||
/// the exception was thrown, or null if a static operation was attempted. | ||
/// </summary> | ||
public JSValueScope? TargetScope { get; internal set; } | ||
|
||
private static string GetMessage(JSValueScope? currentScope, JSValueScope? targetScope) | ||
{ | ||
int threadId = Environment.CurrentManagedThreadId; | ||
string? threadName = Thread.CurrentThread.Name; | ||
string threadDescription = string.IsNullOrEmpty(threadName) ? | ||
$"#{threadId}" : $"#{threadId} \"{threadName}\""; | ||
|
||
if (targetScope == null) | ||
{ | ||
// If the target scope is null, then this was an attempt to access either a static | ||
// operation or a JS reference (which has an environment but no scope). | ||
if (currentScope != null) | ||
{ | ||
// In that case if the current scope is NOT null this exception | ||
// shouldn't be thrown. | ||
throw new ArgumentException("Current scope must be null if target scope is null."); | ||
} | ||
|
||
return $"There is no active JS value scope.\nCurrent thread: {threadDescription}. " + | ||
$"Consider using {nameof(JSSynchronizationContext)} to switch to the JS thread."; | ||
} | ||
|
||
return "The JS value scope cannot be accessed from the current thread.\n" + | ||
$"The scope of type {targetScope.ScopeType} was created on thread" + | ||
$"#{targetScope.ThreadId} and is being accessed from {threadDescription}. " + | ||
$"Consider using {nameof(JSSynchronizationContext)} to switch to the JS thread."; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.